Foxix ebf23e4246 Update 103 files
- /public/file.svg
- /public/globe.svg
- /public/next.svg
- /public/vercel.svg
- /public/window.svg
- /public/google.svg
- /public/logo.png
- /src/eslint.config.mjs
- /src/api.ts
- /src/middleware.ts
- /src/app/favicon.ico
- /src/app/globals.css
- /src/app/layout.tsx
- /src/app/page.tsx
- /src/app/providers.tsx
- /src/app/not-found.tsx
- /src/app/error.tsx
- /src/app/metadata.ts
- /src/app/styles.tsx
- /src/app/api/auth/[...nextauth]/route.ts
- /src/app/api/auth/register/route.ts
- /src/app/api/auth/verify/route.ts
- /src/app/api/auth/check-verification/route.ts
- /src/app/api/auth/resend-code/route.ts
- /src/app/api/movies/search/route.ts
- /src/app/api/movies/sync/route.ts
- /src/app/api/admin/send-verification/route.ts
- /src/app/api/admin/verify-code/route.ts
- /src/app/api/admin/movies/route.ts
- /src/app/api/admin/movies/toggle-visibility/route.ts
- /src/app/api/admin/create/route.ts
- /src/app/api/admin/users/toggle-admin/route.ts
- /src/app/api/admin/toggle-admin/route.ts
- /src/app/login/page.tsx
- /src/app/login/LoginClient.tsx
- /src/app/verify/page.tsx
- /src/app/verify/VerificationClient.tsx
- /src/app/profile/page.tsx
- /src/app/movie/[id]/page.tsx
- /src/app/movie/[id]/MoviePage.tsx
- /src/app/movie/[id]/MovieContent.tsx
- /src/app/settings/page.tsx
- /src/app/tv/[id]/page.tsx
- /src/app/tv/[id]/TVShowPage.tsx
- /src/app/tv/[id]/TVShowContent.tsx
- /src/app/admin/login/page.tsx
- /src/app/admin/login/AdminLoginClient.tsx
- /src/lib/db.ts
- /src/lib/jwt.ts
- /src/lib/registry.tsx
- /src/lib/api.ts
- /src/lib/mongodb.ts
- /src/lib/mailer.ts
- /src/lib/auth.ts
- /src/lib/utils.ts
- /src/lib/email.ts
- /src/lib/movieSync.ts
- /src/models/User.ts
- /src/models/index.ts
- /src/models/Movie.ts
- /src/types/auth.ts
- /src/types/movie.ts
- /src/components/MovieCard.tsx
- /src/components/Notification.tsx
- /src/components/Pagination.tsx
- /src/components/GoogleIcon.tsx
- /src/components/StyleProvider.tsx
- /src/components/Providers.tsx
- /src/components/VerificationCodeInput.tsx
- /src/components/GlassCard.tsx
- /src/components/AppLayout.tsx
- /src/components/SearchModal.tsx
- /src/components/DarkReaderFix.tsx
- /src/components/ClientLayout.tsx
- /src/components/MenuItem.tsx
- /src/components/MoviePlayer.tsx
- /src/components/PageLayout.tsx
- /src/components/SettingsContent.tsx
- /src/components/Navbar.tsx
- /src/components/LayoutContent.tsx
- /src/components/SearchResults.tsx
- /src/components/Icons/Icons.tsx
- /src/components/Icons/HeartIcon.tsx
- /src/components/Icons/PlayIcon.tsx
- /src/components/admin/MovieSearch.tsx
- /src/hooks/useUser.ts
- /src/hooks/useMovies.ts
- /src/hooks/useSettings.ts
- /src/hooks/useSearch.ts
- /src/styles/GlobalStyles.ts
- /src/styles/GlobalStyles.tsx
- /src/providers/AuthProvider.tsx
- /src/data/movies.ts
- /types/next-auth.d.ts
- /middleware.ts
- /next.config.js
- /next-env.d.ts
- /package.json
- /postcss.config.mjs
- /README.md
- /tailwind.config.ts
- /tsconfig.json
- /package-lock.json
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-22 18:29:47 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00
2024-12-23 18:42:18 +00:00

🎬 Neo Movies

Neo Movies Logo

Современный онлайн-кинотеатр с удобным интерфейсом

📋 О проекте

Neo Movies - это современная веб-платформа для просмотра фильмов, построенная с использованием передовых технологий. Проект предлагает удобный интерфейс, быструю навигацию и множество функций для комфортного просмотра фильмов.

Основные возможности

  • 🎥 Три встроенных видеоплеера на выбор (Alloha, Collaps, Lumex)
  • 🔍 Умный поиск по фильмам
  • 📱 Адаптивный дизайн для всех устройств
  • 🌙 Темная тема
  • 👤 Система авторизации и профили пользователей
  • ❤️ Возможность добавлять фильмы в избранное
  • Быстрая загрузка и оптимизированная производительность

🛠 Технологии

  • Frontend:

    • Next.js 13+ (App Router)
    • React 18
    • TypeScript
    • Styled Components
    • NextAuth.js
  • Backend:

    • Next.js
    • MongoDB
    • Mongoose
  • Дополнительно:

    • ESLint
    • Prettier
    • Git
    • npm

Установка

  1. Клонируйте репозиторий:

    git clone https://github.com/your-username/neo-movies-web.git
    cd neo-movies-web
    
  2. Установите зависимости:

    npm install
    
  3. Создайте файл .env в корневой директории и добавьте следующие переменные:

    # База данных MongoDB
    MONGODB_URI=your_mongodb_uri
    
    # NextAuth конфигурация
    NEXTAUTH_SECRET=your_nextauth_secret
    NEXTAUTH_URL=http://localhost:3000
    
    # Google OAuth
    GOOGLE_CLIENT_ID=your_google_client_id
    GOOGLE_CLIENT_SECRET=your_google_client_secret
    
    # Email конфигурация (для подтверждения регистрации)
    GMAIL_USER=your_gmail@gmail.com
    GMAIL_APP_PASSWORD=your_app_specific_password
    
    # TMDB API (для получения информации о фильмах)
    NEXT_PUBLIC_TMDB_API_KEY=your_tmdb_api_key
    NEXT_PUBLIC_TMDB_ACCESS_TOKEN=your_tmdb_access_token
    
    # JWT конфигурация
    JWT_SECRET=your_jwt_secret
    
    # Lumex Player URL
    NEXT_PUBLIC_LUMEX_URL=your_lumex_player_url
    
  4. Запустите проект:

    # Режим разработки
    npm run dev
    
    # Сборка для продакшена
    npm run build
    npm start
    

Получение API ключей

TMDB API

  1. Создайте аккаунт на TMDB
  2. Перейдите в настройки профиля -> API
  3. Создайте новое API приложение
  4. Скопируйте API ключ и Access Token

Google OAuth

  1. Перейдите в Google Cloud Console
  2. Создайте новый проект
  3. Включите Google OAuth API
  4. Создайте учетные данные OAuth 2.0
  5. Добавьте разрешенные URI перенаправления:

Gmail App Password

  1. Включите двухфакторную аутентификацию в аккаунте Google
  2. Перейдите в настройки безопасности
  3. Создайте пароль приложения
  4. Используйте этот пароль в GMAIL_APP_PASSWORD

Разработка

Структура проекта

neo-movies-web/
├── src/
│   ├── app/            # App Router pages
│   ├── components/     # React компоненты
│   ├── hooks/          # React хуки
│   ├── lib/           # Утилиты и API
│   ├── models/        # MongoDB модели
│   └── styles/        # Глобальные стили
├── public/            # Статические файлы
└── package.json

👥 Авторы

  • Frontend Developer - Foxix

📄 Лицензия

Этот проект распространяется под лицензией MIT. Подробности в файле LICENSE.

🤝 Участие в проекте

Мы приветствуем любой вклад в развитие проекта! Если у вас есть предложения по улучшению:

  1. Форкните репозиторий
  2. Создайте ветку для ваших изменений
  3. Внесите изменения
  4. Отправьте pull request

📞 Контакты

Если у вас возникли вопросы или предложения, свяжитесь с нами:


Made with ❤️ by Foxix

Description
No description provided
Readme Apache-2.0 1.1 MiB
Languages
TypeScript 98.8%
JavaScript 0.8%
CSS 0.4%