Created
July 6, 2022 17:25
-
-
Save Code-Victor/26aa4f19238d8553892caea764f3e2f4 to your computer and use it in GitHub Desktop.
layout animation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| import React from "react"; | |
| import { styled } from "../../stitches.config"; | |
| import { motion } from "framer-motion"; | |
| const data = [ | |
| { | |
| id: 1, | |
| name: "Top gun", | |
| img: "/top-gun.jpeg", | |
| }, | |
| { | |
| id: 2, | |
| name: "Bad guys", | |
| img: "/bad-guys.jpeg", | |
| }, | |
| { | |
| id: 3, | |
| name: "Jurassic world", | |
| img: "/jurassic-world.jpeg", | |
| }, | |
| { | |
| id: 4, | |
| name: "Doctor strange", | |
| img: "/doctor-strange.jpeg", | |
| }, | |
| ]; | |
| const Card = styled(motion.div, { | |
| display: "flex", | |
| maxWidth: 560, | |
| borderRadius: 10, | |
| overflow: "clip", | |
| boxShadow: "rgba(100, 100, 111, 0.2) 0px 7px 29px 0px", | |
| "&>*": { | |
| flex: 1, | |
| }, | |
| "& img": { | |
| maxWidth: "100%", | |
| height: "100%", | |
| objectFit: "cover", | |
| }, | |
| }); | |
| const MainCard = styled(motion.div, { | |
| borderRadius: 10, | |
| overflow: "clip", | |
| boxShadow: "rgba(100, 100, 111, 0.2) 0px 7px 29px 0px", | |
| display: "flex", | |
| flexDirection: "column", | |
| maxWidth: 480, | |
| background: "white", | |
| "& img": { | |
| width: "100%", | |
| maxHeight: 480, | |
| objectFit: "cover", | |
| objectPosition: "center", | |
| }, | |
| }); | |
| const Box = styled("div"); | |
| const App = () => { | |
| const [selected, setSelected] = React.useState<undefined | number>(undefined); | |
| const dummyText = | |
| "Lorem ipsum dolor sit amet consectetur adipisicing elit. Eligendi, dolorum! Mollitia enim qui in adipisci reprehenderit aspernatur dolorem. Fuga, iste."; | |
| return ( | |
| <Box | |
| css={{ | |
| minHeight: "100vh", | |
| minWidth: "100vw", | |
| display: "grid", | |
| placeItems: "center", | |
| }} | |
| > | |
| <Box | |
| css={{ display: "grid", gridTemplateColumns: "repeat(2,1fr)", gap: 20 }} | |
| > | |
| {data.map((item, i) => { | |
| if (selected === item.id) { | |
| return ( | |
| null | |
| ); | |
| } | |
| return ( | |
| <Card key={item.id} layoutId={`${item.id}`} onClick={() => setSelected(item.id)}> | |
| <Box> | |
| <motion.img src={item.img} alt="top gun" /> | |
| </Box> | |
| <Box css={{ padding: 10 }}> | |
| <h1>{item.name}</h1> | |
| <p>{dummyText}</p> | |
| </Box> | |
| </Card> | |
| ); | |
| })} | |
| </Box> | |
| {selected && ( | |
| <Box | |
| css={{ | |
| display: "grid", | |
| placeItems: "center", | |
| position: "absolute", | |
| inset: 0, | |
| }} | |
| > | |
| <MainCard layoutId={`${selected}`}> | |
| <Box> | |
| <img src={data[(selected || 0) - 1].img} alt="top gun" /> | |
| </Box> | |
| <Box css={{ padding: 10 }}> | |
| <h1>{data[(selected || 0) - 1].name}</h1> | |
| <p>{dummyText}</p> | |
| <button onClick={() => setSelected(undefined)}>close</button> | |
| </Box> | |
| </MainCard> | |
| </Box> | |
| )} | |
| </Box> | |
| ); | |
| }; | |
| export default App; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment