Update dependencies. (#1314)
This commit is contained in:
		| @@ -2,7 +2,7 @@ | |||||||
|  |  | ||||||
| export default function Error({ reset }: { reset: () => void }) { | export default function Error({ reset }: { reset: () => void }) { | ||||||
|   return ( |   return ( | ||||||
|     <div className="mx-auto my-4 flex max-w-xl flex-col rounded-lg border border-neutral-200 bg-white p-8 dark:border-neutral-800 dark:bg-black md:p-12"> |     <div className="mx-auto my-4 flex max-w-xl flex-col rounded-lg border border-neutral-200 bg-white p-8 md:p-12 dark:border-neutral-800 dark:bg-black"> | ||||||
|       <h2 className="text-xl font-bold">Oh no!</h2> |       <h2 className="text-xl font-bold">Oh no!</h2> | ||||||
|       <p className="my-2"> |       <p className="my-2"> | ||||||
|         There was an issue with our storefront. This could be a temporary issue, please try your |         There was an issue with our storefront. This could be a temporary issue, please try your | ||||||
|   | |||||||
| @@ -82,14 +82,20 @@ export default async function ProductPage({ params }: { params: { handle: string | |||||||
|         }} |         }} | ||||||
|       /> |       /> | ||||||
|       <div className="mx-auto max-w-screen-2xl px-4"> |       <div className="mx-auto max-w-screen-2xl px-4"> | ||||||
|         <div className="flex flex-col rounded-lg border border-neutral-200 bg-white p-8 dark:border-neutral-800 dark:bg-black md:p-12 lg:flex-row lg:gap-8"> |         <div className="flex flex-col rounded-lg border border-neutral-200 bg-white p-8 md:p-12 lg:flex-row lg:gap-8 dark:border-neutral-800 dark:bg-black"> | ||||||
|           <div className="h-full w-full basis-full lg:basis-4/6"> |           <div className="h-full w-full basis-full lg:basis-4/6"> | ||||||
|             <Gallery |             <Suspense | ||||||
|               images={product.images.map((image: Image) => ({ |               fallback={ | ||||||
|                 src: image.url, |                 <div className="relative aspect-square h-full max-h-[550px] w-full overflow-hidden" /> | ||||||
|                 altText: image.altText |               } | ||||||
|               }))} |             > | ||||||
|             /> |               <Gallery | ||||||
|  |                 images={product.images.map((image: Image) => ({ | ||||||
|  |                   src: image.url, | ||||||
|  |                   altText: image.altText | ||||||
|  |                 }))} | ||||||
|  |               /> | ||||||
|  |             </Suspense> | ||||||
|           </div> |           </div> | ||||||
|  |  | ||||||
|           <div className="basis-full lg:basis-2/6"> |           <div className="basis-full lg:basis-2/6"> | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import { Suspense } from 'react'; | |||||||
| export default function SearchLayout({ children }: { children: React.ReactNode }) { | export default function SearchLayout({ children }: { children: React.ReactNode }) { | ||||||
|   return ( |   return ( | ||||||
|     <Suspense> |     <Suspense> | ||||||
|       <div className="mx-auto flex max-w-screen-2xl flex-col gap-8 px-4 pb-4 text-black dark:text-white md:flex-row"> |       <div className="mx-auto flex max-w-screen-2xl flex-col gap-8 px-4 pb-4 text-black md:flex-row dark:text-white"> | ||||||
|         <div className="order-first w-full flex-none md:max-w-[125px]"> |         <div className="order-first w-full flex-none md:max-w-[125px]"> | ||||||
|           <Collections /> |           <Collections /> | ||||||
|         </div> |         </div> | ||||||
|   | |||||||
| @@ -64,7 +64,7 @@ export default function CartModal({ cart }: { cart: Cart | undefined }) { | |||||||
|             leaveFrom="translate-x-0" |             leaveFrom="translate-x-0" | ||||||
|             leaveTo="translate-x-full" |             leaveTo="translate-x-full" | ||||||
|           > |           > | ||||||
|             <Dialog.Panel className="fixed bottom-0 right-0 top-0 flex h-full w-full flex-col border-l border-neutral-200 bg-white/80 p-6 text-black backdrop-blur-xl dark:border-neutral-700 dark:bg-black/80 dark:text-white md:w-[390px]"> |             <Dialog.Panel className="fixed bottom-0 right-0 top-0 flex h-full w-full flex-col border-l border-neutral-200 bg-white/80 p-6 text-black backdrop-blur-xl md:w-[390px] dark:border-neutral-700 dark:bg-black/80 dark:text-white"> | ||||||
|               <div className="flex items-center justify-between"> |               <div className="flex items-center justify-between"> | ||||||
|                 <p className="text-lg font-semibold">My Cart</p> |                 <p className="text-lg font-semibold">My Cart</p> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ const FooterMenuItem = ({ item }: { item: Menu }) => { | |||||||
|       <Link |       <Link | ||||||
|         href={item.path} |         href={item.path} | ||||||
|         className={clsx( |         className={clsx( | ||||||
|           'block p-2 text-lg underline-offset-4 hover:text-black hover:underline dark:hover:text-neutral-300 md:inline-block md:text-sm', |           'block p-2 text-lg underline-offset-4 hover:text-black hover:underline md:inline-block md:text-sm dark:hover:text-neutral-300', | ||||||
|           { |           { | ||||||
|             'text-black dark:text-neutral-300': active |             'text-black dark:text-neutral-300': active | ||||||
|           } |           } | ||||||
|   | |||||||
| @@ -16,9 +16,9 @@ export default async function Footer() { | |||||||
|  |  | ||||||
|   return ( |   return ( | ||||||
|     <footer className="text-sm text-neutral-500 dark:text-neutral-400"> |     <footer className="text-sm text-neutral-500 dark:text-neutral-400"> | ||||||
|       <div className="mx-auto flex w-full max-w-7xl flex-col gap-6 border-t border-neutral-200 px-6 py-12 text-sm dark:border-neutral-700 md:flex-row md:gap-12 md:px-4 min-[1320px]:px-0"> |       <div className="mx-auto flex w-full max-w-7xl flex-col gap-6 border-t border-neutral-200 px-6 py-12 text-sm md:flex-row md:gap-12 md:px-4 min-[1320px]:px-0 dark:border-neutral-700"> | ||||||
|         <div> |         <div> | ||||||
|           <Link className="flex items-center gap-2 text-black dark:text-white md:pt-1" href="/"> |           <Link className="flex items-center gap-2 text-black md:pt-1 dark:text-white" href="/"> | ||||||
|             <LogoSquare size="sm" /> |             <LogoSquare size="sm" /> | ||||||
|             <span className="uppercase">{SITE_NAME}</span> |             <span className="uppercase">{SITE_NAME}</span> | ||||||
|           </Link> |           </Link> | ||||||
|   | |||||||
| @@ -6,7 +6,7 @@ import { Menu } from 'lib/shopify/types'; | |||||||
| import Link from 'next/link'; | import Link from 'next/link'; | ||||||
| import { Suspense } from 'react'; | import { Suspense } from 'react'; | ||||||
| import MobileMenu from './mobile-menu'; | import MobileMenu from './mobile-menu'; | ||||||
| import Search from './search'; | import Search, { SearchSkeleton } from './search'; | ||||||
| const { SITE_NAME } = process.env; | const { SITE_NAME } = process.env; | ||||||
|  |  | ||||||
| export default async function Navbar() { | export default async function Navbar() { | ||||||
| @@ -15,7 +15,9 @@ export default async function Navbar() { | |||||||
|   return ( |   return ( | ||||||
|     <nav className="relative flex items-center justify-between p-4 lg:px-6"> |     <nav className="relative flex items-center justify-between p-4 lg:px-6"> | ||||||
|       <div className="block flex-none md:hidden"> |       <div className="block flex-none md:hidden"> | ||||||
|         <MobileMenu menu={menu} /> |         <Suspense fallback={null}> | ||||||
|  |           <MobileMenu menu={menu} /> | ||||||
|  |         </Suspense> | ||||||
|       </div> |       </div> | ||||||
|       <div className="flex w-full items-center"> |       <div className="flex w-full items-center"> | ||||||
|         <div className="flex w-full md:w-1/3"> |         <div className="flex w-full md:w-1/3"> | ||||||
| @@ -41,7 +43,9 @@ export default async function Navbar() { | |||||||
|           ) : null} |           ) : null} | ||||||
|         </div> |         </div> | ||||||
|         <div className="hidden justify-center md:flex md:w-1/3"> |         <div className="hidden justify-center md:flex md:w-1/3"> | ||||||
|           <Search /> |           <Suspense fallback={<SearchSkeleton />}> | ||||||
|  |             <Search /> | ||||||
|  |           </Suspense> | ||||||
|         </div> |         </div> | ||||||
|         <div className="flex justify-end md:w-1/3"> |         <div className="flex justify-end md:w-1/3"> | ||||||
|           <Suspense fallback={<OpenCart />}> |           <Suspense fallback={<OpenCart />}> | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ | |||||||
| import { Dialog, Transition } from '@headlessui/react'; | import { Dialog, Transition } from '@headlessui/react'; | ||||||
| import Link from 'next/link'; | import Link from 'next/link'; | ||||||
| import { usePathname, useSearchParams } from 'next/navigation'; | import { usePathname, useSearchParams } from 'next/navigation'; | ||||||
| import { Fragment, useEffect, useState } from 'react'; | import { Fragment, Suspense, useEffect, useState } from 'react'; | ||||||
|  |  | ||||||
| import { Bars3Icon, XMarkIcon } from '@heroicons/react/24/outline'; | import { Bars3Icon, XMarkIcon } from '@heroicons/react/24/outline'; | ||||||
| import { Menu } from 'lib/shopify/types'; | import { Menu } from 'lib/shopify/types'; | ||||||
| import Search from './search'; | import Search, { SearchSkeleton } from './search'; | ||||||
|  |  | ||||||
| export default function MobileMenu({ menu }: { menu: Menu[] }) { | export default function MobileMenu({ menu }: { menu: Menu[] }) { | ||||||
|   const pathname = usePathname(); |   const pathname = usePathname(); | ||||||
| @@ -35,7 +35,7 @@ export default function MobileMenu({ menu }: { menu: Menu[] }) { | |||||||
|       <button |       <button | ||||||
|         onClick={openMobileMenu} |         onClick={openMobileMenu} | ||||||
|         aria-label="Open mobile menu" |         aria-label="Open mobile menu" | ||||||
|         className="flex h-11 w-11 items-center justify-center rounded-md border border-neutral-200 text-black transition-colors dark:border-neutral-700 dark:text-white md:hidden" |         className="flex h-11 w-11 items-center justify-center rounded-md border border-neutral-200 text-black transition-colors md:hidden dark:border-neutral-700 dark:text-white" | ||||||
|       > |       > | ||||||
|         <Bars3Icon className="h-4" /> |         <Bars3Icon className="h-4" /> | ||||||
|       </button> |       </button> | ||||||
| @@ -72,7 +72,9 @@ export default function MobileMenu({ menu }: { menu: Menu[] }) { | |||||||
|                 </button> |                 </button> | ||||||
|  |  | ||||||
|                 <div className="mb-4 w-full"> |                 <div className="mb-4 w-full"> | ||||||
|                   <Search /> |                   <Suspense fallback={<SearchSkeleton />}> | ||||||
|  |                     <Search /> | ||||||
|  |                   </Suspense> | ||||||
|                 </div> |                 </div> | ||||||
|                 {menu.length ? ( |                 {menu.length ? ( | ||||||
|                   <ul className="flex w-full flex-col"> |                   <ul className="flex w-full flex-col"> | ||||||
|   | |||||||
| @@ -41,3 +41,17 @@ export default function Search() { | |||||||
|     </form> |     </form> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export function SearchSkeleton() { | ||||||
|  |   return ( | ||||||
|  |     <form className="w-max-[550px] relative w-full lg:w-80 xl:w-full"> | ||||||
|  |       <input | ||||||
|  |         placeholder="Search for products..." | ||||||
|  |         className="w-full rounded-lg border bg-white px-4 py-2 text-sm text-black placeholder:text-neutral-500 dark:border-neutral-800 dark:bg-transparent dark:text-white dark:placeholder:text-neutral-400" | ||||||
|  |       /> | ||||||
|  |       <div className="absolute right-0 top-0 mr-3 flex h-full items-center"> | ||||||
|  |         <MagnifyingGlassIcon className="h-4" /> | ||||||
|  |       </div> | ||||||
|  |     </form> | ||||||
|  |   ); | ||||||
|  | } | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| import { SortFilterItem } from 'lib/constants'; | import { SortFilterItem } from 'lib/constants'; | ||||||
|  | import { Suspense } from 'react'; | ||||||
| import FilterItemDropdown from './dropdown'; | import FilterItemDropdown from './dropdown'; | ||||||
| import { FilterItem } from './item'; | import { FilterItem } from './item'; | ||||||
|  |  | ||||||
| @@ -20,15 +21,19 @@ export default function FilterList({ list, title }: { list: ListItem[]; title?: | |||||||
|     <> |     <> | ||||||
|       <nav> |       <nav> | ||||||
|         {title ? ( |         {title ? ( | ||||||
|           <h3 className="hidden text-xs text-neutral-500 dark:text-neutral-400 md:block"> |           <h3 className="hidden text-xs text-neutral-500 md:block dark:text-neutral-400"> | ||||||
|             {title} |             {title} | ||||||
|           </h3> |           </h3> | ||||||
|         ) : null} |         ) : null} | ||||||
|         <ul className="hidden md:block"> |         <ul className="hidden md:block"> | ||||||
|           <FilterItemList list={list} /> |           <Suspense fallback={null}> | ||||||
|  |             <FilterItemList list={list} /> | ||||||
|  |           </Suspense>{' '} | ||||||
|         </ul> |         </ul> | ||||||
|         <ul className="md:hidden"> |         <ul className="md:hidden"> | ||||||
|           <FilterItemDropdown list={list} /> |           <Suspense fallback={null}> | ||||||
|  |             <FilterItemDropdown list={list} /> | ||||||
|  |           </Suspense>{' '} | ||||||
|         </ul> |         </ul> | ||||||
|       </nav> |       </nav> | ||||||
|     </> |     </> | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| 'use client'; | 'use client'; | ||||||
|  |  | ||||||
| import clsx from 'clsx'; | import clsx from 'clsx'; | ||||||
| import { SortFilterItem } from 'lib/constants'; | import type { SortFilterItem } from 'lib/constants'; | ||||||
| import { createUrl } from 'lib/utils'; | import { createUrl } from 'lib/utils'; | ||||||
| import Link from 'next/link'; | import Link from 'next/link'; | ||||||
| import { usePathname, useSearchParams } from 'next/navigation'; | import { usePathname, useSearchParams } from 'next/navigation'; | ||||||
|   | |||||||
| @@ -2,6 +2,7 @@ import { AddToCart } from 'components/cart/add-to-cart'; | |||||||
| import Price from 'components/price'; | import Price from 'components/price'; | ||||||
| import Prose from 'components/prose'; | import Prose from 'components/prose'; | ||||||
| import { Product } from 'lib/shopify/types'; | import { Product } from 'lib/shopify/types'; | ||||||
|  | import { Suspense } from 'react'; | ||||||
| import { VariantSelector } from './variant-selector'; | import { VariantSelector } from './variant-selector'; | ||||||
|  |  | ||||||
| export function ProductDescription({ product }: { product: Product }) { | export function ProductDescription({ product }: { product: Product }) { | ||||||
| @@ -16,7 +17,9 @@ export function ProductDescription({ product }: { product: Product }) { | |||||||
|           /> |           /> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|       <VariantSelector options={product.options} variants={product.variants} /> |       <Suspense fallback={null}> | ||||||
|  |         <VariantSelector options={product.options} variants={product.variants} /> | ||||||
|  |       </Suspense> | ||||||
|  |  | ||||||
|       {product.descriptionHtml ? ( |       {product.descriptionHtml ? ( | ||||||
|         <Prose |         <Prose | ||||||
| @@ -25,7 +28,9 @@ export function ProductDescription({ product }: { product: Product }) { | |||||||
|         /> |         /> | ||||||
|       ) : null} |       ) : null} | ||||||
|  |  | ||||||
|       <AddToCart variants={product.variants} availableForSale={product.availableForSale} /> |       <Suspense fallback={null}> | ||||||
|  |         <AddToCart variants={product.variants} availableForSale={product.availableForSale} /> | ||||||
|  |       </Suspense> | ||||||
|     </> |     </> | ||||||
|   ); |   ); | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										42
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										42
									
								
								package.json
									
									
									
									
									
								
							| @@ -6,7 +6,7 @@ | |||||||
|     "pnpm": ">=7" |     "pnpm": ">=7" | ||||||
|   }, |   }, | ||||||
|   "scripts": { |   "scripts": { | ||||||
|     "dev": "next dev", |     "dev": "next dev --turbo", | ||||||
|     "build": "next build", |     "build": "next build", | ||||||
|     "start": "next start", |     "start": "next start", | ||||||
|     "lint": "next lint", |     "lint": "next lint", | ||||||
| @@ -22,31 +22,31 @@ | |||||||
|     "*": "prettier --write --ignore-unknown" |     "*": "prettier --write --ignore-unknown" | ||||||
|   }, |   }, | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@headlessui/react": "^1.7.17", |     "@headlessui/react": "^1.7.18", | ||||||
|     "@heroicons/react": "^2.0.18", |     "@heroicons/react": "^2.1.3", | ||||||
|     "clsx": "^2.0.0", |     "clsx": "^2.1.0", | ||||||
|     "geist": "^1.0.0", |     "geist": "^1.3.0", | ||||||
|     "next": "14.0.0", |     "next": "14.1.4", | ||||||
|     "react": "18.2.0", |     "react": "18.2.0", | ||||||
|     "react-dom": "18.2.0" |     "react-dom": "18.2.0" | ||||||
|   }, |   }, | ||||||
|   "devDependencies": { |   "devDependencies": { | ||||||
|     "@tailwindcss/container-queries": "^0.1.1", |     "@tailwindcss/container-queries": "^0.1.1", | ||||||
|     "@tailwindcss/typography": "^0.5.10", |     "@tailwindcss/typography": "^0.5.11", | ||||||
|     "@types/node": "20.8.9", |     "@types/node": "20.11.30", | ||||||
|     "@types/react": "18.2.33", |     "@types/react": "18.2.72", | ||||||
|     "@types/react-dom": "18.2.14", |     "@types/react-dom": "18.2.22", | ||||||
|     "@vercel/git-hooks": "^1.0.0", |     "@vercel/git-hooks": "^1.0.0", | ||||||
|     "autoprefixer": "^10.4.16", |     "autoprefixer": "^10.4.19", | ||||||
|     "eslint": "^8.52.0", |     "eslint": "^8.57.0", | ||||||
|     "eslint-config-next": "^14.0.0", |     "eslint-config-next": "^14.1.4", | ||||||
|     "eslint-config-prettier": "^9.0.0", |     "eslint-config-prettier": "^9.1.0", | ||||||
|     "eslint-plugin-unicorn": "^48.0.1", |     "eslint-plugin-unicorn": "^51.0.1", | ||||||
|     "lint-staged": "^15.0.2", |     "lint-staged": "^15.2.2", | ||||||
|     "postcss": "^8.4.31", |     "postcss": "^8.4.38", | ||||||
|     "prettier": "3.0.3", |     "prettier": "3.2.5", | ||||||
|     "prettier-plugin-tailwindcss": "^0.5.6", |     "prettier-plugin-tailwindcss": "^0.5.12", | ||||||
|     "tailwindcss": "^3.3.5", |     "tailwindcss": "^3.4.1", | ||||||
|     "typescript": "5.2.2" |     "typescript": "5.4.3" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										1793
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1793
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user