Compare commits
No commits in common. "main" and "master" have entirely different histories.
414
.gitignore
vendored
@ -1,400 +1,24 @@
|
|||||||
# ---> VisualStudio
|
# Logs
|
||||||
## Ignore Visual Studio temporary files, build results, and
|
logs
|
||||||
## files generated by popular Visual Studio add-ons.
|
|
||||||
##
|
|
||||||
## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore
|
|
||||||
|
|
||||||
# User-specific files
|
|
||||||
*.rsuser
|
|
||||||
*.suo
|
|
||||||
*.user
|
|
||||||
*.userosscache
|
|
||||||
*.sln.docstates
|
|
||||||
|
|
||||||
# User-specific files (MonoDevelop/Xamarin Studio)
|
|
||||||
*.userprefs
|
|
||||||
|
|
||||||
# Mono auto generated files
|
|
||||||
mono_crash.*
|
|
||||||
|
|
||||||
# Build results
|
|
||||||
[Dd]ebug/
|
|
||||||
[Dd]ebugPublic/
|
|
||||||
[Rr]elease/
|
|
||||||
[Rr]eleases/
|
|
||||||
x64/
|
|
||||||
x86/
|
|
||||||
[Ww][Ii][Nn]32/
|
|
||||||
[Aa][Rr][Mm]/
|
|
||||||
[Aa][Rr][Mm]64/
|
|
||||||
bld/
|
|
||||||
[Bb]in/
|
|
||||||
[Oo]bj/
|
|
||||||
[Ll]og/
|
|
||||||
[Ll]ogs/
|
|
||||||
|
|
||||||
# Visual Studio 2015/2017 cache/options directory
|
|
||||||
.vs/
|
|
||||||
# Uncomment if you have tasks that create the project's static files in wwwroot
|
|
||||||
#wwwroot/
|
|
||||||
|
|
||||||
# Visual Studio 2017 auto generated files
|
|
||||||
Generated\ Files/
|
|
||||||
|
|
||||||
# MSTest test Results
|
|
||||||
[Tt]est[Rr]esult*/
|
|
||||||
[Bb]uild[Ll]og.*
|
|
||||||
|
|
||||||
# NUnit
|
|
||||||
*.VisualState.xml
|
|
||||||
TestResult.xml
|
|
||||||
nunit-*.xml
|
|
||||||
|
|
||||||
# Build Results of an ATL Project
|
|
||||||
[Dd]ebugPS/
|
|
||||||
[Rr]eleasePS/
|
|
||||||
dlldata.c
|
|
||||||
|
|
||||||
# Benchmark Results
|
|
||||||
BenchmarkDotNet.Artifacts/
|
|
||||||
|
|
||||||
# .NET Core
|
|
||||||
project.lock.json
|
|
||||||
project.fragment.lock.json
|
|
||||||
artifacts/
|
|
||||||
|
|
||||||
# ASP.NET Scaffolding
|
|
||||||
ScaffoldingReadMe.txt
|
|
||||||
|
|
||||||
# StyleCop
|
|
||||||
StyleCopReport.xml
|
|
||||||
|
|
||||||
# Files built by Visual Studio
|
|
||||||
*_i.c
|
|
||||||
*_p.c
|
|
||||||
*_h.h
|
|
||||||
*.ilk
|
|
||||||
*.meta
|
|
||||||
*.obj
|
|
||||||
*.iobj
|
|
||||||
*.pch
|
|
||||||
*.pdb
|
|
||||||
*.ipdb
|
|
||||||
*.pgc
|
|
||||||
*.pgd
|
|
||||||
*.rsp
|
|
||||||
*.sbr
|
|
||||||
*.tlb
|
|
||||||
*.tli
|
|
||||||
*.tlh
|
|
||||||
*.tmp
|
|
||||||
*.tmp_proj
|
|
||||||
*_wpftmp.csproj
|
|
||||||
*.log
|
*.log
|
||||||
*.tlog
|
npm-debug.log*
|
||||||
*.vspscc
|
yarn-debug.log*
|
||||||
*.vssscc
|
yarn-error.log*
|
||||||
.builds
|
pnpm-debug.log*
|
||||||
*.pidb
|
lerna-debug.log*
|
||||||
*.svclog
|
|
||||||
*.scc
|
|
||||||
|
|
||||||
# Chutzpah Test files
|
node_modules
|
||||||
_Chutzpah*
|
dist
|
||||||
|
dist-ssr
|
||||||
|
*.local
|
||||||
|
|
||||||
# Visual C++ cache files
|
# Editor directories and files
|
||||||
ipch/
|
|
||||||
*.aps
|
|
||||||
*.ncb
|
|
||||||
*.opendb
|
|
||||||
*.opensdf
|
|
||||||
*.sdf
|
|
||||||
*.cachefile
|
|
||||||
*.VC.db
|
|
||||||
*.VC.VC.opendb
|
|
||||||
|
|
||||||
# Visual Studio profiler
|
|
||||||
*.psess
|
|
||||||
*.vsp
|
|
||||||
*.vspx
|
|
||||||
*.sap
|
|
||||||
|
|
||||||
# Visual Studio Trace Files
|
|
||||||
*.e2e
|
|
||||||
|
|
||||||
# TFS 2012 Local Workspace
|
|
||||||
$tf/
|
|
||||||
|
|
||||||
# Guidance Automation Toolkit
|
|
||||||
*.gpState
|
|
||||||
|
|
||||||
# ReSharper is a .NET coding add-in
|
|
||||||
_ReSharper*/
|
|
||||||
*.[Rr]e[Ss]harper
|
|
||||||
*.DotSettings.user
|
|
||||||
|
|
||||||
# TeamCity is a build add-in
|
|
||||||
_TeamCity*
|
|
||||||
|
|
||||||
# DotCover is a Code Coverage Tool
|
|
||||||
*.dotCover
|
|
||||||
|
|
||||||
# AxoCover is a Code Coverage Tool
|
|
||||||
.axoCover/*
|
|
||||||
!.axoCover/settings.json
|
|
||||||
|
|
||||||
# Coverlet is a free, cross platform Code Coverage Tool
|
|
||||||
coverage*.json
|
|
||||||
coverage*.xml
|
|
||||||
coverage*.info
|
|
||||||
|
|
||||||
# Visual Studio code coverage results
|
|
||||||
*.coverage
|
|
||||||
*.coveragexml
|
|
||||||
|
|
||||||
# NCrunch
|
|
||||||
_NCrunch_*
|
|
||||||
.*crunch*.local.xml
|
|
||||||
nCrunchTemp_*
|
|
||||||
|
|
||||||
# MightyMoose
|
|
||||||
*.mm.*
|
|
||||||
AutoTest.Net/
|
|
||||||
|
|
||||||
# Web workbench (sass)
|
|
||||||
.sass-cache/
|
|
||||||
|
|
||||||
# Installshield output folder
|
|
||||||
[Ee]xpress/
|
|
||||||
|
|
||||||
# DocProject is a documentation generator add-in
|
|
||||||
DocProject/buildhelp/
|
|
||||||
DocProject/Help/*.HxT
|
|
||||||
DocProject/Help/*.HxC
|
|
||||||
DocProject/Help/*.hhc
|
|
||||||
DocProject/Help/*.hhk
|
|
||||||
DocProject/Help/*.hhp
|
|
||||||
DocProject/Help/Html2
|
|
||||||
DocProject/Help/html
|
|
||||||
|
|
||||||
# Click-Once directory
|
|
||||||
publish/
|
|
||||||
|
|
||||||
# Publish Web Output
|
|
||||||
*.[Pp]ublish.xml
|
|
||||||
*.azurePubxml
|
|
||||||
# Note: Comment the next line if you want to checkin your web deploy settings,
|
|
||||||
# but database connection strings (with potential passwords) will be unencrypted
|
|
||||||
*.pubxml
|
|
||||||
*.publishproj
|
|
||||||
|
|
||||||
# Microsoft Azure Web App publish settings. Comment the next line if you want to
|
|
||||||
# checkin your Azure Web App publish settings, but sensitive information contained
|
|
||||||
# in these scripts will be unencrypted
|
|
||||||
PublishScripts/
|
|
||||||
|
|
||||||
# NuGet Packages
|
|
||||||
*.nupkg
|
|
||||||
# NuGet Symbol Packages
|
|
||||||
*.snupkg
|
|
||||||
# The packages folder can be ignored because of Package Restore
|
|
||||||
**/[Pp]ackages/*
|
|
||||||
# except build/, which is used as an MSBuild target.
|
|
||||||
!**/[Pp]ackages/build/
|
|
||||||
# Uncomment if necessary however generally it will be regenerated when needed
|
|
||||||
#!**/[Pp]ackages/repositories.config
|
|
||||||
# NuGet v3's project.json files produces more ignorable files
|
|
||||||
*.nuget.props
|
|
||||||
*.nuget.targets
|
|
||||||
|
|
||||||
# Microsoft Azure Build Output
|
|
||||||
csx/
|
|
||||||
*.build.csdef
|
|
||||||
|
|
||||||
# Microsoft Azure Emulator
|
|
||||||
ecf/
|
|
||||||
rcf/
|
|
||||||
|
|
||||||
# Windows Store app package directories and files
|
|
||||||
AppPackages/
|
|
||||||
BundleArtifacts/
|
|
||||||
Package.StoreAssociation.xml
|
|
||||||
_pkginfo.txt
|
|
||||||
*.appx
|
|
||||||
*.appxbundle
|
|
||||||
*.appxupload
|
|
||||||
|
|
||||||
# Visual Studio cache files
|
|
||||||
# files ending in .cache can be ignored
|
|
||||||
*.[Cc]ache
|
|
||||||
# but keep track of directories ending in .cache
|
|
||||||
!?*.[Cc]ache/
|
|
||||||
|
|
||||||
# Others
|
|
||||||
ClientBin/
|
|
||||||
~$*
|
|
||||||
*~
|
|
||||||
*.dbmdl
|
|
||||||
*.dbproj.schemaview
|
|
||||||
*.jfm
|
|
||||||
*.pfx
|
|
||||||
*.publishsettings
|
|
||||||
orleans.codegen.cs
|
|
||||||
|
|
||||||
# Including strong name files can present a security risk
|
|
||||||
# (https://github.com/github/gitignore/pull/2483#issue-259490424)
|
|
||||||
#*.snk
|
|
||||||
|
|
||||||
# Since there are multiple workflows, uncomment next line to ignore bower_components
|
|
||||||
# (https://github.com/github/gitignore/pull/1529#issuecomment-104372622)
|
|
||||||
#bower_components/
|
|
||||||
|
|
||||||
# RIA/Silverlight projects
|
|
||||||
Generated_Code/
|
|
||||||
|
|
||||||
# Backup & report files from converting an old project file
|
|
||||||
# to a newer Visual Studio version. Backup files are not needed,
|
|
||||||
# because we have git ;-)
|
|
||||||
_UpgradeReport_Files/
|
|
||||||
Backup*/
|
|
||||||
UpgradeLog*.XML
|
|
||||||
UpgradeLog*.htm
|
|
||||||
ServiceFabricBackup/
|
|
||||||
*.rptproj.bak
|
|
||||||
|
|
||||||
# SQL Server files
|
|
||||||
*.mdf
|
|
||||||
*.ldf
|
|
||||||
*.ndf
|
|
||||||
|
|
||||||
# Business Intelligence projects
|
|
||||||
*.rdl.data
|
|
||||||
*.bim.layout
|
|
||||||
*.bim_*.settings
|
|
||||||
*.rptproj.rsuser
|
|
||||||
*- [Bb]ackup.rdl
|
|
||||||
*- [Bb]ackup ([0-9]).rdl
|
|
||||||
*- [Bb]ackup ([0-9][0-9]).rdl
|
|
||||||
|
|
||||||
# Microsoft Fakes
|
|
||||||
FakesAssemblies/
|
|
||||||
|
|
||||||
# GhostDoc plugin setting file
|
|
||||||
*.GhostDoc.xml
|
|
||||||
|
|
||||||
# Node.js Tools for Visual Studio
|
|
||||||
.ntvs_analysis.dat
|
|
||||||
node_modules/
|
|
||||||
|
|
||||||
# Visual Studio 6 build log
|
|
||||||
*.plg
|
|
||||||
|
|
||||||
# Visual Studio 6 workspace options file
|
|
||||||
*.opt
|
|
||||||
|
|
||||||
# Visual Studio 6 auto-generated workspace file (contains which files were open etc.)
|
|
||||||
*.vbw
|
|
||||||
|
|
||||||
# Visual Studio 6 auto-generated project file (contains which files were open etc.)
|
|
||||||
*.vbp
|
|
||||||
|
|
||||||
# Visual Studio 6 workspace and project file (working project files containing files to include in project)
|
|
||||||
*.dsw
|
|
||||||
*.dsp
|
|
||||||
|
|
||||||
# Visual Studio 6 technical files
|
|
||||||
*.ncb
|
|
||||||
*.aps
|
|
||||||
|
|
||||||
# Visual Studio LightSwitch build output
|
|
||||||
**/*.HTMLClient/GeneratedArtifacts
|
|
||||||
**/*.DesktopClient/GeneratedArtifacts
|
|
||||||
**/*.DesktopClient/ModelManifest.xml
|
|
||||||
**/*.Server/GeneratedArtifacts
|
|
||||||
**/*.Server/ModelManifest.xml
|
|
||||||
_Pvt_Extensions
|
|
||||||
|
|
||||||
# Paket dependency manager
|
|
||||||
.paket/paket.exe
|
|
||||||
paket-files/
|
|
||||||
|
|
||||||
# FAKE - F# Make
|
|
||||||
.fake/
|
|
||||||
|
|
||||||
# CodeRush personal settings
|
|
||||||
.cr/personal
|
|
||||||
|
|
||||||
# Python Tools for Visual Studio (PTVS)
|
|
||||||
__pycache__/
|
|
||||||
*.pyc
|
|
||||||
|
|
||||||
# Cake - Uncomment if you are using it
|
|
||||||
# tools/**
|
|
||||||
# !tools/packages.config
|
|
||||||
|
|
||||||
# Tabs Studio
|
|
||||||
*.tss
|
|
||||||
|
|
||||||
# Telerik's JustMock configuration file
|
|
||||||
*.jmconfig
|
|
||||||
|
|
||||||
# BizTalk build output
|
|
||||||
*.btp.cs
|
|
||||||
*.btm.cs
|
|
||||||
*.odx.cs
|
|
||||||
*.xsd.cs
|
|
||||||
|
|
||||||
# OpenCover UI analysis results
|
|
||||||
OpenCover/
|
|
||||||
|
|
||||||
# Azure Stream Analytics local run output
|
|
||||||
ASALocalRun/
|
|
||||||
|
|
||||||
# MSBuild Binary and Structured Log
|
|
||||||
*.binlog
|
|
||||||
|
|
||||||
# NVidia Nsight GPU debugger configuration file
|
|
||||||
*.nvuser
|
|
||||||
|
|
||||||
# MFractors (Xamarin productivity tool) working folder
|
|
||||||
.mfractor/
|
|
||||||
|
|
||||||
# Local History for Visual Studio
|
|
||||||
.localhistory/
|
|
||||||
|
|
||||||
# Visual Studio History (VSHistory) files
|
|
||||||
.vshistory/
|
|
||||||
|
|
||||||
# BeatPulse healthcheck temp database
|
|
||||||
healthchecksdb
|
|
||||||
|
|
||||||
# Backup folder for Package Reference Convert tool in Visual Studio 2017
|
|
||||||
MigrationBackup/
|
|
||||||
|
|
||||||
# Ionide (cross platform F# VS Code tools) working folder
|
|
||||||
.ionide/
|
|
||||||
|
|
||||||
# Fody - auto-generated XML schema
|
|
||||||
FodyWeavers.xsd
|
|
||||||
|
|
||||||
# VS Code files for those working on multiple tools
|
|
||||||
.vscode/*
|
.vscode/*
|
||||||
!.vscode/settings.json
|
|
||||||
!.vscode/tasks.json
|
|
||||||
!.vscode/launch.json
|
|
||||||
!.vscode/extensions.json
|
!.vscode/extensions.json
|
||||||
*.code-workspace
|
.idea
|
||||||
|
.DS_Store
|
||||||
# Local History for Visual Studio Code
|
*.suo
|
||||||
.history/
|
*.ntvs*
|
||||||
|
*.njsproj
|
||||||
# Windows Installer files from build outputs
|
*.sln
|
||||||
*.cab
|
*.sw?
|
||||||
*.msi
|
|
||||||
*.msix
|
|
||||||
*.msm
|
|
||||||
*.msp
|
|
||||||
|
|
||||||
# JetBrains Rider
|
|
||||||
*.sln.iml
|
|
||||||
|
|
||||||
|
6
.vs/VSWorkspaceState.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"ExpandedNodes": [
|
||||||
|
""
|
||||||
|
],
|
||||||
|
"PreviewInSolutionExplorer": false
|
||||||
|
}
|
BIN
.vs/slnx.sqlite
Normal file
0
.vs/vite-project/FileContentIndex/read.lock
Normal file
220
Admin.html
Normal file
@ -0,0 +1,220 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Admin.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="index.html">Выйти из личного кабинета</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="pagePage.html">Таблица</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<div class="text-center">
|
||||||
|
<div class="image-container">
|
||||||
|
<img id="image-preview" src="https://via.placeholder.com/200" class="image-preview"
|
||||||
|
alt="placeholder">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<form id="items-form" class="needs-validation" novalidate>
|
||||||
|
<h3 class="title-h3">Введите название фильма</h3>
|
||||||
|
<div class="mb-2 form-section">
|
||||||
|
<label class="form-label text-field-label" for="filmName">Название фильма</label>
|
||||||
|
<input id="filmName" name="filmName" class="form-control" type="text" required>
|
||||||
|
</div>
|
||||||
|
<h3 class="title-h3">Выберите жанр</h3>
|
||||||
|
<div class="mb-2 form-section">
|
||||||
|
<label for="item" class="form-label text-field-label">Жанр</label>
|
||||||
|
<select id="item" class="form-select" name="selected" required>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<h3 class="title-h3">Введите цену</h3>
|
||||||
|
<div class="mb-2 form-section">
|
||||||
|
<label class="form-label text-field-label" for="price">Цена</label>
|
||||||
|
<input id="price" name="price" class="form-control" type="number" value="0.00" min="100.00" step="10"
|
||||||
|
required>
|
||||||
|
</div>
|
||||||
|
<h3 class="title-h3">Введите размер скидки</h3>
|
||||||
|
<div class="mb-2 form-section">
|
||||||
|
<label class="form-label text-field-label" for="discount">Скидка</label>
|
||||||
|
<input id="discount" name="discount" class="form-control" type="number" value="0" min="0" max="99" step="1" required>
|
||||||
|
</div>
|
||||||
|
<h3 class="title-h3">Загрузите изображение</h3>
|
||||||
|
<div class="mb-2 form-section">
|
||||||
|
<label class="form-label text-field-label" for="image">Изображение</label>
|
||||||
|
<input id="image" type="file" name="image" class="form-control" accept="image/*">
|
||||||
|
</div>
|
||||||
|
<a href="/pagePage.html" class="btn submit-button">Назад</a>
|
||||||
|
<button type="submit" class="btn submit-button">Сохранить</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
<script type="module">
|
||||||
|
import validation from "./js/validation";
|
||||||
|
import { linesPageForm } from "./js/lines"
|
||||||
|
|
||||||
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
|
validation();
|
||||||
|
linesPageForm();
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</body>
|
||||||
|
</html>
|
253
Cabinet.html
Normal file
@ -0,0 +1,253 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Cabinet.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="index.html">Выйти из личного кабинета</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<section class="col-sm-12 col-lg-9 user-data-box">
|
||||||
|
<h2 class="title-h2">
|
||||||
|
Личный кабинет
|
||||||
|
</h2>
|
||||||
|
<ul class="overview-list">
|
||||||
|
<li class="overview-item">
|
||||||
|
Пол: Мужской
|
||||||
|
</li>
|
||||||
|
<li class="overview-item">
|
||||||
|
Год рождения: 1999
|
||||||
|
</li>
|
||||||
|
<li class="overview-item">
|
||||||
|
Телефон: +999-999-99-99
|
||||||
|
</li>
|
||||||
|
<li class="overview-item">
|
||||||
|
Почта: pochta@gmail.com
|
||||||
|
</li>
|
||||||
|
<li class="overview-item">
|
||||||
|
Подписка: <u>премиум</u>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<button class="change-info-button">
|
||||||
|
Изменить данные
|
||||||
|
</button>
|
||||||
|
|
||||||
|
<button class="admin-button">
|
||||||
|
<a href="pagePage.html">
|
||||||
|
Открыть панель администратора
|
||||||
|
</a>
|
||||||
|
</button>
|
||||||
|
</section>
|
||||||
|
<aside class="col-md-4 col-lg-3 add-block">
|
||||||
|
<div class="user-name">
|
||||||
|
Кирилл
|
||||||
|
</div>
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/user-none.png">
|
||||||
|
</a>
|
||||||
|
<a href="#" class="add-link">Загрузить свое фото</a>
|
||||||
|
</aside>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h3 class="col-sm-12 title-h3">
|
||||||
|
Отложенный просмотр
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film1.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film2.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film3.png"></a>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
<div class="row">
|
||||||
|
<button class="col-sm-12 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h3 class="col-sm-12 title-h3">
|
||||||
|
Мои покупки
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series1.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series2.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series3.png"></a>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
<div class="row">
|
||||||
|
<button class="col-sm-12 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
BIN
Images/81point.png
Normal file
After Width: | Height: | Size: 149 KiB |
BIN
Images/Carnifecks.png
Normal file
After Width: | Height: | Size: 170 KiB |
BIN
Images/Cartoons-image.png
Normal file
After Width: | Height: | Size: 24 KiB |
BIN
Images/Comedy.png
Normal file
After Width: | Height: | Size: 14 KiB |
BIN
Images/Criminal.png
Normal file
After Width: | Height: | Size: 11 KiB |
BIN
Images/Film-image.png
Normal file
After Width: | Height: | Size: 17 KiB |
BIN
Images/Film1.png
Normal file
After Width: | Height: | Size: 111 KiB |
BIN
Images/Film2.png
Normal file
After Width: | Height: | Size: 125 KiB |
BIN
Images/Film3.png
Normal file
After Width: | Height: | Size: 118 KiB |
BIN
Images/First-mini.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
Images/First-red-mini.png
Normal file
After Width: | Height: | Size: 962 B |
BIN
Images/First.png
Normal file
After Width: | Height: | Size: 5.3 KiB |
BIN
Images/First24.png
Normal file
After Width: | Height: | Size: 962 B |
BIN
Images/Gampy.png
Normal file
After Width: | Height: | Size: 202 KiB |
BIN
Images/Juls.png
Normal file
After Width: | Height: | Size: 157 KiB |
BIN
Images/Laegue.png
Normal file
After Width: | Height: | Size: 68 KiB |
BIN
Images/League.png
Normal file
After Width: | Height: | Size: 67 KiB |
BIN
Images/Logotip-tv.png
Normal file
After Width: | Height: | Size: 20 KiB |
BIN
Images/Love12.png
Normal file
After Width: | Height: | Size: 201 KiB |
BIN
Images/Match-mini.png
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
Images/Miss.png
Normal file
After Width: | Height: | Size: 234 KiB |
BIN
Images/NBA.png
Normal file
After Width: | Height: | Size: 69 KiB |
BIN
Images/NTV-mini.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
Images/NTV.png
Normal file
After Width: | Height: | Size: 1.8 KiB |
BIN
Images/Nature.png
Normal file
After Width: | Height: | Size: 20 KiB |
BIN
Images/OK.png
Normal file
After Width: | Height: | Size: 2.1 KiB |
BIN
Images/Series-image.png
Normal file
After Width: | Height: | Size: 5.9 KiB |
BIN
Images/Series1.png
Normal file
After Width: | Height: | Size: 141 KiB |
BIN
Images/Series2.png
Normal file
After Width: | Height: | Size: 112 KiB |
BIN
Images/Series3.png
Normal file
After Width: | Height: | Size: 101 KiB |
BIN
Images/TG.png
Normal file
After Width: | Height: | Size: 2.9 KiB |
BIN
Images/TV.png
Normal file
After Width: | Height: | Size: 300 KiB |
BIN
Images/VK.png
Normal file
After Width: | Height: | Size: 2.5 KiB |
BIN
Images/Valencia.png
Normal file
After Width: | Height: | Size: 1.0 MiB |
BIN
Images/Viber.png
Normal file
After Width: | Height: | Size: 3.6 KiB |
BIN
Images/YouTube.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
Images/khl.png
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
Images/match.png
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
Images/parents.png
Normal file
After Width: | Height: | Size: 198 KiB |
BIN
Images/user-none.png
Normal file
After Width: | Height: | Size: 13 KiB |
342
Katalog.html
Normal file
@ -0,0 +1,342 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Katlog.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-5">
|
||||||
|
<a href="Cabinet.html">Войти в личный кабинет</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html"><u>Каталог</u></a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
<u>Каталог</u>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<section class="row">
|
||||||
|
<article class="col">
|
||||||
|
<div class="kind">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Фильмы
|
||||||
|
</h3>
|
||||||
|
<a href="Shop.html" class="image-container">
|
||||||
|
<img src="Images/Film-image.png">
|
||||||
|
</a>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col">
|
||||||
|
<div class="kind">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Сериалы
|
||||||
|
</h3>
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Series-image.png">
|
||||||
|
</a>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col">
|
||||||
|
<div class="kind">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Мультфильмы
|
||||||
|
</h3>
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Cartoons-image.png">
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
<button class="col-sm-10 col-md-6 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h2 class="title-h2">
|
||||||
|
Подборка
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<section class="row">
|
||||||
|
<article class="col">
|
||||||
|
<div class="category">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Комедийные сериалы
|
||||||
|
</h3>
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Comedy.png">
|
||||||
|
</a>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col">
|
||||||
|
<div class="category">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Криминальные фильмы
|
||||||
|
</h3>
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Criminal.png">
|
||||||
|
</a>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col">
|
||||||
|
<div class="category">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Натуральная красота
|
||||||
|
</h3>
|
||||||
|
<a href="#" class="image-container nature-img">
|
||||||
|
<img src="Images/Nature.png">
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
<button class="col-sm-10 col-md-6 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h4 class="title-h4">
|
||||||
|
Жанры
|
||||||
|
</h4>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<section>
|
||||||
|
<ul class="row genres">
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Комедии
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Мультфильмы
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Музыкальное
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Боевики
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Фентези
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Биографии
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Фантастика
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Семейное
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Военное
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Триллеры
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Милодраммы
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Криминал
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Приключения
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Детективы
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="col">
|
||||||
|
<li>
|
||||||
|
Драмы
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
Аниме
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</ul>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
271
Shop.html
Normal file
@ -0,0 +1,271 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Shop.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-5">
|
||||||
|
<a href="Cabinet.html">Войти в личный кабинет</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html"><u>Магазин</u></a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
<u>Магазин</u>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<h2 class="title-h2">
|
||||||
|
Рекомендации
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<section id="shopRec" class="row recomendation">
|
||||||
|
<article class="col-md-6 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/81point.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col-md-6 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Miss.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
<button class="col-sm-10 col-md-6 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h2 class="title-h2">
|
||||||
|
Рекомендации
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<section class="row recomendation">
|
||||||
|
<article class="col-sm-6 col-md-3 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Love12.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col-sm-6 col-md-3 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Gampy.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col-sm-6 col-md-3 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Juls.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col-sm-6 col-md-3 product">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Carnifecks.png">
|
||||||
|
</a>
|
||||||
|
<div class="price">
|
||||||
|
от 99 Р
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
<button class="col-sm-10 col-md-6 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
<div class="col-sm-1 col-md-3">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
<script type="module">
|
||||||
|
import validation from "./js/validation";
|
||||||
|
import { drawInShop } from "./js/lines";
|
||||||
|
|
||||||
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
|
validation();
|
||||||
|
drawInShop();
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
240
Sport.html
Normal file
@ -0,0 +1,240 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Sport.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="Cabinet.html">Войти в личный кабинет</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html"><u>Спорт</u></a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
<u>Спорт</u>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
|
||||||
|
<div class="container">
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-sm-12 event">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/Valencia.png">
|
||||||
|
</a>
|
||||||
|
<div class="data-time">
|
||||||
|
Сегодня в 23:15
|
||||||
|
</div>
|
||||||
|
<div class="add-info">
|
||||||
|
Валенсия - <br> Реал Мадрид
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section>
|
||||||
|
<ul class="row bottom-nav">
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Календарь трансляций
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Футбол
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Баскетбол
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Киберспорт
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Фигурное катание
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="bottom-nav_item">
|
||||||
|
Ещё
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</section>
|
||||||
|
<div class="row">
|
||||||
|
<h3 class="title-h3">
|
||||||
|
Смотрите в прямом эфире
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-sm-6 col-md-4 translation-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/khl.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-sm-6 col-md-4 translation-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/NBA.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-sm-12 col-md-4 translation-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Laegue.png"></a>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
149
Styles/Admin.css
Normal file
@ -0,0 +1,149 @@
|
|||||||
|
.image-preview{
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
border-radius: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container{
|
||||||
|
height: 200px;
|
||||||
|
margin: 20px 0;
|
||||||
|
border-radius: 20px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-center{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
margin: 10px;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 26px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-section{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
padding: 15px 20px;
|
||||||
|
margin: 20px 0;;
|
||||||
|
background: linear-gradient(135deg, #161616, #fff);
|
||||||
|
border-radius: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-radio-btn {
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-radio-btn input[type=radio] {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.form-radio-btn label {
|
||||||
|
display: block;
|
||||||
|
margin: 5px;
|
||||||
|
cursor: pointer;
|
||||||
|
padding: 0px 15px;
|
||||||
|
font-size: 20px;
|
||||||
|
line-height: 34px;
|
||||||
|
background-color: white;
|
||||||
|
border: 1px solid #999;
|
||||||
|
border-radius: 6px;
|
||||||
|
user-select: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-radio-btn input[type=radio]:checked + label {
|
||||||
|
color: white;
|
||||||
|
background: #727272;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-radio-btn label:hover {
|
||||||
|
color: #555;
|
||||||
|
}
|
||||||
|
|
||||||
|
.form-radio-btn input[type=radio]:disabled + label {
|
||||||
|
background: #efefef;
|
||||||
|
color: #666;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-field-label{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-field-input{
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
padding: 7px;
|
||||||
|
font-family: inherit;
|
||||||
|
font-size: 18px;
|
||||||
|
color: #212529;
|
||||||
|
background-color: #fff;
|
||||||
|
background-clip: padding-box;
|
||||||
|
border: 1px solid #bdbdbd;
|
||||||
|
border-radius: 0.25rem;
|
||||||
|
}
|
||||||
|
|
||||||
|
.text-field-textarea{
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
height: 185px;
|
||||||
|
padding: 7px;
|
||||||
|
font-family: inherit;
|
||||||
|
font-size: 18px;
|
||||||
|
color: #212529;
|
||||||
|
background-color: #fff;
|
||||||
|
background-clip: padding-box;
|
||||||
|
border: 1px solid #bdbdbd;
|
||||||
|
border-radius: 0.25rem;
|
||||||
|
resize: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.submit-button-label{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.submit-button{
|
||||||
|
padding: 15px 20px;
|
||||||
|
margin: 20px 0;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: white;
|
||||||
|
background: linear-gradient(135deg, #161616, #fff);
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
.submit-button, .text-field-textarea, .text-field-input, .form-radio-btn label{
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
.title-h3{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
162
Styles/Cabinet.css
Normal file
@ -0,0 +1,162 @@
|
|||||||
|
|
||||||
|
.user-data-box{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
margin: 30px 0;
|
||||||
|
padding: 20px 100px 20px 40px;
|
||||||
|
background: linear-gradient(135deg, #161616, #fff);
|
||||||
|
border-radius: 47px;
|
||||||
|
color: white;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.overview-list{
|
||||||
|
background: linear-gradient(115deg, #161616, #fff);
|
||||||
|
border-radius: 47px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.overview-item{
|
||||||
|
margin: 20px;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.change-info-button{
|
||||||
|
display: inline-block;
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
padding: 20px;
|
||||||
|
background-color: #303030;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
color: white;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.admin-button{
|
||||||
|
display: inline-block;
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
padding: 5px;
|
||||||
|
background-color: #303030;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
color: white;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.admin-button a{
|
||||||
|
text-decoration: none;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add-link {
|
||||||
|
display: block;
|
||||||
|
margin: 20px;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 20px;
|
||||||
|
text-decoration: none;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add-block{
|
||||||
|
margin: 30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.user-name{
|
||||||
|
margin: 0 0 20px 0;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 30px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add-block .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 32px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 36px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.film-box .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 27px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
padding: 15px 0;
|
||||||
|
background-color: transparent;
|
||||||
|
border: none;
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
.add-block{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.film-box{
|
||||||
|
margin: 20px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.user-data-box{
|
||||||
|
padding: 20px 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.overview-list{
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.overview-item{
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.change-info-button{
|
||||||
|
padding: 7px;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
123
Styles/Katlog.css
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
.kind{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
margin: 20px 0;
|
||||||
|
height: 350px;
|
||||||
|
padding: 30px;
|
||||||
|
background: linear-gradient(135deg, #848484, #E4E4E4);
|
||||||
|
border-radius: 35px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.kind .title-h3{
|
||||||
|
text-align: center;
|
||||||
|
font-size: 36px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.kind .image-container{
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
padding: 10px;
|
||||||
|
margin: 10px;
|
||||||
|
color: #fff;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 32px;
|
||||||
|
background-color: #727272;
|
||||||
|
border: none;
|
||||||
|
border-radius: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h2{
|
||||||
|
font-size: 48px;
|
||||||
|
font-weight: 800;
|
||||||
|
}
|
||||||
|
|
||||||
|
.category{
|
||||||
|
margin: 20px 0;
|
||||||
|
height: 200px;
|
||||||
|
padding: 30px;
|
||||||
|
background: linear-gradient(135deg, #848484, #E4E4E4);
|
||||||
|
border-radius: 35px;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.category .title-h3{
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.category .image-container{
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
right: 0;
|
||||||
|
display: flex;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.category .nature-img{
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h4{
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.genres{
|
||||||
|
font-size: 21px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.genres li{
|
||||||
|
margin: 10px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.title-h2{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.category .title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
padding: 4px;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
.kind .title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.genres{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
144
Styles/Main.css
Normal file
@ -0,0 +1,144 @@
|
|||||||
|
|
||||||
|
.subsribe-box{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
columns: 2;
|
||||||
|
margin: 30px 0;
|
||||||
|
padding: 20px 100px 20px 40px;
|
||||||
|
background: linear-gradient(135deg, #161616, #fff);
|
||||||
|
border-radius: 47px;
|
||||||
|
color: white;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-title{
|
||||||
|
margin: 0 0 30px 0;
|
||||||
|
font-size: 48px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .text{
|
||||||
|
font-size: 36px;
|
||||||
|
margin: 0 0 20px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .add-info{
|
||||||
|
font-size: 24px;
|
||||||
|
margin: 0 0 10px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.orange-text{
|
||||||
|
color: #FFC047;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .button-subsribe{
|
||||||
|
display: inline-block;
|
||||||
|
margin: 30px 0 0 0;
|
||||||
|
padding: 20px;
|
||||||
|
background-color: #303030;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
color: white;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add-block{
|
||||||
|
margin: 30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.add-block .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 32px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 36px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.film-box .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 27px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
margin: 0 0 15px 0;
|
||||||
|
padding: 15px 0;
|
||||||
|
background-color: transparent;
|
||||||
|
border: none;
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
.add-block{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.film-box{
|
||||||
|
margin: 20px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.subsribe-box{
|
||||||
|
padding: 20px 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .text{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .add-info{
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
|
||||||
|
.subsribe-box .add-info{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
.subsribe-box .text{
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .add-info{
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.subsribe-box .button-subsribe{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
91
Styles/Shop.css
Normal file
@ -0,0 +1,91 @@
|
|||||||
|
.title-h2{
|
||||||
|
margin: 20px;
|
||||||
|
font-size: 40px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.film-title{
|
||||||
|
font-size: 18px;
|
||||||
|
padding: 5px;
|
||||||
|
position: absolute;
|
||||||
|
bottom: 5px;
|
||||||
|
right: 5px;
|
||||||
|
background-color: #D9D9D9;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recomendation .product{
|
||||||
|
margin: 20px 0;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.recomendation .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 27px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
width: 100%;
|
||||||
|
height: 400px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.product .price{
|
||||||
|
display: inline-block;
|
||||||
|
padding: 7px;
|
||||||
|
background-color: #D9D9D9;
|
||||||
|
position: absolute;
|
||||||
|
top: 20px;
|
||||||
|
left: 30px;
|
||||||
|
border-radius: 20px;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
padding: 10px;
|
||||||
|
margin: 10px 0 30px 0;
|
||||||
|
color: #fff;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 32px;
|
||||||
|
background-color: #727272;
|
||||||
|
border: none;
|
||||||
|
border-radius: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.title-h2{
|
||||||
|
margin-top: 0;
|
||||||
|
font-size: 32px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.button-more{
|
||||||
|
padding: 4px;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
.title-h2{
|
||||||
|
font-size: 26px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
151
Styles/Sport.css
Normal file
@ -0,0 +1,151 @@
|
|||||||
|
|
||||||
|
|
||||||
|
.event{
|
||||||
|
margin: 30px 0;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 50px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
height: 300px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .data-time{
|
||||||
|
padding: 20px;
|
||||||
|
position: absolute;
|
||||||
|
top: 30px;
|
||||||
|
left: 50px;
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
background-color: #D9D9D9;
|
||||||
|
border-radius: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .add-info{
|
||||||
|
padding: 20px 60px;
|
||||||
|
position: absolute;
|
||||||
|
bottom: 30px;
|
||||||
|
left: 50px;
|
||||||
|
color: #fff;
|
||||||
|
font-size: 32px;
|
||||||
|
font-weight: bold;
|
||||||
|
background-color: #242424;
|
||||||
|
border-radius: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bottom-nav{
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bottom-nav .col{
|
||||||
|
margin: 15px 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.bottom-nav_item{
|
||||||
|
height: 100%;
|
||||||
|
padding: 15px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #fff;
|
||||||
|
text-align: center;
|
||||||
|
background: linear-gradient(#707070, #A1A1A1);
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 36px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.translation-box{
|
||||||
|
margin: 30px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.translation-box .image-container{
|
||||||
|
display: block;
|
||||||
|
border-radius: 27px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
.event .data-time{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .add-info{
|
||||||
|
padding: 20px 40px;
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
.event .data-time{
|
||||||
|
padding: 10px;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .add-info{
|
||||||
|
padding: 10px 20px;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.event .data-time{
|
||||||
|
padding: 5px;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .add-info{
|
||||||
|
padding: 5px 10px;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 28px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.bottom-nav{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
.event .data-time{
|
||||||
|
padding: 3px;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.event .add-info{
|
||||||
|
padding: 3px 6px;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h3{
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
.title-h3{
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
345
Styles/Styles.css
Normal file
@ -0,0 +1,345 @@
|
|||||||
|
body,
|
||||||
|
html{
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
min-width: 320px;
|
||||||
|
font-family: Arial;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.header-top {
|
||||||
|
background-color: #D9D9D9;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.header-top a, h1, button{
|
||||||
|
margin-bottom: 20px;
|
||||||
|
color: black;
|
||||||
|
text-decoration: none;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smart-logo{
|
||||||
|
width: 60px;
|
||||||
|
height: 60px;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-top .row{
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h1 {
|
||||||
|
padding: 20px 0 0 0;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 36px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#login-button{
|
||||||
|
padding: 32px 0px;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
background-color: #212121;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
#login-button a{
|
||||||
|
text-decoration: none;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-bottom{
|
||||||
|
background-color: #C1C1C1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-list{
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
list-style-type: none;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item{
|
||||||
|
display: inline-block;
|
||||||
|
margin: 30px 0 0 0;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.nav-item a{
|
||||||
|
color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smart-nav-list{
|
||||||
|
display: none;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smart-nav-item{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: start;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smart-nav-item a{
|
||||||
|
margin-right: 30px;
|
||||||
|
padding: 5px;
|
||||||
|
color: black;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 20px;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.case__btn-close{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: space-between;
|
||||||
|
margin: 0;
|
||||||
|
padding: 10px 0 0 0;
|
||||||
|
width: 25px;
|
||||||
|
height: 25px;
|
||||||
|
transition: 0.5s;
|
||||||
|
background-color: transparent;
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.stick{
|
||||||
|
padding: 2px;
|
||||||
|
width: 100%;
|
||||||
|
background-color: #000;
|
||||||
|
border-radius: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.case__btn-close_open{
|
||||||
|
transform: rotate(360deg);
|
||||||
|
transition: 0.5s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap{
|
||||||
|
background: linear-gradient(#4E4E4E, #000000);
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap a{
|
||||||
|
text-decoration: none;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.footer-wrap ul, li{
|
||||||
|
list-style-type: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .footer-top{
|
||||||
|
color: white;
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .sign{
|
||||||
|
padding-top: 45px;
|
||||||
|
font-size: 24px;
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .row-network{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .item-network{
|
||||||
|
padding: 30px 0 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .row-addinfo{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .add-info{
|
||||||
|
margin-top: 45px;
|
||||||
|
color: white;
|
||||||
|
font-size: 24px;
|
||||||
|
font-weight: bold;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .add-info .item{
|
||||||
|
margin-bottom: 22px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .meta-text span{
|
||||||
|
margin-top: 60px;
|
||||||
|
color: white;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
.footer-wrap .meta-text{
|
||||||
|
padding-bottom: 30px;
|
||||||
|
color: white;
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
.footer-wrap .meta-text span{
|
||||||
|
margin-top: 60px;
|
||||||
|
color: white;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
.footer-wrap .meta-text span{
|
||||||
|
margin-top: 40px;
|
||||||
|
color: white;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h1 {
|
||||||
|
font-size: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .desktop-logo{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .meta-text span{
|
||||||
|
display: block;
|
||||||
|
margin-top: 0;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.nav-list{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.smart-nav-list{
|
||||||
|
display: flex;
|
||||||
|
}
|
||||||
|
|
||||||
|
#login-button{
|
||||||
|
padding: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h1 {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .row-addinfo{
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
.container{
|
||||||
|
width: 400px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h1 {
|
||||||
|
display: inline-block;
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.desktop-logo{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.smart-logo{
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
#login-button{
|
||||||
|
padding: 10px 0px;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
background-color: #212121;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 16px;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .row-addinfo{
|
||||||
|
flex-direction: column;
|
||||||
|
justify-content: start;
|
||||||
|
margin: 10px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .add-info{
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .add-info .item{
|
||||||
|
margin: 5px 0;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .meta-text{
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
.container{
|
||||||
|
width: 320px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.title-h1 {
|
||||||
|
display: inline-block;
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.desktop-logo{
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.smart-logo{
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
#login-button{
|
||||||
|
padding: 10px 0px;
|
||||||
|
border: none;
|
||||||
|
border-radius: 20px;
|
||||||
|
background-color: #212121;
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 16px;
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .item-network img{
|
||||||
|
width: 45px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .row-addinfo{
|
||||||
|
flex-direction: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
.footer-wrap .add-info .item{
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
199
Styles/TV.css
Normal file
@ -0,0 +1,199 @@
|
|||||||
|
.sub-nav{
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sub-nav .col{
|
||||||
|
margin: 15px 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.sub-nav_item{
|
||||||
|
height: 100%;
|
||||||
|
padding: 15px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
color: #fff;
|
||||||
|
text-align: center;
|
||||||
|
background: linear-gradient(#707070, #A1A1A1);
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.TV-box{
|
||||||
|
position: relative;
|
||||||
|
margin: 30px 0;
|
||||||
|
height: 470px;
|
||||||
|
border-radius: 30px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container{
|
||||||
|
display: block;
|
||||||
|
height: 100%;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-picture{
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
top: 30px;
|
||||||
|
left: 30px;
|
||||||
|
border-radius: 30px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-picture img{
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watch-free{
|
||||||
|
padding: 20px;
|
||||||
|
position: absolute;
|
||||||
|
bottom: 30px;
|
||||||
|
left: 30px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
background-color: #D9D9D9;
|
||||||
|
border-radius: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container{
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-container img{
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-box{
|
||||||
|
margin: 30px 0;
|
||||||
|
padding: 0;
|
||||||
|
height: 470px;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* полоса прокрутки (скроллбар) */
|
||||||
|
.channel-box::-webkit-scrollbar {
|
||||||
|
padding: 1px;
|
||||||
|
background-color: #404040;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* ползунок скроллбара */
|
||||||
|
.channel-box::-webkit-scrollbar-thumb {
|
||||||
|
margin: 1px;
|
||||||
|
background-color: #F3F3F3;
|
||||||
|
border: 2px solid #404040;
|
||||||
|
border-radius: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-box::-webkit-scrollbar-thumb:hover {
|
||||||
|
background-color: #c3c3c3;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-box::-webkit-scrollbar-button:vertical:start:decrement {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-box::-webkit-scrollbar-button:vertical:end:increment {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-item{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
justify-content: start;
|
||||||
|
margin: 0 0 20px 0;
|
||||||
|
padding: 6px;
|
||||||
|
background: linear-gradient(#7A7A7A, #949494);
|
||||||
|
border-radius: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-item .image-container{
|
||||||
|
width: 60px;
|
||||||
|
height: 60px;
|
||||||
|
margin: 10px 20px 0 10px;
|
||||||
|
border-radius: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.channel-text-box{
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-time{
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-name{
|
||||||
|
font-size: 20px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-category{
|
||||||
|
font-weight: 200;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
.sub-nav_item{
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 992px) {
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
.sub-nav{
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
|
||||||
|
.TV-box{
|
||||||
|
height: auto;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 576px) {
|
||||||
|
.channel-picture{
|
||||||
|
width: 100px;
|
||||||
|
height: 100px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.watch-free{
|
||||||
|
padding: 10px;
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-time{
|
||||||
|
font-size: 10px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-name{
|
||||||
|
font-size: 15px;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.programm-category{
|
||||||
|
font-weight: 9px;
|
||||||
|
font-weight: 200;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 398px) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
7
Styles/pagePage.css
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
.fa-trash, .fa-pen-to-square{
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.btn-success{
|
||||||
|
background: linear-gradient(135deg, #161616, #888);
|
||||||
|
}
|
279
TV.html
Normal file
@ -0,0 +1,279 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/TV.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="Cabinet.html">Войти в личный кабинет</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html"><u>ТВ-каналы</u></a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
<u>ТВ-каналы</u>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<section>
|
||||||
|
<ul class="row sub-nav">
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Все каналы
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Федеральные
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Фильмы и сериалы
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Научно-популярные
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Детские
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="col">
|
||||||
|
<div class="sub-nav_item">
|
||||||
|
Ещё
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-lg-6">
|
||||||
|
<div class="TV-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/TV.png"></a>
|
||||||
|
<a href="#" class="channel-picture"><img src="Images/First.png"></a>
|
||||||
|
<div class="watch-free">
|
||||||
|
Смотреть бесплатно
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-6">
|
||||||
|
<article>
|
||||||
|
<ul class="channel-box">
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/First-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">18:00 - 19:00</div>
|
||||||
|
<div class="programm-name">Информационный канал</div>
|
||||||
|
<div class="programm-category">Новости - 16+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/First-red-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">17:00 - 19:30</div>
|
||||||
|
<div class="programm-name">Малахов</div>
|
||||||
|
<div class="programm-category">Ток-шоу - 16+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/Match-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">17:25 - 19:30</div>
|
||||||
|
<div class="programm-name">Футбол
|
||||||
|
Кубок России</div>
|
||||||
|
<div class="programm-category">Спорт - 0+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/NTV-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">17:45 - 18:50</div>
|
||||||
|
<div class="programm-name">За гранью</div>
|
||||||
|
<div class="programm-category">Ток-шоу - 16+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/First-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">18:00 - 19:00</div>
|
||||||
|
<div class="programm-name">Информационный канал</div>
|
||||||
|
<div class="programm-category">Новости - 16+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<li class="channel-item">
|
||||||
|
<a class="image-container" href="#"><img src="Images/First-mini.png"></a>
|
||||||
|
<div class="channel-text-box">
|
||||||
|
<div class="programm-time">18:00 - 19:00</div>
|
||||||
|
<div class="programm-name">Информационный канал</div>
|
||||||
|
<div class="programm-category">Новости - 16+</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
|
||||||
|
</ul>
|
||||||
|
</article>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
9
counter.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export function setupCounter(element) {
|
||||||
|
let counter = 0
|
||||||
|
const setCounter = (count) => {
|
||||||
|
counter = count
|
||||||
|
element.innerHTML = `count is ${counter}`
|
||||||
|
}
|
||||||
|
element.addEventListener('click', () => setCounter(counter + 1))
|
||||||
|
setCounter(0)
|
||||||
|
}
|
242
index.html
Normal file
@ -0,0 +1,242 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="ru">
|
||||||
|
<head>
|
||||||
|
<title>Онлайн кинотеатр</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<link rel="stylesheet" type="text/css" href="node_modules\bootstrap\dist\css\bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Main.css">
|
||||||
|
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
|
||||||
|
<script src="JavaScript/script.js"></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="Cabinet.html">Войти в личный кабинет</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html"><u>Главная</u></a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
<u>Главная</u>
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
|
<main class="main-wrap">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<section class="col-sm-12 col-lg-9 subsribe-box">
|
||||||
|
<h2 class="subsribe-title">
|
||||||
|
Подписка
|
||||||
|
</h2>
|
||||||
|
<span class="text">
|
||||||
|
Смотрите кино, сериалы и мультфильмы
|
||||||
|
</span>
|
||||||
|
<span class="add-info orange-text">
|
||||||
|
Месяц за 1 Р, затем месяц за 199 Р
|
||||||
|
</span>
|
||||||
|
<span class="add-info">
|
||||||
|
Дальше - 399 Р в месяц
|
||||||
|
</span>
|
||||||
|
<button class="button-subsribe">
|
||||||
|
Оформить подписку
|
||||||
|
</button>
|
||||||
|
</section>
|
||||||
|
<aside class="col-md-4 col-lg-3 add-block">
|
||||||
|
<a href="#" class="image-container">
|
||||||
|
<img src="Images/parents.png">
|
||||||
|
</a>
|
||||||
|
</aside>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h3 class="col-sm-12 title-h3">
|
||||||
|
Фильмы бесплатно
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film1.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film2.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Film3.png"></a>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
<div class="row">
|
||||||
|
<button class="col-sm-12 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<h3 class="col-sm-12 title-h3">
|
||||||
|
Сериалы бесплатно
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<section class="row">
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series1.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series2.png"></a>
|
||||||
|
</article>
|
||||||
|
<article class="col-lg-4 film-box">
|
||||||
|
<a href="#" class="image-container"><img src="Images/Series3.png"></a>
|
||||||
|
</article>
|
||||||
|
</section>
|
||||||
|
<div class="row">
|
||||||
|
<button class="col-sm-12 button-more">
|
||||||
|
Показать больше
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
1
javascript.svg
Normal file
@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="32" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 256"><path fill="#F7DF1E" d="M0 0h256v256H0V0Z"></path><path d="m67.312 213.932l19.59-11.856c3.78 6.701 7.218 12.371 15.465 12.371c7.905 0 12.89-3.092 12.89-15.12v-81.798h24.057v82.138c0 24.917-14.606 36.259-35.916 36.259c-19.245 0-30.416-9.967-36.087-21.996m85.07-2.576l19.588-11.341c5.157 8.421 11.859 14.607 23.715 14.607c9.969 0 16.325-4.984 16.325-11.858c0-8.248-6.53-11.17-17.528-15.98l-6.013-2.58c-17.357-7.387-28.87-16.667-28.87-36.257c0-18.044 13.747-31.792 35.228-31.792c15.294 0 26.292 5.328 34.196 19.247l-18.732 12.03c-4.125-7.389-8.591-10.31-15.465-10.31c-7.046 0-11.514 4.468-11.514 10.31c0 7.217 4.468 10.14 14.778 14.608l6.014 2.577c20.45 8.765 31.963 17.7 31.963 37.804c0 21.654-17.012 33.51-39.867 33.51c-22.339 0-36.774-10.654-43.819-24.574"></path></svg>
|
After Width: | Height: | Size: 995 B |
101
js/lines-rest-api.js
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
// модуль для работы с REST API сервера
|
||||||
|
|
||||||
|
// адрес сервера
|
||||||
|
const serverUrl = "http://localhost:8081";
|
||||||
|
|
||||||
|
// функция возвращает объект нужной структуры для отправки на сервер
|
||||||
|
function createLineObject(filmName, item, price, discount, image) {
|
||||||
|
return {
|
||||||
|
filmName: String(filmName),
|
||||||
|
itemsId: item,
|
||||||
|
price: parseFloat(price).toFixed(2),
|
||||||
|
discount: (String(discount) + String("%")),
|
||||||
|
finalPrice: parseFloat(price - price * discount / 100).toFixed(2),
|
||||||
|
image,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для получения всех типов товара (get)
|
||||||
|
export async function getAllItemTypes() {
|
||||||
|
const response = await fetch(`${serverUrl}/items`);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для получения всех записей (get)
|
||||||
|
export async function getAllLines() {
|
||||||
|
const response = await fetch(`${serverUrl}/lines?_expand=items`);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для получения записи по первичному ключу (id) (get)
|
||||||
|
// id передается в качестве части пути URL get-запроса
|
||||||
|
export async function getLine(id) {
|
||||||
|
const response = await fetch(`${serverUrl}/lines/${id}?_expand=items`);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для создания записи (post)
|
||||||
|
// объект отправляется в теле запроса (body)
|
||||||
|
export async function createLine(filmName, item, price, discount, image) {
|
||||||
|
const itemObject = createLineObject(filmName, item, price, discount, image);
|
||||||
|
|
||||||
|
const options = {
|
||||||
|
method: "POST",
|
||||||
|
body: JSON.stringify(itemObject),
|
||||||
|
headers: {
|
||||||
|
"Accept": "application/json",
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await fetch(`${serverUrl}/lines`, options);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для обновления записи по id (put)
|
||||||
|
// объект отправляется в теле запроса (body)
|
||||||
|
// id передается в качестве части пути URL get-запроса
|
||||||
|
export async function updateLine(id, filmName, item, price, discount, image) {
|
||||||
|
const itemObject = createLineObject(filmName, item, price, discount, image);
|
||||||
|
|
||||||
|
const options = {
|
||||||
|
method: "PUT",
|
||||||
|
body: JSON.stringify(itemObject),
|
||||||
|
headers: {
|
||||||
|
"Accept": "application/json",
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await fetch(`${serverUrl}/lines/${id}`, options);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
||||||
|
|
||||||
|
// обращение к серверу для удаления записи по id (delete)
|
||||||
|
// id передается в качестве части пути URL get-запроса
|
||||||
|
export async function deleteLine(id) {
|
||||||
|
const options = {
|
||||||
|
method: "DELETE",
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await fetch(`${serverUrl}/lines/${id}`, options);
|
||||||
|
if (!response.ok) {
|
||||||
|
throw response.statusText;
|
||||||
|
}
|
||||||
|
return response.json();
|
||||||
|
}
|
140
js/lines-ui.js
Normal file
@ -0,0 +1,140 @@
|
|||||||
|
// модуль для работы с элементами управления
|
||||||
|
|
||||||
|
// объект для удобного получения элементов
|
||||||
|
// при обращении к атрибуту объекта вызывается
|
||||||
|
// нужная функция для поиска элемента
|
||||||
|
export const cntrls = {
|
||||||
|
button: document.getElementById("items-add"),
|
||||||
|
table: document.querySelector("#items-table tbody"),
|
||||||
|
|
||||||
|
shopRec: document.getElementById("shopRec"),
|
||||||
|
|
||||||
|
form: document.getElementById("items-form"),
|
||||||
|
lineId: document.getElementById("items-line-id"),
|
||||||
|
itemsType: document.getElementById("item"),
|
||||||
|
price: document.getElementById("price"),
|
||||||
|
discount: document.getElementById("discount"),
|
||||||
|
image: document.getElementById("image"),
|
||||||
|
imagePreview: document.getElementById("image-preview"),
|
||||||
|
filmName: document.getElementById("filmName"),
|
||||||
|
};
|
||||||
|
|
||||||
|
// Дефолтное превью
|
||||||
|
export const imagePlaceholder = "https://via.placeholder.com/200";
|
||||||
|
|
||||||
|
// функция создает тег option для select
|
||||||
|
// <option value="" selected>name</option>
|
||||||
|
export function createItemsOption(name, value = "", isSelected = false) {
|
||||||
|
const option = document.createElement("option");
|
||||||
|
option.value = value || "";
|
||||||
|
option.selected = isSelected;
|
||||||
|
option.text = name;
|
||||||
|
return option;
|
||||||
|
}
|
||||||
|
|
||||||
|
// функция создает ссылку (a) для таблицы
|
||||||
|
// содержимое тега a заполняется необходимой иконкой (icon)
|
||||||
|
// при нажатии вызывается callback
|
||||||
|
// ссылка "оборачивается" тегом td
|
||||||
|
// <td><a href="#" onclick="callback()"><i class="fa-solid icon"></i></a></td>
|
||||||
|
function createTableAnchor(icon, callback) {
|
||||||
|
const i = document.createElement("i");
|
||||||
|
i.classList.add("fa-solid", icon);
|
||||||
|
|
||||||
|
const a = document.createElement("a");
|
||||||
|
a.href = "#";
|
||||||
|
a.appendChild(i);
|
||||||
|
a.onclick = (event) => {
|
||||||
|
// чтобы в URL не добавлялась решетка
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
callback();
|
||||||
|
};
|
||||||
|
|
||||||
|
const td = document.createElement("td");
|
||||||
|
td.appendChild(a);
|
||||||
|
return td;
|
||||||
|
}
|
||||||
|
|
||||||
|
// функция создает колонку таблицы с текстом value
|
||||||
|
// <td>value</td>
|
||||||
|
function createTableColumn(value) {
|
||||||
|
const td = document.createElement("td");
|
||||||
|
td.textContent = value;
|
||||||
|
return td;
|
||||||
|
}
|
||||||
|
|
||||||
|
// функция создает строку таблицы
|
||||||
|
// <tr>
|
||||||
|
// <th scope="row">index + 1</th>
|
||||||
|
// <td>item.items.name</td>
|
||||||
|
// <td>parseFloat(item.price).toFixed(2))</td>
|
||||||
|
// <td>item.discount</td>
|
||||||
|
// <td>parseFloat(item.finalPrice).toFixed(2))</td>
|
||||||
|
// <td><a href="#" onclick="editCallback()"><i class="fa-solid fa-pencil"></i></a></td>
|
||||||
|
// <td><a href="#" onclick="editPageCallback()"><i class="fa-solid fa-pen-to-square"></i></a></td>
|
||||||
|
// <td><a href="#" onclick="deleteCallback()"><i class="fa-solid fa-trash"></i></a></td>
|
||||||
|
// </tr>
|
||||||
|
export function createTableRow(item, index, editPageCallback, deleteCallback) {
|
||||||
|
const rowNumber = document.createElement("th");
|
||||||
|
rowNumber.scope = "row";
|
||||||
|
rowNumber.textContent = index + 1;
|
||||||
|
|
||||||
|
const row = document.createElement("tr");
|
||||||
|
row.id = `line-${item.id}`;
|
||||||
|
|
||||||
|
row.appendChild(rowNumber);
|
||||||
|
row.appendChild(createTableColumn(String(item.filmName)));
|
||||||
|
row.appendChild(createTableColumn(item.items.name));
|
||||||
|
row.appendChild(createTableColumn(parseFloat(item.price).toFixed(2)));
|
||||||
|
row.appendChild(createTableColumn(String(item.discount)));
|
||||||
|
row.appendChild(createTableColumn(parseFloat(item.finalPrice).toFixed(2)));
|
||||||
|
// редактировать на странице page-edit
|
||||||
|
row.appendChild(createTableAnchor("fa-pen-to-square", editPageCallback));
|
||||||
|
// удаление
|
||||||
|
row.appendChild(createTableAnchor("fa-trash", deleteCallback));
|
||||||
|
return row;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function createShopElem(item, index, editPageCallback, deleteCallback) {
|
||||||
|
|
||||||
|
const El = document.createElement("article");
|
||||||
|
El.className = "col-md-6 product";
|
||||||
|
El.id = `line-${item.id}`;
|
||||||
|
|
||||||
|
|
||||||
|
El.appendChild(createFilmName(String(item.filmName)));
|
||||||
|
El.appendChild(createFilmPrice(parseFloat(item.finalPrice).toFixed(2)));
|
||||||
|
El.appendChild(createFilmImage(item.image));
|
||||||
|
return El;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function createFilmName(value) {
|
||||||
|
const td = document.createElement("h3");
|
||||||
|
td.className = "film-title";
|
||||||
|
td.textContent = value;
|
||||||
|
return td;
|
||||||
|
}
|
||||||
|
|
||||||
|
function createFilmPrice(value) {
|
||||||
|
const td = document.createElement("div");
|
||||||
|
td.className = "price";
|
||||||
|
td.textContent = String(value) + " Р";
|
||||||
|
return td;
|
||||||
|
}
|
||||||
|
|
||||||
|
function createFilmImage(value) {
|
||||||
|
|
||||||
|
const a = document.createElement("a");
|
||||||
|
a.className = "image-container"
|
||||||
|
a.href = "#";
|
||||||
|
|
||||||
|
const td = document.createElement("img");
|
||||||
|
|
||||||
|
td.src = value;
|
||||||
|
|
||||||
|
a.appendChild(td);
|
||||||
|
|
||||||
|
return a;
|
||||||
|
}
|
263
js/lines.js
Normal file
@ -0,0 +1,263 @@
|
|||||||
|
// модуль с логикой
|
||||||
|
|
||||||
|
import {
|
||||||
|
createLine, deleteLine, getAllItemTypes, getAllLines, getLine, updateLine,
|
||||||
|
} from "./lines-rest-api";
|
||||||
|
import {
|
||||||
|
cntrls, createItemsOption, createTableRow, imagePlaceholder, createShopElem,
|
||||||
|
} from "./lines-ui";
|
||||||
|
|
||||||
|
async function drawItemsSelect() {
|
||||||
|
// вызов метода REST API для получения списка типов товаров
|
||||||
|
const data = await getAllItemTypes();
|
||||||
|
// очистка содержимого select
|
||||||
|
// удаляется все, что находится между тегами <select></select>
|
||||||
|
// но не атрибуты
|
||||||
|
cntrls.itemsType.innerHTML = "";
|
||||||
|
// пустое значение
|
||||||
|
cntrls.itemsType.appendChild(createItemsOption("Выберите значение", "", true));
|
||||||
|
// цикл по результату ответа от сервера
|
||||||
|
// используется лямбда-выражение
|
||||||
|
// (item) => {} аналогично function(item) {}
|
||||||
|
data.forEach((item) => {
|
||||||
|
cntrls.itemsType.appendChild(createItemsOption(item.name, item.id));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function drawInShop() {
|
||||||
|
console.info("Try to load data");
|
||||||
|
if (!cntrls.shopRec) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// вызов метода REST API для получения всех записей
|
||||||
|
const data = await getAllLines();
|
||||||
|
// очистка содержимого table
|
||||||
|
// удаляется все, что находится между тегами <table></table>
|
||||||
|
// но не атрибуты
|
||||||
|
cntrls.shopRec.innerHTML = "";
|
||||||
|
// цикл по результату ответа от сервера
|
||||||
|
// используется лямбда-выражение
|
||||||
|
// (item, index) => {} аналогично function(item, index) {}
|
||||||
|
data.forEach((item, index) => {
|
||||||
|
cntrls.shopRec.appendChild(
|
||||||
|
createShopElem(
|
||||||
|
item,
|
||||||
|
index,
|
||||||
|
// функции передаются в качестве параметра
|
||||||
|
// это очень удобно, так как аргументы функций доступны только
|
||||||
|
// в данном месте кода и не передаются в сервисные модули
|
||||||
|
() => location.assign(`Admin.html?id=${item.id}`),
|
||||||
|
() => removeLine(item.id),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function drawLinesTable() {
|
||||||
|
console.info("Try to load data");
|
||||||
|
if (!cntrls.table) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// вызов метода REST API для получения всех записей
|
||||||
|
const data = await getAllLines();
|
||||||
|
// очистка содержимого table
|
||||||
|
// удаляется все, что находится между тегами <table></table>
|
||||||
|
// но не атрибуты
|
||||||
|
cntrls.table.innerHTML = "";
|
||||||
|
// цикл по результату ответа от сервера
|
||||||
|
// используется лямбда-выражение
|
||||||
|
// (item, index) => {} аналогично function(item, index) {}
|
||||||
|
data.forEach((item, index) => {
|
||||||
|
cntrls.table.appendChild(
|
||||||
|
createTableRow(
|
||||||
|
item,
|
||||||
|
index,
|
||||||
|
// функции передаются в качестве параметра
|
||||||
|
// это очень удобно, так как аргументы функций доступны только
|
||||||
|
// в данном месте кода и не передаются в сервисные модули
|
||||||
|
() => location.assign(`Admin.html?id=${item.id}`),
|
||||||
|
() => removeLine(item.id),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async function addLine(filmName, item, price, discount, image) {
|
||||||
|
console.info("Try to add item");
|
||||||
|
// вызов метода REST API для добавления записи
|
||||||
|
const data = await createLine(filmName, item, price, discount, image);
|
||||||
|
console.info("Added");
|
||||||
|
console.info(data);
|
||||||
|
// загрузка и заполнение table
|
||||||
|
drawLinesTable();
|
||||||
|
}
|
||||||
|
|
||||||
|
async function editLine(id, filmName, item, price, discount, image) {
|
||||||
|
console.info("Try to update item");
|
||||||
|
// вызов метода REST API для обновления записи
|
||||||
|
const data = await updateLine(id, filmName, item, price, discount, image);
|
||||||
|
console.info("Updated");
|
||||||
|
console.info(data);
|
||||||
|
// загрузка и заполнение table
|
||||||
|
drawLinesTable();
|
||||||
|
}
|
||||||
|
|
||||||
|
async function removeLine(id) {
|
||||||
|
if (!confirm("Do you really want to remove this item?")) {
|
||||||
|
console.info("Canceled");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
console.info("Try to remove item");
|
||||||
|
// вызов метода REST API для удаления записи
|
||||||
|
const data = await deleteLine(id);
|
||||||
|
console.info(data);
|
||||||
|
// загрузка и заполнение table
|
||||||
|
drawLinesTable();
|
||||||
|
}
|
||||||
|
|
||||||
|
// функция для получения содержимого файла в виде base64 строки
|
||||||
|
// https://ru.wikipedia.org/wiki/Base64
|
||||||
|
async function readFile(file) {
|
||||||
|
const reader = new FileReader();
|
||||||
|
|
||||||
|
// создание Promise-объекта для использования функции
|
||||||
|
// с помощью await (асинхронно) без коллбэков (callback)
|
||||||
|
// https://learn.javascript.ru/promise
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
// 2. "Возвращаем" содержимое когда файл прочитан
|
||||||
|
// через вызов resolve
|
||||||
|
// Если не использовать Promise, то всю работу по взаимодействию
|
||||||
|
// с REST API пришлось бы делать в обработчике (callback) функции
|
||||||
|
// onloadend
|
||||||
|
reader.onloadend = () => {
|
||||||
|
const fileContent = reader.result;
|
||||||
|
// Здесь могла бы быть работа с REST API
|
||||||
|
// Чтение заканчивает выполняться здесь
|
||||||
|
resolve(fileContent);
|
||||||
|
};
|
||||||
|
// 3. Возвращаем ошибку
|
||||||
|
reader.onerror = () => {
|
||||||
|
// Или здесь в случае ошибки
|
||||||
|
reject(new Error("oops, something went wrong with the file reader."));
|
||||||
|
};
|
||||||
|
// Шаг 1. Сначала читаем файл
|
||||||
|
// Чтение начинает выполняться здесь
|
||||||
|
reader.readAsDataURL(file);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// функция для обновления блока с превью выбранного изображения
|
||||||
|
async function updateImagePreview() {
|
||||||
|
// получение выбранного файла
|
||||||
|
// возможен выбор нескольких файлов, поэтому необходимо получить только первый
|
||||||
|
const file = cntrls.image.files[0];
|
||||||
|
// чтение содержимого файла в виде base64 строки
|
||||||
|
const fileContent = await readFile(file);
|
||||||
|
console.info("base64 ", fileContent);
|
||||||
|
// обновление атрибута src для тега img с id image-preview
|
||||||
|
cntrls.imagePreview.src = fileContent;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Функция для обработки создания и редактирования элементов таблицы через модальное окно
|
||||||
|
// Если хотите делать через страницу, то удалите эту функцию
|
||||||
|
|
||||||
|
|
||||||
|
// Функция для обработки создания и редактирования элементов таблицы через страницу page-edit.html
|
||||||
|
// Если хотите делать через модальное окно, то удалите эту функцию
|
||||||
|
export async function linesPageForm() {
|
||||||
|
console.info("linesPageForm");
|
||||||
|
|
||||||
|
// загрузка и заполнение select со списком товаров
|
||||||
|
drawItemsSelect();
|
||||||
|
|
||||||
|
// func1 = (id) => {} аналогично function func1(id) {}
|
||||||
|
const goBack = () => location.assign("/pagePage.html");
|
||||||
|
|
||||||
|
// Вызов функции обновления превью изображения при возникновении
|
||||||
|
// события onchange в тэге input с id image
|
||||||
|
cntrls.image.addEventListener("change", () => updateImagePreview());
|
||||||
|
|
||||||
|
// получение параметров GET-запроса из URL
|
||||||
|
// параметры перечислены после символа ? (?id=1&color=black&...)
|
||||||
|
const urlParams = new URLSearchParams(location.search);
|
||||||
|
|
||||||
|
// получение значения конкретного параметра (id)
|
||||||
|
// указан только при редактировании
|
||||||
|
const currentId = urlParams.get("id");
|
||||||
|
// если id задан
|
||||||
|
if (currentId) {
|
||||||
|
try {
|
||||||
|
// вызов метода REST API для получения записи по первичному ключу(id)
|
||||||
|
const line = await getLine(currentId);
|
||||||
|
// заполнение формы для редактирования
|
||||||
|
cntrls.filmName.value = line.filmName;
|
||||||
|
cntrls.itemsType.value = line.itemsId;
|
||||||
|
cntrls.price.value = line.price;
|
||||||
|
cntrls.discount.value = line.discount;
|
||||||
|
// заполнение превью
|
||||||
|
// Если пользователь выбрал изображение, то оно загружается
|
||||||
|
// в тэг image с id image - preview
|
||||||
|
// иначе устанавливается заглушка, адрес которой указан в imagePlaceholder
|
||||||
|
cntrls.imagePreview.src = line.image ? line.image : imagePlaceholder;
|
||||||
|
} catch {
|
||||||
|
// в случае ошибки происходит возврат к page4
|
||||||
|
goBack();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// обработчик события отправки формы
|
||||||
|
// возникает при нажатии на кнопку (button) с типом submit
|
||||||
|
// кнопка должна находится внутри тега form
|
||||||
|
cntrls.form.addEventListener("submit", async (event) => {
|
||||||
|
console.info("Form onSubmit");
|
||||||
|
// отключение стандартного поведения формы при отправке
|
||||||
|
// при отправке страница обновляется и JS перестает работать
|
||||||
|
event.preventDefault();
|
||||||
|
event.stopPropagation();
|
||||||
|
// если форма не прошла валидацию, то ничего делать не нужно
|
||||||
|
if (!cntrls.form.checkValidity()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
let imageBase64 = "";
|
||||||
|
// Получение выбранного пользователем изображения в виде base64 строки
|
||||||
|
// Если пользователь ничего не выбрал, то не нужно сохранять в БД
|
||||||
|
// дефолтное изображение
|
||||||
|
if (cntrls.imagePreview.src !== imagePlaceholder) {
|
||||||
|
// Загрузка содержимого атрибута src тэга img с id image-preview
|
||||||
|
// Здесь выполняется HTTP запрос с типом GET
|
||||||
|
const result = await fetch(cntrls.imagePreview.src);
|
||||||
|
// Получение из HTTP-ответа бинарного содержимого
|
||||||
|
const blob = await result.blob();
|
||||||
|
// Получение base64 строки для файла
|
||||||
|
// Здесь выполняется Promise из функции readFile
|
||||||
|
// Promise позволяет писать линейный код для работы с асинхронными методами
|
||||||
|
// без использования обработчиков (callback) с помощью await
|
||||||
|
imageBase64 = await readFile(blob);
|
||||||
|
}
|
||||||
|
|
||||||
|
// если значение параметра запроса не задано,
|
||||||
|
// то необходимо выполнить добавление записи
|
||||||
|
// иначе обновление записи
|
||||||
|
if (!currentId) {
|
||||||
|
await addLine(
|
||||||
|
cntrls.filmName.value,
|
||||||
|
cntrls.itemsType.value,
|
||||||
|
cntrls.price.value,
|
||||||
|
cntrls.discount.value,
|
||||||
|
imageBase64,
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
await editLine(
|
||||||
|
currentId,
|
||||||
|
cntrls.filmName.value,
|
||||||
|
cntrls.itemsType.value,
|
||||||
|
cntrls.price.value,
|
||||||
|
cntrls.discount.value,
|
||||||
|
imageBase64,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// возврат к странице page4
|
||||||
|
goBack();
|
||||||
|
});
|
||||||
|
}
|
25
js/validation.js
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
// модуль используется для валидации форма на странице
|
||||||
|
|
||||||
|
function validation() {
|
||||||
|
// поиск всех форма с классом .needs-validation
|
||||||
|
const forms = document.querySelectorAll("form.needs-validation");
|
||||||
|
|
||||||
|
for (let i = 0; i < forms.length; i += 1) {
|
||||||
|
const form = forms[i];
|
||||||
|
// для каждой формы добавляется обработчик события отправки
|
||||||
|
form.addEventListener("submit", (event) => {
|
||||||
|
// если форма не прошла валидацию
|
||||||
|
// то выключить стандартное действие
|
||||||
|
if (!form.checkValidity()) {
|
||||||
|
event.preventDefault();
|
||||||
|
// предотвращает распространение preventDefault
|
||||||
|
// на другие объекты
|
||||||
|
event.stopPropagation();
|
||||||
|
}
|
||||||
|
// добавляет к форме класс was-validated
|
||||||
|
form.classList.add("was-validated");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default validation;
|
24
main.js
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
import './style.css'
|
||||||
|
import javascriptLogo from './javascript.svg'
|
||||||
|
import viteLogo from '/vite.svg'
|
||||||
|
import { setupCounter } from './counter.js'
|
||||||
|
|
||||||
|
document.querySelector('#app').innerHTML = `
|
||||||
|
<div>
|
||||||
|
<a href="https://vitejs.dev" target="_blank">
|
||||||
|
<img src="${viteLogo}" class="logo" alt="Vite logo" />
|
||||||
|
</a>
|
||||||
|
<a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript" target="_blank">
|
||||||
|
<img src="${javascriptLogo}" class="logo vanilla" alt="JavaScript logo" />
|
||||||
|
</a>
|
||||||
|
<h1>Hello Vite!</h1>
|
||||||
|
<div class="card">
|
||||||
|
<button id="counter" type="button"></button>
|
||||||
|
</div>
|
||||||
|
<p class="read-the-docs">
|
||||||
|
Click on the Vite logo to learn more
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
`
|
||||||
|
|
||||||
|
setupCounter(document.querySelector('#counter'))
|
4626
package-lock.json
generated
Normal file
31
package.json
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
{
|
||||||
|
"name": "int-prog",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"type": "module",
|
||||||
|
"scripts": {
|
||||||
|
"vite": "vite",
|
||||||
|
"serve": "http-server -p 3000 ./dist/",
|
||||||
|
"build": "vite build",
|
||||||
|
"rest": "json-server --watch data.json -p 8081",
|
||||||
|
"dev": "npm-run-all --parallel rest vite",
|
||||||
|
"prod": "npm-run-all build --parallel serve rest"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@fortawesome/fontawesome-free": "6.4.2",
|
||||||
|
"bootstrap": "5.3.2"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"eslint": "^8.54.0",
|
||||||
|
"eslint-config-airbnb-base": "^15.0.0",
|
||||||
|
"eslint-plugin-import": "^2.29.0",
|
||||||
|
"http-server": "14.1.1",
|
||||||
|
"json-server": "0.17.4",
|
||||||
|
"npm-run-all": "4.1.5",
|
||||||
|
"vite": "4.4.9"
|
||||||
|
},
|
||||||
|
"main": "main.js",
|
||||||
|
"keywords": [],
|
||||||
|
"author": "",
|
||||||
|
"license": "ISC",
|
||||||
|
"description": ""
|
||||||
|
}
|
200
pagePage.html
Normal file
@ -0,0 +1,200 @@
|
|||||||
|
<html lang="ru">
|
||||||
|
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<title>Моя страница</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<script type="module" src="./node_modules/bootstrap/dist/js/bootstrap.min.js"></script>
|
||||||
|
<link href="./node_modules/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet" />
|
||||||
|
<link href="./node_modules/@fortawesome/fontawesome-free/css/all.min.css" rel="stylesheet" />
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/Styles.css">
|
||||||
|
<link rel="stylesheet" type="text/css" href="Styles/pagePage.css">
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body class="h-100 d-flex flex-column">
|
||||||
|
<header class="header-wrap">
|
||||||
|
<div class="header-top">
|
||||||
|
<div class="container">
|
||||||
|
<div class="row">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 col-sm-4 desktop-logo"><img class="Logotip" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра"></a>
|
||||||
|
<div class="col-lg-5 col-md-8 col-sm-8">
|
||||||
|
<img class="smart-logo" src="Images\Logotip-tv.png" alt="Логотип онлайн кинотеатра">
|
||||||
|
<h1 class="title-h1">
|
||||||
|
<a href="#">
|
||||||
|
Онлайн кинотеатр
|
||||||
|
</a>
|
||||||
|
</h1>
|
||||||
|
</div>
|
||||||
|
<button id="login-button" class="col-lg-4">
|
||||||
|
<a href="index.html">Выйти из личного кабинета</a>
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="header-bottom">
|
||||||
|
<nav class="container nav-box">
|
||||||
|
<ul class=" row nav-list">
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="index.html">Главная</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Katalog.html">Каталог</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Shop.html">Магазин</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="Sport.html">Спорт</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="TV.html">ТВ-каналы</a></li>
|
||||||
|
<li class="col-lg-2 col-md nav-item"><a href="pagePage.html"><u>Таблица</u></a></li>
|
||||||
|
<li class="col-lg-4 col-md-0 nav-item"></li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<ul class="smart-nav-list">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="index.html">
|
||||||
|
Главная
|
||||||
|
</a>
|
||||||
|
<button class="case__btn-close">
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
<div class="stick">
|
||||||
|
</div>
|
||||||
|
</button>
|
||||||
|
</li>
|
||||||
|
<div class="row">
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Katalog.html">
|
||||||
|
Каталог
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Shop.html">
|
||||||
|
Магазин
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="Sport.html">
|
||||||
|
Спорт
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="smart-nav-item">
|
||||||
|
<a href="TV.html">
|
||||||
|
ТВ-каналы
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</div>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
</nav>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
<main class="container-fluid p-2">
|
||||||
|
<div class="container">
|
||||||
|
<div class="btn-group" role="group">
|
||||||
|
<a class="btn btn-success" href="/Admin.html">Добавить элемент</a>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<table id="items-table" class="table table-striped">
|
||||||
|
<thead>
|
||||||
|
<th scope="col">№</th>
|
||||||
|
<th scope="col" class="w-25">Название</th>
|
||||||
|
<th scope="col" class="w-25">Жанр</th>
|
||||||
|
<th scope="col" class="w-25">Цена</th>
|
||||||
|
<th scope="col" class="w-25">Скидка</th>
|
||||||
|
<th scope="col" class="w-25">Итоговая Цена</th>
|
||||||
|
<th scope="col"></th>
|
||||||
|
<th scope="col"></th>
|
||||||
|
</thead>
|
||||||
|
<tbody></tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</main>
|
||||||
|
<footer class="footer-wrap">
|
||||||
|
<div class="container footer-top">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-12">
|
||||||
|
<div class="row sign">
|
||||||
|
Наши соцсети
|
||||||
|
</div>
|
||||||
|
<ul class="row-network">
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/VK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/Viber.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/OK.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/TG.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
<li class="item-network">
|
||||||
|
<a href="#"><img src="Images/YouTube.png" alt="" class=""></a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-7 col-md-12 row-addinfo">
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">О нас</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Блог</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Карьера</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Агенты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<ul class="add-info">
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Помощь</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Вопросы и ответы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Список устройств</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Дистрибьюторы</a>
|
||||||
|
</li>
|
||||||
|
<li class="item">
|
||||||
|
<a href="#">Контакты</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row meta-text">
|
||||||
|
<a href="#" class="col-lg-2 col-md-3 desktop-logo">
|
||||||
|
<img src="Images/Logotip-tv.png" alt="" class="">
|
||||||
|
</a>
|
||||||
|
<span class="col-lg-10 col-md-12">
|
||||||
|
© 2012-2023 ООО «Онлайн-кинотеатр» 18+<br>
|
||||||
|
Общероссийские каналы доступны для бесплатного просмотра круглосуточно<br>
|
||||||
|
ПО ООО «Онлайн-кинотеатр» состоит в реестре отечественного ПО
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
<script type="module">
|
||||||
|
import validation from "./js/validation";
|
||||||
|
import { drawLinesTable } from "./js/lines";
|
||||||
|
|
||||||
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
|
validation();
|
||||||
|
drawLinesTable();
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
</html>
|
1
public/vite.svg
Normal file
@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg>
|
After Width: | Height: | Size: 1.5 KiB |
97
style.css
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
:root {
|
||||||
|
font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif;
|
||||||
|
line-height: 1.5;
|
||||||
|
font-weight: 400;
|
||||||
|
|
||||||
|
color-scheme: light dark;
|
||||||
|
color: rgba(255, 255, 255, 0.87);
|
||||||
|
background-color: #242424;
|
||||||
|
|
||||||
|
font-synthesis: none;
|
||||||
|
text-rendering: optimizeLegibility;
|
||||||
|
-webkit-font-smoothing: antialiased;
|
||||||
|
-moz-osx-font-smoothing: grayscale;
|
||||||
|
-webkit-text-size-adjust: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
font-weight: 500;
|
||||||
|
color: #646cff;
|
||||||
|
text-decoration: inherit;
|
||||||
|
}
|
||||||
|
a:hover {
|
||||||
|
color: #535bf2;
|
||||||
|
}
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin: 0;
|
||||||
|
display: flex;
|
||||||
|
place-items: center;
|
||||||
|
min-width: 320px;
|
||||||
|
min-height: 100vh;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 3.2em;
|
||||||
|
line-height: 1.1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#app {
|
||||||
|
max-width: 1280px;
|
||||||
|
margin: 0 auto;
|
||||||
|
padding: 2rem;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.logo {
|
||||||
|
height: 6em;
|
||||||
|
padding: 1.5em;
|
||||||
|
will-change: filter;
|
||||||
|
transition: filter 300ms;
|
||||||
|
}
|
||||||
|
.logo:hover {
|
||||||
|
filter: drop-shadow(0 0 2em #646cffaa);
|
||||||
|
}
|
||||||
|
.logo.vanilla:hover {
|
||||||
|
filter: drop-shadow(0 0 2em #f7df1eaa);
|
||||||
|
}
|
||||||
|
|
||||||
|
.card {
|
||||||
|
padding: 2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.read-the-docs {
|
||||||
|
color: #888;
|
||||||
|
}
|
||||||
|
|
||||||
|
button {
|
||||||
|
border-radius: 8px;
|
||||||
|
border: 1px solid transparent;
|
||||||
|
padding: 0.6em 1.2em;
|
||||||
|
font-size: 1em;
|
||||||
|
font-weight: 500;
|
||||||
|
font-family: inherit;
|
||||||
|
background-color: #1a1a1a;
|
||||||
|
cursor: pointer;
|
||||||
|
transition: border-color 0.25s;
|
||||||
|
}
|
||||||
|
button:hover {
|
||||||
|
border-color: #646cff;
|
||||||
|
}
|
||||||
|
button:focus,
|
||||||
|
button:focus-visible {
|
||||||
|
outline: 4px auto -webkit-focus-ring-color;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (prefers-color-scheme: light) {
|
||||||
|
:root {
|
||||||
|
color: #213547;
|
||||||
|
background-color: #ffffff;
|
||||||
|
}
|
||||||
|
a:hover {
|
||||||
|
color: #747bff;
|
||||||
|
}
|
||||||
|
button {
|
||||||
|
background-color: #f9f9f9;
|
||||||
|
}
|
||||||
|
}
|