|
1 | 1 | import { motion } from "motion/react"; |
2 | 2 | import { SkillsType } from "shared/constants/enums"; |
3 | 3 | import ExperienceType from "../../../shared/types/experienceType"; |
4 | | -import ExperienceYearItemMobile from "./experienceYearItemMobile"; |
5 | 4 |
|
6 | 5 | interface ExperienceCardMobileProps { |
7 | 6 | isThemeLight: boolean; |
@@ -29,64 +28,53 @@ const ExperienceCardMobile = (props: ExperienceCardMobileProps) => { |
29 | 28 | initial={{ opacity: 0, y: -20 }} |
30 | 29 | animate={{ opacity: 1, y: 0 }} |
31 | 30 | transition={{ duration: 0.5, delay: 0.2, ease: "easeIn" }} |
32 | | - className={`w-full h-full flex items-start justify-start text-base leading-5 ${ |
33 | | - isThemeLight ? "text-black" : "text-gray-300" |
34 | | - }`} |
| 31 | + className={`relative w-full h-full text-base leading-5 ${isThemeLight ? "text-black" : "text-gray-300" |
| 32 | + }`} |
35 | 33 | > |
36 | | - {experienceList.map((experience, index) => { |
37 | | - const prevYear = index > 0 ? experienceList[index - 1].endDate : null; |
38 | | - const currentYear = experience.endDate; |
39 | | - const isLastItem = index === experienceList.length - 1; |
| 34 | + {/* Vertical timeline line */} |
| 35 | + <div |
| 36 | + className={`absolute top-0 bottom-0 left-0 w-px ${isThemeLight ? "bg-black" : "bg-white" |
| 37 | + }`} |
| 38 | + /> |
40 | 39 |
|
| 40 | + {experienceList.map((experience) => { |
41 | 41 | return ( |
42 | | - <div key={experience.id} className="flex flex-row pt-6"> |
43 | | - {/* Border */} |
44 | | - <div |
45 | | - className={`flex-1 border-r-2 border-double ${ |
46 | | - isThemeLight ? "border-black" : "border-white" |
47 | | - }`} |
48 | | - ></div> |
49 | | - |
50 | | - {/* Year */} |
51 | | - <div className="flex flex-col flex-1 justify-between mr-4 mt-4 mb-4"> |
52 | | - {/* End Date */} |
53 | | - {prevYear !== currentYear && ( |
54 | | - <ExperienceYearItemMobile |
55 | | - isThemeLight={isThemeLight} |
56 | | - date={currentYear} |
57 | | - /> |
58 | | - )} |
59 | | - |
60 | | - {/* Start Date */} |
61 | | - <ExperienceYearItemMobile |
62 | | - isThemeLight={isThemeLight} |
63 | | - date={experience.startDate} |
64 | | - /> |
65 | | - </div> |
66 | | - |
67 | | - {/* Item */} |
68 | | - <div |
69 | | - className={`flex flex-col items-center justify-start min-h-full`} |
70 | | - > |
71 | | - <div |
72 | | - key={experience.id} |
73 | | - className={`${isLastItem ? "" : "pb-4"}`} |
| 42 | + <div |
| 43 | + key={experience.id} |
| 44 | + className="flex flex-row items-stretch mb-4 mt-4 pl-6 relative" |
| 45 | + > |
| 46 | + {/* Date Column (endDate on top, startDate on bottom) */} |
| 47 | + <div className="absolute left-2 top-0 h-full flex flex-col justify-between items-center"> |
| 48 | + <span |
| 49 | + className="text-xs font-bold" |
| 50 | + style={{ writingMode: "vertical-rl", textOrientation: "upright" }} |
74 | 51 | > |
75 | | - {/* Experience Title & Role */} |
76 | | - <div className="flex flex-row items-center justify-start mb-4 leading-4"> |
77 | | - <h1 className="text-xl font-bold border-r-2 border-gray-400 pr-2"> |
78 | | - {experience.title} |
79 | | - </h1> |
80 | | - <h3 className="pl-2 text-base">{experience.role}</h3> |
81 | | - </div> |
| 52 | + {experience.endDate} |
| 53 | + </span> |
| 54 | + <span |
| 55 | + className="text-xs" |
| 56 | + style={{ writingMode: "vertical-rl", textOrientation: "upright" }} |
| 57 | + > |
| 58 | + {experience.startDate} |
| 59 | + </span> |
| 60 | + </div> |
82 | 61 |
|
83 | | - {/* Experience Details */} |
84 | | - {experience.description.map((item, index) => ( |
85 | | - <p key={index} className="mb-2"> |
86 | | - {highlightText(item, Object.values(SkillsType))} |
87 | | - </p> |
88 | | - ))} |
| 62 | + {/* Experience Content */} |
| 63 | + <div className="flex flex-col flex-1 ml-8"> |
| 64 | + {/* Title & Role */} |
| 65 | + <div className="flex flex-row items-center mb-2"> |
| 66 | + <h1 className="text-lg font-bold border-r-2 border-gray-400 pr-2"> |
| 67 | + {experience.title} |
| 68 | + </h1> |
| 69 | + <h3 className="pl-2 text-sm">{experience.role}</h3> |
89 | 70 | </div> |
| 71 | + |
| 72 | + {/* Description */} |
| 73 | + {experience.description.map((item, i) => ( |
| 74 | + <p key={i} className="mb-2"> |
| 75 | + {highlightText(item, Object.values(SkillsType))} |
| 76 | + </p> |
| 77 | + ))} |
90 | 78 | </div> |
91 | 79 | </div> |
92 | 80 | ); |
|
0 commit comments