Compare commits
No commits in common. "master" and "main" have entirely different histories.
420
.gitignore
vendored
@ -1,24 +1,400 @@
|
|||||||
# Logs
|
# ---> VisualStudio
|
||||||
logs
|
## Ignore Visual Studio temporary files, build results, and
|
||||||
*.log
|
## files generated by popular Visual Studio add-ons.
|
||||||
npm-debug.log*
|
##
|
||||||
yarn-debug.log*
|
## Get latest from https://github.com/github/gitignore/blob/main/VisualStudio.gitignore
|
||||||
yarn-error.log*
|
|
||||||
pnpm-debug.log*
|
|
||||||
lerna-debug.log*
|
|
||||||
|
|
||||||
node_modules
|
# User-specific files
|
||||||
dist
|
*.rsuser
|
||||||
dist-ssr
|
|
||||||
*.local
|
|
||||||
|
|
||||||
# Editor directories and files
|
|
||||||
.vscode/*
|
|
||||||
!.vscode/extensions.json
|
|
||||||
.idea
|
|
||||||
.DS_Store
|
|
||||||
*.suo
|
*.suo
|
||||||
*.ntvs*
|
*.user
|
||||||
*.njsproj
|
*.userosscache
|
||||||
*.sln
|
*.sln.docstates
|
||||||
*.sw?
|
|
||||||
|
# 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
|
||||||
|
*.tlog
|
||||||
|
*.vspscc
|
||||||
|
*.vssscc
|
||||||
|
.builds
|
||||||
|
*.pidb
|
||||||
|
*.svclog
|
||||||
|
*.scc
|
||||||
|
|
||||||
|
# Chutzpah Test files
|
||||||
|
_Chutzpah*
|
||||||
|
|
||||||
|
# Visual C++ cache 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/settings.json
|
||||||
|
!.vscode/tasks.json
|
||||||
|
!.vscode/launch.json
|
||||||
|
!.vscode/extensions.json
|
||||||
|
*.code-workspace
|
||||||
|
|
||||||
|
# Local History for Visual Studio Code
|
||||||
|
.history/
|
||||||
|
|
||||||
|
# Windows Installer files from build outputs
|
||||||
|
*.cab
|
||||||
|
*.msi
|
||||||
|
*.msix
|
||||||
|
*.msm
|
||||||
|
*.msp
|
||||||
|
|
||||||
|
# JetBrains Rider
|
||||||
|
*.sln.iml
|
||||||
|
|
||||||
|
@ -1,6 +0,0 @@
|
|||||||
{
|
|
||||||
"ExpandedNodes": [
|
|
||||||
""
|
|
||||||
],
|
|
||||||
"PreviewInSolutionExplorer": false
|
|
||||||
}
|
|
BIN
.vs/slnx.sqlite
220
Admin.html
@ -1,220 +0,0 @@
|
|||||||
<!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
@ -1,253 +0,0 @@
|
|||||||
<!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>
|
|
Before Width: | Height: | Size: 149 KiB |
Before Width: | Height: | Size: 170 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 11 KiB |
Before Width: | Height: | Size: 17 KiB |
BIN
Images/Film1.png
Before Width: | Height: | Size: 111 KiB |
BIN
Images/Film2.png
Before Width: | Height: | Size: 125 KiB |
BIN
Images/Film3.png
Before Width: | Height: | Size: 118 KiB |
Before Width: | Height: | Size: 1.7 KiB |
Before Width: | Height: | Size: 962 B |
BIN
Images/First.png
Before Width: | Height: | Size: 5.3 KiB |
Before Width: | Height: | Size: 962 B |
BIN
Images/Gampy.png
Before Width: | Height: | Size: 202 KiB |
BIN
Images/Juls.png
Before Width: | Height: | Size: 157 KiB |
Before Width: | Height: | Size: 68 KiB |
Before Width: | Height: | Size: 67 KiB |
Before Width: | Height: | Size: 20 KiB |
Before Width: | Height: | Size: 201 KiB |
Before Width: | Height: | Size: 3.8 KiB |
BIN
Images/Miss.png
Before Width: | Height: | Size: 234 KiB |
BIN
Images/NBA.png
Before Width: | Height: | Size: 69 KiB |
Before Width: | Height: | Size: 1.4 KiB |
BIN
Images/NTV.png
Before Width: | Height: | Size: 1.8 KiB |
Before Width: | Height: | Size: 20 KiB |
BIN
Images/OK.png
Before Width: | Height: | Size: 2.1 KiB |
Before Width: | Height: | Size: 5.9 KiB |
Before Width: | Height: | Size: 141 KiB |
Before Width: | Height: | Size: 112 KiB |
Before Width: | Height: | Size: 101 KiB |
BIN
Images/TG.png
Before Width: | Height: | Size: 2.9 KiB |
BIN
Images/TV.png
Before Width: | Height: | Size: 300 KiB |
BIN
Images/VK.png
Before Width: | Height: | Size: 2.5 KiB |
Before Width: | Height: | Size: 1.0 MiB |
BIN
Images/Viber.png
Before Width: | Height: | Size: 3.6 KiB |
Before Width: | Height: | Size: 1.6 KiB |
BIN
Images/khl.png
Before Width: | Height: | Size: 97 KiB |
BIN
Images/match.png
Before Width: | Height: | Size: 3.8 KiB |
Before Width: | Height: | Size: 198 KiB |
Before Width: | Height: | Size: 13 KiB |
342
Katalog.html
@ -1,342 +0,0 @@
|
|||||||
<!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
@ -1,271 +0,0 @@
|
|||||||
<!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
@ -1,240 +0,0 @@
|
|||||||
<!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
@ -1,149 +0,0 @@
|
|||||||
.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;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
@ -1,162 +0,0 @@
|
|||||||
|
|
||||||
.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;
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,123 +0,0 @@
|
|||||||
.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
@ -1,144 +0,0 @@
|
|||||||
|
|
||||||
.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;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,91 +0,0 @@
|
|||||||
.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
@ -1,151 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
.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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,345 +0,0 @@
|
|||||||
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
@ -1,199 +0,0 @@
|
|||||||
.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) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -1,7 +0,0 @@
|
|||||||
.fa-trash, .fa-pen-to-square{
|
|
||||||
color: black;
|
|
||||||
}
|
|
||||||
|
|
||||||
.btn-success{
|
|
||||||
background: linear-gradient(135deg, #161616, #888);
|
|
||||||
}
|
|
279
TV.html
@ -1,279 +0,0 @@
|
|||||||
<!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>
|
|
@ -1,9 +0,0 @@
|
|||||||
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
@ -1,242 +0,0 @@
|
|||||||
<!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 +0,0 @@
|
|||||||
<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>
|
|
Before Width: | Height: | Size: 995 B |
@ -1,101 +0,0 @@
|
|||||||
// модуль для работы с 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
@ -1,140 +0,0 @@
|
|||||||
// модуль для работы с элементами управления
|
|
||||||
|
|
||||||
// объект для удобного получения элементов
|
|
||||||
// при обращении к атрибуту объекта вызывается
|
|
||||||
// нужная функция для поиска элемента
|
|
||||||
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
@ -1,263 +0,0 @@
|
|||||||
// модуль с логикой
|
|
||||||
|
|
||||||
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();
|
|
||||||
});
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
// модуль используется для валидации форма на странице
|
|
||||||
|
|
||||||
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
@ -1,24 +0,0 @@
|
|||||||
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
31
package.json
@ -1,31 +0,0 @@
|
|||||||
{
|
|
||||||
"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
@ -1,200 +0,0 @@
|
|||||||
<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 +0,0 @@
|
|||||||
<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>
|
|
Before Width: | Height: | Size: 1.5 KiB |
97
style.css
@ -1,97 +0,0 @@
|
|||||||
: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;
|
|
||||||
}
|
|
||||||
}
|
|