@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,300 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
json,
|
|
3
|
-
type MetaFunction,
|
|
4
|
-
type SerializeFrom,
|
|
5
|
-
type LoaderArgs,
|
|
6
|
-
} from '@shopify/remix-oxygen';
|
|
7
|
-
import {useLoaderData} from '@remix-run/react';
|
|
8
|
-
import type {
|
|
9
|
-
Collection as CollectionType,
|
|
10
|
-
CollectionConnection,
|
|
11
|
-
Filter,
|
|
12
|
-
} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
13
|
-
import {flattenConnection} from '@shopify/storefront-kit-react';
|
|
14
|
-
import invariant from 'tiny-invariant';
|
|
15
|
-
import {PageHeader, Section, Text, SortFilter, Breadcrumbs} from '~/components';
|
|
16
|
-
import {ProductGrid} from '~/components/ProductGrid';
|
|
17
|
-
|
|
18
|
-
import {PRODUCT_CARD_FRAGMENT} from '~/data';
|
|
19
|
-
|
|
20
|
-
const PAGINATION_SIZE = 48;
|
|
21
|
-
|
|
22
|
-
type VariantFilterParam = Record<string, string | boolean>;
|
|
23
|
-
type PriceFiltersQueryParam = Record<'price', {max?: number; min?: number}>;
|
|
24
|
-
type VariantOptionFiltersQueryParam = Record<
|
|
25
|
-
'variantOption',
|
|
26
|
-
{name: string; value: string}
|
|
27
|
-
>;
|
|
28
|
-
|
|
29
|
-
export type AppliedFilter = {
|
|
30
|
-
label: string;
|
|
31
|
-
urlParam: {
|
|
32
|
-
key: string;
|
|
33
|
-
value: string;
|
|
34
|
-
};
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
type FiltersQueryParams = Array<
|
|
38
|
-
VariantFilterParam | PriceFiltersQueryParam | VariantOptionFiltersQueryParam
|
|
39
|
-
>;
|
|
40
|
-
|
|
41
|
-
export type SortParam =
|
|
42
|
-
| 'price-low-high'
|
|
43
|
-
| 'price-high-low'
|
|
44
|
-
| 'best-selling'
|
|
45
|
-
| 'newest'
|
|
46
|
-
| 'featured';
|
|
47
|
-
|
|
48
|
-
export async function loader({params, request, context}: LoaderArgs) {
|
|
49
|
-
const {collectionHandle} = params;
|
|
50
|
-
|
|
51
|
-
invariant(collectionHandle, 'Missing collectionHandle param');
|
|
52
|
-
|
|
53
|
-
const searchParams = new URL(request.url).searchParams;
|
|
54
|
-
const knownFilters = ['cursor', 'productVendor', 'productType'];
|
|
55
|
-
const available = 'available';
|
|
56
|
-
const variantOption = 'variantOption';
|
|
57
|
-
const {sortKey, reverse} = getSortValuesFromParam(
|
|
58
|
-
searchParams.get('sort') as SortParam,
|
|
59
|
-
);
|
|
60
|
-
const filters: FiltersQueryParams = [];
|
|
61
|
-
const appliedFilters: AppliedFilter[] = [];
|
|
62
|
-
|
|
63
|
-
for (const [key, value] of searchParams.entries()) {
|
|
64
|
-
if (available === key) {
|
|
65
|
-
filters.push({available: value === 'true'});
|
|
66
|
-
appliedFilters.push({
|
|
67
|
-
label: value === 'true' ? 'In stock' : 'Out of stock',
|
|
68
|
-
urlParam: {
|
|
69
|
-
key: available,
|
|
70
|
-
value,
|
|
71
|
-
},
|
|
72
|
-
});
|
|
73
|
-
} else if (knownFilters.includes(key)) {
|
|
74
|
-
filters.push({[key]: value});
|
|
75
|
-
appliedFilters.push({label: value, urlParam: {key, value}});
|
|
76
|
-
} else if (key.includes(variantOption)) {
|
|
77
|
-
const [name, val] = value.split(':');
|
|
78
|
-
filters.push({variantOption: {name, value: val}});
|
|
79
|
-
appliedFilters.push({label: val, urlParam: {key, value}});
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
// Builds min and max price filter since we can't stack them separately into
|
|
84
|
-
// the filters array. See price filters limitations:
|
|
85
|
-
// https://shopify.dev/custom-storefronts/products-collections/filter-products#limitations
|
|
86
|
-
if (searchParams.has('minPrice') || searchParams.has('maxPrice')) {
|
|
87
|
-
const price: {min?: number; max?: number} = {};
|
|
88
|
-
if (searchParams.has('minPrice')) {
|
|
89
|
-
price.min = Number(searchParams.get('minPrice')) || 0;
|
|
90
|
-
appliedFilters.push({
|
|
91
|
-
label: `Min: $${price.min}`,
|
|
92
|
-
urlParam: {key: 'minPrice', value: searchParams.get('minPrice')!},
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
if (searchParams.has('maxPrice')) {
|
|
96
|
-
price.max = Number(searchParams.get('maxPrice')) || 0;
|
|
97
|
-
appliedFilters.push({
|
|
98
|
-
label: `Max: $${price.max}`,
|
|
99
|
-
urlParam: {key: 'maxPrice', value: searchParams.get('maxPrice')!},
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
filters.push({
|
|
103
|
-
price,
|
|
104
|
-
});
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
const {collection, collections} = await context.storefront.query<{
|
|
108
|
-
collection: CollectionType;
|
|
109
|
-
collections: CollectionConnection;
|
|
110
|
-
}>(COLLECTION_QUERY, {
|
|
111
|
-
variables: {
|
|
112
|
-
handle: collectionHandle,
|
|
113
|
-
pageBy: PAGINATION_SIZE,
|
|
114
|
-
filters,
|
|
115
|
-
sortKey,
|
|
116
|
-
reverse,
|
|
117
|
-
country: context.storefront.i18n.country,
|
|
118
|
-
language: context.storefront.i18n.language,
|
|
119
|
-
},
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
if (!collection) {
|
|
123
|
-
throw new Response(null, {status: 404});
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
const collectionNodes = flattenConnection(collections);
|
|
127
|
-
|
|
128
|
-
return json({collection, appliedFilters, collections: collectionNodes});
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
export const meta: MetaFunction = ({
|
|
132
|
-
data,
|
|
133
|
-
}: {
|
|
134
|
-
data: SerializeFrom<typeof loader> | undefined;
|
|
135
|
-
}) => {
|
|
136
|
-
return {
|
|
137
|
-
title: data?.collection?.seo?.title ?? 'Collection',
|
|
138
|
-
description: data?.collection?.seo?.description,
|
|
139
|
-
};
|
|
140
|
-
};
|
|
141
|
-
|
|
142
|
-
export default function Collection() {
|
|
143
|
-
const {collection, collections, appliedFilters} =
|
|
144
|
-
useLoaderData<typeof loader>();
|
|
145
|
-
const breadcrumbs =
|
|
146
|
-
collection.metafield?.references &&
|
|
147
|
-
flattenConnection(collection.metafield.references)
|
|
148
|
-
.reverse()
|
|
149
|
-
.reduce<any[]>((acc, collection) => [collection, ...acc], [collection]);
|
|
150
|
-
|
|
151
|
-
return (
|
|
152
|
-
<>
|
|
153
|
-
<PageHeader heading={collection.title}>
|
|
154
|
-
{collection?.description && (
|
|
155
|
-
<div className="flex items-baseline justify-between w-full">
|
|
156
|
-
<div>
|
|
157
|
-
<Text format width="narrow" as="p" className="inline-block">
|
|
158
|
-
{collection.description}
|
|
159
|
-
</Text>
|
|
160
|
-
</div>
|
|
161
|
-
</div>
|
|
162
|
-
)}
|
|
163
|
-
|
|
164
|
-
<Breadcrumbs breadcrumbs={breadcrumbs} />
|
|
165
|
-
</PageHeader>
|
|
166
|
-
<Section>
|
|
167
|
-
<SortFilter
|
|
168
|
-
filters={collection.products.filters as Filter[]}
|
|
169
|
-
appliedFilters={appliedFilters}
|
|
170
|
-
collections={collections as CollectionType[]}
|
|
171
|
-
>
|
|
172
|
-
<ProductGrid
|
|
173
|
-
key={collection.id}
|
|
174
|
-
collection={collection as CollectionType}
|
|
175
|
-
url={`/collections/${collection.handle}`}
|
|
176
|
-
data-test="product-grid"
|
|
177
|
-
/>
|
|
178
|
-
</SortFilter>
|
|
179
|
-
</Section>
|
|
180
|
-
</>
|
|
181
|
-
);
|
|
182
|
-
}
|
|
183
|
-
|
|
184
|
-
const COLLECTION_QUERY = `#graphql
|
|
185
|
-
${PRODUCT_CARD_FRAGMENT}
|
|
186
|
-
query CollectionDetails(
|
|
187
|
-
$handle: String!
|
|
188
|
-
$country: CountryCode
|
|
189
|
-
$language: LanguageCode
|
|
190
|
-
$pageBy: Int!
|
|
191
|
-
$cursor: String
|
|
192
|
-
$filters: [ProductFilter!]
|
|
193
|
-
$sortKey: ProductCollectionSortKeys!
|
|
194
|
-
$reverse: Boolean
|
|
195
|
-
) @inContext(country: $country, language: $language) {
|
|
196
|
-
collection(handle: $handle) {
|
|
197
|
-
id
|
|
198
|
-
handle
|
|
199
|
-
title
|
|
200
|
-
description
|
|
201
|
-
seo {
|
|
202
|
-
description
|
|
203
|
-
title
|
|
204
|
-
}
|
|
205
|
-
image {
|
|
206
|
-
id
|
|
207
|
-
url
|
|
208
|
-
width
|
|
209
|
-
height
|
|
210
|
-
altText
|
|
211
|
-
}
|
|
212
|
-
metafield(namespace: "breadcrumbs", key: "parents") {
|
|
213
|
-
id
|
|
214
|
-
value
|
|
215
|
-
references(first: 10) {
|
|
216
|
-
edges {
|
|
217
|
-
node {
|
|
218
|
-
... on Collection {
|
|
219
|
-
id
|
|
220
|
-
handle
|
|
221
|
-
title
|
|
222
|
-
}
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
namespace
|
|
227
|
-
key
|
|
228
|
-
}
|
|
229
|
-
products(
|
|
230
|
-
first: $pageBy,
|
|
231
|
-
after: $cursor,
|
|
232
|
-
filters: $filters,
|
|
233
|
-
sortKey: $sortKey,
|
|
234
|
-
reverse: $reverse
|
|
235
|
-
) {
|
|
236
|
-
filters {
|
|
237
|
-
id
|
|
238
|
-
label
|
|
239
|
-
type
|
|
240
|
-
values {
|
|
241
|
-
id
|
|
242
|
-
label
|
|
243
|
-
count
|
|
244
|
-
input
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
nodes {
|
|
248
|
-
...ProductCard
|
|
249
|
-
}
|
|
250
|
-
pageInfo {
|
|
251
|
-
hasNextPage
|
|
252
|
-
endCursor
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
collections(first: 100) {
|
|
257
|
-
edges {
|
|
258
|
-
node {
|
|
259
|
-
title
|
|
260
|
-
handle
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
`;
|
|
266
|
-
|
|
267
|
-
function getSortValuesFromParam(sortParam: SortParam | null) {
|
|
268
|
-
switch (sortParam) {
|
|
269
|
-
case 'price-high-low':
|
|
270
|
-
return {
|
|
271
|
-
sortKey: 'PRICE',
|
|
272
|
-
reverse: true,
|
|
273
|
-
};
|
|
274
|
-
case 'price-low-high':
|
|
275
|
-
return {
|
|
276
|
-
sortKey: 'PRICE',
|
|
277
|
-
reverse: false,
|
|
278
|
-
};
|
|
279
|
-
case 'best-selling':
|
|
280
|
-
return {
|
|
281
|
-
sortKey: 'BEST_SELLING',
|
|
282
|
-
reverse: false,
|
|
283
|
-
};
|
|
284
|
-
case 'newest':
|
|
285
|
-
return {
|
|
286
|
-
sortKey: 'CREATED',
|
|
287
|
-
reverse: true,
|
|
288
|
-
};
|
|
289
|
-
case 'featured':
|
|
290
|
-
return {
|
|
291
|
-
sortKey: 'MANUAL',
|
|
292
|
-
reverse: false,
|
|
293
|
-
};
|
|
294
|
-
default:
|
|
295
|
-
return {
|
|
296
|
-
sortKey: 'RELEVANCE',
|
|
297
|
-
reverse: false,
|
|
298
|
-
};
|
|
299
|
-
}
|
|
300
|
-
}
|
|
@@ -1,188 +0,0 @@
|
|
|
1
|
-
import {json, type MetaFunction, type LoaderArgs} from '@shopify/remix-oxygen';
|
|
2
|
-
import {useLoaderData} from '@remix-run/react';
|
|
3
|
-
import type {
|
|
4
|
-
Collection,
|
|
5
|
-
CollectionConnection,
|
|
6
|
-
} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
7
|
-
import {
|
|
8
|
-
Grid,
|
|
9
|
-
Heading,
|
|
10
|
-
PageHeader,
|
|
11
|
-
Section,
|
|
12
|
-
Link,
|
|
13
|
-
Pagination,
|
|
14
|
-
getPaginationVariables,
|
|
15
|
-
Button,
|
|
16
|
-
} from '~/components';
|
|
17
|
-
import {getImageLoadingPriority} from '~/lib/const';
|
|
18
|
-
|
|
19
|
-
const PAGINATION_SIZE = 8;
|
|
20
|
-
|
|
21
|
-
export const loader = async ({request, context: {storefront}}: LoaderArgs) => {
|
|
22
|
-
const variables = getPaginationVariables(request, PAGINATION_SIZE);
|
|
23
|
-
const {collections} = await storefront.query<{
|
|
24
|
-
collections: CollectionConnection;
|
|
25
|
-
}>(COLLECTIONS_QUERY, {
|
|
26
|
-
variables: {
|
|
27
|
-
...variables,
|
|
28
|
-
country: storefront.i18n.country,
|
|
29
|
-
language: storefront.i18n.language,
|
|
30
|
-
},
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
return json({collections});
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
export const meta: MetaFunction = () => {
|
|
37
|
-
return {
|
|
38
|
-
title: 'All Collections',
|
|
39
|
-
};
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
export default function Collections() {
|
|
43
|
-
const {collections} = useLoaderData<typeof loader>();
|
|
44
|
-
|
|
45
|
-
return (
|
|
46
|
-
<>
|
|
47
|
-
<PageHeader heading="Collections" />
|
|
48
|
-
<Section>
|
|
49
|
-
<Pagination connection={collections}>
|
|
50
|
-
{({
|
|
51
|
-
endCursor,
|
|
52
|
-
hasNextPage,
|
|
53
|
-
hasPreviousPage,
|
|
54
|
-
nextPageUrl,
|
|
55
|
-
nodes,
|
|
56
|
-
prevPageUrl,
|
|
57
|
-
startCursor,
|
|
58
|
-
nextLinkRef,
|
|
59
|
-
isLoading,
|
|
60
|
-
}) => (
|
|
61
|
-
<>
|
|
62
|
-
{hasPreviousPage && (
|
|
63
|
-
<div className="flex items-center justify-center mt-6">
|
|
64
|
-
<Button
|
|
65
|
-
to={prevPageUrl}
|
|
66
|
-
variant="secondary"
|
|
67
|
-
width="full"
|
|
68
|
-
prefetch="intent"
|
|
69
|
-
disabled={!isLoading}
|
|
70
|
-
state={{
|
|
71
|
-
pageInfo: {
|
|
72
|
-
endCursor,
|
|
73
|
-
hasNextPage,
|
|
74
|
-
startCursor,
|
|
75
|
-
},
|
|
76
|
-
nodes,
|
|
77
|
-
}}
|
|
78
|
-
>
|
|
79
|
-
{isLoading ? 'Loading...' : 'Previous products'}
|
|
80
|
-
</Button>
|
|
81
|
-
</div>
|
|
82
|
-
)}
|
|
83
|
-
<Grid
|
|
84
|
-
items={nodes.length === 3 ? 3 : 2}
|
|
85
|
-
data-test="collection-grid"
|
|
86
|
-
>
|
|
87
|
-
{nodes.map((collection, i) => (
|
|
88
|
-
<CollectionCard
|
|
89
|
-
collection={collection as Collection}
|
|
90
|
-
key={collection.id}
|
|
91
|
-
loading={getImageLoadingPriority(i, 2)}
|
|
92
|
-
/>
|
|
93
|
-
))}
|
|
94
|
-
</Grid>
|
|
95
|
-
{hasNextPage && (
|
|
96
|
-
<div className="flex items-center justify-center mt-6">
|
|
97
|
-
<Button
|
|
98
|
-
ref={nextLinkRef}
|
|
99
|
-
to={nextPageUrl}
|
|
100
|
-
variant="secondary"
|
|
101
|
-
width="full"
|
|
102
|
-
prefetch="intent"
|
|
103
|
-
disabled={!isLoading}
|
|
104
|
-
state={{
|
|
105
|
-
pageInfo: {
|
|
106
|
-
endCursor,
|
|
107
|
-
hasPreviousPage,
|
|
108
|
-
startCursor,
|
|
109
|
-
},
|
|
110
|
-
nodes,
|
|
111
|
-
}}
|
|
112
|
-
>
|
|
113
|
-
{isLoading ? 'Loading...' : 'Next products'}
|
|
114
|
-
</Button>
|
|
115
|
-
</div>
|
|
116
|
-
)}
|
|
117
|
-
</>
|
|
118
|
-
)}
|
|
119
|
-
</Pagination>
|
|
120
|
-
</Section>
|
|
121
|
-
</>
|
|
122
|
-
);
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
function CollectionCard({
|
|
126
|
-
collection,
|
|
127
|
-
loading,
|
|
128
|
-
}: {
|
|
129
|
-
collection: Collection;
|
|
130
|
-
loading?: HTMLImageElement['loading'];
|
|
131
|
-
}) {
|
|
132
|
-
return (
|
|
133
|
-
<Link to={`/collections/${collection.handle}`} className="grid gap-4">
|
|
134
|
-
<div className="card-image bg-primary/5 aspect-[3/2]">
|
|
135
|
-
{collection?.image && (
|
|
136
|
-
<img
|
|
137
|
-
alt={collection.title}
|
|
138
|
-
src={collection.image.url}
|
|
139
|
-
height={400}
|
|
140
|
-
sizes="(max-width: 32em) 100vw, 33vw"
|
|
141
|
-
width={600}
|
|
142
|
-
loading={loading}
|
|
143
|
-
/>
|
|
144
|
-
)}
|
|
145
|
-
</div>
|
|
146
|
-
<Heading as="h3" size="copy">
|
|
147
|
-
{collection.title}
|
|
148
|
-
</Heading>
|
|
149
|
-
</Link>
|
|
150
|
-
);
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
const COLLECTIONS_QUERY = `#graphql
|
|
154
|
-
query Collections(
|
|
155
|
-
$country: CountryCode
|
|
156
|
-
$language: LanguageCode
|
|
157
|
-
$first: Int
|
|
158
|
-
$last: Int
|
|
159
|
-
$startCursor: String
|
|
160
|
-
$endCursor: String
|
|
161
|
-
) @inContext(country: $country, language: $language) {
|
|
162
|
-
collections(first: $first, last: $last, before: $startCursor, after: $endCursor) {
|
|
163
|
-
nodes {
|
|
164
|
-
id
|
|
165
|
-
title
|
|
166
|
-
description
|
|
167
|
-
handle
|
|
168
|
-
seo {
|
|
169
|
-
description
|
|
170
|
-
title
|
|
171
|
-
}
|
|
172
|
-
image {
|
|
173
|
-
id
|
|
174
|
-
url
|
|
175
|
-
width
|
|
176
|
-
height
|
|
177
|
-
altText
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
pageInfo {
|
|
181
|
-
hasPreviousPage
|
|
182
|
-
hasNextPage
|
|
183
|
-
startCursor
|
|
184
|
-
endCursor
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
`;
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
import {redirect, type LoaderArgs} from '@shopify/remix-oxygen';
|
|
2
|
-
import {cartCreate, cartDiscountCodesUpdate} from './cart';
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Automatically applies a discount found on the url
|
|
6
|
-
* If a cart exists it's updated with the discount, otherwise a cart is created with the discount already applied
|
|
7
|
-
* @param ?redirect an optional path to return to otherwise return to the home page
|
|
8
|
-
* @example
|
|
9
|
-
* Example path applying a discount and redirecting
|
|
10
|
-
* ```ts
|
|
11
|
-
* /discounts/FREESHIPPING?redirect=/products
|
|
12
|
-
*
|
|
13
|
-
* ```
|
|
14
|
-
* @preserve
|
|
15
|
-
*/
|
|
16
|
-
export async function loader({request, context, params}: LoaderArgs) {
|
|
17
|
-
const {storefront} = context;
|
|
18
|
-
// N.B. This route will probably be removed in the future.
|
|
19
|
-
const session = context.session as any;
|
|
20
|
-
const {code} = params;
|
|
21
|
-
|
|
22
|
-
const url = new URL(request.url);
|
|
23
|
-
const searchParams = new URLSearchParams(url.search);
|
|
24
|
-
const redirectUrl =
|
|
25
|
-
searchParams.get('redirect') || searchParams.get('return_to') || '/';
|
|
26
|
-
|
|
27
|
-
const headers = new Headers();
|
|
28
|
-
|
|
29
|
-
if (!code) {
|
|
30
|
-
return redirect(redirectUrl);
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
let cartId = await session.get('cartId');
|
|
34
|
-
|
|
35
|
-
//! if no existing cart, create one
|
|
36
|
-
if (!cartId) {
|
|
37
|
-
const {cart, errors: graphqlCartErrors} = await cartCreate({
|
|
38
|
-
input: {},
|
|
39
|
-
storefront,
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
if (graphqlCartErrors?.length) {
|
|
43
|
-
return redirect(redirectUrl);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
//! cart created - we only need a Set-Cookie header if we're creating
|
|
47
|
-
cartId = cart.id;
|
|
48
|
-
session.set('cartId', cartId);
|
|
49
|
-
headers.set('Set-Cookie', await session.commit());
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
//! apply discount to the cart
|
|
53
|
-
await cartDiscountCodesUpdate({
|
|
54
|
-
cartId,
|
|
55
|
-
discountCodes: [code],
|
|
56
|
-
storefront,
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
return redirect(redirectUrl, {headers});
|
|
60
|
-
}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import {json, type LoaderArgs} from '@shopify/remix-oxygen';
|
|
2
|
-
import {flattenConnection} from '@shopify/storefront-kit-react';
|
|
3
|
-
import type {
|
|
4
|
-
CollectionConnection,
|
|
5
|
-
ProductConnection,
|
|
6
|
-
} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
7
|
-
import invariant from 'tiny-invariant';
|
|
8
|
-
import {PRODUCT_CARD_FRAGMENT} from '~/data';
|
|
9
|
-
|
|
10
|
-
export async function loader({context: {storefront}}: LoaderArgs) {
|
|
11
|
-
return json(await getFeaturedData(storefront));
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export async function getFeaturedData(
|
|
15
|
-
storefront: LoaderArgs['context']['storefront'],
|
|
16
|
-
) {
|
|
17
|
-
const data = await storefront.query<{
|
|
18
|
-
featuredCollections: CollectionConnection;
|
|
19
|
-
featuredProducts: ProductConnection;
|
|
20
|
-
}>(FEATURED_QUERY, {
|
|
21
|
-
variables: {
|
|
22
|
-
country: storefront.i18n.country,
|
|
23
|
-
language: storefront.i18n.language,
|
|
24
|
-
},
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
invariant(data, 'No data returned from Shopify API');
|
|
28
|
-
|
|
29
|
-
return {
|
|
30
|
-
featuredCollections: flattenConnection(data.featuredCollections),
|
|
31
|
-
featuredProducts: flattenConnection(data.featuredProducts),
|
|
32
|
-
};
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
const FEATURED_QUERY = `#graphql
|
|
36
|
-
${PRODUCT_CARD_FRAGMENT}
|
|
37
|
-
query homepage($country: CountryCode, $language: LanguageCode)
|
|
38
|
-
@inContext(country: $country, language: $language) {
|
|
39
|
-
featuredCollections: collections(first: 3, sortKey: UPDATED_AT) {
|
|
40
|
-
nodes {
|
|
41
|
-
id
|
|
42
|
-
title
|
|
43
|
-
handle
|
|
44
|
-
image {
|
|
45
|
-
altText
|
|
46
|
-
width
|
|
47
|
-
height
|
|
48
|
-
url
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
featuredProducts: products(first: 12) {
|
|
53
|
-
nodes {
|
|
54
|
-
...ProductCard
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
`;
|