From 4c6b7677369e20f9e078ab34abff093e17f0f109 Mon Sep 17 00:00:00 2001 From: sajjad Date: Sun, 19 Nov 2023 01:16:43 +0330 Subject: [PATCH] fix ui --- package-lock.json | 82 +++++++- package.json | 5 +- src/App.css | 6 +- src/App.js | 46 +++-- src/components/Global/main-nav/MainNav.jsx | 181 +++++++++++++++--- .../Global/main-nav/MainNav.module.scss | 17 +- .../Global/main-nav/MainNavItem.jsx | 54 ++++-- .../Global/profile-image/ProfileImage.jsx | 13 ++ .../profile-image/ProfileImage.module.scss | 18 ++ src/components/Global/slider/Slider.jsx | 108 +++++++++++ .../Global/slider/Slider.module.scss | 25 +++ src/components/Global/user-card/UserCard.jsx | 26 +++ .../Global/user-card/UserCard.module.scss | 11 ++ src/components/posts/Item.jsx | 117 +++++++++++ src/components/posts/Item.module.scss | 20 ++ src/index.css | 3 + src/views/dashboard/Dashboard.jsx | 98 +++++++++- src/views/dashboard/Dashboard.module.css | 0 src/views/dashboard/Dashboard.module.scss | 27 +++ tailwind.config.js | 9 + 20 files changed, 800 insertions(+), 66 deletions(-) create mode 100644 src/components/Global/profile-image/ProfileImage.jsx create mode 100644 src/components/Global/profile-image/ProfileImage.module.scss create mode 100644 src/components/Global/slider/Slider.jsx create mode 100644 src/components/Global/slider/Slider.module.scss create mode 100644 src/components/Global/user-card/UserCard.jsx create mode 100644 src/components/Global/user-card/UserCard.module.scss create mode 100644 src/components/posts/Item.jsx create mode 100644 src/components/posts/Item.module.scss delete mode 100644 src/views/dashboard/Dashboard.module.css create mode 100644 src/views/dashboard/Dashboard.module.scss create mode 100644 tailwind.config.js diff --git a/package-lock.json b/package-lock.json index 7fa5c2b..07fa84c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -21,10 +21,13 @@ "react-redux": "^8.1.3", "react-scripts": "5.0.1", "styled-components": "^6.1.1", + "swiper": "^11.0.4", "web-vitals": "^2.1.4" }, "devDependencies": { - "react-router-dom": "^6.18.0" + "react-router-dom": "^6.18.0", + "sass": "^1.69.5", + "tailwindcss": "^3.3.5" } }, "node_modules/@aashutoshrathi/word-wrap": { @@ -9812,6 +9815,12 @@ "url": "https://opencollective.com/immer" } }, + "node_modules/immutable": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.4.tgz", + "integrity": "sha512-fsXeu4J4i6WNWSikpI88v/PcVflZz+6kMhUfIwc5SY+poQRPnaf5V7qds6SUyUN3cVxEzuCab7QIoLOQ+DQ1wA==", + "devOptional": true + }, "node_modules/import-fresh": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", @@ -15950,6 +15959,23 @@ "resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-13.0.0.tgz", "integrity": "sha512-ZRwKbh/eQ6w9vmTjkuG0Ioi3HBwPFce0O+v//ve+aOq1oeCy7jMV2qzzAlpsNuqpqCBjjriM1lbtZbF/Q8jVyA==" }, + "node_modules/sass": { + "version": "1.69.5", + "resolved": "https://registry.npmjs.org/sass/-/sass-1.69.5.tgz", + "integrity": "sha512-qg2+UCJibLr2LCVOt3OlPhr/dqVHWOa9XtZf2OjbLs/T4VPSJ00udtgJxH3neXZm+QqX8B+3cU7RaLqp1iVfcQ==", + "devOptional": true, + "dependencies": { + "chokidar": ">=3.0.0 <4.0.0", + "immutable": "^4.0.0", + "source-map-js": ">=0.6.2 <2.0.0" + }, + "bin": { + "sass": "sass.js" + }, + "engines": { + "node": ">=14.0.0" + } + }, "node_modules/sass-loader": { "version": "12.6.0", "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-12.6.0.tgz", @@ -16979,6 +17005,24 @@ "boolbase": "~1.0.0" } }, + "node_modules/swiper": { + "version": "11.0.4", + "resolved": "https://registry.npmjs.org/swiper/-/swiper-11.0.4.tgz", + "integrity": "sha512-qtUxILrD4aD++rpKzGrkz3IAWL92f9uTrDwjb6HaNLmPvJhZCE/83DL+9w4kIgDDJeF6QKalV47rMBN77UOVYQ==", + "funding": [ + { + "type": "patreon", + "url": "https://www.patreon.com/swiperjs" + }, + { + "type": "open_collective", + "url": "http://opencollective.com/swiper" + } + ], + "engines": { + "node": ">= 4.7.0" + } + }, "node_modules/symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", @@ -17422,16 +17466,16 @@ } }, "node_modules/typescript": { - "version": "5.2.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", - "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==", + "version": "4.9.5", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz", + "integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==", "peer": true, "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" }, "engines": { - "node": ">=14.17" + "node": ">=4.2.0" } }, "node_modules/unbox-primitive": { @@ -25549,6 +25593,12 @@ "resolved": "https://registry.npmjs.org/immer/-/immer-9.0.21.tgz", "integrity": "sha512-bc4NBHqOqSfRW7POMkHd51LvClaeMXpm8dx0e8oE2GORbq5aRK7Bxl4FyzVLdGtLmvLKL7BTDBG5ACQm4HWjTA==" }, + "immutable": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.4.tgz", + "integrity": "sha512-fsXeu4J4i6WNWSikpI88v/PcVflZz+6kMhUfIwc5SY+poQRPnaf5V7qds6SUyUN3cVxEzuCab7QIoLOQ+DQ1wA==", + "devOptional": true + }, "import-fresh": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", @@ -29777,6 +29827,17 @@ "resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-13.0.0.tgz", "integrity": "sha512-ZRwKbh/eQ6w9vmTjkuG0Ioi3HBwPFce0O+v//ve+aOq1oeCy7jMV2qzzAlpsNuqpqCBjjriM1lbtZbF/Q8jVyA==" }, + "sass": { + "version": "1.69.5", + "resolved": "https://registry.npmjs.org/sass/-/sass-1.69.5.tgz", + "integrity": "sha512-qg2+UCJibLr2LCVOt3OlPhr/dqVHWOa9XtZf2OjbLs/T4VPSJ00udtgJxH3neXZm+QqX8B+3cU7RaLqp1iVfcQ==", + "devOptional": true, + "requires": { + "chokidar": ">=3.0.0 <4.0.0", + "immutable": "^4.0.0", + "source-map-js": ">=0.6.2 <2.0.0" + } + }, "sass-loader": { "version": "12.6.0", "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-12.6.0.tgz", @@ -30562,6 +30623,11 @@ } } }, + "swiper": { + "version": "11.0.4", + "resolved": "https://registry.npmjs.org/swiper/-/swiper-11.0.4.tgz", + "integrity": "sha512-qtUxILrD4aD++rpKzGrkz3IAWL92f9uTrDwjb6HaNLmPvJhZCE/83DL+9w4kIgDDJeF6QKalV47rMBN77UOVYQ==" + }, "symbol-tree": { "version": "3.2.4", "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", @@ -30888,9 +30954,9 @@ } }, "typescript": { - "version": "5.2.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.2.2.tgz", - "integrity": "sha512-mI4WrpHsbCIcwT9cF4FZvr80QUeKvsUsUvKDoR+X/7XHQH98xYD8YHZg7ANtz2GtZt/CBq2QJ0thkGJMHfqc1w==", + "version": "4.9.5", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.9.5.tgz", + "integrity": "sha512-1FXk9E2Hm+QzZQ7z+McJiHL4NW1F2EzMu9Nq9i3zAaGqibafqYwCVU6WyWAuyQRRzOlxou8xZSyXLEN8oKj24g==", "peer": true }, "unbox-primitive": { diff --git a/package.json b/package.json index eb0c68e..e732404 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,7 @@ "react-redux": "^8.1.3", "react-scripts": "5.0.1", "styled-components": "^6.1.1", + "swiper": "^11.0.4", "web-vitals": "^2.1.4" }, "scripts": { @@ -43,6 +44,8 @@ ] }, "devDependencies": { - "react-router-dom": "^6.18.0" + "react-router-dom": "^6.18.0", + "sass": "^1.69.5", + "tailwindcss": "^3.3.5" } } diff --git a/src/App.css b/src/App.css index a255e3f..e05eecc 100644 --- a/src/App.css +++ b/src/App.css @@ -1,4 +1,4 @@ a { - text-decoration: none; - color: inherit; -} \ No newline at end of file + text-decoration: none; + color: inherit; +} diff --git a/src/App.js b/src/App.js index 7753432..597d274 100644 --- a/src/App.js +++ b/src/App.js @@ -1,18 +1,42 @@ -import './App.css'; -import { Outlet } from 'react-router-dom'; -import Grid from '@mui/material/Grid'; -import MainNav from './components/Global/main-nav/MainNav'; +import "./App.css"; +import { Outlet } from "react-router-dom"; +import Grid from "@mui/material/Grid"; +import MainNav from "./components/Global/main-nav/MainNav"; +import { createTheme, ThemeProvider } from "@mui/material/styles"; +const theme = createTheme({ + palette: { + primary: { + main: "#0095f6", + // light: will be calculated from palette.primary.main, + // dark: will be calculated from palette.primary.main, + // contrastText: will be calculated to contrast with palette.primary.main + }, + secondary: { + main: "#E0C2FF", + light: "#F5EBFF", + // dark: will be calculated from palette.secondary.main, + contrastText: "#47008F", + }, + black: { + main: "#000", + }, + }, +}); function App() { return ( -
- - - + +
+ + + + + + + - - -
+
+ ); } diff --git a/src/components/Global/main-nav/MainNav.jsx b/src/components/Global/main-nav/MainNav.jsx index 668a397..3410222 100644 --- a/src/components/Global/main-nav/MainNav.jsx +++ b/src/components/Global/main-nav/MainNav.jsx @@ -1,26 +1,163 @@ +// base import { Link } from "react-router-dom"; +import { useState } from "react"; + +// components import MainNavItem from "./MainNavItem"; -import HomeIcon from '@mui/icons-material/Home'; +import { Divider, List, IconButton } from "@mui/material"; +import MuiDrawer from "@mui/material/Drawer"; + +// Icons +import ChevronLeftIcon from "@mui/icons-material/ChevronLeft"; +import ChevronRightIcon from "@mui/icons-material/ChevronRight"; +import HomeOutlinedIcon from "@mui/icons-material/HomeOutlined"; +import HomeSharpIcon from "@mui/icons-material/HomeSharp"; +import SearchOutlinedIcon from "@mui/icons-material/SearchOutlined"; +import SearchSharpIcon from "@mui/icons-material/SearchSharp"; +import ExploreOutlinedIcon from "@mui/icons-material/ExploreOutlined"; +import ExploreSharpIcon from "@mui/icons-material/ExploreSharp"; +import SendIcon from "@mui/icons-material/Send"; +import SendOutlinedIcon from "@mui/icons-material/SendOutlined"; +import AddBoxOutlinedIcon from "@mui/icons-material/AddBoxOutlined"; +// styles +import { styled, useTheme, Theme, CSSObject } from "@mui/material/styles"; + +const DrawerHeader = styled("div")(({ theme }) => ({ + display: "flex", + alignItems: "center", + justifyContent: "flex-end", + padding: theme.spacing(0, 1), + // necessary for content to be below app bar + ...theme.mixins.toolbar, +})); + +const openedMixin = (theme: Theme): CSSObject => ({ + width: 240, + transition: theme.transitions.create("width", { + easing: theme.transitions.easing.sharp, + duration: theme.transitions.duration.enteringScreen, + }), + overflowX: "hidden", +}); + +const closedMixin = (theme: Theme): CSSObject => ({ + transition: theme.transitions.create("width", { + easing: theme.transitions.easing.sharp, + duration: theme.transitions.duration.leavingScreen, + }), + overflowX: "hidden", + width: `calc(${theme.spacing(7)} + 1px)`, + [theme.breakpoints.up("sm")]: { + width: `calc(${theme.spacing(7)} + 1px)`, + }, +}); + +const Drawer = styled(MuiDrawer, { + shouldForwardProp: (prop) => prop !== "open", +})(({ theme, open }) => ({ + width: 240, + flexShrink: 0, + whiteSpace: "nowrap", + boxSizing: "border-box", + ...(open && { + ...openedMixin(theme), + "& .MuiDrawer-paper": openedMixin(theme), + }), + ...(!open && { + ...closedMixin(theme), + "& .MuiDrawer-paper": closedMixin(theme), + }), +})); const MainNav = () => { - const navItems = [ - { - text: 'Home', - path: '/', - icon: HomeIcon - } - ]; - return ( -
- { - navItems.map((navItem, i) => { - return ( - - - - ) - }) - } -
- ) + const [activeItem, setActiveItem] = useState(0); + const navItems = [ + { + text: "Home", + path: "/", + icon: HomeOutlinedIcon, + activeIcon: HomeSharpIcon, + }, + { + text: "Search", + path: null, + icon: SearchOutlinedIcon, + activeIcon: SearchSharpIcon, + }, + { + text: "Explore", + path: "/", + icon: ExploreOutlinedIcon, + activeIcon: ExploreSharpIcon, + }, + { + text: "Messages", + path: "/messages", + icon: SendOutlinedIcon, + activeIcon: SendIcon, + }, + { + text: "Create", + path: "/", + icon: AddBoxOutlinedIcon, + }, + { + text: "Profile", + path: "/", + icon: SearchOutlinedIcon, + }, + ]; + const [open, setOpen] = useState(true); + const handleListItemClick = (index) => { + setActiveItem(index); + if (!navItems[index].path) { + handleDrawerClose(); + } + }; + + const handleDrawerOpen = () => { + setOpen(true); + }; + + const handleDrawerClose = () => { + setOpen(false); + }; + return ( +
+ + + {open ? ( + + + + ) : ( + + + + )} + + + + {navItems.map((navItem, i) => { + return ( + + { + !navItem.path ?? e.preventDefault(); + handleListItemClick(i); + }} + text={navItem.text} + icon={navItem.icon} + activeIcon={navItem.activeIcon} + index={i} + activeItem={activeItem} + open={open} + /> + + ); + })} + + +
+ ); }; -export default MainNav; \ No newline at end of file +export default MainNav; diff --git a/src/components/Global/main-nav/MainNav.module.scss b/src/components/Global/main-nav/MainNav.module.scss index 930cde8..f913c50 100644 --- a/src/components/Global/main-nav/MainNav.module.scss +++ b/src/components/Global/main-nav/MainNav.module.scss @@ -1,5 +1,14 @@ -.main__nav__item { - .main__nav__item--text span { - font-size: 20px; - } +.MainNavItem { + .MainNavItemText span { + color: gray; + font-size: 16px; + } + .MainNavItemIcon { + color: black; + } +} +.MainNavItemActive { + .MainNavItemText span { + color: black; + } } diff --git a/src/components/Global/main-nav/MainNavItem.jsx b/src/components/Global/main-nav/MainNavItem.jsx index 8be2e74..5df44fe 100644 --- a/src/components/Global/main-nav/MainNavItem.jsx +++ b/src/components/Global/main-nav/MainNavItem.jsx @@ -1,16 +1,44 @@ -import { ListItemButton, ListItemText, ListItemIcon } from '@mui/material'; -import styles from './MainNav.module.scss'; +import { ListItemButton, ListItemText, ListItemIcon } from "@mui/material"; +import styled from "./MainNav.module.scss"; -const MainNavItem = ({ text, path, icon }) => { - const MainNavItemIcon = icon; - return ( - - - - - - - ); +const MainNavItem = ({ + text, + path, + icon, + index, + onClick, + activeItem, + activeIcon, + open, +}) => { + const MainNavItemIcon = index === activeItem ? activeIcon : icon; + + return ( + + + + + + + ); }; -export default MainNavItem; \ No newline at end of file +export default MainNavItem; diff --git a/src/components/Global/profile-image/ProfileImage.jsx b/src/components/Global/profile-image/ProfileImage.jsx new file mode 100644 index 0000000..2e72982 --- /dev/null +++ b/src/components/Global/profile-image/ProfileImage.jsx @@ -0,0 +1,13 @@ +import styled from "./ProfileImage.module.scss"; +const ProfileImage = ({ image, title, active }) => { + return ( +
+ {title +
+ ); +}; +export default ProfileImage; diff --git a/src/components/Global/profile-image/ProfileImage.module.scss b/src/components/Global/profile-image/ProfileImage.module.scss new file mode 100644 index 0000000..a127abd --- /dev/null +++ b/src/components/Global/profile-image/ProfileImage.module.scss @@ -0,0 +1,18 @@ +.ImageListItem { + position: relative; + width: 100%; + height: 100%; + overflow: hidden; + margin: 0 auto; + border-radius: 50%; + &.ImageListItemActive { + background: linear-gradient(to right, red, orange) padding-box, + linear-gradient(to right, red, orange) border-box; + border: 2px solid transparent; + } + img { + width: 100%; + height: 100%; + object-fit: cover; + } +} diff --git a/src/components/Global/slider/Slider.jsx b/src/components/Global/slider/Slider.jsx new file mode 100644 index 0000000..e4d50bc --- /dev/null +++ b/src/components/Global/slider/Slider.jsx @@ -0,0 +1,108 @@ +import styled from "./Slider.module.scss"; +import React from "react"; +import ArrowCircleRightTwoToneIcon from "@mui/icons-material/ArrowCircleRightTwoTone"; +import ArrowCircleLeftTwoToneIcon from "@mui/icons-material/ArrowCircleLeftTwoTone"; +import { useRef } from "react"; +// Import Swiper React components +import { Swiper, SwiperSlide } from "swiper/react"; + +// Import Swiper styles +import "swiper/css"; +import "swiper/css/pagination"; +import "swiper/css/navigation"; +// import required modules +import { Navigation } from "swiper/modules"; + +const Slider = ({ body, items, sliderBodyCallBack, slidesPerView = 8 }) => { + const swiperRef = useRef(); + return ( + { + swiperRef.current = swiper; + }} + > +
swiperRef.current?.slidePrev()} + > + {items && items.length > 1 && ( + + )} +
+ {items && + items.map((item, i) => ( + + {sliderBodyCallBack({ data: item, index: i })} + + ))} +
swiperRef.current?.slideNext()} + > + {items && items.length > 1 && ( + + )} +
+
+ ); +}; + +export default Slider; + +// function Body() { +// return null; +// } + +// class Slider extends React.Component { +// static Body = Body; +// constructor(props) { +// super(props); +// this.swiperRef = React.createRef(null); +// } +// render() { +// // const swiperRef = useRef(); +// const { children, items, sendDataToParent, handleCallBack } = this.props; +// const body = children; +// return ( +// { +// this.swiperRef.current = swiper; +// }} +// > +//
this.swiperRef.current?.slidePrev()} +// > +// +//
+// {items && +// items.map((item, i) => { +// sendDataToParent(item, i); +// console.log(body); +// return ( +// +// {body ? body.props.children : null} +// {handleCallBack(item)} +// +// ); +// })} +//
this.swiperRef.current?.slideNext()} +// > +// +//
+//
+// ); +// } +// } + +// export default Slider; diff --git a/src/components/Global/slider/Slider.module.scss b/src/components/Global/slider/Slider.module.scss new file mode 100644 index 0000000..59d322f --- /dev/null +++ b/src/components/Global/slider/Slider.module.scss @@ -0,0 +1,25 @@ +.ImageListItemBar { + text-align: center; + div { + font-size: 12px; + } +} +.mySwiper { + position: relative; + float: right; + width: 100%; +} +.CustomSwiperPrevButton { + position: absolute; + bottom: 45%; + left: 15px; + z-index: 99; + cursor: pointer; +} +.CustomSwiperNextButton { + position: absolute; + bottom: 45%; + right: 15px; + z-index: 99; + cursor: pointer; +} diff --git a/src/components/Global/user-card/UserCard.jsx b/src/components/Global/user-card/UserCard.jsx new file mode 100644 index 0000000..4d0e734 --- /dev/null +++ b/src/components/Global/user-card/UserCard.jsx @@ -0,0 +1,26 @@ +// components +import ProfileImage from "../profile-image/ProfileImage"; +import { Button } from "@mui/material"; +// styles +import styled from "./UserCard.module.scss"; +const UserCard = ({ title, image, subTitle }) => { + return ( +
+
+
+ +
+
+
sajjad_talkhabi_
+
+ followed by sajjad_talkhabi_ +
+
+
+ +
+ ); +}; +export default UserCard; diff --git a/src/components/Global/user-card/UserCard.module.scss b/src/components/Global/user-card/UserCard.module.scss new file mode 100644 index 0000000..6aeaba8 --- /dev/null +++ b/src/components/Global/user-card/UserCard.module.scss @@ -0,0 +1,11 @@ +.UserCardImage { + width: 2.5vw; + height: 2.5vw; +} + +.UserCardSubTitle { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; + max-width: 160px; +} diff --git a/src/components/posts/Item.jsx b/src/components/posts/Item.jsx new file mode 100644 index 0000000..5f147af --- /dev/null +++ b/src/components/posts/Item.jsx @@ -0,0 +1,117 @@ +// styles +import styled from "./Item.module.scss"; +// components +import Slider from "../Global/slider/Slider"; +import { TextField, Button } from "@mui/material"; +import ProfileImage from "../Global/profile-image/ProfileImage"; + +// icons +import MoreHorizOutlinedIcon from "@mui/icons-material/MoreHorizOutlined"; +import FavoriteBorderIcon from "@mui/icons-material/FavoriteBorder"; +import FavoriteSharpIcon from "@mui/icons-material/FavoriteSharp"; +import ChatBubbleOutlineOutlinedIcon from "@mui/icons-material/ChatBubbleOutlineOutlined"; +import SendSharpIcon from "@mui/icons-material/SendSharp"; +import BookmarkBorderOutlinedIcon from "@mui/icons-material/BookmarkBorderOutlined"; +import BookmarkSharpIcon from "@mui/icons-material/BookmarkSharp"; +// colors +import { red } from "@mui/material/colors"; + +const Post = () => { + const posts = [ + { + img: "", + }, + ]; + return ( +
+
+
+
+ +
+
+
sajjad_talkhabi_
+
+ +
+
1h
+
+
+ +
+
+ follow +
+
+
+
+ +
+
+
+ ( + alt + )} + /> +
+
+
+ + {/* */} + + +
+
+ + +
+
+
6 likes
+
+ sajjad_talkhabi_ + تجربش کردی؟🥲💔 +
+
+
+ mohammadh.safa + اره جیب خالی😂 +
+
+ +
+ + +
+
+
+ ); +}; +export default Post; diff --git a/src/components/posts/Item.module.scss b/src/components/posts/Item.module.scss new file mode 100644 index 0000000..cdecab7 --- /dev/null +++ b/src/components/posts/Item.module.scss @@ -0,0 +1,20 @@ +.PostItem { + .PostItemHeader { + .PostItemHeaderAccount { + .PostItemHeaderAccountImage { + height: 2.5vw; + width: 2.5vw; + } + } + } + .PostItemHeaderAccountDot { + span { + height: 4px; + width: 4px; + margin: 0 8px; + background-color: #bbb; + border-radius: 50%; + display: inline-block; + } + } +} diff --git a/src/index.css b/src/index.css index ec2585e..651ed53 100644 --- a/src/index.css +++ b/src/index.css @@ -1,3 +1,6 @@ +@tailwind base; +@tailwind components; +@tailwind utilities; body { margin: 0; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', diff --git a/src/views/dashboard/Dashboard.jsx b/src/views/dashboard/Dashboard.jsx index c79aaf0..53b163a 100644 --- a/src/views/dashboard/Dashboard.jsx +++ b/src/views/dashboard/Dashboard.jsx @@ -1,7 +1,97 @@ -const Dashboard = () => ( +// components +import Slider from "../../components/Global/slider/Slider"; +import PostItem from "../../components/posts/Item"; +import ProfileImage from "../../components/Global/profile-image/ProfileImage"; +import { ImageListItemBar, ImageListItem, Grid, Divider } from "@mui/material"; +// styles +import styled from "./Dashboard.module.scss"; +import UserCard from "../../components/Global/user-card/UserCard"; +const Dashboard = () => { + const stories = [ + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + { + img: "", + author: "sajjad", + title: "story item", + }, + ]; + return (
- dashboard + + +
+ } + /> +
+
+ +
+ +
+
+
+ +
+ +
+
+
-); - + ); +}; +const StoryItem = ({ story }) => { + return ( + +
+ +
+ +
+ ); +}; export default Dashboard; diff --git a/src/views/dashboard/Dashboard.module.css b/src/views/dashboard/Dashboard.module.css deleted file mode 100644 index e69de29..0000000 diff --git a/src/views/dashboard/Dashboard.module.scss b/src/views/dashboard/Dashboard.module.scss new file mode 100644 index 0000000..60f7160 --- /dev/null +++ b/src/views/dashboard/Dashboard.module.scss @@ -0,0 +1,27 @@ +.ImageListItem { + position: relative; + width: 4vw; + height: 4vw; + overflow: hidden; + border-radius: 50%; + img { + width: 100%; + height: 100%; + object-fit: cover; + } +} + +.StoryItemImage { + width: 4vw; + height: 4vw; +} +.swiper-button-next { + background-image: url(""); + background-repeat: no-repeat; + background-size: 100% auto; + background-position: center; +} + +.swiper-button-next::after { + display: none; +} diff --git a/tailwind.config.js b/tailwind.config.js new file mode 100644 index 0000000..31f16de --- /dev/null +++ b/tailwind.config.js @@ -0,0 +1,9 @@ +/** @type {import('tailwindcss').Config} */ +module.exports = { + important: true, + content: ["./src/**/*.{js,jsx,ts,tsx}"], + theme: { + extend: {}, + }, + plugins: [], +};