From ad4f403893aea7bf7c10f29985430bc4ef769307 Mon Sep 17 00:00:00 2001 From: shubham yadav <126192924+yadavshubham01@users.noreply.github.com> Date: Sat, 23 Nov 2024 13:20:42 +0530 Subject: [PATCH] first commit --- .eslintrc.json | 3 + .gitignore | 36 + README.md | 36 + app/(auth)/layout.tsx | 11 + app/(auth)/sign-in/[[...sign-in]]/page.tsx | 10 + app/(auth)/sign-up/[[...sign-up]]/page.tsx | 10 + .../build-resume/[id]/(edit)/layout.tsx | 209 + .../[id]/(edit)/section/custom/page.tsx | 43 + .../[id]/(edit)/section/education/page.tsx | 45 + .../[id]/(edit)/section/experience/page.tsx | 46 + .../[id]/(edit)/section/final/layout.tsx | 7 + .../[id]/(edit)/section/final/page.tsx | 330 + .../[id]/(edit)/section/header/page.tsx | 49 + .../[id]/(edit)/section/projects/page.tsx | 52 + .../[id]/(edit)/section/skills/page.tsx | 49 + .../build-resume/[id]/(edit)/tips/page.tsx | 70 + .../build-resume/[id]/download/page.tsx | 198 + app/(resume)/build-resume/steps/page.tsx | 116 + app/(resume)/build-resume/templates/page.tsx | 29 + app/(resume)/my-resumes/page.tsx | 30 + app/api/generateJD/route.ts | 55 + app/api/generatePD/route.ts | 69 + app/favicon.ico | Bin 0 -> 25931 bytes app/globals.css | 129 + app/layout.tsx | 39 + app/page.tsx | 142 + components.json | 17 + components/ChooseTemplates.tsx | 148 + components/ContineBtn.tsx | 47 + components/HeaderSkeleton.tsx | 24 + components/LiveResumePreview.tsx | 147 + components/MobilePreviewButton.tsx | 35 + components/Navbar.tsx | 147 + components/PreviewModal.tsx | 48 + components/QuillEditors/QuillEditor.tsx | 57 + components/QuillEditors/QuillExp.tsx | 178 + components/QuillEditors/QuillProject.tsx | 171 + components/SectionInfo.tsx | 29 + components/SocialLinkField.tsx | 74 + components/TipsSkeleton.tsx | 29 + components/VerticalTimeline.tsx | 169 + components/forms/CustomForm.tsx | 138 + components/forms/CustomSectionForm.tsx | 111 + components/forms/EducationForm.tsx | 329 + components/forms/ExperienceForm.tsx | 330 + components/forms/HeaderForm.tsx | 300 + components/forms/ProjectForm.tsx | 215 + components/forms/SkillsForm.tsx | 153 + components/ui/button.tsx | 58 + components/ui/checkbox.tsx | 30 + components/ui/dialog.tsx | 122 + components/ui/input.tsx | 25 + components/ui/label.tsx | 26 + components/ui/select.tsx | 160 + components/ui/skeleton.tsx | 15 + components/ui/tabs.tsx | 55 + components/ui/tooltip.tsx | 30 + convex/README.md | 90 + convex/_generated/api.d.ts | 37 + convex/_generated/api.js | 23 + convex/_generated/dataModel.d.ts | 61 + convex/_generated/server.d.ts | 143 + convex/_generated/server.js | 90 + convex/auth.config.ts | 8 + convex/resume.ts | 700 ++ convex/schema.ts | 128 + convex/tsconfig.json | 25 + lib/documents.jsonl | 37 + lib/font.ts | 17 + lib/migrateResumes.js | 15 + lib/motion.js | 15 + lib/tipsData.tsx | 64 + lib/use-preview.ts | 18 + lib/useMobile.tsx | 22 + lib/utils.ts | 6 + next.config.mjs | 4 + package-lock.json | 8834 +++++++++++++++++ package.json | 62 + postcss.config.mjs | 8 + providers/ConvexAndClerk.tsx | 21 + providers/NextLoader.tsx | 22 + providers/ScreenProvider.tsx | 41 + providers/TemplateWrapper.tsx | 35 + public/image.png | Bin 0 -> 168586 bytes public/next.svg | 1 + public/vercel.svg | 1 + tailwind.config.ts | 82 + templates/template1/Temp1Types.tsx | 61 + templates/template1/Template1.tsx | 354 + templates/template1/temp1obj.tsx | 152 + templates/template2/Template2.tsx | 341 + templates/template2/temp2Types.tsx | 59 + templates/template2/temp2obj.tsx | 138 + templates/template3/Template3.tsx | 360 + templates/template3/temp3obj.tsx | 152 + templates/template3/temp3types.tsx | 0 templates/templateStructures.tsx | 154 + tsconfig.json | 26 + types/templateTypes.tsx | 135 + vercel.json | 8 + 100 files changed, 17780 insertions(+) create mode 100644 .eslintrc.json create mode 100644 .gitignore create mode 100644 README.md create mode 100644 app/(auth)/layout.tsx create mode 100644 app/(auth)/sign-in/[[...sign-in]]/page.tsx create mode 100644 app/(auth)/sign-up/[[...sign-up]]/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/layout.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/custom/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/education/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/experience/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/final/layout.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/final/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/header/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/projects/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/section/skills/page.tsx create mode 100644 app/(resume)/build-resume/[id]/(edit)/tips/page.tsx create mode 100644 app/(resume)/build-resume/[id]/download/page.tsx create mode 100644 app/(resume)/build-resume/steps/page.tsx create mode 100644 app/(resume)/build-resume/templates/page.tsx create mode 100644 app/(resume)/my-resumes/page.tsx create mode 100644 app/api/generateJD/route.ts create mode 100644 app/api/generatePD/route.ts create mode 100644 app/favicon.ico create mode 100644 app/globals.css create mode 100644 app/layout.tsx create mode 100644 app/page.tsx create mode 100644 components.json create mode 100644 components/ChooseTemplates.tsx create mode 100644 components/ContineBtn.tsx create mode 100644 components/HeaderSkeleton.tsx create mode 100644 components/LiveResumePreview.tsx create mode 100644 components/MobilePreviewButton.tsx create mode 100644 components/Navbar.tsx create mode 100644 components/PreviewModal.tsx create mode 100644 components/QuillEditors/QuillEditor.tsx create mode 100644 components/QuillEditors/QuillExp.tsx create mode 100644 components/QuillEditors/QuillProject.tsx create mode 100644 components/SectionInfo.tsx create mode 100644 components/SocialLinkField.tsx create mode 100644 components/TipsSkeleton.tsx create mode 100644 components/VerticalTimeline.tsx create mode 100644 components/forms/CustomForm.tsx create mode 100644 components/forms/CustomSectionForm.tsx create mode 100644 components/forms/EducationForm.tsx create mode 100644 components/forms/ExperienceForm.tsx create mode 100644 components/forms/HeaderForm.tsx create mode 100644 components/forms/ProjectForm.tsx create mode 100644 components/forms/SkillsForm.tsx create mode 100644 components/ui/button.tsx create mode 100644 components/ui/checkbox.tsx create mode 100644 components/ui/dialog.tsx create mode 100644 components/ui/input.tsx create mode 100644 components/ui/label.tsx create mode 100644 components/ui/select.tsx create mode 100644 components/ui/skeleton.tsx create mode 100644 components/ui/tabs.tsx create mode 100644 components/ui/tooltip.tsx create mode 100644 convex/README.md create mode 100644 convex/_generated/api.d.ts create mode 100644 convex/_generated/api.js create mode 100644 convex/_generated/dataModel.d.ts create mode 100644 convex/_generated/server.d.ts create mode 100644 convex/_generated/server.js create mode 100644 convex/auth.config.ts create mode 100644 convex/resume.ts create mode 100644 convex/schema.ts create mode 100644 convex/tsconfig.json create mode 100644 lib/documents.jsonl create mode 100644 lib/font.ts create mode 100644 lib/migrateResumes.js create mode 100644 lib/motion.js create mode 100644 lib/tipsData.tsx create mode 100644 lib/use-preview.ts create mode 100644 lib/useMobile.tsx create mode 100644 lib/utils.ts create mode 100644 next.config.mjs create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 postcss.config.mjs create mode 100644 providers/ConvexAndClerk.tsx create mode 100644 providers/NextLoader.tsx create mode 100644 providers/ScreenProvider.tsx create mode 100644 providers/TemplateWrapper.tsx create mode 100644 public/image.png create mode 100644 public/next.svg create mode 100644 public/vercel.svg create mode 100644 tailwind.config.ts create mode 100644 templates/template1/Temp1Types.tsx create mode 100644 templates/template1/Template1.tsx create mode 100644 templates/template1/temp1obj.tsx create mode 100644 templates/template2/Template2.tsx create mode 100644 templates/template2/temp2Types.tsx create mode 100644 templates/template2/temp2obj.tsx create mode 100644 templates/template3/Template3.tsx create mode 100644 templates/template3/temp3obj.tsx create mode 100644 templates/template3/temp3types.tsx create mode 100644 templates/templateStructures.tsx create mode 100644 tsconfig.json create mode 100644 types/templateTypes.tsx create mode 100644 vercel.json diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 0000000..bffb357 --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,3 @@ +{ + "extends": "next/core-web-vitals" +} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..7e1e047 --- /dev/null +++ b/.gitignore @@ -0,0 +1,36 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.js +.yarn/install-state.gz + +# testing +/coverage + +# next.js +/.next/ +/out/ + +# production +/build + +# misc +.DS_Store +*.pem + +# debug +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +# local env files +.env*.local +.env +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts diff --git a/README.md b/README.md new file mode 100644 index 0000000..c403366 --- /dev/null +++ b/README.md @@ -0,0 +1,36 @@ +This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app). + +## Getting Started + +First, run the development server: + +```bash +npm run dev +# or +yarn dev +# or +pnpm dev +# or +bun dev +``` + +Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. + +You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file. + +This project uses [`next/font`](https://nextjs.org/docs/basic-features/font-optimization) to automatically optimize and load Inter, a custom Google Font. + +## Learn More + +To learn more about Next.js, take a look at the following resources: + +- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. +- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. + +You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js/) - your feedback and contributions are welcome! + +## Deploy on Vercel + +The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. + +Check out our [Next.js deployment documentation](https://nextjs.org/docs/deployment) for more details. diff --git a/app/(auth)/layout.tsx b/app/(auth)/layout.tsx new file mode 100644 index 0000000..dc75d69 --- /dev/null +++ b/app/(auth)/layout.tsx @@ -0,0 +1,11 @@ +import React, { ReactNode } from 'react' + +const AuthLayout = ({children} : {children : ReactNode}) => { + return ( +
+ {children} +
+ ) +} + +export default AuthLayout \ No newline at end of file diff --git a/app/(auth)/sign-in/[[...sign-in]]/page.tsx b/app/(auth)/sign-in/[[...sign-in]]/page.tsx new file mode 100644 index 0000000..c256786 --- /dev/null +++ b/app/(auth)/sign-in/[[...sign-in]]/page.tsx @@ -0,0 +1,10 @@ +import { SignIn } from "@clerk/nextjs"; +import AuthLayout from "../../layout"; + +export default function Page() { + return ( + + + + ); +} diff --git a/app/(auth)/sign-up/[[...sign-up]]/page.tsx b/app/(auth)/sign-up/[[...sign-up]]/page.tsx new file mode 100644 index 0000000..aba3bdd --- /dev/null +++ b/app/(auth)/sign-up/[[...sign-up]]/page.tsx @@ -0,0 +1,10 @@ +import { SignUp } from "@clerk/nextjs"; +import AuthLayout from "../../layout"; + +export default function Page() { + return ( + + + + ); +} diff --git a/app/(resume)/build-resume/[id]/(edit)/layout.tsx b/app/(resume)/build-resume/[id]/(edit)/layout.tsx new file mode 100644 index 0000000..284665c --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/layout.tsx @@ -0,0 +1,209 @@ +"use client"; + +import { useParams, usePathname, useSearchParams } from "next/navigation"; +import { useUser } from "@clerk/nextjs"; +import { useQuery } from "convex/react"; +import { useRouter } from "nextjs-toploader/app"; +import React from "react"; +import toast from "react-hot-toast"; + +import LiveResumePreview from "@/components/LiveResumePreview"; +import VerticalTimeline from "@/components/VerticalTimeline"; +import ContineBtn from "@/components/ContineBtn"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { geologicaFont } from "@/lib/font"; +import { cn } from "@/lib/utils"; +import { motion } from "framer-motion"; +import { item } from "@/lib/motion"; +import useMobile from "@/lib/useMobile"; +import MobilePreviewButton from "@/components/MobilePreviewButton"; +import PreviewModal from "@/components/PreviewModal"; +import { ResumeTemplate } from "@/types/templateTypes"; +import { Button } from "@/components/ui/button"; + +// Types +type Section = + | "header" + | "experience" + | "skills" + | "education" + | "projects" + | "custom" + | "final"; +type ResumeSection = { + type: Section; +}; + +interface ResumeData { + userId: string; + sections: ResumeSection[]; +} + +interface ResumeBuilderLayoutProps { + children: React.ReactNode; +} + +// Constants +const POSSIBLE_SECTIONS: readonly Section[] = [ + "header", + "experience", + "skills", + "education", + "projects", + "custom", + "final", +]; + +const ResumeBuilderLayout: React.FC = ({ + children, +}) => { + // Hooks + const params = useParams(); + const router = useRouter(); + const { user, isLoaded } = useUser(); + const searchParams = useSearchParams(); + const pathname = usePathname(); + const isMobile = useMobile(); + + const resumeId = params.id as Id<"resumes">; + const resume = useQuery(api.resume.getTemplateDetails, { id: resumeId }); + + // Helper functions + const validateSection = (section: string): section is Section => { + return POSSIBLE_SECTIONS.includes(section as Section); + }; + + const getNavigationUrls = ( + sectionArray: Section[], + currentSection: string | null, + pathname: string + ): { prevUrl: string; nextUrl: string } => { + if (currentSection) { + return handleSearchParamNavigation(sectionArray, currentSection); + } + return handlePathNavigation(sectionArray, pathname); + }; + + const handleSearchParamNavigation = ( + sectionArray: Section[], + sec: string + ) => { + const index = sectionArray.findIndex((item) => item === sec); + const nextSection = sec === "custom" ? "custom" : sectionArray[index]; + const prevSection = sectionArray[index - 1] ?? "header"; + + return { + nextUrl: `/build-resume/${resumeId}/section/${nextSection}`, + prevUrl: + sec === "header" + ? `/build-resume/${resumeId}/tips?sec=header` + : `/build-resume/${resumeId}/section/${prevSection}`, + }; + }; + + const handlePathNavigation = (sectionArray: Section[], pathname: string) => { + const sectionType = pathname.split("/section/")[1] as Section; + const currentIndex = sectionArray.findIndex((item) => item === sectionType); + + return { + prevUrl: + sectionType === "final" + ? `/build-resume/${resumeId}/tips?sec=custom` + : `/build-resume/${resumeId}/tips?sec=${sectionArray[currentIndex]}`, + nextUrl: + sectionType === "custom" + ? `/build-resume/${resumeId}/section/final` + : sectionType === "final" + ? `/build-resume/${resumeId}/download` + : `/build-resume/${resumeId}/tips?sec=${sectionArray[currentIndex + 1]}`, + }; + }; + + // Error handling and validation + if (resume === undefined) return null; + if (resume === null) return
Template not found
; + if (isLoaded && resume?.userId !== user?.id) { + toast.error("Not authenticated"); + router.push("/"); + return null; + } + + const sectionArray: Section[] = resume.sections.map((item) => item.type); + sectionArray.push("custom"); + sectionArray.push("final"); + const sec = searchParams.get("sec"); + + if (sec && !validateSection(sec)) { + toast.error("Invalid section"); + router.push(`/build-resume/${resumeId}/tips?sec=header`); + return null; + } + + const currentSection = pathname.split("/section/")[1]; + if (currentSection && !validateSection(currentSection)) { + toast.error("Invalid section"); + router.push(`/build-resume/${resumeId}/tips?sec=header`); + return null; + } + + const { prevUrl, nextUrl } = getNavigationUrls(sectionArray, sec, pathname); + + // Render + return ( + <> +
+ +
+
+ + +
+
+
+
+ +
+ +
+ {children} + {(isMobile || (!currentSection && !isMobile)) && ( + + + + + )} +
+
+ +
+ +
+
+ + + + ); +}; + +export default ResumeBuilderLayout; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/custom/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/custom/page.tsx new file mode 100644 index 0000000..fa89042 --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/custom/page.tsx @@ -0,0 +1,43 @@ +"use client"; + +import CustomForm from "@/components/forms/CustomForm"; +import SkillsForm from "@/components/forms/SkillsForm"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import SectionInfo from "@/components/SectionInfo"; +import { api } from "@/convex/_generated/api"; +import { Doc, Id } from "@/convex/_generated/dataModel"; +import { useQuery } from "convex/react"; +import { useParams } from "next/navigation"; +import { useRouter } from 'nextjs-toploader/app'; + +const Page = () => { + const params = useParams(); + const resumeId = params.id; + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + + if (resume === null) { + return
No Template Found
; + } + if (resume === undefined) { + return ; + } + + return ( +
+ + + } + styles={"sadf"} + item={"asdf"} + /> +
+ ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/education/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/education/page.tsx new file mode 100644 index 0000000..f61bb4a --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/education/page.tsx @@ -0,0 +1,45 @@ +"use client"; +import EducationForm from "@/components/forms/EducationForm"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import SectionInfo from "@/components/SectionInfo"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { EducationSection } from "@/types/templateTypes"; +import { useQuery } from "convex/react"; +import { useParams, useRouter } from "next/navigation"; +import React from "react"; + +const Page = () => { + const params = useParams(); + const resumeId = params.id; + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + if (resume === null) { + return
No template found
; + } + if (resume === undefined) { + return ; + } + + return ( + <> + {resume?.sections?.map((item, idx) => { + if (item?.type === "education") { + return ( +
+ + } item={item as EducationSection} /> +
+ ); + } + })} + + ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/experience/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/experience/page.tsx new file mode 100644 index 0000000..86b3ceb --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/experience/page.tsx @@ -0,0 +1,46 @@ +"use client"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { useQuery } from "convex/react"; +import { useParams } from "next/navigation"; +import React from "react"; +import SectionInfo from "@/components/SectionInfo"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import ExperienceForm from "@/components/forms/ExperienceForm"; + +const Page = () => { + + const params = useParams(); + const resumeId = params.id as Id<"resumes">; + const resume = useQuery(api.resume.getTemplateDetails, { id: resumeId }); + + if (resume === null) { + return
Template not found
; + } + + if (resume === undefined) { + return ; + } + + return ( + <> + {resume.sections?.map((item, idx) => { + if (item?.type === "experience") { + return ( +
+ + + +
+ ); + } + return null; + })} + + ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/final/layout.tsx b/app/(resume)/build-resume/[id]/(edit)/section/final/layout.tsx new file mode 100644 index 0000000..2ca29c1 --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/final/layout.tsx @@ -0,0 +1,7 @@ +import React, { ReactNode } from "react"; + +const FinalLayout = ({ children }: { children: ReactNode }) => { + return
{children}
; +}; + +export default FinalLayout; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/final/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/final/page.tsx new file mode 100644 index 0000000..bf07b99 --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/final/page.tsx @@ -0,0 +1,330 @@ +"use client"; +import React, { useEffect, useMemo, useState } from "react"; +import FinalLayout from "./layout"; +import { ColorPicker, useColor } from "react-color-palette"; +import "react-color-palette/css"; +import { debounce } from "lodash"; +import { useParams } from "next/navigation"; +import { useMutation, useQuery } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { Label } from "@/components/ui/label"; +import { Button } from "@/components/ui/button"; +import { motion } from "framer-motion"; +import { ChevronDown, Eye, EyeOff } from "lucide-react"; +import SortableList, { SortableItem } from "react-easy-sort"; +import { arrayMoveImmutable } from "array-move"; + +interface Section { + type: string; + title: string; +} + +const Page = () => { + const [primaryTextColor, setPrimaryTextColor] = useColor("#000"); + const [primaryColor, setPrimaryColor] = useColor("#000"); + const [showPrimaryTextColorBox, setShowPrimaryTextColorBox] = useState(false); + const [showPrimaryColorBox, setShowPrimaryColorBox] = useState(false); + + const params = useParams(); + const resumeId = params.id; + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + + const sortedSections = resume?.sections.sort( + (a: any, b: any) => a.orderNumber - b.orderNumber + ); + const [sections, setSections] = useState(sortedSections); + + const reorder = useMutation(api.resume.reorderSections); + const update = useMutation(api.resume.updateColor); + const updatePC = useMutation(api.resume.updateColorPC); + const updateFont = useMutation(api.resume.updateFont); + + const hideSection = useMutation(api.resume.hideSection); + + const toggleSectionVisibility = (sectionId: string) => { + hideSection({ id: resumeId as Id<"resumes">, sectionId: sectionId }); + }; + + useEffect(() => { + if (resume?.sections) { + const mainSections = resume.sections.filter( + (item) => item.type !== "custom" + ); + const customSections = resume.sections.filter( + (item) => item.type === "custom" + ); + const updatedSections = [...mainSections, ...customSections].sort( + (a: any, b: any) => a.orderNumber - b.orderNumber + ); + setSections(updatedSections); + } + }, [resume]); + + const onSortEnd = (oldIndex: number, newIndex: number) => { + setSections((prev: any) => { + const newSections = arrayMoveImmutable(prev, oldIndex, newIndex); + const updatedSections = newSections.map( + (section: any, index: number) => ({ + ...section, + orderNumber: index, + }) + ); + + reorder({ + id: resumeId as Id<"resumes">, + updatedSections: updatedSections, + }); + return updatedSections; + }); + }; + + const handlePrimaryTextColorChange = useMemo(() => { + return debounce((color: any) => { + setPrimaryTextColor(color); + update({ id: resumeId as Id<"resumes">, color: color.hex }); + }, 400); + }, [update, setPrimaryTextColor, resumeId]); + + const handlePrimaryColorChange = useMemo(() => { + return debounce((color: any) => { + setPrimaryColor(color); + updatePC({ id: resumeId as Id<"resumes">, color: color.hex }); + }, 400); + }, [setPrimaryColor, updatePC, resumeId]); + + const handleChosePrimaryColor = (color: string) => { + updatePC({ id: resumeId as Id<"resumes">, color: color }); + }; + + const handleChosePrimaryTextColor = (color: string) => { + update({ id: resumeId as Id<"resumes">, color: color }); + }; + + const colorOptions = [ + "#000", + "#C026D3", + "#153b66", + "#a1be29", + "#955b15", + ]; + + const fontOptions = [ + "Raleway", + "Inter", + "OpenSans", + "Poppins", + "Montserrat", + "Geologica", + ]; + + const handleFontChange = (font: string) => { + updateFont({ id: resumeId as Id<"resumes">, font }); + }; + + const currentFont = resume?.globalStyles?.fontFamily || "Inter"; + + return ( + +
+
+

Almost Done !!

+

+ Change the theme color and font of your resume if you want... +

+
+ +
+
+ +

Reorder the sections if you want...

+
+ + {sections?.map((item: any, index: number) => { + return ( + +
+
+ {item?.orderNumber + 1} +
+
+ + {item.type === "custom" + ? item.content.sectionTitle + : item.type} + + +
+
+
+ ); + })} +
+
+ +
+
+ +

+ This is for all the title text that you can see in the resume.. +

+
+
+ {colorOptions.map((item) => { + return ( + handleChosePrimaryTextColor(item)} + className={`size-[35px] ${ + resume?.globalStyles?.primaryTextColor === item && + "size-[38px] ring-2 ring-offset-2 ring-black" + } rounded-full cursor-pointer`} + style={{ backgroundColor: item }} + > + ); + })} + + + + +
+
+ + {showPrimaryTextColorBox && ( +
+ +
+ )} + +
+
+ +

+ This is for all the borders or designs that you can see in the + resume. +

+
+
+ {colorOptions.map((item) => { + return ( + handleChosePrimaryColor(item)} + className={`size-[35px] ${ + resume?.globalStyles?.primaryColor === item && + "size-[38px] ring-2 ring-offset-2 ring-black" + } rounded-full cursor-pointer`} + style={{ backgroundColor: item }} + > + ); + })} + + + + +
+
+ + {showPrimaryColorBox && ( +
+ +
+ )} + +
+ +

+ Choose a font style for your resume... +

+
+
+ {fontOptions?.map((item, index) => { + return ( + + ); + })} +
+
+
+ ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/header/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/header/page.tsx new file mode 100644 index 0000000..20b733b --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/header/page.tsx @@ -0,0 +1,49 @@ +"use client"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { useQuery } from "convex/react"; +import { useParams } from "next/navigation"; +import React from "react"; +import SectionInfo from "@/components/SectionInfo"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import HeaderForm from "@/components/forms/HeaderForm"; +import { HeaderSection } from "@/types/templateTypes"; +import useMobile from "@/lib/useMobile"; +import ContineBtn from "@/components/ContineBtn"; + +const Page = () => { + const params = useParams(); + const resumeId = params.id as Id<"resumes">; + const resume = useQuery(api.resume.getTemplateDetails, { id: resumeId }); + const isMobile = useMobile(); + + if (resume === null) { + return
Template not found
; + } + + if (resume === undefined) { + return ; + } + + return ( + <> + {resume.sections?.map((item, idx) => { + if (item?.type === "header") { + return ( +
+ + +
+ ); + } + return null; + })} + + ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/projects/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/projects/page.tsx new file mode 100644 index 0000000..a092399 --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/projects/page.tsx @@ -0,0 +1,52 @@ +"use client"; +import ProjectForm from "@/components/forms/ProjectForm"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import SectionInfo from "@/components/SectionInfo"; +import { Button } from "@/components/ui/button"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { ProjectSection } from "@/types/templateTypes"; +import { useMutation, useQuery } from "convex/react"; +import { useParams } from "next/navigation"; +import React from "react"; +import { useRouter } from 'nextjs-toploader/app'; + +const Page = () => { + const params = useParams(); + const resumeId = params.id; + const router = useRouter(); + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + if (resume === null) { + return
No template found
; + } + if (resume === undefined) { + return ; + } + + + let sectionArray: string[] = []; + resume?.sections?.map((item) => sectionArray.push(item.type)); + let projectIndex = sectionArray.findIndex((item) => item === "projects"); + + return ( + <> + {resume?.sections?.map((item, idx) => { + if (item?.type === "projects") { + return ( +
+ + } item={item as ProjectSection} /> +
+ ); + } + })} + + ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/section/skills/page.tsx b/app/(resume)/build-resume/[id]/(edit)/section/skills/page.tsx new file mode 100644 index 0000000..fef7a90 --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/section/skills/page.tsx @@ -0,0 +1,49 @@ +"use client"; + +import SkillsForm from "@/components/forms/SkillsForm"; +import HeaderSkeleton from "@/components/HeaderSkeleton"; +import SectionInfo from "@/components/SectionInfo"; +import { api } from "@/convex/_generated/api"; +import { Doc, Id } from "@/convex/_generated/dataModel"; +import { useQuery } from "convex/react"; +import { useParams } from "next/navigation"; + +const Page = () => { + const params = useParams(); + const resumeId = params.id; + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + + if (resume === null) { + return
No Template Found
; + } + if (resume === undefined) { + return ; + } + + return ( + <> + {resume?.sections?.map((item, idx) => { + if (item?.type === "skills") { + return ( +
+ + + } + styles={item?.style} + item={item} + /> +
+ ); + } + })} + + ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/(edit)/tips/page.tsx b/app/(resume)/build-resume/[id]/(edit)/tips/page.tsx new file mode 100644 index 0000000..5d6f2db --- /dev/null +++ b/app/(resume)/build-resume/[id]/(edit)/tips/page.tsx @@ -0,0 +1,70 @@ +"use client"; +import ContineBtn from "@/components/ContineBtn"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { tipsData } from "@/lib/tipsData"; +import { cn } from "@/lib/utils"; +import { useQuery } from "convex/react"; +import { useParams, useSearchParams } from "next/navigation"; +import React from "react"; +import { motion } from "framer-motion"; +import { container, item } from "@/lib/motion"; +import TipsSkeleton from "@/components/TipsSkeleton"; +import { geologicaFont, poppinsFont } from "@/lib/font"; + +const Page = () => { + const searchParams = useSearchParams(); + const sec = searchParams.get("sec"); + + const params = useParams(); + const resumeId = params.id; + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + + if (resume === null) { + return
no document
; + } + + if (resume === undefined) { + return ; + } + + let sectionArray: string[] = []; + resume?.sections?.map((item) => sectionArray.push(item.type)); + + const currentTips = tipsData.find((item) => item.sec === sec); + + return ( +
+ +
+ + {currentTips?.topText} + + +

+ {currentTips?.mainText} +

+
+

+ {currentTips?.bottomMainText} +

+

+ {currentTips?.bottomText} +

+
+
+
+ +
+
+ ); +}; + +export default Page; diff --git a/app/(resume)/build-resume/[id]/download/page.tsx b/app/(resume)/build-resume/[id]/download/page.tsx new file mode 100644 index 0000000..a773546 --- /dev/null +++ b/app/(resume)/build-resume/[id]/download/page.tsx @@ -0,0 +1,198 @@ +"use client"; +import { useParams, useSearchParams } from "next/navigation"; +import React, { useRef, useState } from "react"; +import Template1 from "@/templates/template1/Template1"; +import { useQuery } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { ResumeTemplate } from "@/types/templateTypes"; +import Template2 from "@/templates/template2/Template2"; +import { Button } from "@/components/ui/button"; +import { cn } from "@/lib/utils"; +import toast from "react-hot-toast"; +import { + CheckCircle, + Download, + DownloadCloud, + Loader, + Loader2, +} from "lucide-react"; +import Navbar from "@/components/Navbar"; +import { + geologicaFont, + interFont, + montserratFont, + openSansFont, + poppinsFont, + ralewayFont, +} from "@/lib/font"; +import useMobile from "@/lib/useMobile"; + +const LiveResumePreview = () => { + const params = useParams(); + const [loading, setLoading] = useState(false); + + const templateDetails = useQuery(api.resume.getTemplateDetails, { + id: params.id as Id<"resumes">, + }) as ResumeTemplate | undefined | null; + + const searchParams = useSearchParams(); + const resumeOnlyMode = searchParams.get("resumeonly") === "true"; + const isMobile = useMobile(); + + if (templateDetails === null) { + return ( +
+

Template not found

+
+ ); + } + if (templateDetails === undefined) { + return ( +
+ +
+ ); + } + + type TemplateComponentType = React.ComponentType<{ + obj: ResumeTemplate; + size: "md" | "sm" | "lg"; + }>; + + const templateComponents: Record = { + Template1: Template1, + Template2: Template2, + }; + + const TemplateComponent = templateComponents[templateDetails.templateName]; + + if (!TemplateComponent) { + console.error( + `No component found for template: ${templateDetails.templateName}` + ); + return ( +
+

Error: Template not found

+
+ ); + } + + const handlePdfDownload = () => { + window.print(); + }; + + return ( +
+
+ +
+ +
+ {!resumeOnlyMode && ( +
+

+ Your Resume is Ready !! +

+ +
+
+ +

+ Your resume has been professionally formatted and is ready for + download. +

+
+ +
+ +

+ When downloading, select 'Save as Pdf' and Paper + Size 'ISO A4' to ensure the resume text remains + selectable, allowing easy copy-pasting by recruiters. +

+
+ +
+ +

+ Take a moment to review your resume one last time before + sharing it with potential employers. +

+
+
+ +
+ + + {loading && ( +

+ Downloading may take few seconds so kindly be patient... +

+ )} +
+
+ )} + +
+
+ {templateDetails && ( + + )} +
+
+
+
+ ); +}; + +export default LiveResumePreview; diff --git a/app/(resume)/build-resume/steps/page.tsx b/app/(resume)/build-resume/steps/page.tsx new file mode 100644 index 0000000..5021fdb --- /dev/null +++ b/app/(resume)/build-resume/steps/page.tsx @@ -0,0 +1,116 @@ +"use client"; +import { Button } from "@/components/ui/button"; +import { ArrowRight, Computer, LayoutTemplate, PencilLine } from "lucide-react"; +import Link from "next/link"; +import React from "react"; +import { motion } from "framer-motion"; +import { container, item } from "@/lib/motion"; +import { geologicaFont, poppinsFont } from "@/lib/font"; + +const Page = () => { + return ( + <> +
+ {/* Left section */} +
+
+

+ Say hello to ResumeCraft +

+

+ Get your resume ready in 3 steps +

+

+ Resume Craft gives you the tools and guidance you need to create a + truly professional resume that highlights your skills and + experience. +

+
+ + + + + + +
+
+
+ + {/* Right section */} +
+
+
+ +
+
+

+ Step-1: Start with a great template +

+

+ Choose from our collection of pre-designed templates tailored + for various industries and career levels. +

+
+
+ +
+
+ +
+
+

+ Step-2: Add compelling content +

+

+ Utilize our AI-powered content suggestions to effectively + describe your skills, experience, and achievements. +

+
+
+ +
+
+ +
+
+

+ Step-3: Customize and polish +

+

+ Fine-tune your resume's layout, style, and content to make + it uniquely yours and stand out to employers. +

+
+
+
+ + + + + + +
+
+
+ + ); +}; + +export default Page; \ No newline at end of file diff --git a/app/(resume)/build-resume/templates/page.tsx b/app/(resume)/build-resume/templates/page.tsx new file mode 100644 index 0000000..670f47e --- /dev/null +++ b/app/(resume)/build-resume/templates/page.tsx @@ -0,0 +1,29 @@ +import ChooseTemplates from "@/components/ChooseTemplates"; +import Navbar from "@/components/Navbar"; + +const Page = () => { + return ( + <> +
+ +
+
+

+ Recommended Templates +

+

+ Start with a solid foundation — select a template and build your + perfect resume. +

+
+
+ +
+ +
+
+ + ); +}; + +export default Page; diff --git a/app/(resume)/my-resumes/page.tsx b/app/(resume)/my-resumes/page.tsx new file mode 100644 index 0000000..51b5a0a --- /dev/null +++ b/app/(resume)/my-resumes/page.tsx @@ -0,0 +1,30 @@ +"use client"; +import Navbar from "@/components/Navbar"; +import React from "react"; +import ChooseTemplates from "@/components/ChooseTemplates"; + +const Page = () => { + return ( + <> +
+ +
+
+

+ My Resumes. +

+

+ Select a template and contine building your perfect resume. +

+
+
+ +
+ +
+
+ + ); +}; + +export default Page; diff --git a/app/api/generateJD/route.ts b/app/api/generateJD/route.ts new file mode 100644 index 0000000..aed4a8a --- /dev/null +++ b/app/api/generateJD/route.ts @@ -0,0 +1,55 @@ +import { NextRequest, NextResponse } from "next/server"; +import { GoogleGenerativeAI } from "@google/generative-ai"; + +function parseStringToArray(str: string) { + str = str.trim().slice(1, -1); + let items = str.split(/,\s*\n/); + items = items.map((item) => item.trim().replace(/^"|"$/g, "")); + + return items; +} + +export async function POST(req: NextRequest, res: NextResponse) { + try { + const genAI = new GoogleGenerativeAI(process.env.API_KEY!); + + const model = genAI.getGenerativeModel({ model: "gemini-1.5-flash" }); + + const { companyName, role,jobDescription } = await req.json(); + + let prompt = ""; + + if (companyName && role && !jobDescription) { + prompt = `for a ${role} who has worked at ${companyName} write a job description in 3 points..each point + must not exceed 1.5-2lines and should be + atleast 0.5 lines...Use metrics in the job description... + + make sure the response should be in the form of array of points so that i can use JSON.parse() on that response..Dont add any text before or after it... + + dont put a \n after [ and before ] + + Example points : Designed and developed web applications used by the DJSI committee, ensuring a 99.5% uptime to support critical sustainability ratings.,Optimized code and implemented efficient database management strategies, resulting in a 25% reduction in application load times.,Successfully integrated third-party data feeds, improving the accuracy and comprehensiveness of DJSI data by 15% `; + } else { + prompt = `for a ${role} who has worked at ${companyName} this is the job descriptoin ${jobDescription}..write 3 bullet points..each point + must not exceed 1.5-2lines and should be + atleast 0.5 lines...Use metrics in the job description to make it more ats friendly... + + make sure the response should be in the form of array of points so that i can use JSON.parse() on that response..Dont add any text before or after it... + + dont put a \n after [ and before ] + + Example points : Designed and developed web applications used by the DJSI committee, ensuring a 99.5% uptime to support critical sustainability ratings.,Optimized code and implemented efficient database management strategies, resulting in a 25% reduction in application load times.,Successfully integrated third-party data feeds, improving the accuracy and comprehensiveness of DJSI data by 15% `; + } + + const result = await model.generateContent(prompt); + const response = await result.response; + let text = response.text(); + + + const textArray = parseStringToArray(text); + + return NextResponse.json({ textArray }, { status: 200 }); + } catch (error) { + return NextResponse.json({ error }, { status: 500 }); + } +} diff --git a/app/api/generatePD/route.ts b/app/api/generatePD/route.ts new file mode 100644 index 0000000..da46256 --- /dev/null +++ b/app/api/generatePD/route.ts @@ -0,0 +1,69 @@ +import { NextRequest, NextResponse } from "next/server"; +import { GoogleGenerativeAI } from "@google/generative-ai"; + +function parseStringToArray(str: string) { + // Remove leading and trailing brackets + str = str.trim().slice(1, -1); + + // Split the string by comma and newline + let items = str.split(/,\s*\n/); + + // Clean each item and remove surrounding quotes + items = items.map((item) => item.trim().replace(/^"|"$/g, "")); + + return items; +} + +export async function POST(req: NextRequest, res: NextResponse) { + try { + const genAI = new GoogleGenerativeAI(process.env.API_KEY!); + + const model = genAI.getGenerativeModel({ model: "gemini-1.5-flash" }); + + const { projectTitle, projectDescription } = await req.json(); + + let prompt = ""; + + if (projectTitle && !projectDescription) { + prompt = `The title of the project is ${projectTitle}...Write project description in 3 points ..each point + must not exceed 1.5-2lines and should be + atleast 0.5 lines...Use metrics in the job description... + + make sure the response should be in the form of array of points so that i can use JSON.parse() on that response..Dont add any text before or after it... + write description as you are supposed to write it in a resume describing the project and not explaining it to someone + + dont put a \n after [ and before ] + + Example points : Built an Advanced Resume Builder using Next.js, Tailwind CSS, Shadcn UI, and TypeScript, allowing +users to create high ATS (Applicant Tracking System) resumes from scratch with ease, increasing +resume quality by 40%.,Integrated Convex DB for efficient database management, ensuring a 50% improvement in data +retrieval speeds and a smooth user experience with real-time updates.,Implemented customizable templates and real-time preview, enabling users to see changes +instantly and choose from various professional designs, boosting user engagement by 35%. `; + } else if (projectTitle && projectDescription) { + prompt = `The title of the project is ${projectTitle} and its description is ${projectDescription}...Improve this project description and write it in 3 points ..each point + must not exceed 1.5-2lines and should be + atleast 0.5 lines...Use metrics in the job description this is very very important...if the description contains tech stack make sure to use it while you improve + write description as you are supposed to write it in a resume describing the project and not explaining it to someone + + make sure the response should be in the form of array of points so that i can use JSON.parse() on that response..Dont add any text before or after it... + + dont put a \n after [ and before ] + + Example points : Built an Advanced Resume Builder using Next.js, Tailwind CSS, Shadcn UI, and TypeScript, allowing + users to create high ATS (Applicant Tracking System) resumes from scratch with ease, increasing + resume quality by 40%.,Integrated Convex DB for efficient database management, ensuring a 50% improvement in data + retrieval speeds and a smooth user experience with real-time updates.,Implemented customizable templates and real-time preview, enabling users to see changes + instantly and choose from various professional designs, boosting user engagement by 35%. `; + } + + const result = await model.generateContent(prompt); + const response = await result.response; + let text = response.text(); + + const textArray = parseStringToArray(text); + + return NextResponse.json({ textArray }, { status: 200 }); + } catch (error) { + return NextResponse.json({ error }, { status: 500 }); + } +} diff --git a/app/favicon.ico b/app/favicon.ico new file mode 100644 index 0000000000000000000000000000000000000000..718d6fea4835ec2d246af9800eddb7ffb276240c GIT binary patch literal 25931 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 LrJugUA?W`A8`#=m literal 0 HcmV?d00001 diff --git a/app/globals.css b/app/globals.css new file mode 100644 index 0000000..5ff4475 --- /dev/null +++ b/app/globals.css @@ -0,0 +1,129 @@ +@tailwind base; +@tailwind components; +@tailwind utilities; + +@layer base { + img { + @apply inline-block; + } +} +@layer base { + :root { + --background: 345 83% 97%; + --foreground: 240 10% 3.9%; + --card: 0 0% 100%; + --card-foreground: 240 10% 3.9%; + --popover: 0 0% 100%; + --popover-foreground: 240 10% 3.9%; + --primary: 346.8 77.2% 49.8%; + --primary-foreground: 355.7 100% 97.3%; + --secondary: 240 4.8% 95.9%; + --secondary-foreground: 240 5.9% 10%; + --muted: 240 4.8% 95.9%; + --muted-foreground: 240 3.8% 46.1%; + --accent: 240 4.8% 95.9%; + --accent-foreground: 240 5.9% 10%; + --destructive: 0 84.2% 60.2%; + --destructive-foreground: 0 0% 98%; + --border: 240 5.9% 90%; + --input: 240 5.9% 90%; + --ring: 346.8 77.2% 49.8%; + --radius: 0.5rem; + } + + .dark { + --background: 20 14.3% 4.1%; + --foreground: 0 0% 95%; + --card: 24 9.8% 10%; + --card-foreground: 0 0% 95%; + --popover: 0 0% 9%; + --popover-foreground: 0 0% 95%; + --primary: 346.8 77.2% 49.8%; + --primary-foreground: 355.7 100% 97.3%; + --secondary: 240 3.7% 15.9%; + --secondary-foreground: 0 0% 98%; + --muted: 0 0% 15%; + --muted-foreground: 240 5% 64.9%; + --accent: 12 6.5% 15.1%; + --accent-foreground: 0 0% 98%; + --destructive: 0 62.8% 30.6%; + --destructive-foreground: 0 85.7% 97.3%; + --border: 240 3.7% 15.9%; + --input: 240 3.7% 15.9%; + --ring: 346.8 77.2% 49.8%; + } +} + +@layer base { + * { + @apply border-border; + } + body { + @apply bg-background text-foreground !overflow-x-hidden; + } +} + +.quill-content ul { + list-style-type: disc; + padding-left: 1em; +} + +.quill-content ol { + list-style-type: decimal; + padding-left: 1em; +} + +.quill-content li { + margin-bottom: 0.3em; +} + +body { + padding: 0px; + margin: 0px; +} + +@layer utilities { + /* Hide scrollbar for Chrome, Safari and Opera */ + .no-scrollbar::-webkit-scrollbar { + display: none; + } + /* Hide scrollbar for IE, Edge and Firefox */ + .no-scrollbar { + -ms-overflow-style: none; /* IE and Edge */ + scrollbar-width: none; /* Firefox */ + } +} + +@media print { + #no-print { + display: none; + } + + #pdf { + display: block; + } + + body { + margin: 0; + padding: 0; + box-sizing: border-box; + } + + #hello { + transform: none !important; /* Reset any transforms */ + position: absolute !important; + top: 0 !important; + left: 0 !important; + width: 100% !important; + height: 100% !important; + border-radius: 0 !important; + } +} + +@page { + size: auto; + margin: 0mm; +} +.radial { + background: radial-gradient(circle, #fff, #ffe4e6); +} diff --git a/app/layout.tsx b/app/layout.tsx new file mode 100644 index 0000000..be2bf11 --- /dev/null +++ b/app/layout.tsx @@ -0,0 +1,39 @@ +import type { Metadata } from "next"; +import "./globals.css"; +import ConvexAndClerk from "@/providers/ConvexAndClerk"; +import { Toaster } from "react-hot-toast"; +import { poppinsFont } from "@/lib/font"; +import React from "react"; +import { Analytics } from "@vercel/analytics/react"; +import { SpeedInsights } from "@vercel/speed-insights/next"; +import NextTopLoader from "nextjs-toploader"; +import { useRouter } from "next/navigation"; +import NextLoader from "@/providers/NextLoader"; + +export const metadata: Metadata = { + title: "Resume Craft", + description: "Craft a winning resume in minutes", +}; + +export default function RootLayout({ + children, +}: Readonly<{ + children: React.ReactNode; +}>) { + + return ( + + + + {/* */} + + + + + {children} + {/* */} + + + + ); +} diff --git a/app/page.tsx b/app/page.tsx new file mode 100644 index 0000000..c90c730 --- /dev/null +++ b/app/page.tsx @@ -0,0 +1,142 @@ +"use client"; +import Navbar from "@/components/Navbar"; +import { Button } from "@/components/ui/button"; +import { motion } from "framer-motion"; +import { container, item } from "@/lib/motion"; +import { geologicaFont, poppinsFont } from "@/lib/font"; +import { ArrowRight, Check } from "lucide-react"; +import React, { useEffect, useRef, useState } from "react"; +import { temp2Obj } from "@/templates/template2/temp2obj"; +import Template2 from "@/templates/template2/Template2"; +import { useRouter } from "next/navigation"; +import Template1 from "@/templates/template1/Template1"; +import temp1Obj from "@/templates/template1/temp1obj"; +import useMobile from "@/lib/useMobile"; + +export default function Home() { + + const router = useRouter(); + const isMobile = useMobile(); + + // const oneTimeRef = useRef(false); + // const migration = useMutation(api.resume.migrateResumes); + + // useEffect(() => { + // if (!oneTimeRef.current) { + // const promise = migration() + // .then((res) => { + // console.log(res, "yes"); + // }) + // .catch((err) => { + // console.log(err, "no"); + // }); + // oneTimeRef.current = true; + // } + // }, []); + + return ( +
+ +
+
+ {/* Content Section */} + +
+ {/* Heading */} + + Transform Your Experience into an Impactful Resume + + + {/* Description */} + + {!isMobile && ( + Create standout resumes and impress employers. + )} + Our user-friendly builder offers customizable templates to + ensure your resume is job-ready. + + + {/* Features List */} + + {[ + "ATS-optimized resumes", + "Professional templates tto industry standards", + "Customizable layouts for personal branding", + "Real-time preview to ensure perfection", + "Save hours with easy-to-use tools", + ].map((feature, index) => ( +
  • + + {feature} +
  • + ))} +
    + + {/* CTA Button */} + + + +
    +
    + + {/* Template Preview */} + + + + + + + +
    +
    +
    + ); +} diff --git a/components.json b/components.json new file mode 100644 index 0000000..15f2b02 --- /dev/null +++ b/components.json @@ -0,0 +1,17 @@ +{ + "$schema": "https://ui.shadcn.com/schema.json", + "style": "default", + "rsc": true, + "tsx": true, + "tailwind": { + "config": "tailwind.config.ts", + "css": "app/globals.css", + "baseColor": "slate", + "cssVariables": true, + "prefix": "" + }, + "aliases": { + "components": "@/components", + "utils": "@/lib/utils" + } +} \ No newline at end of file diff --git a/components/ChooseTemplates.tsx b/components/ChooseTemplates.tsx new file mode 100644 index 0000000..e5dfb54 --- /dev/null +++ b/components/ChooseTemplates.tsx @@ -0,0 +1,148 @@ +"use client"; +import { Button } from "./ui/button"; +import { Edit, Eye } from "lucide-react"; +import { useUser } from "@clerk/nextjs"; +import { useMutation, useQuery } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { redirect } from "next/navigation"; +import toast from "react-hot-toast"; +import { Id } from "@/convex/_generated/dataModel"; +import { Skeleton } from "./ui/skeleton"; +import { + templateComponents, + TemplateComponentType, +} from "@/templates/templateStructures"; +import { ResumeTemplate } from "@/types/templateTypes"; +import { usePreview } from "@/lib/use-preview"; +import PreviewModal from "./PreviewModal"; +import { cn } from "@/lib/utils"; +import React from "react"; +import { useRouter } from "nextjs-toploader/app"; +import Template3 from "@/templates/template3/Template3"; +import temp1Obj from "@/templates/template1/temp1obj"; +import temp3obj from "@/templates/template3/temp3obj"; + +const ChooseTemplates = ({ myResumes = false }: { myResumes?: boolean }) => { + const { user } = useUser(); + const createUserResume = useMutation(api.resume.createUserResume); + const router = useRouter(); + const templates = useQuery(api.resume.getTemplates); + const myResumeTemplates = useQuery(api.resume.getUserResumes, { + userId: user?.id || "", + }); + const preview = usePreview(); + + const finalTemplates = myResumes ? myResumeTemplates : templates; + + if (finalTemplates === undefined) { + return ; + } + if (finalTemplates.length === 0) { + return ( +
    +

    + {myResumes ? "No resumes found" : "No templates found"} +

    +
    + ); + } + if (!user) { + return redirect("/sign-up"); + } + + const selectResume = async (id: Id<"resumes">, templateName: string) => { + createUserResume({ + id: id, + userId: user?.id, + templateName: templateName, + }) + .then((res) => { + return router.push(`/build-resume/${res}/tips?sec=header`); + }) + .catch((err) => { + console.log(err); + toast.error("Something went wrong..."); + }); + }; + + const editResume = (resumeId: Id<"resumes">) => { + router.push(`/build-resume/${resumeId}/tips?sec=header`); + }; + + return ( +
    + {finalTemplates?.map((item, index) => { + const TemplateComponent: TemplateComponentType = + templateComponents[item.templateName]; + + if (!TemplateComponent) { + console.error( + `No component found for template: ${item.templateName}` + ); + return null; + } + + return ( +
    +
    + +
    + +
    + + +
    +
    + ); + })} + {/* */} +
    + +
    +
    + ); +}; + +const ChooseSkeleton = () => { + return ( +
    + {[1, 2, 3, 4, 5, 6, 7, 8].map((item) => ( +
    + +
    + ))} +
    + ); +}; + +export default ChooseTemplates; diff --git a/components/ContineBtn.tsx b/components/ContineBtn.tsx new file mode 100644 index 0000000..0c34570 --- /dev/null +++ b/components/ContineBtn.tsx @@ -0,0 +1,47 @@ +"use client"; +import { cn } from "@/lib/utils"; +import { Button } from "./ui/button"; +import { motion } from "framer-motion"; +import { useRouter } from "nextjs-toploader/app"; +import useMobile from "@/lib/useMobile"; +import { ArrowLeft, ArrowRight } from "lucide-react"; + +const ContineBtn = ({ + path, + type, + text, +}: { + path: string; + type: string; + text: string; +}) => { + const router = useRouter(); + const isMobile = useMobile(); + + return ( + + + + ); +}; + +export default ContineBtn; diff --git a/components/HeaderSkeleton.tsx b/components/HeaderSkeleton.tsx new file mode 100644 index 0000000..993bada --- /dev/null +++ b/components/HeaderSkeleton.tsx @@ -0,0 +1,24 @@ +import React from "react"; +import { Skeleton } from "./ui/skeleton"; + +const HeaderSkeleton = () => { + return ( +
    +
    + + +
    +
    + + + + + + +
    + +
    + ); +}; + +export default HeaderSkeleton; diff --git a/components/LiveResumePreview.tsx b/components/LiveResumePreview.tsx new file mode 100644 index 0000000..ceb7f9e --- /dev/null +++ b/components/LiveResumePreview.tsx @@ -0,0 +1,147 @@ +"use client"; +import { useParams, usePathname } from "next/navigation"; +import React from "react"; +import { useQuery } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { motion } from "framer-motion"; +import ContineBtn from "./ContineBtn"; +import { Skeleton } from "./ui/skeleton"; +import { ResumeTemplate } from "@/types/templateTypes"; +import Template1 from "@/templates/template1/Template1"; +import Template2 from "@/templates/template2/Template2"; +import { cn } from "@/lib/utils"; +import { + geologicaFont, + interFont, + montserratFont, + openSansFont, + poppinsFont, + ralewayFont, +} from "@/lib/font"; + +type TemplateComponentType = React.ComponentType<{ + obj: ResumeTemplate; + isPreview: boolean; + isLive?: boolean; + size: "sm" | "md" | "lg"; +}>; + +const templateComponents: Record = { + Template1: Template1, + Template2: Template2, +}; + +const LiveResumePreview = () => { + const params = useParams(); + const templateDetails = useQuery(api.resume.getTemplateDetails, { + id: params.id as Id<"resumes">, + }); + const pathname = usePathname(); + const sectionType = pathname.split("/section/")[1]; + + let sectionArray: string[] = []; + templateDetails?.sections?.map((item) => sectionArray.push(item.type)); + let currentIndex = sectionArray.findIndex((item) => item === sectionType); + + if (templateDetails === null) { + return
    Template not found
    ; + } + + if (templateDetails === undefined) { + return ; + } + const backLocation = `/build-resume/${params.id}/tips?sec=${sectionArray[currentIndex]}`; + const nextLocation = + sectionType === "custom" + ? `/build-resume/${params.id}/section/final` + : sectionArray[currentIndex + 1] + ? `/build-resume/${params.id}/tips?sec=${sectionArray[currentIndex + 1]}` + : `/build-resume/${params.id}/section/custom`; + + const TemplateComponent = templateComponents[templateDetails.templateName]; + + if (!TemplateComponent) { + console.error( + `No component found for template: ${templateDetails.templateName}` + ); + return
    Error: Template not found
    ; + } + + return ( + <> +
    + + + +
    + + {sectionType && ( + +
    + + +
    +
    + )} + + ); +}; + +const ResumeSkeleton = () => { + return ( +
    + +
    + ); +}; + +export default LiveResumePreview; diff --git a/components/MobilePreviewButton.tsx b/components/MobilePreviewButton.tsx new file mode 100644 index 0000000..b22e120 --- /dev/null +++ b/components/MobilePreviewButton.tsx @@ -0,0 +1,35 @@ +"use client"; +import React from "react"; +import { Button } from "@/components/ui/button"; +import { Eye } from "lucide-react"; +import { motion } from "framer-motion"; +import { usePreview } from "@/lib/use-preview"; +import temp1Obj from "@/templates/template1/temp1obj"; +import { ResumeTemplate } from "@/types/templateTypes"; + +const MobilePreviewButton = ({ item }: { item: ResumeTemplate }) => { + const preview = usePreview(); + const handlePreview = () => { + if (preview) { + preview.onOpen(item); + } + }; + + return ( + + {!preview.isOpen && } + + ); +}; + +export default MobilePreviewButton; diff --git a/components/Navbar.tsx b/components/Navbar.tsx new file mode 100644 index 0000000..6cea058 --- /dev/null +++ b/components/Navbar.tsx @@ -0,0 +1,147 @@ +"use client"; +import { ChevronDown, File, Menu, X } from "lucide-react"; +import { Button } from "./ui/button"; +import { SignInButton, SignUpButton, UserButton, useUser } from "@clerk/nextjs"; +import Link from "next/link"; +import { poppinsFont } from "@/lib/font"; +import { Skeleton } from "./ui/skeleton"; +import { useRouter } from "nextjs-toploader/app"; +import { useState } from "react"; +import { cn } from "@/lib/utils"; + +const Navbar = () => { + const { user, isLoaded, isSignedIn } = useUser(); + const router = useRouter(); + const [isMenuOpen, setIsMenuOpen] = useState(false); + + const toggleMenu = () => { + setIsMenuOpen(!isMenuOpen); + }; + + return ( + <> + {/* Backdrop */} + {isMenuOpen && ( +
    setIsMenuOpen(false)} + /> + )} + +
    +
    + {/* Logo Section */} +
    + + +

    + ResumeCraft +

    + +
    + + {/* Mobile Menu Button */} + + + {/* Loading State */} + {!isLoaded && ( +
    + + + +
    + )} + + {/* Desktop Navigation */} + {isSignedIn && ( +
    + +

    {user?.firstName}

    + +
    + )} + + {!isSignedIn && isLoaded && ( +
    + +
    + +
    +
    + )} +
    + +
    +
    + {isSignedIn ? ( + <> +
    + +

    {user?.firstName}

    +
    + + + ) : ( + isLoaded && ( +
    + +
    + +
    +
    + ) + )} +
    +
    +
    + + ); +}; + +export default Navbar; diff --git a/components/PreviewModal.tsx b/components/PreviewModal.tsx new file mode 100644 index 0000000..04529a7 --- /dev/null +++ b/components/PreviewModal.tsx @@ -0,0 +1,48 @@ +import { usePreview } from "@/lib/use-preview"; +import React from "react"; +import { + Dialog, + DialogContent, + DialogDescription, + DialogHeader, + DialogTitle, + DialogTrigger, +} from "./ui/dialog"; +import { ResumeTemplate } from "@/types/templateTypes"; +import { + templateComponents, + TemplateComponentType, +} from "@/templates/templateStructures"; + +const PreviewModal = () => { + const preview = usePreview(); + + const TemplateComponent: TemplateComponentType | null = + preview?.currentTemplate + ? templateComponents[preview?.currentTemplate.templateName] + : null; + + if (!TemplateComponent) return null; + + return ( + + + + +
    + {TemplateComponent && preview.currentTemplate && ( + + )} +
    +
    +
    +
    +
    + ); +}; + +export default PreviewModal; diff --git a/components/QuillEditors/QuillEditor.tsx b/components/QuillEditors/QuillEditor.tsx new file mode 100644 index 0000000..f2db708 --- /dev/null +++ b/components/QuillEditors/QuillEditor.tsx @@ -0,0 +1,57 @@ +"use client"; +import React, { useState } from "react"; +import dynamic from "next/dynamic"; +import "react-quill/dist/quill.snow.css"; +import { motion } from "framer-motion"; +import axios from "axios"; +import toast from "react-hot-toast"; +import { poppinsFont } from "@/lib/font"; +import { Label } from "../ui/label"; + +const QuillEditor = dynamic(() => import("react-quill"), { ssr: false }); + +interface QuillEditorComponentProps { + value: string; + onChange: (content: string) => void; + label: string; + currentFormat?: string; + placeholder?: string; +} + +export default function QuillEditorComponent({ + value, + onChange, + label, + currentFormat, + placeholder +}: QuillEditorComponentProps) { + + + const quillModules = { + toolbar: [ + ["bold", "italic", "underline"], + [{ list: "ordered" }, { list: "bullet" }, { list: "check" }], + ["link"], + ], + }; + + const quillFormats = ["bold", "italic", "underline", "list", "bullet","link"]; + + return ( + + + + + ); +} diff --git a/components/QuillEditors/QuillExp.tsx b/components/QuillEditors/QuillExp.tsx new file mode 100644 index 0000000..5d583f8 --- /dev/null +++ b/components/QuillEditors/QuillExp.tsx @@ -0,0 +1,178 @@ +"use client"; +import React, { useState } from "react"; +import dynamic from "next/dynamic"; +import "react-quill/dist/quill.snow.css"; +import { motion } from "framer-motion"; +import { LinkIcon, Loader2, WandSparkles } from "lucide-react"; +import { + Dialog, + DialogContent, + DialogDescription, + DialogHeader, + DialogTitle, + DialogTrigger, +} from "@/components/ui/dialog"; +import axios from "axios"; +import { Button } from "../ui/button"; +import { Label } from "../ui/label"; +import toast from "react-hot-toast"; + +const QuillEditor = dynamic(() => import("react-quill"), { ssr: false }); + +interface QuillEditorComponentProps { + value: string; + onChange: (content: string) => void; + label: string; + companyName: string; + role: string; +} + +export default function QuillExpEditor({ + value, + onChange, + label, + companyName, + role, +}: QuillEditorComponentProps) { + const [generatedContent, setGeneratedContent] = useState(""); + const [tempValue, setTempValue] = useState(""); + const [loading, setLoading] = useState(false); + const [dialogIsOpen, setDialogIsOpen] = useState(false); + + const quillModules = { + toolbar: [ + ["bold", "italic", "underline"], + [{ list: "ordered" }, { list: "bullet" }], + ["link"], // Add link button to toolbar + ], + }; + + const quillFormats = ["bold", "italic", "underline", "list", "bullet","link"]; + + const handleGenerate = async () => { + try { + setLoading(true); + const response = await axios.post( + `${process.env.NEXT_PUBLIC_WEBSITE_URL}/api/generateJD`, + { companyName: companyName, role: role, jobDescription: tempValue } + ); + const listItems = response.data.textArray + .map((item: string) => `
  • ${item}
  • `) + .join(""); + const generatedHtml = `
      ${listItems}
    `; + setGeneratedContent(generatedHtml); + setLoading(false); + } catch (error) { + console.log(error); + toast.error("Something went wrong Quill Experience"); + } + }; + + const continueData = () => { + onChange(generatedContent); + setTempValue(""); + setGeneratedContent(""); + setDialogIsOpen(false); + }; + + const cancelData = () => { + setDialogIsOpen(false); + setGeneratedContent(""); + }; + + return ( + +
    + + + +
    + + +
    + + + + + + Write ATS friendly, professional job descriptions with our AI + + + Enter your experience details in the text area provided. Click + 'Generate Description' to refine and enhance your input. If you + leave the text area blank and click 'Generate Description', our + AI will create experience points based on the job title. + +
    + + {loading ? ( + + ) : ( + <> + {!generatedContent ? ( + + ) : ( +
    + + +
    + )} + + )} +
    +
    +
    +
    +
    + +
    + ); +} diff --git a/components/QuillEditors/QuillProject.tsx b/components/QuillEditors/QuillProject.tsx new file mode 100644 index 0000000..fd7c86c --- /dev/null +++ b/components/QuillEditors/QuillProject.tsx @@ -0,0 +1,171 @@ +"use client"; +import React, { useState } from "react"; +import dynamic from "next/dynamic"; +import "react-quill/dist/quill.snow.css"; +import { motion } from "framer-motion"; +import { Loader2, WandSparkles } from "lucide-react"; +import { + Dialog, + DialogContent, + DialogDescription, + DialogHeader, + DialogTitle, + DialogTrigger, +} from "@/components/ui/dialog"; +import axios from "axios"; +import { Button } from "../ui/button"; +import { Label } from "../ui/label"; +import toast from "react-hot-toast"; + +const QuillEditor = dynamic(() => import("react-quill"), { ssr: false }); + +interface QuillEditorComponentProps { + value: string; + onChange: (content: string) => void; + label: string; + projectTitle: string; +} + +export default function QuillProjectEditor({ + value, + onChange, + label, + projectTitle, +}: QuillEditorComponentProps) { + const [generatedContent, setGeneratedContent] = useState(""); + const [loading, setLoading] = useState(false); + const [dialogIsOpen, setDialogIsOpen] = useState(false); + const [tempValue, setTempValue] = useState(""); + + const quillModules = { + toolbar: [ + ["bold", "italic", "underline"], + [{ list: "ordered" }, { list: "bullet" }], + ["link"], + ], + }; + + const quillFormats = ["bold", "italic", "underline", "list", "bullet","link"]; + + const handleGenerate = async () => { + try { + setLoading(true); + const response = await axios.post( + `${process.env.NEXT_PUBLIC_WEBSITE_URL}/api/generatePD`, + { projectTitle: projectTitle, projectDescription: tempValue } + ); + const listItems = response.data.textArray + .map((item: string) => `
  • ${item}
  • `) + .join(""); + const generatedHtml = `
      ${listItems}
    `; + setGeneratedContent(generatedHtml); + setLoading(false); + } catch (error) { + toast.error("Something went wrong Quill Project"); + } + }; + + const continueData = () => { + onChange(generatedContent); + setTempValue(""); + setGeneratedContent(""); + setDialogIsOpen(false); + }; + + const cancelData = () => { + setDialogIsOpen(false); + setGeneratedContent(""); + }; + + return ( + +
    + + + + + + + + + Write ATS friendly, project descriptions with our AI + + + Compose your description in the text area provided. Select + 'Generate Description' to enhance your writing. If you leave the + text area empty and click 'Generate Description', our AI will + create a description for you based on the title. + +
    + + {loading ? ( + + ) : ( + <> + {!generatedContent ? ( + + ) : ( +
    + + +
    + )} + + )} +
    +
    +
    +
    +
    + +
    + ); +} diff --git a/components/SectionInfo.tsx b/components/SectionInfo.tsx new file mode 100644 index 0000000..4033d0e --- /dev/null +++ b/components/SectionInfo.tsx @@ -0,0 +1,29 @@ +"use client"; +import { cn } from "@/lib/utils"; +import React from "react"; +import { motion } from "framer-motion"; +import { item } from "@/lib/motion"; +import { poppinsFont } from "@/lib/font"; + +interface SectionInfoTypes { + heading: string; + text: string; +} + +const SectionInfo = ({ heading, text }: SectionInfoTypes) => { + return ( + +

    + {heading} +

    +

    {text}

    +
    + ); +}; + +export default SectionInfo; diff --git a/components/SocialLinkField.tsx b/components/SocialLinkField.tsx new file mode 100644 index 0000000..811e3ba --- /dev/null +++ b/components/SocialLinkField.tsx @@ -0,0 +1,74 @@ +import React from 'react'; +import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from "@/components/ui/select"; +import { Input } from "@/components/ui/input"; +import { Label } from "@/components/ui/label"; +import { Github, Linkedin, Globe, Twitter, Instagram, Link } from 'lucide-react'; + +interface SocialLinkFieldProps { + value: { type: string; url: string }; + onChange: (value: { type: string; url: string }) => void; + onRemove: () => void; +} + +const socialOptions = [ + { value: 'github', label: 'GitHub', icon: Github }, + { value: 'linkedin', label: 'LinkedIn', icon: Linkedin }, + { value: 'portfolio', label: 'Portfolio', icon: Globe }, + { value: 'twitter', label: 'Twitter', icon: Twitter }, + { value: 'instagram', label: 'Instagram', icon: Instagram }, + { value: 'other', label: 'Other', icon: Link }, +]; + +const SocialLinkField: React.FC = ({ value, onChange, onRemove }) => { + const handleTypeChange = (newType: string) => { + onChange({ ...value, type: newType }); + }; + + const handleUrlChange = (e: React.ChangeEvent) => { + onChange({ ...value, url: e.target.value }); + }; + + const selectedOption = socialOptions.find(option => option.value === value.type) || socialOptions[socialOptions.length - 1]; + const Icon = selectedOption.icon; + + return ( +
    +
    + + +
    +
    + +
    + + +
    +
    + +
    + ); +}; + +export default SocialLinkField; \ No newline at end of file diff --git a/components/TipsSkeleton.tsx b/components/TipsSkeleton.tsx new file mode 100644 index 0000000..c4a8a26 --- /dev/null +++ b/components/TipsSkeleton.tsx @@ -0,0 +1,29 @@ +import React from "react"; +import { Skeleton } from "./ui/skeleton"; + +const TipsSkeleton = () => { + return ( +
    +
    +
    + +
    + +
    + + +
    +
    +
    + + {/* BUTTONS DIV */} +
    + + +
    +
    +
    + ); +}; + +export default TipsSkeleton; diff --git a/components/VerticalTimeline.tsx b/components/VerticalTimeline.tsx new file mode 100644 index 0000000..712d775 --- /dev/null +++ b/components/VerticalTimeline.tsx @@ -0,0 +1,169 @@ +import React, { useEffect, useState } from "react"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { useQuery } from "convex/react"; +import { + Baseline, + Brain, + FolderKanban, + GraduationCap, + LineChart, + PenToolIcon, + User, +} from "lucide-react"; +import { + redirect, + useParams, + usePathname, + useSearchParams, +} from "next/navigation"; +import { + Tooltip, + TooltipContent, + TooltipProvider, + TooltipTrigger, +} from "./ui/tooltip"; +import Link from "next/link"; +import { Button } from "./ui/button"; +import { useRouter } from "nextjs-toploader/app"; + +const Timeline = () => { + const params = useParams(); + const router = useRouter(); + const resumeId = params.id; + const [isMobile, setIsMobile] = useState(false); + + const resume = useQuery(api.resume.getTemplateDetails, { + id: resumeId as Id<"resumes">, + }); + + const pathname = usePathname(); + const currentSec = pathname.split("section/")[1]; + + const searchParams = useSearchParams(); + const sec = searchParams.get("sec"); + + useEffect(() => { + const checkMobile = () => { + setIsMobile(window.innerWidth <= 768); + }; + + checkMobile(); + window.addEventListener("resize", checkMobile); + return () => window.removeEventListener("resize", checkMobile); + }, []); + + let sectionArray: string[] = []; + resume?.sections?.map((item) => { + item.type !== "custom" && sectionArray.push(item.type); + }); + sectionArray.push("custom"); + sectionArray.push("final"); + + const sectionIconMap: any = { + header: User, + experience: LineChart, + education: GraduationCap, + skills: Brain, + projects: FolderKanban, + final: Baseline, + custom: PenToolIcon, + }; + + const TimelineItem = ({ + section, + index, + total, + }: { + section: string; + index: number; + total: number; + }) => { + const SectionIcon = sectionIconMap[section]; + + return ( +
    +
    + + + + +
    +
    + +
    +
    + +
    + +

    {section}

    +
    +
    +
    +
    +
    +
    + ); + }; + + return ( +
    + +
    +
    +
    + {sectionArray.map((section, index) => ( + + ))} +
    +
    +
    + ); +}; + +export default Timeline; \ No newline at end of file diff --git a/components/forms/CustomForm.tsx b/components/forms/CustomForm.tsx new file mode 100644 index 0000000..1909752 --- /dev/null +++ b/components/forms/CustomForm.tsx @@ -0,0 +1,138 @@ +import { Id } from "@/convex/_generated/dataModel"; +import React, { useEffect, useMemo, useRef, useState } from "react"; +import { Label } from "../ui/label"; +import { Input } from "../ui/input"; +import QuillEditorComponent from "../QuillEditors/QuillEditor"; +import { Button } from "../ui/button"; +import { debounce } from "lodash"; +import { useMutation, useQuery } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { XIcon } from "lucide-react"; + +const CustomForm = ({ + resumeId, + styles, + item, +}: { + resumeId: Id<"resumes">; + styles: string; + item: string; +}) => { + interface SectionItem { + sectionTitle: string; + sectionDescription: string; + sectionNumber: number; + } + + const [sectionsContent, setSectionsContent] = useState([ + { sectionTitle: "", sectionDescription: "", sectionNumber: 1 }, + ]); + const update = useMutation(api.resume.updateCustomSection); + const removeSectionUpdate = useMutation(api.resume.removeCustomSection); + const pendingChangesRef = useRef(false); + + const handleAddSection = () => { + setSectionsContent([ + ...sectionsContent, + { + sectionTitle: "", + sectionDescription: "", + sectionNumber: sectionsContent.length + 1, + }, + ]); + }; + + const debouncedUpdate = useMemo(() => { + return debounce((newSection: SectionItem[], index: number) => { + update({ id: resumeId, content: newSection[index] }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleTitleChange = (index: number, value: string) => { + pendingChangesRef.current = true; + setSectionsContent((prev) => { + const updatedSections = [...prev]; + updatedSections[index].sectionTitle = value; + debouncedUpdate(updatedSections, index); + return updatedSections; + }); + }; + + const handleDescriptionChange = (index: number, value: string) => { + pendingChangesRef.current = true; + setSectionsContent((prev) => { + const updatedSections = [...prev]; + updatedSections[index].sectionDescription = value; + debouncedUpdate(updatedSections, index); + return updatedSections; + }); + }; + + const initialData = useQuery(api.resume.getCustomSections, { id: resumeId }); + useEffect(() => { + if (initialData && initialData.length > 0 && !pendingChangesRef.current) { + const modified: any[] = initialData.map((item) => item.content); + setSectionsContent(modified); + } + }, [initialData]); + + const debouncedRemoveUpdate = useMemo(() => { + return debounce((toRemoveSectionNumber: number) => { + removeSectionUpdate({ + id: resumeId, + sectionNumber: toRemoveSectionNumber, + }); + }, 400); + }, [removeSectionUpdate, resumeId]); + + const removeSection = (index: number) => { + const removedSection = sectionsContent.find( + (section) => section.sectionNumber === index + ); + const toRemoveSectionNumber = removedSection?.sectionNumber; + const filteredContent = sectionsContent.filter((_, i) => i + 1 !== index); + debouncedRemoveUpdate(toRemoveSectionNumber || 0); + setSectionsContent(filteredContent); + }; + + return ( +
    + {sectionsContent.map((section, index) => ( +
    +
    + + {index !== 0 && ( + removeSection(index + 1)} + className="mr-4 cursor-pointer" + width={16} + /> + )} +
    + handleTitleChange(index, e.target.value)} + /> +
    + handleDescriptionChange(index, value)} + label="Section Description" + /> +
    +
    + ))} + +
    + ); +}; + +export default CustomForm; diff --git a/components/forms/CustomSectionForm.tsx b/components/forms/CustomSectionForm.tsx new file mode 100644 index 0000000..3c2c021 --- /dev/null +++ b/components/forms/CustomSectionForm.tsx @@ -0,0 +1,111 @@ +import React, { + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import { Id } from "@/convex/_generated/dataModel"; +import { debounce } from "lodash"; +import { useMutation } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import QuillEditorComponent from "../QuillEditors/QuillEditor"; +import { Input } from "../ui/input"; +import { Label } from "../ui/label"; +import { Button } from "../ui/button"; +import { XIcon } from "lucide-react"; + +interface SectionItem { + sectionTitle: string; + sectionDescription: string; + sectionNumber: number; +} + +interface SkillsFormProps { + item: any; + resumeId: Id<"resumes">; + styles: any; +} + +const SkillsForm: React.FC = ({ item, resumeId, styles }) => { + const initialSection: SectionItem = { + sectionTitle: "", + sectionDescription: "", + sectionNumber: 0, + }; + + const [sectionContent, setSectionContent] = useState([initialSection]); + const pendingChangesRef = useRef(false); + const update = useMutation(api.resume.updateCustomSection); + + const debouncedUpdate = useMemo(() => { + return debounce((newSection: SectionItem[], index: number) => { + update({ id: resumeId, content: newSection[index] }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleChange = useCallback( + (index: number, field: keyof SectionItem, value: string | boolean) => { + pendingChangesRef.current = true; + setSectionContent((prev) => { + const newSectionContent = prev.map((section, i) => + i === index ? { ...section, [field]: value } : section + ); + debouncedUpdate(newSectionContent, index); + return newSectionContent; + }); + }, + [debouncedUpdate] + ); + + useEffect(() => { + if (!pendingChangesRef.current && item?.content) { + setSectionContent(item.content.length > 0 ? item.content : [initialSection]); + } + }, [item?.content]); + + const addNewSection = () => { + setSectionContent((prev) => [...prev, { ...initialSection, sectionNumber: prev.length }]); + }; + + const removeSection = useCallback((index: number) => { + setSectionContent((prev) => { + const newContent = prev.filter((_, i) => i !== index).map((section, i) => ({ + ...section, + sectionNumber: i, + })); + debouncedUpdate(newContent, index); + return newContent; + }); + }, [debouncedUpdate]); + + return ( +
    + {sectionContent.map((section, index) => ( +
    +
    + + {index !== 0 && removeSection(index)} className="mr-4 cursor-pointer" width={16}/>} +
    + handleChange(index, "sectionTitle", e.target.value)} + value={section.sectionTitle} + placeholder="Section Title" + className="w-full mt-2 border border-muted-foreground" + /> +
    + handleChange(index, "sectionDescription", content)} + label="Section Description" + /> +
    +
    + ))} + +
    + ); +}; + +export default SkillsForm; \ No newline at end of file diff --git a/components/forms/EducationForm.tsx b/components/forms/EducationForm.tsx new file mode 100644 index 0000000..9ac732d --- /dev/null +++ b/components/forms/EducationForm.tsx @@ -0,0 +1,329 @@ +"use client"; + +import React, { + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import { Label } from "../ui/label"; +import { Input } from "../ui/input"; +import debounce from "lodash/debounce"; +import { useMutation } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { Button } from "../ui/button"; +import { motion } from "framer-motion"; +import "react-date-picker/dist/DatePicker.css"; +import "react-calendar/dist/Calendar.css"; +import { EducationSection } from "@/types/templateTypes"; +import { Checkbox } from "../ui/checkbox"; +import { XIcon } from "lucide-react"; + +interface EducationItem { + courseName: string; + instituteName: string; + location: string; + grade: string; + startMonth: string; + startYear: string; + endMonth: string; + endYear: string; + studyingHere: boolean; +} + +interface EducationContent { + education: EducationItem[]; +} + +interface EducationFormProps { + item: EducationSection; + resumeId: Id<"resumes">; +} + +const EducationForm: React.FC = ({ item, resumeId }) => { + const emptyEducation: EducationItem = { + courseName: "", + instituteName: "", + location: "", + grade: "", + startMonth: "", + startYear: "", + endMonth: "", + endYear: "", + studyingHere: false, + }; + + const [education, setEducation] = useState({ + education: [], + }); + const pendingChangesRef = useRef(false); + const update = useMutation(api.resume.updateEducation); + + useEffect(() => { + if (!pendingChangesRef.current) { + setEducation(item?.content as EducationContent); + } + }, [item?.content, pendingChangesRef]); + + const debouncedUpdate = useMemo(() => { + return debounce((newEducation: EducationContent) => { + update({ id: resumeId, content: newEducation }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleChange = useCallback( + (index: number) => (name: keyof EducationItem, value: string | boolean) => { + pendingChangesRef.current = true; + setEducation((prevEducation) => { + const newEducation = { ...prevEducation }; + const updatedItem = { ...newEducation.education[index] }; + + if (name === "studyingHere") { + updatedItem.studyingHere = value as boolean; + if (updatedItem.studyingHere) { + updatedItem.endMonth = ""; + updatedItem.endYear = "Present"; + } + } else { + updatedItem[name] = value as string; + } + + newEducation.education[index] = updatedItem; + debouncedUpdate(newEducation); + return newEducation; + }); + }, + [debouncedUpdate] + ); + + const addEducation = () => { + setEducation((prev) => ({ + education: [...prev.education, emptyEducation], + })); + }; + + const removeEducation = useCallback( + (index: number) => { + setEducation((prev) => { + const newEducation = { + ...prev, + education: prev.education.filter((_, i) => i !== index), + }; + debouncedUpdate(newEducation); + return newEducation; + }); + }, + [debouncedUpdate] + ); + + const months = [ + "Jan", + "Feb", + "Mar", + "Apr", + "May", + "Jun", + "Jul", + "Aug", + "Sep", + "Oct", + "Nov", + "Dec", + ]; + const currentYear = new Date().getFullYear(); + const years = Array.from({ length: 30 }, (_, i) => + (currentYear - i).toString() + ); + + return ( +
    + {education?.education?.map((item, index) => ( + + {index !== 0 && ( + removeEducation(index)} + className="right-8 top-4 absolute cursor-pointer" + /> + )} +
    + + + + + + + + + + + handleChange(index)("studyingHere", checked) + } + /> + + +
    +
    + ))} + + + +
    + ); +}; + +interface InputFieldProps { + label: string; + name: keyof EducationItem; + value: string; + onChange: (name: keyof EducationItem, value: string) => void; + placeholder: string; + type?: "text" | "select"; + options?: string[]; + disabled?: boolean; +} + +const InputField: React.FC = ({ + label, + name, + value, + onChange, + placeholder, + type = "text", + options, + disabled = false, +}) => ( + + + {type === "select" ? ( + + ) : ( + onChange(name, e.target.value)} + placeholder={placeholder} + className="border bg-[#FFF5F5] border-muted-foreground" + disabled={disabled} + /> + )} + +); + +export default EducationForm; diff --git a/components/forms/ExperienceForm.tsx b/components/forms/ExperienceForm.tsx new file mode 100644 index 0000000..220bbd2 --- /dev/null +++ b/components/forms/ExperienceForm.tsx @@ -0,0 +1,330 @@ +import { api } from "@/convex/_generated/api"; +import { Id } from "@/convex/_generated/dataModel"; +import { useMutation } from "convex/react"; +import { debounce } from "lodash"; +import React, { + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import { Label } from "../ui/label"; +import { Input } from "../ui/input"; +import QuillExpEditor from "../QuillEditors/QuillExp"; +import { motion } from "framer-motion"; +import { Button } from "../ui/button"; +import { Checkbox } from "../ui/checkbox"; +import { XIcon } from "lucide-react"; + +interface ExperienceItem { + companyName: string; + role: string; + jobDescription: string; + location: string; + startMonth: string; + startYear: string; + endMonth: string; + endYear: string; + workingHere: boolean; +} + +interface ExperienceContent { + experience: ExperienceItem[]; +} + +const emptyExperienceItem: ExperienceItem = { + companyName: "", + role: "", + jobDescription: "", + location: "", + startMonth: "", + startYear: "", + endMonth: "", + endYear: "", + workingHere: false, +}; + +const ExperienceForm = ({ + resumeId, + item, +}: { + resumeId: Id<"resumes">; + item: any; +}) => { + const pendingChangesRef = useRef(false); + const [experience, setExperience] = useState({ + experience: [], + }); + const update = useMutation(api.resume.updateExperience); + + useEffect(() => { + if (!pendingChangesRef.current) { + setExperience(item?.content); + } + }, [item?.content, pendingChangesRef]); + + const debouncedUpdate = useMemo(() => { + return debounce((newExperience: ExperienceContent) => { + update({ id: resumeId, content: newExperience }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleChange = useCallback( + (index: number) => + (name: keyof ExperienceItem, value: string | boolean) => { + pendingChangesRef.current = true; + setExperience((prevExperience) => { + const newExperience = { ...prevExperience }; + const updatedItem = { ...newExperience.experience[index] }; + + if (name === "workingHere") { + updatedItem.workingHere = value as boolean; + if (updatedItem.workingHere) { + updatedItem.endMonth = ""; + updatedItem.endYear = "Present"; + } + } else { + updatedItem[name] = value as string; + } + newExperience.experience[index] = updatedItem; + debouncedUpdate(newExperience); + return newExperience; + }); + }, + [debouncedUpdate] + ); + + const addExperience = () => { + setExperience((prev) => ({ + experience: [...prev.experience, emptyExperienceItem], + })); + }; + + const removeEducation = useCallback( + (index: number) => { + setExperience((prev) => { + const newExperience = { + ...prev, + experience: prev.experience.filter((_, i) => i !== index), + }; + debouncedUpdate(newExperience); + return newExperience; + }); + }, + [debouncedUpdate] + ); + + const months = [ + "Jan", + "Feb", + "Mar", + "Apr", + "May", + "Jun", + "July", + "Aug", + "Sept", + "Oct", + "Nov", + "Dec", + ]; + const currentYear = new Date().getFullYear(); + const years = Array.from({ length: 30 }, (_, i) => + (currentYear - i).toString() + ); + + return ( + <> + {experience.experience.map((exp, index) => ( + + {index !== 0 && ( + removeEducation(index)} + className="right-8 top-4 absolute cursor-pointer" + /> + )} +
    + + + + + + + + + + handleChange(index)("workingHere", checked) + } + /> + + +
    +
    + + handleChange(index)("jobDescription", content) + } + /> +
    +
    + ))} + + + + + ); +}; + +interface InputFieldProps { + label: string; + name: keyof ExperienceItem; + value: string; + onChange: (name: keyof ExperienceItem, value: string) => void; + placeholder: string; + type?: string; + options?: string[]; + disabled?: boolean; +} + +const InputField: React.FC = ({ + label, + name, + value, + onChange, + placeholder, + type = "text", + options, + disabled = false, +}) => ( + + + {type === "select" ? ( + + ) : ( + onChange(name, e.target.value)} + placeholder={placeholder} + className="border bg-[#FFF5F5] border-muted-foreground" + disabled={disabled} + /> + )} + +); + +export default ExperienceForm; diff --git a/components/forms/HeaderForm.tsx b/components/forms/HeaderForm.tsx new file mode 100644 index 0000000..1b16ebf --- /dev/null +++ b/components/forms/HeaderForm.tsx @@ -0,0 +1,300 @@ +import { api } from "@/convex/_generated/api"; +import { Doc, Id } from "@/convex/_generated/dataModel"; +import { useMutation, useQuery } from "convex/react"; +import { debounce } from "lodash"; +import React, { + ChangeEvent, + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import QuillEditorComponent from "../QuillEditors/QuillEditor"; +import { motion } from "framer-motion"; +import { Label } from "../ui/label"; +import { Input } from "../ui/input"; +import { HeaderSection } from "@/types/templateTypes"; +import { + Github, + Globe, + Link, + Linkedin, + Plus, + Twitter, + XIcon, +} from "lucide-react"; + +interface SocialLink { + type: string; + name: string; + url: string; +} + +interface HeaderContent { + firstName: string; + lastName: string; + email: string; + phone: string; + location: string; + summary: string; + socialLinks: SocialLink[]; +} + +const initialHeader: HeaderContent = { + firstName: "", + lastName: "", + email: "", + phone: "", + location: "", + summary: "", + socialLinks: [], +}; + +const HeaderForm = ({ + resumeId, + item, +}: { + resumeId: Id<"resumes">; + item: HeaderSection; +}) => { + const [header, setHeader] = useState(initialHeader); + const [activeLink, setActiveLink] = useState(""); + const [activeLinkValue, setActiveLinkValue] = useState(""); + + const update = useMutation(api.resume.updateHeader); + const pendingChangesRef = useRef(false); + + useEffect(() => { + if (item?.content && !pendingChangesRef.current) { + setHeader(item.content as HeaderContent); + console.log(item.content); + } + }, [item?.content, pendingChangesRef]); + + const debouncedUpdate = useMemo(() => { + return debounce((newHeader: HeaderContent) => { + update({ id: resumeId, content: newHeader }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleChange = useCallback( + (e: ChangeEvent | string) => { + pendingChangesRef.current = true; + setHeader((prevHeader) => { + let newHeader; + if (typeof e === "string") { + newHeader = { ...prevHeader, summary: e }; + } else { + newHeader = { ...prevHeader, [e.target.name]: e.target.value }; + } + debouncedUpdate(newHeader); + return newHeader; + }); + }, + [debouncedUpdate] + ); + + const handleSocialChange = useCallback( + (index: number, name: string, value: string) => { + pendingChangesRef.current = true; + setHeader((prevHeader) => { + const newSocialLinks = [...prevHeader.socialLinks]; + newSocialLinks[index] = { ...newSocialLinks[index], [name]: value }; + const newHeader = { ...prevHeader, socialLinks: newSocialLinks }; + debouncedUpdate(newHeader); + return newHeader; + }); + }, + [debouncedUpdate] + ); + + const handleAddSocialLink = useCallback( + (type: string) => { + pendingChangesRef.current = true; + setHeader((prevHeader) => { + const existingLink = prevHeader.socialLinks.find( + (link) => link.type === type && link.type !== "other" + ); + if (existingLink) { + return prevHeader; + } + const newSocialLinks = [ + ...prevHeader.socialLinks, + { type, name: "", url: "" }, + ]; + const newHeader = { ...prevHeader, socialLinks: newSocialLinks }; + debouncedUpdate(newHeader); + return newHeader; + }); + }, + [debouncedUpdate] + ); + + const handleRemoveSocialLink = useCallback( + (index: number) => { + pendingChangesRef.current = true; + setHeader((prevHeader) => { + const newSocialLinks = [...prevHeader.socialLinks]; + const filteredArray = newSocialLinks.filter((_, i) => i !== index); + const newHeader = { ...prevHeader, socialLinks: filteredArray }; + debouncedUpdate(newHeader); + return newHeader; + }); + }, + [debouncedUpdate] + ); + + const socialOptions = [ + { value: "github", label: "GitHub", icon: Github }, + { value: "linkedin", label: "LinkedIn", icon: Linkedin }, + { value: "portfolio", label: "Portfolio", icon: Globe }, + { value: "twitter", label: "Twitter", icon: Twitter }, + { value: "other", label: "Other", icon: Link }, + ]; + + return ( + <> + +
    + + + + +
    + +
    +

    Social Links

    + {header?.socialLinks?.map((link, index) => ( +
    + + handleSocialChange(index, "name", e.target.value) + } + placeholder={`Enter ${link.type}`} + /> + + handleSocialChange(index, "url", e.target.value) + } + placeholder={`Enter your ${link.type} URL`} + /> + +
    + ))} +
    + +
    + {socialOptions.map((option) => ( + handleAddSocialLink(option.value)} + className={`flex items-center gap-2 bg-[#FFF5F5] shadow-sm shadow-primary/40 cursor-pointer border-2 ${ + header?.socialLinks?.some((link) => link.type === option.value) + ? "border-primary/60" + : "border-transparent hover:border-primary/60" + } transition duration-300 ease rounded-lg p-2`} + > + {option.label} + + ))} +
    + + {item?.content?.summary !== undefined && ( +
    + handleChange(content)} + /> +
    + )} +
    + + ); +}; + +interface InputFieldProps { + label: string; + name: keyof HeaderContent; + value: string; + onChange: (e: ChangeEvent) => void; + placeholder: string; + type?: string; + required?: boolean; +} + +const InputField: React.FC = ({ + label, + name, + value, + onChange, + placeholder, + type = "text", + required, +}) => ( + + + + +); + +export default HeaderForm; diff --git a/components/forms/ProjectForm.tsx b/components/forms/ProjectForm.tsx new file mode 100644 index 0000000..76343f7 --- /dev/null +++ b/components/forms/ProjectForm.tsx @@ -0,0 +1,215 @@ +import { Id } from "@/convex/_generated/dataModel"; +import React, { + ChangeEvent, + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import { Label } from "../ui/label"; +import { Input } from "../ui/input"; +import { useMutation } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import { debounce } from "lodash"; +import { Button } from "../ui/button"; +import { motion } from "framer-motion"; +import QuillProjectEditor from "../QuillEditors/QuillProject"; +import { ProjectSection } from "@/types/templateTypes"; +import { XIcon } from "lucide-react"; + +interface ProjectType { + name: string; + description: string; + githuburl: string; + liveurl: string; +} + +interface ProjectContent { + projects: ProjectType[]; +} + +const ProjectForm = ({ + resumeId, + item, +}: { + resumeId: Id<"resumes">; + item: ProjectSection; +}) => { + const emptyProject: ProjectType = { + name: "", + description: "", + githuburl: "", + liveurl: "", + }; + + const [projects, setProjects] = useState({ projects: [] }); + const pendingChangesRef = useRef(false); + const update = useMutation(api.resume.updateProjects); + + useEffect(() => { + if (!pendingChangesRef.current) { + setProjects(item?.content as ProjectContent); + } + }, [item?.content, pendingChangesRef]); + + const debouncedUpdate = useMemo(() => { + return debounce((newProject: ProjectContent) => { + update({ id: resumeId, content: newProject }); + pendingChangesRef.current = false; + }, 400); + }, [update, resumeId]); + + const handleChange = useCallback( + (index: number) => + ( + e: ChangeEvent | string, + field?: keyof ProjectType + ) => { + pendingChangesRef.current = true; + setProjects((prevProjects) => { + const newProject = { ...prevProjects }; + if (typeof e === "string" && field) { + newProject.projects[index][field] = e; + } else if (typeof e !== "string") { + newProject.projects[index][e.target.name as keyof ProjectType] = + e.target.value; + } + debouncedUpdate(newProject); + return newProject; + }); + }, + [debouncedUpdate] + ); + + const addProject = () => { + setProjects((prev) => ({ + ...prev, + projects: [...prev.projects, emptyProject], + })); + }; + + const removeProject = useCallback( + (index: number) => { + setProjects((prev) => { + const newProjects = { + ...prev, + projects: prev.projects.filter((_, i) => i !== index), + }; + debouncedUpdate(newProjects); + return newProjects; + }); + }, + [debouncedUpdate] + ); + + return ( + <> + {projects?.projects.map((item, index) => { + return ( +
    +
    + {index !== 0 && ( + removeProject(index)} + className="right-8 top-4 absolute cursor-pointer" + /> + )} +
    + + + +
    +
    + + handleChange(index)(content, "description") + } + /> +
    + + + + +
    + ); + })} + + ); +}; + +interface InputFieldProps { + label: string; + name: string; + value: string; + onChange: (e: ChangeEvent) => void; + placeholder: string; +} + +const InputField: React.FC = ({ + label, + name, + value, + onChange, + placeholder, +}) => { + return ( + + + + + ); +}; + +export default ProjectForm; diff --git a/components/forms/SkillsForm.tsx b/components/forms/SkillsForm.tsx new file mode 100644 index 0000000..7dc3d47 --- /dev/null +++ b/components/forms/SkillsForm.tsx @@ -0,0 +1,153 @@ +import React, { + useCallback, + useEffect, + useMemo, + useRef, + useState, +} from "react"; +import { Id } from "@/convex/_generated/dataModel"; +import { debounce, set } from "lodash"; +import { useMutation } from "convex/react"; +import { api } from "@/convex/_generated/api"; +import QuillEditorComponent from "../QuillEditors/QuillEditor"; +import { Tabs, TabsContent, TabsList, TabsTrigger } from "@/components/ui/tabs"; +import { Button } from "../ui/button"; + +const SkillsForm = ({ + item, + resumeId, + styles, +}: { + item: any; + resumeId: Id<"resumes">; + styles: any; +}) => { + const [skillDescription, setSkillDescription] = useState(""); + const [currentFormat, setCurrentFormat] = useState("paragraph"); + const pendingChangesRef = useRef(false); + const update = useMutation(api.resume.updateSkills); + + useEffect(() => { + if (!pendingChangesRef.current) { + setSkillDescription(item?.content?.description || ""); + } + }, [item?.content?.description]); + + const debouncedUpdate = useMemo( + () => + debounce((newSkills: string) => { + update({ id: resumeId, content: { description: newSkills } }); + pendingChangesRef.current = false; + }, 400), + [update, resumeId] + ); + + const handleChange = useCallback( + (description: string) => { + pendingChangesRef.current = true; + setSkillDescription(description); + debouncedUpdate(description); + }, + [debouncedUpdate] + ); + + const descriptionObj = [ + { + heading: "Full Stack Web Developer", + allDescriptions: [ + `Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.`, + `Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.`, + `DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.`, + `Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.`, + ], + }, + { + heading: "Data Scientist", + allDescriptions: [ + `Programming Languages: Python, R, SQL, Java.`, + `Data Analysis Tools: Pandas, NumPy, Scikit-learn, TensorFlow, PyTorch, Matplotlib, Seaborn.`, + `Databases: MySQL, PostgreSQL, MongoDB, Redis.`, + `Machine Learning: Regression, Classification, Clustering, Neural Networks, Natural Language Processing.`, + `Version Control & Tools: Git, GitHub, Jupyter, Anaconda, Docker. Testing: PyTest, Unittest.`, + ], + }, + { + heading: "DevOps Engineer", + allDescriptions: [ + `Tools & Platforms: Jenkins, Docker, Kubernetes, GitHub Actions, CircleCI, TravisCI.`, + `Cloud Services: AWS (EC2, S3, Lambda, CloudFormation), Azure, GCP.`, + `Automation & Monitoring: Terraform, Ansible, Nagios, Prometheus, Grafana.`, + `Version Control & Tools: Git, GitLab, GitHub, Bitbucket.`, + `Networking & Security: VPN, SSL, Firewalls, Load Balancing, AWS IAM.`, + ], + }, + { + heading: "Mobile App Developer", + allDescriptions: [ + `Languages & Frameworks: Swift, Kotlin, Java, React Native, Flutter, Dart.`, + `Mobile Development Tools: Xcode, Android Studio, Firebase, Realm, SQLite.`, + `Backend: REST APIs, GraphQL, Node.js, Express.js.`, + `Version Control & Tools: Git, GitHub, Bitbucket, Postman. Testing: Jest, Detox, Espresso.`, + `Deployment: App Store, Google Play, Fastlane.`, + ], + }, + ]; + + const handleSetDescription = (descriptions: string[]) => { + const combinedDescription = descriptions.join("
    "); + setSkillDescription(combinedDescription); + }; + + return ( + <> +
    + + +

    Tailor Your Skillset

    +

    + We recommend you take this only as a reference and personalize it by + adding your own unique skills. +

    + + {descriptionObj.map((item, index) => { + return ( + <> +
    +
    +
    handleSetDescription(item.allDescriptions)} + className="group-hover:flex items-center justify-center h-full hidden" + > + +
    +
    +
    +

    {item.heading}

    +

    + {item.allDescriptions.map((desc, index) => { + return ( +

  • + ); + })} +

    +
    +
    + + ); + })} +
    + + ); +}; + +export default SkillsForm; diff --git a/components/ui/button.tsx b/components/ui/button.tsx new file mode 100644 index 0000000..d27984d --- /dev/null +++ b/components/ui/button.tsx @@ -0,0 +1,58 @@ +import * as React from "react"; +import { Slot } from "@radix-ui/react-slot"; +import { cva, type VariantProps } from "class-variance-authority"; + +import { cn } from "@/lib/utils"; + +const buttonVariants = cva( + "inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50", + { + variants: { + variant: { + default: "bg-primary text-primary-foreground hover:bg-primary/90", + destructive: + "bg-destructive text-destructive-foreground hover:bg-destructive/90", + outline: + "border border-input bg-background hover:bg-accent hover:text-accent-foreground", + secondary: + "bg-secondary text-secondary-foreground hover:bg-secondary/80", + ghost: "hover:bg-accent hover:text-accent-foreground", + link: "text-primary underline-offset-4 hover:underline", + big_icon: + "bg-primary text-primary-foreground hover:bg-primary/90 !py-[25px] md:!py-[34px] px-8 text-sm md:text-base flex items-center gap-2 hover:gap-4 active:scale-[0.97] transition-all duration-300 ease-out", + }, + size: { + default: "h-10 px-4 py-2", + sm: "h-9 rounded-md px-3", + lg: "h-11 rounded-md px-8", + icon: "h-10 w-10", + }, + }, + defaultVariants: { + variant: "default", + size: "default", + }, + } +); + +export interface ButtonProps + extends React.ButtonHTMLAttributes, + VariantProps { + asChild?: boolean; +} + +const Button = React.forwardRef( + ({ className, variant, size, asChild = false, ...props }, ref) => { + const Comp = asChild ? Slot : "button"; + return ( + + ); + } +); +Button.displayName = "Button"; + +export { Button, buttonVariants }; diff --git a/components/ui/checkbox.tsx b/components/ui/checkbox.tsx new file mode 100644 index 0000000..df61a13 --- /dev/null +++ b/components/ui/checkbox.tsx @@ -0,0 +1,30 @@ +"use client" + +import * as React from "react" +import * as CheckboxPrimitive from "@radix-ui/react-checkbox" +import { Check } from "lucide-react" + +import { cn } from "@/lib/utils" + +const Checkbox = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + + + + + +)) +Checkbox.displayName = CheckboxPrimitive.Root.displayName + +export { Checkbox } diff --git a/components/ui/dialog.tsx b/components/ui/dialog.tsx new file mode 100644 index 0000000..d3ae524 --- /dev/null +++ b/components/ui/dialog.tsx @@ -0,0 +1,122 @@ +"use client"; + +import * as React from "react"; +import * as DialogPrimitive from "@radix-ui/react-dialog"; +import { X } from "lucide-react"; + +import { cn } from "@/lib/utils"; + +const Dialog = DialogPrimitive.Root; + +const DialogTrigger = DialogPrimitive.Trigger; + +const DialogPortal = DialogPrimitive.Portal; + +const DialogClose = DialogPrimitive.Close; + +const DialogOverlay = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +DialogOverlay.displayName = DialogPrimitive.Overlay.displayName; + +const DialogContent = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, children, ...props }, ref) => ( + + + + {children} + + + Close + + + +)); +DialogContent.displayName = DialogPrimitive.Content.displayName; + +const DialogHeader = ({ + className, + ...props +}: React.HTMLAttributes) => ( +
    +); +DialogHeader.displayName = "DialogHeader"; + +const DialogFooter = ({ + className, + ...props +}: React.HTMLAttributes) => ( +
    +); +DialogFooter.displayName = "DialogFooter"; + +const DialogTitle = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +DialogTitle.displayName = DialogPrimitive.Title.displayName; + +const DialogDescription = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +DialogDescription.displayName = DialogPrimitive.Description.displayName; + +export { + Dialog, + DialogPortal, + DialogOverlay, + DialogClose, + DialogTrigger, + DialogContent, + DialogHeader, + DialogFooter, + DialogTitle, + DialogDescription, +}; diff --git a/components/ui/input.tsx b/components/ui/input.tsx new file mode 100644 index 0000000..4cc8e02 --- /dev/null +++ b/components/ui/input.tsx @@ -0,0 +1,25 @@ +import * as React from "react" + +import { cn } from "@/lib/utils" + +export interface InputProps + extends React.InputHTMLAttributes {} + +const Input = React.forwardRef( + ({ className, type, ...props }, ref) => { + return ( + + ) + } +) +Input.displayName = "Input" + +export { Input } diff --git a/components/ui/label.tsx b/components/ui/label.tsx new file mode 100644 index 0000000..5341821 --- /dev/null +++ b/components/ui/label.tsx @@ -0,0 +1,26 @@ +"use client" + +import * as React from "react" +import * as LabelPrimitive from "@radix-ui/react-label" +import { cva, type VariantProps } from "class-variance-authority" + +import { cn } from "@/lib/utils" + +const labelVariants = cva( + "text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70" +) + +const Label = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef & + VariantProps +>(({ className, ...props }, ref) => ( + +)) +Label.displayName = LabelPrimitive.Root.displayName + +export { Label } diff --git a/components/ui/select.tsx b/components/ui/select.tsx new file mode 100644 index 0000000..d296850 --- /dev/null +++ b/components/ui/select.tsx @@ -0,0 +1,160 @@ +"use client" + +import * as React from "react" +import * as SelectPrimitive from "@radix-ui/react-select" +import { Check, ChevronDown, ChevronUp } from "lucide-react" + +import { cn } from "@/lib/utils" + +const Select = SelectPrimitive.Root + +const SelectGroup = SelectPrimitive.Group + +const SelectValue = SelectPrimitive.Value + +const SelectTrigger = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, children, ...props }, ref) => ( + span]:line-clamp-1", + className + )} + {...props} + > + {children} + + + + +)) +SelectTrigger.displayName = SelectPrimitive.Trigger.displayName + +const SelectScrollUpButton = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + + + +)) +SelectScrollUpButton.displayName = SelectPrimitive.ScrollUpButton.displayName + +const SelectScrollDownButton = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + + + +)) +SelectScrollDownButton.displayName = + SelectPrimitive.ScrollDownButton.displayName + +const SelectContent = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, children, position = "popper", ...props }, ref) => ( + + + + + {children} + + + + +)) +SelectContent.displayName = SelectPrimitive.Content.displayName + +const SelectLabel = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)) +SelectLabel.displayName = SelectPrimitive.Label.displayName + +const SelectItem = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, children, ...props }, ref) => ( + + + + + + + + {children} + +)) +SelectItem.displayName = SelectPrimitive.Item.displayName + +const SelectSeparator = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)) +SelectSeparator.displayName = SelectPrimitive.Separator.displayName + +export { + Select, + SelectGroup, + SelectValue, + SelectTrigger, + SelectContent, + SelectLabel, + SelectItem, + SelectSeparator, + SelectScrollUpButton, + SelectScrollDownButton, +} diff --git a/components/ui/skeleton.tsx b/components/ui/skeleton.tsx new file mode 100644 index 0000000..01b8b6d --- /dev/null +++ b/components/ui/skeleton.tsx @@ -0,0 +1,15 @@ +import { cn } from "@/lib/utils" + +function Skeleton({ + className, + ...props +}: React.HTMLAttributes) { + return ( +
    + ) +} + +export { Skeleton } diff --git a/components/ui/tabs.tsx b/components/ui/tabs.tsx new file mode 100644 index 0000000..236e353 --- /dev/null +++ b/components/ui/tabs.tsx @@ -0,0 +1,55 @@ +"use client"; + +import * as React from "react"; +import * as TabsPrimitive from "@radix-ui/react-tabs"; + +import { cn } from "@/lib/utils"; + +const Tabs = TabsPrimitive.Root; + +const TabsList = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +TabsList.displayName = TabsPrimitive.List.displayName; + +const TabsTrigger = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +TabsTrigger.displayName = TabsPrimitive.Trigger.displayName; + +const TabsContent = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, ...props }, ref) => ( + +)); +TabsContent.displayName = TabsPrimitive.Content.displayName; + +export { Tabs, TabsList, TabsTrigger, TabsContent }; diff --git a/components/ui/tooltip.tsx b/components/ui/tooltip.tsx new file mode 100644 index 0000000..c3f4c7d --- /dev/null +++ b/components/ui/tooltip.tsx @@ -0,0 +1,30 @@ +"use client" + +import * as React from "react" +import * as TooltipPrimitive from "@radix-ui/react-tooltip" + +import { cn } from "@/lib/utils" + +const TooltipProvider = TooltipPrimitive.Provider + +const Tooltip = TooltipPrimitive.Root + +const TooltipTrigger = TooltipPrimitive.Trigger + +const TooltipContent = React.forwardRef< + React.ElementRef, + React.ComponentPropsWithoutRef +>(({ className, sideOffset = 4, ...props }, ref) => ( + +)) +TooltipContent.displayName = TooltipPrimitive.Content.displayName + +export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider } diff --git a/convex/README.md b/convex/README.md new file mode 100644 index 0000000..4d82e13 --- /dev/null +++ b/convex/README.md @@ -0,0 +1,90 @@ +# Welcome to your Convex functions directory! + +Write your Convex functions here. +See https://docs.convex.dev/functions for more. + +A query function that takes two arguments looks like: + +```ts +// functions.js +import { query } from "./_generated/server"; +import { v } from "convex/values"; + +export const myQueryFunction = query({ + // Validators for arguments. + args: { + first: v.number(), + second: v.string(), + }, + + // Function implementation. + handler: async (ctx, args) => { + // Read the database as many times as you need here. + // See https://docs.convex.dev/database/reading-data. + const documents = await ctx.db.query("tablename").collect(); + + // Arguments passed from the client are properties of the args object. + console.log(args.first, args.second); + + // Write arbitrary JavaScript here: filter, aggregate, build derived data, + // remove non-public properties, or create new objects. + return documents; + }, +}); +``` + +Using this query function in a React component looks like: + +```ts +const data = useQuery(api.functions.myQueryFunction, { + first: 10, + second: "hello", +}); +``` + +A mutation function looks like: + +```ts +// functions.js +import { mutation } from "./_generated/server"; +import { v } from "convex/values"; + +export const myMutationFunction = mutation({ + // Validators for arguments. + args: { + first: v.string(), + second: v.string(), + }, + + // Function implementation. + handler: async (ctx, args) => { + // Insert or modify documents in the database here. + // Mutations can also read from the database like queries. + // See https://docs.convex.dev/database/writing-data. + const message = { body: args.first, author: args.second }; + const id = await ctx.db.insert("messages", message); + + // Optionally, return a value from your mutation. + return await ctx.db.get(id); + }, +}); +``` + +Using this mutation function in a React component looks like: + +```ts +const mutation = useMutation(api.functions.myMutationFunction); +function handleButtonPress() { + // fire and forget, the most common way to use mutations + mutation({ first: "Hello!", second: "me" }); + // OR + // use the result once the mutation has completed + mutation({ first: "Hello!", second: "me" }).then((result) => + console.log(result), + ); +} +``` + +Use the Convex CLI to push your functions to a deployment. See everything +the Convex CLI can do by running `npx convex -h` in your project root +directory. To learn more, launch the docs with `npx convex docs`. diff --git a/convex/_generated/api.d.ts b/convex/_generated/api.d.ts new file mode 100644 index 0000000..0b46fe9 --- /dev/null +++ b/convex/_generated/api.d.ts @@ -0,0 +1,37 @@ +/* eslint-disable */ +/** + * Generated `api` utility. + * + * THIS CODE IS AUTOMATICALLY GENERATED. + * + * Generated by convex@1.12.2. + * To regenerate, run `npx convex dev`. + * @module + */ + +import type { + ApiFromModules, + FilterApi, + FunctionReference, +} from "convex/server"; +import type * as resume from "../resume.js"; + +/** + * A utility for referencing Convex functions in your app's API. + * + * Usage: + * ```js + * const myFunctionReference = api.myModule.myFunction; + * ``` + */ +declare const fullApi: ApiFromModules<{ + resume: typeof resume; +}>; +export declare const api: FilterApi< + typeof fullApi, + FunctionReference +>; +export declare const internal: FilterApi< + typeof fullApi, + FunctionReference +>; diff --git a/convex/_generated/api.js b/convex/_generated/api.js new file mode 100644 index 0000000..ad3dfd2 --- /dev/null +++ b/convex/_generated/api.js @@ -0,0 +1,23 @@ +/* eslint-disable */ +/** + * Generated `api` utility. + * + * THIS CODE IS AUTOMATICALLY GENERATED. + * + * Generated by convex@1.12.2. + * To regenerate, run `npx convex dev`. + * @module + */ + +import { anyApi } from "convex/server"; + +/** + * A utility for referencing Convex functions in your app's API. + * + * Usage: + * ```js + * const myFunctionReference = api.myModule.myFunction; + * ``` + */ +export const api = anyApi; +export const internal = anyApi; diff --git a/convex/_generated/dataModel.d.ts b/convex/_generated/dataModel.d.ts new file mode 100644 index 0000000..a935214 --- /dev/null +++ b/convex/_generated/dataModel.d.ts @@ -0,0 +1,61 @@ +/* eslint-disable */ +/** + * Generated data model types. + * + * THIS CODE IS AUTOMATICALLY GENERATED. + * + * Generated by convex@1.12.2. + * To regenerate, run `npx convex dev`. + * @module + */ + +import type { + DataModelFromSchemaDefinition, + DocumentByName, + TableNamesInDataModel, + SystemTableNames, +} from "convex/server"; +import type { GenericId } from "convex/values"; +import schema from "../schema.js"; + +/** + * The names of all of your Convex tables. + */ +export type TableNames = TableNamesInDataModel; + +/** + * The type of a document stored in Convex. + * + * @typeParam TableName - A string literal type of the table name (like "users"). + */ +export type Doc = DocumentByName< + DataModel, + TableName +>; + +/** + * An identifier for a document in Convex. + * + * Convex documents are uniquely identified by their `Id`, which is accessible + * on the `_id` field. To learn more, see [Document IDs](https://docs.convex.dev/using/document-ids). + * + * Documents can be loaded using `db.get(id)` in query and mutation functions. + * + * IDs are just strings at runtime, but this type can be used to distinguish them from other + * strings when type checking. + * + * @typeParam TableName - A string literal type of the table name (like "users"). + */ +export type Id = + GenericId; + +/** + * A type describing your Convex data model. + * + * This type includes information about what tables you have, the type of + * documents stored in those tables, and the indexes defined on them. + * + * This type is used to parameterize methods like `queryGeneric` and + * `mutationGeneric` to make them type-safe. + */ +export type DataModel = DataModelFromSchemaDefinition; diff --git a/convex/_generated/server.d.ts b/convex/_generated/server.d.ts new file mode 100644 index 0000000..3c75725 --- /dev/null +++ b/convex/_generated/server.d.ts @@ -0,0 +1,143 @@ +/* eslint-disable */ +/** + * Generated utilities for implementing server-side Convex query and mutation functions. + * + * THIS CODE IS AUTOMATICALLY GENERATED. + * + * Generated by convex@1.12.2. + * To regenerate, run `npx convex dev`. + * @module + */ + +import { + ActionBuilder, + HttpActionBuilder, + MutationBuilder, + QueryBuilder, + GenericActionCtx, + GenericMutationCtx, + GenericQueryCtx, + GenericDatabaseReader, + GenericDatabaseWriter, +} from "convex/server"; +import type { DataModel } from "./dataModel.js"; + +/** + * Define a query in this Convex app's public API. + * + * This function will be allowed to read your Convex database and will be accessible from the client. + * + * @param func - The query function. It receives a {@link QueryCtx} as its first argument. + * @returns The wrapped query. Include this as an `export` to name it and make it accessible. + */ +export declare const query: QueryBuilder; + +/** + * Define a query that is only accessible from other Convex functions (but not from the client). + * + * This function will be allowed to read from your Convex database. It will not be accessible from the client. + * + * @param func - The query function. It receives a {@link QueryCtx} as its first argument. + * @returns The wrapped query. Include this as an `export` to name it and make it accessible. + */ +export declare const internalQuery: QueryBuilder; + +/** + * Define a mutation in this Convex app's public API. + * + * This function will be allowed to modify your Convex database and will be accessible from the client. + * + * @param func - The mutation function. It receives a {@link MutationCtx} as its first argument. + * @returns The wrapped mutation. Include this as an `export` to name it and make it accessible. + */ +export declare const mutation: MutationBuilder; + +/** + * Define a mutation that is only accessible from other Convex functions (but not from the client). + * + * This function will be allowed to modify your Convex database. It will not be accessible from the client. + * + * @param func - The mutation function. It receives a {@link MutationCtx} as its first argument. + * @returns The wrapped mutation. Include this as an `export` to name it and make it accessible. + */ +export declare const internalMutation: MutationBuilder; + +/** + * Define an action in this Convex app's public API. + * + * An action is a function which can execute any JavaScript code, including non-deterministic + * code and code with side-effects, like calling third-party services. + * They can be run in Convex's JavaScript environment or in Node.js using the "use node" directive. + * They can interact with the database indirectly by calling queries and mutations using the {@link ActionCtx}. + * + * @param func - The action. It receives an {@link ActionCtx} as its first argument. + * @returns The wrapped action. Include this as an `export` to name it and make it accessible. + */ +export declare const action: ActionBuilder; + +/** + * Define an action that is only accessible from other Convex functions (but not from the client). + * + * @param func - The function. It receives an {@link ActionCtx} as its first argument. + * @returns The wrapped function. Include this as an `export` to name it and make it accessible. + */ +export declare const internalAction: ActionBuilder; + +/** + * Define an HTTP action. + * + * This function will be used to respond to HTTP requests received by a Convex + * deployment if the requests matches the path and method where this action + * is routed. Be sure to route your action in `convex/http.js`. + * + * @param func - The function. It receives an {@link ActionCtx} as its first argument. + * @returns The wrapped function. Import this function from `convex/http.js` and route it to hook it up. + */ +export declare const httpAction: HttpActionBuilder; + +/** + * A set of services for use within Convex query functions. + * + * The query context is passed as the first argument to any Convex query + * function run on the server. + * + * This differs from the {@link MutationCtx} because all of the services are + * read-only. + */ +export type QueryCtx = GenericQueryCtx; + +/** + * A set of services for use within Convex mutation functions. + * + * The mutation context is passed as the first argument to any Convex mutation + * function run on the server. + */ +export type MutationCtx = GenericMutationCtx; + +/** + * A set of services for use within Convex action functions. + * + * The action context is passed as the first argument to any Convex action + * function run on the server. + */ +export type ActionCtx = GenericActionCtx; + +/** + * An interface to read from the database within Convex query functions. + * + * The two entry points are {@link DatabaseReader.get}, which fetches a single + * document by its {@link Id}, or {@link DatabaseReader.query}, which starts + * building a query. + */ +export type DatabaseReader = GenericDatabaseReader; + +/** + * An interface to read from and write to the database within Convex mutation + * functions. + * + * Convex guarantees that all writes within a single mutation are + * executed atomically, so you never have to worry about partial writes leaving + * your data in an inconsistent state. See [the Convex Guide](https://docs.convex.dev/understanding/convex-fundamentals/functions#atomicity-and-optimistic-concurrency-control) + * for the guarantees Convex provides your functions. + */ +export type DatabaseWriter = GenericDatabaseWriter; diff --git a/convex/_generated/server.js b/convex/_generated/server.js new file mode 100644 index 0000000..d76b05a --- /dev/null +++ b/convex/_generated/server.js @@ -0,0 +1,90 @@ +/* eslint-disable */ +/** + * Generated utilities for implementing server-side Convex query and mutation functions. + * + * THIS CODE IS AUTOMATICALLY GENERATED. + * + * Generated by convex@1.12.2. + * To regenerate, run `npx convex dev`. + * @module + */ + +import { + actionGeneric, + httpActionGeneric, + queryGeneric, + mutationGeneric, + internalActionGeneric, + internalMutationGeneric, + internalQueryGeneric, +} from "convex/server"; + +/** + * Define a query in this Convex app's public API. + * + * This function will be allowed to read your Convex database and will be accessible from the client. + * + * @param func - The query function. It receives a {@link QueryCtx} as its first argument. + * @returns The wrapped query. Include this as an `export` to name it and make it accessible. + */ +export const query = queryGeneric; + +/** + * Define a query that is only accessible from other Convex functions (but not from the client). + * + * This function will be allowed to read from your Convex database. It will not be accessible from the client. + * + * @param func - The query function. It receives a {@link QueryCtx} as its first argument. + * @returns The wrapped query. Include this as an `export` to name it and make it accessible. + */ +export const internalQuery = internalQueryGeneric; + +/** + * Define a mutation in this Convex app's public API. + * + * This function will be allowed to modify your Convex database and will be accessible from the client. + * + * @param func - The mutation function. It receives a {@link MutationCtx} as its first argument. + * @returns The wrapped mutation. Include this as an `export` to name it and make it accessible. + */ +export const mutation = mutationGeneric; + +/** + * Define a mutation that is only accessible from other Convex functions (but not from the client). + * + * This function will be allowed to modify your Convex database. It will not be accessible from the client. + * + * @param func - The mutation function. It receives a {@link MutationCtx} as its first argument. + * @returns The wrapped mutation. Include this as an `export` to name it and make it accessible. + */ +export const internalMutation = internalMutationGeneric; + +/** + * Define an action in this Convex app's public API. + * + * An action is a function which can execute any JavaScript code, including non-deterministic + * code and code with side-effects, like calling third-party services. + * They can be run in Convex's JavaScript environment or in Node.js using the "use node" directive. + * They can interact with the database indirectly by calling queries and mutations using the {@link ActionCtx}. + * + * @param func - The action. It receives an {@link ActionCtx} as its first argument. + * @returns The wrapped action. Include this as an `export` to name it and make it accessible. + */ +export const action = actionGeneric; + +/** + * Define an action that is only accessible from other Convex functions (but not from the client). + * + * @param func - The function. It receives an {@link ActionCtx} as its first argument. + * @returns The wrapped function. Include this as an `export` to name it and make it accessible. + */ +export const internalAction = internalActionGeneric; + +/** + * Define a Convex HTTP action. + * + * @param func - The function. It receives an {@link ActionCtx} as its first argument, and a `Request` object + * as its second. + * @returns The wrapped endpoint function. Route a URL path to this function in `convex/http.js`. + */ +export const httpAction = httpActionGeneric; diff --git a/convex/auth.config.ts b/convex/auth.config.ts new file mode 100644 index 0000000..e712076 --- /dev/null +++ b/convex/auth.config.ts @@ -0,0 +1,8 @@ +export default { + providers: [ + { + domain: "https://sound-crab-61.clerk.accounts.dev/", + applicationID: "convex", + }, + ] + }; \ No newline at end of file diff --git a/convex/resume.ts b/convex/resume.ts new file mode 100644 index 0000000..8f486ce --- /dev/null +++ b/convex/resume.ts @@ -0,0 +1,700 @@ +import { v } from "convex/values"; +import { mutation, query } from "./_generated/server"; +import { + createSection, + templateStructures, +} from "../templates/templateStructures"; +import { ResumeTemplate, SocialLink } from "../types/templateTypes"; + +export const getTemplates = query({ + args: {}, + handler: async (ctx, args) => { + const resumes = await ctx.db + .query("resumes") + .filter((q) => q.eq(q.field("isTemplate"), true)) + .collect(); + + return resumes; + }, +}); + +export const getTemplateDetails = query({ + args: { + id: v.id("resumes"), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + return resume; + }, +}); + +export const updateHeader = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + firstName: v.string(), + lastName: v.optional(v.string()), + email: v.string(), + phone: v.optional(v.string()), + socialLinks: v.optional( + v.array( + v.object({ + name: v.string(), + url: v.string(), + type: v.string(), + }) + ) + ), + location: v.optional(v.string()), + summary: v.optional(v.string()), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + let index = resumeSections.findIndex((obj) => obj.type === "header"); + + if (index === -1) { + throw new Error("Somethign went wrong index"); + } else { + resumeSections[index].content = { + ...resumeSections[index].content, + ...args.content, + }; + } + + const newResume = await ctx.db.patch(args.id, { + sections: resumeSections, + }); + + return resumeSections; + }, +}); + +export const createUserResume = mutation({ + args: { + id: v.id("resumes"), + userId: v.string(), + templateName: v.string(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + + if (!args.userId) { + throw new Error("Something went wrong...no userId"); + } + + if (!resume) { + throw new Error("Something went wrong"); + } + + const templateSections: any = templateStructures[args.templateName]; + if (!templateSections) { + throw new Error("Invalid template name"); + } + + const initialSections = templateSections.map((section: any) => + createSection( + section.type, + section.fields, + section.orderNumber, + section.isVisible + ) + ); + + const newResume = await ctx.db.insert("resumes", { + isTemplate: false, + userId: args.userId, + globalStyles: resume?.globalStyles!, + templateName: args?.templateName, + sections: initialSections, + }); + + return newResume; + }, +}); + +export const updateExperience = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + experience: v.array( + v.object({ + companyName: v.string(), + role: v.string(), + jobDescription: v.string(), + location: v.optional(v.string()), + startMonth: v.optional(v.string()), + startYear: v.string(), + endMonth: v.optional(v.string()), + endYear: v.string(), + workingHere: v.boolean(), + }) + ), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + let index = resumeSections.findIndex((item) => item.type === "experience"); + if (index === -1) { + throw new Error("Something went wrong index"); + } else { + resumeSections[index].content = { + ...resumeSections[index]?.content, + ...args.content, + }; + } + + const newResume = await ctx.db.patch(args.id, { + sections: resumeSections, + }); + return newResume; + }, +}); + +export const updateEducation = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + education: v.array( + v.object({ + courseName: v.string(), + instituteName: v.string(), + startMonth: v.optional(v.string()), + startYear: v.optional(v.string()), + endMonth: v.optional(v.string()), + endYear: v.optional(v.string()), + location: v.string(), + grade: v.optional(v.string()), + studyingHere: v.boolean(), + }) + ), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + let index = resumeSections.findIndex((item) => item.type === "education"); + if (index === -1) { + throw new Error("Something went wrong index"); + } else { + resumeSections[index].content = { + ...resumeSections[index]?.content, + ...args.content, + }; + } + await ctx.db.patch(args.id, { + sections: resumeSections, + }); + }, +}); + +export const updateCustomSection = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + sectionTitle: v.string(), + sectionDescription: v.string(), + sectionNumber: v.number(), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + const customSection = resumeSections.filter( + (item) => item.type === "custom" + ); + + const currentCustomSectionIndex = customSection.findIndex( + (item) => item.content.sectionNumber === args.content.sectionNumber + ); + + const allOrderNumbers: any = + resumeSections?.map((item) => item.orderNumber) || []; + const maxNumber = Math.max(...allOrderNumbers); + + if ( + args.content.sectionTitle.trim() === "" && + (args.content.sectionDescription.trim() === "


    " || + args.content.sectionDescription.trim() === "") + ) { + const updatedSections = resumeSections.filter( + (item) => + !( + item.type === "custom" && + item.content.sectionNumber === args.content.sectionNumber + ) + ); + return await ctx.db.patch(args.id, { + sections: updatedSections, + }); + } + + if (currentCustomSectionIndex === -1) { + resumeSections.push({ + type: "custom", + content: { + sectionTitle: args.content.sectionTitle, + sectionDescription: args.content.sectionDescription, + sectionNumber: args.content.sectionNumber, + }, + orderNumber: maxNumber + 1, + isVisible: true, + }); + await ctx.db.patch(args.id, { + sections: resumeSections, + }); + } else { + customSection[currentCustomSectionIndex].content = args.content; + await ctx.db.patch(args.id, { + sections: resumeSections, + }); + } + }, +}); + +export const removeCustomSection = mutation({ + args: { + id: v.id("resumes"), + sectionNumber: v.number(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const resumeSections = resume?.sections; + const customSection = resumeSections.filter( + (item) => item.type === "custom" + ); + const currentCustomSection = customSection.find( + (item) => item.content.sectionNumber === args.sectionNumber + ); + + const orderNumberRemoved = currentCustomSection?.orderNumber; + + if (!orderNumberRemoved) { + throw new Error("Something went wrong"); + } + + const updatedCustomSections = resumeSections.filter( + (item) => item.orderNumber !== orderNumberRemoved + ); + + await ctx.db.patch(args.id, { + sections: updatedCustomSections, + }); + }, +}); + +export const updateSkills = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + description: v.string(), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + let index = resumeSections.findIndex((item) => item.type === "skills"); + if (index === -1) { + throw new Error("Something went wrong index"); + } else { + resumeSections[index].content = { + ...resumeSections[index].content, + ...args.content, + }; + } + const newResume = await ctx.db.patch(args.id, { + sections: resumeSections, + }); + + return newResume; + }, +}); + +export const updateProjects = mutation({ + args: { + id: v.id("resumes"), + content: v.object({ + projects: v.array( + v.object({ + name: v.string(), + description: v.string(), + githuburl: v.optional(v.string()), + liveurl: v.optional(v.string()), + }) + ), + }), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const resumeSections = resume?.sections; + let projectsIndex = resumeSections.findIndex( + (item) => item.type === "projects" + ); + if (projectsIndex === -1) { + throw new Error("Projects section not found in resume"); + } else { + resumeSections[projectsIndex].content = { + ...resumeSections[projectsIndex].content, + ...args.content, + }; + } + + const newResume = await ctx.db.patch(args.id, { + sections: resumeSections, + }); + return newResume; + }, +}); + +export const updateColor = mutation({ + args: { + id: v.id("resumes"), + color: v.string(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + const newGlobalStyles = { + ...resume.globalStyles, + primaryTextColor: args.color, + }; + const newResume = await ctx.db.patch(args.id, { + globalStyles: newGlobalStyles, + }); + return newResume; + }, +}); + +export const updateColorPC = mutation({ + args: { + id: v.id("resumes"), + color: v.string(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const newGlobalStyles = { + ...resume.globalStyles, + primaryColor: args.color, + }; + const newResume = await ctx.db.patch(args.id, { + globalStyles: newGlobalStyles, + }); + return newResume; + }, +}); + +export const updateFont = mutation({ + args: { + id: v.id("resumes"), + font: v.string(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Something went wrong"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const updatedResume = await ctx.db.patch(args.id, { + globalStyles: { + ...resume.globalStyles, + fontFamily: args.font, + }, + }); + + return updatedResume; + }, +}); + +export const getUserResumes = query({ + args: { + userId: v.string(), + }, + handler: async (ctx, args) => { + const resumes = await ctx.db + .query("resumes") + .filter((q) => q.eq(q.field("userId"), args.userId)) + .collect(); + + return resumes; + }, +}); + +export const getCustomSections = query({ + args: { + id: v.id("resumes"), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Resume not found"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const resumeSections = resume?.sections; + + const customSection = resumeSections.filter( + (item) => item.type === "custom" + ); + + return customSection; + }, +}); + +const SectionType = v.union( + v.literal("header"), + v.literal("skills"), + v.literal("projects"), + v.literal("experience"), + v.literal("education"), + v.literal("custom") +); + +export const reorderSections = mutation({ + args: { + id: v.id("resumes"), + updatedSections: v.any(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Resume not found"); + } + + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const updatedResume = await ctx.db.patch(args.id, { + sections: args.updatedSections, + }); + return updatedResume; + }, +}); + +export const migrateResumes = mutation({ + args: {}, + handler: async (ctx, args) => { + const resumes = await ctx.db.query("resumes").collect(); + + for (const resume of resumes) { + const oldHeader: any = resume.sections.find( + (section) => section.type === "header" + ); + + if (oldHeader) { + const socialLinks: SocialLink[] = []; + + if (oldHeader.content.github) { + socialLinks.push({ + name: "GitHub", + type: "github", + url: `https://github.com/${oldHeader.content.github}`, + }); + } + + if (oldHeader.content.linkedin) { + socialLinks.push({ + name: "LinkedIn", + type: "linkedin", + url: oldHeader.content.linkedin, + }); + } + + const newHeader = { + ...oldHeader, + content: { + email: oldHeader.content.email, + firstName: oldHeader.content.firstName, + lastName: oldHeader.content.lastName, + phone: oldHeader.content.phone, + socialLinks, + }, + }; + + if (oldHeader.content.summary) { + newHeader.content.summary = oldHeader.content.summary; + } + + resume.sections = resume.sections.map((section) => + section.type === "header" ? newHeader : section + ); + + await ctx.db.patch(resume._id, { + sections: resume.sections, + }); + } + } + + return resumes; + }, +}); + + +export const hideSection = mutation({ + args: { + id: v.id("resumes"), + sectionId: v.string(), + }, + handler: async (ctx, args) => { + const resume = await ctx.db.get(args.id); + if (!resume) { + throw new Error("Resume not found"); + } + const identity = await ctx.auth.getUserIdentity(); + if (!identity) { + throw new Error("Not authenticated"); + } + + if (identity.subject !== resume.userId) { + throw new Error("Unauthorized"); + } + + const resumeSections = resume?.sections; + let index = resumeSections.findIndex((item) => item.type === args.sectionId); + if (index === -1) { + throw new Error("Something went wrong index"); + } else { + resumeSections[index].isVisible = !resumeSections[index].isVisible; + } + + const updatedResume = await ctx.db.patch(args.id, { + sections: resumeSections, + }); + + return updatedResume; + }, +}); \ No newline at end of file diff --git a/convex/schema.ts b/convex/schema.ts new file mode 100644 index 0000000..0dab9f8 --- /dev/null +++ b/convex/schema.ts @@ -0,0 +1,128 @@ + import { defineSchema, defineTable } from "convex/server"; + import { v } from "convex/values"; + + const sectionContentSchema = v.union( + v.object({ + type: v.literal("header"), + content: v.object({ + firstName: v.string(), + lastName: v.optional(v.string()), + email: v.string(), + phone: v.optional(v.string()), + location: v.optional(v.string()), + summary: v.optional(v.string()), + photo: v.optional(v.string()), + socialLinks : v.array( + v.object({ + type : v.string(), + name: v.string(), + url: v.string(), + }) + ) + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }), + + v.object({ + type: v.literal("skills"), + content: v.object({ + description: v.string(), + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }), + + v.object({ + type: v.literal("projects"), + content: v.object({ + projects: v.array( + v.object({ + name: v.string(), + description: v.string(), + githuburl: v.optional(v.string()), + liveurl: v.optional(v.string()), + }) + ), + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }), + + v.object({ + type: v.literal("experience"), + content: v.object({ + experience: v.array( + v.object({ + companyName: v.string(), + role: v.string(), + jobDescription: v.string(), + location: v.optional(v.string()), + startMonth: v.optional(v.string()), + startYear: v.string(), + endMonth: v.optional(v.string()), + endYear: v.string(), + workingHere: v.boolean(), + }) + ), + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }), + + v.object({ + type: v.literal("education"), + content: v.object({ + education: v.array( + v.object({ + courseName: v.string(), + instituteName: v.string(), + location: v.optional(v.string()), + startMonth: v.optional(v.string()), + startYear: v.optional(v.string()), + endMonth: v.optional(v.string()), + endYear: v.optional(v.string()), + studyingHere: v.boolean(), + grade: v.optional(v.string()), + }) + ), + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }), + + v.object({ + type: v.literal("custom"), + content: v.object({ + sectionTitle: v.optional(v.string()), + sectionDescription: v.optional(v.string()), + sectionNumber : v.optional(v.number()), + }), + isVisible : v.boolean(), + orderNumber: v.optional(v.number()), + style: v.optional(v.any()), + }) + ); + + export default defineSchema({ + resumes: defineTable({ + isTemplate: v.boolean(), + userId: v.string(), + templateName: v.string(), + sections: v.array(sectionContentSchema), + globalStyles: v.object({ + fontFamily: v.string(), + primaryTextColor: v.string(), + primaryColor: v.string(), + photo: v.boolean(), + columns: v.number(), + }), + }), + }); + + diff --git a/convex/tsconfig.json b/convex/tsconfig.json new file mode 100644 index 0000000..6fa874e --- /dev/null +++ b/convex/tsconfig.json @@ -0,0 +1,25 @@ +{ + /* This TypeScript project config describes the environment that + * Convex functions run in and is used to typecheck them. + * You can modify it, but some settings required to use Convex. + */ + "compilerOptions": { + /* These settings are not required by Convex and can be modified. */ + "allowJs": true, + "strict": true, + "moduleResolution": "Bundler", + "jsx": "react-jsx", + "skipLibCheck": true, + "allowSyntheticDefaultImports": true, + + /* These compiler options are required by Convex */ + "target": "ESNext", + "lib": ["ES2021", "dom"], + "forceConsistentCasingInFileNames": true, + "module": "ESNext", + "isolatedModules": true, + "noEmit": true + }, + "include": ["./**/*"], + "exclude": ["./_generated"] +} diff --git a/lib/documents.jsonl b/lib/documents.jsonl new file mode 100644 index 0000000..c950a0b --- /dev/null +++ b/lib/documents.jsonl @@ -0,0 +1,37 @@ +{"_creationTime":1727527326415.1604,"_id":"j5702s1k3dqqqfymh6a0z5r65x71mvyr","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"Microsoft","endMonth":"","endYear":"","jobDescription":"
    • Developed and maintained key features for Microsoft's Azure platform, contributing to a 10% increase in user engagement and a 5% reduction in support tickets.
    • Collaborated with cross-functional teams to design and implement new software solutions, resulting in a 20% improvement in application performance and a 15% reduction in development time.
    • Leveraged expertise in cloud technologies and software development best practices to deliver high-quality, scalable applications, achieving a 99.9% uptime SLA for critical services.
    ","location":"","role":"Software Developer","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mfPvdV0LAJkDOnZ5QYsAzougsK"} +{"_creationTime":1727738980381.7708,"_id":"j570x1aenyeqjssf2dcwqg4t9n71rrzy","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"parisottohoracio@gmail.com","firstName":"Horacio","github":"johndoe676","lastName":"Parisotto","linkedin":"linkedin.com/johndoe","phone":"01140817173"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2moNS73zQ5ODONPRbBo2GlGGqzI"} +{"_creationTime":1727420986563.1978,"_id":"j5717p3w5r3x1a766285s861j971jkv7","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":true,"sections":[{"content":{"email":"john.doe@example.com","firstName":"JOHN","github":"johndoe","lastName":"DOE","linkedin":"john-doe","location":"New York, NY","phone":"+1-555-123-4567"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"Bachelor of Science in Computer Science","endMonth":"March","endYear":"2023","grade":"8.2 CGPA","instituteName":"University of California, Berkeley","location":"Berkeley, CA","startMonth":"Feb","startYear":"2022","studyingHere":false},{"courseName":"Master of Science in Software Engineering","endMonth":"Dec","endYear":"2022","grade":"8.2 CGPA","instituteName":"Stanford University","location":"Stanford, CA","startMonth":"Jan","startYear":"2020","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"projects":[{"description":"

    Developed a full-featured eCommerce platform with user authentication, product management, and secure payment processing using MongoDB, Express.js, React, and Node.js, resulting in a 40% increase in user engagement.

    Integrated advanced search and filtering capabilities, enhancing the user experience by reducing product search time by 50%, and implemented a real-time order tracking system.

    ","githuburl":"https://github.com/johndoe/ecommerce","liveurl":"https://johndoe.com","name":"E-commerce Website Using MERN Stack"},{"description":"

    Built a dynamic currency converter application in React, leveraging third-party APIs to provide real-time exchange rates for over 150 currencies, resulting in a 25% increase in user satisfaction.

    Implemented a responsive and intuitive user interface, ensuring seamless performance across various devices and improving usability scores by 30%.

    ","githuburl":"https://github.com/johndoe/ecommerce","liveurl":"https://ecommerce.johndoe.com","name":"Currency Converter in React"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"experience":[{"companyName":"Tech Solutions Inc.","endMonth":"","endYear":"2024","jobDescription":"

    Led a team of 5 developers in designing and implementing scalable web applications using microservices architecture.

    Developed and maintained 8 web applications using modern JavaScript frameworks and RESTful APIs, ensuring high performance and user-centric design.

    Contributed to 12 successful software releases, including 3 major feature enhancements, achieving a 20% improvement in application efficiency.

    ","location":"San Francisco, CA","role":"Senior Software Engineer","startMonth":"","startYear":"2024","workingHere":false},{"companyName":"Web Innovations LLC","endMonth":"","endYear":"2024","jobDescription":"

    Spearheaded the development of 6 end-to-end web applications from concept to deployment, leveraging React and Node.js, resulting in a 30% reduction in time-to-market.

    Implemented robust authentication systems and RESTful APIs for 10+ web projects, ensuring data security and seamless integration with external services.

    Collaborated with cross-functional teams on 15+ sprints, delivering scalable solutions that improved performance metrics by 25% across multiple client projects.

    ","location":"Austin, TX","role":"Full Stack Developer","startMonth":"","startYear":"2024","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"description":"Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.
    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.
    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.
    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm."},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"admin"} +{"_creationTime":1727724673627.9053,"_id":"j571gmb1xm2025ysd1vvzbjp2n71sb38","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#00f6ff"},"isTemplate":false,"sections":[{"content":{"email":"nigga@gmail.com","firstName":"Asaf","github":"AsafCN","lastName":"Cohen","linkedin":"","phone":"1234567896","summary":"


    "},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"GaryOnTop","endMonth":"","endYear":"Present","jobDescription":"
    • Successfully led the development and implementation of innovative strategies that increased GaryOnTop's customer base by 20% within the past year.
    • Proven ability to manage and motivate a team of 10+ developers, consistently exceeding project deadlines by an average of 10%.
    • Developed and executed a comprehensive marketing plan that resulted in a 15% increase in website traffic and a 5% rise in lead generation.
    ","location":"somewhere","role":"Owner","startMonth":"May","startYear":"2024","workingHere":true}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"
    • Developed a FiveM server, 'Chinchilla GANG,' using C# and Lua, attracting over 500 active players and generating 200,000+ hours of gameplay, showcasing a robust and engaging server experience.
    • Implemented custom scripts and game mechanics, enhancing player interaction and immersion by 30%, resulting in a thriving community with active roleplay and social interactions.
    • Utilized server optimization techniques, ensuring smooth gameplay with minimal lag for over 90% of players, contributing to a positive and enjoyable experience.
    ","githuburl":"","liveurl":"","name":"Chinchilla GANG"}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mnuSio6cRJPrKBDm4yoLGPE1up"} +{"_creationTime":1727551760988.2375,"_id":"j573jsnbb55sf3fhrpxckvjwf971mnqk","globalStyles":{"columns":2.0,"fontFamily":"Raleway","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"zuberkhan034@gmail.com","firstName":"Zuber","github":"dsyucgyuds","lastName":"Khan","linkedin":"dvcudsfcdus","phone":"8171584000"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"dibcdsibf","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"
    • Developed a foundational project, **sadisadias**, demonstrating core programming principles and showcasing proficiency in basic web development concepts.
    • Successfully implemented the classic \\\"Hello World\\\" output, validating the project's functionality and providing a clear starting point for further development.
    • Utilized fundamental web technologies, including HTML, CSS, and JavaScript, to establish a basic web structure and interaction.
    ","githuburl":"sajvdgas","liveurl":"sbjsdash","name":"sadisadias"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2miFre5HAWwyFKZpjonJCmIPznT"} +{"_creationTime":1727949037431.0198,"_id":"j573kpev81n6hxc8mpjzvc7jh171yeef","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2meJqQdYkaYUlbXpPPB7sTppxxt"} +{"_creationTime":1727549194415.8567,"_id":"j5743yqwz4aysvdg7st3jxahhd71mmbb","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"Present","grade":"","instituteName":"","location":"","startMonth":"","startYear":"2024","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2miAnDAwMyNaxTNd50uNMZTT7VE"} +{"_creationTime":1727530304224.0742,"_id":"j5745bhs6xnrh2ksk790k48rv171n4jb","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"Neo","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mhYU2Phyi4uWWORAf2mb4FMwKR"} +{"_creationTime":1727805571863.8352,"_id":"j574v8v1jymq2f6z2c630k5w1n71vjr4","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mqYQrJtBNCmJftysFa8qWHT3Kb"} +{"_creationTime":1727724326702.2046,"_id":"j575743r1t24v6xye1mcb76w6d71r924","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":"

    Automation

    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mntiGoZF4JIsy0M5tFPEFiMI3B"} +{"_creationTime":1727461599029.3206,"_id":"j5758q2epvr123kqt1cgx7jdj171jche","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"None@ofYour.business","firstName":"Jon","github":"Certainly None Of Yours","lastName":"Doe","linkedin":"Definetly None Of yours","phone":"12301112321","summary":"

    Software engineer

    "},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"Imaginary","endMonth":"","endYear":"Present","jobDescription":"
    • Developed innovative and engaging interactive experiences for Imaginary's clients, consistently exceeding client satisfaction ratings by 10%.
    • Collaborated with cross-functional teams to create compelling and user-friendly prototypes, achieving a 95% success rate in user testing.
    • Leveraged cutting-edge technologies and frameworks to build high-performance, scalable applications, resulting in a 20% improvement in application performance.
    ","location":"Moon","role":"Maker","startMonth":"Apr","startYear":"2018","workingHere":true}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mfJCKfZlYoAJAFgfAxWb6OZFj4"} +{"_creationTime":1727420960206.5225,"_id":"j576ws9av39d0ksq9wnfwmcsrd71jsy5","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":true,"sections":[{"content":{"email":"john.doe@example.com","firstName":"John","github":"johndoe","lastName":"Doe","linkedin":"john-doe","location":"New York, NY","phone":"+1-555-123-456","photo":"","summary":"Experienced software developer with a strong background in full-stack development and a passion for creating innovative solutions."},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"description":"Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.
    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.
    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.
    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium."},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"

    Developed a full-featured eCommerce platform with user authentication, product management, and secure payment processing using MongoDB, Express.js, React, and Node.js, resulting in a 40% increase in user engagement.

    Integrated advanced search and filtering capabilities, enhancing the user experience by reducing product search time by 50%, and implemented a real-time order tracking system.

    ","githuburl":"https://github.com/johndoe/ecommerce","liveurl":"https://johndoe.com","name":"E-commerce Website Using MERN Stack"},{"description":"

    Built a dynamic currency converter application in React, leveraging third-party APIs to provide real-time exchange rates for over 150 currencies, resulting in a 25% increase in user satisfaction.

    Implemented a responsive and intuitive user interface, ensuring seamless performance across various devices and improving usability scores by 30%.

    ","githuburl":"https://github.com/johndoe/ecommerce","liveurl":"https://ecommerce.johndoe.com","name":"Currency Converter in React"}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"experience":[{"companyName":"Tech Solutions Inc.","endMonth":"Dec","endYear":"2024","jobDescription":"

    Led a team of 5 developers in designing and implementing scalable web applications using microservices architecture.

    Developed and maintained 8 web applications using modern JavaScript frameworks and RESTful APIs, ensuring high performance and user-centric design.

    Contributed to 12 successful software releases, including 3 major feature enhancements, achieving a 20% improvement in application efficiency.

    ","location":"San Francisco, CA","role":"Senior Software Engineer","startMonth":"Feb","startYear":"2024","workingHere":false},{"companyName":"Web Innovations LLC","endMonth":"Dec","endYear":"2024","jobDescription":"

    Spearheaded the development of 6 end-to-end web applications from concept to deployment, leveraging React and Node.js, resulting in a 30% reduction in time-to-market.

    Implemented robust authentication systems and RESTful APIs for 10+ web projects, ensuring data security and seamless integration with external services.

    ","location":"Austin, TX","role":"Full Stack Developer","startMonth":"Feb","startYear":"2024","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"education":[{"courseName":"Bachelor of Science in Computer Science","endMonth":"March","endYear":"2023","grade":"8.2 CGPA","instituteName":"University of California, Berkeley","location":"Berkeley, CA","startMonth":"Feb","startYear":"2022","studyingHere":false},{"courseName":"Master of Science in Software Engineering","endMonth":"March","endYear":"2023","grade":"8.2 CGPA","instituteName":"Stanford University","location":"Stanford, CA","startMonth":"Feb","startYear":"2022","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"admin"} +{"_creationTime":1727753717673.132,"_id":"j577120tgb24qc3gn7bbpvmbk171vp7e","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"subhajit@letraz.app","firstName":"Subhajit","github":"pingSubhajit","lastName":"Kundu","linkedin":"","phone":"9239202525"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"Master of Computer Application","endMonth":"Dec","endYear":"2024","grade":"8.2 CGPA","instituteName":"Amity University","location":"Noida, India","startMonth":"Jan","startYear":"2023","studyingHere":false},{"courseName":"Bachelor of Commerce","endMonth":"Jul","endYear":"2022","grade":"9.2 CGPA","instituteName":"Kalyani Mahavidyalaya","location":"Kolkata, India","startMonth":"Jun","startYear":"2019","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"Stacks","endMonth":"","endYear":"Present","jobDescription":"
    • Developed and maintained core features of Stacks, a leading blockchain infrastructure, ensuring 99.9% uptime and contributing to the successful launch of over 100 decentralized applications.
    • Collaborated with a team of engineers to implement performance optimizations, resulting in a 15% reduction in transaction latency and a 20% increase in block throughput.
    • Proactively identified and addressed security vulnerabilities, contributing to the robust security posture of Stacks and securing over $1 billion in user funds.
    ","location":"Mumbai, India","role":"Software Engineer","startMonth":"Apr","startYear":"2024","workingHere":true}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2morLCT7RFbmOwnQrPUCSnZNEKI"} +{"_creationTime":1727526772978.4604,"_id":"j577bnmnxk1djy18qa2eyjecf171m250","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"rojinchhetri07@gmail.com","firstName":"Roshan","github":"RojinXChhetri","lastName":"Bhandari Chhetri","linkedin":"linkedin.com/in/rojinchhetri","phone":"0468957055"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"Bachelor of Information Technology","endMonth":"","endYear":"Present","grade":"","instituteName":"Torrens University Australia","location":"Sydney, Australia","startMonth":"Jun","startYear":"2023","studyingHere":true}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"Tech Sanjal PVT. LTD.","endMonth":"Mar","endYear":"2022","jobDescription":"
    • Developed and maintained high-performance web applications for Tech Sanjal PVT. LTD., achieving an average 98% uptime and exceeding customer satisfaction expectations.
    • Implemented efficient database management strategies and optimized code for improved performance, resulting in a 20% reduction in application loading times.
    • Collaborated with cross-functional teams to integrate third-party APIs and streamline user workflows, leading to a 15% increase in user engagement and data accuracy.
    ","location":"Birtamode, Nepal","role":"FullStack Developer","startMonth":"Feb","startYear":"2020","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"
    • Developed a fully functional blog website using React.js for the frontend and Node.js/Express.js for the backend, featuring user authentication, dynamic content rendering, and CRUD operations for blog posts, achieving a 99.9% uptime and 100% API success rate.
    • Implemented a robust content management system (CMS) allowing users to create, edit, and publish blog posts with rich text formatting, image uploads, and SEO optimization, resulting in a 20% increase in user-generated content.
    • Integrated a responsive design framework, ensuring seamless user experience across various devices and screen sizes, leading to a 30% increase in mobile web traffic and improved overall engagement.
    ","githuburl":"","liveurl":"","name":"FullStack Blog Site"},{"description":"
    • Developed a Python-based Cold Email Sender application with features like personalized email composition, automated scheduling, and tracking, achieving a 20% increase in email open rates.
    • Implemented a robust email verification system to ensure deliverability and reduce bounce rates, resulting in a 15% decrease in undelivered emails.
    • Integrated with popular email marketing platforms like Mailchimp and SendGrid, allowing for seamless integration and enhanced campaign management, increasing email click-through rates by 10%.
    ","githuburl":"","liveurl":"","name":"Cold Email Sender"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mhRKC6j9TcoCGSqBfrE5xrFRWx"} +{"_creationTime":1727464933836.1113,"_id":"j577dp3fck1av8bwqd3p48h6z171k5xf","globalStyles":{"columns":2.0,"fontFamily":"Poppins","photo":false,"primaryColor":"#ebb5b5","primaryTextColor":"#9d161d"},"isTemplate":false,"sections":[{"content":{"email":"jankowalski@gmail.com","firstName":"Jan","github":"JanKowalski69","lastName":"Kowalski","linkedin":"linkedin.com/Jano666","phone":"+48 123 456 789","summary":"

    Bardzo fajnie lubie lody etc lololoo

    "},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"experience":[{"companyName":"Microsoft","endMonth":"","endYear":"Present","jobDescription":"

    i did there so much

    ","location":"New York","role":"Peanut Eater","startMonth":"Jan","startYear":"2024","workingHere":true}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mfPvdV0LAJkDOnZ5QYsAzougsK"} +{"_creationTime":1727647040839.4119,"_id":"j577kqamz0x5gwesbj046p1z7x71qexr","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"vinhwin1810@gmail.com","firstName":"Vinh","github":"","lastName":"Pham","linkedin":"","phone":"5189829436","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mlN6MPqRQQe48KPQKgeR3ix711"} +{"_creationTime":1727699704391.0244,"_id":"j5788gj1kcnfkyy84m98bwheqs71rtwm","globalStyles":{"columns":2.0,"fontFamily":"Raleway","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"vishal909781@gmail.com","firstName":"Vishal","github":"iamvkr","lastName":"Kumar","linkedin":"https://www.linkedin.com/in/vishal-kumar047","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    Version Control & Tools: Git, GitHub, GitLab, Postman

    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"

    Full Stack Shop management Project.

    Tech Stack

    • Frontend: React js
    • Tailwind css With Daisy ui
    • Backend: Node js Express
    • Database: MongoDB
    ","githuburl":"https://github.com/iamvkr/shop-inventory-management-MERN","liveurl":"","name":"Shop Inventory Management System -MERN"},{"description":"

    An eCommerce shopping project. Made with React.

    • React js
    • Redux Toolkit for state management
    • Tailwind css with Daisy UI Tailwind components
    ","githuburl":"https://github.com/iamvkr/cart-flix-reactjs","liveurl":"","name":"Cart Flix E-commerce React Js"},{"description":"

    A school website made with react js.

    Visit School Website. Made using javascript, HTML, CSS, React js and tailwind css

    ","githuburl":"https://github.com/iamvkr/school-website-project","liveurl":"https://iamvkr.github.io/school-website-project/","name":"School Website - React js"},{"description":"

    A Quote app, Explore quotes and create Quotes. Made with Node js and mongodb with authentication.

    • Express js Node js
    • Ejs
    • Mongoose
    ","githuburl":"https://github.com/iamvkr/quote-x","liveurl":"","name":"Quote X"}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"experience":[{"companyName":"Freelancer ","endMonth":"","endYear":"Present","jobDescription":"
    • Developed and maintained web applications using Reactjs, Nextjs ensuring a high level of performance and scalability.
    • Integrated front-end and back-end components seamlessly, delivering a unified and user-friendly experience.
    ","location":"Remote","role":"Full stack developer ","startMonth":"","startYear":"2023","workingHere":true}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"education":[{"courseName":"Master of computer Application","endMonth":"","endYear":"Present","grade":"7.8","instituteName":"Vinoba Bhave University Hazaribagh ","location":"Hazribagh, Jharkhand ","startMonth":"Oct","startYear":"2022","studyingHere":true},{"courseName":"Bachelor of computer Application","endMonth":"Oct","endYear":"2021","grade":"","instituteName":"Vinoba Bhave University Hazaribagh ","location":"Hazaribagh, Jharkhand ","startMonth":"Oct","startYear":"2018","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template2","userId":"user_2mn5pa3q0YU3BYkHNHOucHeiFlv"} +{"_creationTime":1727637634747.6304,"_id":"j578stcdbjej5dg4hw7x1m6rhs71qgyd","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2ml3uz7DuPO3HCS6mXdj1tu3JbW"} +{"_creationTime":1727684786279.126,"_id":"j57915pp2b9050ckw8ztp6m40n71sbgf","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mmbcRUYxnCiJkku0IxgrYLOvN7"} +{"_creationTime":1727719065418.8596,"_id":"j57a32b6hycp18twvagcyjc0kn71r3st","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#9d161d"},"isTemplate":false,"sections":[{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":0.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":3.0,"style":{},"type":"skills"},{"content":{"email":"worklikeakshay@gmail.com","firstName":"Akshay","github":"https://github.com/AkshayPratapSingh09","lastName":"Pratap Singh","linkedin":"https://www.linkedin.com/in/akshaypratap09/","phone":"9045304479"},"isVisible":true,"orderNumber":4.0,"style":{},"type":"header"}],"templateName":"Template2","userId":"user_2mnj51Qk7QTmbaPiDQ8BIRdLg3n"} +{"_creationTime":1727456283051.6255,"_id":"j57a7j6pv0x2qd0epz4941c3b171jxw9","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2me4Ag84YC4XLG3zpoA1Caxtcid"} +{"_creationTime":1727466709587.6462,"_id":"j57asjwn5xde80y6rgcgh41tz971jc80","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"Srivardhan","github":"","lastName":"Veeramalli","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"aaa","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mfTbQCDNKQktp9mkYZuifwrV4G"} +{"_creationTime":1727467623140.439,"_id":"j57c0pgpt1cgzy8fkya4pfqg6n71k5wc","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mfVSaKWBLuluUwafHRyqKhMlSp"} +{"_creationTime":1727527154025.5825,"_id":"j57cegdnxc5t6pjhwdt80msrcs71m401","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":"

    Frontend : JavaScript (ES6+),HTML5, CSS3, TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"wa","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mfPvdV0LAJkDOnZ5QYsAzougsK"} +{"_creationTime":1727461885635.5159,"_id":"j57cjyb9emcx7yfw4n7mmk0r5h71k5db","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"chandrasekharchadalawada7@gmail.com","firstName":"Chandrasekhar","github":"","lastName":"Chadalawada","linkedin":"","phone":"09553394020"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mfJmAqCc0eYjKPY2iCtasXYtZr"} +{"_creationTime":1727551605619.587,"_id":"j57cpr5wsva1syfze5p1s1amhn71mgxd","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2miFgArCN8w2jAZNmbIJnnbtzbF"} +{"_creationTime":1727567540231.9194,"_id":"j57cs2exq027n72pwrp1sdmjds71n183","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2milvvPrNQG22TGmk4Vul3lAC1n"} +{"_creationTime":1727805872452.2234,"_id":"j57d3ba8yz8fky01ragfkrfmx971vrsc","globalStyles":{"columns":2.0,"fontFamily":"Inter","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"work.devanshsk@gmail.com","firstName":"Devansh","github":"DevanshSK","lastName":"Singh Kushwah","linkedin":"https://www.linkedin.com/in/devanshsk/","phone":"8103008804"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"B.Tech in Infrormation Technology","endMonth":"","endYear":"Present","grade":"8.0","instituteName":"Institute of Technology and Management","location":"Gwalior, Madhya Pradesh","startMonth":"Oct","startYear":"2021","studyingHere":true}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"TechieShubDeep IT Solutions Pvt Ltd","endMonth":"Apr","endYear":"2023","jobDescription":"
    • Developed and launched 10+ web applications using MERN stack, achieving seamless user experiences and a 99.9% uptime for the real-time video conferencing platform.
    • Delivered 7+ high-performing mobile applications using Flutter, Dart, Android Studio, Java, and Firebase, resulting in smooth user experiences and increased engagement.
    • Engineered a cross-platform e-commerce app, leveraging Flutter, Dart, Django, and Python, leading to a 30% increase in user engagement through intuitive design and efficient functionality.
    ","location":"Gwalior, Madhya Pradesh","role":"Fullstack Web/App Developer","startMonth":"Nov","startYear":"2022","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"
    • Developed a modern, user-friendly web application using React, Next.js, Redux, RTK-Query, Cloudinary, Python, FastAPI, and PostgreSQL, resulting in a 20% improvement in page load times and a 15% increase in user engagement.
    • Implemented a robust backend using FastAPI and integrated it with the frontend through Redux and RTK Query, improving API response time by 20% and enhancing overall application performance.
    • Utilized Shadcn-UI and Tailwind CSS to create a visually appealing and consistent user interface, resulting in a 25% increase in user retention and a 30% reduction in unauthorized access through role-based authentication using JWT tokens.
    ","githuburl":"https://github.com/DevanshSK/add-learn","liveurl":"https://add-learn.vercel.app/","name":"ADD Learn"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mqYpQjIvgyANms9yU8gDERrbQR"} +{"_creationTime":1727865327934.768,"_id":"j57dvt2440s119v1qhzk1f6a1h71xet2","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2msVYCrmtV4JsymnpAg33GdH705"} +{"_creationTime":1727637633768.1616,"_id":"j57e5v33sxynkv0w0zt520t3t171q21g","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2ml3uz7DuPO3HCS6mXdj1tu3JbW"} +{"_creationTime":1727516865649.3936,"_id":"j57eb5yvrr8xsbb2y611d4ydxx71me1n","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":"","summary":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"description":""},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2mh7FsoZ3jjvD7uQOF2svMOZNQz"} +{"_creationTime":1727462961008.936,"_id":"j57emykcv2e9rkn5wxs6sxf2th71k2a3","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"zuberkhan034@gmail.com","firstName":"Zuber","github":"","lastName":"Khan","linkedin":"","phone":"8171584000"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"Present","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"WayRabbit","endMonth":"","endYear":"","jobDescription":"
    • Developed and maintained key components of WayRabbit's platform, resulting in a 15% increase in user engagement and a 10% reduction in support tickets.
    • Collaborated with cross-functional teams to design and implement new features, achieving a 98% on-time delivery rate for critical project milestones.
    • Utilized agile methodologies and continuous integration/continuous deployment practices, leading to a 20% reduction in development time and a 5% increase in code quality.
    ","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mfLyIEaIgxe6GBmOfQBGzB85GW"} +{"_creationTime":1727942863323.6228,"_id":"j57ewr0pbkjkz23zjbstyz8fgx71yzj4","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"ys30371@gmail.com","firstName":"Yogesh","github":"yogesh616","lastName":"Saini","linkedin":"https://www.linkedin.com/in/yogesh-saini-678563170/","phone":"6367365117","summary":"

    Passionate front-end developer with hands-on experience in HTML, CSS, JavaScript, and React, dedicated to creating responsive and user-centric web applications. Skilled in leveraging tools like Axios and Cheerio for efficient data management and web scraping in projects such as IntelliChat. Eager to embrace new technologies and continuously enhance my skill set, with a strong commitment to delivering innovative solutions and contributing to collaborative team environments.

    "},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"projects":[{"description":"
    •  Ripple is a dynamic social media web application designed to faster engagement and interaction among users.  
    •  User Authentication: Integrates Firebase for secure and streamlined user authentication.   
    •   Post Creation and Interaction: Allows users to create and share posts, comment on them, and engage in real-time conversations through integrated chat features. 
    • Responsive UI: Designed with Bootstrap for consistent and intuitive user experience across devices.
    ","githuburl":"https://github.com/yogesh616/Ripple","liveurl":"https://ripple-steel.vercel.app/","name":"Ripple | React, Firebase, Bootstrap"},{"description":"
    • IntelliChat is a web scraping tool designed to extract data from websites based on user prompts.
    •  Custom Web Scraping: Utilizes Node.js and Cheerio to scrape and collect data from multiple websites according to user-defined queries. 
    •  User-Friendly Interface: Built with React and Bootstrap for a responsive and intuitive interface.
    •  Data Readability: Future enhancements include AI integration to convert raw scraped data into more readable formats.
    ","githuburl":"https://github.com/yogesh616/IntelliChat","liveurl":"https://intelli-chat-two.vercel.app/","name":"IntelliChat | React, Node.js, Cheerio"},{"description":"
    • Syncy is a music streaming web app where users can search and listen to music, and add songs to their favorites. 
    •  Features: Search for songs, play music, and manage favorite tracks.
    •  Responsive Design: Built with Tailwind CSS for a smooth and visually appealing user experience across devices.
    ","githuburl":"https://github.com/yogesh616/Syncy","liveurl":"https://syncy.vercel.app/","name":"Syncy | React, Tailwind"}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), React.js, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid.

    Backend : Node.js, Express.js, REST APIs, Mongoose, Firebase, Cheerio.

    "},"isVisible":true,"orderNumber":2.0,"style":{},"type":"skills"},{"content":{"sectionDescription":"

    M.J.F. Sr. Sec. School Deeg, 12th PCM 71%

    ","sectionNumber":1.0,"sectionTitle":"EDUCATION"},"isVisible":true,"orderNumber":3.0,"type":"custom"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":5.0,"style":{},"type":"experience"}],"templateName":"Template1","userId":"user_2mv2idPITGQRh9Rih1ItJMYcLwC"} +{"_creationTime":1727578499619.3809,"_id":"j57ezwshczc2ftm9q3pswb653d71q0rz","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"","firstName":"","github":"","lastName":"","linkedin":"","phone":""},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"
    • Developed an E-learning platform utilizing React, Redux, and Node.js, facilitating online learning with interactive content, achieving a 20% increase in user engagement and a 15% reduction in course completion time.
    • Implemented a robust course management system with features like personalized learning paths, progress tracking, and interactive quizzes, resulting in a 10% improvement in student performance and a 5% increase in course completion rates.
    • Integrated a secure payment gateway and analytics dashboard, enabling seamless transactions and providing valuable insights into user behavior, leading to a 15% rise in revenue and a 20% increase in course enrollment.
    ","githuburl":"","liveurl":"","name":"E-learning"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mj89hARzHDse7AZ46xgEFAuazs"} +{"_creationTime":1727745292327.6963,"_id":"j57fff4sfzm064v7e1x479greh71vp8y","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"jatinsharma4586@gmail.com","firstName":"Jatin","github":"github.com/softartinc","lastName":"Sharma","linkedin":"https://www.linkedin.com/in/jatinsharma4586/","phone":"7906957815"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"","githuburl":"","liveurl":"","name":""}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":""},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2moaG05oJH5DtxJKPjsnLTrYlK9"} +{"_creationTime":1727493093777.6614,"_id":"j57fhk2nzcdmamk2bceba1yjed71nsve","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#000","primaryTextColor":"#000"},"isTemplate":false,"sections":[{"content":{"email":"majorvidosa@gmail.com","firstName":"Major","github":"AlanGacihi","lastName":"Vidosa","linkedin":"linkedin.com/alan-gacihi","phone":"+154112557830"},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"education":[{"courseName":"Software Engineering","endMonth":"Mar","endYear":"2023","grade":"86","instituteName":"ALX Holberton School","location":"Nairobi","startMonth":"Feb","startYear":"2022","studyingHere":false}]},"isVisible":true,"orderNumber":1.0,"style":{},"type":"education"},{"content":{"experience":[{"companyName":"Next Technologies","endMonth":"Aug","endYear":"2023","jobDescription":"
    • Streamlined software delivery processes by implementing CI/CD pipelines, leading to a 15% reduction in deployment time and a 20% increase in release frequency.
    • Collaborated with cross-functional teams to optimize development workflows, resulting in a 10% improvement in developer productivity and a 5% decrease in time to market.
    • Contributed to infrastructure design and deployment, ensuring high availability and scalability for critical applications, leading to a 99.9% uptime.
    ","location":"Nairobi, Kenya","role":"Systems Engineer","startMonth":"Jun","startYear":"2023","workingHere":false}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"experience"},{"content":{"projects":[{"description":"
    • Developed a Sudoku Solver application using Python, implementing backtracking algorithms to efficiently solve Sudoku puzzles of varying difficulty levels.
    • Utilized constraint satisfaction techniques to optimize the solver's performance, achieving a 95% success rate in solving complex Sudoku puzzles within a reasonable timeframe.
    • Implemented a user-friendly interface for puzzle input and solution display, enhancing user experience and allowing for easy interaction with the solver.
    ","githuburl":"https://github.com/AlanGacihi/SudokuSolver","liveurl":"","name":"SudokuSolver"}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"projects"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    "},"isVisible":true,"orderNumber":4.0,"style":{},"type":"skills"}],"templateName":"Template2","userId":"user_2mgKzWp5GUOmJggZMoinXCzSVo5"} +{"_creationTime":1727940490063.4783,"_id":"j57ft0kv6zmp5ndbpqemp9kt8n71z2qf","globalStyles":{"columns":2.0,"fontFamily":"Geologica","photo":false,"primaryColor":"#C026D3","primaryTextColor":"#C026D3"},"isTemplate":false,"sections":[{"content":{"email":"ys30371@gmail.com","firstName":"Yogesh","github":"yogesh616","lastName":"Saini","linkedin":"https://in.linkedin.com/in/yogesh-saini-678563170","phone":"6367365117","summary":"

    Passionate front-end developer with hands-on experience in HTML, CSS, JavaScript, and React, dedicated to creating responsive and user-centric web applications. Skilled in leveraging tools like Axios and Cheerio for efficient data management and web scraping in projects such as IntelliChat. Eager to embrace new technologies and continuously enhance my skill set, with a strong commitment to delivering innovative solutions and contributing to collaborative team environments.

    "},"isVisible":true,"orderNumber":0.0,"style":{},"type":"header"},{"content":{"experience":[{"companyName":"","endMonth":"","endYear":"","jobDescription":"","location":"","role":"","startMonth":"","startYear":"","workingHere":false}]},"isVisible":true,"orderNumber":3.0,"style":{},"type":"experience"},{"content":{"description":"

    Frontend : HTML5, CSS3, JavaScript (ES6+), React.js, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Mongoose, Firebase, Cheerio.


    "},"isVisible":true,"orderNumber":1.0,"style":{},"type":"skills"},{"content":{"projects":[{"description":"
    • Ripple is a dynamic social media web application designed to faster engagement and interaction among users.  
    • User Authentication: Integrates Firebase for secure and streamlined user authentication.  
    • Post Creation and Interaction: Allows users to create and share posts, comment on them, and engage in real-time conversations through integrated chat features.   - Responsive UI: Designed with Bootstrap for consistent and intuitive user experience across devices.
    ","githuburl":"https://github.com/yogesh616/Ripple","liveurl":"https://ripple-steel.vercel.app/","name":"Ripple"}]},"isVisible":true,"orderNumber":2.0,"style":{},"type":"projects"},{"content":{"education":[{"courseName":"","endMonth":"","endYear":"","grade":"","instituteName":"","location":"","startMonth":"","startYear":"","studyingHere":false}]},"isVisible":true,"orderNumber":4.0,"style":{},"type":"education"}],"templateName":"Template1","userId":"user_2muxrfMacIHWVZBxZBIMO0yWyto"} diff --git a/lib/font.ts b/lib/font.ts new file mode 100644 index 0000000..c46776c --- /dev/null +++ b/lib/font.ts @@ -0,0 +1,17 @@ +import { Inter, Montserrat, Open_Sans, Poppins, Raleway, Geologica } from 'next/font/google'; + +export type FontName = 'Inter' | 'Montserrat' | 'OpenSans' | 'Poppins' | 'Raleway' | 'Geologica'; + +export const interFont = Inter({ subsets: ["latin"] }); +export const montserratFont = Montserrat({ subsets: ["latin"] }); +export const openSansFont = Open_Sans({ subsets: ["latin"] }); +export const poppinsFont = Poppins({ + subsets: ["latin"], + weight: ["100", "200", "300", "400", "500", "600", "700", "800", "900"], +}); +export const ralewayFont = Raleway({ subsets: ["latin"] }); +export const geologicaFont = Geologica({ + subsets: ["latin"], + weight: ["100", "200", "300", "400", "500", "600", "700", "800", "900"], +}); + diff --git a/lib/migrateResumes.js b/lib/migrateResumes.js new file mode 100644 index 0000000..ef876b3 --- /dev/null +++ b/lib/migrateResumes.js @@ -0,0 +1,15 @@ +import { query } from "@/convex/_generated/server"; + +const migrateResumes = query({ + args: {}, + handler: async (ctx, args) => { + const resumes = await ctx.db + .query("resumes") + .filter((q) => q.eq(q.field("isTemplate"), true)) + .collect(); + + console.log(resumes); + }, +}); + +export { migrateResumes }; diff --git a/lib/motion.js b/lib/motion.js new file mode 100644 index 0000000..558caf7 --- /dev/null +++ b/lib/motion.js @@ -0,0 +1,15 @@ +export const container = { + hidden: { opacity: 0 }, + visible: { + opacity: 1, + transition: { + delayChildren: 0.3, + staggerChildren: 0.4, + }, + }, + }; + + export const item = { + hidden: { y: 20, opacity: 0 }, + visible: { y: 0, opacity: 1 }, + }; \ No newline at end of file diff --git a/lib/tipsData.tsx b/lib/tipsData.tsx new file mode 100644 index 0000000..49d413d --- /dev/null +++ b/lib/tipsData.tsx @@ -0,0 +1,64 @@ +interface TipsType { + sec: string; + topText: string; + mainText: string; + bottomMainText?: string; + bottomText?: string; +} + +export const tipsData: TipsType[] = [ + { + sec: "introduction", + topText: "Ready to begin?", + mainText: "Craft your standout resume", + bottomMainText: "Our AI-powered tools streamline the writing process!", + }, + { + sec: "header", + topText: "Welcome aboard! Let's dive in", + mainText: "Your journey to a stellar resume starts now", + bottomMainText: "Our intuitive tools will navigate you through each phase.", + bottomText: + "Begin with your core details, and let our AI assistant enhance your content along the way.", + }, + { + sec: "experience", + topText: "Excellent progress! Next stop → Work Experience", + mainText: "Showcase your professional journey", + bottomMainText: "Our AI simplifies the writing process!", + bottomText: + "Leverage our writing assistance to refine and tailor your experience descriptions for maximum impact.", + }, + { + sec: "education", + topText: "Well done! Moving on to → Education", + mainText: "Time to highlight your academic path", + bottomMainText: "Showcase your educational milestones!", + bottomText: + "Feature your degrees, certifications, and any standout academic achievements.", + }, + { + sec: "skills", + topText: "Fantastic progress! Next up → Skills", + mainText: "Let's spotlight your unique abilities", + bottomMainText: "Craft a skills section that truly stands out.", + bottomText: + "Utilize our curated suggestions to emphasize your strengths and boost your resume's visibility to potential employers.", + }, + { + sec: "projects", + topText: "Final stretch! Last stop → Projects", + mainText: "Showcase projects that define your expertise", + bottomMainText: + "Featuring projects demonstrates your hands-on experience.", + bottomText: + "Include personal, academic, or professional projects to illustrate your skills in real-world scenarios.", + }, + { + sec: "custom", + topText: "Tailor your resume with a custom section", + mainText: "Add any additional details to personalize your resume", + bottomMainText: "Whether it's achievements, hackathons, certifications, or any unique experience—make your resume truly yours.", + bottomText: "Highlight what sets you apart by adding specialized sections that showcase your unique qualifications." + } +]; \ No newline at end of file diff --git a/lib/use-preview.ts b/lib/use-preview.ts new file mode 100644 index 0000000..539db10 --- /dev/null +++ b/lib/use-preview.ts @@ -0,0 +1,18 @@ +import { ResumeTemplate } from '@/types/templateTypes'; +import {create} from 'zustand' + +type previewStore = { + isOpen : boolean; + currentTemplate: ResumeTemplate | null; + onOpen : (template : ResumeTemplate)=>void; + onClose: ()=>void; + toggle : ()=>void; +} + +export const usePreview = create((set,get)=>({ + isOpen: false, + currentTemplate : null, + onOpen: (template)=>set({isOpen : true,currentTemplate: template}), + onClose: ()=>set({isOpen : false,currentTemplate: null}), + toggle : ()=>set({isOpen: !get().isOpen}), +})) \ No newline at end of file diff --git a/lib/useMobile.tsx b/lib/useMobile.tsx new file mode 100644 index 0000000..bdeac71 --- /dev/null +++ b/lib/useMobile.tsx @@ -0,0 +1,22 @@ +"use client"; +import React, { useEffect, useState } from "react"; + +const useMobile = () => { + const [isMobile, setIsMobile] = useState(false); + + useEffect(() => { + const handleResize = () => { + setIsMobile(window.innerWidth < 768); + }; + + handleResize(); + + window.addEventListener("resize", handleResize); + + return () => window.removeEventListener("resize", handleResize); + }, []); + + return isMobile; +}; + +export default useMobile; diff --git a/lib/utils.ts b/lib/utils.ts new file mode 100644 index 0000000..d084cca --- /dev/null +++ b/lib/utils.ts @@ -0,0 +1,6 @@ +import { type ClassValue, clsx } from "clsx" +import { twMerge } from "tailwind-merge" + +export function cn(...inputs: ClassValue[]) { + return twMerge(clsx(inputs)) +} diff --git a/next.config.mjs b/next.config.mjs new file mode 100644 index 0000000..4678774 --- /dev/null +++ b/next.config.mjs @@ -0,0 +1,4 @@ +/** @type {import('next').NextConfig} */ +const nextConfig = {}; + +export default nextConfig; diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..4426a1b --- /dev/null +++ b/package-lock.json @@ -0,0 +1,8834 @@ +{ + "name": "resume-craft", + "version": "0.1.0", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "resume-craft", + "version": "0.1.0", + "dependencies": { + "@clerk/nextjs": "^5.1.6", + "@google/generative-ai": "^0.14.0", + "@radix-ui/react-checkbox": "^1.1.1", + "@radix-ui/react-dialog": "^1.1.1", + "@radix-ui/react-label": "^2.1.0", + "@radix-ui/react-select": "^2.1.1", + "@radix-ui/react-slot": "^1.1.0", + "@radix-ui/react-tabs": "^1.1.0", + "@radix-ui/react-tooltip": "^1.1.1", + "@types/lodash": "^4.17.5", + "@vercel/analytics": "^1.3.1", + "@vercel/speed-insights": "^1.0.12", + "array-move": "^4.0.0", + "axios": "^1.7.2", + "class-variance-authority": "^0.7.0", + "clsx": "^2.1.1", + "convex": "^1.12.2", + "framer-motion": "^11.2.12", + "fs": "^0.0.1-security", + "lodash": "^4.17.21", + "lucide-react": "^0.396.0", + "next": "^14.2.4", + "nextjs-toploader": "^3.7.15", + "nprogress": "^0.2.0", + "quill": "^2.0.2", + "react": "^18", + "react-color-palette": "^7.1.1", + "react-color-pallete": "^1.0.1", + "react-date-picker": "^11.0.0", + "react-dom": "^18", + "react-easy-sort": "^1.6.0", + "react-hot-toast": "^2.4.1", + "react-quill": "^2.0.0", + "tailwind-merge": "^2.3.0", + "tailwindcss-animate": "^1.0.7", + "zustand": "^4.5.4" + }, + "devDependencies": { + "@types/node": "^20", + "@types/nprogress": "^0.2.3", + "@types/react": "^18", + "@types/react-dom": "^18", + "eslint": "^8", + "eslint-config-next": "14.2.4", + "ignore-loader": "^0.1.2", + "postcss": "^8", + "puppeteer": "^22.12.1", + "tailwindcss": "^3.4.1", + "typescript": "^5" + } + }, + "node_modules/@alloc/quick-lru": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@alloc/quick-lru/-/quick-lru-5.2.0.tgz", + "integrity": "sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@babel/code-frame": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/highlight": "^7.24.7", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/helper-validator-identifier": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/helper-validator-identifier": "^7.24.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@babel/highlight/node_modules/ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-convert": "^1.9.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "dev": true, + "license": "MIT", + "dependencies": { + "color-name": "1.1.3" + } + }, + "node_modules/@babel/highlight/node_modules/color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==", + "dev": true, + "license": "MIT" + }, + "node_modules/@babel/highlight/node_modules/escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.0" + } + }, + "node_modules/@babel/highlight/node_modules/has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/highlight/node_modules/supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^3.0.0" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/@babel/runtime": { + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.7.tgz", + "integrity": "sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw==", + "license": "MIT", + "dependencies": { + "regenerator-runtime": "^0.14.0" + }, + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@clerk/backend": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/@clerk/backend/-/backend-1.2.4.tgz", + "integrity": "sha512-H6K1kHPaDFM6pBdwDAHh1jWSZxCWhGPzDmqgc7LByjqKS6RZUf3cs5mJkIXyopUpHY7wvwj50vSF0xJ46MEzNA==", + "license": "MIT", + "dependencies": { + "@clerk/shared": "2.3.1", + "@clerk/types": "4.6.1", + "cookie": "0.5.0", + "snakecase-keys": "5.4.4", + "tslib": "2.4.1" + }, + "engines": { + "node": ">=18.17.0" + } + }, + "node_modules/@clerk/backend/node_modules/tslib": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", + "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==", + "license": "0BSD" + }, + "node_modules/@clerk/clerk-react": { + "version": "5.2.5", + "resolved": "https://registry.npmjs.org/@clerk/clerk-react/-/clerk-react-5.2.5.tgz", + "integrity": "sha512-Ihf1t2LdWTagW3U5BH5KRwQ8i+ECaZGEUymhJ89eZA+Ux5iXwLfOIBdwCIs45gbVuFiQ8WK0W00eaDgsNaf1mw==", + "license": "MIT", + "dependencies": { + "@clerk/shared": "2.3.1", + "@clerk/types": "4.6.1", + "tslib": "2.4.1" + }, + "engines": { + "node": ">=18.17.0" + }, + "peerDependencies": { + "react": ">=18 || >=19.0.0-beta", + "react-dom": ">=18 || >=19.0.0-beta" + } + }, + "node_modules/@clerk/clerk-react/node_modules/tslib": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", + "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==", + "license": "0BSD" + }, + "node_modules/@clerk/nextjs": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/@clerk/nextjs/-/nextjs-5.1.6.tgz", + "integrity": "sha512-HAxDzvVJ6EM99NbxNYOvMfGSSFEXyz+yPo1ER7RoV95sTH61PZ4ugsg+Ml0AhjQ60j3xUU/BPhQEYogGxvQzEA==", + "license": "MIT", + "dependencies": { + "@clerk/backend": "1.2.4", + "@clerk/clerk-react": "5.2.5", + "@clerk/shared": "2.3.1", + "@clerk/types": "4.6.1", + "crypto-js": "4.2.0", + "path-to-regexp": "6.2.2", + "tslib": "2.4.1" + }, + "engines": { + "node": ">=18.17.0" + }, + "peerDependencies": { + "next": "^13.5.4 || ^14.0.3 || >=15.0.0-rc", + "react": ">=18 || >=19.0.0-beta", + "react-dom": ">=18 || >=19.0.0-beta" + } + }, + "node_modules/@clerk/nextjs/node_modules/tslib": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", + "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==", + "license": "0BSD" + }, + "node_modules/@clerk/shared": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/@clerk/shared/-/shared-2.3.1.tgz", + "integrity": "sha512-WX7cCViYqkNMnbFfT2B93ykNcSseoYM1obMUynO60VBl9Zi6Epde5tn9VRamhuOdojgPR+DyYkH9AzBpXFYnSg==", + "hasInstallScript": true, + "license": "MIT", + "dependencies": { + "@clerk/types": "4.6.1", + "glob-to-regexp": "0.4.1", + "js-cookie": "3.0.5", + "std-env": "^3.7.0", + "swr": "^2.2.0" + }, + "engines": { + "node": ">=18.17.0" + }, + "peerDependencies": { + "react": ">=18 || >=19.0.0-beta", + "react-dom": ">=18 || >=19.0.0-beta" + }, + "peerDependenciesMeta": { + "react": { + "optional": true + }, + "react-dom": { + "optional": true + } + } + }, + "node_modules/@clerk/types": { + "version": "4.6.1", + "resolved": "https://registry.npmjs.org/@clerk/types/-/types-4.6.1.tgz", + "integrity": "sha512-QFeNKPYDmTJ88l5QYG0SPwbABk42wRMalW3M/wAtr+wnQxBCXyX2XRZe9h4g2rH1VF+wG4Xe56abeeD+xE4iEw==", + "license": "MIT", + "dependencies": { + "csstype": "3.1.1" + }, + "engines": { + "node": ">=18.17.0" + } + }, + "node_modules/@clerk/types/node_modules/csstype": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", + "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==", + "license": "MIT" + }, + "node_modules/@esbuild/android-arm": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", + "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", + "cpu": [ + "arm" + ], + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", + "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/android-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", + "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", + "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/darwin-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", + "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", + "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/freebsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", + "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", + "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", + "cpu": [ + "arm" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", + "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ia32": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", + "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", + "cpu": [ + "ia32" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-loong64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", + "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", + "cpu": [ + "loong64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-mips64el": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", + "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", + "cpu": [ + "mips64el" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-ppc64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", + "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", + "cpu": [ + "ppc64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-riscv64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", + "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", + "cpu": [ + "riscv64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-s390x": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", + "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", + "cpu": [ + "s390x" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/linux-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", + "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/netbsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", + "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/openbsd-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", + "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/sunos-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", + "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-arm64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", + "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-ia32": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", + "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", + "cpu": [ + "ia32" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@esbuild/win32-x64": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", + "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@eslint-community/eslint-utils": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz", + "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==", + "dev": true, + "license": "MIT", + "dependencies": { + "eslint-visitor-keys": "^3.3.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "peerDependencies": { + "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0" + } + }, + "node_modules/@eslint-community/regexpp": { + "version": "4.10.1", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.10.1.tgz", + "integrity": "sha512-Zm2NGpWELsQAD1xsJzGQpYfvICSsFkEpU0jxBjfdC6uNEWXcHnfs9hScFWtXVDVl+rBQJGrl4g1vcKIejpH9dA==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.0.0 || ^14.0.0 || >=16.0.0" + } + }, + "node_modules/@eslint/eslintrc": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-2.1.4.tgz", + "integrity": "sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ajv": "^6.12.4", + "debug": "^4.3.2", + "espree": "^9.6.0", + "globals": "^13.19.0", + "ignore": "^5.2.0", + "import-fresh": "^3.2.1", + "js-yaml": "^4.1.0", + "minimatch": "^3.1.2", + "strip-json-comments": "^3.1.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/@eslint/js": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", + "integrity": "sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + } + }, + "node_modules/@floating-ui/core": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/@floating-ui/core/-/core-1.6.2.tgz", + "integrity": "sha512-+2XpQV9LLZeanU4ZevzRnGFg2neDeKHgFLjP6YLW+tly0IvrhqT4u8enLGjLH3qeh85g19xY5rsAusfwTdn5lg==", + "license": "MIT", + "dependencies": { + "@floating-ui/utils": "^0.2.0" + } + }, + "node_modules/@floating-ui/dom": { + "version": "1.6.5", + "resolved": "https://registry.npmjs.org/@floating-ui/dom/-/dom-1.6.5.tgz", + "integrity": "sha512-Nsdud2X65Dz+1RHjAIP0t8z5e2ff/IRbei6BqFrl1urT8sDVzM1HMQ+R0XcU5ceRfyO3I6ayeqIfh+6Wb8LGTw==", + "license": "MIT", + "dependencies": { + "@floating-ui/core": "^1.0.0", + "@floating-ui/utils": "^0.2.0" + } + }, + "node_modules/@floating-ui/react-dom": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@floating-ui/react-dom/-/react-dom-2.1.0.tgz", + "integrity": "sha512-lNzj5EQmEKn5FFKc04+zasr09h/uX8RtJRNj5gUXsSQIXHVWTVh+hVAg1vOMCexkX8EgvemMvIFpQfkosnVNyA==", + "license": "MIT", + "dependencies": { + "@floating-ui/dom": "^1.0.0" + }, + "peerDependencies": { + "react": ">=16.8.0", + "react-dom": ">=16.8.0" + } + }, + "node_modules/@floating-ui/utils": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@floating-ui/utils/-/utils-0.2.2.tgz", + "integrity": "sha512-J4yDIIthosAsRZ5CPYP/jQvUAQtlZTTD/4suA08/FEnlxqW3sKS9iAhgsa9VYLZ6vDHn/ixJgIqRQPotoBjxIw==", + "license": "MIT" + }, + "node_modules/@google/generative-ai": { + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@google/generative-ai/-/generative-ai-0.14.0.tgz", + "integrity": "sha512-wNgIGEpInlVd98SapqvnQX8HQz0zM43U9NMvrbIMKQzz2pQm60pJTeHHlICTDcy/yZNLsvFQ/RfD+Ck9H8K7vw==", + "license": "Apache-2.0", + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@humanwhocodes/config-array": { + "version": "0.11.14", + "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.14.tgz", + "integrity": "sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==", + "deprecated": "Use @eslint/config-array instead", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@humanwhocodes/object-schema": "^2.0.2", + "debug": "^4.3.1", + "minimatch": "^3.0.5" + }, + "engines": { + "node": ">=10.10.0" + } + }, + "node_modules/@humanwhocodes/module-importer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", + "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">=12.22" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/nzakas" + } + }, + "node_modules/@humanwhocodes/object-schema": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", + "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", + "deprecated": "Use @eslint/object-schema instead", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/@isaacs/cliui": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", + "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==", + "license": "ISC", + "dependencies": { + "string-width": "^5.1.2", + "string-width-cjs": "npm:string-width@^4.2.0", + "strip-ansi": "^7.0.1", + "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", + "wrap-ansi": "^8.1.0", + "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/@isaacs/cliui/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/@isaacs/cliui/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "license": "MIT", + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.4.15", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", + "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", + "license": "MIT" + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "license": "MIT", + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@next/env": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/env/-/env-14.2.4.tgz", + "integrity": "sha512-3EtkY5VDkuV2+lNmKlbkibIJxcO4oIHEhBWne6PaAp+76J9KoSsGvNikp6ivzAT8dhhBMYrm6op2pS1ApG0Hzg==", + "license": "MIT" + }, + "node_modules/@next/eslint-plugin-next": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/eslint-plugin-next/-/eslint-plugin-next-14.2.4.tgz", + "integrity": "sha512-svSFxW9f3xDaZA3idQmlFw7SusOuWTpDTAeBlO3AEPDltrraV+lqs7mAc6A27YdnpQVVIA3sODqUAAHdWhVWsA==", + "dev": true, + "license": "MIT", + "dependencies": { + "glob": "10.3.10" + } + }, + "node_modules/@next/swc-darwin-arm64": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.4.tgz", + "integrity": "sha512-AH3mO4JlFUqsYcwFUHb1wAKlebHU/Hv2u2kb1pAuRanDZ7pD/A/KPD98RHZmwsJpdHQwfEc/06mgpSzwrJYnNg==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-darwin-x64": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.4.tgz", + "integrity": "sha512-QVadW73sWIO6E2VroyUjuAxhWLZWEpiFqHdZdoQ/AMpN9YWGuHV8t2rChr0ahy+irKX5mlDU7OY68k3n4tAZTg==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-linux-arm64-gnu": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.4.tgz", + "integrity": "sha512-KT6GUrb3oyCfcfJ+WliXuJnD6pCpZiosx2X3k66HLR+DMoilRb76LpWPGb4tZprawTtcnyrv75ElD6VncVamUQ==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-linux-arm64-musl": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.4.tgz", + "integrity": "sha512-Alv8/XGSs/ytwQcbCHwze1HmiIkIVhDHYLjczSVrf0Wi2MvKn/blt7+S6FJitj3yTlMwMxII1gIJ9WepI4aZ/A==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-linux-x64-gnu": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.4.tgz", + "integrity": "sha512-ze0ShQDBPCqxLImzw4sCdfnB3lRmN3qGMB2GWDRlq5Wqy4G36pxtNOo2usu/Nm9+V2Rh/QQnrRc2l94kYFXO6Q==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-linux-x64-musl": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.4.tgz", + "integrity": "sha512-8dwC0UJoc6fC7PX70csdaznVMNr16hQrTDAMPvLPloazlcaWfdPogq+UpZX6Drqb1OBlwowz8iG7WR0Tzk/diQ==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-win32-arm64-msvc": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.4.tgz", + "integrity": "sha512-jxyg67NbEWkDyvM+O8UDbPAyYRZqGLQDTPwvrBBeOSyVWW/jFQkQKQ70JDqDSYg1ZDdl+E3nkbFbq8xM8E9x8A==", + "cpu": [ + "arm64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-win32-ia32-msvc": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.4.tgz", + "integrity": "sha512-twrmN753hjXRdcrZmZttb/m5xaCBFa48Dt3FbeEItpJArxriYDunWxJn+QFXdJ3hPkm4u7CKxncVvnmgQMY1ag==", + "cpu": [ + "ia32" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@next/swc-win32-x64-msvc": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.4.tgz", + "integrity": "sha512-tkLrjBzqFTP8DVrAAQmZelEahfR9OxWpFR++vAI9FBhCiIxtwHwBHC23SBHCTURBtwB4kc/x44imVOnkKGNVGg==", + "cpu": [ + "x64" + ], + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">= 10" + } + }, + "node_modules/@nodelib/fs.scandir": { + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", + "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", + "license": "MIT", + "dependencies": { + "@nodelib/fs.stat": "2.0.5", + "run-parallel": "^1.1.9" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.stat": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", + "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", + "license": "MIT", + "engines": { + "node": ">= 8" + } + }, + "node_modules/@nodelib/fs.walk": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", + "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", + "license": "MIT", + "dependencies": { + "@nodelib/fs.scandir": "2.1.5", + "fastq": "^1.6.0" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/@pkgjs/parseargs": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", + "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==", + "license": "MIT", + "optional": true, + "engines": { + "node": ">=14" + } + }, + "node_modules/@puppeteer/browsers": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/@puppeteer/browsers/-/browsers-2.2.3.tgz", + "integrity": "sha512-bJ0UBsk0ESOs6RFcLXOt99a3yTDcOKlzfjad+rhFwdaG1Lu/Wzq58GHYCDTlZ9z6mldf4g+NTb+TXEfe0PpnsQ==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "debug": "4.3.4", + "extract-zip": "2.0.1", + "progress": "2.0.3", + "proxy-agent": "6.4.0", + "semver": "7.6.0", + "tar-fs": "3.0.5", + "unbzip2-stream": "1.4.3", + "yargs": "17.7.2" + }, + "bin": { + "browsers": "lib/cjs/main-cli.js" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@puppeteer/browsers/node_modules/debug": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", + "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/@puppeteer/browsers/node_modules/lru-cache": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", + "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "dev": true, + "license": "ISC", + "dependencies": { + "yallist": "^4.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/@puppeteer/browsers/node_modules/semver": { + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", + "dev": true, + "license": "ISC", + "dependencies": { + "lru-cache": "^6.0.0" + }, + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/@radix-ui/number": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/number/-/number-1.1.0.tgz", + "integrity": "sha512-V3gRzhVNU1ldS5XhAPTom1fOIo4ccrjjJgmE+LI2h/WaFpHmx0MQApT+KZHnx8abG6Avtfcz4WoEciMnpFT3HQ==", + "license": "MIT" + }, + "node_modules/@radix-ui/primitive": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/primitive/-/primitive-1.1.0.tgz", + "integrity": "sha512-4Z8dn6Upk0qk4P74xBhZ6Hd/w0mPEzOOLxy4xiPXOXqjF7jZS0VAKk7/x/H6FyY2zCkYJqePf1G5KmkmNJ4RBA==", + "license": "MIT" + }, + "node_modules/@radix-ui/react-arrow": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-arrow/-/react-arrow-1.1.0.tgz", + "integrity": "sha512-FmlW1rCg7hBpEBwFbjHwCW6AmWLQM6g/v0Sn8XbP9NvmSZ2San1FpQeyPtufzOMSIx7Y4dzjlHoifhp+7NkZhw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-primitive": "2.0.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-checkbox": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@radix-ui/react-checkbox/-/react-checkbox-1.1.1.tgz", + "integrity": "sha512-0i/EKJ222Afa1FE0C6pNJxDq1itzcl3HChE9DwskA4th4KRse8ojx8a1nVcOjwJdbpDLcz7uol77yYnQNMHdKw==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-presence": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-controllable-state": "1.1.0", + "@radix-ui/react-use-previous": "1.1.0", + "@radix-ui/react-use-size": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-collection": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-collection/-/react-collection-1.1.0.tgz", + "integrity": "sha512-GZsZslMJEyo1VKm5L1ZJY8tGDxZNPAoUeQUIbKeJfoi7Q4kmig5AsgLMYYuyYbfjd8fBmFORAIwYAkXMnXZgZw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-slot": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-compose-refs": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-compose-refs/-/react-compose-refs-1.1.0.tgz", + "integrity": "sha512-b4inOtiaOnYf9KWyO3jAeeCG6FeyfY6ldiEPanbUjWd+xIk5wZeHa8yVwmrJ2vderhu/BQvzCrJI0lHd+wIiqw==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-context": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-context/-/react-context-1.1.0.tgz", + "integrity": "sha512-OKrckBy+sMEgYM/sMmqmErVn0kZqrHPJze+Ql3DzYsDDp0hl0L62nx/2122/Bvps1qz645jlcu2tD9lrRSdf8A==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-dialog": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@radix-ui/react-dialog/-/react-dialog-1.1.1.tgz", + "integrity": "sha512-zysS+iU4YP3STKNS6USvFVqI4qqx8EpiwmT5TuCApVEBca+eRCbONi4EgzfNSuVnOXvC5UPHHMjs8RXO6DH9Bg==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-dismissable-layer": "1.1.0", + "@radix-ui/react-focus-guards": "1.1.0", + "@radix-ui/react-focus-scope": "1.1.0", + "@radix-ui/react-id": "1.1.0", + "@radix-ui/react-portal": "1.1.1", + "@radix-ui/react-presence": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-slot": "1.1.0", + "@radix-ui/react-use-controllable-state": "1.1.0", + "aria-hidden": "^1.1.1", + "react-remove-scroll": "2.5.7" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-direction": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-direction/-/react-direction-1.1.0.tgz", + "integrity": "sha512-BUuBvgThEiAXh2DWu93XsT+a3aWrGqolGlqqw5VU1kG7p/ZH2cuDlM1sRLNnY3QcBS69UIz2mcKhMxDsdewhjg==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-dismissable-layer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-dismissable-layer/-/react-dismissable-layer-1.1.0.tgz", + "integrity": "sha512-/UovfmmXGptwGcBQawLzvn2jOfM0t4z3/uKffoBlj724+n3FvBbZ7M0aaBOmkp6pqFYpO4yx8tSVJjx3Fl2jig==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-callback-ref": "1.1.0", + "@radix-ui/react-use-escape-keydown": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-focus-guards": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-focus-guards/-/react-focus-guards-1.1.0.tgz", + "integrity": "sha512-w6XZNUPVv6xCpZUqb/yN9DL6auvpGX3C/ee6Hdi16v2UUy25HV2Q5bcflsiDyT/g5RwbPQ/GIT1vLkeRb+ITBw==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-focus-scope": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-focus-scope/-/react-focus-scope-1.1.0.tgz", + "integrity": "sha512-200UD8zylvEyL8Bx+z76RJnASR2gRMuxlgFCPAe/Q/679a/r0eK3MBVYMb7vZODZcffZBdob1EGnky78xmVvcA==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-callback-ref": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-id": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-id/-/react-id-1.1.0.tgz", + "integrity": "sha512-EJUrI8yYh7WOjNOqpoJaf1jlFIH2LvtgAl+YcFqNCa+4hj64ZXmPkAKOFs/ukjz3byN6bdb/AVUqHkI8/uWWMA==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-use-layout-effect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-label": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-label/-/react-label-2.1.0.tgz", + "integrity": "sha512-peLblDlFw/ngk3UWq0VnYaOLy6agTZZ+MUO/WhVfm14vJGML+xH4FAl2XQGLqdefjNb7ApRg6Yn7U42ZhmYXdw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-primitive": "2.0.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-popper": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-popper/-/react-popper-1.2.0.tgz", + "integrity": "sha512-ZnRMshKF43aBxVWPWvbj21+7TQCvhuULWJ4gNIKYpRlQt5xGRhLx66tMp8pya2UkGHTSlhpXwmjqltDYHhw7Vg==", + "license": "MIT", + "dependencies": { + "@floating-ui/react-dom": "^2.0.0", + "@radix-ui/react-arrow": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-callback-ref": "1.1.0", + "@radix-ui/react-use-layout-effect": "1.1.0", + "@radix-ui/react-use-rect": "1.1.0", + "@radix-ui/react-use-size": "1.1.0", + "@radix-ui/rect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-portal": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@radix-ui/react-portal/-/react-portal-1.1.1.tgz", + "integrity": "sha512-A3UtLk85UtqhzFqtoC8Q0KvR2GbXF3mtPgACSazajqq6A41mEQgo53iPzY4i6BwDxlIFqWIhiQ2G729n+2aw/g==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-layout-effect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-presence": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-presence/-/react-presence-1.1.0.tgz", + "integrity": "sha512-Gq6wuRN/asf9H/E/VzdKoUtT8GC9PQc9z40/vEr0VCJ4u5XvvhWIrSsCB6vD2/cH7ugTdSfYq9fLJCcM00acrQ==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-use-layout-effect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-primitive": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-primitive/-/react-primitive-2.0.0.tgz", + "integrity": "sha512-ZSpFm0/uHa8zTvKBDjLFWLo8dkr4MBsiDLz0g3gMUwqgLHz9rTaRRGYDgvZPtBJgYCBKXkS9fzmoySgr8CO6Cw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-slot": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-roving-focus": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-roving-focus/-/react-roving-focus-1.1.0.tgz", + "integrity": "sha512-EA6AMGeq9AEeQDeSH0aZgG198qkfHSbvWTf1HvoDmOB5bBG/qTxjYMWUKMnYiV6J/iP/J8MEFSuB2zRU2n7ODA==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-collection": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-direction": "1.1.0", + "@radix-ui/react-id": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-use-callback-ref": "1.1.0", + "@radix-ui/react-use-controllable-state": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-select": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/@radix-ui/react-select/-/react-select-2.1.1.tgz", + "integrity": "sha512-8iRDfyLtzxlprOo9IicnzvpsO1wNCkuwzzCM+Z5Rb5tNOpCdMvcc2AkzX0Fz+Tz9v6NJ5B/7EEgyZveo4FBRfQ==", + "license": "MIT", + "dependencies": { + "@radix-ui/number": "1.1.0", + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-collection": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-direction": "1.1.0", + "@radix-ui/react-dismissable-layer": "1.1.0", + "@radix-ui/react-focus-guards": "1.1.0", + "@radix-ui/react-focus-scope": "1.1.0", + "@radix-ui/react-id": "1.1.0", + "@radix-ui/react-popper": "1.2.0", + "@radix-ui/react-portal": "1.1.1", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-slot": "1.1.0", + "@radix-ui/react-use-callback-ref": "1.1.0", + "@radix-ui/react-use-controllable-state": "1.1.0", + "@radix-ui/react-use-layout-effect": "1.1.0", + "@radix-ui/react-use-previous": "1.1.0", + "@radix-ui/react-visually-hidden": "1.1.0", + "aria-hidden": "^1.1.1", + "react-remove-scroll": "2.5.7" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-slot": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-slot/-/react-slot-1.1.0.tgz", + "integrity": "sha512-FUCf5XMfmW4dtYl69pdS4DbxKy8nj4M7SafBgPllysxmdachynNflAdp/gCsnYWNDnge6tI9onzMp5ARYc1KNw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-compose-refs": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-tabs": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-tabs/-/react-tabs-1.1.0.tgz", + "integrity": "sha512-bZgOKB/LtZIij75FSuPzyEti/XBhJH52ExgtdVqjCIh+Nx/FW+LhnbXtbCzIi34ccyMsyOja8T0thCzoHFXNKA==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-direction": "1.1.0", + "@radix-ui/react-id": "1.1.0", + "@radix-ui/react-presence": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-roving-focus": "1.1.0", + "@radix-ui/react-use-controllable-state": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-tooltip": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@radix-ui/react-tooltip/-/react-tooltip-1.1.1.tgz", + "integrity": "sha512-LLE8nzNE4MzPMw3O2zlVlkLFid3y9hMUs7uCbSHyKSo+tCN4yMCf+ZCCcfrYgsOC0TiHBPQ1mtpJ2liY3ZT3SQ==", + "license": "MIT", + "dependencies": { + "@radix-ui/primitive": "1.1.0", + "@radix-ui/react-compose-refs": "1.1.0", + "@radix-ui/react-context": "1.1.0", + "@radix-ui/react-dismissable-layer": "1.1.0", + "@radix-ui/react-id": "1.1.0", + "@radix-ui/react-popper": "1.2.0", + "@radix-ui/react-portal": "1.1.1", + "@radix-ui/react-presence": "1.1.0", + "@radix-ui/react-primitive": "2.0.0", + "@radix-ui/react-slot": "1.1.0", + "@radix-ui/react-use-controllable-state": "1.1.0", + "@radix-ui/react-visually-hidden": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-callback-ref": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-callback-ref/-/react-use-callback-ref-1.1.0.tgz", + "integrity": "sha512-CasTfvsy+frcFkbXtSJ2Zu9JHpN8TYKxkgJGWbjiZhFivxaeW7rMeZt7QELGVLaYVfFMsKHjb7Ak0nMEe+2Vfw==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-controllable-state": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-controllable-state/-/react-use-controllable-state-1.1.0.tgz", + "integrity": "sha512-MtfMVJiSr2NjzS0Aa90NPTnvTSg6C/JLCV7ma0W6+OMV78vd8OyRpID+Ng9LxzsPbLeuBnWBA1Nq30AtBIDChw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-use-callback-ref": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-escape-keydown": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-escape-keydown/-/react-use-escape-keydown-1.1.0.tgz", + "integrity": "sha512-L7vwWlR1kTTQ3oh7g1O0CBF3YCyyTj8NmhLR+phShpyA50HCfBFKVJTpshm9PzLiKmehsrQzTYTpX9HvmC9rhw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-use-callback-ref": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-layout-effect": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-layout-effect/-/react-use-layout-effect-1.1.0.tgz", + "integrity": "sha512-+FPE0rOdziWSrH9athwI1R0HDVbWlEhd+FR+aSDk4uWGmSJ9Z54sdZVDQPZAinJhJXwfT+qnj969mCsT2gfm5w==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-previous": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-previous/-/react-use-previous-1.1.0.tgz", + "integrity": "sha512-Z/e78qg2YFnnXcW88A4JmTtm4ADckLno6F7OXotmkQfeuCVaKuYzqAATPhVzl3delXE7CxIV8shofPn3jPc5Og==", + "license": "MIT", + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-rect": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-rect/-/react-use-rect-1.1.0.tgz", + "integrity": "sha512-0Fmkebhr6PiseyZlYAOtLS+nb7jLmpqTrJyv61Pe68MKYW6OWdRE2kI70TaYY27u7H0lajqM3hSMMLFq18Z7nQ==", + "license": "MIT", + "dependencies": { + "@radix-ui/rect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-use-size": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-use-size/-/react-use-size-1.1.0.tgz", + "integrity": "sha512-XW3/vWuIXHa+2Uwcc2ABSfcCledmXhhQPlGbfcRXbiUQI5Icjcg19BGCZVKKInYbvUCut/ufbbLLPFC5cbb1hw==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-use-layout-effect": "1.1.0" + }, + "peerDependencies": { + "@types/react": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/@radix-ui/react-visually-hidden": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/react-visually-hidden/-/react-visually-hidden-1.1.0.tgz", + "integrity": "sha512-N8MDZqtgCgG5S3aV60INAB475osJousYpZ4cTJ2cFbMpdHS5Y6loLTH8LPtkj2QN0x93J30HT/M3qJXM0+lyeQ==", + "license": "MIT", + "dependencies": { + "@radix-ui/react-primitive": "2.0.0" + }, + "peerDependencies": { + "@types/react": "*", + "@types/react-dom": "*", + "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc", + "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/@radix-ui/rect": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@radix-ui/rect/-/rect-1.1.0.tgz", + "integrity": "sha512-A9+lCBZoaMJlVKcRBz2YByCG+Cp2t6nAnMnNba+XiWxnj6r4JUFqfsgwocMBZU9LPtdxC6wB56ySYpc7LQIoJg==", + "license": "MIT" + }, + "node_modules/@rushstack/eslint-patch": { + "version": "1.10.3", + "resolved": "https://registry.npmjs.org/@rushstack/eslint-patch/-/eslint-patch-1.10.3.tgz", + "integrity": "sha512-qC/xYId4NMebE6w/V33Fh9gWxLgURiNYgVNObbJl2LZv0GUUItCcCqC5axQSwRaAgaxl2mELq1rMzlswaQ0Zxg==", + "dev": true, + "license": "MIT" + }, + "node_modules/@swc/counter": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@swc/counter/-/counter-0.1.3.tgz", + "integrity": "sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ==", + "license": "Apache-2.0" + }, + "node_modules/@swc/helpers": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/@swc/helpers/-/helpers-0.5.5.tgz", + "integrity": "sha512-KGYxvIOXcceOAbEk4bi/dVLEK9z8sZ0uBB3Il5b1rhfClSpcX0yfRO0KmTkqR2cnQDymwLB+25ZyMzICg/cm/A==", + "license": "Apache-2.0", + "dependencies": { + "@swc/counter": "^0.1.3", + "tslib": "^2.4.0" + } + }, + "node_modules/@tootallnate/quickjs-emscripten": { + "version": "0.23.0", + "resolved": "https://registry.npmjs.org/@tootallnate/quickjs-emscripten/-/quickjs-emscripten-0.23.0.tgz", + "integrity": "sha512-C5Mc6rdnsaJDjO3UpGW/CQTHtCKaYlScZTly4JIu97Jxo/odCiH0ITnDXSJPTOrEKk/ycSZ0AOgTmkDtkOsvIA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/json5": { + "version": "0.0.29", + "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", + "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/lodash": { + "version": "4.17.5", + "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.17.5.tgz", + "integrity": "sha512-MBIOHVZqVqgfro1euRDWX7OO0fBVUUMrN6Pwm8LQsz8cWhEpihlvR70ENj3f40j58TNxZaWv2ndSkInykNBBJw==", + "license": "MIT" + }, + "node_modules/@types/node": { + "version": "20.14.8", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.8.tgz", + "integrity": "sha512-DO+2/jZinXfROG7j7WKFn/3C6nFwxy2lLpgLjEXJz+0XKphZlTLJ14mo8Vfg8X5BWN6XjyESXq+LcYdT7tR3bA==", + "dev": true, + "license": "MIT", + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/@types/nprogress": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@types/nprogress/-/nprogress-0.2.3.tgz", + "integrity": "sha512-k7kRA033QNtC+gLc4VPlfnue58CM1iQLgn1IMAU8VPHGOj7oIHPp9UlhedEnD/Gl8evoCjwkZjlBORtZ3JByUA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/prop-types": { + "version": "15.7.12", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.12.tgz", + "integrity": "sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==", + "devOptional": true, + "license": "MIT" + }, + "node_modules/@types/quill": { + "version": "1.3.10", + "resolved": "https://registry.npmjs.org/@types/quill/-/quill-1.3.10.tgz", + "integrity": "sha512-IhW3fPW+bkt9MLNlycw8u8fWb7oO7W5URC9MfZYHBlA24rex9rs23D5DETChu1zvgVdc5ka64ICjJOgQMr6Shw==", + "license": "MIT", + "dependencies": { + "parchment": "^1.1.2" + } + }, + "node_modules/@types/quill/node_modules/parchment": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/parchment/-/parchment-1.1.4.tgz", + "integrity": "sha512-J5FBQt/pM2inLzg4hEWmzQx/8h8D0CiDxaG3vyp9rKrQRSDgBlhjdP5jQGgosEajXPSQouXGHOmVdgo7QmJuOg==", + "license": "BSD-3-Clause" + }, + "node_modules/@types/react": { + "version": "18.3.3", + "resolved": "https://registry.npmjs.org/@types/react/-/react-18.3.3.tgz", + "integrity": "sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw==", + "devOptional": true, + "license": "MIT", + "dependencies": { + "@types/prop-types": "*", + "csstype": "^3.0.2" + } + }, + "node_modules/@types/react-dom": { + "version": "18.3.0", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.3.0.tgz", + "integrity": "sha512-EhwApuTmMBmXuFOikhQLIBUn6uFg81SwLMOAUgodJF14SOBOCMdU04gDoYi0WOJJHD144TL32z4yDqCW3dnkQg==", + "devOptional": true, + "license": "MIT", + "dependencies": { + "@types/react": "*" + } + }, + "node_modules/@types/yauzl": { + "version": "2.10.3", + "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.3.tgz", + "integrity": "sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==", + "dev": true, + "license": "MIT", + "optional": true, + "dependencies": { + "@types/node": "*" + } + }, + "node_modules/@typescript-eslint/parser": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.2.0.tgz", + "integrity": "sha512-5FKsVcHTk6TafQKQbuIVkXq58Fnbkd2wDL4LB7AURN7RUOu1utVP+G8+6u3ZhEroW3DF6hyo3ZEXxgKgp4KeCg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "@typescript-eslint/scope-manager": "7.2.0", + "@typescript-eslint/types": "7.2.0", + "@typescript-eslint/typescript-estree": "7.2.0", + "@typescript-eslint/visitor-keys": "7.2.0", + "debug": "^4.3.4" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^8.56.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/scope-manager": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.2.0.tgz", + "integrity": "sha512-Qh976RbQM/fYtjx9hs4XkayYujB/aPwglw2choHmf3zBjB4qOywWSdt9+KLRdHubGcoSwBnXUH2sR3hkyaERRg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/types": "7.2.0", + "@typescript-eslint/visitor-keys": "7.2.0" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/types": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.2.0.tgz", + "integrity": "sha512-XFtUHPI/abFhm4cbCDc5Ykc8npOKBSJePY3a3s+lwumt7XWJuzP5cZcfZ610MIPHjQjNsOLlYK8ASPaNG8UiyA==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@typescript-eslint/typescript-estree": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.2.0.tgz", + "integrity": "sha512-cyxS5WQQCoBwSakpMrvMXuMDEbhOo9bNHHrNcEWis6XHx6KF518tkF1wBvKIn/tpq5ZpUYK7Bdklu8qY0MsFIA==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "@typescript-eslint/types": "7.2.0", + "@typescript-eslint/visitor-keys": "7.2.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "minimatch": "9.0.3", + "semver": "^7.5.4", + "ts-api-utils": "^1.0.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": { + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/@typescript-eslint/visitor-keys": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.2.0.tgz", + "integrity": "sha512-c6EIQRHhcpl6+tO8EMR+kjkkV+ugUNXOmeASA1rlzkd8EPIriavpWoiEz1HR/VLhbVIdhqnV6E7JZm00cBDx2A==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/types": "7.2.0", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/@vercel/analytics": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/@vercel/analytics/-/analytics-1.3.1.tgz", + "integrity": "sha512-xhSlYgAuJ6Q4WQGkzYTLmXwhYl39sWjoMA3nHxfkvG+WdBT25c563a7QhwwKivEOZtPJXifYHR1m2ihoisbWyA==", + "license": "MPL-2.0", + "dependencies": { + "server-only": "^0.0.1" + }, + "peerDependencies": { + "next": ">= 13", + "react": "^18 || ^19" + }, + "peerDependenciesMeta": { + "next": { + "optional": true + }, + "react": { + "optional": true + } + } + }, + "node_modules/@vercel/speed-insights": { + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/@vercel/speed-insights/-/speed-insights-1.0.12.tgz", + "integrity": "sha512-ZGQ+a7bcfWJD2VYEp2R1LHvRAMyyaFBYytZXsfnbOMkeOvzGNVxUL7aVUvisIrTZjXTSsxG45DKX7yiw6nq2Jw==", + "hasInstallScript": true, + "license": "Apache-2.0", + "peerDependencies": { + "@sveltejs/kit": "^1 || ^2", + "next": ">= 13", + "react": "^18 || ^19", + "svelte": "^4", + "vue": "^3", + "vue-router": "^4" + }, + "peerDependenciesMeta": { + "@sveltejs/kit": { + "optional": true + }, + "next": { + "optional": true + }, + "react": { + "optional": true + }, + "svelte": { + "optional": true + }, + "vue": { + "optional": true + }, + "vue-router": { + "optional": true + } + } + }, + "node_modules/@wojtekmaj/date-utils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/@wojtekmaj/date-utils/-/date-utils-1.5.1.tgz", + "integrity": "sha512-+i7+JmNiE/3c9FKxzWFi2IjRJ+KzZl1QPu6QNrsgaa2MuBgXvUy4gA1TVzf/JMdIIloB76xSKikTWuyYAIVLww==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/date-utils?sponsor=1" + } + }, + "node_modules/acorn": { + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.0.tgz", + "integrity": "sha512-RTvkC4w+KNXrM39/lWCUaG0IbRkWdCv7W/IOW9oU6SawyxulvkQy5HQPVTKxEjczcUvapcrw3cFx/60VN/NRNw==", + "dev": true, + "license": "MIT", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/acorn-jsx": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", + "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" + } + }, + "node_modules/agent-base": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-7.1.1.tgz", + "integrity": "sha512-H0TSyFNDMomMNJQBn8wFV5YC/2eJ+VXECwOadZJT554xP6cODZHPX3H9QMQECxvrgiSOP1pHjy1sMWQVYJOUOA==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/ajv": { + "version": "6.12.6", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", + "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", + "dev": true, + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/any-promise": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/any-promise/-/any-promise-1.3.0.tgz", + "integrity": "sha512-7UvmKalWRt1wgjL1RrGxoSJW/0QZFIegpeGvZG9kjp8vrRu55XTHbwnqq2GpXm9uLbcuhxm3IqX9OB4MZR1b2A==", + "license": "MIT" + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "license": "ISC", + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/arg": { + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/arg/-/arg-5.0.2.tgz", + "integrity": "sha512-PYjyFOLKQ9y57JvQ6QLo8dAgNqswh8M1RMJYdQduT6xbWSgK36P/Z/v+p888pM69jMMfS8Xd8F6I1kQ/I9HUGg==", + "license": "MIT" + }, + "node_modules/argparse": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", + "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", + "dev": true, + "license": "Python-2.0" + }, + "node_modules/aria-hidden": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/aria-hidden/-/aria-hidden-1.2.4.tgz", + "integrity": "sha512-y+CcFFwelSXpLZk/7fMB2mUbGtX9lKycf1MWJ7CaTIERyitVlyQx6C+sxcROU2BAJ24OiZyK+8wj2i8AlBoS3A==", + "license": "MIT", + "dependencies": { + "tslib": "^2.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/aria-query": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.1.3.tgz", + "integrity": "sha512-R5iJ5lkuHybztUfuOAznmboyjWq8O6sqNqtK7CLOqdydi54VNbORp49mb14KbWgG1QD3JFO9hJdZ+y4KutfdOQ==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "deep-equal": "^2.0.5" + } + }, + "node_modules/array-buffer-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-includes": { + "version": "3.1.8", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", + "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "is-string": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array-move": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/array-move/-/array-move-4.0.0.tgz", + "integrity": "sha512-+RY54S8OuVvg94THpneQvFRmqWdAHeqtMzgMW6JNurHxe8rsS07cHQdfGkXnTUXiBcyZ0j3SiDIxxj0RPiqCkQ==", + "license": "MIT", + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/array-union": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", + "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/array.prototype.findlast": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlast/-/array.prototype.findlast-1.2.5.tgz", + "integrity": "sha512-CVvd6FHg1Z3POpBLxO6E6zr+rSKEQ9L6rZHAaY7lLfhKsWYUBBOuMs0e9o24oopj6H+geRCX0YJ+TJLBK2eHyQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.findlastindex": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.5.tgz", + "integrity": "sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flat": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.2.tgz", + "integrity": "sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.flatmap": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.2.tgz", + "integrity": "sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/array.prototype.toreversed": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/array.prototype.toreversed/-/array.prototype.toreversed-1.1.2.tgz", + "integrity": "sha512-wwDCoT4Ck4Cz7sLtgUmzR5UV3YF5mFHUlbChCzZBQZ+0m2cl/DH3tKgvphv1nKgFsJ48oCSg6p91q2Vm0I/ZMA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "es-shim-unscopables": "^1.0.0" + } + }, + "node_modules/array.prototype.tosorted": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.4.tgz", + "integrity": "sha512-p6Fx8B7b7ZhL/gmUsAy0D15WhvDccw3mnGNbZpi3pmeJdxtWsj2jEaI4Y6oo3XiHfzuSgPwKc04MYt6KgvC/wA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-shim-unscopables": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/arraybuffer.prototype.slice": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", + "is-shared-array-buffer": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/ast-types": { + "version": "0.13.4", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.13.4.tgz", + "integrity": "sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==", + "dev": true, + "license": "MIT", + "dependencies": { + "tslib": "^2.0.1" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/ast-types-flow": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.8.tgz", + "integrity": "sha512-OH/2E5Fg20h2aPrbe+QL8JZQFko0YZaF+j4mnQ7BGhfavO7OpSLa8a0y9sBwomHdSbkhTS8TQNayBfnW5DwbvQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "license": "MIT" + }, + "node_modules/available-typed-arrays": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/axe-core": { + "version": "4.9.1", + "resolved": "https://registry.npmjs.org/axe-core/-/axe-core-4.9.1.tgz", + "integrity": "sha512-QbUdXJVTpvUTHU7871ppZkdOLBeGUKBQWHkHrvN2V9IQWGMt61zf3B45BtzjxEJzYuj0JBjBZP/hmYS/R9pmAw==", + "dev": true, + "license": "MPL-2.0", + "engines": { + "node": ">=4" + } + }, + "node_modules/axios": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.7.2.tgz", + "integrity": "sha512-2A8QhOMrbomlDuiLeK9XibIBzuHeRcqqNOHp0Cyp5EoJ1IFDh+XZH3A6BkXtv0K4gFGCI0Y4BM7B1wOEi0Rmgw==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.6", + "form-data": "^4.0.0", + "proxy-from-env": "^1.1.0" + } + }, + "node_modules/axobject-query": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-3.1.1.tgz", + "integrity": "sha512-goKlv8DZrK9hUh975fnHzhNIO4jUnFCfv/dszV5VwUGDFjI6vQ2VwoyjYjYNEbBE8AH87TduWP5uyDR1D+Iteg==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "deep-equal": "^2.0.5" + } + }, + "node_modules/b4a": { + "version": "1.6.6", + "resolved": "https://registry.npmjs.org/b4a/-/b4a-1.6.6.tgz", + "integrity": "sha512-5Tk1HLk6b6ctmjIkAcU/Ujv/1WqiDl0F0JdRCR80VsOcUlHcu7pWeWRlOqQLHfDEsVx9YH/aif5AG4ehoCtTmg==", + "dev": true, + "license": "Apache-2.0" + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "license": "MIT" + }, + "node_modules/bare-events": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/bare-events/-/bare-events-2.4.2.tgz", + "integrity": "sha512-qMKFd2qG/36aA4GwvKq8MxnPgCQAmBWmSyLWsJcbn8v03wvIPQ/hG1Ms8bPzndZxMDoHpxez5VOS+gC9Yi24/Q==", + "dev": true, + "license": "Apache-2.0", + "optional": true + }, + "node_modules/bare-fs": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/bare-fs/-/bare-fs-2.3.1.tgz", + "integrity": "sha512-W/Hfxc/6VehXlsgFtbB5B4xFcsCl+pAh30cYhoFyXErf6oGrwjh8SwiPAdHgpmWonKuYpZgGywN0SXt7dgsADA==", + "dev": true, + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "bare-events": "^2.0.0", + "bare-path": "^2.0.0", + "bare-stream": "^2.0.0" + } + }, + "node_modules/bare-os": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/bare-os/-/bare-os-2.4.0.tgz", + "integrity": "sha512-v8DTT08AS/G0F9xrhyLtepoo9EJBJ85FRSMbu1pQUlAf6A8T0tEEQGMVObWeqpjhSPXsE0VGlluFBJu2fdoTNg==", + "dev": true, + "license": "Apache-2.0", + "optional": true + }, + "node_modules/bare-path": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/bare-path/-/bare-path-2.1.3.tgz", + "integrity": "sha512-lh/eITfU8hrj9Ru5quUp0Io1kJWIk1bTjzo7JH1P5dWmQ2EL4hFUlfI8FonAhSlgIfhn63p84CDY/x+PisgcXA==", + "dev": true, + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "bare-os": "^2.1.0" + } + }, + "node_modules/bare-stream": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/bare-stream/-/bare-stream-2.1.3.tgz", + "integrity": "sha512-tiDAH9H/kP+tvNO5sczyn9ZAA7utrSMobyDchsnyyXBuUe2FSQWbxhtuHB8jwpHYYevVo2UJpcmvvjrbHboUUQ==", + "dev": true, + "license": "Apache-2.0", + "optional": true, + "dependencies": { + "streamx": "^2.18.0" + } + }, + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/basic-ftp": { + "version": "5.0.5", + "resolved": "https://registry.npmjs.org/basic-ftp/-/basic-ftp-5.0.5.tgz", + "integrity": "sha512-4Bcg1P8xhUuqcii/S0Z9wiHIrQVPMermM1any+MX5GeGD7faD3/msQUDGLol9wOcz4/jbg/WJnGqoJF6LiBdtg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/binary-extensions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/braces": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", + "license": "MIT", + "dependencies": { + "fill-range": "^7.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/buffer": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", + "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT", + "dependencies": { + "base64-js": "^1.3.1", + "ieee754": "^1.1.13" + } + }, + "node_modules/buffer-crc32": { + "version": "0.2.13", + "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", + "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/busboy": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", + "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", + "dependencies": { + "streamsearch": "^1.1.0" + }, + "engines": { + "node": ">=10.16.0" + } + }, + "node_modules/call-bind": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/camelcase-css": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/camelcase-css/-/camelcase-css-2.0.1.tgz", + "integrity": "sha512-QOSvevhslijgYwRx6Rv7zKdMF8lbRmx+uQGx2+vDc+KI/eBnsy9kit5aj23AgGu3pa4t9AgwbnXWqS+iOY+2aA==", + "license": "MIT", + "engines": { + "node": ">= 6" + } + }, + "node_modules/caniuse-lite": { + "version": "1.0.30001636", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001636.tgz", + "integrity": "sha512-bMg2vmr8XBsbL6Lr0UHXy/21m84FTxDLWn2FSqMd5PrlbMxwJlQnC2YWYxVgp66PZE+BBNF2jYQUBKCo1FDeZg==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/browserslist" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/caniuse-lite" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "CC-BY-4.0" + }, + "node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", + "license": "MIT", + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/chokidar/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/chromium-bidi": { + "version": "0.5.24", + "resolved": "https://registry.npmjs.org/chromium-bidi/-/chromium-bidi-0.5.24.tgz", + "integrity": "sha512-5xQNN2SVBdZv4TxeMLaI+PelrnZsHDhn8h2JtyriLr+0qHcZS8BMuo93qN6J1VmtmrgYP+rmcLHcbpnA8QJh+w==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "mitt": "3.0.1", + "urlpattern-polyfill": "10.0.0", + "zod": "3.23.8" + }, + "peerDependencies": { + "devtools-protocol": "*" + } + }, + "node_modules/class-variance-authority": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/class-variance-authority/-/class-variance-authority-0.7.0.tgz", + "integrity": "sha512-jFI8IQw4hczaL4ALINxqLEXQbWcNjoSkloa4IaufXCJr6QawJyw7tuRysRsrE8w2p/4gGaxKIt/hX3qz/IbD1A==", + "license": "Apache-2.0", + "dependencies": { + "clsx": "2.0.0" + }, + "funding": { + "url": "https://joebell.co.uk" + } + }, + "node_modules/class-variance-authority/node_modules/clsx": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.0.0.tgz", + "integrity": "sha512-rQ1+kcj+ttHG0MKVGBUXwayCCF1oh39BF5COIpRzuCEv8Mwjv0XucrI2ExNTOn9IlLifGClWQcU9BrZORvtw6Q==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/client-only": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/client-only/-/client-only-0.0.1.tgz", + "integrity": "sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA==", + "license": "MIT" + }, + "node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dev": true, + "license": "ISC", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/cliui/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true, + "license": "MIT" + }, + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/clone": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/clone/-/clone-2.1.2.tgz", + "integrity": "sha512-3Pe/CF1Nn94hyhIYpjtiLhdCoEoz0DqQ+988E9gmeEdQZlojxnOb74wctFyuwWQHzqyf9X7C7MG8juUpqBJT8w==", + "license": "MIT", + "engines": { + "node": ">=0.8" + } + }, + "node_modules/clsx": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz", + "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "license": "MIT" + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "license": "MIT", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", + "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==", + "license": "MIT", + "engines": { + "node": ">= 6" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true, + "license": "MIT" + }, + "node_modules/convex": { + "version": "1.12.2", + "resolved": "https://registry.npmjs.org/convex/-/convex-1.12.2.tgz", + "integrity": "sha512-LQb5o2eritXTObYA/HqkUzHky60qTVU4pLefqTh09PU5xfBBAi0ObF9EmYvD657jKsWGjU5MVjdg8aZ5XhVl2A==", + "license": "Apache-2.0", + "dependencies": { + "esbuild": "^0.17.5", + "jwt-decode": "^3.1.2", + "node-fetch": "^2.6.1", + "prettier": "3.2.5" + }, + "bin": { + "convex": "bin/main.js" + }, + "engines": { + "node": ">=16.15.1", + "npm": ">=7.0.0" + }, + "peerDependencies": { + "@auth0/auth0-react": "^2.0.1", + "@clerk/clerk-react": "^4.12.8 || ^5.0.0", + "react": "^17.0.2 || ^18.0.0", + "react-dom": "^17.0.2 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@auth0/auth0-react": { + "optional": true + }, + "@clerk/clerk-react": { + "optional": true + }, + "react": { + "optional": true + }, + "react-dom": { + "optional": true + } + } + }, + "node_modules/cookie": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", + "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cross-spawn": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", + "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", + "license": "MIT", + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/crypto-js": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/crypto-js/-/crypto-js-4.2.0.tgz", + "integrity": "sha512-KALDyEYgpY+Rlob/iriUtjV6d5Eq+Y191A5g4UqLAi8CyGP9N1+FdVbkc1SxKc2r4YAYqG8JzO2KGL+AizD70Q==", + "license": "MIT" + }, + "node_modules/cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "license": "MIT", + "bin": { + "cssesc": "bin/cssesc" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/csstype": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.3.tgz", + "integrity": "sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==", + "license": "MIT" + }, + "node_modules/damerau-levenshtein": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz", + "integrity": "sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA==", + "dev": true, + "license": "BSD-2-Clause" + }, + "node_modules/data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/debug": { + "version": "4.3.5", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", + "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "2.1.2" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/deep-equal": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-2.2.3.tgz", + "integrity": "sha512-ZIwpnevOurS8bpT4192sqAowWM76JDKSHYzMLty3BZGSswgq6pBaH3DhCSW5xVAZICZyKdOBPjwww5wfgT/6PA==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-buffer-byte-length": "^1.0.0", + "call-bind": "^1.0.5", + "es-get-iterator": "^1.1.3", + "get-intrinsic": "^1.2.2", + "is-arguments": "^1.1.1", + "is-array-buffer": "^3.0.2", + "is-date-object": "^1.0.5", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.2", + "isarray": "^2.0.5", + "object-is": "^1.1.5", + "object-keys": "^1.1.1", + "object.assign": "^4.1.4", + "regexp.prototype.flags": "^1.5.1", + "side-channel": "^1.0.4", + "which-boxed-primitive": "^1.0.2", + "which-collection": "^1.0.1", + "which-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/deep-is": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", + "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/define-data-property": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/define-properties": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.2.1.tgz", + "integrity": "sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==", + "license": "MIT", + "dependencies": { + "define-data-property": "^1.0.1", + "has-property-descriptors": "^1.0.0", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/degenerator": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/degenerator/-/degenerator-5.0.1.tgz", + "integrity": "sha512-TllpMR/t0M5sqCXfj85i4XaAzxmS5tVA16dqvdkMwGmzI+dXLXnw3J+3Vdv7VKw+ThlTMboK6i9rnZ6Nntj5CQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ast-types": "^0.13.4", + "escodegen": "^2.1.0", + "esprima": "^4.0.1" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/detect-element-overflow": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/detect-element-overflow/-/detect-element-overflow-1.4.2.tgz", + "integrity": "sha512-4m6cVOtvm/GJLjo7WFkPfwXoEIIbM7GQwIh4WEa4g7IsNi1YzwUsGL5ApNLrrHL29bHeNeQ+/iZhw+YHqgE2Fw==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/detect-element-overflow?sponsor=1" + } + }, + "node_modules/detect-node-es": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/detect-node-es/-/detect-node-es-1.1.0.tgz", + "integrity": "sha512-ypdmJU/TbBby2Dxibuv7ZLW3Bs1QEmM7nHjEANfohJLvE0XVujisn1qPJcZxg+qDucsr+bP6fLD1rPS3AhJ7EQ==", + "license": "MIT" + }, + "node_modules/devtools-protocol": { + "version": "0.0.1299070", + "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.1299070.tgz", + "integrity": "sha512-+qtL3eX50qsJ7c+qVyagqi7AWMoQCBGNfoyJZMwm/NSXVqLYbuitrWEEIzxfUmTNy7//Xe8yhMmQ+elj3uAqSg==", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/didyoumean": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/didyoumean/-/didyoumean-1.2.2.tgz", + "integrity": "sha512-gxtyfqMg7GKyhQmb056K7M3xszy/myH8w+B4RT+QXBQsvAOdc3XymqDDPHx1BgPgsdAA5SIifona89YtRATDzw==", + "license": "Apache-2.0" + }, + "node_modules/dir-glob": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", + "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", + "dev": true, + "license": "MIT", + "dependencies": { + "path-type": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/dlv": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/dlv/-/dlv-1.1.3.tgz", + "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==", + "license": "MIT" + }, + "node_modules/doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/dot-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", + "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/eastasianwidth": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", + "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", + "license": "MIT" + }, + "node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", + "license": "MIT" + }, + "node_modules/encoding": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", + "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", + "license": "MIT", + "optional": true, + "peer": true, + "dependencies": { + "iconv-lite": "^0.6.2" + } + }, + "node_modules/end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "once": "^1.4.0" + } + }, + "node_modules/enhanced-resolve": { + "version": "5.17.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.0.tgz", + "integrity": "sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA==", + "dev": true, + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.2.4", + "tapable": "^2.2.0" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/env-paths": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/env-paths/-/env-paths-2.2.1.tgz", + "integrity": "sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-arrayish": "^0.2.1" + } + }, + "node_modules/es-abstract": { + "version": "1.23.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", + "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", + "es-to-primitive": "^1.2.1", + "function.prototype.name": "^1.1.6", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", + "globalthis": "^1.0.3", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", + "is-callable": "^1.2.7", + "is-data-view": "^1.0.1", + "is-negative-zero": "^2.0.3", + "is-regex": "^1.1.4", + "is-shared-array-buffer": "^1.0.3", + "is-string": "^1.0.7", + "is-typed-array": "^1.1.13", + "is-weakref": "^1.0.2", + "object-inspect": "^1.13.1", + "object-keys": "^1.1.1", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.8", + "typed-array-buffer": "^1.0.2", + "typed-array-byte-length": "^1.0.1", + "typed-array-byte-offset": "^1.0.2", + "typed-array-length": "^1.0.6", + "unbox-primitive": "^1.0.2", + "which-typed-array": "^1.1.15" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-get-iterator": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/es-get-iterator/-/es-get-iterator-1.1.3.tgz", + "integrity": "sha512-sPZmqHBe6JIiTfN5q2pEi//TwxmAFHwj/XEuYjTuse78i8KxaqMTTzxPoFKuzRpDpTJ+0NAbpfenkmH2rePtuw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.1.3", + "has-symbols": "^1.0.3", + "is-arguments": "^1.1.1", + "is-map": "^2.0.2", + "is-set": "^2.0.2", + "is-string": "^1.0.7", + "isarray": "^2.0.5", + "stop-iteration-iterator": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/es-iterator-helpers": { + "version": "1.0.19", + "resolved": "https://registry.npmjs.org/es-iterator-helpers/-/es-iterator-helpers-1.0.19.tgz", + "integrity": "sha512-zoMwbCcH5hwUkKJkT8kDIBZSz9I6mVG//+lDCinLCGov4+r7NIy0ld8o03M0cJxl2spVf6ESYVS6/gpIfq1FFw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.3", + "es-errors": "^1.3.0", + "es-set-tostringtag": "^2.0.3", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "has-property-descriptors": "^1.0.2", + "has-proto": "^1.0.3", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "iterator.prototype": "^1.1.2", + "safe-array-concat": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-shim-unscopables": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.2.tgz", + "integrity": "sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==", + "dev": true, + "license": "MIT", + "dependencies": { + "hasown": "^2.0.0" + } + }, + "node_modules/es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/esbuild": { + "version": "0.17.19", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", + "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", + "hasInstallScript": true, + "license": "MIT", + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/android-arm": "0.17.19", + "@esbuild/android-arm64": "0.17.19", + "@esbuild/android-x64": "0.17.19", + "@esbuild/darwin-arm64": "0.17.19", + "@esbuild/darwin-x64": "0.17.19", + "@esbuild/freebsd-arm64": "0.17.19", + "@esbuild/freebsd-x64": "0.17.19", + "@esbuild/linux-arm": "0.17.19", + "@esbuild/linux-arm64": "0.17.19", + "@esbuild/linux-ia32": "0.17.19", + "@esbuild/linux-loong64": "0.17.19", + "@esbuild/linux-mips64el": "0.17.19", + "@esbuild/linux-ppc64": "0.17.19", + "@esbuild/linux-riscv64": "0.17.19", + "@esbuild/linux-s390x": "0.17.19", + "@esbuild/linux-x64": "0.17.19", + "@esbuild/netbsd-x64": "0.17.19", + "@esbuild/openbsd-x64": "0.17.19", + "@esbuild/sunos-x64": "0.17.19", + "@esbuild/win32-arm64": "0.17.19", + "@esbuild/win32-ia32": "0.17.19", + "@esbuild/win32-x64": "0.17.19" + } + }, + "node_modules/escalade": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", + "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/escape-string-regexp": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", + "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/escodegen": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.1.0.tgz", + "integrity": "sha512-2NlIDTwUWJN0mRPQOdtQBzbUHvdGY2P1VXSyU83Q3xKxM7WHX2Ql8dKq782Q9TgQUNOLEzEYu9bzLNj1q88I5w==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "esprima": "^4.0.1", + "estraverse": "^5.2.0", + "esutils": "^2.0.2" + }, + "bin": { + "escodegen": "bin/escodegen.js", + "esgenerate": "bin/esgenerate.js" + }, + "engines": { + "node": ">=6.0" + }, + "optionalDependencies": { + "source-map": "~0.6.1" + } + }, + "node_modules/escodegen/node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "license": "BSD-3-Clause", + "optional": true, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint": { + "version": "8.57.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.57.0.tgz", + "integrity": "sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@eslint-community/eslint-utils": "^4.2.0", + "@eslint-community/regexpp": "^4.6.1", + "@eslint/eslintrc": "^2.1.4", + "@eslint/js": "8.57.0", + "@humanwhocodes/config-array": "^0.11.14", + "@humanwhocodes/module-importer": "^1.0.1", + "@nodelib/fs.walk": "^1.2.8", + "@ungap/structured-clone": "^1.2.0", + "ajv": "^6.12.4", + "chalk": "^4.0.0", + "cross-spawn": "^7.0.2", + "debug": "^4.3.2", + "doctrine": "^3.0.0", + "escape-string-regexp": "^4.0.0", + "eslint-scope": "^7.2.2", + "eslint-visitor-keys": "^3.4.3", + "espree": "^9.6.1", + "esquery": "^1.4.2", + "esutils": "^2.0.2", + "fast-deep-equal": "^3.1.3", + "file-entry-cache": "^6.0.1", + "find-up": "^5.0.0", + "glob-parent": "^6.0.2", + "globals": "^13.19.0", + "graphemer": "^1.4.0", + "ignore": "^5.2.0", + "imurmurhash": "^0.1.4", + "is-glob": "^4.0.0", + "is-path-inside": "^3.0.3", + "js-yaml": "^4.1.0", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.4.1", + "lodash.merge": "^4.6.2", + "minimatch": "^3.1.2", + "natural-compare": "^1.4.0", + "optionator": "^0.9.3", + "strip-ansi": "^6.0.1", + "text-table": "^0.2.0" + }, + "bin": { + "eslint": "bin/eslint.js" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-config-next": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/eslint-config-next/-/eslint-config-next-14.2.4.tgz", + "integrity": "sha512-Qr0wMgG9m6m4uYy2jrYJmyuNlYZzPRQq5Kvb9IDlYwn+7yq6W6sfMNFgb+9guM1KYwuIo6TIaiFhZJ6SnQ/Efw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@next/eslint-plugin-next": "14.2.4", + "@rushstack/eslint-patch": "^1.3.3", + "@typescript-eslint/parser": "^5.4.2 || ^6.0.0 || 7.0.0 - 7.2.0", + "eslint-import-resolver-node": "^0.3.6", + "eslint-import-resolver-typescript": "^3.5.2", + "eslint-plugin-import": "^2.28.1", + "eslint-plugin-jsx-a11y": "^6.7.1", + "eslint-plugin-react": "^7.33.2", + "eslint-plugin-react-hooks": "^4.5.0 || 5.0.0-canary-7118f5dd7-20230705" + }, + "peerDependencies": { + "eslint": "^7.23.0 || ^8.0.0", + "typescript": ">=3.3.1" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/eslint-import-resolver-node": { + "version": "0.3.9", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.9.tgz", + "integrity": "sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^3.2.7", + "is-core-module": "^2.13.0", + "resolve": "^1.22.4" + } + }, + "node_modules/eslint-import-resolver-node/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-import-resolver-typescript": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-3.6.1.tgz", + "integrity": "sha512-xgdptdoi5W3niYeuQxKmzVDTATvLYqhpwmykwsh7f6HIOStGWEIL9iqZgQDF9u9OEzrRwR8no5q2VT+bjAujTg==", + "dev": true, + "license": "ISC", + "dependencies": { + "debug": "^4.3.4", + "enhanced-resolve": "^5.12.0", + "eslint-module-utils": "^2.7.4", + "fast-glob": "^3.3.1", + "get-tsconfig": "^4.5.0", + "is-core-module": "^2.11.0", + "is-glob": "^4.0.3" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/unts/projects/eslint-import-resolver-ts" + }, + "peerDependencies": { + "eslint": "*", + "eslint-plugin-import": "*" + } + }, + "node_modules/eslint-module-utils": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.1.tgz", + "integrity": "sha512-rXDXR3h7cs7dy9RNpUlQf80nX31XWJEyGq1tRMo+6GsO5VmTe4UTwtmonAD4ZkAsrfMVDA2wlGJ3790Ys+D49Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^3.2.7" + }, + "engines": { + "node": ">=4" + }, + "peerDependenciesMeta": { + "eslint": { + "optional": true + } + } + }, + "node_modules/eslint-module-utils/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import": { + "version": "2.29.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.29.1.tgz", + "integrity": "sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-includes": "^3.1.7", + "array.prototype.findlastindex": "^1.2.3", + "array.prototype.flat": "^1.3.2", + "array.prototype.flatmap": "^1.3.2", + "debug": "^3.2.7", + "doctrine": "^2.1.0", + "eslint-import-resolver-node": "^0.3.9", + "eslint-module-utils": "^2.8.0", + "hasown": "^2.0.0", + "is-core-module": "^2.13.1", + "is-glob": "^4.0.3", + "minimatch": "^3.1.2", + "object.fromentries": "^2.0.7", + "object.groupby": "^1.0.1", + "object.values": "^1.1.7", + "semver": "^6.3.1", + "tsconfig-paths": "^3.15.0" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + } + }, + "node_modules/eslint-plugin-import/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-import/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-plugin-jsx-a11y": { + "version": "6.9.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.9.0.tgz", + "integrity": "sha512-nOFOCaJG2pYqORjK19lqPqxMO/JpvdCZdPtNdxY3kvom3jTvkAbOvQvD8wuD0G8BYR0IGAGYDlzqWJOh/ybn2g==", + "dev": true, + "license": "MIT", + "dependencies": { + "aria-query": "~5.1.3", + "array-includes": "^3.1.8", + "array.prototype.flatmap": "^1.3.2", + "ast-types-flow": "^0.0.8", + "axe-core": "^4.9.1", + "axobject-query": "~3.1.1", + "damerau-levenshtein": "^1.0.8", + "emoji-regex": "^9.2.2", + "es-iterator-helpers": "^1.0.19", + "hasown": "^2.0.2", + "jsx-ast-utils": "^3.3.5", + "language-tags": "^1.0.9", + "minimatch": "^3.1.2", + "object.fromentries": "^2.0.8", + "safe-regex-test": "^1.0.3", + "string.prototype.includes": "^2.0.0" + }, + "engines": { + "node": ">=4.0" + }, + "peerDependencies": { + "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" + } + }, + "node_modules/eslint-plugin-react": { + "version": "7.34.3", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.34.3.tgz", + "integrity": "sha512-aoW4MV891jkUulwDApQbPYTVZmeuSyFrudpbTAQuj5Fv8VL+o6df2xIGpw8B0hPjAaih1/Fb0om9grCdyFYemA==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-includes": "^3.1.8", + "array.prototype.findlast": "^1.2.5", + "array.prototype.flatmap": "^1.3.2", + "array.prototype.toreversed": "^1.1.2", + "array.prototype.tosorted": "^1.1.4", + "doctrine": "^2.1.0", + "es-iterator-helpers": "^1.0.19", + "estraverse": "^5.3.0", + "jsx-ast-utils": "^2.4.1 || ^3.0.0", + "minimatch": "^3.1.2", + "object.entries": "^1.1.8", + "object.fromentries": "^2.0.8", + "object.hasown": "^1.1.4", + "object.values": "^1.2.0", + "prop-types": "^15.8.1", + "resolve": "^2.0.0-next.5", + "semver": "^6.3.1", + "string.prototype.matchall": "^4.0.11" + }, + "engines": { + "node": ">=4" + }, + "peerDependencies": { + "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" + } + }, + "node_modules/eslint-plugin-react-hooks": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.2.tgz", + "integrity": "sha512-QzliNJq4GinDBcD8gPB5v0wh6g8q3SUi6EFF0x8N/BL9PoVs0atuGc47ozMRyOWAKdwaZ5OnbOEa3WR+dSGKuQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" + } + }, + "node_modules/eslint-plugin-react/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-react/node_modules/resolve": { + "version": "2.0.0-next.5", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.5.tgz", + "integrity": "sha512-U7WjGVG9sH8tvjW5SmGbQuui75FiyjAX72HX15DwBBwF9dNiQZRQAg9nnPhYy+TUnE0+VcrttuvNI8oSxZcocA==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/eslint-plugin-react/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-scope": { + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "esrecurse": "^4.3.0", + "estraverse": "^5.2.0" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-visitor-keys": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", + "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/espree": { + "version": "9.6.1", + "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", + "integrity": "sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "acorn": "^8.9.0", + "acorn-jsx": "^5.3.2", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", + "dev": true, + "license": "BSD-2-Clause", + "bin": { + "esparse": "bin/esparse.js", + "esvalidate": "bin/esvalidate.js" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/esquery": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz", + "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==", + "dev": true, + "license": "BSD-3-Clause", + "dependencies": { + "estraverse": "^5.1.0" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/esrecurse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", + "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "estraverse": "^5.2.0" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/estraverse": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", + "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=4.0" + } + }, + "node_modules/esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", + "dev": true, + "license": "BSD-2-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eventemitter3": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz", + "integrity": "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==", + "license": "MIT" + }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "license": "MIT" + }, + "node_modules/extract-zip": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", + "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "debug": "^4.1.1", + "get-stream": "^5.1.0", + "yauzl": "^2.10.0" + }, + "bin": { + "extract-zip": "cli.js" + }, + "engines": { + "node": ">= 10.17.0" + }, + "optionalDependencies": { + "@types/yauzl": "^2.9.1" + } + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-diff": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.3.0.tgz", + "integrity": "sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==", + "license": "Apache-2.0" + }, + "node_modules/fast-fifo": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/fast-fifo/-/fast-fifo-1.3.2.tgz", + "integrity": "sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-glob": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", + "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", + "license": "MIT", + "dependencies": { + "@nodelib/fs.stat": "^2.0.2", + "@nodelib/fs.walk": "^1.2.3", + "glob-parent": "^5.1.2", + "merge2": "^1.3.0", + "micromatch": "^4.0.4" + }, + "engines": { + "node": ">=8.6.0" + } + }, + "node_modules/fast-glob/node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", + "dev": true, + "license": "MIT" + }, + "node_modules/fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", + "dev": true, + "license": "MIT" + }, + "node_modules/fastq": { + "version": "1.17.1", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", + "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", + "license": "ISC", + "dependencies": { + "reusify": "^1.0.4" + } + }, + "node_modules/fd-slicer": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", + "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", + "dev": true, + "license": "MIT", + "dependencies": { + "pend": "~1.2.0" + } + }, + "node_modules/file-entry-cache": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", + "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", + "dev": true, + "license": "MIT", + "dependencies": { + "flat-cache": "^3.0.4" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "license": "MIT", + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/find-up": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", + "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "dev": true, + "license": "MIT", + "dependencies": { + "locate-path": "^6.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/flat-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.2.0.tgz", + "integrity": "sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==", + "dev": true, + "license": "MIT", + "dependencies": { + "flatted": "^3.2.9", + "keyv": "^4.5.3", + "rimraf": "^3.0.2" + }, + "engines": { + "node": "^10.12.0 || >=12.0.0" + } + }, + "node_modules/flatted": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", + "dev": true, + "license": "ISC" + }, + "node_modules/follow-redirects": { + "version": "1.15.6", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", + "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "license": "MIT", + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/for-each": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz", + "integrity": "sha512-jqYfLp7mo9vIyQf8ykW2v7A+2N4QjeCeI5+Dz9XraiO1ign81wjiH7Fb9vSOWvQfNtmSa4H2RoQTrrXivdUZmw==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-callable": "^1.1.3" + } + }, + "node_modules/foreground-child": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.2.1.tgz", + "integrity": "sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==", + "license": "ISC", + "dependencies": { + "cross-spawn": "^7.0.0", + "signal-exit": "^4.0.1" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/form-data": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", + "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", + "license": "MIT", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/framer-motion": { + "version": "11.2.12", + "resolved": "https://registry.npmjs.org/framer-motion/-/framer-motion-11.2.12.tgz", + "integrity": "sha512-lCjkV4nA9rWOy2bhR4RZzkp2xpB++kFmUZ6D44V9VQaxk+JDmbDd5lq+u58DjJIIllE8AZEXp9OG/TyDN4FB/w==", + "license": "MIT", + "dependencies": { + "tslib": "^2.4.0" + }, + "peerDependencies": { + "@emotion/is-prop-valid": "*", + "react": "^18.0.0", + "react-dom": "^18.0.0" + }, + "peerDependenciesMeta": { + "@emotion/is-prop-valid": { + "optional": true + }, + "react": { + "optional": true + }, + "react-dom": { + "optional": true + } + } + }, + "node_modules/fs": { + "version": "0.0.1-security", + "resolved": "https://registry.npmjs.org/fs/-/fs-0.0.1-security.tgz", + "integrity": "sha512-3XY9e1pP0CVEUCdj5BmfIZxRBTSDycnbqhIOGec9QYtmVH2fbLpj86CFWkrNOkt/Fvty4KZG5lTglL9j/gJ87w==", + "license": "ISC" + }, + "node_modules/fs-extra": { + "version": "11.2.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-11.2.0.tgz", + "integrity": "sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==", + "dev": true, + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.2.0", + "jsonfile": "^6.0.1", + "universalify": "^2.0.0" + }, + "engines": { + "node": ">=14.14" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true, + "license": "ISC" + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/function.prototype.name": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.6.tgz", + "integrity": "sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "define-properties": "^1.2.0", + "es-abstract": "^1.22.1", + "functions-have-names": "^1.2.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/functions-have-names": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", + "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "dev": true, + "license": "ISC", + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-intrinsic": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "has-proto": "^1.0.1", + "has-symbols": "^1.0.3", + "hasown": "^2.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-nonce": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/get-nonce/-/get-nonce-1.0.1.tgz", + "integrity": "sha512-FJhYRoDaiatfEkUK8HKlicmu/3SGFD51q3itKDGoSTysQJBnfOcxU5GxnhE1E6soB76MbT0MBtnKJuXyAx+96Q==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/get-stream": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", + "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", + "dev": true, + "license": "MIT", + "dependencies": { + "pump": "^3.0.0" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-symbol-description": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-tsconfig": { + "version": "4.7.5", + "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.7.5.tgz", + "integrity": "sha512-ZCuZCnlqNzjb4QprAzXKdpp/gh6KTxSJuw3IBsPnV/7fV4NxC9ckB+vPTt8w7fJA0TaSD7c55BR47JD6MEDyDw==", + "dev": true, + "license": "MIT", + "dependencies": { + "resolve-pkg-maps": "^1.0.0" + }, + "funding": { + "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" + } + }, + "node_modules/get-uri": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/get-uri/-/get-uri-6.0.3.tgz", + "integrity": "sha512-BzUrJBS9EcUb4cFol8r4W3v1cPsSyajLSthNkz5BxbpDcHN5tIrM10E2eNvfnvBn3DaT3DUgx0OpsBKkaOpanw==", + "dev": true, + "license": "MIT", + "dependencies": { + "basic-ftp": "^5.0.2", + "data-uri-to-buffer": "^6.0.2", + "debug": "^4.3.4", + "fs-extra": "^11.2.0" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/get-uri/node_modules/data-uri-to-buffer": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/data-uri-to-buffer/-/data-uri-to-buffer-6.0.2.tgz", + "integrity": "sha512-7hvf7/GW8e86rW0ptuwS3OcBGDjIi6SZva7hCyWC0yYry2cOPmLIjXAUHI6DK2HsnwJd9ifmt57i8eV2n4YNpw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 14" + } + }, + "node_modules/get-user-locale": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/get-user-locale/-/get-user-locale-2.3.2.tgz", + "integrity": "sha512-O2GWvQkhnbDoWFUJfaBlDIKUEdND8ATpBXD6KXcbhxlfktyD/d8w6mkzM/IlQEqGZAMz/PW6j6Hv53BiigKLUQ==", + "license": "MIT", + "dependencies": { + "mem": "^8.0.0" + }, + "funding": { + "url": "https://github.com/wojtekmaj/get-user-locale?sponsor=1" + } + }, + "node_modules/glob": { + "version": "10.3.10", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", + "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", + "license": "ISC", + "dependencies": { + "foreground-child": "^3.1.0", + "jackspeak": "^2.3.5", + "minimatch": "^9.0.1", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", + "path-scurry": "^1.10.1" + }, + "bin": { + "glob": "dist/esm/bin.mjs" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", + "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.3" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/glob-to-regexp": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", + "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", + "license": "BSD-2-Clause" + }, + "node_modules/glob/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/glob/node_modules/minimatch": { + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz", + "integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==", + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/globals": { + "version": "13.24.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", + "integrity": "sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "type-fest": "^0.20.2" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/globalthis": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/globalthis/-/globalthis-1.0.4.tgz", + "integrity": "sha512-DpLKbNU4WylpxJykQujfCcwYWiV/Jhm50Goo0wrVILAv5jOr9d+H+UR3PhSCD2rCCEIg0uc+G+muBTwD54JhDQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.2.1", + "gopd": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/globby": { + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", + "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-union": "^2.1.0", + "dir-glob": "^3.0.1", + "fast-glob": "^3.2.9", + "ignore": "^5.2.0", + "merge2": "^1.4.1", + "slash": "^3.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/goober": { + "version": "2.1.14", + "resolved": "https://registry.npmjs.org/goober/-/goober-2.1.14.tgz", + "integrity": "sha512-4UpC0NdGyAFqLNPnhCT2iHpza2q+RAY3GV85a/mRPdzyPQMsj0KmMMuetdIkzWRbJ+Hgau1EZztq8ImmiMGhsg==", + "license": "MIT", + "peerDependencies": { + "csstype": "^3.0.10" + } + }, + "node_modules/gopd": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", + "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", + "license": "MIT", + "dependencies": { + "get-intrinsic": "^1.1.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "license": "ISC" + }, + "node_modules/graphemer": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", + "integrity": "sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag==", + "dev": true, + "license": "MIT" + }, + "node_modules/has-bigints": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", + "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/has-property-descriptors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", + "license": "MIT", + "dependencies": { + "es-define-property": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-proto": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-symbols": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", + "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/http-proxy-agent": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-7.0.2.tgz", + "integrity": "sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==", + "dev": true, + "license": "MIT", + "dependencies": { + "agent-base": "^7.1.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/https-proxy-agent": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-7.0.4.tgz", + "integrity": "sha512-wlwpilI7YdjSkWaQ/7omYBMTliDcmCN8OLihO6I9B86g06lMyAoqgoDpV0XqoaPOKj+0DIdAvnsWfyAAhmimcg==", + "dev": true, + "license": "MIT", + "dependencies": { + "agent-base": "^7.0.2", + "debug": "4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "license": "MIT", + "optional": true, + "peer": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/ieee754": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", + "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "BSD-3-Clause" + }, + "node_modules/ignore": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", + "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 4" + } + }, + "node_modules/ignore-loader": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ignore-loader/-/ignore-loader-0.1.2.tgz", + "integrity": "sha512-yOJQEKrNwoYqrWLS4DcnzM7SEQhRKis5mB+LdKKh4cPmGYlLPR0ozRzHV5jmEk2IxptqJNQA5Cc0gw8Fj12bXA==", + "dev": true + }, + "node_modules/import-fresh": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", + "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", + "dev": true, + "license": "MIT", + "dependencies": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.8.19" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", + "dev": true, + "license": "ISC", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/internal-slot": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", + "dev": true, + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "hasown": "^2.0.0", + "side-channel": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/invariant": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", + "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.0.0" + } + }, + "node_modules/ip-address": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/ip-address/-/ip-address-9.0.5.tgz", + "integrity": "sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==", + "dev": true, + "license": "MIT", + "dependencies": { + "jsbn": "1.1.0", + "sprintf-js": "^1.1.3" + }, + "engines": { + "node": ">= 12" + } + }, + "node_modules/is-arguments": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.1.1.tgz", + "integrity": "sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==", + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-array-buffer": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "get-intrinsic": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==", + "dev": true, + "license": "MIT" + }, + "node_modules/is-async-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-async-function/-/is-async-function-2.0.0.tgz", + "integrity": "sha512-Y1JXKrfykRJGdlDwdKlLpLyMIiWqWvuSd17TvZk68PLAOGOoF4Xyav1z0Xhoi+gCYjZVeC5SI+hYFOfvXmGRCA==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-bigint": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", + "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-bigints": "^1.0.1" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "license": "MIT", + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-boolean-object": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", + "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-callable": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", + "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-core-module": { + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.14.0.tgz", + "integrity": "sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==", + "license": "MIT", + "dependencies": { + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-date-object": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", + "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-finalizationregistry": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-finalizationregistry/-/is-finalizationregistry-1.0.2.tgz", + "integrity": "sha512-0by5vtUJs8iFQb5TYUHHPudOR+qXYIMKtiUzvLIZITZUjknFmziyBJuLhVRc+Ds0dREFlskDNJKYIdIzu/9pfw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-generator-function": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/is-generator-function/-/is-generator-function-1.0.10.tgz", + "integrity": "sha512-jsEjy9l3yiXEQ+PsXdmBwEPcOxaXWLspKdplFUVI9vq1iZgIekeC0L167qeu86czQaxed3q/Uzuw0swL0irL8A==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-map": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-map/-/is-map-2.0.3.tgz", + "integrity": "sha512-1Qed0/Hr2m+YqxnM09CjA2d/i6YZNfF6R2oRAOj36eUdS6qIV/huPJNSEpKbupewFs+ZsJlxsjjPbc0/afW6Lw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-negative-zero": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-number-object": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", + "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-path-inside": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", + "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/is-regex": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", + "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-set": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-set/-/is-set-2.0.3.tgz", + "integrity": "sha512-iPAjerrse27/ygGLxw+EBR9agv9Y6uLeYVJMu+QNCoouJ1/1ri0mGrcWpfCqFZuzzx3WjtwxG098X+n4OuRkPg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-shared-array-buffer": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-string": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", + "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-tostringtag": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-symbol": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", + "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-typed-array": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", + "dev": true, + "license": "MIT", + "dependencies": { + "which-typed-array": "^1.1.14" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakmap": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/is-weakmap/-/is-weakmap-2.0.2.tgz", + "integrity": "sha512-K5pXYOm9wqY1RgjpL3YTkF39tni1XajUIkawTLUo9EZEVUFga5gSQJF8nNS7ZwJQ02y+1YCNYcMh+HIf1ZqE+w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakref": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", + "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/is-weakset": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-weakset/-/is-weakset-2.0.3.tgz", + "integrity": "sha512-LvIm3/KWzS9oRFHugab7d+M/GcBXuXX5xZkzPmN+NxihdQlZUQ4dWuSV1xR/sq6upL1TJEDrfBgRepHFdBtSNQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/isarray": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.5.tgz", + "integrity": "sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==", + "dev": true, + "license": "MIT" + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "license": "ISC" + }, + "node_modules/iterator.prototype": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/iterator.prototype/-/iterator.prototype-1.1.2.tgz", + "integrity": "sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.2.1", + "get-intrinsic": "^1.2.1", + "has-symbols": "^1.0.3", + "reflect.getprototypeof": "^1.0.4", + "set-function-name": "^2.0.1" + } + }, + "node_modules/jackspeak": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-2.3.6.tgz", + "integrity": "sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==", + "license": "BlueOak-1.0.0", + "dependencies": { + "@isaacs/cliui": "^8.0.2" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + }, + "optionalDependencies": { + "@pkgjs/parseargs": "^0.11.0" + } + }, + "node_modules/jiti": { + "version": "1.21.6", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", + "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", + "license": "MIT", + "bin": { + "jiti": "bin/jiti.js" + } + }, + "node_modules/js-cookie": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/js-cookie/-/js-cookie-3.0.5.tgz", + "integrity": "sha512-cEiJEAEoIbWfCZYKWhVwFuvPX1gETRYPw6LlaTKoxD3s2AkXzkCjnp6h0V77ozyqj0jakteJ4YqDJT830+lVGw==", + "license": "MIT", + "engines": { + "node": ">=14" + } + }, + "node_modules/js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", + "license": "MIT" + }, + "node_modules/js-yaml": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", + "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", + "dev": true, + "license": "MIT", + "dependencies": { + "argparse": "^2.0.1" + }, + "bin": { + "js-yaml": "bin/js-yaml.js" + } + }, + "node_modules/jsbn": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-1.1.0.tgz", + "integrity": "sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-buffer": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz", + "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-parse-even-better-errors": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", + "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", + "dev": true, + "license": "MIT" + }, + "node_modules/json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/json5": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.2.tgz", + "integrity": "sha512-g1MWMLBiz8FKi1e4w0UyVL3w+iJceWAFBAaBnnGKOpNa5f8TLktkbre1+s6oICydWAm+HRUGTmI+//xv2hvXYA==", + "dev": true, + "license": "MIT", + "dependencies": { + "minimist": "^1.2.0" + }, + "bin": { + "json5": "lib/cli.js" + } + }, + "node_modules/jsonfile": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", + "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "universalify": "^2.0.0" + }, + "optionalDependencies": { + "graceful-fs": "^4.1.6" + } + }, + "node_modules/jsx-ast-utils": { + "version": "3.3.5", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.5.tgz", + "integrity": "sha512-ZZow9HBI5O6EPgSJLUb8n2NKgmVWTwCvHGwFuJlMjvLFqlGG6pjirPhtdsseaLZjSibD8eegzmYpUZwoIlj2cQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "array-includes": "^3.1.6", + "array.prototype.flat": "^1.3.1", + "object.assign": "^4.1.4", + "object.values": "^1.1.6" + }, + "engines": { + "node": ">=4.0" + } + }, + "node_modules/jwt-decode": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/jwt-decode/-/jwt-decode-3.1.2.tgz", + "integrity": "sha512-UfpWE/VZn0iP50d8cz9NrZLM9lSWhcJ+0Gt/nm4by88UL+J1SiKN8/5dkjMmbEzwL2CAe+67GsegCbIKtbp75A==", + "license": "MIT" + }, + "node_modules/keyv": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz", + "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==", + "dev": true, + "license": "MIT", + "dependencies": { + "json-buffer": "3.0.1" + } + }, + "node_modules/language-subtag-registry": { + "version": "0.3.23", + "resolved": "https://registry.npmjs.org/language-subtag-registry/-/language-subtag-registry-0.3.23.tgz", + "integrity": "sha512-0K65Lea881pHotoGEa5gDlMxt3pctLi2RplBb7Ezh4rRdLEOtgi7n4EwK9lamnUCkKBqaeKRVebTq6BAxSkpXQ==", + "dev": true, + "license": "CC0-1.0" + }, + "node_modules/language-tags": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/language-tags/-/language-tags-1.0.9.tgz", + "integrity": "sha512-MbjN408fEndfiQXbFQ1vnd+1NoLDsnQW41410oQBXiyXDMYH5z505juWa4KUE1LqxRC7DgOgZDbKLxHIwm27hA==", + "dev": true, + "license": "MIT", + "dependencies": { + "language-subtag-registry": "^0.3.20" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/levn": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", + "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1", + "type-check": "~0.4.0" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/lilconfig": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.1.0.tgz", + "integrity": "sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==", + "license": "MIT", + "engines": { + "node": ">=10" + } + }, + "node_modules/lines-and-columns": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", + "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==", + "license": "MIT" + }, + "node_modules/locate-path": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", + "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-locate": "^5.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "license": "MIT" + }, + "node_modules/lodash-es": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz", + "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw==", + "license": "MIT" + }, + "node_modules/lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ==", + "license": "MIT" + }, + "node_modules/lodash.isequal": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", + "integrity": "sha512-pDo3lu8Jhfjqls6GkMgpahsF9kCyayhgykjyLMNFTKWrpVdAQtYyB4muAMWozBB4ig/dtWAmsMxLEI8wuz+DYQ==", + "license": "MIT" + }, + "node_modules/lodash.merge": { + "version": "4.6.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", + "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "license": "MIT", + "dependencies": { + "js-tokens": "^3.0.0 || ^4.0.0" + }, + "bin": { + "loose-envify": "cli.js" + } + }, + "node_modules/lower-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", + "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", + "license": "MIT", + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/lru-cache": { + "version": "10.2.2", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.2.tgz", + "integrity": "sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==", + "license": "ISC", + "engines": { + "node": "14 || >=16.14" + } + }, + "node_modules/lucide-react": { + "version": "0.396.0", + "resolved": "https://registry.npmjs.org/lucide-react/-/lucide-react-0.396.0.tgz", + "integrity": "sha512-N/zP+9vEfEYHiMWMpjwH/M5diaV0e4UFe07BpgdzaRYce5QvXi87hixf7F0Xqdr3zuX/9u7H/2D4MVXIK22O0A==", + "license": "ISC", + "peerDependencies": { + "react": "^16.5.1 || ^17.0.0 || ^18.0.0" + } + }, + "node_modules/make-event-props": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/make-event-props/-/make-event-props-1.6.2.tgz", + "integrity": "sha512-iDwf7mA03WPiR8QxvcVHmVWEPfMY1RZXerDVNCRYW7dUr2ppH3J58Rwb39/WG39yTZdRSxr3x+2v22tvI0VEvA==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/make-event-props?sponsor=1" + } + }, + "node_modules/map-age-cleaner": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", + "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", + "license": "MIT", + "dependencies": { + "p-defer": "^1.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/map-obj": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", + "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==", + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/mem": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/mem/-/mem-8.1.1.tgz", + "integrity": "sha512-qFCFUDs7U3b8mBDPyz5EToEKoAkgCzqquIgi9nkkR9bixxOVOre+09lbuH7+9Kn2NFpm56M3GUWVbU2hQgdACA==", + "license": "MIT", + "dependencies": { + "map-age-cleaner": "^0.1.3", + "mimic-fn": "^3.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sindresorhus/mem?sponsor=1" + } + }, + "node_modules/merge2": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", + "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", + "license": "MIT", + "engines": { + "node": ">= 8" + } + }, + "node_modules/micromatch": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", + "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", + "license": "MIT", + "dependencies": { + "braces": "^3.0.3", + "picomatch": "^2.3.1" + }, + "engines": { + "node": ">=8.6" + } + }, + "node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mimic-fn": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-3.1.0.tgz", + "integrity": "sha512-Ysbi9uYW9hFyfrThdDEQuykN4Ey6BuwPD2kpI5ES/nFTDn/98yxYNLZJcgUAKPT/mcrLLKaGzJR9YVxJrIdASQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/minipass": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz", + "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==", + "license": "ISC", + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/mitt": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mitt/-/mitt-3.0.1.tgz", + "integrity": "sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==", + "dev": true, + "license": "MIT" + }, + "node_modules/ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true, + "license": "MIT" + }, + "node_modules/mz": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/mz/-/mz-2.7.0.tgz", + "integrity": "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==", + "license": "MIT", + "dependencies": { + "any-promise": "^1.0.0", + "object-assign": "^4.0.1", + "thenify-all": "^1.0.0" + } + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", + "dev": true, + "license": "MIT" + }, + "node_modules/netmask": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/netmask/-/netmask-2.0.2.tgz", + "integrity": "sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4.0" + } + }, + "node_modules/next": { + "version": "14.2.4", + "resolved": "https://registry.npmjs.org/next/-/next-14.2.4.tgz", + "integrity": "sha512-R8/V7vugY+822rsQGQCjoLhMuC9oFj9SOi4Cl4b2wjDrseD0LRZ10W7R6Czo4w9ZznVSshKjuIomsRjvm9EKJQ==", + "license": "MIT", + "dependencies": { + "@next/env": "14.2.4", + "@swc/helpers": "0.5.5", + "busboy": "1.6.0", + "caniuse-lite": "^1.0.30001579", + "graceful-fs": "^4.2.11", + "postcss": "8.4.31", + "styled-jsx": "5.1.1" + }, + "bin": { + "next": "dist/bin/next" + }, + "engines": { + "node": ">=18.17.0" + }, + "optionalDependencies": { + "@next/swc-darwin-arm64": "14.2.4", + "@next/swc-darwin-x64": "14.2.4", + "@next/swc-linux-arm64-gnu": "14.2.4", + "@next/swc-linux-arm64-musl": "14.2.4", + "@next/swc-linux-x64-gnu": "14.2.4", + "@next/swc-linux-x64-musl": "14.2.4", + "@next/swc-win32-arm64-msvc": "14.2.4", + "@next/swc-win32-ia32-msvc": "14.2.4", + "@next/swc-win32-x64-msvc": "14.2.4" + }, + "peerDependencies": { + "@opentelemetry/api": "^1.1.0", + "@playwright/test": "^1.41.2", + "react": "^18.2.0", + "react-dom": "^18.2.0", + "sass": "^1.3.0" + }, + "peerDependenciesMeta": { + "@opentelemetry/api": { + "optional": true + }, + "@playwright/test": { + "optional": true + }, + "sass": { + "optional": true + } + } + }, + "node_modules/next/node_modules/postcss": { + "version": "8.4.31", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", + "integrity": "sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "nanoid": "^3.3.6", + "picocolors": "^1.0.0", + "source-map-js": "^1.0.2" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/nextjs-toploader": { + "version": "3.7.15", + "resolved": "https://registry.npmjs.org/nextjs-toploader/-/nextjs-toploader-3.7.15.tgz", + "integrity": "sha512-DvvXEJVRPfE2j1HVXgFhmPl8pRcLb/4mvyVBDuYdMdkbEY7KJghp0fG5iOZ002cV6awbBw9j/Di7vQL8LRazxQ==", + "license": "MIT", + "dependencies": { + "nprogress": "^0.2.0", + "prop-types": "^15.8.1" + }, + "funding": { + "url": "https://buymeacoffee.com/thesgj" + }, + "peerDependencies": { + "next": ">= 6.0.0", + "react": ">= 16.0.0", + "react-dom": ">= 16.0.0" + } + }, + "node_modules/no-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", + "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", + "license": "MIT", + "dependencies": { + "lower-case": "^2.0.2", + "tslib": "^2.0.3" + } + }, + "node_modules/node-fetch": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.7.0.tgz", + "integrity": "sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==", + "license": "MIT", + "dependencies": { + "whatwg-url": "^5.0.0" + }, + "engines": { + "node": "4.x || >=6.0.0" + }, + "peerDependencies": { + "encoding": "^0.1.0" + }, + "peerDependenciesMeta": { + "encoding": { + "optional": true + } + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/nprogress": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/nprogress/-/nprogress-0.2.0.tgz", + "integrity": "sha512-I19aIingLgR1fmhftnbWWO3dXc0hSxqHQHQb3H8m+K3TnEn/iSeTZZOyvKXWqQESMwuUVnatlCnZdLBZZt2VSA==", + "license": "MIT" + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-hash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-3.0.0.tgz", + "integrity": "sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==", + "license": "MIT", + "engines": { + "node": ">= 6" + } + }, + "node_modules/object-inspect": { + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-is": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/object-is/-/object-is-1.1.6.tgz", + "integrity": "sha512-F8cZ+KfGlSGi09lJT7/Nd6KJZ9ygtvYC0/UYYLI9nmQKLMnydpB9yvbv9K1uSkEu7FU9vYPmVwLg328tX+ot3Q==", + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.assign": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.5.tgz", + "integrity": "sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "has-symbols": "^1.0.3", + "object-keys": "^1.1.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.entries": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", + "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.fromentries": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", + "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.groupby": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.3.tgz", + "integrity": "sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/object.hasown": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.4.tgz", + "integrity": "sha512-FZ9LZt9/RHzGySlBARE3VF+gE26TxR38SdmqOqliuTnl9wrKulaQs+4dee1V+Io8VfxqzAfHu6YuRgUy8OHoTg==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/object.values": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", + "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "license": "ISC", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/optionator": { + "version": "0.9.4", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.4.tgz", + "integrity": "sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==", + "dev": true, + "license": "MIT", + "dependencies": { + "deep-is": "^0.1.3", + "fast-levenshtein": "^2.0.6", + "levn": "^0.4.1", + "prelude-ls": "^1.2.1", + "type-check": "^0.4.0", + "word-wrap": "^1.2.5" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/p-defer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", + "integrity": "sha512-wB3wfAxZpk2AzOfUMJNL+d36xothRSyj8EXOa4f6GMqYDN9BJaaSISbsk+wS9abmnebVw95C2Kb5t85UmpCxuw==", + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/p-limit": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", + "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "yocto-queue": "^0.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", + "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "p-limit": "^3.0.2" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/pac-proxy-agent": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/pac-proxy-agent/-/pac-proxy-agent-7.0.1.tgz", + "integrity": "sha512-ASV8yU4LLKBAjqIPMbrgtaKIvxQri/yh2OpI+S6hVa9JRkUI3Y3NPFbfngDtY7oFtSMD3w31Xns89mDa3Feo5A==", + "dev": true, + "license": "MIT", + "dependencies": { + "@tootallnate/quickjs-emscripten": "^0.23.0", + "agent-base": "^7.0.2", + "debug": "^4.3.4", + "get-uri": "^6.0.1", + "http-proxy-agent": "^7.0.0", + "https-proxy-agent": "^7.0.2", + "pac-resolver": "^7.0.0", + "socks-proxy-agent": "^8.0.2" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/pac-resolver": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-7.0.1.tgz", + "integrity": "sha512-5NPgf87AT2STgwa2ntRMr45jTKrYBGkVU36yT0ig/n/GMAa3oPqhZfIQ2kMEimReg0+t9kZViDVZ83qfVUlckg==", + "dev": true, + "license": "MIT", + "dependencies": { + "degenerator": "^5.0.0", + "netmask": "^2.0.2" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/parchment": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/parchment/-/parchment-3.0.0.tgz", + "integrity": "sha512-HUrJFQ/StvgmXRcQ1ftY6VEZUq3jA2t9ncFN4F84J/vN0/FPpQF+8FKXb3l6fLces6q0uOHj6NJn+2xvZnxO6A==", + "license": "BSD-3-Clause" + }, + "node_modules/parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "dev": true, + "license": "MIT", + "dependencies": { + "callsites": "^3.0.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-json": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", + "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-even-better-errors": "^2.3.0", + "lines-and-columns": "^1.1.6" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-parse": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", + "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", + "license": "MIT" + }, + "node_modules/path-scurry": { + "version": "1.11.1", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz", + "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==", + "license": "BlueOak-1.0.0", + "dependencies": { + "lru-cache": "^10.2.0", + "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" + }, + "engines": { + "node": ">=16 || 14 >=14.18" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/path-to-regexp": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.2.tgz", + "integrity": "sha512-GQX3SSMokngb36+whdpRXE+3f9V8UzyAorlYvOGx87ufGHehNTn5lCxrKtLyZ4Yl/wEKnNnr98ZzOwwDZV5ogw==", + "license": "MIT" + }, + "node_modules/path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/pend": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", + "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==", + "dev": true, + "license": "MIT" + }, + "node_modules/picocolors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==", + "license": "ISC" + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "license": "MIT", + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/pirates": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.6.tgz", + "integrity": "sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==", + "license": "MIT", + "engines": { + "node": ">= 6" + } + }, + "node_modules/possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/postcss": { + "version": "8.4.38", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.38.tgz", + "integrity": "sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.0.0", + "source-map-js": "^1.2.0" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/postcss-import": { + "version": "15.1.0", + "resolved": "https://registry.npmjs.org/postcss-import/-/postcss-import-15.1.0.tgz", + "integrity": "sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==", + "license": "MIT", + "dependencies": { + "postcss-value-parser": "^4.0.0", + "read-cache": "^1.0.0", + "resolve": "^1.1.7" + }, + "engines": { + "node": ">=14.0.0" + }, + "peerDependencies": { + "postcss": "^8.0.0" + } + }, + "node_modules/postcss-js": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-js/-/postcss-js-4.0.1.tgz", + "integrity": "sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==", + "license": "MIT", + "dependencies": { + "camelcase-css": "^2.0.1" + }, + "engines": { + "node": "^12 || ^14 || >= 16" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.4.21" + } + }, + "node_modules/postcss-load-config": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-4.0.2.tgz", + "integrity": "sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "lilconfig": "^3.0.0", + "yaml": "^2.3.4" + }, + "engines": { + "node": ">= 14" + }, + "peerDependencies": { + "postcss": ">=8.0.9", + "ts-node": ">=9.0.0" + }, + "peerDependenciesMeta": { + "postcss": { + "optional": true + }, + "ts-node": { + "optional": true + } + } + }, + "node_modules/postcss-load-config/node_modules/lilconfig": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.2.tgz", + "integrity": "sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==", + "license": "MIT", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/antonk52" + } + }, + "node_modules/postcss-nested": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/postcss-nested/-/postcss-nested-6.0.1.tgz", + "integrity": "sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==", + "license": "MIT", + "dependencies": { + "postcss-selector-parser": "^6.0.11" + }, + "engines": { + "node": ">=12.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + "peerDependencies": { + "postcss": "^8.2.14" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.0.tgz", + "integrity": "sha512-UMz42UD0UY0EApS0ZL9o1XnLhSTtvvvLe5Dc2H2O56fvRZi+KulDyf5ctDhhtYJBGKStV2FL1fy6253cmLgqVQ==", + "license": "MIT", + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", + "license": "MIT" + }, + "node_modules/prelude-ls": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", + "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/prettier": { + "version": "3.2.5", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.2.5.tgz", + "integrity": "sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==", + "license": "MIT", + "bin": { + "prettier": "bin/prettier.cjs" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" + } + }, + "node_modules/progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/prop-types": { + "version": "15.8.1", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", + "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.13.1" + } + }, + "node_modules/proxy-agent": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/proxy-agent/-/proxy-agent-6.4.0.tgz", + "integrity": "sha512-u0piLU+nCOHMgGjRbimiXmA9kM/L9EHh3zL81xCdp7m+Y2pHIsnmbdDoEDoAz5geaonNR6q6+yOPQs6n4T6sBQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "agent-base": "^7.0.2", + "debug": "^4.3.4", + "http-proxy-agent": "^7.0.1", + "https-proxy-agent": "^7.0.3", + "lru-cache": "^7.14.1", + "pac-proxy-agent": "^7.0.1", + "proxy-from-env": "^1.1.0", + "socks-proxy-agent": "^8.0.2" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/proxy-agent/node_modules/lru-cache": { + "version": "7.18.3", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz", + "integrity": "sha512-jumlc0BIUrS3qJGgIkWZsyfAM7NCWiBcCDhnd+3NNM5KbBmLTgHVfWBcg6W+rLUsIpzpERPsvwUP7CckAQSOoA==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=12" + } + }, + "node_modules/proxy-from-env": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", + "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", + "license": "MIT" + }, + "node_modules/pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "dev": true, + "license": "MIT", + "dependencies": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "node_modules/punycode": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", + "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/puppeteer": { + "version": "22.12.1", + "resolved": "https://registry.npmjs.org/puppeteer/-/puppeteer-22.12.1.tgz", + "integrity": "sha512-1GxY8dnEnHr1SLzdSDr0FCjM6JQfAh2E2I/EqzeF8a58DbGVk9oVjj4lFdqNoVbpgFSpAbz7VER9St7S1wDpNg==", + "dev": true, + "hasInstallScript": true, + "license": "Apache-2.0", + "dependencies": { + "@puppeteer/browsers": "2.2.3", + "cosmiconfig": "^9.0.0", + "devtools-protocol": "0.0.1299070", + "puppeteer-core": "22.12.1" + }, + "bin": { + "puppeteer": "lib/esm/puppeteer/node/cli.js" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/puppeteer/node_modules/cosmiconfig": { + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-9.0.0.tgz", + "integrity": "sha512-itvL5h8RETACmOTFc4UfIyB2RfEHi71Ax6E/PivVxq9NseKbOWpeyHEOIbmAw1rs8Ak0VursQNww7lf7YtUwzg==", + "dev": true, + "license": "MIT", + "dependencies": { + "env-paths": "^2.2.1", + "import-fresh": "^3.3.0", + "js-yaml": "^4.1.0", + "parse-json": "^5.2.0" + }, + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/d-fischer" + }, + "peerDependencies": { + "typescript": ">=4.9.5" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/puppeteer/node_modules/puppeteer-core": { + "version": "22.12.1", + "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-22.12.1.tgz", + "integrity": "sha512-XmqeDPVdC5/3nGJys1jbgeoZ02wP0WV1GBlPtr/ULRbGXJFuqgXMcKQ3eeNtFpBzGRbpeoCGWHge1ZWKWl0Exw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@puppeteer/browsers": "2.2.3", + "chromium-bidi": "0.5.24", + "debug": "^4.3.5", + "devtools-protocol": "0.0.1299070", + "ws": "^8.17.1" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/puppeteer/node_modules/ws": { + "version": "8.18.0", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.18.0.tgz", + "integrity": "sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": ">=5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/queue-microtask": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", + "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/queue-tick": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/queue-tick/-/queue-tick-1.0.1.tgz", + "integrity": "sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==", + "dev": true, + "license": "MIT" + }, + "node_modules/quill": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/quill/-/quill-2.0.2.tgz", + "integrity": "sha512-QfazNrhMakEdRG57IoYFwffUIr04LWJxbS/ZkidRFXYCQt63c1gK6Z7IHUXMx/Vh25WgPBU42oBaNzQ0K1R/xw==", + "license": "BSD-3-Clause", + "dependencies": { + "eventemitter3": "^5.0.1", + "lodash-es": "^4.17.21", + "parchment": "^3.0.0", + "quill-delta": "^5.1.0" + }, + "engines": { + "npm": ">=8.2.3" + } + }, + "node_modules/quill-delta": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/quill-delta/-/quill-delta-5.1.0.tgz", + "integrity": "sha512-X74oCeRI4/p0ucjb5Ma8adTXd9Scumz367kkMK5V/IatcX6A0vlgLgKbzXWy5nZmCGeNJm2oQX0d2Eqj+ZIlCA==", + "license": "MIT", + "dependencies": { + "fast-diff": "^1.3.0", + "lodash.clonedeep": "^4.5.0", + "lodash.isequal": "^4.5.0" + }, + "engines": { + "node": ">= 12.0.0" + } + }, + "node_modules/react": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react/-/react-18.3.1.tgz", + "integrity": "sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-calendar": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/react-calendar/-/react-calendar-5.0.0.tgz", + "integrity": "sha512-bHcE5e5f+VUKLd4R19BGkcSQLpuwjKBVG0fKz74cwPW5xDfNsReHdDbfd4z3mdjuUuZzVtw4Q920mkwK5/ZOEg==", + "license": "MIT", + "dependencies": { + "@wojtekmaj/date-utils": "^1.1.3", + "clsx": "^2.0.0", + "get-user-locale": "^2.2.1", + "warning": "^4.0.0" + }, + "funding": { + "url": "https://github.com/wojtekmaj/react-calendar?sponsor=1" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/react-color-palette": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/react-color-palette/-/react-color-palette-7.1.1.tgz", + "integrity": "sha512-fBmTRWmTCrH08yZwU+5647pUKABRM6h4TS/43Q/mt/TLH1hyTfWopCc6wm2L9IoynPcOT7SaOm3Xmdz+goFEDw==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "react": ">=16.8" + } + }, + "node_modules/react-color-pallete": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/react-color-pallete/-/react-color-pallete-1.0.1.tgz", + "integrity": "sha512-j4Yh6K8lh3LWP0ExYV2qQPp1KT/y4fTkTJH/UsBWByr+q74zcNcszwHz062wbxqux+kK76e4OUfDgMolW9zzXg==" + }, + "node_modules/react-date-picker": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/react-date-picker/-/react-date-picker-11.0.0.tgz", + "integrity": "sha512-l+siu5HSZ/ciGL1293KCAHl4o9aD5rw16V4tB0C43h7QbMv2dWGgj7Dxgt8iztLaPVtEfOt/+sxNiTYw4WVq6A==", + "license": "MIT", + "dependencies": { + "@wojtekmaj/date-utils": "^1.1.3", + "clsx": "^2.0.0", + "get-user-locale": "^2.2.1", + "make-event-props": "^1.6.0", + "react-calendar": "^5.0.0", + "react-fit": "^2.0.0", + "update-input-width": "^1.4.0" + }, + "funding": { + "url": "https://github.com/wojtekmaj/react-date-picker?sponsor=1" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/react-dom": { + "version": "18.3.1", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.3.1.tgz", + "integrity": "sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0", + "scheduler": "^0.23.2" + }, + "peerDependencies": { + "react": "^18.3.1" + } + }, + "node_modules/react-easy-sort": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/react-easy-sort/-/react-easy-sort-1.6.0.tgz", + "integrity": "sha512-zd9Nn90wVlZPEwJrpqElN87sf9GZnFR1StfjgNQVbSpR5QTSzCHjEYK6REuwq49Ip+76KOMSln9tg/ST2KLelg==", + "license": "MIT", + "dependencies": { + "array-move": "^3.0.1", + "tslib": "2.0.1" + }, + "engines": { + "node": ">=16" + }, + "peerDependencies": { + "react": ">=16.4.0", + "react-dom": ">=16.4.0" + } + }, + "node_modules/react-easy-sort/node_modules/array-move": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/array-move/-/array-move-3.0.1.tgz", + "integrity": "sha512-H3Of6NIn2nNU1gsVDqDnYKY/LCdWvCMMOWifNGhKcVQgiZ6nOek39aESOvro6zmueP07exSl93YLvkN4fZOkSg==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/react-easy-sort/node_modules/tslib": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.0.1.tgz", + "integrity": "sha512-SgIkNheinmEBgx1IUNirK0TUD4X9yjjBRTqqjggWCU3pUEqIk3/Uwl3yRixYKT6WjQuGiwDv4NomL3wqRCj+CQ==", + "license": "0BSD" + }, + "node_modules/react-fit": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/react-fit/-/react-fit-2.0.1.tgz", + "integrity": "sha512-Eip6ALs/+6Jv82Si0I9UnfysdwVlAhkkZRycgmMdnj7jwUg69SVFp84ICxwB8zszkfvJJ2MGAAo9KAYM8ZUykQ==", + "license": "MIT", + "dependencies": { + "detect-element-overflow": "^1.4.0", + "warning": "^4.0.0" + }, + "funding": { + "url": "https://github.com/wojtekmaj/react-fit?sponsor=1" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0", + "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "@types/react-dom": { + "optional": true + } + } + }, + "node_modules/react-hot-toast": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/react-hot-toast/-/react-hot-toast-2.4.1.tgz", + "integrity": "sha512-j8z+cQbWIM5LY37pR6uZR6D4LfseplqnuAO4co4u8917hBUvXlEqyP1ZzqVLcqoyUesZZv/ImreoCeHVDpE5pQ==", + "license": "MIT", + "dependencies": { + "goober": "^2.1.10" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "react": ">=16", + "react-dom": ">=16" + } + }, + "node_modules/react-is": { + "version": "16.13.1", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", + "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==", + "license": "MIT" + }, + "node_modules/react-quill": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/react-quill/-/react-quill-2.0.0.tgz", + "integrity": "sha512-4qQtv1FtCfLgoD3PXAur5RyxuUbPXQGOHgTlFie3jtxp43mXDtzCKaOgQ3mLyZfi1PUlyjycfivKelFhy13QUg==", + "license": "MIT", + "dependencies": { + "@types/quill": "^1.3.10", + "lodash": "^4.17.4", + "quill": "^1.3.7" + }, + "peerDependencies": { + "react": "^16 || ^17 || ^18", + "react-dom": "^16 || ^17 || ^18" + } + }, + "node_modules/react-quill/node_modules/deep-equal": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.1.2.tgz", + "integrity": "sha512-5tdhKF6DbU7iIzrIOa1AOUt39ZRm13cmL1cGEh//aqR8x9+tNfbywRf0n5FD/18OKMdo7DNEtrX2t22ZAkI+eg==", + "license": "MIT", + "dependencies": { + "is-arguments": "^1.1.1", + "is-date-object": "^1.0.5", + "is-regex": "^1.1.4", + "object-is": "^1.1.5", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.5.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/react-quill/node_modules/eventemitter3": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-2.0.3.tgz", + "integrity": "sha512-jLN68Dx5kyFHaePoXWPsCGW5qdyZQtLYHkxkg02/Mz6g0kYpDx4FyP6XfArhQdlOC4b8Mv+EMxPo/8La7Tzghg==", + "license": "MIT" + }, + "node_modules/react-quill/node_modules/fast-diff": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.1.2.tgz", + "integrity": "sha512-KaJUt+M9t1qaIteSvjc6P3RbMdXsNhK61GRftR6SNxqmhthcd9MGIi4T+o0jD8LUSpSnSKXE20nLtJ3fOHxQig==", + "license": "Apache-2.0" + }, + "node_modules/react-quill/node_modules/parchment": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/parchment/-/parchment-1.1.4.tgz", + "integrity": "sha512-J5FBQt/pM2inLzg4hEWmzQx/8h8D0CiDxaG3vyp9rKrQRSDgBlhjdP5jQGgosEajXPSQouXGHOmVdgo7QmJuOg==", + "license": "BSD-3-Clause" + }, + "node_modules/react-quill/node_modules/quill": { + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/quill/-/quill-1.3.7.tgz", + "integrity": "sha512-hG/DVzh/TiknWtE6QmWAF/pxoZKYxfe3J/d/+ShUWkDvvkZQVTPeVmUJVu1uE6DDooC4fWTiCLh84ul89oNz5g==", + "license": "BSD-3-Clause", + "dependencies": { + "clone": "^2.1.1", + "deep-equal": "^1.0.1", + "eventemitter3": "^2.0.3", + "extend": "^3.0.2", + "parchment": "^1.1.4", + "quill-delta": "^3.6.2" + } + }, + "node_modules/react-quill/node_modules/quill-delta": { + "version": "3.6.3", + "resolved": "https://registry.npmjs.org/quill-delta/-/quill-delta-3.6.3.tgz", + "integrity": "sha512-wdIGBlcX13tCHOXGMVnnTVFtGRLoP0imqxM696fIPwIf5ODIYUHIvHbZcyvGlZFiFhK5XzDC2lpjbxRhnM05Tg==", + "license": "MIT", + "dependencies": { + "deep-equal": "^1.0.1", + "extend": "^3.0.2", + "fast-diff": "1.1.2" + }, + "engines": { + "node": ">=0.10" + } + }, + "node_modules/react-remove-scroll": { + "version": "2.5.7", + "resolved": "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.5.7.tgz", + "integrity": "sha512-FnrTWO4L7/Bhhf3CYBNArEG/yROV0tKmTv7/3h9QCFvH6sndeFf1wPqOcbFVu5VAulS5dV1wGT3GZZ/1GawqiA==", + "license": "MIT", + "dependencies": { + "react-remove-scroll-bar": "^2.3.4", + "react-style-singleton": "^2.2.1", + "tslib": "^2.1.0", + "use-callback-ref": "^1.3.0", + "use-sidecar": "^1.1.2" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/react-remove-scroll-bar": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.6.tgz", + "integrity": "sha512-DtSYaao4mBmX+HDo5YWYdBWQwYIQQshUV/dVxFxK+KM26Wjwp1gZ6rv6OC3oujI6Bfu6Xyg3TwK533AQutsn/g==", + "license": "MIT", + "dependencies": { + "react-style-singleton": "^2.2.1", + "tslib": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/react-style-singleton": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/react-style-singleton/-/react-style-singleton-2.2.1.tgz", + "integrity": "sha512-ZWj0fHEMyWkHzKYUr2Bs/4zU6XLmq9HsgBURm7g5pAVfyn49DgUiNgY2d4lXRlYSiCif9YBGpQleewkcqddc7g==", + "license": "MIT", + "dependencies": { + "get-nonce": "^1.0.0", + "invariant": "^2.2.4", + "tslib": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/read-cache": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/read-cache/-/read-cache-1.0.0.tgz", + "integrity": "sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==", + "license": "MIT", + "dependencies": { + "pify": "^2.3.0" + } + }, + "node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "license": "MIT", + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/reflect.getprototypeof": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/reflect.getprototypeof/-/reflect.getprototypeof-1.0.6.tgz", + "integrity": "sha512-fmfw4XgoDke3kdI6h4xcUz1dG8uaiv5q9gcEwLS4Pnth2kxT+GZ7YehS1JTMGBQmtV7Y4GFGbs2re2NqhdozUg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.1", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "globalthis": "^1.0.3", + "which-builtin-type": "^1.1.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/regenerator-runtime": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz", + "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==", + "license": "MIT" + }, + "node_modules/regexp.prototype.flags": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/resolve": { + "version": "1.22.8", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.8.tgz", + "integrity": "sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==", + "license": "MIT", + "dependencies": { + "is-core-module": "^2.13.0", + "path-parse": "^1.0.7", + "supports-preserve-symlinks-flag": "^1.0.0" + }, + "bin": { + "resolve": "bin/resolve" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/resolve-pkg-maps": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz", + "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1" + } + }, + "node_modules/reusify": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", + "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", + "license": "MIT", + "engines": { + "iojs": ">=1.0.0", + "node": ">=0.10.0" + } + }, + "node_modules/rimraf": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", + "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/run-parallel": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", + "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT", + "dependencies": { + "queue-microtask": "^1.2.2" + } + }, + "node_modules/safe-array-concat": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "get-intrinsic": "^1.2.4", + "has-symbols": "^1.0.3", + "isarray": "^2.0.5" + }, + "engines": { + "node": ">=0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safe-regex-test": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-regex": "^1.1.4" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "license": "MIT", + "optional": true, + "peer": true + }, + "node_modules/scheduler": { + "version": "0.23.2", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.2.tgz", + "integrity": "sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.1.0" + } + }, + "node_modules/semver": { + "version": "7.6.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", + "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/server-only": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/server-only/-/server-only-0.0.1.tgz", + "integrity": "sha512-qepMx2JxAa5jjfzxG79yPPq+8BuFToHd1hm7kI+Z4zAq1ftQiP7HcxMhDDItrbtwVeLg/cY2JnKnrcFkmiswNA==", + "license": "MIT" + }, + "node_modules/set-function-length": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "function-bind": "^1.1.2", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/set-function-name": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", + "license": "MIT", + "dependencies": { + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", + "functions-have-names": "^1.2.3", + "has-property-descriptors": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "license": "MIT", + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/side-channel": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "license": "ISC", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/smart-buffer": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/smart-buffer/-/smart-buffer-4.2.0.tgz", + "integrity": "sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 6.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/snake-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", + "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", + "license": "MIT", + "dependencies": { + "dot-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/snakecase-keys": { + "version": "5.4.4", + "resolved": "https://registry.npmjs.org/snakecase-keys/-/snakecase-keys-5.4.4.tgz", + "integrity": "sha512-YTywJG93yxwHLgrYLZjlC75moVEX04LZM4FHfihjHe1FCXm+QaLOFfSf535aXOAd0ArVQMWUAe8ZPm4VtWyXaA==", + "license": "MIT", + "dependencies": { + "map-obj": "^4.1.0", + "snake-case": "^3.0.4", + "type-fest": "^2.5.2" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/snakecase-keys/node_modules/type-fest": { + "version": "2.19.0", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-2.19.0.tgz", + "integrity": "sha512-RAH822pAdBgcNMAfWnCBU3CFZcfZ/i1eZjwFU/dsLKumyuuP3niueg2UAukXYF0E2AAoc82ZSSf9J0WQBinzHA==", + "license": "(MIT OR CC0-1.0)", + "engines": { + "node": ">=12.20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/socks": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/socks/-/socks-2.8.3.tgz", + "integrity": "sha512-l5x7VUUWbjVFbafGLxPWkYsHIhEvmF85tbIeFZWc8ZPtoMyybuEhL7Jye/ooC4/d48FgOjSJXgsF/AJPYCW8Zw==", + "dev": true, + "license": "MIT", + "dependencies": { + "ip-address": "^9.0.5", + "smart-buffer": "^4.2.0" + }, + "engines": { + "node": ">= 10.0.0", + "npm": ">= 3.0.0" + } + }, + "node_modules/socks-proxy-agent": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/socks-proxy-agent/-/socks-proxy-agent-8.0.3.tgz", + "integrity": "sha512-VNegTZKhuGq5vSD6XNKlbqWhyt/40CgoEw8XxD6dhnm8Jq9IEa3nIa4HwnM8XOqU0CdB0BwWVXusqiFXfHB3+A==", + "dev": true, + "license": "MIT", + "dependencies": { + "agent-base": "^7.1.1", + "debug": "^4.3.4", + "socks": "^2.7.1" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/source-map-js": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", + "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/sprintf-js": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.3.tgz", + "integrity": "sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/std-env": { + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.7.0.tgz", + "integrity": "sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==", + "license": "MIT" + }, + "node_modules/stop-iteration-iterator": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/stop-iteration-iterator/-/stop-iteration-iterator-1.0.0.tgz", + "integrity": "sha512-iCGQj+0l0HOdZ2AEeBADlsRC+vsnDsZsbdSiH1yNSjcfKM7fdpCMfqAL/dwF5BLiw/XhRft/Wax6zQbhq2BcjQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "internal-slot": "^1.0.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/streamsearch": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", + "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", + "engines": { + "node": ">=10.0.0" + } + }, + "node_modules/streamx": { + "version": "2.18.0", + "resolved": "https://registry.npmjs.org/streamx/-/streamx-2.18.0.tgz", + "integrity": "sha512-LLUC1TWdjVdn1weXGcSxyTR3T4+acB6tVGXT95y0nGbca4t4o/ng1wKAGTljm9VicuCVLvRlqFYXYy5GwgM7sQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "fast-fifo": "^1.3.2", + "queue-tick": "^1.0.1", + "text-decoder": "^1.1.0" + }, + "optionalDependencies": { + "bare-events": "^2.2.0" + } + }, + "node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "license": "MIT", + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/string-width-cjs": { + "name": "string-width", + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/string-width-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "license": "MIT" + }, + "node_modules/string-width/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/string-width/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/string.prototype.includes": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/string.prototype.includes/-/string.prototype.includes-2.0.0.tgz", + "integrity": "sha512-E34CkBgyeqNDcrbU76cDjL5JLcVrtSdYq0MEh/B10r17pRP4ciHLwTgnuLV8Ay6cgEMLkcBkFCKyFZ43YldYzg==", + "dev": true, + "license": "MIT", + "dependencies": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.5" + } + }, + "node_modules/string.prototype.matchall": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.11.tgz", + "integrity": "sha512-NUdh0aDavY2og7IbBPenWqR9exH+E26Sv8e0/eTe1tltDGZL+GtBkDAnnyBtmekfK6/Dq3MkcGtzXFEd1LQrtg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", + "gopd": "^1.0.1", + "has-symbols": "^1.0.3", + "internal-slot": "^1.0.7", + "regexp.prototype.flags": "^1.5.2", + "set-function-name": "^2.0.2", + "side-channel": "^1.0.6" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trim": { + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimend": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/string.prototype.trimstart": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", + "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-ansi-cjs": { + "name": "strip-ansi", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/strip-json-comments": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", + "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/styled-jsx": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/styled-jsx/-/styled-jsx-5.1.1.tgz", + "integrity": "sha512-pW7uC1l4mBZ8ugbiZrcIsiIvVx1UmTfw7UkC3Um2tmfUq9Bhk8IiyEIPl6F8agHgjzku6j0xQEZbfA5uSgSaCw==", + "license": "MIT", + "dependencies": { + "client-only": "0.0.1" + }, + "engines": { + "node": ">= 12.0.0" + }, + "peerDependencies": { + "react": ">= 16.8.0 || 17.x.x || ^18.0.0-0" + }, + "peerDependenciesMeta": { + "@babel/core": { + "optional": true + }, + "babel-plugin-macros": { + "optional": true + } + } + }, + "node_modules/sucrase": { + "version": "3.35.0", + "resolved": "https://registry.npmjs.org/sucrase/-/sucrase-3.35.0.tgz", + "integrity": "sha512-8EbVDiu9iN/nESwxeSxDKe0dunta1GOlHufmSSXxMD2z2/tMZpDMpvXQGsc+ajGo8y2uYUmixaSRUc/QPoQ0GA==", + "license": "MIT", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.2", + "commander": "^4.0.0", + "glob": "^10.3.10", + "lines-and-columns": "^1.1.6", + "mz": "^2.7.0", + "pirates": "^4.0.1", + "ts-interface-checker": "^0.1.9" + }, + "bin": { + "sucrase": "bin/sucrase", + "sucrase-node": "bin/sucrase-node" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + } + }, + "node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "license": "MIT", + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/supports-preserve-symlinks-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", + "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/swr": { + "version": "2.2.5", + "resolved": "https://registry.npmjs.org/swr/-/swr-2.2.5.tgz", + "integrity": "sha512-QtxqyclFeAsxEUeZIYmsaQ0UjimSq1RZ9Un7I68/0ClKK/U3LoyQunwkQfJZr2fc22DfIXLNDc2wFyTEikCUpg==", + "license": "MIT", + "dependencies": { + "client-only": "^0.0.1", + "use-sync-external-store": "^1.2.0" + }, + "peerDependencies": { + "react": "^16.11.0 || ^17.0.0 || ^18.0.0" + } + }, + "node_modules/tailwind-merge": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/tailwind-merge/-/tailwind-merge-2.3.0.tgz", + "integrity": "sha512-vkYrLpIP+lgR0tQCG6AP7zZXCTLc1Lnv/CCRT3BqJ9CZ3ui2++GPaGb1x/ILsINIMSYqqvrpqjUFsMNLlW99EA==", + "license": "MIT", + "dependencies": { + "@babel/runtime": "^7.24.1" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/dcastil" + } + }, + "node_modules/tailwindcss": { + "version": "3.4.4", + "resolved": "https://registry.npmjs.org/tailwindcss/-/tailwindcss-3.4.4.tgz", + "integrity": "sha512-ZoyXOdJjISB7/BcLTR6SEsLgKtDStYyYZVLsUtWChO4Ps20CBad7lfJKVDiejocV4ME1hLmyY0WJE3hSDcmQ2A==", + "license": "MIT", + "dependencies": { + "@alloc/quick-lru": "^5.2.0", + "arg": "^5.0.2", + "chokidar": "^3.5.3", + "didyoumean": "^1.2.2", + "dlv": "^1.1.3", + "fast-glob": "^3.3.0", + "glob-parent": "^6.0.2", + "is-glob": "^4.0.3", + "jiti": "^1.21.0", + "lilconfig": "^2.1.0", + "micromatch": "^4.0.5", + "normalize-path": "^3.0.0", + "object-hash": "^3.0.0", + "picocolors": "^1.0.0", + "postcss": "^8.4.23", + "postcss-import": "^15.1.0", + "postcss-js": "^4.0.1", + "postcss-load-config": "^4.0.1", + "postcss-nested": "^6.0.1", + "postcss-selector-parser": "^6.0.11", + "resolve": "^1.22.2", + "sucrase": "^3.32.0" + }, + "bin": { + "tailwind": "lib/cli.js", + "tailwindcss": "lib/cli.js" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/tailwindcss-animate": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/tailwindcss-animate/-/tailwindcss-animate-1.0.7.tgz", + "integrity": "sha512-bl6mpH3T7I3UFxuvDEXLxy/VuFxBk5bbzplh7tXI68mwMokNYd1t9qPBHlnyTwfa4JGC4zP516I1hYYtQ/vspA==", + "license": "MIT", + "peerDependencies": { + "tailwindcss": ">=3.0.0 || insiders" + } + }, + "node_modules/tapable": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", + "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/tar-fs": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-3.0.5.tgz", + "integrity": "sha512-JOgGAmZyMgbqpLwct7ZV8VzkEB6pxXFBVErLtb+XCOqzc6w1xiWKI9GVd6bwk68EX7eJ4DWmfXVmq8K2ziZTGg==", + "dev": true, + "license": "MIT", + "dependencies": { + "pump": "^3.0.0", + "tar-stream": "^3.1.5" + }, + "optionalDependencies": { + "bare-fs": "^2.1.1", + "bare-path": "^2.1.0" + } + }, + "node_modules/tar-stream": { + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-3.1.7.tgz", + "integrity": "sha512-qJj60CXt7IU1Ffyc3NJMjh6EkuCFej46zUqJ4J7pqYlThyd9bO0XBTmcOIhSzZJVWfsLks0+nle/j538YAW9RQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "b4a": "^1.6.4", + "fast-fifo": "^1.2.0", + "streamx": "^2.15.0" + } + }, + "node_modules/text-decoder": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/text-decoder/-/text-decoder-1.1.0.tgz", + "integrity": "sha512-TmLJNj6UgX8xcUZo4UDStGQtDiTzF7BzWlzn9g7UWrjkpHr5uJTK1ld16wZ3LXb2vb6jH8qU89dW5whuMdXYdw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "b4a": "^1.6.4" + } + }, + "node_modules/text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", + "dev": true, + "license": "MIT" + }, + "node_modules/thenify": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/thenify/-/thenify-3.3.1.tgz", + "integrity": "sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==", + "license": "MIT", + "dependencies": { + "any-promise": "^1.0.0" + } + }, + "node_modules/thenify-all": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/thenify-all/-/thenify-all-1.6.0.tgz", + "integrity": "sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==", + "license": "MIT", + "dependencies": { + "thenify": ">= 3.1.0 < 4" + }, + "engines": { + "node": ">=0.8" + } + }, + "node_modules/through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", + "dev": true, + "license": "MIT" + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "license": "MIT", + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/tr46": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", + "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", + "license": "MIT" + }, + "node_modules/ts-api-utils": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz", + "integrity": "sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=16" + }, + "peerDependencies": { + "typescript": ">=4.2.0" + } + }, + "node_modules/ts-interface-checker": { + "version": "0.1.13", + "resolved": "https://registry.npmjs.org/ts-interface-checker/-/ts-interface-checker-0.1.13.tgz", + "integrity": "sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==", + "license": "Apache-2.0" + }, + "node_modules/tsconfig-paths": { + "version": "3.15.0", + "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.15.0.tgz", + "integrity": "sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/json5": "^0.0.29", + "json5": "^1.0.2", + "minimist": "^1.2.6", + "strip-bom": "^3.0.0" + } + }, + "node_modules/tslib": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", + "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==", + "license": "0BSD" + }, + "node_modules/type-check": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", + "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", + "dev": true, + "license": "MIT", + "dependencies": { + "prelude-ls": "^1.2.1" + }, + "engines": { + "node": ">= 0.8.0" + } + }, + "node_modules/type-fest": { + "version": "0.20.2", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", + "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", + "dev": true, + "license": "(MIT OR CC0-1.0)", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/typed-array-buffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/typed-array-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-byte-offset": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", + "dev": true, + "license": "MIT", + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typed-array-length": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", + "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/typescript": { + "version": "5.5.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.2.tgz", + "integrity": "sha512-NcRtPEOsPFFWjobJEtfihkLCZCXZt/os3zf8nTxjVH3RvTSxjrCamJpbExGvYOF+tFHc3pA65qpdwPbzjohhew==", + "dev": true, + "license": "Apache-2.0", + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=14.17" + } + }, + "node_modules/unbox-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", + "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", + "dev": true, + "license": "MIT", + "dependencies": { + "call-bind": "^1.0.2", + "has-bigints": "^1.0.2", + "has-symbols": "^1.0.3", + "which-boxed-primitive": "^1.0.2" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/unbzip2-stream": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", + "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", + "dev": true, + "license": "MIT", + "dependencies": { + "buffer": "^5.2.1", + "through": "^2.3.8" + } + }, + "node_modules/undici-types": { + "version": "5.26.5", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", + "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", + "dev": true, + "license": "MIT" + }, + "node_modules/universalify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", + "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 10.0.0" + } + }, + "node_modules/update-input-width": { + "version": "1.4.2", + "resolved": "https://registry.npmjs.org/update-input-width/-/update-input-width-1.4.2.tgz", + "integrity": "sha512-/p0XLhrQQQ4bMWD7bL9duYObwYCO1qGr8R19xcMmoMSmXuQ7/1//veUnCObQ7/iW6E2pGS6rFkS4TfH4ur7e/g==", + "license": "MIT", + "funding": { + "url": "https://github.com/wojtekmaj/update-input-width?sponsor=1" + } + }, + "node_modules/uri-js": { + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", + "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "punycode": "^2.1.0" + } + }, + "node_modules/urlpattern-polyfill": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/urlpattern-polyfill/-/urlpattern-polyfill-10.0.0.tgz", + "integrity": "sha512-H/A06tKD7sS1O1X2SshBVeA5FLycRpjqiBeqGKmBwBDBy28EnRjORxTNe269KSSr5un5qyWi1iL61wLxpd+ZOg==", + "dev": true, + "license": "MIT" + }, + "node_modules/use-callback-ref": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/use-callback-ref/-/use-callback-ref-1.3.2.tgz", + "integrity": "sha512-elOQwe6Q8gqZgDA8mrh44qRTQqpIHDcZ3hXTLjBe1i4ph8XpNJnO+aQf3NaG+lriLopI4HMx9VjQLfPQ6vhnoA==", + "license": "MIT", + "dependencies": { + "tslib": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "@types/react": "^16.8.0 || ^17.0.0 || ^18.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/use-sidecar": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.2.tgz", + "integrity": "sha512-epTbsLuzZ7lPClpz2TyryBfztm7m+28DlEv2ZCQ3MDr5ssiwyOwGH/e5F9CkfWjJ1t4clvI58yF822/GUkjjhw==", + "license": "MIT", + "dependencies": { + "detect-node-es": "^1.1.0", + "tslib": "^2.0.0" + }, + "engines": { + "node": ">=10" + }, + "peerDependencies": { + "@types/react": "^16.9.0 || ^17.0.0 || ^18.0.0", + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + } + } + }, + "node_modules/use-sync-external-store": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.2.tgz", + "integrity": "sha512-PElTlVMwpblvbNqQ82d2n6RjStvdSoNe9FG28kNfz3WiXilJm4DdNkEzRhCZuIDwY8U08WVihhGR5iRqAwfDiw==", + "license": "MIT", + "peerDependencies": { + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + } + }, + "node_modules/util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", + "license": "MIT" + }, + "node_modules/warning": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/warning/-/warning-4.0.3.tgz", + "integrity": "sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==", + "license": "MIT", + "dependencies": { + "loose-envify": "^1.0.0" + } + }, + "node_modules/webidl-conversions": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", + "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", + "license": "BSD-2-Clause" + }, + "node_modules/whatwg-url": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", + "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", + "license": "MIT", + "dependencies": { + "tr46": "~0.0.3", + "webidl-conversions": "^3.0.0" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-boxed-primitive": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", + "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-bigint": "^1.0.1", + "is-boolean-object": "^1.1.0", + "is-number-object": "^1.0.4", + "is-string": "^1.0.5", + "is-symbol": "^1.0.3" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-builtin-type": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/which-builtin-type/-/which-builtin-type-1.1.3.tgz", + "integrity": "sha512-YmjsSMDBYsM1CaFiayOVT06+KJeXf0o5M/CAd4o1lTadFAtacTUM49zoYxr/oroopFDfhvN6iEcBxUyc3gvKmw==", + "dev": true, + "license": "MIT", + "dependencies": { + "function.prototype.name": "^1.1.5", + "has-tostringtag": "^1.0.0", + "is-async-function": "^2.0.0", + "is-date-object": "^1.0.5", + "is-finalizationregistry": "^1.0.2", + "is-generator-function": "^1.0.10", + "is-regex": "^1.1.4", + "is-weakref": "^1.0.2", + "isarray": "^2.0.5", + "which-boxed-primitive": "^1.0.2", + "which-collection": "^1.0.1", + "which-typed-array": "^1.1.9" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-collection": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/which-collection/-/which-collection-1.0.2.tgz", + "integrity": "sha512-K4jVyjnBdgvc86Y6BkaLZEN933SwYOuBFkdmBu9ZfkcAbdVbpITnDmjvZ/aQjRXQrv5EPkTnD1s39GiiqbngCw==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-map": "^2.0.3", + "is-set": "^2.0.3", + "is-weakmap": "^2.0.2", + "is-weakset": "^2.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/which-typed-array": { + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", + "dev": true, + "license": "MIT", + "dependencies": { + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "for-each": "^0.3.3", + "gopd": "^1.0.1", + "has-tostringtag": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/word-wrap": { + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.5.tgz", + "integrity": "sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/wrap-ansi": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", + "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.1.0", + "string-width": "^5.0.1", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs": { + "name": "wrap-ansi", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "license": "MIT" + }, + "node_modules/wrap-ansi-cjs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-regex": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", + "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/wrap-ansi/node_modules/ansi-styles": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz", + "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/wrap-ansi/node_modules/strip-ansi": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz", + "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^6.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=10" + } + }, + "node_modules/yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", + "dev": true, + "license": "ISC" + }, + "node_modules/yaml": { + "version": "2.4.5", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.4.5.tgz", + "integrity": "sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg==", + "license": "ISC", + "bin": { + "yaml": "bin.mjs" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/yargs": { + "version": "17.7.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", + "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", + "dev": true, + "license": "MIT", + "dependencies": { + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" + }, + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs-parser": { + "version": "21.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", + "integrity": "sha512-tVpsJW7DdjecAiFpbIB1e3qxIQsE6NoPc5/eTdrbbIC4h0LVsWhnoa3g+m2HclBIujHzsxZ4VJVA+GUuc2/LBw==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=12" + } + }, + "node_modules/yargs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true, + "license": "MIT" + }, + "node_modules/yargs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yauzl": { + "version": "2.10.0", + "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", + "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", + "dev": true, + "license": "MIT", + "dependencies": { + "buffer-crc32": "~0.2.3", + "fd-slicer": "~1.1.0" + } + }, + "node_modules/yocto-queue": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", + "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/zod": { + "version": "3.23.8", + "resolved": "https://registry.npmjs.org/zod/-/zod-3.23.8.tgz", + "integrity": "sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/colinhacks" + } + }, + "node_modules/zustand": { + "version": "4.5.4", + "resolved": "https://registry.npmjs.org/zustand/-/zustand-4.5.4.tgz", + "integrity": "sha512-/BPMyLKJPtFEvVL0E9E9BTUM63MNyhPGlvxk1XjrfWTUlV+BR8jufjsovHzrtR6YNcBEcL7cMHovL1n9xHawEg==", + "license": "MIT", + "dependencies": { + "use-sync-external-store": "1.2.0" + }, + "engines": { + "node": ">=12.7.0" + }, + "peerDependencies": { + "@types/react": ">=16.8", + "immer": ">=9.0.6", + "react": ">=16.8" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "immer": { + "optional": true + }, + "react": { + "optional": true + } + } + }, + "node_modules/zustand/node_modules/use-sync-external-store": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", + "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", + "license": "MIT", + "peerDependencies": { + "react": "^16.8.0 || ^17.0.0 || ^18.0.0" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..811b8d3 --- /dev/null +++ b/package.json @@ -0,0 +1,62 @@ +{ + "name": "resume-craft", + "version": "0.1.0", + "private": true, + "scripts": { + "dev": "next dev", + "build": "next build", + "start": "next start", + "lint": "next lint" + }, + "dependencies": { + "@clerk/nextjs": "^5.1.6", + "@google/generative-ai": "^0.14.0", + "@radix-ui/react-checkbox": "^1.1.1", + "@radix-ui/react-dialog": "^1.1.1", + "@radix-ui/react-label": "^2.1.0", + "@radix-ui/react-select": "^2.1.1", + "@radix-ui/react-slot": "^1.1.0", + "@radix-ui/react-tabs": "^1.1.0", + "@radix-ui/react-tooltip": "^1.1.1", + "@types/lodash": "^4.17.5", + "@vercel/analytics": "^1.3.1", + "@vercel/speed-insights": "^1.0.12", + "array-move": "^4.0.0", + "axios": "^1.7.2", + "class-variance-authority": "^0.7.0", + "clsx": "^2.1.1", + "convex": "^1.12.2", + "framer-motion": "^11.2.12", + "fs": "^0.0.1-security", + "lodash": "^4.17.21", + "lucide-react": "^0.396.0", + "next": "^14.2.4", + "nextjs-toploader": "^3.7.15", + "nprogress": "^0.2.0", + "quill": "^2.0.2", + "react": "^18", + "react-color-palette": "^7.1.1", + "react-color-pallete": "^1.0.1", + "react-date-picker": "^11.0.0", + "react-dom": "^18", + "react-easy-sort": "^1.6.0", + "react-hot-toast": "^2.4.1", + "react-quill": "^2.0.0", + "tailwind-merge": "^2.3.0", + "tailwindcss-animate": "^1.0.7", + "zustand": "^4.5.4" + }, + "devDependencies": { + "@types/node": "^20", + "@types/nprogress": "^0.2.3", + "@types/react": "^18", + "@types/react-dom": "^18", + "eslint": "^8", + "eslint-config-next": "14.2.4", + "ignore-loader": "^0.1.2", + "postcss": "^8", + "puppeteer": "^22.12.1", + "tailwindcss": "^3.4.1", + "typescript": "^5" + } +} diff --git a/postcss.config.mjs b/postcss.config.mjs new file mode 100644 index 0000000..1a69fd2 --- /dev/null +++ b/postcss.config.mjs @@ -0,0 +1,8 @@ +/** @type {import('postcss-load-config').Config} */ +const config = { + plugins: { + tailwindcss: {}, + }, +}; + +export default config; diff --git a/providers/ConvexAndClerk.tsx b/providers/ConvexAndClerk.tsx new file mode 100644 index 0000000..10d36d8 --- /dev/null +++ b/providers/ConvexAndClerk.tsx @@ -0,0 +1,21 @@ +"use client" +import { ClerkProvider, useAuth } from "@clerk/nextjs"; +import { ConvexReactClient } from "convex/react"; +import { ConvexProviderWithClerk } from "convex/react-clerk"; +import React from "react"; + +const ConvexAndClerk = ({ children }: { children: React.ReactNode }) => { + const convex = new ConvexReactClient(process.env.NEXT_PUBLIC_CONVEX_URL as string); + + return ( + <> + + + {children} + + + + ); +}; + +export default ConvexAndClerk; diff --git a/providers/NextLoader.tsx b/providers/NextLoader.tsx new file mode 100644 index 0000000..c2e0b4e --- /dev/null +++ b/providers/NextLoader.tsx @@ -0,0 +1,22 @@ +"use client"; +import useMobile from "@/lib/useMobile"; +import { usePathname } from "next/navigation"; +import NextTopLoader from "nextjs-toploader"; +import React from "react"; +const NextLoader = () => { + const pathname = usePathname(); + const isInBuildResume = pathname.includes("build-resume"); + const isMobile = useMobile(); + + return ( + + ); +}; + +export default NextLoader; diff --git a/providers/ScreenProvider.tsx b/providers/ScreenProvider.tsx new file mode 100644 index 0000000..7eb2449 --- /dev/null +++ b/providers/ScreenProvider.tsx @@ -0,0 +1,41 @@ +"use client"; +import { useState, useEffect } from "react"; + +export default function ScreenProvider({ + children, +}: Readonly<{ + children: React.ReactNode; +}>) { + const [isMobile, setIsMobile] = useState(false); + + useEffect(() => { + const checkIfMobile = () => { + setIsMobile(window.innerWidth < 768); + }; + + checkIfMobile(); + window.addEventListener("resize", checkIfMobile); + + return () => window.removeEventListener("resize", checkIfMobile); + }, []); + + return ( +
    + {isMobile ? ( +
    +
    +

    + Best Experience on Larger Screens +

    +

    + For the best experience, please open this website on a laptop or + PC. +

    +
    +
    + ) : ( + children + )} +
    + ); +} diff --git a/providers/TemplateWrapper.tsx b/providers/TemplateWrapper.tsx new file mode 100644 index 0000000..8d2e4ed --- /dev/null +++ b/providers/TemplateWrapper.tsx @@ -0,0 +1,35 @@ +import useMobile from "@/lib/useMobile"; +import { cn } from "@/lib/utils"; + +const TemplateWrapper = ({ + children, + size, +}: { + children: React.ReactNode; + size: "sm" | "md" | "lg"; +}) => { + const isMobile = useMobile(); + + return ( +
    + {children} +
    + ); +}; + +export default TemplateWrapper; diff --git a/public/image.png b/public/image.png new file mode 100644 index 0000000000000000000000000000000000000000..88998ff907ac057da7b44bf5e6b99f394f72e250 GIT binary patch literal 168586 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 literal 0 HcmV?d00001 diff --git a/public/next.svg b/public/next.svg new file mode 100644 index 0000000..5174b28 --- /dev/null +++ b/public/next.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/vercel.svg b/public/vercel.svg new file mode 100644 index 0000000..d2f8422 --- /dev/null +++ b/public/vercel.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/tailwind.config.ts b/tailwind.config.ts new file mode 100644 index 0000000..ff76665 --- /dev/null +++ b/tailwind.config.ts @@ -0,0 +1,82 @@ +import type { Config } from "tailwindcss" + +const config = { + darkMode: ["class"], + + content: [ + './pages/**/*.{ts,tsx}', + './components/**/*.{ts,tsx}', + './app/**/*.{ts,tsx}', + './src/**/*.{ts,tsx}', + './templates/**/*.{ts,tsx}', // Add this line + ], + prefix: "", + theme: { + container: { + center: true, + padding: "2rem", + screens: { + "2xl": "1400px", + }, + }, + extend: { + colors: { + border: "hsl(var(--border))", + input: "hsl(var(--input))", + ring: "hsl(var(--ring))", + background: "hsl(var(--background))", + foreground: "hsl(var(--foreground))", + primary: { + DEFAULT: "hsl(var(--primary))", + foreground: "hsl(var(--primary-foreground))", + }, + secondary: { + DEFAULT: "hsl(var(--secondary))", + foreground: "hsl(var(--secondary-foreground))", + }, + destructive: { + DEFAULT: "hsl(var(--destructive))", + foreground: "hsl(var(--destructive-foreground))", + }, + muted: { + DEFAULT: "hsl(var(--muted))", + foreground: "hsl(var(--muted-foreground))", + }, + accent: { + DEFAULT: "hsl(var(--accent))", + foreground: "hsl(var(--accent-foreground))", + }, + popover: { + DEFAULT: "hsl(var(--popover))", + foreground: "hsl(var(--popover-foreground))", + }, + card: { + DEFAULT: "hsl(var(--card))", + foreground: "hsl(var(--card-foreground))", + }, + }, + borderRadius: { + lg: "var(--radius)", + md: "calc(var(--radius) - 2px)", + sm: "calc(var(--radius) - 4px)", + }, + keyframes: { + "accordion-down": { + from: { height: "0" }, + to: { height: "var(--radix-accordion-content-height)" }, + }, + "accordion-up": { + from: { height: "var(--radix-accordion-content-height)" }, + to: { height: "0" }, + }, + }, + animation: { + "accordion-down": "accordion-down 0.2s ease-out", + "accordion-up": "accordion-up 0.2s ease-out", + }, + }, + }, + plugins: [require("tailwindcss-animate")], +} satisfies Config + +export default config \ No newline at end of file diff --git a/templates/template1/Temp1Types.tsx b/templates/template1/Temp1Types.tsx new file mode 100644 index 0000000..bbf79c7 --- /dev/null +++ b/templates/template1/Temp1Types.tsx @@ -0,0 +1,61 @@ +import { SocialLink } from "@/types/templateTypes"; + + +export type HeaderContent = { + firstName: string; + lastName: string; + phone?: string; + email?: string; + summary?: string; + socialLinks : SocialLink[]; +}; + +export type EducationContent = { + education: { + courseName: string; + instituteName: string; + startMonth?: string; + startYear: string; + endMonth?: string; + endYear: string; + location?: string; + grade?: string; + studyingHere: boolean; + }[]; +}; + +export type ExperienceContent = { + experience: { + companyName: string; + role: string; + jobDescription: string; + location?: string; + startMonth?: string; + startYear: string; + endMonth?: string; + endYear: string; + workingHere: boolean; + }[]; +}; + +export type SkillsContent = { + content: { + description: string; + }; +}; + +export type ProjectContent = { + projects: { + name: string; + description: string; + githuburl?: string; + liveurl?: string; + }[]; +}; + + +export type CustomContent = { + sectionTitle: string; + sectionDescription: string; + sectionNumber: string; +} \ No newline at end of file diff --git a/templates/template1/Template1.tsx b/templates/template1/Template1.tsx new file mode 100644 index 0000000..cb95ec4 --- /dev/null +++ b/templates/template1/Template1.tsx @@ -0,0 +1,354 @@ +"use client"; +import { cn } from "@/lib/utils"; +import { ResumeTemplate } from "@/types/templateTypes"; +import { + Github, + Globe, + Link2, + Linkedin, + Mail, + Phone, + Twitter, +} from "lucide-react"; +import Link from "next/link"; +import React from "react"; +import { + EducationContent, + ExperienceContent, + HeaderContent, + ProjectContent, + SkillsContent, +} from "./Temp1Types"; +import TemplateWrapper from "@/providers/TemplateWrapper"; + +export interface TemplateType { + obj: ResumeTemplate; + size?: "sm" | "md" | "lg"; +} + +const Template1 = ({ obj, size }: TemplateType) => { + const headerLogoMap: any = { + github: , + linkedin: , + portfolio: , + twitter: , + other: , + }; + + const visitedCustoms: number[] = []; + const primaryTextColor = obj?.globalStyles?.primaryTextColor || "black"; + const primaryColor = obj?.globalStyles?.primaryColor || "black"; + const sortedSections = [...obj.sections].sort( + (a, b) => a.orderNumber - b.orderNumber + ); + + const uniqueSectionTypes = Array.from( + new Set(sortedSections.map((item) => item.type)) + ); + + const renderSection = (type: string) => { + return sortedSections?.map((item, index) => { + if (item.type === type) { + switch (type) { + case "header": + const headerContent = item.content as HeaderContent; + + return ( +
    +
    +

    + {headerContent?.firstName} {headerContent?.lastName} +

    + +
    + {headerContent.phone && ( +
    + +

    {`${headerContent.phone}`}

    +
    + )} + {headerContent.email && ( +
    + +

    + {`${headerContent.email}`} +

    +
    + )} + {headerContent.socialLinks.map((item) => { + return ( +
    + {headerLogoMap[item.type]} + + {item.name} + +
    + ); + })} +
    +
    + + {/* SUMMARY */} +
    +

    + SUMMARY +

    +
    +
    +
    + ); + + case "education": + const educationContent = item.content as EducationContent; + + return ( +
    + {" "} +

    + EDUCATION +

    +
    + {educationContent?.education.map((edu, index2) => { + return ( +
    +
    +

    + {edu?.courseName} +

    +

    {edu?.instituteName}

    +
    +
    + {edu?.startYear && edu?.endYear && ( +

    + {`${edu?.startMonth ? `${edu.startMonth} ` : ""}${edu?.startYear ? edu.startYear : ""}${!edu?.studyingHere && (edu?.endMonth || edu?.endYear) ? ` - ${edu.endMonth} ${edu.endYear}` : edu?.studyingHere ? " - Present" : ""}`} +

    + )} +
    +
    + ); + })} +
    +
    + ); + + case "experience": + const experienceContent = item.content as ExperienceContent; + + return ( +
    +

    + WORK EXPERIENCE +

    + {experienceContent.experience?.map((exp, index) => { + return ( +
    +
    +

    + {exp?.role} {exp?.role && exp?.companyName && ","}{" "} + {exp?.companyName} +

    +
    + {exp?.startMonth && + exp?.startYear && + exp?.endMonth && + exp?.endYear && ( +

    + {exp?.startMonth}, {exp?.startYear} -{" "} + {exp?.endMonth}, {exp?.endYear} +

    + )} +
    +
    +
    +
    + ); + })} +
    + ); + + case "projects": + const projectContent = item.content as ProjectContent; + return ( + <> +
    +

    + PROJECTS +

    + +
    + {projectContent?.projects?.map((project, index) => { + return ( +
    +
    +

    + {project?.name} +

    + {project?.githuburl && ( + + + + )} + + {project?.liveurl && ( + + + + )} +
    +
    +
    + ); + })} +
    +
    + + ); + + case "skills": + const skillsContent = item as SkillsContent; + + return ( +
    + {" "} +

    + SKILLS +

    +
    +
    {" "} +
    +
    + ); + + case "custom": + return sortedSections.map((item, index) => { + if (item.type === "custom") { + if (visitedCustoms.includes(item.orderNumber)) return; + visitedCustoms.push(item.orderNumber); + + return ( +
    +

    + {item.content.sectionTitle} +

    +
    +
    + ); + } + return null; + }); + } + } + }); + }; + + const content = ( +
    +
    + {uniqueSectionTypes?.map((section, index) => { + return ( + + {renderSection(section)} + + ); + })} +
    +
    + ); + + return {content}; +}; + +export default Template1; diff --git a/templates/template1/temp1obj.tsx b/templates/template1/temp1obj.tsx new file mode 100644 index 0000000..c48394c --- /dev/null +++ b/templates/template1/temp1obj.tsx @@ -0,0 +1,152 @@ +import { ResumeTemplate } from "@/types/templateTypes"; + +const temp1Obj: ResumeTemplate = { + isTemplate: true, + userId: "admin", + templateName: "Template1", + sections: [ + { + type: "header", + content: { + email: "john.doe@example.com", + firstName: "John", + lastName: "Doe", + socialLinks: [ + { + type: "github", + name: "JohnDoe", + url: "https://github.com/JohnDoe", + }, + ], + location: "New York, NY", + phone: "+1-555-123-4567", + photo: "", + summary: + "Experienced software developer with a strong background in full-stack development and a passion for creating innovative solutions.", + }, + isVisible: true, + orderNumber: 0, + style: {}, + }, + { + type: "skills", + content: { + description: + "

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    ", + }, + isVisible: true, + orderNumber: 1, + style: {}, + }, + { + type: "projects", + content: { + projects: [ + { + name: "E-commerce Website Using MERN Stack", + description: + "

    Developed a full-featured eCommerce platform with user authentication, product management, and secure payment processing using MongoDB, Express.js, React, and Node.js, resulting in a 40% increase in user engagement.

    Integrated advanced search and filtering capabilities, enhancing the user experience by reducing product search time by 50%, and implemented a real-time order tracking system.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://johndoe.com", + }, + { + name: "Currency Converter in React", + description: + "

    Built a dynamic currency converter application in React, leveraging third-party APIs to provide real-time exchange rates for over 150 currencies, resulting in a 25% increase in user satisfaction.

    Implemented a responsive and intuitive user interface, ensuring seamless performance across various devices and improving usability scores by 30%.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://ecommerce.johndoe.com", + }, + ], + }, + isVisible: true, + orderNumber: 2, + style: {}, + }, + { + type: "experience", + content: { + experience: [ + { + companyName: "Tech Solutions Inc.", + jobDescription: + "

    Led a team of 5 developers in designing and implementing scalable web applications using microservices architecture.

    Developed and maintained 8 web applications using modern JavaScript frameworks and RESTful APIs, ensuring high performance and user-centric design.

    Contributed to 12 successful software releases, including 3 major feature enhancements, achieving a 20% improvement in application efficiency.

    ", + location: "San Francisco, CA", + role: "Senior Software Engineer", + startYear: "2024", + endYear: "2024", + workingHere: false, + startMonth: "Feb", + endMonth: "Dec", + }, + { + companyName: "Web Innovations LLC", + jobDescription: + "

    Implemented robust authentication systems and RESTful APIs for 10+ web projects, ensuring data security and seamless integration with external services.

    Collaborated with cross-functional teams on 15+ sprints, delivering scalable solutions that improved performance metrics by 25% across multiple client projects.

    ", + location: "Austin, TX", + role: "Full Stack Developer", + startYear: "2024", + endYear: "2024", + workingHere: false, + startMonth: "Feb", + endMonth: "Dec", + }, + ], + }, + isVisible: true, + orderNumber: 3, + style: {}, + }, + { + type: "education", + content: { + education: [ + { + courseName: "Bachelor of Science in Computer Science", + instituteName: "University of California, Berkeley", + location: "Berkeley, CA", + startMonth: "Feb", + startYear: "2022", + endMonth: "March", + endYear: "2023", + studyingHere: false, + grade: "8.2 CGPA", + }, + { + courseName: "Master of Science in Software Engineering", + instituteName: "Stanford University", + location: "Stanford, CA", + startMonth: "Feb", + startYear: "2022", + endMonth: "March", + endYear: "2023", + studyingHere: false, + grade: "8.2 CGPA", + }, + ], + }, + isVisible: true, + orderNumber: 4, + style: {}, + }, + { + type: "custom", + content: { + sectionTitle: "About Me", + sectionDescription: "Summary", + sectionNumber: 0, + }, + isVisible: false, + orderNumber: 5, + style: {}, + }, + ], + globalStyles: { + fontFamily: "Geologica", + primaryTextColor: "#C026D3", + primaryColor: "#C026D3", + photo: false, + columns: 2, + }, +}; + +export default temp1Obj; diff --git a/templates/template2/Template2.tsx b/templates/template2/Template2.tsx new file mode 100644 index 0000000..3f001d8 --- /dev/null +++ b/templates/template2/Template2.tsx @@ -0,0 +1,341 @@ +import { cn } from "@/lib/utils"; +import Link from "next/link"; +import { + Github, + Globe, + Globe2, + Link2, + Linkedin, + Mail, + MessageCircle, + Phone, + Twitter, +} from "lucide-react"; +import React from "react"; +import { + HeaderContent, + EducationContent, + SkillsContent, + ExperienceContent, + ProjectContent, + CustomContent, +} from "./temp2Types"; +import { ResumeTemplate } from "@/types/templateTypes"; +import useMobile from "@/lib/useMobile"; + +interface TemplateType { + obj: ResumeTemplate; + size?: "sm" | "md" | "lg"; +} + +const Template2 = ({ obj, size }: TemplateType) => { + const sectionArray = obj?.sections?.map((item) => item.type); + const isMobile = useMobile(); + + const PreviewWrapper = ({ children }: { children: React.ReactNode }) => ( +
    + {children} +
    + ); + + const primaryTextColorClass = obj?.globalStyles?.primaryTextColor || "black"; + const primaryColorClass = obj?.globalStyles?.primaryColor || "black"; + + const sortedSections = [...obj.sections].sort( + (a, b) => a.orderNumber - b.orderNumber + ); + const visitedCustoms: number[] = []; + const uniqueSectionTypes = Array.from( + new Set(sortedSections.map((item) => item.type)) + ); + + const headerLogoMap: any = { + github: , + linkedin: , + portfolio: , + twitter: , + other: , + }; + + const renderSection = (type: string) => { + return obj?.sections?.map((item, index) => { + if (item.type === type) { + switch (type) { + case "header": + const headerContent = item.content as HeaderContent; + + return ( +
    +

    + {headerContent.firstName} {headerContent.lastName} +

    +
    + {headerContent.phone && ( +
    + +

    {`${headerContent.phone}`}

    +
    + )} + {headerContent.email && ( +
    + +

    + {`${headerContent.email}`} +

    +
    + )} + {headerContent.socialLinks.map((item) => { + return ( +
    + {headerLogoMap[item.type]} + + {item.name} + +
    + ); + })} +
    +
    + ); + + case "education": + const educationContent = item.content as EducationContent; + + return ( +
    +
    +

    + EDUCATION +

    +
    + {educationContent?.education?.map((edu, index) => ( +
    +
    +

    + {edu?.instituteName} +

    +

    + {edu?.courseName} {edu?.grade && "-"} {edu?.grade} +

    +
    +
    +

    + {edu?.location && edu?.location} +

    +

    + {`${edu?.startMonth ? `${edu.startMonth} ` : ""}${edu?.startYear ? edu.startYear : ""}${!edu?.studyingHere && (edu?.endMonth || edu?.endYear) ? ` - ${edu.endMonth} ${edu.endYear}` : edu?.studyingHere ? " - Present" : ""}`} +

    +
    +
    + ))} +
    + ); + + case "experience": + const experienceContent = item.content as ExperienceContent; + return ( +
    +
    +

    + EXPERIENCE +

    +
    + {experienceContent?.experience?.map((exp, index) => ( +
    +
    +
    +

    {exp?.role}

    +

    {exp?.companyName}

    +
    +
    + {exp?.startYear && exp?.endYear && ( +

    + {exp?.startMonth} {exp?.startYear}{" "} + {(exp?.startYear || exp?.startMonth) && + (exp?.endYear || exp?.endMonth) && + "-"} + {exp?.endMonth} {exp?.endYear} +

    + )}{" "} + {exp?.location && ( +

    {exp?.location}

    + )} +
    +
    +
    +
    + ))} +
    + ); + + case "skills": + const skillsContent = item as SkillsContent; + + return ( +
    +
    +

    + SKILLS +

    +
    +
    +
    + ); + + case "projects": + const projectContent = item.content as ProjectContent; + return ( +
    +
    +

    + PROJECTS +

    +
    + {projectContent?.projects?.map((project, index) => ( +
    +
    +

    + {project?.name} +

    + {project?.githuburl && ( + + + + )} + + {project?.liveurl && ( + + + + )} +
    +
    +
    + ))} +
    + ); + + case "custom": + return sortedSections.map((item, index) => { + if (item.type === "custom") { + if (visitedCustoms.includes(item.orderNumber)) return; + visitedCustoms.push(item.orderNumber); + return ( + <> +
    +

    + {item.content.sectionTitle} +

    +
    +
    + + ); + } + return null; + }); + + default: + return null; + } + } + return null; + }); + }; + + const content = ( +
    +
    + {uniqueSectionTypes?.map((section, index) => { + return
    {renderSection(section)}
    ; + })} +
    +
    + ); + + return {content}; +}; + +export default Template2; diff --git a/templates/template2/temp2Types.tsx b/templates/template2/temp2Types.tsx new file mode 100644 index 0000000..f68d654 --- /dev/null +++ b/templates/template2/temp2Types.tsx @@ -0,0 +1,59 @@ +import { SocialLink } from "@/types/templateTypes"; + + +export type HeaderContent = { + firstName: string; + lastName: string; + phone?: string; + email?: string; + socialLinks : SocialLink[] +}; + +export type EducationContent = { + education: { + courseName: string; + instituteName: string; + startMonth?: string; + startYear: string; + endMonth?: string; + endYear: string; + location?: string; + grade?: string; + studyingHere: boolean; + }[]; +}; + +export type ExperienceContent = { + experience: { + companyName: string; + role: string; + jobDescription: string; + location?: string; + startMonth?: string; + startYear: string; + endMonth?: string; + endYear: string; + workingHere: boolean; + }[]; +}; + +export type SkillsContent = { + content: { + description : string; + }; +}; + +export type ProjectContent = { + projects: { + name: string; + description: string; + githuburl?: string; + liveurl?: string; + }[]; +}; + +export type CustomContent = { + sectionTitle: string; + sectionDescription: string; + sectionNumber: string; +} \ No newline at end of file diff --git a/templates/template2/temp2obj.tsx b/templates/template2/temp2obj.tsx new file mode 100644 index 0000000..f6410c4 --- /dev/null +++ b/templates/template2/temp2obj.tsx @@ -0,0 +1,138 @@ +import { ResumeTemplate } from "@/types/templateTypes"; + +export const temp2Obj: ResumeTemplate = { + isTemplate: true, + userId: "admin", + templateName: "Template2", + sections: [ + { + content: { + email: "john.doe@example.com", + firstName: "John", + lastName: "Doe", + socialLinks: [ + { + type: "github", + name: "JohnDoe", + url: "https://github.com/JohnDoe", + }, + ], + location: "New York, NY", + phone: "+1-555-123-4567", + photo: "", + summary: "", + }, + style: {}, + isVisible: true, + orderNumber: 0, + type: "header", + }, + { + content: { + education: [ + { + courseName: "Bachelor of Science in Computer Science", + instituteName: "University of California, Berkeley", + location: "Berkeley, CA", + startMonth: "Feb", + startYear: "2022", + endMonth: "March", + endYear: "2023", + grade: "8.2 CGPA", + studyingHere: false, + }, + { + courseName: "Master of Science in Software Engineering", + instituteName: "Stanford University", + location: "Stanford, CA", + startMonth: "Jan", + startYear: "2020", + endMonth: "Dec", + endYear: "2022", + grade: "8.2 CGPA", + studyingHere: false, + }, + ], + }, + style: {}, + isVisible: true, + orderNumber: 1, + type: "education", + }, + { + content: { + projects: [ + { + description: + "

    Developed a full-featured eCommerce platform with user authentication, product management, and secure payment processing using MongoDB, Express.js, React, and Node.js, resulting in a 40% increase in user engagement.

    Integrated advanced search and filtering capabilities, enhancing the user experience by reducing product search time by 50%, and implemented a real-time order tracking system.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://johndoe.com", + name: "E-commerce Website Using MERN Stack", + }, + { + description: + "

    Built a dynamic currency converter application in React, leveraging third-party APIs to provide real-time exchange rates for over 150 currencies, resulting in a 25% increase in user satisfaction.

    Implemented a responsive and intuitive user interface, ensuring seamless performance across various devices and improving usability scores by 30%.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://ecommerce.johndoe.com", + name: "Currency Converter in React", + }, + ], + }, + style: {}, + isVisible: true, + orderNumber: 3, + type: "projects", + }, + { + content: { + experience: [ + { + companyName: "Tech Solutions Inc.", + jobDescription: + "

    Led a team of 5 developers in designing and implementing scalable web applications using microservices architecture.

    Developed and maintained 8 web applications using modern JavaScript frameworks and RESTful APIs, ensuring high performance and user-centric design.

    Contributed to 12 successful software releases, including 3 major feature enhancements, achieving a 20% improvement in application efficiency.

    ", + location: "San Francisco, CA", + role: "Senior Software Engineer", + startYear: "2024", + endYear: "2024", + workingHere: false, + endMonth: "", + startMonth: "", + }, + { + companyName: "Web Innovations LLC", + jobDescription: + "

    Spearheaded the development of 6 end-to-end web applications from concept to deployment, leveraging React and Node.js, resulting in a 30% reduction in time-to-market.

    Implemented robust authentication systems and RESTful APIs for 10+ web projects, ensuring data security and seamless integration with external services.

    Collaborated with cross-functional teams on 15+ sprints, delivering scalable solutions that improved performance metrics by 25% across multiple client projects.

    ", + location: "Austin, TX", + role: "Full Stack Developer", + startYear: "2024", + endYear: "2024", + workingHere: false, + endMonth: "", + startMonth: "", + }, + ], + }, + style: {}, + isVisible: true, + orderNumber: 2, + type: "experience", + }, + { + content: { + description: + "

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    ", + }, + style: {}, + isVisible: true, + orderNumber: 4, + type: "skills", + }, + ], + globalStyles: { + columns: 2, + fontFamily: "Geologica", + photo: false, + primaryColor: "#000", + primaryTextColor: "#000", + }, +}; diff --git a/templates/template3/Template3.tsx b/templates/template3/Template3.tsx new file mode 100644 index 0000000..706d15f --- /dev/null +++ b/templates/template3/Template3.tsx @@ -0,0 +1,360 @@ +"use client"; +import { cn } from "@/lib/utils"; +import { ResumeTemplate } from "@/types/templateTypes"; +import { + Github, + Globe, + Link2, + Linkedin, + Mail, + Phone, + Twitter, +} from "lucide-react"; +import Link from "next/link"; +import React from "react"; +import { + EducationContent, + ExperienceContent, + HeaderContent, + ProjectContent, + SkillsContent, +} from "../template1/Temp1Types"; +import TemplateWrapper from "@/providers/TemplateWrapper"; + +export interface TemplateType { + obj: ResumeTemplate; + size: "sm" | "md" | "lg"; +} + +const Template3 = ({ obj, size }: TemplateType) => { + const headerLogoMap: any = { + github: , + linkedin: , + portfolio: , + twitter: , + other: , + }; + + console.log(obj); + + const visitedCustoms: number[] = []; + const primaryTextColor = obj?.globalStyles?.primaryTextColor || "black"; + const primaryColor = obj?.globalStyles?.primaryColor || "black"; + const sortedSections = [...obj.sections].sort( + (a, b) => a.orderNumber - b.orderNumber + ); + + const uniqueSectionTypes = Array.from( + new Set(sortedSections.map((item) => item.type)) + ); + + const renderSection = (type: string) => { + return sortedSections?.map((item, index) => { + if (item.type === type) { + switch (type) { + case "header": + const headerContent = item.content as HeaderContent; + + return ( +

    +
    +

    + {headerContent?.firstName} {headerContent?.lastName} +

    + +
    + {headerContent.phone && ( +
    + +

    {`${headerContent.phone}`}

    +
    + )} + {headerContent.email && ( +
    + +

    + {`${headerContent.email}`} +

    +
    + )} + {headerContent.socialLinks.map((item) => { + return ( +
    + {headerLogoMap[item.type]} + + {item.name} + +
    + ); + })} +
    +
    + + {/* SUMMARY */} +
    +

    + SUMMARY +

    +
    +
    +
    + ); + + case "education": + const educationContent = item.content as EducationContent; + + return ( +
    + {" "} +

    + EDUCATION +

    +
    + {educationContent?.education.map((edu, index2) => { + return ( +
    +
    +

    + {edu?.courseName} +

    +

    {edu?.instituteName}

    +
    +
    + {edu?.startYear && edu?.endYear && ( +

    + {`${edu?.startMonth ? `${edu.startMonth} ` : ""}${edu?.startYear ? edu.startYear : ""}${!edu?.studyingHere && (edu?.endMonth || edu?.endYear) ? ` - ${edu.endMonth} ${edu.endYear}` : edu?.studyingHere ? " - Present" : ""}`} +

    + )} +
    +
    + ); + })} +
    +
    + ); + + case "experience": + const experienceContent = item.content as ExperienceContent; + + return ( +
    +

    + WORK EXPERIENCE +

    + {experienceContent.experience?.map((exp, index) => { + return ( +
    +
    +

    + {exp?.role} {exp?.role && exp?.companyName && ","}{" "} + {exp?.companyName} +

    +
    + {exp?.startMonth && + exp?.startYear && + exp?.endMonth && + exp?.endYear && ( +

    + {exp?.startMonth}, {exp?.startYear} -{" "} + {exp?.endMonth}, {exp?.endYear} +

    + )} +
    +
    +
    +
    + ); + })} +
    + ); + + case "projects": + const projectContent = item.content as ProjectContent; + return ( + <> +
    +

    + PROJECTS +

    + +
    + {projectContent?.projects?.map((project, index) => { + return ( +
    +
    +

    + {project?.name} +

    + {project?.githuburl && ( + + + + )} + + {project?.liveurl && ( + + + + )} +
    +
    +
    + ); + })} +
    +
    + + ); + + case "skills": + const skillsContent = item as SkillsContent; + + return ( +
    + {" "} +

    + SKILLS +

    +
    +
    {" "} +
    +
    + ); + + case "custom": + return sortedSections.map((item, index) => { + if (item.type === "custom") { + if (visitedCustoms.includes(item.orderNumber)) return; + visitedCustoms.push(item.orderNumber); + + return ( +
    +

    + {item.content.sectionTitle} +

    +
    +
    + ); + } + return null; + }); + } + } + }); + }; + + const content = ( +
    +
    + {uniqueSectionTypes?.map((section, index) => { + return ( + + {/* {renderSection(section)} */} +
    +
    {section === 'header' && renderSection(section)}
    +
    +
    +
    + ); + })} +
    +
    + ); + + return {content}; +}; + +export default Template3; diff --git a/templates/template3/temp3obj.tsx b/templates/template3/temp3obj.tsx new file mode 100644 index 0000000..bb6c713 --- /dev/null +++ b/templates/template3/temp3obj.tsx @@ -0,0 +1,152 @@ +import { ResumeTemplate } from "@/types/templateTypes"; + +const temp3obj: ResumeTemplate = { + isTemplate: true, + userId: "admin", + templateName: "Template1", + sections: [ + { + type: "header", + content: { + email: "john.doe@example.com", + firstName: "John", + lastName: "Doe", + socialLinks: [ + { + type: "github", + name: "JohnDoe", + url: "https://github.com/JohnDoe", + }, + ], + location: "New York, NY", + phone: "+1-555-123-4567", + photo: "", + summary: + "Experienced software developer with a strong background in full-stack development and a passion for creating innovative solutions.", + }, + isVisible: true, + orderNumber: 0, + style: {}, + }, + { + type: "skills", + content: { + description: + "

    Frontend : HTML5, CSS3, JavaScript (ES6+), TypeScript, React.js, Next.js, Redux, Tailwind CSS, Bootstrap, Responsive Design, Flexbox, CSS Grid, Webpack, Babel.

    Backend : Node.js, Express.js, REST APIs, GraphQL, Authentication (JWT, OAuth), MongoDB, Mongoose, PostgreSQL, WebSockets (Socket.io), Real-Time Data.

    DevOps: Docker, Kubernetes, AWS (S3, EC2, Lambda), DigitalOcean, CI/CD Pipelines (GitHub Actions, Jenkins), Nginx, Apache, PM2.

    Version Control & Tools: Git, GitHub, GitLab, Postman, Insomnia, Swagger, VS Code, WebStorm. Testing: Jest, Mocha, Chai, Cypress, Selenium.

    ", + }, + isVisible: true, + orderNumber: 1, + style: {}, + }, + { + type: "projects", + content: { + projects: [ + { + name: "E-commerce Website Using MERN Stack", + description: + "

    Developed a full-featured eCommerce platform with user authentication, product management, and secure payment processing using MongoDB, Express.js, React, and Node.js, resulting in a 40% increase in user engagement.

    Integrated advanced search and filtering capabilities, enhancing the user experience by reducing product search time by 50%, and implemented a real-time order tracking system.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://johndoe.com", + }, + { + name: "Currency Converter in React", + description: + "

    Built a dynamic currency converter application in React, leveraging third-party APIs to provide real-time exchange rates for over 150 currencies, resulting in a 25% increase in user satisfaction.

    Implemented a responsive and intuitive user interface, ensuring seamless performance across various devices and improving usability scores by 30%.

    ", + githuburl: "https://github.com/johndoe/ecommerce", + liveurl: "https://ecommerce.johndoe.com", + }, + ], + }, + isVisible: true, + orderNumber: 2, + style: {}, + }, + { + type: "experience", + content: { + experience: [ + { + companyName: "Tech Solutions Inc.", + jobDescription: + "

    Led a team of 5 developers in designing and implementing scalable web applications using microservices architecture.

    Developed and maintained 8 web applications using modern JavaScript frameworks and RESTful APIs, ensuring high performance and user-centric design.

    Contributed to 12 successful software releases, including 3 major feature enhancements, achieving a 20% improvement in application efficiency.

    ", + location: "San Francisco, CA", + role: "Senior Software Engineer", + startYear: "2024", + endYear: "2024", + workingHere: false, + startMonth: "Feb", + endMonth: "Dec", + }, + { + companyName: "Web Innovations LLC", + jobDescription: + "

    Implemented robust authentication systems and RESTful APIs for 10+ web projects, ensuring data security and seamless integration with external services.

    Collaborated with cross-functional teams on 15+ sprints, delivering scalable solutions that improved performance metrics by 25% across multiple client projects.

    ", + location: "Austin, TX", + role: "Full Stack Developer", + startYear: "2024", + endYear: "2024", + workingHere: false, + startMonth: "Feb", + endMonth: "Dec", + }, + ], + }, + isVisible: true, + orderNumber: 3, + style: {}, + }, + { + type: "education", + content: { + education: [ + { + courseName: "Bachelor of Science in Computer Science", + instituteName: "University of California, Berkeley", + location: "Berkeley, CA", + startMonth: "Feb", + startYear: "2022", + endMonth: "March", + endYear: "2023", + studyingHere: false, + grade: "8.2 CGPA", + }, + { + courseName: "Master of Science in Software Engineering", + instituteName: "Stanford University", + location: "Stanford, CA", + startMonth: "Feb", + startYear: "2022", + endMonth: "March", + endYear: "2023", + studyingHere: false, + grade: "8.2 CGPA", + }, + ], + }, + isVisible: true, + orderNumber: 4, + style: {}, + }, + { + type: "custom", + content: { + sectionTitle: "About Me", + sectionDescription: "Summary", + sectionNumber: 0, + }, + isVisible: false, + orderNumber: 5, + style: {}, + }, + ], + globalStyles: { + fontFamily: "Geologica", + primaryTextColor: "#C026D3", + primaryColor: "#C026D3", + photo: false, + columns: 2, + }, +}; + +export default temp3obj; diff --git a/templates/template3/temp3types.tsx b/templates/template3/temp3types.tsx new file mode 100644 index 0000000..e69de29 diff --git a/templates/templateStructures.tsx b/templates/templateStructures.tsx new file mode 100644 index 0000000..d7450eb --- /dev/null +++ b/templates/templateStructures.tsx @@ -0,0 +1,154 @@ +import { ResumeTemplate } from "@/types/templateTypes"; +import Template1 from "@/templates/template1/Template1"; +import Template2 from "@/templates/template2/Template2"; + +export const allSectionFields: any = { + header: { + firstName: "", + lastName: "", + email: "", + phone: "", + socialLinks: [], + summary: "", + location: "", + photo: undefined, + }, + experience: { + experience: [ + { + companyName: "", + role: "", + jobDescription: "", + location: "", + startMonth: "", + endMonth: "", + startYear: "", + endYear: "", + workingHere: false, + }, + ], + }, + education: { + education: [ + { + courseName: "", + instituteName: "", + startMonth: "", + startYear: "", + endMonth: "", + endYear: "", + location: "", + grade: "", + studyingHere: false, + }, + ], + }, + skills: { + description: "", + }, + projects: { + projects: [ + { + name: "", + description: "", + githuburl: "", + liveurl: "", + }, + ], + }, +}; + +export function createSection( + type: any, + fields: string[], + orderNumber: number, + isVisible: boolean +) { + let content: any = {}; + fields.forEach((field) => { + content[field] = allSectionFields[type][field]; + }); + + return { + type, + content, + orderNumber: orderNumber, + isVisible: isVisible, + style: {}, + }; +} + +export const templateStructures: any = { + Template1: [ + { + type: "header", + fields: [ + "firstName", + "lastName", + "email", + "phone", + "socialLinks", + "summary", + ], + orderNumber: 0, + isVisible: true, + }, + { + type: "experience", + fields: ["experience"], + orderNumber: 3, + isVisible: true, + }, + { + type: "skills", + fields: ["description"], + orderNumber: 1, + isVisible: true, + }, + { type: "projects", fields: ["projects"], orderNumber: 2, isVisible: true }, + { + type: "education", + fields: ["education"], + orderNumber: 4, + isVisible: true, + }, + ], + Template2: [ + { + type: "header", + fields: ["firstName", "lastName", "email", "phone", "socialLinks"], + orderNumber: 0, + isVisible: true, + }, + { + type: "education", + fields: ["education"], + orderNumber: 1, + isVisible: true, + }, + { + type: "experience", + fields: ["experience"], + orderNumber: 2, + isVisible: true, + }, + { type: "projects", fields: ["projects"], orderNumber: 3, isVisible: true }, + { + type: "skills", + fields: ["description"], + orderNumber: 4, + isVisible: true, + }, + ], +}; + +export type TemplateComponentType = React.ComponentType<{ + obj: ResumeTemplate; + isPreview: boolean; + size? : "sm" | "md" | "lg"; +}>; + +export const templateComponents: Record = { + Template1: Template1, + Template2: Template2, +}; diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..e0fe834 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,26 @@ +{ + "compilerOptions": { + "lib": ["dom", "dom.iterable", "esnext"], + "allowJs": true, + "skipLibCheck": true, + "strict": true, + "noEmit": true, + "esModuleInterop": true, + "module": "esnext", + "moduleResolution": "bundler", + "resolveJsonModule": true, + "isolatedModules": true, + "jsx": "preserve", + "incremental": true, + "plugins": [ + { + "name": "next" + } + ], + "paths": { + "@/*": ["./*"] + } + }, + "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts", "components/QuillEditors/Quill.modules", "components/QuillEditors/QuillModules.js"], + "exclude": ["node_modules"] +} diff --git a/types/templateTypes.tsx b/types/templateTypes.tsx new file mode 100644 index 0000000..4d5e73f --- /dev/null +++ b/types/templateTypes.tsx @@ -0,0 +1,135 @@ +type SectionType = + | "header" + | "education" + | "skills" + | "projects" + | "experience" + | "custom"; + +interface BaseSection { + type: SectionType; + content: Record; + style?: Record; +} + +export interface SocialLink { + type: string; + name: string; + url: string; +} + +export interface HeaderSection extends BaseSection { + type: "header"; + content: { + firstName: string; + lastName?: string; + email: string; + phone?: string; + location?: string; + summary?: string; + photo?: string; + socialLinks : SocialLink[] + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export interface SkillSection extends BaseSection { + type: "skills"; + content: { + description: string; + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export interface ProjectSection extends BaseSection { + type: "projects"; + content: { + projects: { + name: string; + description: string; + githuburl?: string; + liveurl?: string; + }[]; + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export interface ExperienceSection extends BaseSection { + type: "experience"; + content: { + experience: { + companyName: string; + role: string; + jobDescription: string; + location?: string; + startMonth?: string; + startYear: string; + endMonth?: string; + endYear: string; + workingHere: false; + }[]; + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export interface EducationSection extends BaseSection { + type: "education"; + content: { + education: { + courseName: string; + instituteName: string; + startMonth?: string; + startYear?: string; + endMonth?: string; + endYear?: string; + location?: string; + studyingHere: boolean; + grade?: string; + }[]; + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export interface CustomSection extends BaseSection { + type: "custom"; + content: { + sectionTitle : string; + sectionDescription : string; + sectionNumber : number; + }; + isVisible: boolean; + orderNumber: number; + style?: {}; +} + +export type SectionTypes = + | HeaderSection + | SkillSection + | ProjectSection + | ExperienceSection + | EducationSection + | CustomSection; + +export interface ResumeTemplate { + isTemplate: boolean; + userId: string; + templateName: string; + sections: SectionTypes[]; + globalStyles: { + fontFamily: string; + primaryTextColor: string; + primaryColor: string; + photo: boolean; + columns: number; + }; +} diff --git a/vercel.json b/vercel.json new file mode 100644 index 0000000..f3c09f5 --- /dev/null +++ b/vercel.json @@ -0,0 +1,8 @@ +{ + "builds": [ + { + "src": "package.json", + "use": "@vercel/next" + } + ] +} \ No newline at end of file