diff --git a/nodejs/week2/.gitignore b/nodejs/week2/.gitignore
new file mode 100644
index 00000000..b512c09d
--- /dev/null
+++ b/nodejs/week2/.gitignore
@@ -0,0 +1 @@
+node_modules
\ No newline at end of file
diff --git a/nodejs/week3/.gitignore b/nodejs/week3/.gitignore
new file mode 100644
index 00000000..1dcef2d9
--- /dev/null
+++ b/nodejs/week3/.gitignore
@@ -0,0 +1,2 @@
+node_modules
+.env
\ No newline at end of file
diff --git a/react/react1/week1/.gitignore b/react/react1/week1/.gitignore
new file mode 100644
index 00000000..3e161128
--- /dev/null
+++ b/react/react1/week1/.gitignore
@@ -0,0 +1,6 @@
+.DS_Store
+node_modules
+.next
+jsconfig.json
+next.config.mjs
+data
\ No newline at end of file
diff --git a/react/react1/week1/app/about_us/README.md b/react/react1/week1/app/about_us/README.md
new file mode 100644
index 00000000..ee4b4656
--- /dev/null
+++ b/react/react1/week1/app/about_us/README.md
@@ -0,0 +1,47 @@
+# TASK 1
+
+Let's finish the "About Us" page!
+
+## Content to use
+
+### Our Mission
+
+At Galactica, our mission is to unlock the wonders of the universe for everyone. We believe that space is the final frontier and that the opportunity to explore it should be within everyone’s reach. Our journeys are designed to inspire, educate, and provide a once-in-a-lifetime experience that transcends the ordinary.
+
+### Our Values
+
+Exploration: We are driven by a deep-seated desire to explore the unknown. We believe that the pursuit of discovery is at the heart of human nature, and we are committed to pushing the boundaries of what is possible.
+
+Innovation: At Galactica, we prioritize cutting-edge technology and innovation. We are constantly evolving our spacecraft, safety protocols, and services to ensure that our travelers experience the most advanced and secure space journeys available.
+
+Sustainability: We are committed to making space exploration sustainable for future generations. Our space missions are designed to minimize environmental impact, both on Earth and in space, and to foster a spirit of responsibility towards our universe.
+
+Community: We believe in the power of collective exploration. Our journeys are not just about reaching new destinations; they are about building a community of space enthusiasts who share a passion for the stars.
+
+
+### Our Crew
+
+#### Description
+Our crew is the heart and soul of Galactica. We are a diverse team of seasoned space explorers, engineers, and visionaries who are united by a common goal: to make space travel accessible and exciting for all.
+
+Captain Sarah Vega: A former NASA astronaut with over 15 years of experience, Captain Vega leads our missions with unparalleled expertise and a passion for space exploration.
+
+Dr. Leo Redding: Our chief astrophysicist, Dr. Redding, is a renowned scientist who has contributed to major space discoveries. He ensures that every journey is as educational as it is exhilarating.
+
+Chief Engineer Hana Lee: With her extensive background in aerospace engineering, Hana Lee is responsible for the state-of-the-art technology that powers our spacecraft. Her innovation ensures that our travelers are always in safe hands.
+
+Mission Specialist Alex Santos: As a mission specialist, Alex’s job is to ensure that every aspect of the journey runs smoothly. With a background in both science and adventure tourism, Alex is the perfect guide for our space travelers.
+
+Crew Member Maya Patel: Maya brings a unique blend of technical skills and customer service experience to the team. She’s always ready to assist with any needs and to make sure every traveler has an unforgettable experience.
+
+#### Content
+
+Use the content saved in the `/public/crew` folder!
+
+### Our Partners
+
+We collaborate with some of the most respected names in the space and technology industries to make every journey extraordinary.
+
+#### Content
+
+Use the content saved in the `/public/business_partners` folder!
\ No newline at end of file
diff --git a/react/react1/week1/app/about_us/ourCrew.js b/react/react1/week1/app/about_us/ourCrew.js
new file mode 100644
index 00000000..cf0d5a1c
--- /dev/null
+++ b/react/react1/week1/app/about_us/ourCrew.js
@@ -0,0 +1,56 @@
+import styles from "./page.module.css";
+
+const crew = [
+ {
+ img: "/crew/image-douglas-hurley.webp",
+ name: "Captain Douglas Hurley",
+ description:
+ "A former NASA astronaut with over 15 years of experience, Captain Douglas leads our missions with unparalleled expertise and a passion for space exploration.",
+ },
+ {
+ img: "/crew/image-anousheh-ansari.webp",
+ name: "Chief Engineer Anousheh Ansari",
+ description:
+ "With her extensive background in aerospace engineering, Anousheh is responsible for the state-of-the-art technology that powers our spacecraft. Her innovation ensures that our travelers are always in safe hands.",
+ },
+ {
+ img: "/crew/image-mark-shuttleworth.webp",
+ name: "Crew Member Mark Shuttleworth",
+ description:
+ "Mark brings a unique blend of technical skills and customer service experience to the team. He's always ready to assist with any needs and to make sure every traveler has an unforgettable experience",
+ },
+ {
+ img: "/crew/image-victor-glover.webp",
+ name: "Mission Specialist Victor Glover",
+ description:
+ "As a mission specialist, Victor's job is to ensure that every aspect of the journey runs smoothly. With a background in both science and adventure tourism, Victor is the perfect guide for our space travelers.",
+ },
+];
+
+const OurCrew = () => {
+ return (
+
+ Meet our talented crew
+
+ Our crew is the heart and soul of Galactica. We are a diverse team of
+ seasoned space explorers, engineers, and visionaries who are united by a
+ common goal: to make space travel accessible and exciting for all.
+
+
+ {crew.map((member, index) => (
+
+
+
{member.name}
+
{member.description}
+
+ ))}
+
+
+ );
+};
+
+export default OurCrew;
diff --git a/react/react1/week1/app/about_us/ourPartners.js b/react/react1/week1/app/about_us/ourPartners.js
new file mode 100644
index 00000000..b2e173e4
--- /dev/null
+++ b/react/react1/week1/app/about_us/ourPartners.js
@@ -0,0 +1,39 @@
+import styles from "@/app/about_us/page.module.css";
+
+const partners = [
+ { name: "alphabet", img: "/business_partners/alphabet-logo.png" },
+ { name: "amazon", img: "/business_partners/amazon_logo.png" },
+ { name: "cbc", img: "/business_partners/CBC_Logo_White.png" },
+ { name: "microsoft", img: "/business_partners/Microsoft-Logo-white.png" },
+ { name: "nyu", img: "/business_partners/nyu-logo.png" },
+ { name: "queen", img: "/business_partners/QueensLogo_white.png" },
+ { name: "samsung", img: "/business_partners/samsung-logo.png" },
+ { name: "sodexo", img: "/business_partners/sodexo-logo.png" },
+];
+
+const OurPartners = () => {
+ return (
+
+ OUR PARTNERS
+
+ We collaborate with some of the most respected names in the space and
+ technology industries to make every journey extraordinary.
+
+
+ {partners.map((partner, index) => {
+ return (
+
+
+
+ );
+ })}
+
+
+ );
+};
+
+export default OurPartners;
diff --git a/react/react1/week1/app/about_us/ourValues.js b/react/react1/week1/app/about_us/ourValues.js
new file mode 100644
index 00000000..0b6f0365
--- /dev/null
+++ b/react/react1/week1/app/about_us/ourValues.js
@@ -0,0 +1,28 @@
+const values = [
+ {
+ number: "01",
+ title: "Exploration",
+ description:
+ "We are driven by a deep-seated desire to explore the unknown. We believe that the pursuit of discovery is at the heart of human nature, and we are committed to pushing the boundaries of what is possible.",
+ },
+ {
+ number: "02",
+ title: "Innovation",
+ description:
+ "At Galactica, we prioritize cutting-edge technology and innovation. We are constantly evolving our spacecraft, safety protocols, and services to ensure that our travelers experience the most advanced and secure space journeys available.",
+ },
+ {
+ number: "03",
+ title: "Sustainability",
+ description:
+ "We are committed to making space exploration sustainable for future generations. Our space missions are designed to minimize environmental impact, both on Earth and in space, and to foster a spirit of responsibility towards our universe",
+ },
+ {
+ number: "04",
+ title: "Community",
+ description:
+ "We believe in the power of collective exploration. Our journeys are not just about reaching new destinations; they are about building a community of space enthusiasts who share a passion for the stars.",
+ },
+];
+
+export default values;
diff --git a/react/react1/week1/app/about_us/page.js b/react/react1/week1/app/about_us/page.js
new file mode 100644
index 00000000..e4b49048
--- /dev/null
+++ b/react/react1/week1/app/about_us/page.js
@@ -0,0 +1,45 @@
+import styles from "./page.module.css";
+import values from "./ourValues";
+import OurCrew from "./ourCrew.js";
+import OurPartners from "./ourPartners";
+
+const OurValues = () => {
+ return (
+
+
+ Our Values
+
+
+ {values.map((value, index) => (
+
+
{value.number}
+
{value.title}
+
{value.description}
+
+
+ ))}
+
+
+ );
+};
+
+export const Crew = () => {
+ return (
+
+
+ About us
+
+
+
+
+
+ );
+};
+
+export default Crew;
diff --git a/react/react1/week1/app/about_us/page.module.css b/react/react1/week1/app/about_us/page.module.css
new file mode 100644
index 00000000..7f3d1cec
--- /dev/null
+++ b/react/react1/week1/app/about_us/page.module.css
@@ -0,0 +1,134 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+.OurValues {
+ background-color: #121212;
+ color: #fff;
+ padding: 4rem 2rem;
+ text-align: center;
+}
+.OurValues h2 {
+ font-size: 1rem;
+ font-weight: bold;
+ text-transform: uppercase;
+ letter-spacing: 2px;
+ opacity: 0.8;
+}
+
+.grid {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
+ gap: 2rem;
+ max-width: 900px;
+ margin: 0 auto;
+}
+
+.card {
+ text-align: left;
+ padding: 2rem;
+ background-color: #1a1a1a;
+ border-radius: 8px;
+ position: relative;
+}
+
+.number {
+ font-size: 3rem;
+ font-weight: bold;
+ display: block;
+ margin-bottom: 1rem;
+}
+
+.title {
+ font-size: 1.5rem;
+ font-weight: bold;
+ margin-bottom: 0.5rem;
+}
+
+.description {
+ font-size: 1rem;
+ opacity: 0.8;
+}
+
+.divider {
+ width: 100%;
+ height: 1px;
+ background-color: #333;
+ margin-top: 2rem;
+}
+
+.card:hover {
+ transform: scale(1.02);
+ transition: transform 0.3s ease-in-out;
+}
+
+.ourCrew {
+ padding: 2rem;
+ text-align: center;
+ background-color: #111;
+}
+
+.ourCrew p {
+ padding: 2rem;
+}
+
+.crewList {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
+ gap: 20px;
+ justify-items: center;
+}
+
+.crewMember {
+ background-color: #f9f9f9;
+ padding: 20px;
+ border-radius: 10px;
+ box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
+ transition: transform 0.2s ease-in-out;
+ max-width: 250px;
+}
+
+.crewMember:hover {
+ transform: scale(1.05);
+}
+
+.crewImage {
+ width: 180px;
+ height: 180px;
+ border-radius: 50%;
+ object-fit: cover;
+ margin-bottom: 10px;
+ align-self: center;
+}
+
+.ourPartners {
+ background-color: #111;
+ padding: 50px;
+ color: white;
+}
+
+.gridStyle {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
+ gap: 60px;
+ align-items: center;
+ justify-content: center;
+ padding: 50px;
+ text-align: center;
+}
+
+.logoContainer {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ height: 100px;
+}
+
+.imageStyle {
+ max-width: 120px;
+ max-height: 80px;
+ object-fit: contain;
+ filter: brightness(0) invert(1);
+}
diff --git a/react/react1/week1/app/destination/README.md b/react/react1/week1/app/destination/README.md
new file mode 100644
index 00000000..58a9252d
--- /dev/null
+++ b/react/react1/week1/app/destination/README.md
@@ -0,0 +1,13 @@
+## Descriptions for the planets
+
+### Europa
+Europa, one of Jupiter’s moons, is an icy world with a hidden ocean beneath its surface. This mysterious moon is a prime candidate for the search for extraterrestrial life, making it a thrilling destination for space explorers.
+
+### Mars
+Mars, the Red Planet, is a barren yet fascinating world with vast deserts, towering volcanoes, and the deepest canyon in the solar system. As humanity’s next frontier, Mars invites us to dream of colonization and the possibilities of life beyond Earth.
+
+### Moon
+Our closest celestial neighbor, the Moon, is a silent witness to Earth's history. With its stunning craters and desolate landscapes, the Moon offers a unique glimpse into space exploration's past and future, making it a perfect destination for lunar adventurers.
+
+### Titan
+Titan, Saturn's largest moon, is a world of dense atmosphere and liquid methane lakes. This enigmatic moon is shrouded in a thick orange haze, concealing a landscape that is both alien and strangely familiar, beckoning explorers to uncover its secrets.
\ No newline at end of file
diff --git a/react/react1/week1/app/destination/page.js b/react/react1/week1/app/destination/page.js
new file mode 100644
index 00000000..006037be
--- /dev/null
+++ b/react/react1/week1/app/destination/page.js
@@ -0,0 +1,114 @@
+"use client";
+
+import { useState } from 'react';
+
+import styles from '@/components/destination/destination.module.css';
+import { AddWishlistItem } from '@/components/destination/AddWishlistItem';
+
+// TASK - React 1 week 2
+// Move this to its own file
+const PlanetWishlistItem = ({
+ name,
+ onRemove,
+ thumbnail,
+}) => {
+ return (
+
+
+
{name.toUpperCase()}
+
remove
+
+ );
+}
+
+
+export const Destinations = () => {
+ const [selectedPlanets, onAddPlanet] = useState([]);
+
+ let isPlanetSelected = false;
+ let numberOfPlanets = 0;
+
+ const onAddOrRemovePlanet = (name, index) => {
+ // TASK - React 1 week 2
+ // Implement this function
+ // If you press the "ADD PLANET" the selected planet should display "SELECTED"
+ // And the counter should update, how many planets are selected (numberOfPlanets)
+ console.log(`You seleceted the following planet: ${name}, with the index of ${index}`);
+ }
+
+ return (
+
+
+ Travel destinations
+
+ Wishlist
+ {/* TASK - React 1 week 2 */}
+ {/* Display the number Of selected planets */}
+ {/* Display the "no planets" message if it is empty! */}
+ No planets in wishlist :(
+ You have {numberOfPlanets} in your wishlist
+ List coming soon after lesson 3!
+
+ {/* STOP! - this is for week 3!*/}
+ {/* TASK - React 1 week 3 */}
+ {/* Import the AddWishlistItem react component */}
+ {/* */}
+ {/* TASK - React 1 week 3 */}
+ {/* Convert the list, so it is using selectedPlanets.map() to display the items */}
+ {/* Implement the "REMOVE" function */}
+ {/* uncomment the following code snippet: */}
+ {/*
+ Your current wishlist
+
+
removeFromWishlist('europa')}
+ thumbnail="/destination/image-europa.png"
+ />
+ removeFromWishlist('europa')}
+ thumbnail="/destination/image-europa.png"
+ />
+ */}
+
+
+ Possible destinations
+ {/* TASK - React 1 week 2 */}
+ {/* Add all 4 planets! Europa, Moon, Mars, Titan */}
+ {/* Use the README.md file for descriptions */}
+ {/* Create a component, which accepts the following properties: */}
+ {/* name, description, thumbnail, isSelected, onAddOrRemovePlanet */}
+
+
+
+
EUROPA {isPlanetSelected ? "- SELECTED" : ""}
+
Lorem ipsum...
+
+
onAddOrRemovePlanet('Pluto', 0)}
+ >
+ {isPlanetSelected ? "REMOVE" : "ADD PLANET"}
+
+
+
+
+
+
EUROPA {isPlanetSelected ? "- SELECTED" : ""}
+
Lorem ipsum...
+
+
onAddOrRemovePlanet('Pluto', 0)}
+ >
+ {isPlanetSelected ? "REMOVE" : "ADD PLANET"}
+
+
+
+
+
+ );
+}
+
+export default Destinations;
diff --git a/react/react1/week1/app/favicon.ico b/react/react1/week1/app/favicon.ico
new file mode 100644
index 00000000..53ae0d7b
Binary files /dev/null and b/react/react1/week1/app/favicon.ico differ
diff --git a/react/react1/week1/app/globals.css b/react/react1/week1/app/globals.css
new file mode 100644
index 00000000..de0f6718
--- /dev/null
+++ b/react/react1/week1/app/globals.css
@@ -0,0 +1,217 @@
+:root {
+ --max-width: 1100px;
+ --border-radius: 12px;
+ --font-mono: ui-monospace, Menlo, Monaco, "Cascadia Mono", "Segoe UI Mono",
+ "Roboto Mono", "Oxygen Mono", "Ubuntu Monospace", "Source Code Pro",
+ "Fira Mono", "Droid Sans Mono", "Courier New", monospace;
+
+ --foreground-rgb: 0, 0, 0;
+ --background-start-rgb: 214, 219, 220;
+ --background-end-rgb: 255, 255, 255;
+
+ --primary-background-color: #000;
+ --primary-text-color: #fff;
+ --border-color: #eee;
+ --card-bg-color: rgba(100, 100, 100, 0.3);
+
+ --primary-glow: conic-gradient(
+ from 180deg at 50% 50%,
+ #16abff33 0deg,
+ #0885ff33 55deg,
+ #54d6ff33 120deg,
+ #0071ff33 160deg,
+ transparent 360deg
+ );
+ --secondary-glow: radial-gradient(
+ rgba(255, 255, 255, 1),
+ rgba(255, 255, 255, 0)
+ );
+
+ --tile-start-rgb: 239, 245, 249;
+ --tile-end-rgb: 228, 232, 233;
+ --tile-border: conic-gradient(
+ #00000080,
+ #00000040,
+ #00000030,
+ #00000020,
+ #00000010,
+ #00000010,
+ #00000080
+ );
+
+ --callout-rgb: 238, 240, 241;
+ --callout-border-rgb: 172, 175, 176;
+ --card-rgb: 180, 185, 188;
+ --card-border-rgb: 131, 134, 135;
+
+ --spacing-04: 0.25rem;
+ --spacing-08: 0.5rem;
+ --spacing-12: 0.75rem;
+ --spacing-16: 1rem;
+ --spacing-20: 1.25rem;
+ --spacing-24: 1.5rem;
+ --spacing-32: 2rem;
+ --spacing-40: 2.5rem;
+ --spacing-48: 3rem;
+ --spacing-64: 4rem;
+
+ --font-size-3xl: 2.5rem;
+ --font-size-2xl: 2rem;
+ --font-size-xl: 1.5rem;
+ --font-size-lg: 1.25rem;
+ --font-size-md: 1rem;
+ --font-size-sm: 0.875rem;
+ --font-size-xs: 0.75rem;
+ --font-size-2xs: 0.6875rem;
+ --font-size-3xs: 0.625rem;
+ --font-size-base: 0.8125rem;
+ --font-size-jumbo: 3rem;
+ --font-size-huge: 2rem;
+ --font-size-large: 0.9375rem;
+ --font-size-lead: 0.875rem;
+ --font-size-small: 0.6875rem;
+ --font-size-tiny: 0.5625rem;
+
+ --header-height: 100px;
+}
+
+* {
+ box-sizing: border-box;
+ padding: 0;
+ margin: 0;
+}
+
+html,
+body {
+ max-width: 100vw;
+ overflow-x: hidden;
+}
+
+
+body {
+ color: rgb(var(--foreground-rgb));
+ background: linear-gradient(
+ to bottom,
+ transparent,
+ rgb(var(--background-end-rgb))
+ )
+ rgb(var(--background-start-rgb));
+}
+
+a {
+ color: inherit;
+ text-decoration: none;
+}
+
+h1, h2, h3, h4, h5, h6 {
+ margin-block-end: var(--spacing-08);
+ color: var(--primary-text-color);
+}
+
+p, b, i {
+ margin-block-end: var(--spacing-08);
+}
+
+button {
+ cursor: pointer;
+ text-transform: uppercase;
+ padding: var(--spacing-08);
+ border: none;
+ background-color: white;
+ font-weight: 600;
+ letter-spacing: 2px;
+}
+
+@media (prefers-color-scheme: dark) {
+ html {
+ color-scheme: dark;
+ }
+}
+
+.mainContent {
+ max-width: var(--max-width);
+ margin: auto;
+ padding-block-start: var(--header-height);
+ color: #fff;
+}
+
+
+.card {
+ position: relative;
+ padding: var(--spacing-12);
+ margin: var(--spacing-16);
+}
+
+.card::before {
+ background-color: var(--card-bg-color);
+ content: "";
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ backdrop-filter: blur(10px);
+}
+
+.card > * {
+ position: relative;
+ z-index: 2;
+}
+
+.roundButtonJumbo {
+ padding: unset;
+ height: 250px;
+ width: 250px;
+ min-height: 250px;
+ min-width: 250px;
+ line-height: 250px;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 30px;
+ font-weight: 200;
+ letter-spacing: 4px;
+}
+
+.roundButton {
+ padding: unset;
+ height: 100px;
+ width: 100px;
+ min-height: 100px;
+ min-width: 100px;
+ line-height: 100px;
+ cursor: pointer;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 8px;
+ font-weight: 800;
+ letter-spacing: 3px;
+}
+
+.fullBGpicture {
+ /* background: url('/destination/background-destination-desktop.jpg') no-repeat; */
+ /* background-color: #000; */
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ width: auto;
+ height: 100%;
+}
+
+.fullBGpicture::before {
+ content: "";
+ background: url('/destination/background-destination-desktop.jpg') no-repeat;
+ background-color: #000;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ width: 100%;
+ height: 100%;
+ position: fixed;
+ z-index: -1;
+}
+
+.fullBGpicture > main {
+ overflow: auto;
+}
\ No newline at end of file
diff --git a/react/react1/week1/app/layout.js b/react/react1/week1/app/layout.js
new file mode 100644
index 00000000..1d6b9fba
--- /dev/null
+++ b/react/react1/week1/app/layout.js
@@ -0,0 +1,29 @@
+import { Inter } from "next/font/google";
+import "./globals.css";
+
+import { Navbar } from "@/components/ui/Navbar";
+import { Footer } from "@/components/ui/Footer";
+
+const inter = Inter({ subsets: ["latin"] });
+
+export const metadata = {
+ title: "Galactica",
+ description: "Your space travel agency",
+};
+
+export const RootLayout = ({ children }) => {
+ return (
+
+
+
+ {children}
+ {/* TASK - React 1 week 1 */}
+ {/* Import and use the Footer component here */}
+
+ {/* Footer found in the ui/Footer.js folder */}
+
+
+ );
+};
+
+export default RootLayout;
diff --git a/react/react1/week1/app/nasa_collaboration/README.md b/react/react1/week1/app/nasa_collaboration/README.md
new file mode 100644
index 00000000..50dbbf53
--- /dev/null
+++ b/react/react1/week1/app/nasa_collaboration/README.md
@@ -0,0 +1,25 @@
+## Generating an API_KEY
+
+You need to generate an API Key at NASA's website!
+
+>> Link to the NASA API: https://api.nasa.gov/
+
+After subscribing, you will receive an email with your API_KEY
+Overwrite the `API_KEY` variable with your `API_KEY` from the email. It should look like this:
+```
+const API_KEY = 'hlcFvEJEPXDr9eUJ7fMHpbsX.....h9V';
+```
+
+If you did it successfully, the rover photo should load after reload
+
+## TIPS:
+
+There is a limit per user for this API. You can fetch an API 30 times/hour or 50 times/ day. If you get a `429` error message in the console it is because of this.
+
+You can use another email to get a new `API_KEY` or use the "./mock_data.json" to import the data, but fetch doesn't work with a `.json` file
+
+The `.json` file represents the data only. So it can be used to display the components, but not for the fetch.
+
+### How to use the JSON file:
+
+https://docs.deno.com/examples/importing-json/
\ No newline at end of file
diff --git a/react/react1/week1/app/nasa_collaboration/page.js b/react/react1/week1/app/nasa_collaboration/page.js
new file mode 100644
index 00000000..dc31e21f
--- /dev/null
+++ b/react/react1/week1/app/nasa_collaboration/page.js
@@ -0,0 +1,72 @@
+"use client";
+
+import React, { useState, useEffect } from 'react';
+import styles from './page.module.css';
+
+// Read "/app/nasa_collaboration/README.md" for more info about the API_KEY
+// You need a proper API_KEY for the requests to work
+const API_KEY = 'API_KEY';
+
+const NASA_URLs = {
+ astronomyPicOfTheDay: `https://api.nasa.gov/planetary/apod?api_key=${API_KEY}`,
+ marsRoverPhoto: `https://api.nasa.gov/mars-photos/api/v1/rovers/curiosity/photos?earth_date=2015-6-3&api_key=${API_KEY}`,
+};
+
+export const NasaCollaboration = () => {
+ const [dailyImg, setDailyImg] = useState({});
+ const [roverPhoto, setRoverPhoto] = useState({});
+
+ useEffect(() => {
+ const fetchRoverPhotos = async () => {
+ const roverPhotoResponse = await fetch(NASA_URLs.marsRoverPhoto).then(response => response.json());
+ setRoverPhoto(roverPhotoResponse);
+ };
+
+ fetchRoverPhotos();
+
+ // TASK - React 1 week 3
+ // fetch the extra data for NASA_URLs.astronomyPicOfTheDay and save it to the dailyImg state variable
+ }, []);
+
+ return (
+
+
+ Collaboration with NASA
+
+ Astronomy Picture of the day
+ {/* TASK - React 1 week 3 */}
+ {/* After fetching data from the NASA_URLs.astronomyPicOfTheDay url, display the returned data here */}
+ {/* You should display the title, explanation, and the image using the url from the response */}
+ {/* */}
+
+
+ Rover Photos
+ {/* TASK - React 1 week 3 */}
+ {/* Iteratate over the roverPhoto?.photos array and display all the pictures! */}
+ {
+ roverPhoto?.photos?.length ? (
+ <>
+ {/* TASK - React 1 week 3 */}
+ {/* Create a react component for the , which should accept the following props */}
+ {/* 1. src: source of the img (img_src in the data from the API) */}
+ {/* 2. date: earth_date data coming from the API */}
+ {/* 3. roverName: will be in the rover object - rover.name */}
+
+ {/* TIPS: */}
+ {/* If you don't know how the data looks like you can: */}
+ {/* 1. use console.log() to write the data to the console */}
+ {/* 2. use the network tab in the developer tab - https://developer.chrome.com/docs/devtools/network */}
+ Date {roverPhoto.photos[0]?.earth_date}
+
+ >
+ ) : (
+ Loading rover photos...
+ )
+ }
+
+
+
+ );
+}
+
+export default NasaCollaboration;
diff --git a/react/react1/week1/app/nasa_collaboration/page.module.css b/react/react1/week1/app/nasa_collaboration/page.module.css
new file mode 100644
index 00000000..790e9c86
--- /dev/null
+++ b/react/react1/week1/app/nasa_collaboration/page.module.css
@@ -0,0 +1,12 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+
+.nasaPicOfTheDayImg {
+ width: auto;
+ height: 400px;
+
+}
\ No newline at end of file
diff --git a/react/react1/week1/app/page.js b/react/react1/week1/app/page.js
new file mode 100644
index 00000000..74e72abf
--- /dev/null
+++ b/react/react1/week1/app/page.js
@@ -0,0 +1,30 @@
+import Link from 'next/link'
+import styles from './page.module.css';
+
+
+const HeroSection = () => {
+ return (
+
+
+
SO, YOU WANT TO TRAVEL TO
+
SPACE
+
+ Let’s face it; if you want to go to space, you might as well genuinely go to outer space
+ and not hover kind of on the edge of it. Well sit back, and relax because we’ll give you
+ a truly out of this world experience!
+
+
+ EXPLORE
+
+ );
+};
+
+export const Home = () => {
+ return (
+
+
+
+ );
+}
+
+export default Home;
\ No newline at end of file
diff --git a/react/react1/week1/app/page.module.css b/react/react1/week1/app/page.module.css
new file mode 100644
index 00000000..d64978cb
--- /dev/null
+++ b/react/react1/week1/app/page.module.css
@@ -0,0 +1,49 @@
+.app {
+ text-align: center;
+}
+
+.hero {
+ background-image: url("/home/background-home-desktop.jpg");
+ background-size: cover;
+ background-position: center;
+ height: 100vh;
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ padding: 0 var(--spacing-64);
+}
+
+.heroContent {
+ max-width: 500px;
+ text-align: left;
+ color: #fff;
+}
+
+.heroContent p {
+ font-size: 18px;
+ line-height: 1.6;
+ font-weight: 200;
+}
+
+p.heroH5 {
+ font-size: 18px;
+ font-weight: 300;
+ letter-spacing: var(--spacing-04);
+}
+
+p.heroJumbo {
+ font-size: 100px;
+ font-family: Verdana;
+ font-weight: 100;
+}
+
+.exploreButton {
+ height: 250px;
+ width: 250px;
+ line-height: 250px;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 30px;
+ font-weight: 200;
+ letter-spacing: 4px;
+}
diff --git a/react/react1/week1/components/destination/AddWishlistItem.js b/react/react1/week1/components/destination/AddWishlistItem.js
new file mode 100644
index 00000000..fe9b5a72
--- /dev/null
+++ b/react/react1/week1/components/destination/AddWishlistItem.js
@@ -0,0 +1,38 @@
+"use client";
+
+import { useState } from 'react';
+import styles from './destination.module.css';
+
+export const AddWishlistItem = ({
+ onAddWishlistItem,
+}) => {
+ const [thumbnail, onThumbnailChange] = useState('/destination/image-europa.png');
+ // TASK - React 1 week 3
+ // 1. Add a useState for the handling the
+ // 2. Connect the onThumbnailChange to the
+
+ const onAddItemPressed = () => {
+ // TASK - React 1 week 3
+ // implement this function
+ // Clear the field on button press
+ // pass the thumbnail and the name from the input to the onAddWishlistItem function
+ // call the onAddWishlistItem here
+ }
+
+
+ return (
+
+
Add custom planet to wishlist
+
Wishlist item name
+
+
Wishlist item thumbnail
+
+ EUROPA
+ MARS
+ MOON
+ TITAN
+
+
ADD CUSTOM
+
+ );
+};
diff --git a/react/react1/week1/components/destination/destination.module.css b/react/react1/week1/components/destination/destination.module.css
new file mode 100644
index 00000000..4ad132f4
--- /dev/null
+++ b/react/react1/week1/components/destination/destination.module.css
@@ -0,0 +1,84 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+.planetCard {
+ border: 1px solid var(--border-color);
+ max-width: 70%;
+ margin: var(--spacing-20) 0;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ padding: var(--spacing-08);
+ gap: var(--spacing-08);
+}
+
+.planetCard:nth-child(odd) {
+ margin-inline-start: auto;
+}
+
+.planetCard > *:last-child {
+ margin-inline-start: auto;
+}
+
+.planetDescription {
+ padding-block-start: var(--spacing-04);
+ margin-block-end: auto;
+}
+
+.planetThumbnail {
+ width: 150px;
+ height: 150px;
+ border-radius: 50%;
+ margin: 0 var(--spacing-16);
+}
+
+.wishlistItem {
+ border: 1px solid var(--border-color);
+ width: 150px;
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ gap: var(--spacing-16);
+ margin: var(--spacing-20);
+ padding: var(--spacing-20);
+}
+
+.wishlistItemThumbnail {
+ width: 60px;
+ height: 60px;
+ border-radius: 50%;
+ margin: 0 var(--spacing-16);
+}
+.wishlistList {
+ display: flex;
+ margin: var(--spacing-16) 0;
+}
+
+.addWishlistItem {
+ border: 1px solid var(--border-color);
+ width: 200px;
+ display: flex;
+ justify-content: space-between;
+ flex-direction: column;
+ align-items: stretch;
+ margin: var(--spacing-20);
+ padding: var(--spacing-20);
+}
+
+.addWishlistItem p {
+ margin-block-end: var(--spacing-20);
+}
+
+.addWishlistItem label {
+ margin: 0;
+ font-size: small;
+}
+
+.addWishlistItem input,
+.addWishlistItem select {
+ height: 30px;
+ margin-block-end: var(--spacing-20);
+}
\ No newline at end of file
diff --git a/react/react1/week1/components/ui/Footer.js b/react/react1/week1/components/ui/Footer.js
new file mode 100644
index 00000000..69a5e2b3
--- /dev/null
+++ b/react/react1/week1/components/ui/Footer.js
@@ -0,0 +1,60 @@
+"use client";
+
+import { usePathname } from "next/navigation";
+import styles from "./Footer.module.css";
+
+export const Footer = () => {
+ const path = usePathname().split("?")[0];
+ return (
+
+ );
+};
diff --git a/react/react1/week1/components/ui/Footer.module.css b/react/react1/week1/components/ui/Footer.module.css
new file mode 100644
index 00000000..7a7cc90a
--- /dev/null
+++ b/react/react1/week1/components/ui/Footer.module.css
@@ -0,0 +1,48 @@
+.footer {
+ inset-inline-start: 0;
+ inset-inline-end: 0;
+ inset-block-end: 0;
+ background-color: #eee;
+ color: #000;
+ padding: var(--spacing-20) var(--spacing-40);
+ display: flex;
+ justify-content: space-between;
+}
+
+.hidden {
+ display: none;
+}
+
+.footer h3 {
+ color: #000;
+ font-size: large;
+ padding: var(--spacing-08) 0;
+}
+
+.footer p, .footer a, .footer li {
+ color: #000;
+ font-size: medium;
+ font-weight: 200;
+ text-align: start;
+}
+
+.footerDescription {
+ max-width: 300px;
+ text-align: start;
+}
+
+.footerDescription p {
+ margin-block-end: var(--spacing-20);
+}
+
+.footerLinks {
+ gap: var(--spacing-20);
+}
+
+.footerList {
+ list-style-type: none;
+}
+
+.footerList li {
+ padding-block: var(--spacing-04);
+}
diff --git a/react/react1/week1/components/ui/Navbar.js b/react/react1/week1/components/ui/Navbar.js
new file mode 100644
index 00000000..3868afc5
--- /dev/null
+++ b/react/react1/week1/components/ui/Navbar.js
@@ -0,0 +1,59 @@
+"use client"
+import classNames from 'classnames';
+import { usePathname } from 'next/navigation';
+import Link from 'next/link'
+
+import styles from './Navbar.module.css';
+
+const navbarItems = [
+ {
+ title: 'ABOUT US',
+ link: '/about_us',
+ },
+ {
+ title: 'DESTINATION',
+ link: '/destination',
+ },
+ {
+ title: 'NASA COLLABORATION',
+ link: '/nasa_collaboration',
+ }
+];
+
+export const Navbar = () => {
+ const currentPath = usePathname()
+
+ return (
+
+
+
+
+
+
+ {/* TASK - React 1 week 2 */}
+ {/* Create a component, which accepts the following: */}
+ {/* title, link, isActive */}
+
+ 01 {navbarItems[0].title}
+
+
+ 02 {navbarItems[1].title}
+
+
+ 03 NASA COLLABORATION
+
+ {/* TASK - React 1 week 3 */}
+ {/* replace repeating content by using navbarItems.map(() => ) */}
+
+
+
+ );
+}
\ No newline at end of file
diff --git a/react/react1/week1/components/ui/Navbar.module.css b/react/react1/week1/components/ui/Navbar.module.css
new file mode 100644
index 00000000..fd3cfa1d
--- /dev/null
+++ b/react/react1/week1/components/ui/Navbar.module.css
@@ -0,0 +1,77 @@
+.headerContainer {
+ position: fixed;
+ top: 0;
+ left: 0;
+ right: 0;
+ width: 100%;
+ display: flex;
+ justify-content: space-between;
+ padding: var(--spacing-16) var(--spacing-40);
+ height: var(--header-height);
+ max-height: var(--header-height);
+ align-items: center;
+ z-index: 10;
+}
+
+.decorativeLine {
+ height: 0.1px;
+ width: 30vw;
+ background-color: #999;
+ margin-inline-end: -60px;
+ z-index: 10;
+}
+
+.navbarLogo {
+ margin-inline-end: var(--spacing-20);
+}
+
+.navbarLogo img {
+ height: 40px;
+}
+
+.navbarLogo a {
+ display: flex;
+ align-items: center;
+ gap: var(--spacing-20);
+ font-size: large;
+ font-weight: 600;
+ color: #fff;
+}
+
+.navbar {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ padding: 0 var(--spacing-8);
+ margin: var(--spacing-20);
+ background-color: transparent;
+
+}
+
+.navbarBG {
+ position: absolute;
+ width: 100%;
+ height: 60%;
+ backdrop-filter: blur(20px);
+}
+
+.navbarList {
+ position: relative;
+ list-style-type: none;
+ display: flex;
+ padding: 0 var(--spacing-40);
+ gap: var(--spacing-20);
+ z-index: 10;
+}
+
+.navbarLinks a {
+ color: white;
+ text-decoration: none;
+ font-weight: 200;
+ letter-spacing: 1px;
+}
+
+.navbarLinks:hover, .isLinkActive {
+ border-block-end: var(--spacing-04) solid var(--border-color);
+ margin-block-end: -4px;
+}
diff --git a/react/react1/week1/data/inspiration_about_us/our_partners.png b/react/react1/week1/data/inspiration_about_us/our_partners.png
new file mode 100644
index 00000000..add47aa5
Binary files /dev/null and b/react/react1/week1/data/inspiration_about_us/our_partners.png differ
diff --git a/react/react1/week1/data/inspiration_about_us/our_team.png b/react/react1/week1/data/inspiration_about_us/our_team.png
new file mode 100644
index 00000000..4d37d508
Binary files /dev/null and b/react/react1/week1/data/inspiration_about_us/our_team.png differ
diff --git a/react/react1/week1/data/inspiration_about_us/our_values.png b/react/react1/week1/data/inspiration_about_us/our_values.png
new file mode 100644
index 00000000..081a2900
Binary files /dev/null and b/react/react1/week1/data/inspiration_about_us/our_values.png differ
diff --git a/react/react1/week1/data/mock_data.json b/react/react1/week1/data/mock_data.json
new file mode 100644
index 00000000..d0e791e4
--- /dev/null
+++ b/react/react1/week1/data/mock_data.json
@@ -0,0 +1,223 @@
+{
+ "roverPhotos": {
+ "photos": [
+ {
+ "id": 102685,
+ "sol": 1004,
+ "camera": {
+ "id": 20,
+ "name": "FHAZ",
+ "rover_id": 5,
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ "img_src": "http://mars.jpl.nasa.gov/msl-raw-images/proj/msl/redops/ods/surface/sol/01004/opgs/edr/fcam/FLB_486615455EDR_F0481570FHAZ00323M_.JPG",
+ "earth_date": "2015-06-03",
+ "rover": {
+ "id": 5,
+ "name": "Curiosity",
+ "landing_date": "2012-08-06",
+ "launch_date": "2011-11-26",
+ "status": "active",
+ "max_sol": 4102,
+ "max_date": "2024-02-19",
+ "total_photos": 695670,
+ "cameras": [
+ {
+ "name": "FHAZ",
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ {
+ "name": "NAVCAM",
+ "full_name": "Navigation Camera"
+ },
+ {
+ "name": "MAST",
+ "full_name": "Mast Camera"
+ },
+ {
+ "name": "CHEMCAM",
+ "full_name": "Chemistry and Camera Complex"
+ },
+ {
+ "name": "MAHLI",
+ "full_name": "Mars Hand Lens Imager"
+ },
+ {
+ "name": "MARDI",
+ "full_name": "Mars Descent Imager"
+ },
+ {
+ "name": "RHAZ",
+ "full_name": "Rear Hazard Avoidance Camera"
+ }
+ ]
+ }
+ },
+ {
+ "id": 102686,
+ "sol": 1004,
+ "camera": {
+ "id": 20,
+ "name": "FHAZ",
+ "rover_id": 5,
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ "img_src": "http://mars.jpl.nasa.gov/msl-raw-images/proj/msl/redops/ods/surface/sol/01004/opgs/edr/fcam/FRB_486615455EDR_F0481570FHAZ00323M_.JPG",
+ "earth_date": "2015-06-03",
+ "rover": {
+ "id": 5,
+ "name": "Curiosity",
+ "landing_date": "2012-08-06",
+ "launch_date": "2011-11-26",
+ "status": "active",
+ "max_sol": 4102,
+ "max_date": "2024-02-19",
+ "total_photos": 695670,
+ "cameras": [
+ {
+ "name": "FHAZ",
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ {
+ "name": "NAVCAM",
+ "full_name": "Navigation Camera"
+ },
+ {
+ "name": "MAST",
+ "full_name": "Mast Camera"
+ },
+ {
+ "name": "CHEMCAM",
+ "full_name": "Chemistry and Camera Complex"
+ },
+ {
+ "name": "MAHLI",
+ "full_name": "Mars Hand Lens Imager"
+ },
+ {
+ "name": "MARDI",
+ "full_name": "Mars Descent Imager"
+ },
+ {
+ "name": "RHAZ",
+ "full_name": "Rear Hazard Avoidance Camera"
+ }
+ ]
+ }
+ },
+ {
+ "id": 102842,
+ "sol": 1004,
+ "camera": {
+ "id": 21,
+ "name": "RHAZ",
+ "rover_id": 5,
+ "full_name": "Rear Hazard Avoidance Camera"
+ },
+ "img_src": "http://mars.jpl.nasa.gov/msl-raw-images/proj/msl/redops/ods/surface/sol/01004/opgs/edr/rcam/RLB_486615482EDR_F0481570RHAZ00323M_.JPG",
+ "earth_date": "2015-06-03",
+ "rover": {
+ "id": 5,
+ "name": "Curiosity",
+ "landing_date": "2012-08-06",
+ "launch_date": "2011-11-26",
+ "status": "active",
+ "max_sol": 4102,
+ "max_date": "2024-02-19",
+ "total_photos": 695670,
+ "cameras": [
+ {
+ "name": "FHAZ",
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ {
+ "name": "NAVCAM",
+ "full_name": "Navigation Camera"
+ },
+ {
+ "name": "MAST",
+ "full_name": "Mast Camera"
+ },
+ {
+ "name": "CHEMCAM",
+ "full_name": "Chemistry and Camera Complex"
+ },
+ {
+ "name": "MAHLI",
+ "full_name": "Mars Hand Lens Imager"
+ },
+ {
+ "name": "MARDI",
+ "full_name": "Mars Descent Imager"
+ },
+ {
+ "name": "RHAZ",
+ "full_name": "Rear Hazard Avoidance Camera"
+ }
+ ]
+ }
+ },
+ {
+ "id": 102843,
+ "sol": 1004,
+ "camera": {
+ "id": 21,
+ "name": "RHAZ",
+ "rover_id": 5,
+ "full_name": "Rear Hazard Avoidance Camera"
+ },
+ "img_src": "http://mars.jpl.nasa.gov/msl-raw-images/proj/msl/redops/ods/surface/sol/01004/opgs/edr/rcam/RRB_486615482EDR_F0481570RHAZ00323M_.JPG",
+ "earth_date": "2015-06-03",
+ "rover": {
+ "id": 5,
+ "name": "Curiosity",
+ "landing_date": "2012-08-06",
+ "launch_date": "2011-11-26",
+ "status": "active",
+ "max_sol": 4102,
+ "max_date": "2024-02-19",
+ "total_photos": 695670,
+ "cameras": [
+ {
+ "name": "FHAZ",
+ "full_name": "Front Hazard Avoidance Camera"
+ },
+ {
+ "name": "NAVCAM",
+ "full_name": "Navigation Camera"
+ },
+ {
+ "name": "MAST",
+ "full_name": "Mast Camera"
+ },
+ {
+ "name": "CHEMCAM",
+ "full_name": "Chemistry and Camera Complex"
+ },
+ {
+ "name": "MAHLI",
+ "full_name": "Mars Hand Lens Imager"
+ },
+ {
+ "name": "MARDI",
+ "full_name": "Mars Descent Imager"
+ },
+ {
+ "name": "RHAZ",
+ "full_name": "Rear Hazard Avoidance Camera"
+ }
+ ]
+ }
+ }
+ ]
+ },
+ "dailyImage": {
+ "date": "2024-08-21",
+ "explanation": "Forget X-ray vision \u2014 imagine what you could see with gamma-ray vision! The featured all-sky map shows what the universe looks like to NASA's Fermi Gamma-ray Space Telescope. Fermi sees light with energies about a billion times what the human eye can see, and the map combines 12 years of Fermi observations. The colors represent the brightness of the gamma-ray sources, with brighter sources appearing lighter in color. The prominent stripe across the middle is the central plane of our Milky Way galaxy. Most of the red and yellow dots scattered above and below the Milky Way\u2019s plane are very distant galaxies, while most of those within the plane are nearby pulsars. The blue background that fills the image is the diffuse glow of gamma-rays from distant sources that are too dim to be detected individually. Some gamma-ray sources remain unidentified and topics of research \u2014 currently no one knows what they are.",
+ "hdurl": "https://apod.nasa.gov/apod/image/2408/12YearMap_Fermi_2160.jpg",
+ "media_type": "image",
+ "service_version": "v1",
+ "title": "Fermi's 12-year All-Sky Gamma-ray Map",
+ "url": "https://apod.nasa.gov/apod/image/2408/12YearMap_Fermi_1080.jpg"
+ }
+}
\ No newline at end of file
diff --git a/react/react1/week1/package-lock.json b/react/react1/week1/package-lock.json
new file mode 100644
index 00000000..9b0ff51a
--- /dev/null
+++ b/react/react1/week1/package-lock.json
@@ -0,0 +1,1550 @@
+{
+ "name": "space-turism",
+ "version": "0.1.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "space-turism",
+ "version": "0.1.0",
+ "dependencies": {
+ "@chakra-ui/next-js": "^2.2.0",
+ "@chakra-ui/react": "^2.8.2",
+ "@emotion/react": "^11.13.0",
+ "@emotion/styled": "^11.13.0",
+ "classnames": "^2.5.1",
+ "framer-motion": "^11.3.28",
+ "next": "14.2.5",
+ "react": "^18",
+ "react-dom": "^18"
+ },
+ "devDependencies": {}
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.26.2",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz",
+ "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.25.9",
+ "js-tokens": "^4.0.0",
+ "picocolors": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.10.tgz",
+ "integrity": "sha512-rRHT8siFIXQrAYOYqZQVsAr8vJ+cBNqcVAY6m5V8/4QqzaPl+zDBe6cLEPRDuNOUf3ww8RfJVlOyQMoSI+5Ang==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.26.10",
+ "@babel/types": "^7.26.10",
+ "@jridgewell/gen-mapping": "^0.3.5",
+ "@jridgewell/trace-mapping": "^0.3.25",
+ "jsesc": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz",
+ "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/traverse": "^7.25.9",
+ "@babel/types": "^7.25.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz",
+ "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz",
+ "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.10.tgz",
+ "integrity": "sha512-6aQR2zGE/QFi8JpDLjUZEPYOs7+mhKXm86VaKFiLP35JQwQb6bwUE+XbvkH0EptsYhbNBSUGaUBLKqxH1xSgsA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.26.10"
+ },
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.26.10.tgz",
+ "integrity": "sha512-2WJMeRQPHKSPemqk/awGrAiuFfzBmOIPXKizAsVhWH9YJqLZ0H+HS4c8loHGgW6utJ3E/ejXQUsiGaQy2NZ9Fw==",
+ "license": "MIT",
+ "dependencies": {
+ "regenerator-runtime": "^0.14.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.26.9",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.26.9.tgz",
+ "integrity": "sha512-qyRplbeIpNZhmzOysF/wFMuP9sctmh2cFzRAZOn1YapxBsE1i9bJIY586R/WBLfLcmcBlM8ROBiQURnnNy+zfA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.26.2",
+ "@babel/parser": "^7.26.9",
+ "@babel/types": "^7.26.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.26.10.tgz",
+ "integrity": "sha512-k8NuDrxr0WrPH5Aupqb2LCVURP/S0vBEn5mK6iH+GIYob66U5EtoZvcdudR2jQ4cmTwhEwW1DLB+Yyas9zjF6A==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.26.2",
+ "@babel/generator": "^7.26.10",
+ "@babel/parser": "^7.26.10",
+ "@babel/template": "^7.26.9",
+ "@babel/types": "^7.26.10",
+ "debug": "^4.3.1",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.10.tgz",
+ "integrity": "sha512-emqcG3vHrpxUKTrxcblR36dcrcoRDvKmnL/dCL6ZsHaShW80qxCAcNhzQZrpeM765VzEos+xOi4s+r4IXzTwdQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.25.9",
+ "@babel/helper-validator-identifier": "^7.25.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@chakra-ui/anatomy": {
+ "version": "2.3.6",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/anatomy/-/anatomy-2.3.6.tgz",
+ "integrity": "sha512-TjmjyQouIZzha/l8JxdBZN1pKZTj7sLpJ0YkFnQFyqHcbfWggW9jKWzY1E0VBnhtFz/xF3KC6UAVuZVSJx+y0g==",
+ "license": "MIT"
+ },
+ "node_modules/@chakra-ui/hooks": {
+ "version": "2.4.4",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/hooks/-/hooks-2.4.4.tgz",
+ "integrity": "sha512-+gMwLIkabtddIL/GICU7JmnYtvfONP+fNiTfdYLV9/I1eyCz8igKgLmFJOGM6F+BpUev6hh+/+DX5ezGQ9VTbQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/utils": "2.2.4",
+ "@zag-js/element-size": "0.31.1",
+ "copy-to-clipboard": "3.3.3",
+ "framesync": "6.1.2"
+ },
+ "peerDependencies": {
+ "react": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/next-js": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/next-js/-/next-js-2.4.2.tgz",
+ "integrity": "sha512-loo82RyPbMyvJwRhhZVZovut9v2hFBSkqd1vQoNXgMrCRApLwrrttu5Iuodns15gLE3mqI+it5oEhxTtO5DrxA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/cache": "^11.11.0"
+ },
+ "peerDependencies": {
+ "@chakra-ui/react": ">=2.4.0",
+ "@emotion/react": ">=11",
+ "next": ">=13",
+ "react": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/react": {
+ "version": "2.10.7",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/react/-/react-2.10.7.tgz",
+ "integrity": "sha512-GX1dCmnvrxxyZEofDX9GMAtRakZJKnUqFM9k8qhaycPaeyfkiTNNTjhPNX917hgVx1yhC3kcJOs5IeC7yW56/g==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/hooks": "2.4.4",
+ "@chakra-ui/styled-system": "2.12.2",
+ "@chakra-ui/theme": "3.4.8",
+ "@chakra-ui/utils": "2.2.4",
+ "@popperjs/core": "^2.11.8",
+ "@zag-js/focus-visible": "^0.31.1",
+ "aria-hidden": "^1.2.3",
+ "react-fast-compare": "3.2.2",
+ "react-focus-lock": "^2.9.6",
+ "react-remove-scroll": "^2.5.7"
+ },
+ "peerDependencies": {
+ "@emotion/react": ">=11",
+ "@emotion/styled": ">=11",
+ "framer-motion": ">=4.0.0",
+ "react": ">=18",
+ "react-dom": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/styled-system": {
+ "version": "2.12.2",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/styled-system/-/styled-system-2.12.2.tgz",
+ "integrity": "sha512-BlQ7i3+GYC0S0c72B+paa0sYo+QeNSMfz6fwQRFsc8A5Aax9i9lSdRL+vwJVC+k6r/0HWfRwk016R2RD2ihEwQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/utils": "2.2.4",
+ "csstype": "^3.1.2"
+ }
+ },
+ "node_modules/@chakra-ui/theme": {
+ "version": "3.4.8",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/theme/-/theme-3.4.8.tgz",
+ "integrity": "sha512-ZLMP2Gek38ZTIlj+sMZLsd1TW27yVdmUKMfBmjsr1psAeOa5bDBLKDszICjhEqk7gAbiWB7jr1/HzBXid4kduQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/anatomy": "2.3.6",
+ "@chakra-ui/theme-tools": "2.2.8",
+ "@chakra-ui/utils": "2.2.4"
+ },
+ "peerDependencies": {
+ "@chakra-ui/styled-system": ">=2.8.0"
+ }
+ },
+ "node_modules/@chakra-ui/theme-tools": {
+ "version": "2.2.8",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/theme-tools/-/theme-tools-2.2.8.tgz",
+ "integrity": "sha512-X2i2qgkG+k3DQfh/adn3zzM4Ty8QrGobVPjMl9rMrEYq3ac+pur6KVdVHy/SwwoPvB6S4i84uq7y35+KbJan9g==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/anatomy": "2.3.6",
+ "@chakra-ui/utils": "2.2.4",
+ "color2k": "^2.0.2"
+ },
+ "peerDependencies": {
+ "@chakra-ui/styled-system": ">=2.0.0"
+ }
+ },
+ "node_modules/@chakra-ui/utils": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/utils/-/utils-2.2.4.tgz",
+ "integrity": "sha512-nRpR9SnX7aLcJx7lKu8kgQWxdJso1oR/78HcBI+mzidvWdTykbTGdm5Q2R7S0PVH1IFBzBTgi6TiAjHvu96auA==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/lodash.mergewith": "4.6.9",
+ "lodash.mergewith": "4.6.2"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ }
+ },
+ "node_modules/@emotion/babel-plugin": {
+ "version": "11.13.5",
+ "resolved": "https://registry.npmjs.org/@emotion/babel-plugin/-/babel-plugin-11.13.5.tgz",
+ "integrity": "sha512-pxHCpT2ex+0q+HH91/zsdHkw/lXd468DIN2zvfvLtPKLLMo6gQj7oLObq8PhkrxOZb/gGCq03S3Z7PDhS8pduQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.16.7",
+ "@babel/runtime": "^7.18.3",
+ "@emotion/hash": "^0.9.2",
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/serialize": "^1.3.3",
+ "babel-plugin-macros": "^3.1.0",
+ "convert-source-map": "^1.5.0",
+ "escape-string-regexp": "^4.0.0",
+ "find-root": "^1.1.0",
+ "source-map": "^0.5.7",
+ "stylis": "4.2.0"
+ }
+ },
+ "node_modules/@emotion/cache": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-11.14.0.tgz",
+ "integrity": "sha512-L/B1lc/TViYk4DcpGxtAVbx0ZyiKM5ktoIyafGkH6zg/tj+mA+NE//aPYKG0k8kCHSHVJrpLpcAlOBEXQ3SavA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/sheet": "^1.4.0",
+ "@emotion/utils": "^1.4.2",
+ "@emotion/weak-memoize": "^0.4.0",
+ "stylis": "4.2.0"
+ }
+ },
+ "node_modules/@emotion/hash": {
+ "version": "0.9.2",
+ "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.2.tgz",
+ "integrity": "sha512-MyqliTZGuOm3+5ZRSaaBGP3USLw6+EGykkwZns2EPC5g8jJ4z9OrdZY9apkl3+UP9+sdz76YYkwCKP5gh8iY3g==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/is-prop-valid": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.3.1.tgz",
+ "integrity": "sha512-/ACwoqx7XQi9knQs/G0qKvv5teDMhD7bXYns9N/wM8ah8iNb8jZ2uNO0YOgiq2o2poIvVtJS2YALasQuMSQ7Kw==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/memoize": "^0.9.0"
+ }
+ },
+ "node_modules/@emotion/memoize": {
+ "version": "0.9.0",
+ "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.9.0.tgz",
+ "integrity": "sha512-30FAj7/EoJ5mwVPOWhAyCX+FPfMDrVecJAM+Iw9NRoSl4BBAQeqj4cApHHUXOVvIPgLVDsCFoz/hGD+5QQD1GQ==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/react": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/react/-/react-11.14.0.tgz",
+ "integrity": "sha512-O000MLDBDdk/EohJPFUqvnp4qnHeYkVP5B0xEG0D/L7cOKP9kefu2DXn8dj74cQfsEzUqh+sr1RzFqiL1o+PpA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.18.3",
+ "@emotion/babel-plugin": "^11.13.5",
+ "@emotion/cache": "^11.14.0",
+ "@emotion/serialize": "^1.3.3",
+ "@emotion/use-insertion-effect-with-fallbacks": "^1.2.0",
+ "@emotion/utils": "^1.4.2",
+ "@emotion/weak-memoize": "^0.4.0",
+ "hoist-non-react-statics": "^3.3.1"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@emotion/serialize": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.3.3.tgz",
+ "integrity": "sha512-EISGqt7sSNWHGI76hC7x1CksiXPahbxEOrC5RjmFRJTqLyEK9/9hZvBbiYn70dw4wuwMKiEMCUlR6ZXTSWQqxA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/hash": "^0.9.2",
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/unitless": "^0.10.0",
+ "@emotion/utils": "^1.4.2",
+ "csstype": "^3.0.2"
+ }
+ },
+ "node_modules/@emotion/sheet": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.4.0.tgz",
+ "integrity": "sha512-fTBW9/8r2w3dXWYM4HCB1Rdp8NLibOw2+XELH5m5+AkWiL/KqYX6dc0kKYlaYyKjrQ6ds33MCdMPEwgs2z1rqg==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/styled": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-11.14.0.tgz",
+ "integrity": "sha512-XxfOnXFffatap2IyCeJyNov3kiDQWoR08gPUQxvbL7fxKryGBKUZUkG6Hz48DZwVrJSVh9sJboyV1Ds4OW6SgA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.18.3",
+ "@emotion/babel-plugin": "^11.13.5",
+ "@emotion/is-prop-valid": "^1.3.0",
+ "@emotion/serialize": "^1.3.3",
+ "@emotion/use-insertion-effect-with-fallbacks": "^1.2.0",
+ "@emotion/utils": "^1.4.2"
+ },
+ "peerDependencies": {
+ "@emotion/react": "^11.0.0-rc.0",
+ "react": ">=16.8.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@emotion/unitless": {
+ "version": "0.10.0",
+ "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.10.0.tgz",
+ "integrity": "sha512-dFoMUuQA20zvtVTuxZww6OHoJYgrzfKM1t52mVySDJnMSEa08ruEvdYQbhvyu6soU+NeLVd3yKfTfT0NeV6qGg==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/use-insertion-effect-with-fallbacks": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.2.0.tgz",
+ "integrity": "sha512-yJMtVdH59sxi/aVJBpk9FQq+OR8ll5GT8oWd57UpeaKEVGab41JWaCFA7FRLoMLloOZF/c/wsPoe+bfGmRKgDg==",
+ "license": "MIT",
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ }
+ },
+ "node_modules/@emotion/utils": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-1.4.2.tgz",
+ "integrity": "sha512-3vLclRofFziIa3J2wDh9jjbkUz9qk5Vi3IZ/FSTKViB0k+ef0fPV7dYrUIugbgupYDx7v9ud/SjrtEP8Y4xLoA==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/weak-memoize": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.4.0.tgz",
+ "integrity": "sha512-snKqtPW01tN0ui7yu9rGv69aJXr/a/Ywvl11sUjNtEcRc+ng/mQriFL0wLXMef74iHa/EkftbDzU9F8iFbH+zg==",
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.8",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz",
+ "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==",
+ "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.5.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
+ "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==",
+ "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.5",
+ "resolved": "https://registry.npmjs.org/@next/env/-/env-14.2.5.tgz",
+ "integrity": "sha512-/zZGkrTOsraVfYjGP8uM0p6r0BDT6xWpkjdVbcz66PJVSpwXX3yNiRycxAuDfBKGWBrZBXRuK/YVlkNgxHGwmA==",
+ "license": "MIT"
+ },
+ "node_modules/@next/swc-darwin-arm64": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.5.tgz",
+ "integrity": "sha512-/9zVxJ+K9lrzSGli1///ujyRfon/ZneeZ+v4ptpiPoOU+GKZnm8Wj8ELWU1Pm7GHltYRBklmXMTUqM/DqQ99FQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-darwin-x64": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.5.tgz",
+ "integrity": "sha512-vXHOPCwfDe9qLDuq7U1OYM2wUY+KQ4Ex6ozwsKxp26BlJ6XXbHleOUldenM67JRyBfVjv371oneEvYd3H2gNSA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-arm64-gnu": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.5.tgz",
+ "integrity": "sha512-vlhB8wI+lj8q1ExFW8lbWutA4M2ZazQNvMWuEDqZcuJJc78iUnLdPPunBPX8rC4IgT6lIx/adB+Cwrl99MzNaA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-arm64-musl": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.5.tgz",
+ "integrity": "sha512-NpDB9NUR2t0hXzJJwQSGu1IAOYybsfeB+LxpGsXrRIb7QOrYmidJz3shzY8cM6+rO4Aojuef0N/PEaX18pi9OA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-x64-gnu": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.5.tgz",
+ "integrity": "sha512-8XFikMSxWleYNryWIjiCX+gU201YS+erTUidKdyOVYi5qUQo/gRxv/3N1oZFCgqpesN6FPeqGM72Zve+nReVXQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-x64-musl": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.5.tgz",
+ "integrity": "sha512-6QLwi7RaYiQDcRDSU/os40r5o06b5ue7Jsk5JgdRBGGp8l37RZEh9JsLSM8QF0YDsgcosSeHjglgqi25+m04IQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-arm64-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.5.tgz",
+ "integrity": "sha512-1GpG2VhbspO+aYoMOQPQiqc/tG3LzmsdBH0LhnDS3JrtDx2QmzXe0B6mSZZiN3Bq7IOMXxv1nlsjzoS1+9mzZw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-ia32-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.5.tgz",
+ "integrity": "sha512-Igh9ZlxwvCDsu6438FXlQTHlRno4gFpJzqPjSIBZooD22tKeI4fE/YMRoHVJHmrQ2P5YL1DoZ0qaOKkbeFWeMg==",
+ "cpu": [
+ "ia32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-x64-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.5.tgz",
+ "integrity": "sha512-tEQ7oinq1/CjSG9uSTerca3v4AZ+dFa+4Yu6ihaG8Ud8ddqLQgFGcnwYls13H5X5CPDPZJdYxyeMui6muOLd4g==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@popperjs/core": {
+ "version": "2.11.8",
+ "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz",
+ "integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==",
+ "license": "MIT",
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/popperjs"
+ }
+ },
+ "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/@types/lodash": {
+ "version": "4.17.16",
+ "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.17.16.tgz",
+ "integrity": "sha512-HX7Em5NYQAXKW+1T+FiuG27NGwzJfCX3s1GjOa7ujxZa52kjJLOr4FUxT+giF6Tgxv1e+/czV/iTtBw27WTU9g==",
+ "license": "MIT"
+ },
+ "node_modules/@types/lodash.mergewith": {
+ "version": "4.6.9",
+ "resolved": "https://registry.npmjs.org/@types/lodash.mergewith/-/lodash.mergewith-4.6.9.tgz",
+ "integrity": "sha512-fgkoCAOF47K7sxrQ7Mlud2TH023itugZs2bUg8h/KzT+BnZNrR2jAOmaokbLunHNnobXVWOezAeNn/lZqwxkcw==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/lodash": "*"
+ }
+ },
+ "node_modules/@types/parse-json": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.2.tgz",
+ "integrity": "sha512-dISoDXWWQwUquiKsyZ4Ng+HX2KsPL7LyHKHQwgGFEA3IaKac4Obd+h2a/a6waisAoepJlBcx9paWqjA8/HVjCw==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/dom-query": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/dom-query/-/dom-query-0.31.1.tgz",
+ "integrity": "sha512-oiuohEXAXhBxpzzNm9k2VHGEOLC1SXlXSbRPcfBZ9so5NRQUA++zCE7cyQJqGLTZR0t3itFLlZqDbYEXRrefwg==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/element-size": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/element-size/-/element-size-0.31.1.tgz",
+ "integrity": "sha512-4T3yvn5NqqAjhlP326Fv+w9RqMIBbNN9H72g5q2ohwzhSgSfZzrKtjL4rs9axY/cw9UfMfXjRjEE98e5CMq7WQ==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/focus-visible": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/focus-visible/-/focus-visible-0.31.1.tgz",
+ "integrity": "sha512-dbLksz7FEwyFoANbpIlNnd3bVm0clQSUsnP8yUVQucStZPsuWjCrhL2jlAbGNrTrahX96ntUMXHb/sM68TibFg==",
+ "license": "MIT",
+ "dependencies": {
+ "@zag-js/dom-query": "0.31.1"
+ }
+ },
+ "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/babel-plugin-macros": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz",
+ "integrity": "sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.12.5",
+ "cosmiconfig": "^7.0.0",
+ "resolve": "^1.19.0"
+ },
+ "engines": {
+ "node": ">=10",
+ "npm": ">=6"
+ }
+ },
+ "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/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001705",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001705.tgz",
+ "integrity": "sha512-S0uyMMiYvA7CxNgomYBwwwPUnWzFD83f3B1ce5jHUfHTH//QL6hHsreI8RVC5606R4ssqravelYO5TU6t8sEyg==",
+ "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/classnames": {
+ "version": "2.5.1",
+ "resolved": "https://registry.npmjs.org/classnames/-/classnames-2.5.1.tgz",
+ "integrity": "sha512-saHYOzhIQs6wy2sVxTM6bUDsQO4F50V9RQ22qBpEdCW+I+/Wmke2HOl6lS6dTpdxVhb88/I6+Hs+438c3lfUow==",
+ "license": "MIT"
+ },
+ "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/color2k": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/color2k/-/color2k-2.0.3.tgz",
+ "integrity": "sha512-zW190nQTIoXcGCaU08DvVNFTmQhUpnJfVuAKfWqUQkflXKpaDdpaYoM0iluLS9lgJNHyBF58KKA2FBEwkD7wog==",
+ "license": "MIT"
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "license": "MIT"
+ },
+ "node_modules/copy-to-clipboard": {
+ "version": "3.3.3",
+ "resolved": "https://registry.npmjs.org/copy-to-clipboard/-/copy-to-clipboard-3.3.3.tgz",
+ "integrity": "sha512-2KV8NhB5JqC3ky0r9PMCAZKbUHSwtEo4CwCs0KXgruG43gX5PMqDEBbVU4OUzw2MuAWUfsuFmWvEKG5QRfSnJA==",
+ "license": "MIT",
+ "dependencies": {
+ "toggle-selection": "^1.0.6"
+ }
+ },
+ "node_modules/cosmiconfig": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
+ "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/parse-json": "^4.0.0",
+ "import-fresh": "^3.2.1",
+ "parse-json": "^5.0.0",
+ "path-type": "^4.0.0",
+ "yaml": "^1.10.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "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/debug": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz",
+ "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==",
+ "license": "MIT",
+ "dependencies": {
+ "ms": "^2.1.3"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "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/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==",
+ "license": "MIT",
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "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==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/find-root": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz",
+ "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==",
+ "license": "MIT"
+ },
+ "node_modules/focus-lock": {
+ "version": "1.3.6",
+ "resolved": "https://registry.npmjs.org/focus-lock/-/focus-lock-1.3.6.tgz",
+ "integrity": "sha512-Ik/6OCk9RQQ0T5Xw+hKNLWrjSMtv51dD4GRmJjbD5a58TIEpI5a5iXagKVl3Z5UuyslMCA8Xwnu76jQob62Yhg==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^2.0.3"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/framer-motion": {
+ "version": "11.18.2",
+ "resolved": "https://registry.npmjs.org/framer-motion/-/framer-motion-11.18.2.tgz",
+ "integrity": "sha512-5F5Och7wrvtLVElIpclDT0CBzMVg3dL22B64aZwHtsIY8RB4mXICLrkajK4G9R+ieSAGcgrLeae2SeUTg2pr6w==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-dom": "^11.18.1",
+ "motion-utils": "^11.18.1",
+ "tslib": "^2.4.0"
+ },
+ "peerDependencies": {
+ "@emotion/is-prop-valid": "*",
+ "react": "^18.0.0 || ^19.0.0",
+ "react-dom": "^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@emotion/is-prop-valid": {
+ "optional": true
+ },
+ "react": {
+ "optional": true
+ },
+ "react-dom": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/framesync": {
+ "version": "6.1.2",
+ "resolved": "https://registry.npmjs.org/framesync/-/framesync-6.1.2.tgz",
+ "integrity": "sha512-jBTqhX6KaQVDyus8muwZbBeGGP0XgujBRbQ7gM7BRdS3CadCZIHiawyzYLnafYcvZIh5j8WE7cxZKFn7dXhu9g==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "2.4.0"
+ }
+ },
+ "node_modules/framesync/node_modules/tslib": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz",
+ "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==",
+ "license": "0BSD"
+ },
+ "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/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/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "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/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/hoist-non-react-statics": {
+ "version": "3.3.2",
+ "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz",
+ "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==",
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "react-is": "^16.7.0"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
+ "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
+ "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/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "license": "MIT"
+ },
+ "node_modules/is-core-module": {
+ "version": "2.16.1",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.16.1.tgz",
+ "integrity": "sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==",
+ "license": "MIT",
+ "dependencies": {
+ "hasown": "^2.0.2"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "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/jsesc": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz",
+ "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==",
+ "license": "MIT",
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "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==",
+ "license": "MIT"
+ },
+ "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/lodash.mergewith": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz",
+ "integrity": "sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ==",
+ "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/motion-dom": {
+ "version": "11.18.1",
+ "resolved": "https://registry.npmjs.org/motion-dom/-/motion-dom-11.18.1.tgz",
+ "integrity": "sha512-g76KvA001z+atjfxczdRtw/RXOM3OMSdd1f4DL77qCTF/+avrRJiawSG4yDibEQ215sr9kpinSlX2pCTJ9zbhw==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-utils": "^11.18.1"
+ }
+ },
+ "node_modules/motion-utils": {
+ "version": "11.18.1",
+ "resolved": "https://registry.npmjs.org/motion-utils/-/motion-utils-11.18.1.tgz",
+ "integrity": "sha512-49Kt+HKjtbJKLtgO/LKj9Ld+6vw9BjH5d9sc40R/kVyH8GLAXgT42M2NnuPcJNuA3s9ZfZBUcwIgpmZWGEE+hA==",
+ "license": "MIT"
+ },
+ "node_modules/ms": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.10",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.10.tgz",
+ "integrity": "sha512-vSJJTG+t/dIKAUhUDw/dLdZ9s//5OxcHqLaDWWrW4Cdq7o6tdLIczUkMXt2MBNmk6sJRZBZRXVixs7URY1CmIg==",
+ "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/next": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/next/-/next-14.2.5.tgz",
+ "integrity": "sha512-0f8aRfBVL+mpzfBjYfQuLWh2WyAwtJXCRfkPF4UJ5qd2YwrHczsrSzXU4tRMV0OAxR8ZJZWPFn6uhSC56UTsLA==",
+ "license": "MIT",
+ "dependencies": {
+ "@next/env": "14.2.5",
+ "@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.5",
+ "@next/swc-darwin-x64": "14.2.5",
+ "@next/swc-linux-arm64-gnu": "14.2.5",
+ "@next/swc-linux-arm64-musl": "14.2.5",
+ "@next/swc-linux-x64-gnu": "14.2.5",
+ "@next/swc-linux-x64-musl": "14.2.5",
+ "@next/swc-win32-arm64-msvc": "14.2.5",
+ "@next/swc-win32-ia32-msvc": "14.2.5",
+ "@next/swc-win32-x64-msvc": "14.2.5"
+ },
+ "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/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/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==",
+ "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==",
+ "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-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-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
+ "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
+ "license": "ISC"
+ },
+ "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/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/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-clientside-effect": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/react-clientside-effect/-/react-clientside-effect-1.2.7.tgz",
+ "integrity": "sha512-gce9m0Pk/xYYMEojRI9bgvqQAkl6hm7ozQvqWPyQx+kULiatdHgkNM1QG4DQRx5N9BAzWSCJmt9mMV8/KsdgVg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.12.13"
+ },
+ "peerDependencies": {
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ }
+ },
+ "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-fast-compare": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-3.2.2.tgz",
+ "integrity": "sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ==",
+ "license": "MIT"
+ },
+ "node_modules/react-focus-lock": {
+ "version": "2.13.6",
+ "resolved": "https://registry.npmjs.org/react-focus-lock/-/react-focus-lock-2.13.6.tgz",
+ "integrity": "sha512-ehylFFWyYtBKXjAO9+3v8d0i+cnc1trGS0vlTGhzFW1vbFXVUTmR8s2tt/ZQG8x5hElg6rhENlLG1H3EZK0Llg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.0.0",
+ "focus-lock": "^1.3.6",
+ "prop-types": "^15.6.2",
+ "react-clientside-effect": "^1.2.7",
+ "use-callback-ref": "^1.3.3",
+ "use-sidecar": "^1.1.3"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "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-remove-scroll": {
+ "version": "2.6.3",
+ "resolved": "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.6.3.tgz",
+ "integrity": "sha512-pnAi91oOk8g8ABQKGF5/M9qxmmOPxaAnopyTHYfqYEwJhyFrbbBtHuSgtKEoH0jpcxx5o3hXqH1mNd9/Oi+8iQ==",
+ "license": "MIT",
+ "dependencies": {
+ "react-remove-scroll-bar": "^2.3.7",
+ "react-style-singleton": "^2.2.3",
+ "tslib": "^2.1.0",
+ "use-callback-ref": "^1.3.3",
+ "use-sidecar": "^1.1.3"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-remove-scroll-bar": {
+ "version": "2.3.8",
+ "resolved": "https://registry.npmjs.org/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.8.tgz",
+ "integrity": "sha512-9r+yi9+mgU33AKcj6IbT9oRCO78WriSj6t/cF8DWBZJ9aOGPOTEDvdUDz1FwKim7QXWwmHqtdHnRJfhAxEG46Q==",
+ "license": "MIT",
+ "dependencies": {
+ "react-style-singleton": "^2.2.2",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-style-singleton": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/react-style-singleton/-/react-style-singleton-2.2.3.tgz",
+ "integrity": "sha512-b6jSvxvVnyptAiLjbkWLE/lOnR4lfTtDAl+eUC7RZy+QQWc6wRzIV2CE6xBuMmDxc2qIihtDCZD5NPOFl7fRBQ==",
+ "license": "MIT",
+ "dependencies": {
+ "get-nonce": "^1.0.0",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "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/resolve": {
+ "version": "1.22.10",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.10.tgz",
+ "integrity": "sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w==",
+ "license": "MIT",
+ "dependencies": {
+ "is-core-module": "^2.16.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "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==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "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/source-map": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
+ "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
+ "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "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/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/stylis": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.2.0.tgz",
+ "integrity": "sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw==",
+ "license": "MIT"
+ },
+ "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/toggle-selection": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/toggle-selection/-/toggle-selection-1.0.6.tgz",
+ "integrity": "sha512-BiZS+C1OS8g/q2RRbJmy59xpyghNBqrr6k5L/uKBGRsTfxmu3ffiRnd8mlGPUVayg8pvfi5urfnu8TU7DVOkLQ==",
+ "license": "MIT"
+ },
+ "node_modules/tslib": {
+ "version": "2.8.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz",
+ "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==",
+ "license": "0BSD"
+ },
+ "node_modules/use-callback-ref": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/use-callback-ref/-/use-callback-ref-1.3.3.tgz",
+ "integrity": "sha512-jQL3lRnocaFtu3V00JToYz/4QkNWswxijDaCVNZRiRTO3HQDLsdu1ZtmIUvV4yPp+rvWm5j0y0TG/S61cuijTg==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/use-sidecar": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.3.tgz",
+ "integrity": "sha512-Fedw0aZvkhynoPYlA5WXrMCAMm+nSWdZt6lzJQ7Ok8S6Q+VsHmHpRWndVRJ8Be0ZbkfPc5LRYH+5XrzXcEeLRQ==",
+ "license": "MIT",
+ "dependencies": {
+ "detect-node-es": "^1.1.0",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "license": "ISC",
+ "engines": {
+ "node": ">= 6"
+ }
+ }
+ }
+}
diff --git a/react/react1/week1/package.json b/react/react1/week1/package.json
new file mode 100644
index 00000000..fb950f56
--- /dev/null
+++ b/react/react1/week1/package.json
@@ -0,0 +1,22 @@
+{
+ "name": "space-turism",
+ "version": "0.1.0",
+ "private": true,
+ "scripts": {
+ "dev": "next dev",
+ "build": "next build",
+ "start": "next start"
+ },
+ "dependencies": {
+ "@chakra-ui/next-js": "^2.2.0",
+ "@chakra-ui/react": "^2.8.2",
+ "@emotion/react": "^11.13.0",
+ "@emotion/styled": "^11.13.0",
+ "classnames": "^2.5.1",
+ "framer-motion": "^11.3.28",
+ "next": "14.2.5",
+ "react": "^18",
+ "react-dom": "^18"
+ },
+ "devDependencies": {}
+}
diff --git a/react/react1/week1/public/business_partners/CBC_Logo_White.png b/react/react1/week1/public/business_partners/CBC_Logo_White.png
new file mode 100644
index 00000000..eeb0390f
Binary files /dev/null and b/react/react1/week1/public/business_partners/CBC_Logo_White.png differ
diff --git a/react/react1/week1/public/business_partners/Microsoft-Logo-white.png b/react/react1/week1/public/business_partners/Microsoft-Logo-white.png
new file mode 100644
index 00000000..f37d4dfe
Binary files /dev/null and b/react/react1/week1/public/business_partners/Microsoft-Logo-white.png differ
diff --git a/react/react1/week1/public/business_partners/QueensLogo_white.png b/react/react1/week1/public/business_partners/QueensLogo_white.png
new file mode 100644
index 00000000..618ed1ed
Binary files /dev/null and b/react/react1/week1/public/business_partners/QueensLogo_white.png differ
diff --git a/react/react1/week1/public/business_partners/alphabet-logo.png b/react/react1/week1/public/business_partners/alphabet-logo.png
new file mode 100644
index 00000000..637f9f4f
Binary files /dev/null and b/react/react1/week1/public/business_partners/alphabet-logo.png differ
diff --git a/react/react1/week1/public/business_partners/amazon_logo.png b/react/react1/week1/public/business_partners/amazon_logo.png
new file mode 100644
index 00000000..af0a9c3c
Binary files /dev/null and b/react/react1/week1/public/business_partners/amazon_logo.png differ
diff --git a/react/react1/week1/public/business_partners/nyu-logo.png b/react/react1/week1/public/business_partners/nyu-logo.png
new file mode 100644
index 00000000..9482feeb
Binary files /dev/null and b/react/react1/week1/public/business_partners/nyu-logo.png differ
diff --git a/react/react1/week1/public/business_partners/samsung-logo.png b/react/react1/week1/public/business_partners/samsung-logo.png
new file mode 100644
index 00000000..bc43aec3
Binary files /dev/null and b/react/react1/week1/public/business_partners/samsung-logo.png differ
diff --git a/react/react1/week1/public/business_partners/sodexo-logo.png b/react/react1/week1/public/business_partners/sodexo-logo.png
new file mode 100644
index 00000000..accf9fa9
Binary files /dev/null and b/react/react1/week1/public/business_partners/sodexo-logo.png differ
diff --git a/react/react1/week1/public/crew/background-crew-desktop.jpg b/react/react1/week1/public/crew/background-crew-desktop.jpg
new file mode 100644
index 00000000..34ac3641
Binary files /dev/null and b/react/react1/week1/public/crew/background-crew-desktop.jpg differ
diff --git a/react/react1/week1/public/crew/background-crew-mobile.jpg b/react/react1/week1/public/crew/background-crew-mobile.jpg
new file mode 100644
index 00000000..d8237856
Binary files /dev/null and b/react/react1/week1/public/crew/background-crew-mobile.jpg differ
diff --git a/react/react1/week1/public/crew/background-crew-tablet.jpg b/react/react1/week1/public/crew/background-crew-tablet.jpg
new file mode 100644
index 00000000..16997036
Binary files /dev/null and b/react/react1/week1/public/crew/background-crew-tablet.jpg differ
diff --git a/react/react1/week1/public/crew/image-anousheh-ansari.png b/react/react1/week1/public/crew/image-anousheh-ansari.png
new file mode 100644
index 00000000..52a986f6
Binary files /dev/null and b/react/react1/week1/public/crew/image-anousheh-ansari.png differ
diff --git a/react/react1/week1/public/crew/image-anousheh-ansari.webp b/react/react1/week1/public/crew/image-anousheh-ansari.webp
new file mode 100644
index 00000000..fe05e556
Binary files /dev/null and b/react/react1/week1/public/crew/image-anousheh-ansari.webp differ
diff --git a/react/react1/week1/public/crew/image-douglas-hurley.png b/react/react1/week1/public/crew/image-douglas-hurley.png
new file mode 100644
index 00000000..1b036c01
Binary files /dev/null and b/react/react1/week1/public/crew/image-douglas-hurley.png differ
diff --git a/react/react1/week1/public/crew/image-douglas-hurley.webp b/react/react1/week1/public/crew/image-douglas-hurley.webp
new file mode 100644
index 00000000..17d7b0db
Binary files /dev/null and b/react/react1/week1/public/crew/image-douglas-hurley.webp differ
diff --git a/react/react1/week1/public/crew/image-mark-shuttleworth.png b/react/react1/week1/public/crew/image-mark-shuttleworth.png
new file mode 100644
index 00000000..e4cf63b9
Binary files /dev/null and b/react/react1/week1/public/crew/image-mark-shuttleworth.png differ
diff --git a/react/react1/week1/public/crew/image-mark-shuttleworth.webp b/react/react1/week1/public/crew/image-mark-shuttleworth.webp
new file mode 100644
index 00000000..b22b63b7
Binary files /dev/null and b/react/react1/week1/public/crew/image-mark-shuttleworth.webp differ
diff --git a/react/react1/week1/public/crew/image-victor-glover.png b/react/react1/week1/public/crew/image-victor-glover.png
new file mode 100644
index 00000000..f31b5810
Binary files /dev/null and b/react/react1/week1/public/crew/image-victor-glover.png differ
diff --git a/react/react1/week1/public/crew/image-victor-glover.webp b/react/react1/week1/public/crew/image-victor-glover.webp
new file mode 100644
index 00000000..5cb85ecf
Binary files /dev/null and b/react/react1/week1/public/crew/image-victor-glover.webp differ
diff --git a/react/react1/week1/public/destination/background-destination-desktop.jpg b/react/react1/week1/public/destination/background-destination-desktop.jpg
new file mode 100644
index 00000000..57eb0251
Binary files /dev/null and b/react/react1/week1/public/destination/background-destination-desktop.jpg differ
diff --git a/react/react1/week1/public/destination/background-destination-mobile.jpg b/react/react1/week1/public/destination/background-destination-mobile.jpg
new file mode 100644
index 00000000..4dd02036
Binary files /dev/null and b/react/react1/week1/public/destination/background-destination-mobile.jpg differ
diff --git a/react/react1/week1/public/destination/background-destination-tablet.jpg b/react/react1/week1/public/destination/background-destination-tablet.jpg
new file mode 100644
index 00000000..9220c6c9
Binary files /dev/null and b/react/react1/week1/public/destination/background-destination-tablet.jpg differ
diff --git a/react/react1/week1/public/destination/image-europa.png b/react/react1/week1/public/destination/image-europa.png
new file mode 100644
index 00000000..e6addcf0
Binary files /dev/null and b/react/react1/week1/public/destination/image-europa.png differ
diff --git a/react/react1/week1/public/destination/image-europa.webp b/react/react1/week1/public/destination/image-europa.webp
new file mode 100644
index 00000000..532821f8
Binary files /dev/null and b/react/react1/week1/public/destination/image-europa.webp differ
diff --git a/react/react1/week1/public/destination/image-mars.png b/react/react1/week1/public/destination/image-mars.png
new file mode 100644
index 00000000..d2040430
Binary files /dev/null and b/react/react1/week1/public/destination/image-mars.png differ
diff --git a/react/react1/week1/public/destination/image-mars.webp b/react/react1/week1/public/destination/image-mars.webp
new file mode 100644
index 00000000..f81679be
Binary files /dev/null and b/react/react1/week1/public/destination/image-mars.webp differ
diff --git a/react/react1/week1/public/destination/image-moon.png b/react/react1/week1/public/destination/image-moon.png
new file mode 100644
index 00000000..0bcaf85d
Binary files /dev/null and b/react/react1/week1/public/destination/image-moon.png differ
diff --git a/react/react1/week1/public/destination/image-moon.webp b/react/react1/week1/public/destination/image-moon.webp
new file mode 100644
index 00000000..ed3ed05e
Binary files /dev/null and b/react/react1/week1/public/destination/image-moon.webp differ
diff --git a/react/react1/week1/public/destination/image-titan.png b/react/react1/week1/public/destination/image-titan.png
new file mode 100644
index 00000000..3a6cb885
Binary files /dev/null and b/react/react1/week1/public/destination/image-titan.png differ
diff --git a/react/react1/week1/public/destination/image-titan.webp b/react/react1/week1/public/destination/image-titan.webp
new file mode 100644
index 00000000..7165bf83
Binary files /dev/null and b/react/react1/week1/public/destination/image-titan.webp differ
diff --git a/react/react1/week1/public/destination/planetary-lineup_3x4.png b/react/react1/week1/public/destination/planetary-lineup_3x4.png
new file mode 100644
index 00000000..d876cc56
Binary files /dev/null and b/react/react1/week1/public/destination/planetary-lineup_3x4.png differ
diff --git a/react/react1/week1/public/home/background-home-desktop.jpg b/react/react1/week1/public/home/background-home-desktop.jpg
new file mode 100644
index 00000000..6d6bfe0f
Binary files /dev/null and b/react/react1/week1/public/home/background-home-desktop.jpg differ
diff --git a/react/react1/week1/public/home/background-home-mobile.jpg b/react/react1/week1/public/home/background-home-mobile.jpg
new file mode 100644
index 00000000..f88a6af4
Binary files /dev/null and b/react/react1/week1/public/home/background-home-mobile.jpg differ
diff --git a/react/react1/week1/public/home/background-home-tablet.jpg b/react/react1/week1/public/home/background-home-tablet.jpg
new file mode 100644
index 00000000..e4a2d9a9
Binary files /dev/null and b/react/react1/week1/public/home/background-home-tablet.jpg differ
diff --git a/react/react1/week1/public/shared/icon-close.svg b/react/react1/week1/public/shared/icon-close.svg
new file mode 100644
index 00000000..ace11dbc
--- /dev/null
+++ b/react/react1/week1/public/shared/icon-close.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week1/public/shared/icon-hamburger.svg b/react/react1/week1/public/shared/icon-hamburger.svg
new file mode 100644
index 00000000..7e5eab1d
--- /dev/null
+++ b/react/react1/week1/public/shared/icon-hamburger.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week1/public/shared/logo.svg b/react/react1/week1/public/shared/logo.svg
new file mode 100644
index 00000000..94fe604b
--- /dev/null
+++ b/react/react1/week1/public/shared/logo.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week1/readme.md b/react/react1/week1/readme.md
index 8b137891..b80541fc 100644
--- a/react/react1/week1/readme.md
+++ b/react/react1/week1/readme.md
@@ -1 +1,41 @@
+# Galactica Space Travel App
+## Introduction
+Galactica is a space travel application built with Next.js and React. This project aims to teach students the fundamentals of React and Next.js by creating a dynamic and interactive space exploration app.
+
+## Prerequisites
+- Node.js (version 18 or higher)
+- npm or yarn
+
+## Getting Started
+
+### Installation
+1. Fork the repository (Recommended)
+2. Clone the repository using Code > Clone
+
+Now you should have to project on your computer.
+
+3. cd into the homework folder
+4. run `npm install`
+
+
+### Running the Development Server
+
+`npm run dev`
+
+Open your browser and navigate to http://localhost:3000 to see the app in action.
+
+## HOMEWORKS:
+
+Throughout the weeks you will be adding new features to this existing application.
+For your tasks you should be searching for the following:
+
+- Tasks for week1: `TASK - React 1 week 1`
+- Tasks for week2: `TASK - React 1 week 2`
+- Tasks for week3: `TASK - React 1 week 3`
+
+You should be fixing ALL THE INSTANSCES of the current week.
+
+### How to find the tags?
+
+Use the global search function in your IDE. (`cmnd + shift + F` OR `Control + shift + F`)
\ No newline at end of file
diff --git a/react/react1/week2/.gitignore b/react/react1/week2/.gitignore
new file mode 100644
index 00000000..3e161128
--- /dev/null
+++ b/react/react1/week2/.gitignore
@@ -0,0 +1,6 @@
+.DS_Store
+node_modules
+.next
+jsconfig.json
+next.config.mjs
+data
\ No newline at end of file
diff --git a/react/react1/week2/app/about_us/README.md b/react/react1/week2/app/about_us/README.md
new file mode 100644
index 00000000..ee4b4656
--- /dev/null
+++ b/react/react1/week2/app/about_us/README.md
@@ -0,0 +1,47 @@
+# TASK 1
+
+Let's finish the "About Us" page!
+
+## Content to use
+
+### Our Mission
+
+At Galactica, our mission is to unlock the wonders of the universe for everyone. We believe that space is the final frontier and that the opportunity to explore it should be within everyone’s reach. Our journeys are designed to inspire, educate, and provide a once-in-a-lifetime experience that transcends the ordinary.
+
+### Our Values
+
+Exploration: We are driven by a deep-seated desire to explore the unknown. We believe that the pursuit of discovery is at the heart of human nature, and we are committed to pushing the boundaries of what is possible.
+
+Innovation: At Galactica, we prioritize cutting-edge technology and innovation. We are constantly evolving our spacecraft, safety protocols, and services to ensure that our travelers experience the most advanced and secure space journeys available.
+
+Sustainability: We are committed to making space exploration sustainable for future generations. Our space missions are designed to minimize environmental impact, both on Earth and in space, and to foster a spirit of responsibility towards our universe.
+
+Community: We believe in the power of collective exploration. Our journeys are not just about reaching new destinations; they are about building a community of space enthusiasts who share a passion for the stars.
+
+
+### Our Crew
+
+#### Description
+Our crew is the heart and soul of Galactica. We are a diverse team of seasoned space explorers, engineers, and visionaries who are united by a common goal: to make space travel accessible and exciting for all.
+
+Captain Sarah Vega: A former NASA astronaut with over 15 years of experience, Captain Vega leads our missions with unparalleled expertise and a passion for space exploration.
+
+Dr. Leo Redding: Our chief astrophysicist, Dr. Redding, is a renowned scientist who has contributed to major space discoveries. He ensures that every journey is as educational as it is exhilarating.
+
+Chief Engineer Hana Lee: With her extensive background in aerospace engineering, Hana Lee is responsible for the state-of-the-art technology that powers our spacecraft. Her innovation ensures that our travelers are always in safe hands.
+
+Mission Specialist Alex Santos: As a mission specialist, Alex’s job is to ensure that every aspect of the journey runs smoothly. With a background in both science and adventure tourism, Alex is the perfect guide for our space travelers.
+
+Crew Member Maya Patel: Maya brings a unique blend of technical skills and customer service experience to the team. She’s always ready to assist with any needs and to make sure every traveler has an unforgettable experience.
+
+#### Content
+
+Use the content saved in the `/public/crew` folder!
+
+### Our Partners
+
+We collaborate with some of the most respected names in the space and technology industries to make every journey extraordinary.
+
+#### Content
+
+Use the content saved in the `/public/business_partners` folder!
\ No newline at end of file
diff --git a/react/react1/week2/app/about_us/ourCrew.js b/react/react1/week2/app/about_us/ourCrew.js
new file mode 100644
index 00000000..cf0d5a1c
--- /dev/null
+++ b/react/react1/week2/app/about_us/ourCrew.js
@@ -0,0 +1,56 @@
+import styles from "./page.module.css";
+
+const crew = [
+ {
+ img: "/crew/image-douglas-hurley.webp",
+ name: "Captain Douglas Hurley",
+ description:
+ "A former NASA astronaut with over 15 years of experience, Captain Douglas leads our missions with unparalleled expertise and a passion for space exploration.",
+ },
+ {
+ img: "/crew/image-anousheh-ansari.webp",
+ name: "Chief Engineer Anousheh Ansari",
+ description:
+ "With her extensive background in aerospace engineering, Anousheh is responsible for the state-of-the-art technology that powers our spacecraft. Her innovation ensures that our travelers are always in safe hands.",
+ },
+ {
+ img: "/crew/image-mark-shuttleworth.webp",
+ name: "Crew Member Mark Shuttleworth",
+ description:
+ "Mark brings a unique blend of technical skills and customer service experience to the team. He's always ready to assist with any needs and to make sure every traveler has an unforgettable experience",
+ },
+ {
+ img: "/crew/image-victor-glover.webp",
+ name: "Mission Specialist Victor Glover",
+ description:
+ "As a mission specialist, Victor's job is to ensure that every aspect of the journey runs smoothly. With a background in both science and adventure tourism, Victor is the perfect guide for our space travelers.",
+ },
+];
+
+const OurCrew = () => {
+ return (
+
+ Meet our talented crew
+
+ Our crew is the heart and soul of Galactica. We are a diverse team of
+ seasoned space explorers, engineers, and visionaries who are united by a
+ common goal: to make space travel accessible and exciting for all.
+
+
+ {crew.map((member, index) => (
+
+
+
{member.name}
+
{member.description}
+
+ ))}
+
+
+ );
+};
+
+export default OurCrew;
diff --git a/react/react1/week2/app/about_us/ourPartners.js b/react/react1/week2/app/about_us/ourPartners.js
new file mode 100644
index 00000000..b2e173e4
--- /dev/null
+++ b/react/react1/week2/app/about_us/ourPartners.js
@@ -0,0 +1,39 @@
+import styles from "@/app/about_us/page.module.css";
+
+const partners = [
+ { name: "alphabet", img: "/business_partners/alphabet-logo.png" },
+ { name: "amazon", img: "/business_partners/amazon_logo.png" },
+ { name: "cbc", img: "/business_partners/CBC_Logo_White.png" },
+ { name: "microsoft", img: "/business_partners/Microsoft-Logo-white.png" },
+ { name: "nyu", img: "/business_partners/nyu-logo.png" },
+ { name: "queen", img: "/business_partners/QueensLogo_white.png" },
+ { name: "samsung", img: "/business_partners/samsung-logo.png" },
+ { name: "sodexo", img: "/business_partners/sodexo-logo.png" },
+];
+
+const OurPartners = () => {
+ return (
+
+ OUR PARTNERS
+
+ We collaborate with some of the most respected names in the space and
+ technology industries to make every journey extraordinary.
+
+
+ {partners.map((partner, index) => {
+ return (
+
+
+
+ );
+ })}
+
+
+ );
+};
+
+export default OurPartners;
diff --git a/react/react1/week2/app/about_us/ourValues.js b/react/react1/week2/app/about_us/ourValues.js
new file mode 100644
index 00000000..0b6f0365
--- /dev/null
+++ b/react/react1/week2/app/about_us/ourValues.js
@@ -0,0 +1,28 @@
+const values = [
+ {
+ number: "01",
+ title: "Exploration",
+ description:
+ "We are driven by a deep-seated desire to explore the unknown. We believe that the pursuit of discovery is at the heart of human nature, and we are committed to pushing the boundaries of what is possible.",
+ },
+ {
+ number: "02",
+ title: "Innovation",
+ description:
+ "At Galactica, we prioritize cutting-edge technology and innovation. We are constantly evolving our spacecraft, safety protocols, and services to ensure that our travelers experience the most advanced and secure space journeys available.",
+ },
+ {
+ number: "03",
+ title: "Sustainability",
+ description:
+ "We are committed to making space exploration sustainable for future generations. Our space missions are designed to minimize environmental impact, both on Earth and in space, and to foster a spirit of responsibility towards our universe",
+ },
+ {
+ number: "04",
+ title: "Community",
+ description:
+ "We believe in the power of collective exploration. Our journeys are not just about reaching new destinations; they are about building a community of space enthusiasts who share a passion for the stars.",
+ },
+];
+
+export default values;
diff --git a/react/react1/week2/app/about_us/page.js b/react/react1/week2/app/about_us/page.js
new file mode 100644
index 00000000..e4b49048
--- /dev/null
+++ b/react/react1/week2/app/about_us/page.js
@@ -0,0 +1,45 @@
+import styles from "./page.module.css";
+import values from "./ourValues";
+import OurCrew from "./ourCrew.js";
+import OurPartners from "./ourPartners";
+
+const OurValues = () => {
+ return (
+
+
+ Our Values
+
+
+ {values.map((value, index) => (
+
+
{value.number}
+
{value.title}
+
{value.description}
+
+
+ ))}
+
+
+ );
+};
+
+export const Crew = () => {
+ return (
+
+
+ About us
+
+
+
+
+
+ );
+};
+
+export default Crew;
diff --git a/react/react1/week2/app/about_us/page.module.css b/react/react1/week2/app/about_us/page.module.css
new file mode 100644
index 00000000..7f3d1cec
--- /dev/null
+++ b/react/react1/week2/app/about_us/page.module.css
@@ -0,0 +1,134 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+.OurValues {
+ background-color: #121212;
+ color: #fff;
+ padding: 4rem 2rem;
+ text-align: center;
+}
+.OurValues h2 {
+ font-size: 1rem;
+ font-weight: bold;
+ text-transform: uppercase;
+ letter-spacing: 2px;
+ opacity: 0.8;
+}
+
+.grid {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
+ gap: 2rem;
+ max-width: 900px;
+ margin: 0 auto;
+}
+
+.card {
+ text-align: left;
+ padding: 2rem;
+ background-color: #1a1a1a;
+ border-radius: 8px;
+ position: relative;
+}
+
+.number {
+ font-size: 3rem;
+ font-weight: bold;
+ display: block;
+ margin-bottom: 1rem;
+}
+
+.title {
+ font-size: 1.5rem;
+ font-weight: bold;
+ margin-bottom: 0.5rem;
+}
+
+.description {
+ font-size: 1rem;
+ opacity: 0.8;
+}
+
+.divider {
+ width: 100%;
+ height: 1px;
+ background-color: #333;
+ margin-top: 2rem;
+}
+
+.card:hover {
+ transform: scale(1.02);
+ transition: transform 0.3s ease-in-out;
+}
+
+.ourCrew {
+ padding: 2rem;
+ text-align: center;
+ background-color: #111;
+}
+
+.ourCrew p {
+ padding: 2rem;
+}
+
+.crewList {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
+ gap: 20px;
+ justify-items: center;
+}
+
+.crewMember {
+ background-color: #f9f9f9;
+ padding: 20px;
+ border-radius: 10px;
+ box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1);
+ transition: transform 0.2s ease-in-out;
+ max-width: 250px;
+}
+
+.crewMember:hover {
+ transform: scale(1.05);
+}
+
+.crewImage {
+ width: 180px;
+ height: 180px;
+ border-radius: 50%;
+ object-fit: cover;
+ margin-bottom: 10px;
+ align-self: center;
+}
+
+.ourPartners {
+ background-color: #111;
+ padding: 50px;
+ color: white;
+}
+
+.gridStyle {
+ display: grid;
+ grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
+ gap: 60px;
+ align-items: center;
+ justify-content: center;
+ padding: 50px;
+ text-align: center;
+}
+
+.logoContainer {
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ height: 100px;
+}
+
+.imageStyle {
+ max-width: 120px;
+ max-height: 80px;
+ object-fit: contain;
+ filter: brightness(0) invert(1);
+}
diff --git a/react/react1/week2/app/destination/PlanetCard.jsx b/react/react1/week2/app/destination/PlanetCard.jsx
new file mode 100644
index 00000000..0baf3224
--- /dev/null
+++ b/react/react1/week2/app/destination/PlanetCard.jsx
@@ -0,0 +1,25 @@
+import React from "react";
+import styles from "@/components/destination/destination.module.css";
+
+const PlanetCard = ({
+ name,
+ description,
+ thumbnail,
+ isSelected,
+ onAddOrRemovePlanet,
+}) => (
+
+
+
+
+ {name} {isSelected ? "- SELECTED" : ""}
+
+
{description}
+
+
onAddOrRemovePlanet(name)}>
+ {isSelected ? "REMOVE" : "ADD PLANET"}
+
+
+);
+
+export default PlanetCard;
diff --git a/react/react1/week2/app/destination/PlanetWishlistItem.js b/react/react1/week2/app/destination/PlanetWishlistItem.js
new file mode 100644
index 00000000..03cbbe82
--- /dev/null
+++ b/react/react1/week2/app/destination/PlanetWishlistItem.js
@@ -0,0 +1,13 @@
+"use client";
+import styles from "@/components/destination/destination.module.css";
+const PlanetWishlistItem = ({ name, onRemove, thumbnail }) => {
+ return (
+
+
+
{name.toUpperCase()}
+
remove
+
+ );
+};
+
+export default PlanetWishlistItem;
diff --git a/react/react1/week2/app/destination/README.md b/react/react1/week2/app/destination/README.md
new file mode 100644
index 00000000..58a9252d
--- /dev/null
+++ b/react/react1/week2/app/destination/README.md
@@ -0,0 +1,13 @@
+## Descriptions for the planets
+
+### Europa
+Europa, one of Jupiter’s moons, is an icy world with a hidden ocean beneath its surface. This mysterious moon is a prime candidate for the search for extraterrestrial life, making it a thrilling destination for space explorers.
+
+### Mars
+Mars, the Red Planet, is a barren yet fascinating world with vast deserts, towering volcanoes, and the deepest canyon in the solar system. As humanity’s next frontier, Mars invites us to dream of colonization and the possibilities of life beyond Earth.
+
+### Moon
+Our closest celestial neighbor, the Moon, is a silent witness to Earth's history. With its stunning craters and desolate landscapes, the Moon offers a unique glimpse into space exploration's past and future, making it a perfect destination for lunar adventurers.
+
+### Titan
+Titan, Saturn's largest moon, is a world of dense atmosphere and liquid methane lakes. This enigmatic moon is shrouded in a thick orange haze, concealing a landscape that is both alien and strangely familiar, beckoning explorers to uncover its secrets.
\ No newline at end of file
diff --git a/react/react1/week2/app/destination/page.js b/react/react1/week2/app/destination/page.js
new file mode 100644
index 00000000..da06794b
--- /dev/null
+++ b/react/react1/week2/app/destination/page.js
@@ -0,0 +1,106 @@
+"use client";
+
+import { useState } from "react";
+
+import styles from "@/components/destination/destination.module.css";
+import { PlanetWishlistItem } from "@/app/destination/PlanetWishlistItem";
+import { AddWishlistItem } from "@/components/destination/AddWishlistItem";
+import PlanetCard from "./PlanetCard";
+
+export const Destinations = () => {
+ const [selectedPlanets, setSelectedPlanets] = useState([]);
+ const onAddOrRemovePlanet = (name, index) => {
+ setSelectedPlanets((prevSelected) => {
+ if (prevSelected.includes(name)) {
+ return prevSelected.filter((planet) => planet !== name);
+ } else {
+ return [...prevSelected, name];
+ }
+ });
+ console.log(
+ `You selected the following planet: ${name}, with the index of ${index}`
+ );
+ };
+ const numberOfPlanets = selectedPlanets.length;
+ return (
+
+
+ Travel destinations
+
+ Wishlist
+ {numberOfPlanets === 0 ? (
+ No planets in wishlist :(
+ ) : (
+ You have {numberOfPlanets} in your wishlist
+ )}
+ List coming soon after lesson 3!
+
+ {/* STOP! - this is for week 3!*/}
+ {/* TASK - React 1 week 3 */}
+ {/* Import the AddWishlistItem react component */}
+ {/* */}
+ {/* TASK - React 1 week 3 */}
+ {/* Convert the list, so it is using selectedPlanets.map() to display the items */}
+ {/* Implement the "REMOVE" function */}
+ {/* uncomment the following code snippet: */}
+ {/*
+ Your current wishlist
+
+
removeFromWishlist('europa')}
+ thumbnail="/destination/image-europa.png"
+ />
+ removeFromWishlist('europa')}
+ thumbnail="/destination/image-europa.png"
+ />
+ */}
+
+
+ Possible destinations
+
+
+
+
+
+
+
+
+ );
+};
+
+export default Destinations;
diff --git a/react/react1/week2/app/favicon.ico b/react/react1/week2/app/favicon.ico
new file mode 100644
index 00000000..53ae0d7b
Binary files /dev/null and b/react/react1/week2/app/favicon.ico differ
diff --git a/react/react1/week2/app/globals.css b/react/react1/week2/app/globals.css
new file mode 100644
index 00000000..de0f6718
--- /dev/null
+++ b/react/react1/week2/app/globals.css
@@ -0,0 +1,217 @@
+:root {
+ --max-width: 1100px;
+ --border-radius: 12px;
+ --font-mono: ui-monospace, Menlo, Monaco, "Cascadia Mono", "Segoe UI Mono",
+ "Roboto Mono", "Oxygen Mono", "Ubuntu Monospace", "Source Code Pro",
+ "Fira Mono", "Droid Sans Mono", "Courier New", monospace;
+
+ --foreground-rgb: 0, 0, 0;
+ --background-start-rgb: 214, 219, 220;
+ --background-end-rgb: 255, 255, 255;
+
+ --primary-background-color: #000;
+ --primary-text-color: #fff;
+ --border-color: #eee;
+ --card-bg-color: rgba(100, 100, 100, 0.3);
+
+ --primary-glow: conic-gradient(
+ from 180deg at 50% 50%,
+ #16abff33 0deg,
+ #0885ff33 55deg,
+ #54d6ff33 120deg,
+ #0071ff33 160deg,
+ transparent 360deg
+ );
+ --secondary-glow: radial-gradient(
+ rgba(255, 255, 255, 1),
+ rgba(255, 255, 255, 0)
+ );
+
+ --tile-start-rgb: 239, 245, 249;
+ --tile-end-rgb: 228, 232, 233;
+ --tile-border: conic-gradient(
+ #00000080,
+ #00000040,
+ #00000030,
+ #00000020,
+ #00000010,
+ #00000010,
+ #00000080
+ );
+
+ --callout-rgb: 238, 240, 241;
+ --callout-border-rgb: 172, 175, 176;
+ --card-rgb: 180, 185, 188;
+ --card-border-rgb: 131, 134, 135;
+
+ --spacing-04: 0.25rem;
+ --spacing-08: 0.5rem;
+ --spacing-12: 0.75rem;
+ --spacing-16: 1rem;
+ --spacing-20: 1.25rem;
+ --spacing-24: 1.5rem;
+ --spacing-32: 2rem;
+ --spacing-40: 2.5rem;
+ --spacing-48: 3rem;
+ --spacing-64: 4rem;
+
+ --font-size-3xl: 2.5rem;
+ --font-size-2xl: 2rem;
+ --font-size-xl: 1.5rem;
+ --font-size-lg: 1.25rem;
+ --font-size-md: 1rem;
+ --font-size-sm: 0.875rem;
+ --font-size-xs: 0.75rem;
+ --font-size-2xs: 0.6875rem;
+ --font-size-3xs: 0.625rem;
+ --font-size-base: 0.8125rem;
+ --font-size-jumbo: 3rem;
+ --font-size-huge: 2rem;
+ --font-size-large: 0.9375rem;
+ --font-size-lead: 0.875rem;
+ --font-size-small: 0.6875rem;
+ --font-size-tiny: 0.5625rem;
+
+ --header-height: 100px;
+}
+
+* {
+ box-sizing: border-box;
+ padding: 0;
+ margin: 0;
+}
+
+html,
+body {
+ max-width: 100vw;
+ overflow-x: hidden;
+}
+
+
+body {
+ color: rgb(var(--foreground-rgb));
+ background: linear-gradient(
+ to bottom,
+ transparent,
+ rgb(var(--background-end-rgb))
+ )
+ rgb(var(--background-start-rgb));
+}
+
+a {
+ color: inherit;
+ text-decoration: none;
+}
+
+h1, h2, h3, h4, h5, h6 {
+ margin-block-end: var(--spacing-08);
+ color: var(--primary-text-color);
+}
+
+p, b, i {
+ margin-block-end: var(--spacing-08);
+}
+
+button {
+ cursor: pointer;
+ text-transform: uppercase;
+ padding: var(--spacing-08);
+ border: none;
+ background-color: white;
+ font-weight: 600;
+ letter-spacing: 2px;
+}
+
+@media (prefers-color-scheme: dark) {
+ html {
+ color-scheme: dark;
+ }
+}
+
+.mainContent {
+ max-width: var(--max-width);
+ margin: auto;
+ padding-block-start: var(--header-height);
+ color: #fff;
+}
+
+
+.card {
+ position: relative;
+ padding: var(--spacing-12);
+ margin: var(--spacing-16);
+}
+
+.card::before {
+ background-color: var(--card-bg-color);
+ content: "";
+ position: absolute;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ backdrop-filter: blur(10px);
+}
+
+.card > * {
+ position: relative;
+ z-index: 2;
+}
+
+.roundButtonJumbo {
+ padding: unset;
+ height: 250px;
+ width: 250px;
+ min-height: 250px;
+ min-width: 250px;
+ line-height: 250px;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 30px;
+ font-weight: 200;
+ letter-spacing: 4px;
+}
+
+.roundButton {
+ padding: unset;
+ height: 100px;
+ width: 100px;
+ min-height: 100px;
+ min-width: 100px;
+ line-height: 100px;
+ cursor: pointer;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 8px;
+ font-weight: 800;
+ letter-spacing: 3px;
+}
+
+.fullBGpicture {
+ /* background: url('/destination/background-destination-desktop.jpg') no-repeat; */
+ /* background-color: #000; */
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ width: auto;
+ height: 100%;
+}
+
+.fullBGpicture::before {
+ content: "";
+ background: url('/destination/background-destination-desktop.jpg') no-repeat;
+ background-color: #000;
+ top: 0;
+ bottom: 0;
+ left: 0;
+ right: 0;
+ width: 100%;
+ height: 100%;
+ position: fixed;
+ z-index: -1;
+}
+
+.fullBGpicture > main {
+ overflow: auto;
+}
\ No newline at end of file
diff --git a/react/react1/week2/app/layout.js b/react/react1/week2/app/layout.js
new file mode 100644
index 00000000..1d6b9fba
--- /dev/null
+++ b/react/react1/week2/app/layout.js
@@ -0,0 +1,29 @@
+import { Inter } from "next/font/google";
+import "./globals.css";
+
+import { Navbar } from "@/components/ui/Navbar";
+import { Footer } from "@/components/ui/Footer";
+
+const inter = Inter({ subsets: ["latin"] });
+
+export const metadata = {
+ title: "Galactica",
+ description: "Your space travel agency",
+};
+
+export const RootLayout = ({ children }) => {
+ return (
+
+
+
+ {children}
+ {/* TASK - React 1 week 1 */}
+ {/* Import and use the Footer component here */}
+
+ {/* Footer found in the ui/Footer.js folder */}
+
+
+ );
+};
+
+export default RootLayout;
diff --git a/react/react1/week2/app/nasa_collaboration/README.md b/react/react1/week2/app/nasa_collaboration/README.md
new file mode 100644
index 00000000..50dbbf53
--- /dev/null
+++ b/react/react1/week2/app/nasa_collaboration/README.md
@@ -0,0 +1,25 @@
+## Generating an API_KEY
+
+You need to generate an API Key at NASA's website!
+
+>> Link to the NASA API: https://api.nasa.gov/
+
+After subscribing, you will receive an email with your API_KEY
+Overwrite the `API_KEY` variable with your `API_KEY` from the email. It should look like this:
+```
+const API_KEY = 'hlcFvEJEPXDr9eUJ7fMHpbsX.....h9V';
+```
+
+If you did it successfully, the rover photo should load after reload
+
+## TIPS:
+
+There is a limit per user for this API. You can fetch an API 30 times/hour or 50 times/ day. If you get a `429` error message in the console it is because of this.
+
+You can use another email to get a new `API_KEY` or use the "./mock_data.json" to import the data, but fetch doesn't work with a `.json` file
+
+The `.json` file represents the data only. So it can be used to display the components, but not for the fetch.
+
+### How to use the JSON file:
+
+https://docs.deno.com/examples/importing-json/
\ No newline at end of file
diff --git a/react/react1/week2/app/nasa_collaboration/page.js b/react/react1/week2/app/nasa_collaboration/page.js
new file mode 100644
index 00000000..dc31e21f
--- /dev/null
+++ b/react/react1/week2/app/nasa_collaboration/page.js
@@ -0,0 +1,72 @@
+"use client";
+
+import React, { useState, useEffect } from 'react';
+import styles from './page.module.css';
+
+// Read "/app/nasa_collaboration/README.md" for more info about the API_KEY
+// You need a proper API_KEY for the requests to work
+const API_KEY = 'API_KEY';
+
+const NASA_URLs = {
+ astronomyPicOfTheDay: `https://api.nasa.gov/planetary/apod?api_key=${API_KEY}`,
+ marsRoverPhoto: `https://api.nasa.gov/mars-photos/api/v1/rovers/curiosity/photos?earth_date=2015-6-3&api_key=${API_KEY}`,
+};
+
+export const NasaCollaboration = () => {
+ const [dailyImg, setDailyImg] = useState({});
+ const [roverPhoto, setRoverPhoto] = useState({});
+
+ useEffect(() => {
+ const fetchRoverPhotos = async () => {
+ const roverPhotoResponse = await fetch(NASA_URLs.marsRoverPhoto).then(response => response.json());
+ setRoverPhoto(roverPhotoResponse);
+ };
+
+ fetchRoverPhotos();
+
+ // TASK - React 1 week 3
+ // fetch the extra data for NASA_URLs.astronomyPicOfTheDay and save it to the dailyImg state variable
+ }, []);
+
+ return (
+
+
+ Collaboration with NASA
+
+ Astronomy Picture of the day
+ {/* TASK - React 1 week 3 */}
+ {/* After fetching data from the NASA_URLs.astronomyPicOfTheDay url, display the returned data here */}
+ {/* You should display the title, explanation, and the image using the url from the response */}
+ {/* */}
+
+
+ Rover Photos
+ {/* TASK - React 1 week 3 */}
+ {/* Iteratate over the roverPhoto?.photos array and display all the pictures! */}
+ {
+ roverPhoto?.photos?.length ? (
+ <>
+ {/* TASK - React 1 week 3 */}
+ {/* Create a react component for the , which should accept the following props */}
+ {/* 1. src: source of the img (img_src in the data from the API) */}
+ {/* 2. date: earth_date data coming from the API */}
+ {/* 3. roverName: will be in the rover object - rover.name */}
+
+ {/* TIPS: */}
+ {/* If you don't know how the data looks like you can: */}
+ {/* 1. use console.log() to write the data to the console */}
+ {/* 2. use the network tab in the developer tab - https://developer.chrome.com/docs/devtools/network */}
+ Date {roverPhoto.photos[0]?.earth_date}
+
+ >
+ ) : (
+ Loading rover photos...
+ )
+ }
+
+
+
+ );
+}
+
+export default NasaCollaboration;
diff --git a/react/react1/week2/app/nasa_collaboration/page.module.css b/react/react1/week2/app/nasa_collaboration/page.module.css
new file mode 100644
index 00000000..790e9c86
--- /dev/null
+++ b/react/react1/week2/app/nasa_collaboration/page.module.css
@@ -0,0 +1,12 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+
+.nasaPicOfTheDayImg {
+ width: auto;
+ height: 400px;
+
+}
\ No newline at end of file
diff --git a/react/react1/week2/app/page.js b/react/react1/week2/app/page.js
new file mode 100644
index 00000000..74e72abf
--- /dev/null
+++ b/react/react1/week2/app/page.js
@@ -0,0 +1,30 @@
+import Link from 'next/link'
+import styles from './page.module.css';
+
+
+const HeroSection = () => {
+ return (
+
+
+
SO, YOU WANT TO TRAVEL TO
+
SPACE
+
+ Let’s face it; if you want to go to space, you might as well genuinely go to outer space
+ and not hover kind of on the edge of it. Well sit back, and relax because we’ll give you
+ a truly out of this world experience!
+
+
+ EXPLORE
+
+ );
+};
+
+export const Home = () => {
+ return (
+
+
+
+ );
+}
+
+export default Home;
\ No newline at end of file
diff --git a/react/react1/week2/app/page.module.css b/react/react1/week2/app/page.module.css
new file mode 100644
index 00000000..d64978cb
--- /dev/null
+++ b/react/react1/week2/app/page.module.css
@@ -0,0 +1,49 @@
+.app {
+ text-align: center;
+}
+
+.hero {
+ background-image: url("/home/background-home-desktop.jpg");
+ background-size: cover;
+ background-position: center;
+ height: 100vh;
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ padding: 0 var(--spacing-64);
+}
+
+.heroContent {
+ max-width: 500px;
+ text-align: left;
+ color: #fff;
+}
+
+.heroContent p {
+ font-size: 18px;
+ line-height: 1.6;
+ font-weight: 200;
+}
+
+p.heroH5 {
+ font-size: 18px;
+ font-weight: 300;
+ letter-spacing: var(--spacing-04);
+}
+
+p.heroJumbo {
+ font-size: 100px;
+ font-family: Verdana;
+ font-weight: 100;
+}
+
+.exploreButton {
+ height: 250px;
+ width: 250px;
+ line-height: 250px;
+ background-color: white;
+ border-radius: 50%;
+ font-size: 30px;
+ font-weight: 200;
+ letter-spacing: 4px;
+}
diff --git a/react/react1/week2/components/destination/AddWishlistItem.js b/react/react1/week2/components/destination/AddWishlistItem.js
new file mode 100644
index 00000000..fe9b5a72
--- /dev/null
+++ b/react/react1/week2/components/destination/AddWishlistItem.js
@@ -0,0 +1,38 @@
+"use client";
+
+import { useState } from 'react';
+import styles from './destination.module.css';
+
+export const AddWishlistItem = ({
+ onAddWishlistItem,
+}) => {
+ const [thumbnail, onThumbnailChange] = useState('/destination/image-europa.png');
+ // TASK - React 1 week 3
+ // 1. Add a useState for the handling the
+ // 2. Connect the onThumbnailChange to the
+
+ const onAddItemPressed = () => {
+ // TASK - React 1 week 3
+ // implement this function
+ // Clear the field on button press
+ // pass the thumbnail and the name from the input to the onAddWishlistItem function
+ // call the onAddWishlistItem here
+ }
+
+
+ return (
+
+
Add custom planet to wishlist
+
Wishlist item name
+
+
Wishlist item thumbnail
+
+ EUROPA
+ MARS
+ MOON
+ TITAN
+
+
ADD CUSTOM
+
+ );
+};
diff --git a/react/react1/week2/components/destination/destination.module.css b/react/react1/week2/components/destination/destination.module.css
new file mode 100644
index 00000000..4ad132f4
--- /dev/null
+++ b/react/react1/week2/components/destination/destination.module.css
@@ -0,0 +1,84 @@
+.app {
+ background-color: black;
+ width: 100vw;
+ height: 100vh;
+}
+
+.planetCard {
+ border: 1px solid var(--border-color);
+ max-width: 70%;
+ margin: var(--spacing-20) 0;
+ display: flex;
+ align-items: center;
+ justify-content: center;
+ padding: var(--spacing-08);
+ gap: var(--spacing-08);
+}
+
+.planetCard:nth-child(odd) {
+ margin-inline-start: auto;
+}
+
+.planetCard > *:last-child {
+ margin-inline-start: auto;
+}
+
+.planetDescription {
+ padding-block-start: var(--spacing-04);
+ margin-block-end: auto;
+}
+
+.planetThumbnail {
+ width: 150px;
+ height: 150px;
+ border-radius: 50%;
+ margin: 0 var(--spacing-16);
+}
+
+.wishlistItem {
+ border: 1px solid var(--border-color);
+ width: 150px;
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ gap: var(--spacing-16);
+ margin: var(--spacing-20);
+ padding: var(--spacing-20);
+}
+
+.wishlistItemThumbnail {
+ width: 60px;
+ height: 60px;
+ border-radius: 50%;
+ margin: 0 var(--spacing-16);
+}
+.wishlistList {
+ display: flex;
+ margin: var(--spacing-16) 0;
+}
+
+.addWishlistItem {
+ border: 1px solid var(--border-color);
+ width: 200px;
+ display: flex;
+ justify-content: space-between;
+ flex-direction: column;
+ align-items: stretch;
+ margin: var(--spacing-20);
+ padding: var(--spacing-20);
+}
+
+.addWishlistItem p {
+ margin-block-end: var(--spacing-20);
+}
+
+.addWishlistItem label {
+ margin: 0;
+ font-size: small;
+}
+
+.addWishlistItem input,
+.addWishlistItem select {
+ height: 30px;
+ margin-block-end: var(--spacing-20);
+}
\ No newline at end of file
diff --git a/react/react1/week2/components/ui/Footer.js b/react/react1/week2/components/ui/Footer.js
new file mode 100644
index 00000000..1b29f16f
--- /dev/null
+++ b/react/react1/week2/components/ui/Footer.js
@@ -0,0 +1,93 @@
+"use client";
+
+import { usePathname } from "next/navigation";
+import Link from "next/link";
+import styles from "./Footer.module.css";
+
+const navbarItems = [
+ {
+ title: "ABOUT_US",
+ link: "/about_us",
+ },
+ {
+ title: "DESTINATION",
+ link: "/destination",
+ },
+ {
+ title: "NASA COLLABORATION",
+ link: "/nasa_collaboration",
+ },
+];
+
+const socialMediaLinks = [
+ {
+ title: "Facebook",
+ url: "https://facebook.com",
+ icon: "/socialmedia/facebook.png",
+ },
+ {
+ title: "Instagram",
+ url: "https://instagram.com",
+ icon: "/socialmedia/instagram.jpeg",
+ },
+ {
+ title: "TikTok",
+ url: "https://tiktok.com",
+ icon: "/socialmedia/tiktok.png",
+ },
+ {
+ title: "On the streets at night",
+ url: "https://google.com",
+ icon: "/socialmedia/google.png",
+ },
+ {
+ title: "LinkedIn",
+ url: "https://www.linkedin.com/",
+ icon: "/socialmedia/linkedin.png",
+ },
+];
+
+const SocialMediaItem = ({ url, title, icon }) => (
+
+
+
+ {title}
+
+
+);
+
+export const Footer = () => {
+ const path = usePathname().split("?")[0];
+ return (
+
+ );
+};
diff --git a/react/react1/week2/components/ui/Footer.module.css b/react/react1/week2/components/ui/Footer.module.css
new file mode 100644
index 00000000..8454a7b6
--- /dev/null
+++ b/react/react1/week2/components/ui/Footer.module.css
@@ -0,0 +1,57 @@
+.footer {
+ inset-inline-start: 0;
+ inset-inline-end: 0;
+ inset-block-end: 0;
+ background-color: #eee;
+ color: #000;
+ padding: var(--spacing-20) var(--spacing-40);
+ display: flex;
+ justify-content: space-between;
+}
+
+.hidden {
+ display: none;
+}
+
+.footer h3 {
+ color: #000;
+ font-size: large;
+ padding: var(--spacing-08) 0;
+}
+
+.footer p,
+.footer a,
+.footer li {
+ color: #000;
+ font-size: medium;
+ font-weight: 200;
+ text-align: start;
+}
+
+.footerDescription {
+ max-width: 300px;
+ text-align: start;
+}
+
+.footerDescription p {
+ margin-block-end: var(--spacing-20);
+}
+
+.footerLinks {
+ gap: var(--spacing-20);
+}
+
+.footerList {
+ list-style-type: none;
+}
+
+.footerList li {
+ padding-block: var(--spacing-04);
+}
+
+.socialIcon {
+ width: 24px;
+ height: 24px;
+ margin-right: 8px;
+ vertical-align: middle;
+}
diff --git a/react/react1/week2/components/ui/Navbar.js b/react/react1/week2/components/ui/Navbar.js
new file mode 100644
index 00000000..1d82ab53
--- /dev/null
+++ b/react/react1/week2/components/ui/Navbar.js
@@ -0,0 +1,64 @@
+"use client";
+import classNames from "classnames";
+import { usePathname } from "next/navigation";
+import Link from "next/link";
+
+import styles from "./Navbar.module.css";
+
+const navbarItems = [
+ {
+ title: "ABOUT US",
+ link: "/about_us",
+ },
+ {
+ title: "DESTINATION",
+ link: "/destination",
+ },
+ {
+ title: "NASA COLLABORATION",
+ link: "/nasa_collaboration",
+ },
+];
+const NavItem = ({ title, link, isActive, index }) => (
+
+
+ {index} {title}
+
+
+);
+
+export const Navbar = () => {
+ const currentPath = usePathname();
+
+ return (
+
+
+ {/*
*/}
+
+
+
+ {navbarItems.map((item, index) => (
+
+ ))}
+
+ {/* TASK - React 1 week 3 */}
+ {/* replace repeating content by using navbarItems.map(() => ) */}
+
+
+
+ );
+};
diff --git a/react/react1/week2/components/ui/Navbar.module.css b/react/react1/week2/components/ui/Navbar.module.css
new file mode 100644
index 00000000..fd3cfa1d
--- /dev/null
+++ b/react/react1/week2/components/ui/Navbar.module.css
@@ -0,0 +1,77 @@
+.headerContainer {
+ position: fixed;
+ top: 0;
+ left: 0;
+ right: 0;
+ width: 100%;
+ display: flex;
+ justify-content: space-between;
+ padding: var(--spacing-16) var(--spacing-40);
+ height: var(--header-height);
+ max-height: var(--header-height);
+ align-items: center;
+ z-index: 10;
+}
+
+.decorativeLine {
+ height: 0.1px;
+ width: 30vw;
+ background-color: #999;
+ margin-inline-end: -60px;
+ z-index: 10;
+}
+
+.navbarLogo {
+ margin-inline-end: var(--spacing-20);
+}
+
+.navbarLogo img {
+ height: 40px;
+}
+
+.navbarLogo a {
+ display: flex;
+ align-items: center;
+ gap: var(--spacing-20);
+ font-size: large;
+ font-weight: 600;
+ color: #fff;
+}
+
+.navbar {
+ display: flex;
+ justify-content: space-between;
+ align-items: center;
+ padding: 0 var(--spacing-8);
+ margin: var(--spacing-20);
+ background-color: transparent;
+
+}
+
+.navbarBG {
+ position: absolute;
+ width: 100%;
+ height: 60%;
+ backdrop-filter: blur(20px);
+}
+
+.navbarList {
+ position: relative;
+ list-style-type: none;
+ display: flex;
+ padding: 0 var(--spacing-40);
+ gap: var(--spacing-20);
+ z-index: 10;
+}
+
+.navbarLinks a {
+ color: white;
+ text-decoration: none;
+ font-weight: 200;
+ letter-spacing: 1px;
+}
+
+.navbarLinks:hover, .isLinkActive {
+ border-block-end: var(--spacing-04) solid var(--border-color);
+ margin-block-end: -4px;
+}
diff --git a/react/react1/week2/package-lock.json b/react/react1/week2/package-lock.json
new file mode 100644
index 00000000..9b0ff51a
--- /dev/null
+++ b/react/react1/week2/package-lock.json
@@ -0,0 +1,1550 @@
+{
+ "name": "space-turism",
+ "version": "0.1.0",
+ "lockfileVersion": 3,
+ "requires": true,
+ "packages": {
+ "": {
+ "name": "space-turism",
+ "version": "0.1.0",
+ "dependencies": {
+ "@chakra-ui/next-js": "^2.2.0",
+ "@chakra-ui/react": "^2.8.2",
+ "@emotion/react": "^11.13.0",
+ "@emotion/styled": "^11.13.0",
+ "classnames": "^2.5.1",
+ "framer-motion": "^11.3.28",
+ "next": "14.2.5",
+ "react": "^18",
+ "react-dom": "^18"
+ },
+ "devDependencies": {}
+ },
+ "node_modules/@babel/code-frame": {
+ "version": "7.26.2",
+ "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz",
+ "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-validator-identifier": "^7.25.9",
+ "js-tokens": "^4.0.0",
+ "picocolors": "^1.0.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/generator": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.10.tgz",
+ "integrity": "sha512-rRHT8siFIXQrAYOYqZQVsAr8vJ+cBNqcVAY6m5V8/4QqzaPl+zDBe6cLEPRDuNOUf3ww8RfJVlOyQMoSI+5Ang==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/parser": "^7.26.10",
+ "@babel/types": "^7.26.10",
+ "@jridgewell/gen-mapping": "^0.3.5",
+ "@jridgewell/trace-mapping": "^0.3.25",
+ "jsesc": "^3.0.2"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-module-imports": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz",
+ "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/traverse": "^7.25.9",
+ "@babel/types": "^7.25.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-string-parser": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz",
+ "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/helper-validator-identifier": {
+ "version": "7.25.9",
+ "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz",
+ "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/parser": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.10.tgz",
+ "integrity": "sha512-6aQR2zGE/QFi8JpDLjUZEPYOs7+mhKXm86VaKFiLP35JQwQb6bwUE+XbvkH0EptsYhbNBSUGaUBLKqxH1xSgsA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/types": "^7.26.10"
+ },
+ "bin": {
+ "parser": "bin/babel-parser.js"
+ },
+ "engines": {
+ "node": ">=6.0.0"
+ }
+ },
+ "node_modules/@babel/runtime": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.26.10.tgz",
+ "integrity": "sha512-2WJMeRQPHKSPemqk/awGrAiuFfzBmOIPXKizAsVhWH9YJqLZ0H+HS4c8loHGgW6utJ3E/ejXQUsiGaQy2NZ9Fw==",
+ "license": "MIT",
+ "dependencies": {
+ "regenerator-runtime": "^0.14.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/template": {
+ "version": "7.26.9",
+ "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.26.9.tgz",
+ "integrity": "sha512-qyRplbeIpNZhmzOysF/wFMuP9sctmh2cFzRAZOn1YapxBsE1i9bJIY586R/WBLfLcmcBlM8ROBiQURnnNy+zfA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.26.2",
+ "@babel/parser": "^7.26.9",
+ "@babel/types": "^7.26.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/traverse": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.26.10.tgz",
+ "integrity": "sha512-k8NuDrxr0WrPH5Aupqb2LCVURP/S0vBEn5mK6iH+GIYob66U5EtoZvcdudR2jQ4cmTwhEwW1DLB+Yyas9zjF6A==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/code-frame": "^7.26.2",
+ "@babel/generator": "^7.26.10",
+ "@babel/parser": "^7.26.10",
+ "@babel/template": "^7.26.9",
+ "@babel/types": "^7.26.10",
+ "debug": "^4.3.1",
+ "globals": "^11.1.0"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@babel/types": {
+ "version": "7.26.10",
+ "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.10.tgz",
+ "integrity": "sha512-emqcG3vHrpxUKTrxcblR36dcrcoRDvKmnL/dCL6ZsHaShW80qxCAcNhzQZrpeM765VzEos+xOi4s+r4IXzTwdQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-string-parser": "^7.25.9",
+ "@babel/helper-validator-identifier": "^7.25.9"
+ },
+ "engines": {
+ "node": ">=6.9.0"
+ }
+ },
+ "node_modules/@chakra-ui/anatomy": {
+ "version": "2.3.6",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/anatomy/-/anatomy-2.3.6.tgz",
+ "integrity": "sha512-TjmjyQouIZzha/l8JxdBZN1pKZTj7sLpJ0YkFnQFyqHcbfWggW9jKWzY1E0VBnhtFz/xF3KC6UAVuZVSJx+y0g==",
+ "license": "MIT"
+ },
+ "node_modules/@chakra-ui/hooks": {
+ "version": "2.4.4",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/hooks/-/hooks-2.4.4.tgz",
+ "integrity": "sha512-+gMwLIkabtddIL/GICU7JmnYtvfONP+fNiTfdYLV9/I1eyCz8igKgLmFJOGM6F+BpUev6hh+/+DX5ezGQ9VTbQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/utils": "2.2.4",
+ "@zag-js/element-size": "0.31.1",
+ "copy-to-clipboard": "3.3.3",
+ "framesync": "6.1.2"
+ },
+ "peerDependencies": {
+ "react": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/next-js": {
+ "version": "2.4.2",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/next-js/-/next-js-2.4.2.tgz",
+ "integrity": "sha512-loo82RyPbMyvJwRhhZVZovut9v2hFBSkqd1vQoNXgMrCRApLwrrttu5Iuodns15gLE3mqI+it5oEhxTtO5DrxA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/cache": "^11.11.0"
+ },
+ "peerDependencies": {
+ "@chakra-ui/react": ">=2.4.0",
+ "@emotion/react": ">=11",
+ "next": ">=13",
+ "react": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/react": {
+ "version": "2.10.7",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/react/-/react-2.10.7.tgz",
+ "integrity": "sha512-GX1dCmnvrxxyZEofDX9GMAtRakZJKnUqFM9k8qhaycPaeyfkiTNNTjhPNX917hgVx1yhC3kcJOs5IeC7yW56/g==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/hooks": "2.4.4",
+ "@chakra-ui/styled-system": "2.12.2",
+ "@chakra-ui/theme": "3.4.8",
+ "@chakra-ui/utils": "2.2.4",
+ "@popperjs/core": "^2.11.8",
+ "@zag-js/focus-visible": "^0.31.1",
+ "aria-hidden": "^1.2.3",
+ "react-fast-compare": "3.2.2",
+ "react-focus-lock": "^2.9.6",
+ "react-remove-scroll": "^2.5.7"
+ },
+ "peerDependencies": {
+ "@emotion/react": ">=11",
+ "@emotion/styled": ">=11",
+ "framer-motion": ">=4.0.0",
+ "react": ">=18",
+ "react-dom": ">=18"
+ }
+ },
+ "node_modules/@chakra-ui/styled-system": {
+ "version": "2.12.2",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/styled-system/-/styled-system-2.12.2.tgz",
+ "integrity": "sha512-BlQ7i3+GYC0S0c72B+paa0sYo+QeNSMfz6fwQRFsc8A5Aax9i9lSdRL+vwJVC+k6r/0HWfRwk016R2RD2ihEwQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/utils": "2.2.4",
+ "csstype": "^3.1.2"
+ }
+ },
+ "node_modules/@chakra-ui/theme": {
+ "version": "3.4.8",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/theme/-/theme-3.4.8.tgz",
+ "integrity": "sha512-ZLMP2Gek38ZTIlj+sMZLsd1TW27yVdmUKMfBmjsr1psAeOa5bDBLKDszICjhEqk7gAbiWB7jr1/HzBXid4kduQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/anatomy": "2.3.6",
+ "@chakra-ui/theme-tools": "2.2.8",
+ "@chakra-ui/utils": "2.2.4"
+ },
+ "peerDependencies": {
+ "@chakra-ui/styled-system": ">=2.8.0"
+ }
+ },
+ "node_modules/@chakra-ui/theme-tools": {
+ "version": "2.2.8",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/theme-tools/-/theme-tools-2.2.8.tgz",
+ "integrity": "sha512-X2i2qgkG+k3DQfh/adn3zzM4Ty8QrGobVPjMl9rMrEYq3ac+pur6KVdVHy/SwwoPvB6S4i84uq7y35+KbJan9g==",
+ "license": "MIT",
+ "dependencies": {
+ "@chakra-ui/anatomy": "2.3.6",
+ "@chakra-ui/utils": "2.2.4",
+ "color2k": "^2.0.2"
+ },
+ "peerDependencies": {
+ "@chakra-ui/styled-system": ">=2.0.0"
+ }
+ },
+ "node_modules/@chakra-ui/utils": {
+ "version": "2.2.4",
+ "resolved": "https://registry.npmjs.org/@chakra-ui/utils/-/utils-2.2.4.tgz",
+ "integrity": "sha512-nRpR9SnX7aLcJx7lKu8kgQWxdJso1oR/78HcBI+mzidvWdTykbTGdm5Q2R7S0PVH1IFBzBTgi6TiAjHvu96auA==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/lodash.mergewith": "4.6.9",
+ "lodash.mergewith": "4.6.2"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ }
+ },
+ "node_modules/@emotion/babel-plugin": {
+ "version": "11.13.5",
+ "resolved": "https://registry.npmjs.org/@emotion/babel-plugin/-/babel-plugin-11.13.5.tgz",
+ "integrity": "sha512-pxHCpT2ex+0q+HH91/zsdHkw/lXd468DIN2zvfvLtPKLLMo6gQj7oLObq8PhkrxOZb/gGCq03S3Z7PDhS8pduQ==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/helper-module-imports": "^7.16.7",
+ "@babel/runtime": "^7.18.3",
+ "@emotion/hash": "^0.9.2",
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/serialize": "^1.3.3",
+ "babel-plugin-macros": "^3.1.0",
+ "convert-source-map": "^1.5.0",
+ "escape-string-regexp": "^4.0.0",
+ "find-root": "^1.1.0",
+ "source-map": "^0.5.7",
+ "stylis": "4.2.0"
+ }
+ },
+ "node_modules/@emotion/cache": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-11.14.0.tgz",
+ "integrity": "sha512-L/B1lc/TViYk4DcpGxtAVbx0ZyiKM5ktoIyafGkH6zg/tj+mA+NE//aPYKG0k8kCHSHVJrpLpcAlOBEXQ3SavA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/sheet": "^1.4.0",
+ "@emotion/utils": "^1.4.2",
+ "@emotion/weak-memoize": "^0.4.0",
+ "stylis": "4.2.0"
+ }
+ },
+ "node_modules/@emotion/hash": {
+ "version": "0.9.2",
+ "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.2.tgz",
+ "integrity": "sha512-MyqliTZGuOm3+5ZRSaaBGP3USLw6+EGykkwZns2EPC5g8jJ4z9OrdZY9apkl3+UP9+sdz76YYkwCKP5gh8iY3g==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/is-prop-valid": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.3.1.tgz",
+ "integrity": "sha512-/ACwoqx7XQi9knQs/G0qKvv5teDMhD7bXYns9N/wM8ah8iNb8jZ2uNO0YOgiq2o2poIvVtJS2YALasQuMSQ7Kw==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/memoize": "^0.9.0"
+ }
+ },
+ "node_modules/@emotion/memoize": {
+ "version": "0.9.0",
+ "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.9.0.tgz",
+ "integrity": "sha512-30FAj7/EoJ5mwVPOWhAyCX+FPfMDrVecJAM+Iw9NRoSl4BBAQeqj4cApHHUXOVvIPgLVDsCFoz/hGD+5QQD1GQ==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/react": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/react/-/react-11.14.0.tgz",
+ "integrity": "sha512-O000MLDBDdk/EohJPFUqvnp4qnHeYkVP5B0xEG0D/L7cOKP9kefu2DXn8dj74cQfsEzUqh+sr1RzFqiL1o+PpA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.18.3",
+ "@emotion/babel-plugin": "^11.13.5",
+ "@emotion/cache": "^11.14.0",
+ "@emotion/serialize": "^1.3.3",
+ "@emotion/use-insertion-effect-with-fallbacks": "^1.2.0",
+ "@emotion/utils": "^1.4.2",
+ "@emotion/weak-memoize": "^0.4.0",
+ "hoist-non-react-statics": "^3.3.1"
+ },
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@emotion/serialize": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.3.3.tgz",
+ "integrity": "sha512-EISGqt7sSNWHGI76hC7x1CksiXPahbxEOrC5RjmFRJTqLyEK9/9hZvBbiYn70dw4wuwMKiEMCUlR6ZXTSWQqxA==",
+ "license": "MIT",
+ "dependencies": {
+ "@emotion/hash": "^0.9.2",
+ "@emotion/memoize": "^0.9.0",
+ "@emotion/unitless": "^0.10.0",
+ "@emotion/utils": "^1.4.2",
+ "csstype": "^3.0.2"
+ }
+ },
+ "node_modules/@emotion/sheet": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.4.0.tgz",
+ "integrity": "sha512-fTBW9/8r2w3dXWYM4HCB1Rdp8NLibOw2+XELH5m5+AkWiL/KqYX6dc0kKYlaYyKjrQ6ds33MCdMPEwgs2z1rqg==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/styled": {
+ "version": "11.14.0",
+ "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-11.14.0.tgz",
+ "integrity": "sha512-XxfOnXFffatap2IyCeJyNov3kiDQWoR08gPUQxvbL7fxKryGBKUZUkG6Hz48DZwVrJSVh9sJboyV1Ds4OW6SgA==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.18.3",
+ "@emotion/babel-plugin": "^11.13.5",
+ "@emotion/is-prop-valid": "^1.3.0",
+ "@emotion/serialize": "^1.3.3",
+ "@emotion/use-insertion-effect-with-fallbacks": "^1.2.0",
+ "@emotion/utils": "^1.4.2"
+ },
+ "peerDependencies": {
+ "@emotion/react": "^11.0.0-rc.0",
+ "react": ">=16.8.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/@emotion/unitless": {
+ "version": "0.10.0",
+ "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.10.0.tgz",
+ "integrity": "sha512-dFoMUuQA20zvtVTuxZww6OHoJYgrzfKM1t52mVySDJnMSEa08ruEvdYQbhvyu6soU+NeLVd3yKfTfT0NeV6qGg==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/use-insertion-effect-with-fallbacks": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.2.0.tgz",
+ "integrity": "sha512-yJMtVdH59sxi/aVJBpk9FQq+OR8ll5GT8oWd57UpeaKEVGab41JWaCFA7FRLoMLloOZF/c/wsPoe+bfGmRKgDg==",
+ "license": "MIT",
+ "peerDependencies": {
+ "react": ">=16.8.0"
+ }
+ },
+ "node_modules/@emotion/utils": {
+ "version": "1.4.2",
+ "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-1.4.2.tgz",
+ "integrity": "sha512-3vLclRofFziIa3J2wDh9jjbkUz9qk5Vi3IZ/FSTKViB0k+ef0fPV7dYrUIugbgupYDx7v9ud/SjrtEP8Y4xLoA==",
+ "license": "MIT"
+ },
+ "node_modules/@emotion/weak-memoize": {
+ "version": "0.4.0",
+ "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.4.0.tgz",
+ "integrity": "sha512-snKqtPW01tN0ui7yu9rGv69aJXr/a/Ywvl11sUjNtEcRc+ng/mQriFL0wLXMef74iHa/EkftbDzU9F8iFbH+zg==",
+ "license": "MIT"
+ },
+ "node_modules/@jridgewell/gen-mapping": {
+ "version": "0.3.8",
+ "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz",
+ "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==",
+ "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.5.0",
+ "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
+ "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==",
+ "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.5",
+ "resolved": "https://registry.npmjs.org/@next/env/-/env-14.2.5.tgz",
+ "integrity": "sha512-/zZGkrTOsraVfYjGP8uM0p6r0BDT6xWpkjdVbcz66PJVSpwXX3yNiRycxAuDfBKGWBrZBXRuK/YVlkNgxHGwmA==",
+ "license": "MIT"
+ },
+ "node_modules/@next/swc-darwin-arm64": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-darwin-arm64/-/swc-darwin-arm64-14.2.5.tgz",
+ "integrity": "sha512-/9zVxJ+K9lrzSGli1///ujyRfon/ZneeZ+v4ptpiPoOU+GKZnm8Wj8ELWU1Pm7GHltYRBklmXMTUqM/DqQ99FQ==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-darwin-x64": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-darwin-x64/-/swc-darwin-x64-14.2.5.tgz",
+ "integrity": "sha512-vXHOPCwfDe9qLDuq7U1OYM2wUY+KQ4Ex6ozwsKxp26BlJ6XXbHleOUldenM67JRyBfVjv371oneEvYd3H2gNSA==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "darwin"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-arm64-gnu": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-gnu/-/swc-linux-arm64-gnu-14.2.5.tgz",
+ "integrity": "sha512-vlhB8wI+lj8q1ExFW8lbWutA4M2ZazQNvMWuEDqZcuJJc78iUnLdPPunBPX8rC4IgT6lIx/adB+Cwrl99MzNaA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-arm64-musl": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-arm64-musl/-/swc-linux-arm64-musl-14.2.5.tgz",
+ "integrity": "sha512-NpDB9NUR2t0hXzJJwQSGu1IAOYybsfeB+LxpGsXrRIb7QOrYmidJz3shzY8cM6+rO4Aojuef0N/PEaX18pi9OA==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-x64-gnu": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-gnu/-/swc-linux-x64-gnu-14.2.5.tgz",
+ "integrity": "sha512-8XFikMSxWleYNryWIjiCX+gU201YS+erTUidKdyOVYi5qUQo/gRxv/3N1oZFCgqpesN6FPeqGM72Zve+nReVXQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-linux-x64-musl": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-linux-x64-musl/-/swc-linux-x64-musl-14.2.5.tgz",
+ "integrity": "sha512-6QLwi7RaYiQDcRDSU/os40r5o06b5ue7Jsk5JgdRBGGp8l37RZEh9JsLSM8QF0YDsgcosSeHjglgqi25+m04IQ==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "linux"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-arm64-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-arm64-msvc/-/swc-win32-arm64-msvc-14.2.5.tgz",
+ "integrity": "sha512-1GpG2VhbspO+aYoMOQPQiqc/tG3LzmsdBH0LhnDS3JrtDx2QmzXe0B6mSZZiN3Bq7IOMXxv1nlsjzoS1+9mzZw==",
+ "cpu": [
+ "arm64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-ia32-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-ia32-msvc/-/swc-win32-ia32-msvc-14.2.5.tgz",
+ "integrity": "sha512-Igh9ZlxwvCDsu6438FXlQTHlRno4gFpJzqPjSIBZooD22tKeI4fE/YMRoHVJHmrQ2P5YL1DoZ0qaOKkbeFWeMg==",
+ "cpu": [
+ "ia32"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@next/swc-win32-x64-msvc": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/@next/swc-win32-x64-msvc/-/swc-win32-x64-msvc-14.2.5.tgz",
+ "integrity": "sha512-tEQ7oinq1/CjSG9uSTerca3v4AZ+dFa+4Yu6ihaG8Ud8ddqLQgFGcnwYls13H5X5CPDPZJdYxyeMui6muOLd4g==",
+ "cpu": [
+ "x64"
+ ],
+ "license": "MIT",
+ "optional": true,
+ "os": [
+ "win32"
+ ],
+ "engines": {
+ "node": ">= 10"
+ }
+ },
+ "node_modules/@popperjs/core": {
+ "version": "2.11.8",
+ "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.8.tgz",
+ "integrity": "sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==",
+ "license": "MIT",
+ "funding": {
+ "type": "opencollective",
+ "url": "https://opencollective.com/popperjs"
+ }
+ },
+ "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/@types/lodash": {
+ "version": "4.17.16",
+ "resolved": "https://registry.npmjs.org/@types/lodash/-/lodash-4.17.16.tgz",
+ "integrity": "sha512-HX7Em5NYQAXKW+1T+FiuG27NGwzJfCX3s1GjOa7ujxZa52kjJLOr4FUxT+giF6Tgxv1e+/czV/iTtBw27WTU9g==",
+ "license": "MIT"
+ },
+ "node_modules/@types/lodash.mergewith": {
+ "version": "4.6.9",
+ "resolved": "https://registry.npmjs.org/@types/lodash.mergewith/-/lodash.mergewith-4.6.9.tgz",
+ "integrity": "sha512-fgkoCAOF47K7sxrQ7Mlud2TH023itugZs2bUg8h/KzT+BnZNrR2jAOmaokbLunHNnobXVWOezAeNn/lZqwxkcw==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/lodash": "*"
+ }
+ },
+ "node_modules/@types/parse-json": {
+ "version": "4.0.2",
+ "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.2.tgz",
+ "integrity": "sha512-dISoDXWWQwUquiKsyZ4Ng+HX2KsPL7LyHKHQwgGFEA3IaKac4Obd+h2a/a6waisAoepJlBcx9paWqjA8/HVjCw==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/dom-query": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/dom-query/-/dom-query-0.31.1.tgz",
+ "integrity": "sha512-oiuohEXAXhBxpzzNm9k2VHGEOLC1SXlXSbRPcfBZ9so5NRQUA++zCE7cyQJqGLTZR0t3itFLlZqDbYEXRrefwg==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/element-size": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/element-size/-/element-size-0.31.1.tgz",
+ "integrity": "sha512-4T3yvn5NqqAjhlP326Fv+w9RqMIBbNN9H72g5q2ohwzhSgSfZzrKtjL4rs9axY/cw9UfMfXjRjEE98e5CMq7WQ==",
+ "license": "MIT"
+ },
+ "node_modules/@zag-js/focus-visible": {
+ "version": "0.31.1",
+ "resolved": "https://registry.npmjs.org/@zag-js/focus-visible/-/focus-visible-0.31.1.tgz",
+ "integrity": "sha512-dbLksz7FEwyFoANbpIlNnd3bVm0clQSUsnP8yUVQucStZPsuWjCrhL2jlAbGNrTrahX96ntUMXHb/sM68TibFg==",
+ "license": "MIT",
+ "dependencies": {
+ "@zag-js/dom-query": "0.31.1"
+ }
+ },
+ "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/babel-plugin-macros": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz",
+ "integrity": "sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.12.5",
+ "cosmiconfig": "^7.0.0",
+ "resolve": "^1.19.0"
+ },
+ "engines": {
+ "node": ">=10",
+ "npm": ">=6"
+ }
+ },
+ "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/callsites": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
+ "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "node_modules/caniuse-lite": {
+ "version": "1.0.30001705",
+ "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001705.tgz",
+ "integrity": "sha512-S0uyMMiYvA7CxNgomYBwwwPUnWzFD83f3B1ce5jHUfHTH//QL6hHsreI8RVC5606R4ssqravelYO5TU6t8sEyg==",
+ "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/classnames": {
+ "version": "2.5.1",
+ "resolved": "https://registry.npmjs.org/classnames/-/classnames-2.5.1.tgz",
+ "integrity": "sha512-saHYOzhIQs6wy2sVxTM6bUDsQO4F50V9RQ22qBpEdCW+I+/Wmke2HOl6lS6dTpdxVhb88/I6+Hs+438c3lfUow==",
+ "license": "MIT"
+ },
+ "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/color2k": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/color2k/-/color2k-2.0.3.tgz",
+ "integrity": "sha512-zW190nQTIoXcGCaU08DvVNFTmQhUpnJfVuAKfWqUQkflXKpaDdpaYoM0iluLS9lgJNHyBF58KKA2FBEwkD7wog==",
+ "license": "MIT"
+ },
+ "node_modules/convert-source-map": {
+ "version": "1.9.0",
+ "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz",
+ "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==",
+ "license": "MIT"
+ },
+ "node_modules/copy-to-clipboard": {
+ "version": "3.3.3",
+ "resolved": "https://registry.npmjs.org/copy-to-clipboard/-/copy-to-clipboard-3.3.3.tgz",
+ "integrity": "sha512-2KV8NhB5JqC3ky0r9PMCAZKbUHSwtEo4CwCs0KXgruG43gX5PMqDEBbVU4OUzw2MuAWUfsuFmWvEKG5QRfSnJA==",
+ "license": "MIT",
+ "dependencies": {
+ "toggle-selection": "^1.0.6"
+ }
+ },
+ "node_modules/cosmiconfig": {
+ "version": "7.1.0",
+ "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz",
+ "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==",
+ "license": "MIT",
+ "dependencies": {
+ "@types/parse-json": "^4.0.0",
+ "import-fresh": "^3.2.1",
+ "parse-json": "^5.0.0",
+ "path-type": "^4.0.0",
+ "yaml": "^1.10.0"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "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/debug": {
+ "version": "4.4.0",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz",
+ "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==",
+ "license": "MIT",
+ "dependencies": {
+ "ms": "^2.1.3"
+ },
+ "engines": {
+ "node": ">=6.0"
+ },
+ "peerDependenciesMeta": {
+ "supports-color": {
+ "optional": true
+ }
+ }
+ },
+ "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/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==",
+ "license": "MIT",
+ "dependencies": {
+ "is-arrayish": "^0.2.1"
+ }
+ },
+ "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==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=10"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/sindresorhus"
+ }
+ },
+ "node_modules/find-root": {
+ "version": "1.1.0",
+ "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz",
+ "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==",
+ "license": "MIT"
+ },
+ "node_modules/focus-lock": {
+ "version": "1.3.6",
+ "resolved": "https://registry.npmjs.org/focus-lock/-/focus-lock-1.3.6.tgz",
+ "integrity": "sha512-Ik/6OCk9RQQ0T5Xw+hKNLWrjSMtv51dD4GRmJjbD5a58TIEpI5a5iXagKVl3Z5UuyslMCA8Xwnu76jQob62Yhg==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^2.0.3"
+ },
+ "engines": {
+ "node": ">=10"
+ }
+ },
+ "node_modules/framer-motion": {
+ "version": "11.18.2",
+ "resolved": "https://registry.npmjs.org/framer-motion/-/framer-motion-11.18.2.tgz",
+ "integrity": "sha512-5F5Och7wrvtLVElIpclDT0CBzMVg3dL22B64aZwHtsIY8RB4mXICLrkajK4G9R+ieSAGcgrLeae2SeUTg2pr6w==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-dom": "^11.18.1",
+ "motion-utils": "^11.18.1",
+ "tslib": "^2.4.0"
+ },
+ "peerDependencies": {
+ "@emotion/is-prop-valid": "*",
+ "react": "^18.0.0 || ^19.0.0",
+ "react-dom": "^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@emotion/is-prop-valid": {
+ "optional": true
+ },
+ "react": {
+ "optional": true
+ },
+ "react-dom": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/framesync": {
+ "version": "6.1.2",
+ "resolved": "https://registry.npmjs.org/framesync/-/framesync-6.1.2.tgz",
+ "integrity": "sha512-jBTqhX6KaQVDyus8muwZbBeGGP0XgujBRbQ7gM7BRdS3CadCZIHiawyzYLnafYcvZIh5j8WE7cxZKFn7dXhu9g==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "2.4.0"
+ }
+ },
+ "node_modules/framesync/node_modules/tslib": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz",
+ "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==",
+ "license": "0BSD"
+ },
+ "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/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/globals": {
+ "version": "11.12.0",
+ "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
+ "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "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/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/hoist-non-react-statics": {
+ "version": "3.3.2",
+ "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz",
+ "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==",
+ "license": "BSD-3-Clause",
+ "dependencies": {
+ "react-is": "^16.7.0"
+ }
+ },
+ "node_modules/import-fresh": {
+ "version": "3.3.1",
+ "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
+ "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
+ "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/is-arrayish": {
+ "version": "0.2.1",
+ "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz",
+ "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==",
+ "license": "MIT"
+ },
+ "node_modules/is-core-module": {
+ "version": "2.16.1",
+ "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.16.1.tgz",
+ "integrity": "sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==",
+ "license": "MIT",
+ "dependencies": {
+ "hasown": "^2.0.2"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "funding": {
+ "url": "https://github.com/sponsors/ljharb"
+ }
+ },
+ "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/jsesc": {
+ "version": "3.1.0",
+ "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz",
+ "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==",
+ "license": "MIT",
+ "bin": {
+ "jsesc": "bin/jsesc"
+ },
+ "engines": {
+ "node": ">=6"
+ }
+ },
+ "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==",
+ "license": "MIT"
+ },
+ "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/lodash.mergewith": {
+ "version": "4.6.2",
+ "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.2.tgz",
+ "integrity": "sha512-GK3g5RPZWTRSeLSpgP8Xhra+pnjBC56q9FZYe1d5RN3TJ35dbkGy3YqBSMbyCrlbi+CM9Z3Jk5yTL7RCsqboyQ==",
+ "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/motion-dom": {
+ "version": "11.18.1",
+ "resolved": "https://registry.npmjs.org/motion-dom/-/motion-dom-11.18.1.tgz",
+ "integrity": "sha512-g76KvA001z+atjfxczdRtw/RXOM3OMSdd1f4DL77qCTF/+avrRJiawSG4yDibEQ215sr9kpinSlX2pCTJ9zbhw==",
+ "license": "MIT",
+ "dependencies": {
+ "motion-utils": "^11.18.1"
+ }
+ },
+ "node_modules/motion-utils": {
+ "version": "11.18.1",
+ "resolved": "https://registry.npmjs.org/motion-utils/-/motion-utils-11.18.1.tgz",
+ "integrity": "sha512-49Kt+HKjtbJKLtgO/LKj9Ld+6vw9BjH5d9sc40R/kVyH8GLAXgT42M2NnuPcJNuA3s9ZfZBUcwIgpmZWGEE+hA==",
+ "license": "MIT"
+ },
+ "node_modules/ms": {
+ "version": "2.1.3",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
+ "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
+ "license": "MIT"
+ },
+ "node_modules/nanoid": {
+ "version": "3.3.10",
+ "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.10.tgz",
+ "integrity": "sha512-vSJJTG+t/dIKAUhUDw/dLdZ9s//5OxcHqLaDWWrW4Cdq7o6tdLIczUkMXt2MBNmk6sJRZBZRXVixs7URY1CmIg==",
+ "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/next": {
+ "version": "14.2.5",
+ "resolved": "https://registry.npmjs.org/next/-/next-14.2.5.tgz",
+ "integrity": "sha512-0f8aRfBVL+mpzfBjYfQuLWh2WyAwtJXCRfkPF4UJ5qd2YwrHczsrSzXU4tRMV0OAxR8ZJZWPFn6uhSC56UTsLA==",
+ "license": "MIT",
+ "dependencies": {
+ "@next/env": "14.2.5",
+ "@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.5",
+ "@next/swc-darwin-x64": "14.2.5",
+ "@next/swc-linux-arm64-gnu": "14.2.5",
+ "@next/swc-linux-arm64-musl": "14.2.5",
+ "@next/swc-linux-x64-gnu": "14.2.5",
+ "@next/swc-linux-x64-musl": "14.2.5",
+ "@next/swc-win32-arm64-msvc": "14.2.5",
+ "@next/swc-win32-ia32-msvc": "14.2.5",
+ "@next/swc-win32-x64-msvc": "14.2.5"
+ },
+ "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/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/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==",
+ "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==",
+ "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-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-type": {
+ "version": "4.0.0",
+ "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz",
+ "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=8"
+ }
+ },
+ "node_modules/picocolors": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
+ "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
+ "license": "ISC"
+ },
+ "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/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/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-clientside-effect": {
+ "version": "1.2.7",
+ "resolved": "https://registry.npmjs.org/react-clientside-effect/-/react-clientside-effect-1.2.7.tgz",
+ "integrity": "sha512-gce9m0Pk/xYYMEojRI9bgvqQAkl6hm7ozQvqWPyQx+kULiatdHgkNM1QG4DQRx5N9BAzWSCJmt9mMV8/KsdgVg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.12.13"
+ },
+ "peerDependencies": {
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ }
+ },
+ "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-fast-compare": {
+ "version": "3.2.2",
+ "resolved": "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-3.2.2.tgz",
+ "integrity": "sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ==",
+ "license": "MIT"
+ },
+ "node_modules/react-focus-lock": {
+ "version": "2.13.6",
+ "resolved": "https://registry.npmjs.org/react-focus-lock/-/react-focus-lock-2.13.6.tgz",
+ "integrity": "sha512-ehylFFWyYtBKXjAO9+3v8d0i+cnc1trGS0vlTGhzFW1vbFXVUTmR8s2tt/ZQG8x5hElg6rhENlLG1H3EZK0Llg==",
+ "license": "MIT",
+ "dependencies": {
+ "@babel/runtime": "^7.0.0",
+ "focus-lock": "^1.3.6",
+ "prop-types": "^15.6.2",
+ "react-clientside-effect": "^1.2.7",
+ "use-callback-ref": "^1.3.3",
+ "use-sidecar": "^1.1.3"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "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-remove-scroll": {
+ "version": "2.6.3",
+ "resolved": "https://registry.npmjs.org/react-remove-scroll/-/react-remove-scroll-2.6.3.tgz",
+ "integrity": "sha512-pnAi91oOk8g8ABQKGF5/M9qxmmOPxaAnopyTHYfqYEwJhyFrbbBtHuSgtKEoH0jpcxx5o3hXqH1mNd9/Oi+8iQ==",
+ "license": "MIT",
+ "dependencies": {
+ "react-remove-scroll-bar": "^2.3.7",
+ "react-style-singleton": "^2.2.3",
+ "tslib": "^2.1.0",
+ "use-callback-ref": "^1.3.3",
+ "use-sidecar": "^1.1.3"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-remove-scroll-bar": {
+ "version": "2.3.8",
+ "resolved": "https://registry.npmjs.org/react-remove-scroll-bar/-/react-remove-scroll-bar-2.3.8.tgz",
+ "integrity": "sha512-9r+yi9+mgU33AKcj6IbT9oRCO78WriSj6t/cF8DWBZJ9aOGPOTEDvdUDz1FwKim7QXWwmHqtdHnRJfhAxEG46Q==",
+ "license": "MIT",
+ "dependencies": {
+ "react-style-singleton": "^2.2.2",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/react-style-singleton": {
+ "version": "2.2.3",
+ "resolved": "https://registry.npmjs.org/react-style-singleton/-/react-style-singleton-2.2.3.tgz",
+ "integrity": "sha512-b6jSvxvVnyptAiLjbkWLE/lOnR4lfTtDAl+eUC7RZy+QQWc6wRzIV2CE6xBuMmDxc2qIihtDCZD5NPOFl7fRBQ==",
+ "license": "MIT",
+ "dependencies": {
+ "get-nonce": "^1.0.0",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "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/resolve": {
+ "version": "1.22.10",
+ "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.10.tgz",
+ "integrity": "sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w==",
+ "license": "MIT",
+ "dependencies": {
+ "is-core-module": "^2.16.0",
+ "path-parse": "^1.0.7",
+ "supports-preserve-symlinks-flag": "^1.0.0"
+ },
+ "bin": {
+ "resolve": "bin/resolve"
+ },
+ "engines": {
+ "node": ">= 0.4"
+ },
+ "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==",
+ "license": "MIT",
+ "engines": {
+ "node": ">=4"
+ }
+ },
+ "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/source-map": {
+ "version": "0.5.7",
+ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz",
+ "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "node_modules/source-map-js": {
+ "version": "1.2.1",
+ "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
+ "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
+ "license": "BSD-3-Clause",
+ "engines": {
+ "node": ">=0.10.0"
+ }
+ },
+ "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/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/stylis": {
+ "version": "4.2.0",
+ "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.2.0.tgz",
+ "integrity": "sha512-Orov6g6BB1sDfYgzWfTHDOxamtX1bE/zo104Dh9e6fqJ3PooipYyfJ0pUmrZO2wAvO8YbEyeFrkV91XTsGMSrw==",
+ "license": "MIT"
+ },
+ "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/toggle-selection": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/toggle-selection/-/toggle-selection-1.0.6.tgz",
+ "integrity": "sha512-BiZS+C1OS8g/q2RRbJmy59xpyghNBqrr6k5L/uKBGRsTfxmu3ffiRnd8mlGPUVayg8pvfi5urfnu8TU7DVOkLQ==",
+ "license": "MIT"
+ },
+ "node_modules/tslib": {
+ "version": "2.8.1",
+ "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.1.tgz",
+ "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==",
+ "license": "0BSD"
+ },
+ "node_modules/use-callback-ref": {
+ "version": "1.3.3",
+ "resolved": "https://registry.npmjs.org/use-callback-ref/-/use-callback-ref-1.3.3.tgz",
+ "integrity": "sha512-jQL3lRnocaFtu3V00JToYz/4QkNWswxijDaCVNZRiRTO3HQDLsdu1ZtmIUvV4yPp+rvWm5j0y0TG/S61cuijTg==",
+ "license": "MIT",
+ "dependencies": {
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/use-sidecar": {
+ "version": "1.1.3",
+ "resolved": "https://registry.npmjs.org/use-sidecar/-/use-sidecar-1.1.3.tgz",
+ "integrity": "sha512-Fedw0aZvkhynoPYlA5WXrMCAMm+nSWdZt6lzJQ7Ok8S6Q+VsHmHpRWndVRJ8Be0ZbkfPc5LRYH+5XrzXcEeLRQ==",
+ "license": "MIT",
+ "dependencies": {
+ "detect-node-es": "^1.1.0",
+ "tslib": "^2.0.0"
+ },
+ "engines": {
+ "node": ">=10"
+ },
+ "peerDependencies": {
+ "@types/react": "*",
+ "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc"
+ },
+ "peerDependenciesMeta": {
+ "@types/react": {
+ "optional": true
+ }
+ }
+ },
+ "node_modules/yaml": {
+ "version": "1.10.2",
+ "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz",
+ "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==",
+ "license": "ISC",
+ "engines": {
+ "node": ">= 6"
+ }
+ }
+ }
+}
diff --git a/react/react1/week2/package.json b/react/react1/week2/package.json
new file mode 100644
index 00000000..fb950f56
--- /dev/null
+++ b/react/react1/week2/package.json
@@ -0,0 +1,22 @@
+{
+ "name": "space-turism",
+ "version": "0.1.0",
+ "private": true,
+ "scripts": {
+ "dev": "next dev",
+ "build": "next build",
+ "start": "next start"
+ },
+ "dependencies": {
+ "@chakra-ui/next-js": "^2.2.0",
+ "@chakra-ui/react": "^2.8.2",
+ "@emotion/react": "^11.13.0",
+ "@emotion/styled": "^11.13.0",
+ "classnames": "^2.5.1",
+ "framer-motion": "^11.3.28",
+ "next": "14.2.5",
+ "react": "^18",
+ "react-dom": "^18"
+ },
+ "devDependencies": {}
+}
diff --git a/react/react1/week2/public/business_partners/CBC_Logo_White.png b/react/react1/week2/public/business_partners/CBC_Logo_White.png
new file mode 100644
index 00000000..eeb0390f
Binary files /dev/null and b/react/react1/week2/public/business_partners/CBC_Logo_White.png differ
diff --git a/react/react1/week2/public/business_partners/Microsoft-Logo-white.png b/react/react1/week2/public/business_partners/Microsoft-Logo-white.png
new file mode 100644
index 00000000..f37d4dfe
Binary files /dev/null and b/react/react1/week2/public/business_partners/Microsoft-Logo-white.png differ
diff --git a/react/react1/week2/public/business_partners/QueensLogo_white.png b/react/react1/week2/public/business_partners/QueensLogo_white.png
new file mode 100644
index 00000000..618ed1ed
Binary files /dev/null and b/react/react1/week2/public/business_partners/QueensLogo_white.png differ
diff --git a/react/react1/week2/public/business_partners/alphabet-logo.png b/react/react1/week2/public/business_partners/alphabet-logo.png
new file mode 100644
index 00000000..637f9f4f
Binary files /dev/null and b/react/react1/week2/public/business_partners/alphabet-logo.png differ
diff --git a/react/react1/week2/public/business_partners/amazon_logo.png b/react/react1/week2/public/business_partners/amazon_logo.png
new file mode 100644
index 00000000..af0a9c3c
Binary files /dev/null and b/react/react1/week2/public/business_partners/amazon_logo.png differ
diff --git a/react/react1/week2/public/business_partners/nyu-logo.png b/react/react1/week2/public/business_partners/nyu-logo.png
new file mode 100644
index 00000000..9482feeb
Binary files /dev/null and b/react/react1/week2/public/business_partners/nyu-logo.png differ
diff --git a/react/react1/week2/public/business_partners/samsung-logo.png b/react/react1/week2/public/business_partners/samsung-logo.png
new file mode 100644
index 00000000..bc43aec3
Binary files /dev/null and b/react/react1/week2/public/business_partners/samsung-logo.png differ
diff --git a/react/react1/week2/public/business_partners/sodexo-logo.png b/react/react1/week2/public/business_partners/sodexo-logo.png
new file mode 100644
index 00000000..accf9fa9
Binary files /dev/null and b/react/react1/week2/public/business_partners/sodexo-logo.png differ
diff --git a/react/react1/week2/public/crew/background-crew-desktop.jpg b/react/react1/week2/public/crew/background-crew-desktop.jpg
new file mode 100644
index 00000000..34ac3641
Binary files /dev/null and b/react/react1/week2/public/crew/background-crew-desktop.jpg differ
diff --git a/react/react1/week2/public/crew/background-crew-mobile.jpg b/react/react1/week2/public/crew/background-crew-mobile.jpg
new file mode 100644
index 00000000..d8237856
Binary files /dev/null and b/react/react1/week2/public/crew/background-crew-mobile.jpg differ
diff --git a/react/react1/week2/public/crew/background-crew-tablet.jpg b/react/react1/week2/public/crew/background-crew-tablet.jpg
new file mode 100644
index 00000000..16997036
Binary files /dev/null and b/react/react1/week2/public/crew/background-crew-tablet.jpg differ
diff --git a/react/react1/week2/public/crew/image-anousheh-ansari.png b/react/react1/week2/public/crew/image-anousheh-ansari.png
new file mode 100644
index 00000000..52a986f6
Binary files /dev/null and b/react/react1/week2/public/crew/image-anousheh-ansari.png differ
diff --git a/react/react1/week2/public/crew/image-anousheh-ansari.webp b/react/react1/week2/public/crew/image-anousheh-ansari.webp
new file mode 100644
index 00000000..fe05e556
Binary files /dev/null and b/react/react1/week2/public/crew/image-anousheh-ansari.webp differ
diff --git a/react/react1/week2/public/crew/image-douglas-hurley.png b/react/react1/week2/public/crew/image-douglas-hurley.png
new file mode 100644
index 00000000..1b036c01
Binary files /dev/null and b/react/react1/week2/public/crew/image-douglas-hurley.png differ
diff --git a/react/react1/week2/public/crew/image-douglas-hurley.webp b/react/react1/week2/public/crew/image-douglas-hurley.webp
new file mode 100644
index 00000000..17d7b0db
Binary files /dev/null and b/react/react1/week2/public/crew/image-douglas-hurley.webp differ
diff --git a/react/react1/week2/public/crew/image-mark-shuttleworth.png b/react/react1/week2/public/crew/image-mark-shuttleworth.png
new file mode 100644
index 00000000..e4cf63b9
Binary files /dev/null and b/react/react1/week2/public/crew/image-mark-shuttleworth.png differ
diff --git a/react/react1/week2/public/crew/image-mark-shuttleworth.webp b/react/react1/week2/public/crew/image-mark-shuttleworth.webp
new file mode 100644
index 00000000..b22b63b7
Binary files /dev/null and b/react/react1/week2/public/crew/image-mark-shuttleworth.webp differ
diff --git a/react/react1/week2/public/crew/image-victor-glover.png b/react/react1/week2/public/crew/image-victor-glover.png
new file mode 100644
index 00000000..f31b5810
Binary files /dev/null and b/react/react1/week2/public/crew/image-victor-glover.png differ
diff --git a/react/react1/week2/public/crew/image-victor-glover.webp b/react/react1/week2/public/crew/image-victor-glover.webp
new file mode 100644
index 00000000..5cb85ecf
Binary files /dev/null and b/react/react1/week2/public/crew/image-victor-glover.webp differ
diff --git a/react/react1/week2/public/destination/background-destination-desktop.jpg b/react/react1/week2/public/destination/background-destination-desktop.jpg
new file mode 100644
index 00000000..57eb0251
Binary files /dev/null and b/react/react1/week2/public/destination/background-destination-desktop.jpg differ
diff --git a/react/react1/week2/public/destination/background-destination-mobile.jpg b/react/react1/week2/public/destination/background-destination-mobile.jpg
new file mode 100644
index 00000000..4dd02036
Binary files /dev/null and b/react/react1/week2/public/destination/background-destination-mobile.jpg differ
diff --git a/react/react1/week2/public/destination/background-destination-tablet.jpg b/react/react1/week2/public/destination/background-destination-tablet.jpg
new file mode 100644
index 00000000..9220c6c9
Binary files /dev/null and b/react/react1/week2/public/destination/background-destination-tablet.jpg differ
diff --git a/react/react1/week2/public/destination/image-europa.png b/react/react1/week2/public/destination/image-europa.png
new file mode 100644
index 00000000..e6addcf0
Binary files /dev/null and b/react/react1/week2/public/destination/image-europa.png differ
diff --git a/react/react1/week2/public/destination/image-europa.webp b/react/react1/week2/public/destination/image-europa.webp
new file mode 100644
index 00000000..532821f8
Binary files /dev/null and b/react/react1/week2/public/destination/image-europa.webp differ
diff --git a/react/react1/week2/public/destination/image-mars.png b/react/react1/week2/public/destination/image-mars.png
new file mode 100644
index 00000000..d2040430
Binary files /dev/null and b/react/react1/week2/public/destination/image-mars.png differ
diff --git a/react/react1/week2/public/destination/image-mars.webp b/react/react1/week2/public/destination/image-mars.webp
new file mode 100644
index 00000000..f81679be
Binary files /dev/null and b/react/react1/week2/public/destination/image-mars.webp differ
diff --git a/react/react1/week2/public/destination/image-moon.png b/react/react1/week2/public/destination/image-moon.png
new file mode 100644
index 00000000..0bcaf85d
Binary files /dev/null and b/react/react1/week2/public/destination/image-moon.png differ
diff --git a/react/react1/week2/public/destination/image-moon.webp b/react/react1/week2/public/destination/image-moon.webp
new file mode 100644
index 00000000..ed3ed05e
Binary files /dev/null and b/react/react1/week2/public/destination/image-moon.webp differ
diff --git a/react/react1/week2/public/destination/image-titan.png b/react/react1/week2/public/destination/image-titan.png
new file mode 100644
index 00000000..3a6cb885
Binary files /dev/null and b/react/react1/week2/public/destination/image-titan.png differ
diff --git a/react/react1/week2/public/destination/image-titan.webp b/react/react1/week2/public/destination/image-titan.webp
new file mode 100644
index 00000000..7165bf83
Binary files /dev/null and b/react/react1/week2/public/destination/image-titan.webp differ
diff --git a/react/react1/week2/public/destination/planetary-lineup_3x4.png b/react/react1/week2/public/destination/planetary-lineup_3x4.png
new file mode 100644
index 00000000..d876cc56
Binary files /dev/null and b/react/react1/week2/public/destination/planetary-lineup_3x4.png differ
diff --git a/react/react1/week2/public/home/background-home-desktop.jpg b/react/react1/week2/public/home/background-home-desktop.jpg
new file mode 100644
index 00000000..6d6bfe0f
Binary files /dev/null and b/react/react1/week2/public/home/background-home-desktop.jpg differ
diff --git a/react/react1/week2/public/home/background-home-mobile.jpg b/react/react1/week2/public/home/background-home-mobile.jpg
new file mode 100644
index 00000000..f88a6af4
Binary files /dev/null and b/react/react1/week2/public/home/background-home-mobile.jpg differ
diff --git a/react/react1/week2/public/home/background-home-tablet.jpg b/react/react1/week2/public/home/background-home-tablet.jpg
new file mode 100644
index 00000000..e4a2d9a9
Binary files /dev/null and b/react/react1/week2/public/home/background-home-tablet.jpg differ
diff --git a/react/react1/week2/public/shared/icon-close.svg b/react/react1/week2/public/shared/icon-close.svg
new file mode 100644
index 00000000..ace11dbc
--- /dev/null
+++ b/react/react1/week2/public/shared/icon-close.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week2/public/shared/icon-hamburger.svg b/react/react1/week2/public/shared/icon-hamburger.svg
new file mode 100644
index 00000000..7e5eab1d
--- /dev/null
+++ b/react/react1/week2/public/shared/icon-hamburger.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week2/public/shared/logo.svg b/react/react1/week2/public/shared/logo.svg
new file mode 100644
index 00000000..94fe604b
--- /dev/null
+++ b/react/react1/week2/public/shared/logo.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/react/react1/week2/public/socialmedia/facebook.png b/react/react1/week2/public/socialmedia/facebook.png
new file mode 100644
index 00000000..65c26c2a
Binary files /dev/null and b/react/react1/week2/public/socialmedia/facebook.png differ
diff --git a/react/react1/week2/public/socialmedia/google.png b/react/react1/week2/public/socialmedia/google.png
new file mode 100644
index 00000000..6583196d
Binary files /dev/null and b/react/react1/week2/public/socialmedia/google.png differ
diff --git a/react/react1/week2/public/socialmedia/instagram.jpeg b/react/react1/week2/public/socialmedia/instagram.jpeg
new file mode 100644
index 00000000..0cd10d2c
Binary files /dev/null and b/react/react1/week2/public/socialmedia/instagram.jpeg differ
diff --git a/react/react1/week2/public/socialmedia/linkedin.png b/react/react1/week2/public/socialmedia/linkedin.png
new file mode 100644
index 00000000..c03acda6
Binary files /dev/null and b/react/react1/week2/public/socialmedia/linkedin.png differ
diff --git a/react/react1/week2/public/socialmedia/tiktok.png b/react/react1/week2/public/socialmedia/tiktok.png
new file mode 100644
index 00000000..5f00d70a
Binary files /dev/null and b/react/react1/week2/public/socialmedia/tiktok.png differ
diff --git a/react/react1/week2/readme.md b/react/react1/week2/readme.md
index 8b137891..b80541fc 100644
--- a/react/react1/week2/readme.md
+++ b/react/react1/week2/readme.md
@@ -1 +1,41 @@
+# Galactica Space Travel App
+## Introduction
+Galactica is a space travel application built with Next.js and React. This project aims to teach students the fundamentals of React and Next.js by creating a dynamic and interactive space exploration app.
+
+## Prerequisites
+- Node.js (version 18 or higher)
+- npm or yarn
+
+## Getting Started
+
+### Installation
+1. Fork the repository (Recommended)
+2. Clone the repository using Code > Clone
+
+Now you should have to project on your computer.
+
+3. cd into the homework folder
+4. run `npm install`
+
+
+### Running the Development Server
+
+`npm run dev`
+
+Open your browser and navigate to http://localhost:3000 to see the app in action.
+
+## HOMEWORKS:
+
+Throughout the weeks you will be adding new features to this existing application.
+For your tasks you should be searching for the following:
+
+- Tasks for week1: `TASK - React 1 week 1`
+- Tasks for week2: `TASK - React 1 week 2`
+- Tasks for week3: `TASK - React 1 week 3`
+
+You should be fixing ALL THE INSTANSCES of the current week.
+
+### How to find the tags?
+
+Use the global search function in your IDE. (`cmnd + shift + F` OR `Control + shift + F`)
\ No newline at end of file