From 2ef874c74bb4b4381205695cd5d70d688ca0ffa1 Mon Sep 17 00:00:00 2001 From: Kamlendra Singh Date: Mon, 6 May 2024 13:47:10 +0200 Subject: [PATCH] Add files via upload --- app/_components/about/appbar.jsx | 99 ++ app/_components/about/card.jsx | 39 + app/_components/about/cardgrid.jsx | 73 ++ app/_components/about/images.jsx | 94 ++ app/_components/about/text.jsx | 30 + app/_components/browse/card.jsx | 101 +++ app/_components/courses/card.jsx | 35 + app/_components/courses/cardgrid.jsx | 242 +++++ app/_components/courses/swiper.jsx | 49 + app/_components/home/card.jsx | 143 +++ app/_components/home/cardgrid.jsx | 354 ++++++++ app/_components/home/dot.jsx | 128 +++ app/_components/play/swiper.tsx | 10 + app/_components/space/AddressForm.js | 190 ++++ app/_components/space/Checkout.js | 124 +++ app/_components/space/PaymentForm.js | 65 ++ app/_components/space/Review.js | 88 ++ app/_components/spaces/spaces.jsx | 81 ++ app/_components/watch/dot.js | 122 +++ app/_components/watch/download.jsx | 84 ++ app/_components/watch/share.jsx | 75 ++ app/_components/watch/subscribe.jsx | 20 + app/_components/watch/watch.jsx | 1239 ++++++++++++++++++++++++++ 23 files changed, 3485 insertions(+) create mode 100644 app/_components/about/appbar.jsx create mode 100644 app/_components/about/card.jsx create mode 100644 app/_components/about/cardgrid.jsx create mode 100644 app/_components/about/images.jsx create mode 100644 app/_components/about/text.jsx create mode 100644 app/_components/browse/card.jsx create mode 100644 app/_components/courses/card.jsx create mode 100644 app/_components/courses/cardgrid.jsx create mode 100644 app/_components/courses/swiper.jsx create mode 100644 app/_components/home/card.jsx create mode 100644 app/_components/home/cardgrid.jsx create mode 100644 app/_components/home/dot.jsx create mode 100644 app/_components/play/swiper.tsx create mode 100644 app/_components/space/AddressForm.js create mode 100644 app/_components/space/Checkout.js create mode 100644 app/_components/space/PaymentForm.js create mode 100644 app/_components/space/Review.js create mode 100644 app/_components/spaces/spaces.jsx create mode 100644 app/_components/watch/dot.js create mode 100644 app/_components/watch/download.jsx create mode 100644 app/_components/watch/share.jsx create mode 100644 app/_components/watch/subscribe.jsx create mode 100644 app/_components/watch/watch.jsx diff --git a/app/_components/about/appbar.jsx b/app/_components/about/appbar.jsx new file mode 100644 index 0000000..96ff590 --- /dev/null +++ b/app/_components/about/appbar.jsx @@ -0,0 +1,99 @@ +"use client" +import * as React from 'react'; +import Appbar from '@mui/material/AppBar'; +import Box from '@mui/material/Box'; +import Toolbar from '@mui/material/Toolbar'; +import IconButton from '@mui/material/IconButton'; +import Typography from '@mui/material/Typography'; +import Menu from '@mui/material/Menu'; +import MenuIcon from '@mui/icons-material/Menu'; +import Container from '@mui/material/Container'; +import Avatar from '@mui/material/Avatar'; +import Button from '@mui/material/Button'; +import Tooltip from '@mui/material/Tooltip'; +import MenuItem from '@mui/material/MenuItem'; +import AdbIcon from '@mui/icons-material/Adb'; + +const pages = [ 'How Code Press Works','Creators','Products', 'Blog']; +const settings = ['Profile', 'Account', 'Dashboard', 'Logout']; + +function ResponsiveAppBar() { + const [anchorElNav, setAnchorElNav] = React.useState(null); + const [anchorElUser, setAnchorElUser] = React.useState(null); + + const handleOpenNavMenu = (event) => { + setAnchorElNav(event.currentTarget); + }; + const handleOpenUserMenu = (event) => { + setAnchorElUser(event.currentTarget); + }; + + const handleCloseNavMenu = () => { + setAnchorElNav(null); + }; + + const handleCloseUserMenu = () => { + setAnchorElUser(null); + }; + + return ( + + + + + + + + + + + LOGO + + + {pages.map((page) => ( + + ))} + + + + + + + ); +} +export default ResponsiveAppBar; \ No newline at end of file diff --git a/app/_components/about/card.jsx b/app/_components/about/card.jsx new file mode 100644 index 0000000..61886f5 --- /dev/null +++ b/app/_components/about/card.jsx @@ -0,0 +1,39 @@ +import * as React from 'react'; +import Card from '@mui/material/Card'; +import CardActions from '@mui/material/CardActions'; +import CardContent from '@mui/material/CardContent'; +import CardMedia from '@mui/material/CardMedia'; +import Button from '@mui/material/Button'; +import Typography from '@mui/material/Typography'; +import Grid from '@mui/material/Unstable_Grid2'; + +export default function ImgMediaCard(props) { + return ( + + + + + + + {props.t} + + + {props.tt} + + + + + + + + + + + ); +} \ No newline at end of file diff --git a/app/_components/about/cardgrid.jsx b/app/_components/about/cardgrid.jsx new file mode 100644 index 0000000..d0df538 --- /dev/null +++ b/app/_components/about/cardgrid.jsx @@ -0,0 +1,73 @@ +import React from 'react' +import Card from './card' +function CardGrid() { + return( + <> + { + messages.map(({ i,t,tt}) => ( + + <> + +
+ + +
+ + + + )) + } + + + ) + +} +export default CardGrid + +const messages = [ + { + + + i: 'https://abnresource.com/wp-content/uploads/2021/05/We-are-carbon-positive-LinkedIn.png', + t: 'We are carbon neutral', + tt: 'We are the worlds 1st e-company to achive the title of 100% carbon neutral.', + + }, + + + { + i: 'https://assets.codepen.io/14089/internal/screenshots/pens/ZEBYEOm.default.png?fit=cover&format=auto&ha=true&height=540&quality=75&v=2&version=1613843076&width=960', + t: 'Right to Code', + tt: 'Through our Nap Learning program we are helping millions to Learn to code.', + + }, + + { + i: 'https://media.istockphoto.com/photos/variety-of-raw-black-angus-prime-meat-steaks-picture-id923692030?k=20&m=923692030&s=612x612&w=0&h=k-b2wtmHwBbpmSM74dN0gZzRD9oEwBUYiXdlWYD6mHY=', + t: 'No Meat', + tt: 'Since meat contribute in 15% in Global carbon footprint we are no longer providing meat to our employees.', + + }, + { + i: 'https://c1.wallpaperflare.com/preview/41/972/836/people-work-hands-business.jpg', + t: 'We hire without degree', + tt: 'We belive degree or any kind of certificate is not necessary to get a job.', + + }, + { + i: 'https://ocdn.eu/images/pulscms/YmI7MDA_/dae186791f35a41f702b11fe648b79b4.jpg', + t: 'Unemployment', + tt: 'Today a large quator of worlds population suffers from Unemployment and we are commeted to solve it.', + + }, + { + i: 'https://static-cse.canva.com/blob/558554/studyingtips1.4762374a.jpg', + t: 'Get scholarship (NSAT)', + tt: 'NSAT (NAP SCHOLARSHIP ADMISSION TEST)', + + }, + + + + ]; \ No newline at end of file diff --git a/app/_components/about/images.jsx b/app/_components/about/images.jsx new file mode 100644 index 0000000..f8b9dbc --- /dev/null +++ b/app/_components/about/images.jsx @@ -0,0 +1,94 @@ +import * as React from 'react'; +import ImageList from '@mui/material/ImageList'; +import ImageListItem from '@mui/material/ImageListItem'; + +function srcset(image, size, rows = 1, cols = 1) { + return { + src: `${image}?w=${size * cols}&h=${size * rows}&fit=crop&auto=format`, + srcSet: `${image}?w=${size * cols}&h=${ + size * rows + }&fit=crop&auto=format&dpr=2 2x`, + }; +} + +export default function QuiltedImageList() { + return ( + + {itemData.map((item) => ( + + {item.title} + + ))} + + ); +} + +const itemData = [ + { + img: 'https://images.unsplash.com/photo-1451187580459-43490279c0fa?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=872&q=80', + title: 'Earth', + rows: 2, + cols: 2, + }, + { + img: 'https://images.unsplash.com/photo-1518770660439-4636190af475?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=870&q=80', + title: 'Electronics', + }, + { + img: 'https://images.unsplash.com/photo-1557853197-aefb550b6fdc?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=435&q=80', + title: 'Code', + }, + { + img: 'https://images.unsplash.com/photo-1517420704952-d9f39e95b43e?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=870&q=80', + title: 'Electronicswire', + cols: 2, + }, + { + img: 'https://images.unsplash.com/photo-1576141546153-3e04370b5ff7?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=924&q=80', + title: 'Chip', + cols: 2, + }, + { + img: 'https://images.unsplash.com/photo-1593349480506-8433634cdcbe?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=870&q=80', + title: 'sata', + author: '@arwinneil', + rows: 2, + cols: 2, + }, + { + img: 'https://images.unsplash.com/photo-1633957897986-70e83293f3ff?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=393&q=80', + title: 'aired', + }, + { + img: 'https://images.unsplash.com/photo-1543967708-2418d2e7748c?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=870&q=80', + title: 'Fern', + }, + { + img: 'https://images.unsplash.com/photo-1667487935540-f59515f6c7fd?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=981&q=80', + title: 'Mushrooms', + rows: 2, + cols: 2, + }, + { + img: 'https://images.unsplash.com/photo-1642229407991-e28d009cb968?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=773&q=80', + title: 'Tomato basil', + }, + { + img: 'https://images.unsplash.com/photo-1651340765216-ba02df201308?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=870&q=80', + title: 'Sea star', + }, + { + img: 'https://images.unsplash.com/photo-1563207153-f403bf289096?ixlib=rb-4.0.3&ixid=MnwxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8&auto=format&fit=crop&w=871&q=80', + title: 'Bike', + cols: 2, + }, +]; \ No newline at end of file diff --git a/app/_components/about/text.jsx b/app/_components/about/text.jsx new file mode 100644 index 0000000..0df7810 --- /dev/null +++ b/app/_components/about/text.jsx @@ -0,0 +1,30 @@ +import * as React from 'react'; +import Box from '@mui/material/Box'; +import Typography from '@mui/material/Typography'; +import Grid from '@mui/material/Unstable_Grid2'; +export default function Types() { + return ( + + + + + About FossTube + + + + + Our mission is to give everyone a Power to Code The World. + + + + + We believe that everyone deserves to have a Open Source, + and that the world is a better place when we contribute to it and make it accessible for Everyone. + + + + + + ); +} diff --git a/app/_components/browse/card.jsx b/app/_components/browse/card.jsx new file mode 100644 index 0000000..56e71bd --- /dev/null +++ b/app/_components/browse/card.jsx @@ -0,0 +1,101 @@ +"use client" +import * as React from 'react'; +import { styled } from '@mui/material/styles'; +import Card from '@mui/material/Card'; +import CardHeader from '@mui/material/CardHeader'; +import CardMedia from '@mui/material/CardMedia'; +import CardContent from '@mui/material/CardContent'; +import CardActions from '@mui/material/CardActions'; +import Collapse from '@mui/material/Collapse'; +import Avatar from '@mui/material/Avatar'; +import IconButton from '@mui/material/IconButton'; +import Typography from '@mui/material/Typography'; +import { red } from '@mui/material/colors'; +import FavoriteIcon from '@mui/icons-material/Favorite'; +import ShareIcon from '@mui/icons-material/Share'; +import ExpandMoreIcon from '@mui/icons-material/ExpandMore'; +import MoreVertIcon from '@mui/icons-material/MoreVert'; +import Button from '@mui/material/Button'; + +const ExpandMore = styled((props) => { + const { expand, ...other } = props; + return ; +})(({ theme, expand }) => ({ + transform: !expand ? 'rotate(0deg)' : 'rotate(180deg)', + marginLeft: 'auto', + transition: theme.transitions.create('transform', { + duration: theme.transitions.duration.shortest, + }), +})); + +export default function RecipeReviewCard() { + const [expanded, setExpanded] = React.useState(false); + + const handleExpandClick = () => { + setExpanded(!expanded); + }; + + return ( + + + k + + } + action={ + + + + } + title="ksingh" + subheader="nextjs developer." + /> + + + + Hey i am a nextjs developer, i hav + + + + + + + + + + Method: + + Heat 1/2 cup of the broth in a pot until simmering, add saffron and set + aside for 10 minutes. + + + Heat oil in a (14- to 16-inch) paella pan or a large, deep skillet over + medium-high heat. Add chicken, shrimp and chorizo, and cook, stirring + occasionally until lightly browned, 6 to 8 minutes. Transfer shrimp to a + large plate and set aside, leaving chicken and chorizo in the pan. Add + pimentón, bay leaves, garlic, tomatoes, onion, salt and pepper, and cook, + stirring often until thickened and fragrant, about 10 minutes. Add + saffron broth and remaining 4 1/2 cups chicken broth; bring to a boil. + + + Add rice and stir very gently to distribute. Top with artichokes and + peppers, and cook without stirring, until most of the liquid is absorbed, + 15 to 18 minutes. Reduce heat to medium-low, add reserved shrimp and + mussels, tucking them down into the rice, and cook again without + stirring, until mussels have opened and rice is just tender, 5 to 7 + minutes more. (Discard any mussels that don't open.) + + + Set aside off of the heat to let rest for 10 minutes, and then serve. + + + + + ); +} diff --git a/app/_components/courses/card.jsx b/app/_components/courses/card.jsx new file mode 100644 index 0000000..0822efb --- /dev/null +++ b/app/_components/courses/card.jsx @@ -0,0 +1,35 @@ +import Card from "@mui/material/Card"; +import CardContent from "@mui/material/CardContent"; +import CardMedia from "@mui/material/CardMedia"; +import Typography from "@mui/material/Typography"; +import { Button, CardActionArea, CardActions } from "@mui/material"; +import Link from "next/link"; +export default function Co(props) { + return ( + + + + + + + {props.t} + + + {props.d} + + + + + + + + + ); +} diff --git a/app/_components/courses/cardgrid.jsx b/app/_components/courses/cardgrid.jsx new file mode 100644 index 0000000..d920e4e --- /dev/null +++ b/app/_components/courses/cardgrid.jsx @@ -0,0 +1,242 @@ +"use client" +import * as React from 'react'; +import Card from "./card"; +import { experimentalStyled as styled } from '@mui/material/styles'; +import Paper from '@mui/material/Paper'; +import styles from "../../_styles/Courses.module.css"; +function refreshMessages() { + const getRandomInt = (max) => Math.floor(Math.random() * Math.floor(max)); + // Array.from(new Array(40)) + return messageExamples.map( + () => messageExamples[getRandomInt(messageExamples.length)], + ); +} +const Item = styled(Paper)(({ theme }) => ({ + ...theme.typography.body2, + padding: theme.spacing(2), + textAlign: 'center', + color: theme.palette.text.secondary, +})); +export default function Icourses() { + const [value, setValue] = React.useState(0); + const ref = React.useRef(null); + const [messages, setMessages] = React.useState(() => refreshMessages()); + + React.useEffect(() => { + setMessages(refreshMessages()); + }, [value, setMessages]); + + + return ( + + + <> + + + { + messages.map(({ d, i, t,l }) => ( + + <>
+ + + + + + +
+ + )) + } + + + + + ); +} + + + + + +const messageExamples = [ + { + + t: 'HTML.', + i: '/html.png', + d: 'Learn HTML from basic.', + l:'Courses/HTML' + + }, + + { + + t: 'CSS.', + i: '', + d: 'Learn CSS from basic', + l:'Courses/CSS' + + }, + + + { + + t: 'JavaScript.', + i: '/js.png', + d: 'Learn JavaScript from basic.', + l:'Courses/JavaScript' + + + }, + + { + + t: 'Figma.', + i: '/Figma.svg', + d: 'Learn Figma from basic', + l:'Courses/Figma' + + }, + + { + + t: 'React JS.', + i: 'https://en.karabayyazilim.com/uploads/blogs/reactjs-nedir-2019-06-24-091546/reactjs-nedir-2019-06-24-091546-0.jpg', + d: 'This series will cover React from starting to the end. You will learn react from the ground up.', + l:'Courses/React-Js' + + }, { + + t: 'React Native.', + i: 'https://miro.medium.com/max/700/1*C3kxjCrJy-aWSMpe2chfaA.png', + d: 'This series will cover React Native from starting to the end. You will learn react from the ground up.', + l:'Courses/React-Native' + + }, + + { + + t: 'Python.', + i: 'https://miro.medium.com/max/700/1*C3kxjCrJy-aWSMpe2chfaA.png', + d: 'Learn Python Programs With Logic.', + l:'Courses/Python' + + }, + + + + { + + t: 'java.', + i: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTJ7LFrSTpn-hmIh_YMy1AXub7S8-6aiJQB9w&usqp=CAU', + d: 'This series will cover Java from starting to the end. You will learn java from the start to the end.', + l:'Courses/java' + + }, + + { + + t: 'Learn C Simple & Clean.', + i: 'https://nareshit.com/wp-content/uploads/2018/08/C-Programming-online-training-nareshit.jpg', + d: 'This series contains programs for you to practice C Programming and related concepts', + l:'Courses/C-Language' + + }, { + + t: 'Learn Data Structures and Algorithms.', + i: '', + d: 'Data Structures and algorithms course', + l:'Courses/Data-Structures-and-algorithms-course' + + }, { + + t: 'Learn PHP.', + i: '', + d: 'PHP Tutorials', + l:'Courses/PHP-Tutorials' + + }, { + + t: 'Learn C++.', + i: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQQuMi_FAtJ6_osAZcU3qzFKhmkAHYUcUD9sB8HboTWlAnhMLN8WgOODzksPSB4bgOBGp0&usqp=CAU', + d: 'C++ Tutorials', + l:'Courses/C++-Tutorials' + + }, { + + t: 'Web Development.', + i: '', + d: 'Web Development For Beginners HTML, CSS, JavaScript & More', + l:'Courses/Web-Development' + + }, { + + t: 'Complete Git.', + i: 'https://tatsuno-system.co.jp/wp-content/uploads/2020/06/git-command.png', + d: 'Learn Git For Beginners', + l:'Courses/Complete-Git' + + }, { + + t: 'Android Development from bases.', + i: '', + d: 'Learn to create native android applications.', + l:'Courses/Android-Development' + + }, { + + t: 'Learn Python & Django.', + i: 'https://miro.medium.com/max/1200/1*slHeZngyeUr7ypEz7MNL5w.png', + d: 'Python Django Tutorials', + l:'Courses/Python-Django' + + }, { + + t: 'Python GUI Tkinter.', + i: 'https://d1zx6djv3kb1v7.cloudfront.net/wp-content/media/2020/08/Building-Desktop-ApplicationGUI-Using-Python-and-Tkinter.jpg', + d: 'Python GUI Tkinter Tutorials', + l:'Courses/Python-GUI-Tkinter' + + }, { + + t: 'Game Development with python.', + i: 'https://dg53gp9bd7dcq.cloudfront.net/files/2750/icon/1423556780_720_20.jpg', + d: 'Python Game Development Using Pygame', + l:'Courses/Python-Game-Development' + + }, { + + t: 'Machine Learning with Python', + i: 'https://tutoraj.com/wp-content/uploads/2021/04/20190903-MachineLearning.jpg', + d: 'Machine Learning Tutorials For Beginners Using Python', + l:'Courses/Machine-Learning' + + }, { + + t: 'Basic Python Programs.', + i: 'https://www.maxupskill.com/media/course/python.jpg', + d: 'Basic Python Programs With Code', + l:'Courses/Basic-Python-Programs' + + }, { + + t: 'Web Development Using Flask and Python.', + i: 'https://tutsnode.com/wp-content/uploads/2021/05/Learn-Flask-A-web-Development-Framework-of-Python.jpg', + d: 'Web Development Using Flask and Python', + l:'Courses/Web-Development-Using-Flask-and-Python' + + }, + + + + + + + + + + + + + + +]; diff --git a/app/_components/courses/swiper.jsx b/app/_components/courses/swiper.jsx new file mode 100644 index 0000000..987e023 --- /dev/null +++ b/app/_components/courses/swiper.jsx @@ -0,0 +1,49 @@ +"use client"; +import React, { useRef, useState } from "react"; +import { Swiper, SwiperSlide } from "swiper/react"; +import "swiper/css"; +import "swiper/css/pagination"; +import "swiper/css/navigation"; +import styles from "../../_styles/Courses.module.css"; +import { Autoplay, Pagination, Navigation } from +'swiper/modules'; + +export default function App() { + return ( + + + no internet + + + no internet + + + no internet + + + no internet + + + no internet + + + no internet + + + + ); +} diff --git a/app/_components/home/card.jsx b/app/_components/home/card.jsx new file mode 100644 index 0000000..d7a4f12 --- /dev/null +++ b/app/_components/home/card.jsx @@ -0,0 +1,143 @@ +"use client"; +import * as React from "react"; +import Avatar from "@mui/material/Avatar"; +import IconButton from "@mui/material/IconButton"; +import Typography from "@mui/material/Typography"; +import CircleIcon from "@mui/icons-material/Circle"; +import CheckCircleIcon from "@mui/icons-material/CheckCircle"; +import Grid from "@mui/material/Unstable_Grid2"; +import Paper from "@mui/material/Paper"; +import Dot from "./dot"; +import Link from "next/link"; +import { + useTheme, + styled, + createTheme, + ThemeProvider, +} from "@mui/material/styles"; +import HoverVideoPlayer from "react-hover-video-player"; + +const darkTheme = createTheme({ + palette: { + mode: "dark", + }, +}); +const mdTheme = createTheme(); +export default function Component(props) { + const [mode, setMode] = React.useState("light"); + const colorMode = React.useMemo( + () => ({ + toggleColorMode: () => { + setMode((prevMode) => (prevMode === "light" ? "dark" : "light")); + }, + }), + [] + ); + + const theme = React.useMemo( + () => + createTheme({ + palette: { + mode, + }, + }), + [mode] + ); + + return ( + + + + + + } + loadingOverlay={ +
+
+
+ } + /> + + + + + + + + + + {props.heading} + + + + + {props.channel} + + + + + + {props.view} + {props.date} + + + + + + + + + + + + + + + + + + ); +} \ No newline at end of file diff --git a/app/_components/home/cardgrid.jsx b/app/_components/home/cardgrid.jsx new file mode 100644 index 0000000..043017a --- /dev/null +++ b/app/_components/home/cardgrid.jsx @@ -0,0 +1,354 @@ +"use client"; +import * as React from "react"; +import Card from "./card"; +import { experimentalStyled as styled } from "@mui/material/styles"; +import Paper from "@mui/material/Paper"; +import styles from "../../_styles/Courses.module.css"; +function refreshMessages() { + const getRandomInt = (max) => Math.floor(Math.random() * Math.floor(max)); + // Array.from(new Array(40)) + return messageExamples.map( + () => messageExamples[getRandomInt(messageExamples.length)] + ); +} +const Item = styled(Paper)(({ theme }) => ({ + ...theme.typography.body2, + padding: theme.spacing(2), + textAlign: "center", + color: theme.palette.text.secondary, +})); +export default function Icourses() { + const [value, setValue] = React.useState(0); + const ref = React.useRef(null); + const [messages, setMessages] = React.useState(() => refreshMessages()); + + React.useEffect(() => { + setMessages(refreshMessages()); + }, [value, setMessages]); + + return ( + <> + {messages.map( + ({ img, l, video, heading, avatar, date, channel, view }) => ( + <> +
+ +
+ + ) + )} + + ); +} +const messageExamples = [ + { + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd1.jpg", + video: "/video.mp4", + heading: "$20K vs $2,000,000 Hybrid Car!", + avatar: "/amkbhd.jpg", + date: " 8 days ago", + view: "2.8M views", + channel: "Marques Brownlee", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd2.jpg", + video: "/3.mp4", + heading: "Here's the Thing about the M3 Macbook Air...", + avatar: "/amkbhd.jpg", + date: "1 day ago", + view: "3.5M views", +channel: "Marques Brownlee", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd3.jpg", + video: "/3.mp4", + heading: "Tesla Cybertruck Review: Already Iconic?", + avatar: "/amkbhd.jpg", + date: "6 day ago", + view: "3.3M views", +channel: "Marques Brownlee", + link: "/watch", +}, +{ + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd4.jpg", + video: "/3.mp4", + heading: "Google Pixel 8/8 Pro Review: We'll Fix It In Post!", + avatar: "/amkbhd.jpg", + date: "9 day ago", + view: "4.2M views", +channel: "Marques Brownlee", + link: "/watch", +}, +{ + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd5.jpg", + video: "/3.mp4", + heading: "I Tried a Disney Secret Project!", + avatar: "/amkbhd.jpg", + date: "9 days ago", + view: "5.9M views", +channel: "Marques Brownlee", + link: "/watch", +}, + + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa1.jpg", + video: "/2.mp4", + heading: "We Are Going", + avatar: "/nasa.jpg", + date: " 2 min ago", + view: "17M views ", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa2.jpg", + video: "/2.mp4", + heading: "How We Are Going to the Moon - 4K", + avatar: "/nasa.jpg", + date: " 4 years ago", + view: "10M views", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa3.jpg", + video: "/2.mp4", + heading: "Welcome Back! Discovery Lands Safely at Kennedy", + avatar: "/nasa.jpg", + date: "14 years ago", + view: "4.4M views", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa4.jpg", + video: "/3.mp4", + heading: "NASA Artemis Lunar Terrain Vehicle (Official NASA Trailer)", + avatar: "/nasa.jpg", + date: " 1 month ago", + view: "17K views ", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa5.jpg", + video: "/4.mp4", + heading: "NASA Astronauts Aboard Space Station Huddle Up for Super Bowl", + avatar: "/nasa.jpg", + date: " 2 months ago", + view: "14K views ", +channel: "NASA", + link: "/watch", + },{ + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd1.jpg", + video: "/video.mp4", + heading: "$20K vs $2,000,000 Hybrid Car!", + avatar: "/amkbhd.jpg", + date: " 3 days ago", + view: "2.8M views", + channel: "Marques Brownlee", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd2.jpg", + video: "/3.mp4", + heading: "Here's the Thing about the M3 Macbook Air...", + avatar: "/amkbhd.jpg", + date: "1 month ago", + view: "3.5M views", +channel: "Marques Brownlee", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd3.jpg", + video: "/3.mp4", + heading: "Tesla Cybertruck Review: Already Iconic?", + avatar: "/amkbhd.jpg", + date: "1 month ago", + view: "3.3M views", +channel: "Marques Brownlee", + link: "/watch", +}, +{ + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd4.jpg", + video: "/3.mp4", + heading: "Google Pixel 8/8 Pro Review: We'll Fix It In Post!", + avatar: "/amkbhd.jpg", + date: "6 month ago", + view: "4.2M views", +channel: "Marques Brownlee", + link: "/watch", +}, +{ + l: "Courses/Python-GUI-Tkinter", + img: "/mkbhd5.jpg", + video: "/3.mp4", + heading: "I Tried a Disney Secret Project!", + avatar: "/amkbhd.jpg", + date: "9 days ago", + view: "5.9M views", +channel: "Marques Brownlee", + link: "/watch", +}, + + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa1.jpg", + video: "/2.mp4", + heading: "We Are Going (Official NASA Trailer)", + avatar: "/nasa.jpg", + date: " 2 min ago", + view: "17M views ", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa2.jpg", + video: "/2.mp4", + heading: "How We Are Going to the Moon - 4K", + avatar: "/nasa.jpg", + date: " 4 years ago", + view: "10M views", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa3.jpg", + video: "/2.mp4", + heading: "Welcome Back! Discovery Lands Safely at Kennedy", + avatar: "/nasa.jpg", + date: "14 years ago", + view: "4.4M views", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa4.jpg", + video: "/3.mp4", + heading: "NASA Artemis Lunar Terrain Vehicle (Official NASA Trailer)", + avatar: "/nasa.jpg", + date: " 1 month ago", + view: "17K views ", +channel: "NASA", + link: "/watch", + }, + { + l: "Courses/Python-GUI-Tkinter", + img: "/nasa5.jpg", + video: "/4.mp4", + heading: "NASA Astronauts Aboard Space Station Huddle Up for Super Bowl", + avatar: "/nasa.jpg", + date: " 2 months ago", + view: "14K views ", +channel: "NASA", + link: "/watch", + }, + +]; + +{ + /*
+ +
*/ +} +// +// ); +// } + +// import * as React from "react"; +// import Card from "./card"; +// import styles from "../../styles/Courses.module.css"; +// import youtubeService from '../../services/youtube'; +// export async function getServerSideProps() { +// const playlistId = 'PLMElh5YpJilZCEzu6OhfbsLYPJYz5TACL'; // Replace with your actual YouTube playlist ID +// const response = await youtubeService.playlistItems.list({ +// part: 'snippet', +// maxResults: 50, // Set the number of videos you want to retrieve +// playlistId, +// }); + +// const playlistItems = response.data.items; + +// return { +// props: { playlistItems }, +// }; +// } + +// function PlaylistPage({ playlistItems }) { +// return ( +//
+//

YouTube Playlist

+// +//
+// ); +// } + +// export default PlaylistPage; + +{ + /*
+ +
*/ +} diff --git a/app/_components/home/dot.jsx b/app/_components/home/dot.jsx new file mode 100644 index 0000000..c473264 --- /dev/null +++ b/app/_components/home/dot.jsx @@ -0,0 +1,128 @@ +import * as React from 'react'; +import Box from '@mui/material/Box'; +import Avatar from '@mui/material/Avatar'; +import Menu from '@mui/material/Menu'; +import MenuItem from '@mui/material/MenuItem'; +import ListItemIcon from '@mui/material/ListItemIcon'; +import Divider from '@mui/material/Divider'; +import IconButton from '@mui/material/IconButton'; +import Typography from '@mui/material/Typography'; +import Tooltip from '@mui/material/Tooltip'; +import PersonAdd from '@mui/icons-material/PersonAdd'; +import Settings from '@mui/icons-material/Settings'; +import Logout from '@mui/icons-material/Logout'; +import MoreVertIcon from '@mui/icons-material/MoreVert'; +import QueueOutlinedIcon from '@mui/icons-material/QueueOutlined'; +import HistoryIcon from '@mui/icons-material/History'; +import PlaylistAddOutlinedIcon from '@mui/icons-material/PlaylistAddOutlined'; +import FileDownloadOutlinedIcon from '@mui/icons-material/FileDownloadOutlined'; +import ShareOutlinedIcon from '@mui/icons-material/ShareOutlined'; +import BlockOutlinedIcon from '@mui/icons-material/BlockOutlined'; +import RemoveCircleOutlineOutlinedIcon from '@mui/icons-material/RemoveCircleOutlineOutlined'; +import OutlinedFlagIcon from '@mui/icons-material/OutlinedFlag'; +export default function AccountMenu() { + const [anchorEl, setAnchorEl] = React.useState(null); + const open = Boolean(anchorEl); + const handleClick = (event) => { + setAnchorEl(event.currentTarget); + }; + const handleClose = () => { + setAnchorEl(null); + }; + return ( + + + + + + + + + + + + + + Add to queue + + + + + + Save to Watch later + + + + + + Save to playlist + + + + + + Download + + + + + + Share + + + + + + + Not interested + + + + + + Don't recommend space + + + + + + Report + + + + ); +} \ No newline at end of file diff --git a/app/_components/play/swiper.tsx b/app/_components/play/swiper.tsx new file mode 100644 index 0000000..9086302 --- /dev/null +++ b/app/_components/play/swiper.tsx @@ -0,0 +1,10 @@ + +export default function Play(){ +return( +<> +

FossTube
Play

+ + +); + +} \ No newline at end of file diff --git a/app/_components/space/AddressForm.js b/app/_components/space/AddressForm.js new file mode 100644 index 0000000..75b6046 --- /dev/null +++ b/app/_components/space/AddressForm.js @@ -0,0 +1,190 @@ +import * as React from 'react'; +import Grid from '@mui/material/Grid'; +import Typography from '@mui/material/Typography'; +import TextField from '@mui/material/TextField'; +import FormControlLabel from '@mui/material/FormControlLabel'; +import Checkbox from '@mui/material/Checkbox'; +import Chip from '@mui/material/Chip'; +import Autocomplete from '@mui/material/Autocomplete'; +export default function AddressForm() { + return ( + + + About your space + + + + + + + + + + option.title} + defaultValue={[top100Films[13]]} + renderInput={(params) => ( + + )}/> + + + } + label="Use this channel as my main space" + /> + + + + ); +} +// Top 100 films as rated by IMDb users. http://www.imdb.com/chart/top +const top100Films = [ + { title: 'The Shawshank Redemption', year: 1994 }, + { title: 'The Godfather', year: 1972 }, + { title: 'The Godfather: Part II', year: 1974 }, + { title: 'The Dark Knight', year: 2008 }, + { title: '12 Angry Men', year: 1957 }, + { title: "Schindler's List", year: 1993 }, + { title: 'Pulp Fiction', year: 1994 }, + { + title: 'The Lord of the Rings: The Return of the King', + year: 2003, + }, + { title: 'The Good, the Bad and the Ugly', year: 1966 }, + { title: 'Fight Club', year: 1999 }, + { + title: 'The Lord of the Rings: The Fellowship of the Ring', + year: 2001, + }, + { + title: 'Star Wars: Episode V - The Empire Strikes Back', + year: 1980, + }, + { title: 'Forrest Gump', year: 1994 }, + { title: 'Inception', year: 2010 }, + { + title: 'The Lord of the Rings: The Two Towers', + year: 2002, + }, + { title: "One Flew Over the Cuckoo's Nest", year: 1975 }, + { title: 'Goodfellas', year: 1990 }, + { title: 'The Matrix', year: 1999 }, + { title: 'Seven Samurai', year: 1954 }, + { + title: 'Star Wars: Episode IV - A New Hope', + year: 1977, + }, + { title: 'City of God', year: 2002 }, + { title: 'Se7en', year: 1995 }, + { title: 'The Silence of the Lambs', year: 1991 }, + { title: "It's a Wonderful Life", year: 1946 }, + { title: 'Life Is Beautiful', year: 1997 }, + { title: 'The Usual Suspects', year: 1995 }, + { title: 'Léon: The Professional', year: 1994 }, + { title: 'Spirited Away', year: 2001 }, + { title: 'Saving Private Ryan', year: 1998 }, + { title: 'Once Upon a Time in the West', year: 1968 }, + { title: 'American History X', year: 1998 }, + { title: 'Interstellar', year: 2014 }, + { title: 'Casablanca', year: 1942 }, + { title: 'City Lights', year: 1931 }, + { title: 'Psycho', year: 1960 }, + { title: 'The Green Mile', year: 1999 }, + { title: 'The Intouchables', year: 2011 }, + { title: 'Modern Times', year: 1936 }, + { title: 'Raiders of the Lost Ark', year: 1981 }, + { title: 'Rear Window', year: 1954 }, + { title: 'The Pianist', year: 2002 }, + { title: 'The Departed', year: 2006 }, + { title: 'Terminator 2: Judgment Day', year: 1991 }, + { title: 'Back to the Future', year: 1985 }, + { title: 'Whiplash', year: 2014 }, + { title: 'Gladiator', year: 2000 }, + { title: 'Memento', year: 2000 }, + { title: 'The Prestige', year: 2006 }, + { title: 'The Lion King', year: 1994 }, + { title: 'Apocalypse Now', year: 1979 }, + { title: 'Alien', year: 1979 }, + { title: 'Sunset Boulevard', year: 1950 }, + { + title: 'Dr. Strangelove or: How I Learned to Stop Worrying and Love the Bomb', + year: 1964, + }, + { title: 'The Great Dictator', year: 1940 }, + { title: 'Cinema Paradiso', year: 1988 }, + { title: 'The Lives of Others', year: 2006 }, + { title: 'Grave of the Fireflies', year: 1988 }, + { title: 'Paths of Glory', year: 1957 }, + { title: 'Django Unchained', year: 2012 }, + { title: 'The Shining', year: 1980 }, + { title: 'WALL·E', year: 2008 }, + { title: 'American Beauty', year: 1999 }, + { title: 'The Dark Knight Rises', year: 2012 }, + { title: 'Princess Mononoke', year: 1997 }, + { title: 'Aliens', year: 1986 }, + { title: 'Oldboy', year: 2003 }, + { title: 'Once Upon a Time in America', year: 1984 }, + { title: 'Witness for the Prosecution', year: 1957 }, + { title: 'Das Boot', year: 1981 }, + { title: 'Citizen Kane', year: 1941 }, + { title: 'North by Northwest', year: 1959 }, + { title: 'Vertigo', year: 1958 }, + { + title: 'Star Wars: Episode VI - Return of the Jedi', + year: 1983, + }, + { title: 'Reservoir Dogs', year: 1992 }, + { title: 'Braveheart', year: 1995 }, + { title: 'M', year: 1931 }, + { title: 'Requiem for a Dream', year: 2000 }, + { title: 'Amélie', year: 2001 }, + { title: 'A Clockwork Orange', year: 1971 }, + { title: 'Like Stars on Earth', year: 2007 }, + { title: 'Taxi Driver', year: 1976 }, + { title: 'Lawrence of Arabia', year: 1962 }, + { title: 'Double Indemnity', year: 1944 }, + { + title: 'Eternal Sunshine of the Spotless Mind', + year: 2004, + }, + { title: 'Amadeus', year: 1984 }, + { title: 'To Kill a Mockingbird', year: 1962 }, + { title: 'Toy Story 3', year: 2010 }, + { title: 'Logan', year: 2017 }, + { title: 'Full Metal Jacket', year: 1987 }, + { title: 'Dangal', year: 2016 }, + { title: 'The Sting', year: 1973 }, + { title: '2001: A Space Odyssey', year: 1968 }, + { title: "Singin' in the Rain", year: 1952 }, + { title: 'Toy Story', year: 1995 }, + { title: 'Bicycle Thieves', year: 1948 }, + { title: 'The Kid', year: 1921 }, + { title: 'Inglourious Basterds', year: 2009 }, + { title: 'Snatch', year: 2000 }, + { title: '3 Idiots', year: 2009 }, + { title: 'Monty Python and the Holy Grail', year: 1975 }, +]; \ No newline at end of file diff --git a/app/_components/space/Checkout.js b/app/_components/space/Checkout.js new file mode 100644 index 0000000..4f9d993 --- /dev/null +++ b/app/_components/space/Checkout.js @@ -0,0 +1,124 @@ +"use client" +import * as React from 'react'; +import CssBaseline from '@mui/material/CssBaseline'; +import AppBar from '@mui/material/AppBar'; +import Box from '@mui/material/Box'; +import Container from '@mui/material/Container'; +import Toolbar from '@mui/material/Toolbar'; +import Paper from '@mui/material/Paper'; +import Stepper from '@mui/material/Stepper'; +import Step from '@mui/material/Step'; +import StepLabel from '@mui/material/StepLabel'; +import Button from '@mui/material/Button'; +import Link from '@mui/material/Link'; +import Typography from '@mui/material/Typography'; +import AddressForm from './AddressForm'; +import PaymentForm from './PaymentForm'; +import Review from './Review'; + +function Copyright() { + return ( + + {'Copyright © '} + + FossTube + {' '} + {new Date().getFullYear()} + {'.'} + + ); +} + +const steps = ['Make a space', 'Earn Money', 'reCAPTCHA']; + +function getStepContent(step) { + switch (step) { + case 0: + return ; + case 1: + return ; + case 2: + return ; + default: + throw new Error('Unknown step'); + } +} + +export default function Checkout() { + const [activeStep, setActiveStep] = React.useState(0); + + const handleNext = () => { + setActiveStep(activeStep + 1); + }; + + const handleBack = () => { + setActiveStep(activeStep - 1); + }; + + return ( + + + `1px solid ${t.palette.divider}`, + }} + > + + + FossTube + + + + + + + Make A Space + + + {steps.map((label) => ( + + {label} + + ))} + + {activeStep === steps.length ? ( + + + Thank you for your order. + + + Your order number is #2001539. We have emailed your order + confirmation, and will send you an update when your order has + shipped. + + + ) : ( + + {getStepContent(activeStep)} + + {activeStep !== 0 && ( + + )} + + + + + )} + + + + + ); +} diff --git a/app/_components/space/PaymentForm.js b/app/_components/space/PaymentForm.js new file mode 100644 index 0000000..277ae03 --- /dev/null +++ b/app/_components/space/PaymentForm.js @@ -0,0 +1,65 @@ +import * as React from 'react'; +import Typography from '@mui/material/Typography'; +import Grid from '@mui/material/Grid'; +import TextField from '@mui/material/TextField'; +import FormControlLabel from '@mui/material/FormControlLabel'; +import Checkbox from '@mui/material/Checkbox'; + +export default function PaymentForm() { + return ( + + + Earn Money + + + + + + + + + + + + + + + + } + label="For human verification one-time 1$ will be deducted from your account ( Help us fight against botnet world )" + disabled checked/> + + + + ); +} diff --git a/app/_components/space/Review.js b/app/_components/space/Review.js new file mode 100644 index 0000000..139daca --- /dev/null +++ b/app/_components/space/Review.js @@ -0,0 +1,88 @@ +import * as React from 'react'; +import Typography from '@mui/material/Typography'; +import List from '@mui/material/List'; +import ListItem from '@mui/material/ListItem'; +import ListItemText from '@mui/material/ListItemText'; +import Grid from '@mui/material/Grid'; + +const products = [ + { + name: 'Product 1', + desc: 'A nice thing', + price: '$9.99', + }, + { + name: 'Product 2', + desc: 'Another thing', + price: '$3.45', + }, + { + name: 'Product 3', + desc: 'Something else', + price: '$6.51', + }, + { + name: 'Product 4', + desc: 'Best thing of all', + price: '$14.11', + }, + { name: 'Shipping', desc: '', price: 'Free' }, +]; + +const addresses = ['1 MUI Drive', 'Reactville', 'Anytown', '99999', 'USA']; +const payments = [ + { name: 'Card type', detail: 'Visa' }, + { name: 'Card holder', detail: 'Mr John Smith' }, + { name: 'Card number', detail: 'xxxx-xxxx-xxxx-1234' }, + { name: 'Expiry date', detail: '04/2024' }, +]; + +export default function Review() { + return ( + + + Order summary + + + {products.map((product) => ( + + + {product.price} + + ))} + + + + $34.06 + + + + + + + Shipping + + John Smith + {addresses.join(', ')} + + + + Payment details + + + {payments.map((payment) => ( + + + {payment.name} + + + {payment.detail} + + + ))} + + + + + ); +} diff --git a/app/_components/spaces/spaces.jsx b/app/_components/spaces/spaces.jsx new file mode 100644 index 0000000..cb2f405 --- /dev/null +++ b/app/_components/spaces/spaces.jsx @@ -0,0 +1,81 @@ +"use client" +import * as React from 'react'; +import AppBar from '@mui/material/AppBar'; +import Button from '@mui/material/Button'; +import CameraIcon from '@mui/icons-material/PhotoCamera'; +import Card from '@mui/material/Card'; +import CardActions from '@mui/material/CardActions'; +import CardContent from '@mui/material/CardContent'; +import CardMedia from '@mui/material/CardMedia'; +import CssBaseline from '@mui/material/CssBaseline'; +import Grid from '@mui/material/Grid'; +import Stack from '@mui/material/Stack'; +import Box from '@mui/material/Box'; +import Toolbar from '@mui/material/Toolbar'; +import Typography from '@mui/material/Typography'; +import Container from '@mui/material/Container'; +import Link from '@mui/material/Link'; +import { createTheme, ThemeProvider } from '@mui/material/styles'; +import { useState } from "react"; + + +const cards = [1, 2, 3, 4, 5, 6, 7, 8, 9]; + +// TODO remove, this demo shouldn't need to reset the theme. +const defaultTheme = createTheme(); + +export default function Album() { + const [active, setActive] = useState(false); + const handleClick = () => { + setActive(!active); + }; + return ( + <> + + + + +
+ + + + + + {/* End hero unit */} + + {cards.map((card) => ( + + + + + + FossTube + + + FossTube official channel. + + + + + + + + + ))} + + +
+ + + + ); +} diff --git a/app/_components/watch/dot.js b/app/_components/watch/dot.js new file mode 100644 index 0000000..048d030 --- /dev/null +++ b/app/_components/watch/dot.js @@ -0,0 +1,122 @@ +import * as React from 'react'; +import Box from '@mui/material/Box'; +import Avatar from '@mui/material/Avatar'; +import Menu from '@mui/material/Menu'; +import MenuItem from '@mui/material/MenuItem'; +import ListItemIcon from '@mui/material/ListItemIcon'; +import Divider from '@mui/material/Divider'; +import IconButton from '@mui/material/IconButton'; +import Typography from '@mui/material/Typography'; +import Tooltip from '@mui/material/Tooltip'; +import PersonAdd from '@mui/icons-material/PersonAdd'; +import Settings from '@mui/icons-material/Settings'; +import Logout from '@mui/icons-material/Logout'; +import MoreVertIcon from '@mui/icons-material/MoreVert'; +import Fab from '@mui/material/Fab'; +import MoreHorizOutlinedIcon from '@mui/icons-material/MoreHorizOutlined'; +import QueueOutlinedIcon from '@mui/icons-material/QueueOutlined'; +import HistoryIcon from '@mui/icons-material/History'; +import PlaylistAddOutlinedIcon from '@mui/icons-material/PlaylistAddOutlined'; +import FileDownloadOutlinedIcon from '@mui/icons-material/FileDownloadOutlined'; +import ShareOutlinedIcon from '@mui/icons-material/ShareOutlined'; +import BlockOutlinedIcon from '@mui/icons-material/BlockOutlined'; +import RemoveCircleOutlineOutlinedIcon from '@mui/icons-material/RemoveCircleOutlineOutlined'; +import OutlinedFlagIcon from '@mui/icons-material/OutlinedFlag'; +import VolunteerActivismOutlinedIcon from '@mui/icons-material/VolunteerActivismOutlined'; +import ContentCutOutlinedIcon from '@mui/icons-material/ContentCutOutlined'; +import SubtitlesOutlinedIcon from '@mui/icons-material/SubtitlesOutlined'; +export default function Dot() { + const [anchorEl, setAnchorEl] = React.useState(null); + const open = Boolean(anchorEl); + const handleClick = (event) => { + setAnchorEl(event.currentTarget); + }; + const handleClose = () => { + setAnchorEl(null); + }; + return ( + + + {/* + + */} + + + + + + + + + + + + + + Donate + + + + + + Clip + + + + + + Save + + + + + + Report + + + + + + Show Transcript + + + + + + + ); +} \ No newline at end of file diff --git a/app/_components/watch/download.jsx b/app/_components/watch/download.jsx new file mode 100644 index 0000000..8ca2d2c --- /dev/null +++ b/app/_components/watch/download.jsx @@ -0,0 +1,84 @@ +import * as React from 'react'; +import Fab from '@mui/material/Fab'; +import FileDownloadOutlinedIcon from "@mui/icons-material/FileDownloadOutlined"; +import Button from '@mui/material/Button'; +import Dialog from '@mui/material/Dialog'; +import DialogActions from '@mui/material/DialogActions'; +import DialogContent from '@mui/material/DialogContent'; +import DialogContentText from '@mui/material/DialogContentText'; +import DialogTitle from '@mui/material/DialogTitle'; +import useMediaQuery from '@mui/material/useMediaQuery'; +import { useTheme } from '@mui/material/styles'; +import FormGroup from '@mui/material/FormGroup'; +import FormControlLabel from '@mui/material/FormControlLabel'; +import Checkbox from '@mui/material/Checkbox'; +import Radio from '@mui/material/Radio'; +import RadioGroup from '@mui/material/RadioGroup'; +import FormControl from '@mui/material/FormControl'; +import Divider from "@mui/material/Divider"; +import FormLabel from '@mui/material/FormLabel'; +export default function Download() { + const [open, setOpen] = React.useState(false); + const theme = useTheme(); + const fullScreen = useMediaQuery(theme.breakpoints.down('md')); + + const handleClickOpen = () => { + setOpen(true); + }; + + const handleClose = () => { + setOpen(false); + }; + return ( + + + {/* + + */} + + + + Download + + + + {"Download Quality"} + + + + + {/* Gender */} + + } label="Low (144p)" /> + } label="Standard (480p)" /> + } label="High (720p)" /> + } label="Full HD (1080p)" /> + + + + + } label="Remember my settings for 30 days" /> + + + + + + + + + + ); +} \ No newline at end of file diff --git a/app/_components/watch/share.jsx b/app/_components/watch/share.jsx new file mode 100644 index 0000000..ebd97ba --- /dev/null +++ b/app/_components/watch/share.jsx @@ -0,0 +1,75 @@ +import * as React from 'react'; +import Fab from '@mui/material/Fab'; +import FileDownloadOutlinedIcon from "@mui/icons-material/FileDownloadOutlined"; +import Dialog from '@mui/material/Dialog'; +import DialogActions from '@mui/material/DialogActions'; +import DialogContent from '@mui/material/DialogContent'; +import DialogContentText from '@mui/material/DialogContentText'; +import DialogTitle from '@mui/material/DialogTitle'; +import useMediaQuery from '@mui/material/useMediaQuery'; +import { useTheme } from '@mui/material/styles'; +import FormGroup from '@mui/material/FormGroup'; +import FormControlLabel from '@mui/material/FormControlLabel'; +import Checkbox from '@mui/material/Checkbox'; +import Radio from '@mui/material/Radio'; +import RadioGroup from '@mui/material/RadioGroup'; +import FormControl from '@mui/material/FormControl'; +import Divider from "@mui/material/Divider"; +import FormLabel from '@mui/material/FormLabel'; +// import {ShareSocial} from 'react-share-social' +import ShareOutlinedIcon from "@mui/icons-material/ShareOutlined"; +export default function Download() { + const [open, setOpen] = React.useState(false); + const theme = useTheme(); + const fullScreen = useMediaQuery(theme.breakpoints.down('md')); + + const handleClickOpen = () => { + setOpen(true); + }; + + const handleClose = () => { + setOpen(false); + }; + return ( + + + + + Share + + + + {"Share"} + + + {/* */} + {/* */} +

social

+ {/*
*/} +
+ +
+ +
+ ); +} \ No newline at end of file diff --git a/app/_components/watch/subscribe.jsx b/app/_components/watch/subscribe.jsx new file mode 100644 index 0000000..e59b582 --- /dev/null +++ b/app/_components/watch/subscribe.jsx @@ -0,0 +1,20 @@ +import * as React from 'react'; +import { useState } from "react"; +import Fab from '@mui/material/Fab'; + +export default function Dot() { + const [active, setActive] = useState(false); + const handleClick = () => { + setActive(!active); + }; + return ( + + + + + { active ? "Subscribed" : "Subscribe"} + + + ); +} \ No newline at end of file diff --git a/app/_components/watch/watch.jsx b/app/_components/watch/watch.jsx new file mode 100644 index 0000000..16804bb --- /dev/null +++ b/app/_components/watch/watch.jsx @@ -0,0 +1,1239 @@ +"use client"; +import { useState } from "react"; +import * as React from "react"; +import Typography from "@mui/material/Typography"; +import Divider from "@mui/material/Divider"; +import "vidstack/styles/defaults.css"; +import "vidstack/styles/community-skin/video.css"; +import Toolbar from "@mui/material/Toolbar"; +import SimpleBar from "simplebar-react"; +import "simplebar-react/dist/simplebar.min.css"; +import { + MediaCommunitySkin, + MediaOutlet, + MediaPlayer, + MediaPoster, +} from "@vidstack/react"; +import Grid from "@mui/material/Grid"; +import List from "@mui/material/List"; +import ListItem from "@mui/material/ListItem"; +import ListItemText from "@mui/material/ListItemText"; +import ListItemAvatar from "@mui/material/ListItemAvatar"; +import Avatar from "@mui/material/Avatar"; +import ImageIcon from "@mui/icons-material/Image"; +import WorkIcon from "@mui/icons-material/Work"; +import BeachAccessIcon from "@mui/icons-material/BeachAccess"; +import Box from "@mui/material/Box"; +import Fab from "@mui/material/Fab"; +import AddIcon from "@mui/icons-material/Add"; +import EditIcon from "@mui/icons-material/Edit"; +import FavoriteIcon from "@mui/icons-material/Favorite"; +import NavigationIcon from "@mui/icons-material/Navigation"; +import Share from "./share"; +import Download from "./download"; +import ThumbUpOutlinedIcon from "@mui/icons-material/ThumbUpOutlined"; +import ThumbDownOutlinedIcon from "@mui/icons-material/ThumbDownOutlined"; +import EmojiPicker from "emoji-picker-react"; +import TextField from "@mui/material/TextField"; +import Stack from "@mui/material/Stack"; +import Dot from "./dot"; +import CardGrid from "../home/cardgrid"; +import Subscribe from "./subscribe"; +import Paper from "@mui/material/Paper"; +export default function App() { + return ( + <> + + {/* */} + + + {/* */} + + + + + + + + + + + {/* */} + Big Buck Bunny 60fps 4K - Official Blender Foundation Short Film + {/* */} + + + + + + + + + + {/* */} + {/* */} + + + {/* */} + {/* */} + + + 92K | + + 248 + + {/* */} + {/* */} + + {/* */} + {/* */} + + {/* */} + {/* */} + + {/* */} + {/* + + */} + {/* */} + {/* */} + {/* + + */} + {/* + + + 900 | + + 400 + + + + share + + + + Download + + + + */} +
+ {/* */} + +
+ 9,728 Comments + + + + + + + + + @ShinyFilms + + {" 7 years ago"} + + } + secondary={ + + + I saw this playing on TV's at the tech stores to show off + the quality of the TV's. Not surprised. + + + } + /> + + + + + + + + @Seed + + {" 4 months ago"} + + } + secondary={ + + + Ah.. The classic test video + + + } + /> + + + + + + + + @mlpfanboy1701 + + {" 3 years ago "} + + } + secondary={ + + + “There are three things all wise men fear: a storm at sea, + a night with no moon and the anger of a gentle man” + + + } + /> + + + + + + + + @aaliyahgadon9939 + + {" 3 years ago"} + + } + secondary={ + + + I used to watch this on my old tablet. I miss my childhood + + + } + /> + + + + + + + + @BergsArt + + {" 4 years ago "} + + } + secondary={ + + + Comments 90% - Big Chungus 9% - Remembering this as a kid + 1% - This short was made using free software + + + } + /> + + + + + + + + @Smargin + + {" 5 years ago "} + + } + secondary={ + + + 2014: haha what a funny animation 2019: BIG CHUNGUS + + + } + /> + + + + + + + + @Nikku4211 + + {" 2 years ago "} + + } + secondary={ + + + Wait, so this is actually rendered at 60fps, no AI crap? + Awesome. + + + } + /> + + + + + + + + @sergddr + + {"5 years ago "} + + } + secondary={ + + + Big Chungus: Story mode + + + } + /> + + + + + + + + @Zanderbolt-js4fv + + {" 5 years ago"} + + } + secondary={ + + + Wait,is that..............BIG CHUNGUS?! + + + } + /> + + + + + + + + @progamerzach1 + + {" 5 years ago "} + + } + secondary={ + + + Saw this before big chungus became a thing. + + + } + /> + + + + + + + + @danielsan2142 + + {"1 year ago "} + + } + secondary={ + + + I remember watching this animation for the first time + around 2009 or 2010. It remains one of the most beautiful + and well-made animations on the web, with spectacular + graphics and a very cool story. Pure masterpiece! + + + } + /> + + + + + + + + @miriamhodges5632 + + {" 2 years ago "} + + } + secondary={ + + + Me and my little brother used to watch this constantly on + this old mp3 player we had, and we even learned the + montage music on the piano because it was so fun and + catchy. Years later, it came up in conversation, and out + of curiosity, I looked up "bumny butterfly animation" and + this was the first result. Showed it to my brother today + and we laughed hysterically for several minutes. What a + throwback. + + + } + /> + + + + + + + + @ceweoh + + {"5 years ago "} + + } + secondary={ + + + This Big Chungus for the PS4 gameplay is so good + + + } + /> + + + + + + + + @ElijahCiali + + {" 4 years ago "} + + } + secondary={ + + + Blender: makes a free movie Every coding website: it’s + free real estate + + + } + /> + + + + + + + + @octolin6007 + + {" 3 years ago "} + + } + secondary={ + + + this movie: exists everyone: meme approved + + + } + /> + + + + + + + + @Reehatk + + {" 11 months ago"} + + } + secondary={ + + + I used to watch this all the time as a kid. I was so + young, while my parents fed me I just lay in their lap + watching this on the phone. I was only 1 or 2 years old + back then, now as I'm watching this again, it brings back + so much memories. God I love this + + + } + /> + + + + + + + + @bigburd875 + + {" 5 years ago "} + + } + secondary={ + + + Big Chungus confronts kids who made fun of him + + + } + /> + + + + + + + + @lilchickenwing3955 + + {" 5 years ago "} + + } + secondary={ + + + 95% of comments: big chungus 5% of comments: remember + watching this as a kid + + + } + /> + + + + + + + + @sergeantsapient + + {" 3 months ago "} + + } + secondary={ + + + Amazing how well this holds up so many years later. + + + } + /> + + + + + + + + @kanikabhatia9865 + + {"3 years ago "} + + } + secondary={ + + + It feels so good seeing the graphics and emotions in this + film. I respect this kind of work a lot. Keep it up. + + + } + /> + + + + + + + + @themanofmilk6394 + + {" 5 years ago "} + + } + secondary={ + + + Big chungus 2: chungus takes revenge on forest creatures + + + } + /> + + + + + + + + @chickensanders7870 + + {" 5 years ago (edited)"} + + } + secondary={ + + + The gameplay of my Big Chungus trailer XD + + + } + /> + + + + + + + + @May-gr8bp + + {" 2 years ago "} + + } + secondary={ + + + my friend introduced this today as a tradition that she + has, to watch every so often. this is a good film + + + } + /> + + + + + + + + @NyxLikesCats + + {"8 months ago "} + + } + secondary={ + + + out of 5 "not violent enough, i wanted to see that flying + squirrel get impaled I a going to teach myself blender so + I can fix the ending" + + + } + /> + + + + + + + + @josfedomi4087 + + {"5 years ago "} + + } + secondary={ + + + Big Chungus Remastered + + + } + /> + + + + + + + + @cannibalcandyy + + {"3 years ago "} + + } + secondary={ + + + I have a CD of this animation. When or why I have it is + unknown. + + + } + /> + + + + + + + + @papajohns1533 + + {"3 years ago "} + + } + secondary={ + + + Oké so I’ve been looking for this bunny for 6 years now + because I always thought it was fun on my Nintendo 3ds, + thank god I found this + + + } + /> + + + + + + + + @mysteriousvoice907 + + {" 2 years ago "} + + } + secondary={ + + + i came back to watch this after 6 years and oh my god i + forgot how comicly dark this was + + + } + /> + + + + + + + + @yeetnoodle9668 + + {"1 year ago "} + + } + secondary={ + + + This is nostalgic, I now have Blender and I aspire to be + as this good + + + } + /> + + +
+ + + + +
+ + ); +}