Skip to content

Commit

Permalink
SOEOPSFY24-315 | explore fade-out timing variations for timeline imag…
Browse files Browse the repository at this point in the history
…e overlay opacity
  • Loading branch information
rebeccahongsf committed Nov 1, 2024
1 parent b7575b8 commit 1107f0d
Show file tree
Hide file tree
Showing 25 changed files with 107 additions and 71 deletions.
4 changes: 2 additions & 2 deletions app/components/TimelineEven/TimelineItem.styles.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,6 @@ export const size = {
};

export const trapezoid = {
left: "rotate-y-[25deg] group-hocus:rotate-y-[-25deg]",
right: "rotate-y-[-25deg] group-hocus:rotate-y-[25deg]",
left: "rotate-y-[25deg] hocus:rotate-y-[-25deg]",
right: "rotate-y-[-25deg] hocus:rotate-y-[25deg]",
};
76 changes: 44 additions & 32 deletions app/components/TimelineEven/TimelineItem.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import { cnb } from "cnbuilder";
import * as styles from "./TimelineItem.styles";
import * as types from "./TimelineItem.types";
import { Heading, Text } from "../Typography";
import { AnimatePresence, motion, MotionProps } from "framer-motion";

interface TimelineItemProps {
heading: string;
Expand All @@ -10,6 +11,7 @@ interface TimelineItemProps {
size?: types.SizeType;
trapezoid?: types.TrapezoidType;
className?: string;
animationProps?: MotionProps;
}

const TimelineItem = ({
Expand All @@ -19,45 +21,55 @@ const TimelineItem = ({
size = "medium",
trapezoid = "left",
className,
animationProps,
...props
}: TimelineItemProps) => {
const imageSize = styles.size[size];
const trapezoidType = styles.trapezoid[trapezoid];

return (
<div {...props} className={cnb("flex flex-col", className)}>
<button
className={cnb(
"group relative hocus:transform-none rounded-lg flex items-center justify-center",
trapezoidType,
)}
>
<div
className={cnb(
"aspect-[1/1] group relative perspective-600",
imageSize,
)}
>
<img
alt=""
src={image}
className="inset-0 w-full h-full object-cover rounded-lg transform ease-in-out duration-500"
/>
<div
{...props}
className={cnb("flex flex-col items-center justify-center", className)}
>
<AnimatePresence>
<button className={cnb("group relative", trapezoidType)}>
<div
className={cnb("aspect-[1/1] relative perspective-600", imageSize)}
>
<motion.div
{...animationProps}
className="absolute perspective-600 z-10 w-full h-full"
>
<div
className={cnb(
"relative transform rounded-lg opacity-60 bg-digital-blue w-full h-full ease-in-out duration-500",
trapezoidType,
imageSize,
)}
/>
</motion.div>
<img
alt=""
src={image}
className="inset-0 w-full h-full object-cover rounded-lg transform ease-in-out duration-500"
/>
</div>
</button>
<div className="flex flex-col *:font-dm-sans">
<Heading className="type-0" weight="normal">
{heading}
</Heading>
<Text
font="serif"
variant="overview"
weight="normal"
className="order-first mt-28"
>
{year}
</Text>
</div>
</button>
<div className="flex flex-col *:font-dm-sans">
<Heading className="type-0" weight="normal">
{heading}
</Heading>
<Text
font="serif"
variant="overview"
weight="normal"
className="order-first mt-28"
>
{year}
</Text>
</div>
</AnimatePresence>
</div>
);
};
Expand Down
29 changes: 27 additions & 2 deletions app/components/TimelineEven/TimelineOverview.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -19,15 +19,33 @@ type TimelineProps = {
hasBorder?: boolean;
};

// Helper function to generate a random delay between a specified range
function getRandomDelay(min = 0.5, max = 5) {
return Math.random() * (max - min) + min;
}

// Animation variant with random delay for overlay fade-out
const overlayFadeOutVariant = {
visible: { opacity: 1 },
hidden: (custom: number) => ({
opacity: 0,
transition: {
duration: 1,
delay: custom, // Use the random delay
},
}),
};

const TimelineEven = ({ timelineData, hasBorder }: TimelineProps) => {
const sizePattern: SizeType[] = ["large", "medium", "small"];

return (
<Container width="site" py={5} bgColor="fog-light" className="mb-50">
<div className="grid grid-cols-2 md:grid-cols-3 xl:grid-cols-4 *:px-61">
<div className="grid grid-cols-2 md:grid-cols-3 xl:grid-cols-4">
{timelineData.map((item, idx) => {
const trapezoid = idx % 2 === 0 ? "right" : "left";
const size = sizePattern[idx % sizePattern.length];
const randomDelay = getRandomDelay();

return (
<TimelineItem
Expand All @@ -36,10 +54,17 @@ const TimelineEven = ({ timelineData, hasBorder }: TimelineProps) => {
size={size}
trapezoid={trapezoid}
className={cnb(
"rs-pb-8",
"rs-pb-3 rs-pt-5 rs-px-4",
hasBorder &&
"border-r-3 border-black nth-2n:border-0 md:nth-2n:border-r-3 md:nth-3n:border-0 xl:nth-3n:border-r-3 xl:nth-4n:border-0",
)}
animationProps={{
custom: randomDelay,
initial: "visible",
animate: "hidden",
exit: "visible",
variants: overlayFadeOutVariant,
}}
/>
);
})}
Expand Down
2 changes: 1 addition & 1 deletion out/404.html

Large diffs are not rendered by default.

Large diffs are not rendered by default.

1 change: 0 additions & 1 deletion out/_next/static/chunks/398-5259381c3f12d3c9.js

This file was deleted.

1 change: 0 additions & 1 deletion out/_next/static/chunks/618-fbcdd492e82ddfa3.js

This file was deleted.

1 change: 1 addition & 0 deletions out/_next/static/chunks/932-fb842629337a0d1a.js

Large diffs are not rendered by default.

Loading

0 comments on commit 1107f0d

Please sign in to comment.