@shopify/cli-hydrogen 4.0.0-alpha.9 → 4.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/commands/hydrogen/build.d.ts +20 -0
- package/dist/commands/hydrogen/build.js +36 -33
- package/dist/commands/hydrogen/check.d.ts +18 -0
- package/dist/commands/hydrogen/check.js +35 -0
- package/dist/commands/hydrogen/dev.d.ts +14 -0
- package/dist/commands/hydrogen/dev.js +56 -60
- package/dist/commands/hydrogen/generate/route.d.ts +34 -0
- package/dist/commands/hydrogen/generate/route.js +165 -0
- package/dist/commands/hydrogen/generate/route.test.d.ts +1 -0
- package/dist/commands/hydrogen/generate/route.test.js +126 -0
- package/dist/commands/hydrogen/generate/routes.d.ts +16 -0
- package/dist/commands/hydrogen/generate/routes.js +22 -0
- package/dist/commands/hydrogen/init.d.ts +22 -0
- package/dist/commands/hydrogen/init.js +169 -25
- package/dist/commands/hydrogen/preview.d.ts +17 -0
- package/dist/commands/hydrogen/preview.js +2 -2
- package/dist/create-app.d.ts +1 -0
- package/dist/create-app.js +4 -0
- package/dist/{templates/demo-store/app/routes/($lang) → generator-templates/routes}/[robots.txt].tsx +2 -1
- package/dist/{templates/demo-store/app/routes/($lang) → generator-templates/routes}/[sitemap.xml].tsx +8 -6
- package/dist/generator-templates/routes/account/login.tsx +74 -0
- package/dist/generator-templates/routes/account/register.tsx +74 -0
- package/dist/generator-templates/routes/cart.tsx +43 -0
- package/dist/generator-templates/routes/collections/$collectionHandle.tsx +65 -0
- package/dist/{templates/demo-store/app → generator-templates}/routes/graphiql.tsx +0 -0
- package/dist/{templates/hello-world/app → generator-templates}/routes/index.tsx +0 -0
- package/dist/generator-templates/routes/pages/$pageHandle.tsx +74 -0
- package/dist/{templates/demo-store/app/routes/($lang) → generator-templates/routes}/policies/$policyHandle.tsx +9 -38
- package/dist/generator-templates/routes/policies/index.tsx +65 -0
- package/dist/generator-templates/routes/products/$productHandle.tsx +57 -0
- package/dist/hooks/init.d.ts +5 -0
- package/dist/utils/check-lockfile.d.ts +3 -0
- package/dist/utils/check-lockfile.js +78 -0
- package/dist/utils/check-version.d.ts +3 -0
- package/dist/utils/check-version.js +50 -0
- package/dist/utils/config.d.ts +18 -0
- package/dist/utils/config.js +116 -43
- package/dist/utils/flags.d.ts +10 -0
- package/dist/utils/flags.js +15 -3
- package/dist/utils/flags.test.d.ts +1 -0
- package/dist/utils/flags.test.js +18 -0
- package/dist/utils/log.d.ts +5 -0
- package/dist/utils/mini-oxygen.d.ts +11 -0
- package/dist/utils/mini-oxygen.js +7 -4
- package/dist/utils/missing-routes.d.ts +6 -0
- package/dist/utils/missing-routes.js +71 -0
- package/dist/utils/template-downloader.d.ts +11 -0
- package/dist/utils/template-downloader.js +66 -0
- package/dist/utils/transpile-ts.d.ts +16 -0
- package/dist/utils/transpile-ts.js +169 -0
- package/dist/utils/virtual-routes.d.ts +7 -0
- package/dist/utils/virtual-routes.js +47 -0
- package/dist/utils/virtual-routes.test.d.ts +1 -0
- package/dist/utils/virtual-routes.test.js +46 -0
- package/dist/virtual-routes/assets/dummy.d.ts +1 -0
- package/dist/virtual-routes/assets/dummy.js +1 -0
- package/dist/virtual-routes/assets/dummy.ts +1 -0
- package/dist/{templates/demo-store/dist/client → virtual-routes/assets}/favicon.svg +0 -0
- package/dist/virtual-routes/assets/styles.css +207 -0
- package/dist/virtual-routes/components/HydrogenLogoBaseBW.jsx +7 -0
- package/dist/virtual-routes/components/HydrogenLogoBaseColor.jsx +13 -0
- package/dist/virtual-routes/components/IconBanner.jsx +47 -0
- package/dist/virtual-routes/components/IconDiscord.jsx +4 -0
- package/dist/virtual-routes/components/IconError.jsx +20 -0
- package/dist/virtual-routes/components/IconGithub.jsx +4 -0
- package/dist/virtual-routes/components/IconTwitter.jsx +4 -0
- package/dist/virtual-routes/components/Layout.jsx +6 -0
- package/dist/virtual-routes/routes/graphiql.jsx +5 -0
- package/dist/virtual-routes/routes/index.jsx +140 -0
- package/dist/virtual-routes/virtual-root.jsx +38 -0
- package/oclif.manifest.json +1 -131
- package/package.json +36 -7
- package/dist/templates/demo-store/.cache/content-v2/sha512/02/76/13bbea15bb42b81a204b0dc5f14726e0bfa8d012a7b284f887cc2e3c92195d6b07a78f199f990b311ca5fafa9079563503cdd81808cd9b7e496d86c72732 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/08/56/c9a478b8c5c2fbfb6eed219f0861db568eceecbb45155124491ca25125ca421aac7e1b10d29151e5294a776ae10e02e01dc2da3561da793d111c4f908502 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/0f/d5/950a1e0708f440217f567601ee2bfed73c56ada7491058d1ebb769f9a348484d29d4c3897d848d5f9123b0cfb8be69de4ebddc9d964a368e779e2927be5b +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/10/31/47b4061a63eaedea6368416dff9248ab2e51a4bea4004882a27c1437490c8150a4709438d28bbd8fd71a7516c9af612204f6116b0604e18902b5c6f69453 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/13/f6/b7f804d45a961ca1e392429e75ad80f23ba46cbba0e960c6a70f8de81f3f3763af59651474176798d1a1a4bd2a5109b1d441f6d1c8ba070b678b38378adf +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/28/7c/c71b0c6367bdf7307a8061fe1c4568c9f1e9603d835b6fc917fe8042535a867c37154e35376a01ad6bdb3c2d6f29b88b41902fd6f20b1227e02081682d01 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/29/62/a788055902cff8e9403b901ebd715b56541b0ee4dc9f13cb739cd906ae89ae1fa7199831d613ab21c3ee5d84c5456608dc8707d9199ae3d8ba5e9fd7ce95 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/2b/b2/d5a8e11c89553d08b26b4a7ba8b901de31c0b182f745f8c5d1c5aba44bf46d0d69e3d8042f5917728d0b69d5eba102e3de332f8141aef67a12d215a66843 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/34/dd/ec66f7075936ba94dd741485089904914960fd50a4886c31783c27c27ca08852be43dea712e8aaea6f5197b83ccf1949c8a24c27ff61f5280377917d722e +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/46/04/af285aee74d96b28b24f75d7911de65e6c7bb26475ab5219fe5308028fda55060cf45650dfa09c0731ec73ece453c1e24e0c38715e8d4c5c80fd6365a1f4 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/4e/ea/2fe739931285fa2839b54fe6c91470491475eac2d960e35ef0c6750313c08fbf2b2d784c0bb71c5fb2ef6c4a27f2202a4c29199b53bf7fd43c5721f90ecf +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/51/ab/e165384df6374c7b2d0ebebc8642ecb0e0c14f7c5b57970ec5d2e17f7d1643e0b01eda69e5ffbefde85ecba6d613bcc5175c5564e36bfb73d966c8ea4153 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/54/b2/a99146d18769ec698b6c61e4c3e63689a24110cca7c671d926fc1320f5a2ac5cdbf143db9074dcfb383359307c50ccbe2512f2d9ee992eb53f2ed98997af +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/57/7e/37b69b357be4c488e5fca37c009c908201ac2107ddaa589143bcb108e9c5f7e4ca91a36f068b3f88bb0da655d7832bd040dcbef25d807faf0804a7f93c9a +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/6d/d8/5ad2b238dcc09122c8977b26e2a2eb94e12b1cda5181a020ec77d9364ea2efdc2ddddaf2ba766ced871d8cc33e5862fb4ae0c6591080b7523e5e779dceb5 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/72/e4/3df1f2ae672aa3148b6afde9bd16b5371250464c301be7a4ca40e459768db712d39fb7039ce9710264f726b531b7dd346e43fe260b53789206a05f665393 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/73/40/c822831f11f08a9ceea944d0145b072ba6164a3e2e75f98fda5437cda6dfddf9ca9450445c1f3236228d6259ac95e4cde9bb6e5996490ed00b7b13b06121 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/73/ad/c5cb88faf344aa1be4c7f263610bbf4e5b4b4122a277e9f8adb20bdaabf46a65f647d902bf885172c5e17f16d63c69d9f0213938ad0648099d627bcdc7a3 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/79/6a/c7905d20904ce592cd04dabc941dcfb9ae88a2936f564c6ca21dba66c7b89f44c697504d1fef3427d5121f3ce0abfc72225a25a5985cc2f823c50cb1a4e0 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/7e/bd/739d3492efb96a9a5952538eee6f83dd7123c59a4b48538a5a554b8684ba84a1e65dd626b5aa9c6dc74c96734c46e3303ab93e6a5fcc56ecb4150c036aea +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/88/76/d18fdfbb05293909609d42368642fc6da4bd138c5864ec2f721212b52e595b84ae46f48021ed3e6240edf443f78bdea557d56d700e3da848459ea3077a80 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/88/d0/847cc94057b70b5352a6f097d172883a789eedabfe597475672bec5495d323bc41e185cd5a6477aa691befeb69bd6f19f77b4735ebd8f230d39491bdabae +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/93/6b/e60098157f6bff8ba570cab2ffd97a14983109006f7fa87e4432728366f96dfb19e957d28754daa45f1b6cb2421d26ab59bbd5ce5a448d6102e8e662403d +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/bc/1c/74650cdfe58d3295c52501b3572b71ca4d0bcebe895291b39d63fc57d60b1924315d5b6292c825bec288196d39acf45d63688726fd77e85d99ce18e52f28 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/bc/33/6e26ece5ac53d9eac9ac8a192ef39faf2a587a5808253c659fb1d371c477fc8074d428c8d1929b0d85dd1fec66fc79ea6b9fcb01507e2efec75fb7fbc2cc +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/cb/63/324e426b4c93a3fa8db83dab506b9abbe2d7628897dfd1369642f19d66f140c090e1c3834728d5082f8cffe846f7c54d112e11f5d934d629ed996d177a1f +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/d6/bd/656ddf1b02384b21b4fb55c615f28bba616f85c0992a8555bfbc3b0cf0692e2b3f20a534b4c3baef86e7c9ccf36b8d3a9239747b3d8422ff4dbe7dd2d0a6 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/da/84/b6d27e02f9b109d7cff3095b08e2e2ed1802c8b6829c98f6e297d1c404059f8bacfdc278afd07e2f81cbc487318396a3775037b678ab6aff9a5231c94c0d +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/e8/ae/9b467e1d23913d4584d9417875b3cdc25f6dfed8b228f3a0c818129010b778aae1af1eb200b015ab428e79afe0ef1061262392fbdb96ed7da95efbe7f758 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/f4/ba/e578b89fa1a4a0549fa2e68e0ba078fa8c9207c376189d1550a7ae0e54c4c0548d0a29a0cef532ca613e25832b9343e74f6a8bc7338fcc28d51e6e3d7898 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/fb/75/9195d7f913bc6ae5a345003e0863e0c38c00e744334e2ae61feba1a3099be8207599085a8264590dbd0fd9e1fff1d58037183d106cdbc750c7ad6f979d88 +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/fd/ef/df6382410602f345da5bb420585629c22c350bc028c87eb6da71e611f381c5ccba09b435b9b5fb31d7c8beb5b8abfa87abdb874b189a3211efe61840fbac +0 -1
- package/dist/templates/demo-store/.cache/content-v2/sha512/fd/f3/986b7ee5ea5ad1d89af5c08de69d43c025b54381092e0a19fd7e7a1e0352552aa85c056315ce5e11a46ec75a252b1a44e2083abb73cd6df8407dfdb0ac48 +0 -1
- package/dist/templates/demo-store/.cache/index-v5/05/44/bebd201ef5e9e9a7c41bd789ff110691a32c7f7fbbbdd630f33d96667cd1 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/26/b5/113aeb17f9f4ef406a1f8b143895199ca545fd0cc1e7972435a092910963 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/2c/09/e60b5cd818510e0cbec908aae3b74175e35e446f4383e87c21489433a11e +0 -2
- package/dist/templates/demo-store/.cache/index-v5/38/21/c3fb7841590b85142018ba88a01045ef1249ac34211342579f0129eae294 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/3a/98/8858fe7de4bf85d37c71adc322cc95335b498bef9a4ae41db324bf5696cc +0 -2
- package/dist/templates/demo-store/.cache/index-v5/3e/40/7021422a7cae2c05484b491fb5b85edd82b325e598ac9e5c6afb858049da +0 -2
- package/dist/templates/demo-store/.cache/index-v5/47/2f/8e9ec62247eca3464d07de774855bb30a56145adc6525b907490e0c1bda0 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/5e/83/14bed234cd143eaf4043de721fcf4250a5adc7008e76d663365e8a322c88 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/5f/87/f79366b4aab5423acdda7930c6c989c49dd1c6607885df3afaa5e6873c9f +0 -2
- package/dist/templates/demo-store/.cache/index-v5/6e/9e/dc622ea9b5c66089a08f3e8b7a0e62a29e85bab337da0a3b28d6126185ec +0 -2
- package/dist/templates/demo-store/.cache/index-v5/71/4c/401eb7f3b2db5e56857a3ddd90e61181e636a5d01cc569ff8671ddf7f14b +0 -2
- package/dist/templates/demo-store/.cache/index-v5/78/84/46021cf9ede94313b5bc2cbf2355909ae811d4879a7747f9e2341f6b5bfb +0 -2
- package/dist/templates/demo-store/.cache/index-v5/79/2e/b0dd8fcd37a11ecb71cfd33184651560cabda672e55e0b244fc6f825190c +0 -2
- package/dist/templates/demo-store/.cache/index-v5/7b/e1/807e64f6a84e568bf9163283e9d49b77b24ff24bd8eed751d9fd94ea404a +0 -2
- package/dist/templates/demo-store/.cache/index-v5/85/07/e0c4be5b8442583f11be2d0b6f09171d22721437456b745eb2c977294995 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/87/4d/89bc172664efe0dc7f86d8e67559073b2900ae079bd42ae9e3c015d38ab0 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/8c/0d/a633a8771437b330d83eef0fdd99a81c41356b2bdc81f80ec9277f92b060 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/a3/fc/e2e503290d165b9b0e20c6880bc23ff8ec39a440482418b5103c36be66b9 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/a5/bc/d87ab9468457cb872d6c360f8acecd05e0f88b7239b50754f120706fabd4 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/a5/c0/8e6e4f498a17b6198e54f204247ba544e6404b282d4ce3065d85fa69a8a4 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/af/65/89b0c9eb41779c1658ace443604fea125c524bc95cfc71c9b6300da2dc81 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/b2/75/51549baf010c977c70017db497fd9bd20e1efa9b658a6d52761c559f9c0b +0 -2
- package/dist/templates/demo-store/.cache/index-v5/b3/75/d3e7a4a5df68530007409daf1d2e66ab789c8b658d1819d7e5fd183f5f57 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/bb/db/9dc2cbdcdc6ff352f9a34463a02e198aa2123a4c2e4ef37fea8b8ccae413 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/d0/c4/d960260ece228d28f70e317741b3f3f3df05c53956d870235837ae2b73b4 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/d3/ca/ff5860148f0bedafb91dab72b54462de81a32a21210324c45a051b197b48 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/d4/55/296e80e87e2652f4cf1aebd5419fe73ef16c94ab20cd0400166d44ea1746 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/da/7a/4b6977be684885e550a0d8fd21c955d0195371ffc3a9535a5a7b950a5ac9 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/dd/aa/599a1cd855476ba058c63ae75a9c006ca11f7fbc2efc00b361d7f1b95cb4 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/df/d2/bcfa3853e61309abab85dbd561dbc632ad0ea79b24f1b77c95f861eead5f +0 -2
- package/dist/templates/demo-store/.cache/index-v5/df/f5/cc3a1197c607eac768ab1b1cdb7b53a7f87b67c23c92da957d45a5bd0bda +0 -2
- package/dist/templates/demo-store/.cache/index-v5/e4/bd/743967c269ef70a14ba6b5dd223d26759eae9295d79f165c66f514b7d8d3 +0 -2
- package/dist/templates/demo-store/.cache/index-v5/e5/d3/0de6bfbb93ef9271b53f0ded9696291312b19ff087c2826d679ee2c74c01 +0 -2
- package/dist/templates/demo-store/.editorconfig +0 -8
- package/dist/templates/demo-store/.eslintignore +0 -4
- package/dist/templates/demo-store/.eslintrc.js +0 -16
- package/dist/templates/demo-store/.graphqlrc.yml +0 -1
- package/dist/templates/demo-store/.prettierignore +0 -2
- package/dist/templates/demo-store/_env +0 -6
- package/dist/templates/demo-store/_gitignore +0 -13
- package/dist/templates/demo-store/app/components/AccountAddressBook.tsx +0 -97
- package/dist/templates/demo-store/app/components/AccountDetails.tsx +0 -41
- package/dist/templates/demo-store/app/components/AddToCartButton.tsx +0 -42
- package/dist/templates/demo-store/app/components/Breadcrumbs.tsx +0 -36
- package/dist/templates/demo-store/app/components/Button.tsx +0 -56
- package/dist/templates/demo-store/app/components/Cart.tsx +0 -431
- package/dist/templates/demo-store/app/components/CartLoading.tsx +0 -50
- package/dist/templates/demo-store/app/components/CountrySelector.tsx +0 -180
- package/dist/templates/demo-store/app/components/Drawer.tsx +0 -115
- package/dist/templates/demo-store/app/components/FeaturedCollections.tsx +0 -54
- package/dist/templates/demo-store/app/components/FeaturedProducts.tsx +0 -116
- package/dist/templates/demo-store/app/components/FeaturedSection.tsx +0 -39
- package/dist/templates/demo-store/app/components/GenericError.tsx +0 -58
- package/dist/templates/demo-store/app/components/Grid.tsx +0 -44
- package/dist/templates/demo-store/app/components/Hero.tsx +0 -129
- package/dist/templates/demo-store/app/components/Icon.tsx +0 -253
- package/dist/templates/demo-store/app/components/Input.tsx +0 -24
- package/dist/templates/demo-store/app/components/Layout.tsx +0 -492
- package/dist/templates/demo-store/app/components/Link.tsx +0 -46
- package/dist/templates/demo-store/app/components/Modal.tsx +0 -46
- package/dist/templates/demo-store/app/components/NotFound.tsx +0 -22
- package/dist/templates/demo-store/app/components/OrderCard.tsx +0 -82
- package/dist/templates/demo-store/app/components/Pagination.tsx +0 -277
- package/dist/templates/demo-store/app/components/ProductCard.tsx +0 -140
- package/dist/templates/demo-store/app/components/ProductGallery.tsx +0 -114
- package/dist/templates/demo-store/app/components/ProductGrid.tsx +0 -93
- package/dist/templates/demo-store/app/components/ProductSwimlane.tsx +0 -30
- package/dist/templates/demo-store/app/components/Skeleton.tsx +0 -24
- package/dist/templates/demo-store/app/components/SortFilter.tsx +0 -414
- package/dist/templates/demo-store/app/components/Text.tsx +0 -192
- package/dist/templates/demo-store/app/components/index.ts +0 -28
- package/dist/templates/demo-store/app/data/countries.ts +0 -194
- package/dist/templates/demo-store/app/data/index.ts +0 -1027
- package/dist/templates/demo-store/app/entry.client.tsx +0 -4
- package/dist/templates/demo-store/app/entry.server.tsx +0 -26
- package/dist/templates/demo-store/app/hooks/useCartFetchers.tsx +0 -14
- package/dist/templates/demo-store/app/hooks/useIsHydrated.tsx +0 -12
- package/dist/templates/demo-store/app/lib/const.ts +0 -10
- package/dist/templates/demo-store/app/lib/placeholders.ts +0 -244
- package/dist/templates/demo-store/app/lib/seo/common.tsx +0 -367
- package/dist/templates/demo-store/app/lib/seo/debugger.tsx +0 -175
- package/dist/templates/demo-store/app/lib/seo/image.tsx +0 -32
- package/dist/templates/demo-store/app/lib/seo/index.ts +0 -4
- package/dist/templates/demo-store/app/lib/seo/seo.tsx +0 -24
- package/dist/templates/demo-store/app/lib/seo/types.ts +0 -84
- package/dist/templates/demo-store/app/lib/session.server.ts +0 -57
- package/dist/templates/demo-store/app/lib/type.ts +0 -21
- package/dist/templates/demo-store/app/lib/utils.ts +0 -310
- package/dist/templates/demo-store/app/root.tsx +0 -279
- package/dist/templates/demo-store/app/routes/($lang)/$.tsx +0 -7
- package/dist/templates/demo-store/app/routes/($lang)/account/__private/address/$id.tsx +0 -320
- package/dist/templates/demo-store/app/routes/($lang)/account/__private/edit.tsx +0 -273
- package/dist/templates/demo-store/app/routes/($lang)/account/__private/logout.ts +0 -25
- package/dist/templates/demo-store/app/routes/($lang)/account/__private/orders.$id.tsx +0 -322
- package/dist/templates/demo-store/app/routes/($lang)/account/__public/activate.$id.$activationToken.tsx +0 -218
- package/dist/templates/demo-store/app/routes/($lang)/account/__public/login.tsx +0 -197
- package/dist/templates/demo-store/app/routes/($lang)/account/__public/recover.tsx +0 -144
- package/dist/templates/demo-store/app/routes/($lang)/account/__public/register.tsx +0 -184
- package/dist/templates/demo-store/app/routes/($lang)/account/__public/reset.$id.$resetToken.tsx +0 -214
- package/dist/templates/demo-store/app/routes/($lang)/account.tsx +0 -188
- package/dist/templates/demo-store/app/routes/($lang)/api/countries.tsx +0 -22
- package/dist/templates/demo-store/app/routes/($lang)/api/products.tsx +0 -116
- package/dist/templates/demo-store/app/routes/($lang)/cart.tsx +0 -510
- package/dist/templates/demo-store/app/routes/($lang)/collections/$collectionHandle.tsx +0 -300
- package/dist/templates/demo-store/app/routes/($lang)/collections/all.tsx +0 -5
- package/dist/templates/demo-store/app/routes/($lang)/collections/index.tsx +0 -188
- package/dist/templates/demo-store/app/routes/($lang)/discounts.$code.tsx +0 -60
- package/dist/templates/demo-store/app/routes/($lang)/featured-products.tsx +0 -58
- package/dist/templates/demo-store/app/routes/($lang)/index.tsx +0 -241
- package/dist/templates/demo-store/app/routes/($lang)/journal/$journalHandle.tsx +0 -141
- package/dist/templates/demo-store/app/routes/($lang)/journal/index.tsx +0 -152
- package/dist/templates/demo-store/app/routes/($lang)/og-image.tsx +0 -19
- package/dist/templates/demo-store/app/routes/($lang)/pages/$pageHandle.tsx +0 -75
- package/dist/templates/demo-store/app/routes/($lang)/policies/index.tsx +0 -97
- package/dist/templates/demo-store/app/routes/($lang)/products/$productHandle.tsx +0 -551
- package/dist/templates/demo-store/app/routes/($lang)/products/index.tsx +0 -148
- package/dist/templates/demo-store/app/routes/($lang)/search.tsx +0 -198
- package/dist/templates/demo-store/app/styles/app.css +0 -4203
- package/dist/templates/demo-store/app/styles/custom-font.css +0 -13
- package/dist/templates/demo-store/app/styles/fonts/IBMPlexSerif-Text.woff2 +0 -0
- package/dist/templates/demo-store/app/styles/fonts/IBMPlexSerif-TextItalic.woff2 +0 -0
- package/dist/templates/demo-store/dist/client/build/_assets/IBMPlexSerif-Text-YFMZNZW6.woff2 +0 -0
- package/dist/templates/demo-store/dist/client/build/_assets/IBMPlexSerif-TextItalic-CS6L5H7S.woff2 +0 -0
- package/dist/templates/demo-store/dist/client/build/_assets/app-PPSD2NK6.css +0 -1
- package/dist/templates/demo-store/dist/client/build/_assets/custom-font-WVPOFKHF.css +0 -1
- package/dist/templates/demo-store/dist/client/build/_assets/favicon-5FIZBM2K.svg +0 -28
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-7CASD2US.js +0 -9
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-7CASD2US.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-7CKXJRLM.js +0 -2
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-7CKXJRLM.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-AYHDHSL7.js +0 -2
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-AYHDHSL7.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-EW52HEI6.js +0 -133
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-EW52HEI6.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-MEPKJ2VW.js +0 -2
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-MEPKJ2VW.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-NIVT6A2W.js +0 -2
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-NIVT6A2W.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-SYP5DAMV.js +0 -2
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-SYP5DAMV.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-SZCP6RSO.js +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-SZCP6RSO.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-YCAWB56Y.js +0 -31
- package/dist/templates/demo-store/dist/client/build/_shared/chunk-YCAWB56Y.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/entry.client-3PUQSZFF.js +0 -2
- package/dist/templates/demo-store/dist/client/build/entry.client-3PUQSZFF.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/manifest-E4E22121.js +0 -1
- package/dist/templates/demo-store/dist/client/build/root-6BHVTOEY.js +0 -14
- package/dist/templates/demo-store/dist/client/build/root-6BHVTOEY.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/$-HDBACFGJ.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/$-HDBACFGJ.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/[robots.txt]-KDA3EX2G.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/[robots.txt]-KDA3EX2G.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/[sitemap.xml]-AAQRJL2R.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/[sitemap.xml]-AAQRJL2R.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/address/$id-3WQU2LQT.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/address/$id-3WQU2LQT.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/edit-3XQ4BLHS.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/edit-3XQ4BLHS.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/logout-7KXWFBCX.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/logout-7KXWFBCX.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/orders.$id-7VQDCWO5.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__private/orders.$id-7VQDCWO5.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/activate.$id.$activationToken-Z5BQE6J5.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/activate.$id.$activationToken-Z5BQE6J5.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/login-K6QUN2VF.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/login-K6QUN2VF.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/recover-UV5PLPS5.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/recover-UV5PLPS5.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/register-SZW3ORRR.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/register-SZW3ORRR.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/reset.$id.$resetToken-WOUXQWZU.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account/__public/reset.$id.$resetToken-WOUXQWZU.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account-PRE5HSJE.js +0 -25
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/account-PRE5HSJE.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/api/countries-UD6BGYL2.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/api/countries-UD6BGYL2.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/api/products-KIFIWUFE.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/api/products-KIFIWUFE.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/cart-3AJ7UOZX.js +0 -55
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/cart-3AJ7UOZX.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/$collectionHandle-ORDYEBM3.js +0 -83
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/$collectionHandle-ORDYEBM3.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/all-IXDFOKCK.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/all-IXDFOKCK.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/index-3AJFWRDR.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/collections/index-3AJFWRDR.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/discounts.$code-GYKQBNLQ.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/discounts.$code-GYKQBNLQ.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/featured-products-KNUST6DD.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/featured-products-KNUST6DD.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/index-4US2D5XK.js +0 -32
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/index-4US2D5XK.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/journal/$journalHandle-BCHHYOJX.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/journal/$journalHandle-BCHHYOJX.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/journal/index-LZR4YNUM.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/journal/index-LZR4YNUM.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/og-image-KUOACO4J.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/og-image-KUOACO4J.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/pages/$pageHandle-5WR6PFRU.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/pages/$pageHandle-5WR6PFRU.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/policies/$policyHandle-C5ATUMN6.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/policies/$policyHandle-C5ATUMN6.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/policies/index-MJDYZG5P.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/policies/index-MJDYZG5P.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/products/$productHandle-IB2WTXB6.js +0 -68
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/products/$productHandle-IB2WTXB6.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/products/index-266HKDAN.js +0 -24
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/products/index-266HKDAN.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/search-CH57YG7S.js +0 -54
- package/dist/templates/demo-store/dist/client/build/routes/($lang)/search-CH57YG7S.js.map +0 -7
- package/dist/templates/demo-store/dist/client/build/routes/graphiql-ZHVT5SA7.js +0 -2
- package/dist/templates/demo-store/dist/client/build/routes/graphiql-ZHVT5SA7.js.map +0 -7
- package/dist/templates/demo-store/dist/worker/_assets/IBMPlexSerif-Text-YFMZNZW6.woff2 +0 -0
- package/dist/templates/demo-store/dist/worker/_assets/IBMPlexSerif-TextItalic-CS6L5H7S.woff2 +0 -0
- package/dist/templates/demo-store/dist/worker/index.js +0 -1385
- package/dist/templates/demo-store/dist/worker/index.js.map +0 -7
- package/dist/templates/demo-store/package.json +0 -67
- package/dist/templates/demo-store/playwright.config.ts +0 -109
- package/dist/templates/demo-store/postcss.config.js +0 -10
- package/dist/templates/demo-store/public/favicon.svg +0 -28
- package/dist/templates/demo-store/remix.env.d.ts +0 -40
- package/dist/templates/demo-store/remix.init/index.js +0 -25
- package/dist/templates/demo-store/remix.init/package.json +0 -7
- package/dist/templates/demo-store/server.ts +0 -73
- package/dist/templates/demo-store/styles/app.css +0 -182
- package/dist/templates/demo-store/tailwind.config.js +0 -70
- package/dist/templates/demo-store/tests/cart.test.ts +0 -70
- package/dist/templates/demo-store/tests/seo.test.ts +0 -36
- package/dist/templates/demo-store/tests/utils.ts +0 -100
- package/dist/templates/demo-store/tsconfig.json +0 -25
- package/dist/templates/hello-world/.cache/content-v2/sha512/13/f6/b7f804d45a961ca1e392429e75ad80f23ba46cbba0e960c6a70f8de81f3f3763af59651474176798d1a1a4bd2a5109b1d441f6d1c8ba070b678b38378adf +0 -1
- package/dist/templates/hello-world/.cache/content-v2/sha512/4b/d3/aedf0c5a14c0f852936adb81a3bbd15ad1d5d9964ffe11a40d56bbdb2f2a4c7588ffa1d1ee657a3c3be4f6e6194465365f5d4213ef3b4e5086aa4bf0a5a4 +0 -1
- package/dist/templates/hello-world/.cache/content-v2/sha512/fa/dd/9bc10a1cb1f145eabd96bdba509178e20484197fefd8469ace9f53bf277e875751db3c4dddf229807c48cbe8db19494fe2a5aab7d2a4b7ae8bebbd67509c +0 -1
- package/dist/templates/hello-world/.cache/index-v5/09/f6/fe4b05c4157320b8b59b3f84116195be0437d87357d743d21acd638a4606 +0 -2
- package/dist/templates/hello-world/.cache/index-v5/b3/75/d3e7a4a5df68530007409daf1d2e66ab789c8b658d1819d7e5fd183f5f57 +0 -2
- package/dist/templates/hello-world/.cache/index-v5/d0/c4/d960260ece228d28f70e317741b3f3f3df05c53956d870235837ae2b73b4 +0 -2
- package/dist/templates/hello-world/.eslintignore +0 -4
- package/dist/templates/hello-world/.eslintrc.js +0 -6
- package/dist/templates/hello-world/.graphqlrc.yml +0 -1
- package/dist/templates/hello-world/README.md +0 -20
- package/dist/templates/hello-world/_env +0 -6
- package/dist/templates/hello-world/_gitignore +0 -8
- package/dist/templates/hello-world/app/components/Layout.tsx +0 -15
- package/dist/templates/hello-world/app/components/index.ts +0 -1
- package/dist/templates/hello-world/app/entry.client.tsx +0 -4
- package/dist/templates/hello-world/app/entry.server.tsx +0 -21
- package/dist/templates/hello-world/app/root.tsx +0 -212
- package/dist/templates/hello-world/app/routes/graphiql.tsx +0 -10
- package/dist/templates/hello-world/app/styles/app.css +0 -38
- package/dist/templates/hello-world/dist/client/build/_assets/app-NBPUE4H5.css +0 -1
- package/dist/templates/hello-world/dist/client/build/_assets/favicon-5FIZBM2K.svg +0 -28
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-MEPKJ2VW.js +0 -2
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-MEPKJ2VW.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-SYP5DAMV.js +0 -2
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-SYP5DAMV.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-UWGFS4PS.js +0 -31
- package/dist/templates/hello-world/dist/client/build/_shared/chunk-UWGFS4PS.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/entry.client-YKLPLTIJ.js +0 -9
- package/dist/templates/hello-world/dist/client/build/entry.client-YKLPLTIJ.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/manifest-5BEA23FF.js +0 -1
- package/dist/templates/hello-world/dist/client/build/root-YMCCM3GG.js +0 -2
- package/dist/templates/hello-world/dist/client/build/root-YMCCM3GG.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/routes/graphiql-ZHVT5SA7.js +0 -2
- package/dist/templates/hello-world/dist/client/build/routes/graphiql-ZHVT5SA7.js.map +0 -7
- package/dist/templates/hello-world/dist/client/build/routes/index-TH4MKESG.js +0 -2
- package/dist/templates/hello-world/dist/client/build/routes/index-TH4MKESG.js.map +0 -7
- package/dist/templates/hello-world/dist/client/favicon.svg +0 -28
- package/dist/templates/hello-world/dist/worker/index.js +0 -172
- package/dist/templates/hello-world/dist/worker/index.js.map +0 -7
- package/dist/templates/hello-world/package.json +0 -41
- package/dist/templates/hello-world/public/favicon.svg +0 -28
- package/dist/templates/hello-world/remix.env.d.ts +0 -35
- package/dist/templates/hello-world/remix.init/index.js +0 -25
- package/dist/templates/hello-world/remix.init/package.json +0 -7
- package/dist/templates/hello-world/server.ts +0 -129
- package/dist/templates/hello-world/tsconfig.json +0 -25
- package/dist/tmp-create-app.js +0 -33
|
@@ -1,492 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
type EnhancedMenu,
|
|
3
|
-
type EnhancedMenuItem,
|
|
4
|
-
useIsHomePath,
|
|
5
|
-
} from '~/lib/utils';
|
|
6
|
-
import {
|
|
7
|
-
Drawer,
|
|
8
|
-
useDrawer,
|
|
9
|
-
Text,
|
|
10
|
-
Input,
|
|
11
|
-
IconAccount,
|
|
12
|
-
IconBag,
|
|
13
|
-
IconSearch,
|
|
14
|
-
Heading,
|
|
15
|
-
IconMenu,
|
|
16
|
-
IconCaret,
|
|
17
|
-
Section,
|
|
18
|
-
CountrySelector,
|
|
19
|
-
Cart,
|
|
20
|
-
CartLoading,
|
|
21
|
-
Link,
|
|
22
|
-
} from '~/components';
|
|
23
|
-
import {useParams, Form, Await, useMatches} from '@remix-run/react';
|
|
24
|
-
import {useWindowScroll} from 'react-use';
|
|
25
|
-
import {Disclosure} from '@headlessui/react';
|
|
26
|
-
import type {LayoutData} from '~/data';
|
|
27
|
-
import {Suspense, useEffect, useMemo} from 'react';
|
|
28
|
-
import {useIsHydrated} from '~/hooks/useIsHydrated';
|
|
29
|
-
import {useCartFetchers} from '~/hooks/useCartFetchers';
|
|
30
|
-
|
|
31
|
-
export function Layout({
|
|
32
|
-
children,
|
|
33
|
-
layout,
|
|
34
|
-
}: {
|
|
35
|
-
children: React.ReactNode;
|
|
36
|
-
layout: LayoutData;
|
|
37
|
-
}) {
|
|
38
|
-
return (
|
|
39
|
-
<>
|
|
40
|
-
<div className="flex flex-col min-h-screen">
|
|
41
|
-
<div className="">
|
|
42
|
-
<a href="#mainContent" className="sr-only">
|
|
43
|
-
Skip to content
|
|
44
|
-
</a>
|
|
45
|
-
</div>
|
|
46
|
-
<Header
|
|
47
|
-
title={layout?.shop.name ?? 'Hydrogen'}
|
|
48
|
-
menu={layout?.headerMenu}
|
|
49
|
-
/>
|
|
50
|
-
<main role="main" id="mainContent" className="flex-grow">
|
|
51
|
-
{children}
|
|
52
|
-
</main>
|
|
53
|
-
</div>
|
|
54
|
-
<Footer menu={layout?.footerMenu} />
|
|
55
|
-
</>
|
|
56
|
-
);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
function Header({title, menu}: {title: string; menu?: EnhancedMenu}) {
|
|
60
|
-
const isHome = useIsHomePath();
|
|
61
|
-
|
|
62
|
-
const {
|
|
63
|
-
isOpen: isCartOpen,
|
|
64
|
-
openDrawer: openCart,
|
|
65
|
-
closeDrawer: closeCart,
|
|
66
|
-
} = useDrawer();
|
|
67
|
-
|
|
68
|
-
const {
|
|
69
|
-
isOpen: isMenuOpen,
|
|
70
|
-
openDrawer: openMenu,
|
|
71
|
-
closeDrawer: closeMenu,
|
|
72
|
-
} = useDrawer();
|
|
73
|
-
|
|
74
|
-
const addToCartFetchers = useCartFetchers('ADD_TO_CART');
|
|
75
|
-
|
|
76
|
-
// toggle cart drawer when adding to cart
|
|
77
|
-
useEffect(() => {
|
|
78
|
-
if (isCartOpen || !addToCartFetchers.length) return;
|
|
79
|
-
openCart();
|
|
80
|
-
}, [addToCartFetchers, isCartOpen, openCart]);
|
|
81
|
-
|
|
82
|
-
return (
|
|
83
|
-
<>
|
|
84
|
-
<CartDrawer isOpen={isCartOpen} onClose={closeCart} />
|
|
85
|
-
{menu && (
|
|
86
|
-
<MenuDrawer isOpen={isMenuOpen} onClose={closeMenu} menu={menu} />
|
|
87
|
-
)}
|
|
88
|
-
<DesktopHeader
|
|
89
|
-
isHome={isHome}
|
|
90
|
-
title={title}
|
|
91
|
-
menu={menu}
|
|
92
|
-
openCart={openCart}
|
|
93
|
-
/>
|
|
94
|
-
<MobileHeader
|
|
95
|
-
isHome={isHome}
|
|
96
|
-
title={title}
|
|
97
|
-
openCart={openCart}
|
|
98
|
-
openMenu={openMenu}
|
|
99
|
-
/>
|
|
100
|
-
</>
|
|
101
|
-
);
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
function CartDrawer({isOpen, onClose}: {isOpen: boolean; onClose: () => void}) {
|
|
105
|
-
const [root] = useMatches();
|
|
106
|
-
|
|
107
|
-
return (
|
|
108
|
-
<Drawer open={isOpen} onClose={onClose} heading="Cart" openFrom="right">
|
|
109
|
-
<div className="grid">
|
|
110
|
-
<Suspense fallback={<CartLoading />}>
|
|
111
|
-
<Await resolve={root.data?.cart}>
|
|
112
|
-
{(cart) => <Cart layout="drawer" onClose={onClose} cart={cart} />}
|
|
113
|
-
</Await>
|
|
114
|
-
</Suspense>
|
|
115
|
-
</div>
|
|
116
|
-
</Drawer>
|
|
117
|
-
);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
export function MenuDrawer({
|
|
121
|
-
isOpen,
|
|
122
|
-
onClose,
|
|
123
|
-
menu,
|
|
124
|
-
}: {
|
|
125
|
-
isOpen: boolean;
|
|
126
|
-
onClose: () => void;
|
|
127
|
-
menu: EnhancedMenu;
|
|
128
|
-
}) {
|
|
129
|
-
return (
|
|
130
|
-
<Drawer open={isOpen} onClose={onClose} openFrom="left" heading="Menu">
|
|
131
|
-
<div className="grid">
|
|
132
|
-
<MenuMobileNav menu={menu} onClose={onClose} />
|
|
133
|
-
</div>
|
|
134
|
-
</Drawer>
|
|
135
|
-
);
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
function MenuMobileNav({
|
|
139
|
-
menu,
|
|
140
|
-
onClose,
|
|
141
|
-
}: {
|
|
142
|
-
menu: EnhancedMenu;
|
|
143
|
-
onClose: () => void;
|
|
144
|
-
}) {
|
|
145
|
-
const styles = {
|
|
146
|
-
link: 'pb-1',
|
|
147
|
-
linkActive: 'pb-1 border-b -mb-px',
|
|
148
|
-
};
|
|
149
|
-
|
|
150
|
-
return (
|
|
151
|
-
<nav className="grid gap-4 p-6 sm:gap-6 sm:px-12 sm:py-8">
|
|
152
|
-
{/* Top level menu items */}
|
|
153
|
-
{(menu?.items || []).map((item) => (
|
|
154
|
-
<span key={item.id} className="block">
|
|
155
|
-
<Link
|
|
156
|
-
to={item.to}
|
|
157
|
-
target={item.target}
|
|
158
|
-
onClick={onClose}
|
|
159
|
-
className={({isActive}) =>
|
|
160
|
-
isActive ? styles.linkActive : styles.link
|
|
161
|
-
}
|
|
162
|
-
>
|
|
163
|
-
<Text as="span" size="copy">
|
|
164
|
-
{item.title}
|
|
165
|
-
</Text>
|
|
166
|
-
</Link>
|
|
167
|
-
</span>
|
|
168
|
-
))}
|
|
169
|
-
</nav>
|
|
170
|
-
);
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
function MobileHeader({
|
|
174
|
-
title,
|
|
175
|
-
isHome,
|
|
176
|
-
openCart,
|
|
177
|
-
openMenu,
|
|
178
|
-
}: {
|
|
179
|
-
title: string;
|
|
180
|
-
isHome: boolean;
|
|
181
|
-
openCart: () => void;
|
|
182
|
-
openMenu: () => void;
|
|
183
|
-
}) {
|
|
184
|
-
const {y} = useWindowScroll();
|
|
185
|
-
|
|
186
|
-
const styles = {
|
|
187
|
-
button: 'relative flex items-center justify-center w-8 h-8',
|
|
188
|
-
container: `${
|
|
189
|
-
isHome
|
|
190
|
-
? 'bg-primary/80 dark:bg-contrast/60 text-contrast dark:text-primary shadow-darkHeader'
|
|
191
|
-
: 'bg-contrast/80 text-primary'
|
|
192
|
-
} ${
|
|
193
|
-
y > 50 && !isHome ? 'shadow-lightHeader ' : ''
|
|
194
|
-
}flex lg:hidden items-center h-nav sticky backdrop-blur-lg z-40 top-0 justify-between w-full leading-none gap-4 px-4 md:px-8`,
|
|
195
|
-
};
|
|
196
|
-
const params = useParams();
|
|
197
|
-
|
|
198
|
-
return (
|
|
199
|
-
<header role="banner" className={styles.container}>
|
|
200
|
-
<div className="flex items-center justify-start w-full gap-4">
|
|
201
|
-
<button onClick={openMenu} className={styles.button}>
|
|
202
|
-
<IconMenu />
|
|
203
|
-
</button>
|
|
204
|
-
<Form
|
|
205
|
-
method="get"
|
|
206
|
-
action={params.lang ? `/${params.lang}/search` : '/search'}
|
|
207
|
-
className="items-center gap-2 sm:flex"
|
|
208
|
-
>
|
|
209
|
-
<button type="submit" className={styles.button}>
|
|
210
|
-
<IconSearch />
|
|
211
|
-
</button>
|
|
212
|
-
<Input
|
|
213
|
-
className={
|
|
214
|
-
isHome
|
|
215
|
-
? 'focus:border-contrast/20 dark:focus:border-primary/20'
|
|
216
|
-
: 'focus:border-primary/20'
|
|
217
|
-
}
|
|
218
|
-
type="search"
|
|
219
|
-
variant="minisearch"
|
|
220
|
-
placeholder="Search"
|
|
221
|
-
name="q"
|
|
222
|
-
/>
|
|
223
|
-
</Form>
|
|
224
|
-
</div>
|
|
225
|
-
|
|
226
|
-
<Link
|
|
227
|
-
className="flex items-center self-stretch leading-[3rem] md:leading-[4rem] justify-center flex-grow w-full h-full"
|
|
228
|
-
to="/"
|
|
229
|
-
>
|
|
230
|
-
<Heading className="font-bold text-center" as={isHome ? 'h1' : 'h2'}>
|
|
231
|
-
{title}
|
|
232
|
-
</Heading>
|
|
233
|
-
</Link>
|
|
234
|
-
|
|
235
|
-
<div className="flex items-center justify-end w-full gap-4">
|
|
236
|
-
<Link to="/account" className={styles.button}>
|
|
237
|
-
<IconAccount />
|
|
238
|
-
</Link>
|
|
239
|
-
<CartCount isHome={isHome} openCart={openCart} />
|
|
240
|
-
</div>
|
|
241
|
-
</header>
|
|
242
|
-
);
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
function DesktopHeader({
|
|
246
|
-
isHome,
|
|
247
|
-
menu,
|
|
248
|
-
openCart,
|
|
249
|
-
title,
|
|
250
|
-
}: {
|
|
251
|
-
isHome: boolean;
|
|
252
|
-
openCart: () => void;
|
|
253
|
-
menu?: EnhancedMenu;
|
|
254
|
-
title: string;
|
|
255
|
-
}) {
|
|
256
|
-
const {y} = useWindowScroll();
|
|
257
|
-
const params = useParams();
|
|
258
|
-
|
|
259
|
-
const styles = {
|
|
260
|
-
link: 'pb-1',
|
|
261
|
-
linkActive: 'pb-1 border-b -mb-px',
|
|
262
|
-
button:
|
|
263
|
-
'relative flex items-center justify-center w-8 h-8 focus:ring-primary/5',
|
|
264
|
-
container: `${
|
|
265
|
-
isHome
|
|
266
|
-
? 'bg-primary/80 dark:bg-contrast/60 text-contrast dark:text-primary shadow-darkHeader'
|
|
267
|
-
: 'bg-contrast/80 text-primary'
|
|
268
|
-
} ${
|
|
269
|
-
y > 50 && !isHome ? 'shadow-lightHeader ' : ''
|
|
270
|
-
}hidden h-nav lg:flex items-center sticky transition duration-300 backdrop-blur-lg z-40 top-0 justify-between w-full leading-none gap-8 px-12 py-8`,
|
|
271
|
-
};
|
|
272
|
-
|
|
273
|
-
return (
|
|
274
|
-
<header role="banner" className={styles.container}>
|
|
275
|
-
<div className="flex gap-12">
|
|
276
|
-
<Link className="font-bold" to="/" prefetch="intent">
|
|
277
|
-
{title}
|
|
278
|
-
</Link>
|
|
279
|
-
<nav className="flex gap-8">
|
|
280
|
-
{/* Top level menu items */}
|
|
281
|
-
{(menu?.items || []).map((item) => (
|
|
282
|
-
<Link
|
|
283
|
-
key={item.id}
|
|
284
|
-
to={item.to}
|
|
285
|
-
target={item.target}
|
|
286
|
-
prefetch="intent"
|
|
287
|
-
className={({isActive}) =>
|
|
288
|
-
isActive ? styles.linkActive : styles.link
|
|
289
|
-
}
|
|
290
|
-
>
|
|
291
|
-
{item.title}
|
|
292
|
-
</Link>
|
|
293
|
-
))}
|
|
294
|
-
</nav>
|
|
295
|
-
</div>
|
|
296
|
-
<div className="flex items-center gap-1">
|
|
297
|
-
<Form
|
|
298
|
-
method="get"
|
|
299
|
-
action={params.lang ? `/${params.lang}/search` : '/search'}
|
|
300
|
-
className="flex items-center gap-2"
|
|
301
|
-
>
|
|
302
|
-
<Input
|
|
303
|
-
className={
|
|
304
|
-
isHome
|
|
305
|
-
? 'focus:border-contrast/20 dark:focus:border-primary/20'
|
|
306
|
-
: 'focus:border-primary/20'
|
|
307
|
-
}
|
|
308
|
-
type="search"
|
|
309
|
-
variant="minisearch"
|
|
310
|
-
placeholder="Search"
|
|
311
|
-
name="q"
|
|
312
|
-
/>
|
|
313
|
-
<button type="submit" className={styles.button}>
|
|
314
|
-
<IconSearch />
|
|
315
|
-
</button>
|
|
316
|
-
</Form>
|
|
317
|
-
<Link to="/account" className={styles.button}>
|
|
318
|
-
<IconAccount />
|
|
319
|
-
</Link>
|
|
320
|
-
<CartCount isHome={isHome} openCart={openCart} />
|
|
321
|
-
</div>
|
|
322
|
-
</header>
|
|
323
|
-
);
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
function CartCount({
|
|
327
|
-
isHome,
|
|
328
|
-
openCart,
|
|
329
|
-
}: {
|
|
330
|
-
isHome: boolean;
|
|
331
|
-
openCart: () => void;
|
|
332
|
-
}) {
|
|
333
|
-
const [root] = useMatches();
|
|
334
|
-
|
|
335
|
-
return (
|
|
336
|
-
<Suspense fallback={<Badge count={0} dark={isHome} openCart={openCart} />}>
|
|
337
|
-
<Await resolve={root.data?.cart}>
|
|
338
|
-
{(cart) => (
|
|
339
|
-
<Badge
|
|
340
|
-
dark={isHome}
|
|
341
|
-
openCart={openCart}
|
|
342
|
-
count={cart?.totalQuantity || 0}
|
|
343
|
-
/>
|
|
344
|
-
)}
|
|
345
|
-
</Await>
|
|
346
|
-
</Suspense>
|
|
347
|
-
);
|
|
348
|
-
}
|
|
349
|
-
|
|
350
|
-
function Badge({
|
|
351
|
-
openCart,
|
|
352
|
-
dark,
|
|
353
|
-
count,
|
|
354
|
-
}: {
|
|
355
|
-
count: number;
|
|
356
|
-
dark: boolean;
|
|
357
|
-
openCart: () => void;
|
|
358
|
-
}) {
|
|
359
|
-
const isHydrated = useIsHydrated();
|
|
360
|
-
|
|
361
|
-
const BadgeCounter = useMemo(
|
|
362
|
-
() => (
|
|
363
|
-
<>
|
|
364
|
-
<IconBag />
|
|
365
|
-
<div
|
|
366
|
-
className={`${
|
|
367
|
-
dark
|
|
368
|
-
? 'text-primary bg-contrast dark:text-contrast dark:bg-primary'
|
|
369
|
-
: 'text-contrast bg-primary'
|
|
370
|
-
} absolute bottom-1 right-1 text-[0.625rem] font-medium subpixel-antialiased h-3 min-w-[0.75rem] flex items-center justify-center leading-none text-center rounded-full w-auto px-[0.125rem] pb-px`}
|
|
371
|
-
>
|
|
372
|
-
<span>{count || 0}</span>
|
|
373
|
-
</div>
|
|
374
|
-
</>
|
|
375
|
-
),
|
|
376
|
-
[count, dark],
|
|
377
|
-
);
|
|
378
|
-
|
|
379
|
-
return isHydrated ? (
|
|
380
|
-
<button
|
|
381
|
-
onClick={openCart}
|
|
382
|
-
className={
|
|
383
|
-
'relative flex items-center justify-center w-8 h-8 focus:ring-primary/5'
|
|
384
|
-
}
|
|
385
|
-
>
|
|
386
|
-
{BadgeCounter}
|
|
387
|
-
</button>
|
|
388
|
-
) : (
|
|
389
|
-
<Link
|
|
390
|
-
to="/cart"
|
|
391
|
-
className={
|
|
392
|
-
'relative flex items-center justify-center w-8 h-8 focus:ring-primary/5'
|
|
393
|
-
}
|
|
394
|
-
>
|
|
395
|
-
{BadgeCounter}
|
|
396
|
-
</Link>
|
|
397
|
-
);
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
function Footer({menu}: {menu?: EnhancedMenu}) {
|
|
401
|
-
const isHome = useIsHomePath();
|
|
402
|
-
const itemsCount = menu
|
|
403
|
-
? menu?.items?.length + 1 > 4
|
|
404
|
-
? 4
|
|
405
|
-
: menu?.items?.length + 1
|
|
406
|
-
: [];
|
|
407
|
-
|
|
408
|
-
return (
|
|
409
|
-
<Section
|
|
410
|
-
divider={isHome ? 'none' : 'top'}
|
|
411
|
-
as="footer"
|
|
412
|
-
role="contentinfo"
|
|
413
|
-
className={`grid min-h-[25rem] items-start grid-flow-row w-full gap-6 py-8 px-6 md:px-8 lg:px-12
|
|
414
|
-
border-b md:gap-8 lg:gap-12 grid-cols-1 md:grid-cols-2 lg:grid-cols-${itemsCount}
|
|
415
|
-
bg-primary dark:bg-contrast dark:text-primary text-contrast overflow-hidden`}
|
|
416
|
-
>
|
|
417
|
-
<FooterMenu menu={menu} />
|
|
418
|
-
<CountrySelector />
|
|
419
|
-
<div
|
|
420
|
-
className={`self-end pt-8 opacity-50 md:col-span-2 lg:col-span-${itemsCount}`}
|
|
421
|
-
>
|
|
422
|
-
© {new Date().getFullYear()} / Shopify, Inc. Hydrogen is an MIT
|
|
423
|
-
Licensed Open Source project. This website is carbon neutral.
|
|
424
|
-
</div>
|
|
425
|
-
</Section>
|
|
426
|
-
);
|
|
427
|
-
}
|
|
428
|
-
|
|
429
|
-
const FooterLink = ({item}: {item: EnhancedMenuItem}) => {
|
|
430
|
-
if (item.to.startsWith('http')) {
|
|
431
|
-
return (
|
|
432
|
-
<a href={item.to} target={item.target} rel="noopener noreferrer">
|
|
433
|
-
{item.title}
|
|
434
|
-
</a>
|
|
435
|
-
);
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
return (
|
|
439
|
-
<Link to={item.to} target={item.target} prefetch="intent">
|
|
440
|
-
{item.title}
|
|
441
|
-
</Link>
|
|
442
|
-
);
|
|
443
|
-
};
|
|
444
|
-
|
|
445
|
-
function FooterMenu({menu}: {menu?: EnhancedMenu}) {
|
|
446
|
-
const styles = {
|
|
447
|
-
section: 'grid gap-4',
|
|
448
|
-
nav: 'grid gap-2 pb-6',
|
|
449
|
-
};
|
|
450
|
-
|
|
451
|
-
return (
|
|
452
|
-
<>
|
|
453
|
-
{(menu?.items || []).map((item: EnhancedMenuItem) => (
|
|
454
|
-
<section key={item.id} className={styles.section}>
|
|
455
|
-
<Disclosure>
|
|
456
|
-
{({open}) => (
|
|
457
|
-
<>
|
|
458
|
-
<Disclosure.Button className="text-left md:cursor-default">
|
|
459
|
-
<Heading className="flex justify-between" size="lead" as="h3">
|
|
460
|
-
{item.title}
|
|
461
|
-
{item?.items?.length > 0 && (
|
|
462
|
-
<span className="md:hidden">
|
|
463
|
-
<IconCaret direction={open ? 'up' : 'down'} />
|
|
464
|
-
</span>
|
|
465
|
-
)}
|
|
466
|
-
</Heading>
|
|
467
|
-
</Disclosure.Button>
|
|
468
|
-
{item?.items?.length > 0 ? (
|
|
469
|
-
<div
|
|
470
|
-
className={`${
|
|
471
|
-
open ? `max-h-48 h-fit` : `max-h-0 md:max-h-fit`
|
|
472
|
-
} overflow-hidden transition-all duration-300`}
|
|
473
|
-
>
|
|
474
|
-
<Suspense data-comment="This suspense fixes a hydration bug in Disclosure.Panel with static prop">
|
|
475
|
-
<Disclosure.Panel static>
|
|
476
|
-
<nav className={styles.nav}>
|
|
477
|
-
{item.items.map((subItem) => (
|
|
478
|
-
<FooterLink key={subItem.id} item={subItem} />
|
|
479
|
-
))}
|
|
480
|
-
</nav>
|
|
481
|
-
</Disclosure.Panel>
|
|
482
|
-
</Suspense>
|
|
483
|
-
</div>
|
|
484
|
-
) : null}
|
|
485
|
-
</>
|
|
486
|
-
)}
|
|
487
|
-
</Disclosure>
|
|
488
|
-
</section>
|
|
489
|
-
))}{' '}
|
|
490
|
-
</>
|
|
491
|
-
);
|
|
492
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
Link as RemixLink,
|
|
3
|
-
NavLink as RemixNavLink,
|
|
4
|
-
type NavLinkProps as RemixNavLinkProps,
|
|
5
|
-
type LinkProps as RemixLinkProps,
|
|
6
|
-
useMatches,
|
|
7
|
-
} from '@remix-run/react';
|
|
8
|
-
|
|
9
|
-
type LinkProps = Omit<RemixLinkProps, 'className'> & {
|
|
10
|
-
className?: RemixNavLinkProps['className'] | RemixLinkProps['className'];
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* In our app, we've chosen to wrap Remix's `Link` component to add
|
|
15
|
-
* helper functionality. If the `to` value is a string (not object syntax),
|
|
16
|
-
* we prefix the locale to the path if there is one.
|
|
17
|
-
*
|
|
18
|
-
* You could implement the same behavior throughout your app using the
|
|
19
|
-
* Remix-native nested routes. However, your route and component structure
|
|
20
|
-
* changes the level of nesting required to get the locale into the route,
|
|
21
|
-
* which may not be ideal for shared components or layouts.
|
|
22
|
-
*
|
|
23
|
-
* Likewise, your internationalization strategy may not require a locale
|
|
24
|
-
* in the pathname and instead rely on a domain, cookie, or header.
|
|
25
|
-
*
|
|
26
|
-
* Ultimately, it is up to you to decide how to implement this behavior.
|
|
27
|
-
*/
|
|
28
|
-
export function Link(props: LinkProps) {
|
|
29
|
-
const {to, className, ...resOfProps} = props;
|
|
30
|
-
const [root] = useMatches();
|
|
31
|
-
const selectedLocale = root.data?.selectedLocale;
|
|
32
|
-
|
|
33
|
-
let toWithLocale = to;
|
|
34
|
-
|
|
35
|
-
if (typeof to === 'string') {
|
|
36
|
-
toWithLocale = selectedLocale ? `${selectedLocale.pathPrefix}${to}` : to;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
if (typeof className === 'function') {
|
|
40
|
-
return (
|
|
41
|
-
<RemixNavLink to={toWithLocale} className={className} {...resOfProps} />
|
|
42
|
-
);
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return <RemixLink to={toWithLocale} className={className} {...resOfProps} />;
|
|
46
|
-
}
|
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
import {IconClose, Link} from '~/components';
|
|
2
|
-
|
|
3
|
-
export function Modal({
|
|
4
|
-
children,
|
|
5
|
-
cancelLink,
|
|
6
|
-
}: {
|
|
7
|
-
children: React.ReactNode;
|
|
8
|
-
cancelLink: string;
|
|
9
|
-
}) {
|
|
10
|
-
return (
|
|
11
|
-
<div
|
|
12
|
-
className="relative z-50"
|
|
13
|
-
aria-labelledby="modal-title"
|
|
14
|
-
role="dialog"
|
|
15
|
-
aria-modal="true"
|
|
16
|
-
id="modal-bg"
|
|
17
|
-
>
|
|
18
|
-
<div className="fixed inset-0 transition-opacity bg-opacity-75 bg-primary/40"></div>
|
|
19
|
-
<div className="fixed inset-0 z-50 overflow-y-auto">
|
|
20
|
-
<div className="flex items-center justify-center min-h-full p-4 text-center sm:p-0">
|
|
21
|
-
<div
|
|
22
|
-
className="relative flex-1 px-4 pt-5 pb-4 overflow-hidden text-left transition-all transform rounded shadow-xl bg-contrast sm:my-12 sm:flex-none sm:w-full sm:max-w-sm sm:p-6"
|
|
23
|
-
role="button"
|
|
24
|
-
onClick={(e) => {
|
|
25
|
-
e.stopPropagation();
|
|
26
|
-
}}
|
|
27
|
-
onKeyPress={(e) => {
|
|
28
|
-
e.stopPropagation();
|
|
29
|
-
}}
|
|
30
|
-
tabIndex={0}
|
|
31
|
-
>
|
|
32
|
-
<div className="absolute top-0 right-0 hidden pt-4 pr-4 sm:block">
|
|
33
|
-
<Link
|
|
34
|
-
to={cancelLink}
|
|
35
|
-
className="p-4 -m-4 transition text-primary hover:text-primary/50"
|
|
36
|
-
>
|
|
37
|
-
<IconClose aria-label="Close panel" />
|
|
38
|
-
</Link>
|
|
39
|
-
</div>
|
|
40
|
-
{children}
|
|
41
|
-
</div>
|
|
42
|
-
</div>
|
|
43
|
-
</div>
|
|
44
|
-
</div>
|
|
45
|
-
);
|
|
46
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import {Button} from './Button';
|
|
2
|
-
import {FeaturedSection} from './FeaturedSection';
|
|
3
|
-
import {PageHeader, Text} from './Text';
|
|
4
|
-
|
|
5
|
-
export function NotFound({type = 'page'}: {type?: string}) {
|
|
6
|
-
const heading = `We’ve lost this ${type}`;
|
|
7
|
-
const description = `We couldn’t find the ${type} you’re looking for. Try checking the URL or heading back to the home page.`;
|
|
8
|
-
|
|
9
|
-
return (
|
|
10
|
-
<>
|
|
11
|
-
<PageHeader heading={heading}>
|
|
12
|
-
<Text width="narrow" as="p">
|
|
13
|
-
{description}
|
|
14
|
-
</Text>
|
|
15
|
-
<Button width="auto" variant="secondary" to={'/'}>
|
|
16
|
-
Take me to the home page
|
|
17
|
-
</Button>
|
|
18
|
-
</PageHeader>
|
|
19
|
-
<FeaturedSection />
|
|
20
|
-
</>
|
|
21
|
-
);
|
|
22
|
-
}
|
|
@@ -1,82 +0,0 @@
|
|
|
1
|
-
import {flattenConnection} from '@shopify/storefront-kit-react';
|
|
2
|
-
import type {Order} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
3
|
-
import {Heading, Text, Link} from '~/components';
|
|
4
|
-
import {statusMessage} from '~/lib/utils';
|
|
5
|
-
|
|
6
|
-
export function OrderCard({order}: {order: Order}) {
|
|
7
|
-
if (!order?.id) return null;
|
|
8
|
-
const [legacyOrderId, key] = order!.id!.split('/').pop()!.split('?');
|
|
9
|
-
const lineItems = flattenConnection(order?.lineItems);
|
|
10
|
-
|
|
11
|
-
return (
|
|
12
|
-
<li className="grid text-center border rounded">
|
|
13
|
-
<Link
|
|
14
|
-
className="grid items-center gap-4 p-4 md:gap-6 md:p-6 md:grid-cols-2"
|
|
15
|
-
to={`/account/orders/${legacyOrderId}?${key}`}
|
|
16
|
-
prefetch="intent"
|
|
17
|
-
>
|
|
18
|
-
{lineItems[0].variant?.image && (
|
|
19
|
-
<div className="card-image aspect-square bg-primary/5">
|
|
20
|
-
<img
|
|
21
|
-
width={168}
|
|
22
|
-
height={168}
|
|
23
|
-
className="w-full fadeIn cover"
|
|
24
|
-
alt={lineItems[0].variant?.image?.altText ?? 'Order image'}
|
|
25
|
-
src={lineItems[0].variant?.image.url}
|
|
26
|
-
/>
|
|
27
|
-
</div>
|
|
28
|
-
)}
|
|
29
|
-
<div
|
|
30
|
-
className={`flex-col justify-center text-left ${
|
|
31
|
-
!lineItems[0].variant?.image && 'md:col-span-2'
|
|
32
|
-
}`}
|
|
33
|
-
>
|
|
34
|
-
<Heading as="h3" format size="copy">
|
|
35
|
-
{lineItems.length > 1
|
|
36
|
-
? `${lineItems[0].title} +${lineItems.length - 1} more`
|
|
37
|
-
: lineItems[0].title}
|
|
38
|
-
</Heading>
|
|
39
|
-
<dl className="grid grid-gap-1">
|
|
40
|
-
<dt className="sr-only">Order ID</dt>
|
|
41
|
-
<dd>
|
|
42
|
-
<Text size="fine" color="subtle">
|
|
43
|
-
Order No. {order.orderNumber}
|
|
44
|
-
</Text>
|
|
45
|
-
</dd>
|
|
46
|
-
<dt className="sr-only">Order Date</dt>
|
|
47
|
-
<dd>
|
|
48
|
-
<Text size="fine" color="subtle">
|
|
49
|
-
{new Date(order.processedAt).toDateString()}
|
|
50
|
-
</Text>
|
|
51
|
-
</dd>
|
|
52
|
-
<dt className="sr-only">Fulfillment Status</dt>
|
|
53
|
-
<dd className="mt-2">
|
|
54
|
-
<span
|
|
55
|
-
className={`px-3 py-1 text-xs font-medium rounded-full ${
|
|
56
|
-
order.fulfillmentStatus === 'FULFILLED'
|
|
57
|
-
? 'bg-green-100 text-green-800'
|
|
58
|
-
: 'bg-primary/5 text-primary/50'
|
|
59
|
-
}`}
|
|
60
|
-
>
|
|
61
|
-
<Text size="fine">
|
|
62
|
-
{statusMessage(order.fulfillmentStatus)}
|
|
63
|
-
</Text>
|
|
64
|
-
</span>
|
|
65
|
-
</dd>
|
|
66
|
-
</dl>
|
|
67
|
-
</div>
|
|
68
|
-
</Link>
|
|
69
|
-
<div className="self-end border-t">
|
|
70
|
-
<Link
|
|
71
|
-
className="block w-full p-2 text-center"
|
|
72
|
-
to={`/account/orders/${legacyOrderId}?${key}`}
|
|
73
|
-
prefetch="intent"
|
|
74
|
-
>
|
|
75
|
-
<Text color="subtle" className="ml-3">
|
|
76
|
-
View Details
|
|
77
|
-
</Text>
|
|
78
|
-
</Link>
|
|
79
|
-
</div>
|
|
80
|
-
</li>
|
|
81
|
-
);
|
|
82
|
-
}
|