@shopify/cli-hydrogen 4.0.0-alpha.9 → 4.0.0
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 +161 -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,97 +0,0 @@
|
|
|
1
|
-
import {Form} from '@remix-run/react';
|
|
2
|
-
import type {
|
|
3
|
-
Customer,
|
|
4
|
-
MailingAddress,
|
|
5
|
-
} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
6
|
-
import {Button, Link, Text} from '~/components';
|
|
7
|
-
|
|
8
|
-
export function AccountAddressBook({
|
|
9
|
-
customer,
|
|
10
|
-
addresses,
|
|
11
|
-
}: {
|
|
12
|
-
customer: Customer;
|
|
13
|
-
addresses: MailingAddress[];
|
|
14
|
-
}) {
|
|
15
|
-
return (
|
|
16
|
-
<>
|
|
17
|
-
<div className="grid w-full gap-4 p-4 py-6 md:gap-8 md:p-8 lg:p-12">
|
|
18
|
-
<h3 className="font-bold text-lead">Address Book</h3>
|
|
19
|
-
<div>
|
|
20
|
-
{!addresses?.length && (
|
|
21
|
-
<Text className="mb-1" width="narrow" as="p" size="copy">
|
|
22
|
-
You haven't saved any addresses yet.
|
|
23
|
-
</Text>
|
|
24
|
-
)}
|
|
25
|
-
<div className="w-48">
|
|
26
|
-
<Button
|
|
27
|
-
to="address/add"
|
|
28
|
-
className="mt-2 text-sm w-full mb-6"
|
|
29
|
-
variant="secondary"
|
|
30
|
-
>
|
|
31
|
-
Add an Address
|
|
32
|
-
</Button>
|
|
33
|
-
</div>
|
|
34
|
-
{Boolean(addresses?.length) && (
|
|
35
|
-
<div className="grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 gap-6">
|
|
36
|
-
{customer.defaultAddress && (
|
|
37
|
-
<Address address={customer.defaultAddress} defaultAddress />
|
|
38
|
-
)}
|
|
39
|
-
{addresses
|
|
40
|
-
.filter((address) => address.id !== customer.defaultAddress?.id)
|
|
41
|
-
.map((address) => (
|
|
42
|
-
<Address key={address.id} address={address} />
|
|
43
|
-
))}
|
|
44
|
-
</div>
|
|
45
|
-
)}
|
|
46
|
-
</div>
|
|
47
|
-
</div>
|
|
48
|
-
</>
|
|
49
|
-
);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
function Address({
|
|
53
|
-
address,
|
|
54
|
-
defaultAddress,
|
|
55
|
-
}: {
|
|
56
|
-
address: MailingAddress;
|
|
57
|
-
defaultAddress?: boolean;
|
|
58
|
-
}) {
|
|
59
|
-
return (
|
|
60
|
-
<div className="lg:p-8 p-6 border border-gray-200 rounded flex flex-col">
|
|
61
|
-
{defaultAddress && (
|
|
62
|
-
<div className="mb-3 flex flex-row">
|
|
63
|
-
<span className="px-3 py-1 text-xs font-medium rounded-full bg-primary/20 text-primary/50">
|
|
64
|
-
Default
|
|
65
|
-
</span>
|
|
66
|
-
</div>
|
|
67
|
-
)}
|
|
68
|
-
<ul className="flex-1 flex-row">
|
|
69
|
-
{(address.firstName || address.lastName) && (
|
|
70
|
-
<li>
|
|
71
|
-
{'' +
|
|
72
|
-
(address.firstName && address.firstName + ' ') +
|
|
73
|
-
address?.lastName}
|
|
74
|
-
</li>
|
|
75
|
-
)}
|
|
76
|
-
{address.formatted &&
|
|
77
|
-
address.formatted.map((line: string) => <li key={line}>{line}</li>)}
|
|
78
|
-
</ul>
|
|
79
|
-
|
|
80
|
-
<div className="flex flex-row font-medium mt-6">
|
|
81
|
-
<Link
|
|
82
|
-
to={`/account/address/${encodeURIComponent(address.id)}`}
|
|
83
|
-
className="text-left underline text-sm"
|
|
84
|
-
prefetch="intent"
|
|
85
|
-
>
|
|
86
|
-
Edit
|
|
87
|
-
</Link>
|
|
88
|
-
<Form action="address/delete" method="delete">
|
|
89
|
-
<input type="hidden" name="addressId" value={address.id} />
|
|
90
|
-
<button className="text-left text-primary/50 ml-6 text-sm">
|
|
91
|
-
Remove
|
|
92
|
-
</button>
|
|
93
|
-
</Form>
|
|
94
|
-
</div>
|
|
95
|
-
</div>
|
|
96
|
-
);
|
|
97
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import type {Customer} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
2
|
-
import {Link} from '~/components';
|
|
3
|
-
|
|
4
|
-
export function AccountDetails({customer}: {customer: Customer}) {
|
|
5
|
-
const {firstName, lastName, email, phone} = customer;
|
|
6
|
-
|
|
7
|
-
return (
|
|
8
|
-
<>
|
|
9
|
-
<div className="grid w-full gap-4 p-4 py-6 md:gap-8 md:p-8 lg:p-12">
|
|
10
|
-
<h3 className="font-bold text-lead">Account Details</h3>
|
|
11
|
-
<div className="lg:p-8 p-6 border border-gray-200 rounded">
|
|
12
|
-
<div className="flex">
|
|
13
|
-
<h3 className="font-bold text-base flex-1">Profile & Security</h3>
|
|
14
|
-
<Link
|
|
15
|
-
prefetch="intent"
|
|
16
|
-
className="underline text-sm font-normal"
|
|
17
|
-
to="/account/edit"
|
|
18
|
-
>
|
|
19
|
-
Edit
|
|
20
|
-
</Link>
|
|
21
|
-
</div>
|
|
22
|
-
<div className="mt-4 text-sm text-primary/50">Name</div>
|
|
23
|
-
<p className="mt-1">
|
|
24
|
-
{firstName || lastName
|
|
25
|
-
? (firstName ? firstName + ' ' : '') + lastName
|
|
26
|
-
: 'Add name'}{' '}
|
|
27
|
-
</p>
|
|
28
|
-
|
|
29
|
-
<div className="mt-4 text-sm text-primary/50">Contact</div>
|
|
30
|
-
<p className="mt-1">{phone ?? 'Add mobile'}</p>
|
|
31
|
-
|
|
32
|
-
<div className="mt-4 text-sm text-primary/50">Email address</div>
|
|
33
|
-
<p className="mt-1">{email}</p>
|
|
34
|
-
|
|
35
|
-
<div className="mt-4 text-sm text-primary/50">Password</div>
|
|
36
|
-
<p className="mt-1">**************</p>
|
|
37
|
-
</div>
|
|
38
|
-
</div>
|
|
39
|
-
</>
|
|
40
|
-
);
|
|
41
|
-
}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import type {CartLineInput} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
2
|
-
import {useFetcher, useMatches} from '@remix-run/react';
|
|
3
|
-
import {Button} from '~/components';
|
|
4
|
-
import {CartAction} from '~/lib/type';
|
|
5
|
-
|
|
6
|
-
export function AddToCartButton({
|
|
7
|
-
children,
|
|
8
|
-
lines,
|
|
9
|
-
className = '',
|
|
10
|
-
variant = 'primary',
|
|
11
|
-
width = 'full',
|
|
12
|
-
...props
|
|
13
|
-
}: {
|
|
14
|
-
children: React.ReactNode;
|
|
15
|
-
lines: CartLineInput[];
|
|
16
|
-
className?: string;
|
|
17
|
-
variant?: 'primary' | 'secondary' | 'inline';
|
|
18
|
-
width?: 'auto' | 'full';
|
|
19
|
-
[key: string]: any;
|
|
20
|
-
}) {
|
|
21
|
-
const [root] = useMatches();
|
|
22
|
-
const selectedLocale = root?.data?.selectedLocale;
|
|
23
|
-
const fetcher = useFetcher();
|
|
24
|
-
|
|
25
|
-
return (
|
|
26
|
-
<fetcher.Form action="/cart" method="post">
|
|
27
|
-
<input type="hidden" name="cartAction" value={CartAction.ADD_TO_CART} />
|
|
28
|
-
<input type="hidden" name="countryCode" value={selectedLocale.country} />
|
|
29
|
-
<input type="hidden" name="lines" value={JSON.stringify(lines)} />
|
|
30
|
-
<Button
|
|
31
|
-
as="button"
|
|
32
|
-
type="submit"
|
|
33
|
-
width={width}
|
|
34
|
-
variant={variant}
|
|
35
|
-
className={className}
|
|
36
|
-
{...props}
|
|
37
|
-
>
|
|
38
|
-
{children}
|
|
39
|
-
</Button>
|
|
40
|
-
</fetcher.Form>
|
|
41
|
-
);
|
|
42
|
-
}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import {Text} from './Text';
|
|
2
|
-
import {Link} from './Link';
|
|
3
|
-
|
|
4
|
-
interface Breadcrumb {
|
|
5
|
-
handle: string;
|
|
6
|
-
title: string;
|
|
7
|
-
id: string;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
// Renders a breadcrumb trail from a references metafield list
|
|
11
|
-
export function Breadcrumbs({
|
|
12
|
-
breadcrumbs,
|
|
13
|
-
}: {
|
|
14
|
-
breadcrumbs?: Breadcrumb[] | null;
|
|
15
|
-
}) {
|
|
16
|
-
if (!breadcrumbs || breadcrumbs.length === 0) {
|
|
17
|
-
return null;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
const breadcrumbsMarkup = breadcrumbs.map((breadcrumb, index) => {
|
|
21
|
-
const isLastBreadcrumb = index === breadcrumbs.length - 1;
|
|
22
|
-
|
|
23
|
-
return isLastBreadcrumb ? (
|
|
24
|
-
<Text key={breadcrumb.id} as="span">
|
|
25
|
-
{breadcrumb.title}
|
|
26
|
-
</Text>
|
|
27
|
-
) : (
|
|
28
|
-
<span key={breadcrumb.id}>
|
|
29
|
-
<Link to={`/collections/${breadcrumb.handle}`}>{breadcrumb.title}</Link>
|
|
30
|
-
<span className="px-2">/</span>
|
|
31
|
-
</span>
|
|
32
|
-
);
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
return <nav className="flex items-center">{breadcrumbsMarkup}</nav>;
|
|
36
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import {forwardRef} from 'react';
|
|
2
|
-
import {Link} from '@remix-run/react';
|
|
3
|
-
import clsx from 'clsx';
|
|
4
|
-
|
|
5
|
-
import {missingClass} from '~/lib/utils';
|
|
6
|
-
|
|
7
|
-
export const Button = forwardRef(
|
|
8
|
-
(
|
|
9
|
-
{
|
|
10
|
-
as = 'button',
|
|
11
|
-
className = '',
|
|
12
|
-
variant = 'primary',
|
|
13
|
-
width = 'auto',
|
|
14
|
-
...props
|
|
15
|
-
}: {
|
|
16
|
-
as?: React.ElementType;
|
|
17
|
-
className?: string;
|
|
18
|
-
variant?: 'primary' | 'secondary' | 'inline';
|
|
19
|
-
width?: 'auto' | 'full';
|
|
20
|
-
[key: string]: any;
|
|
21
|
-
},
|
|
22
|
-
ref,
|
|
23
|
-
) => {
|
|
24
|
-
const Component = props?.to ? Link : as;
|
|
25
|
-
|
|
26
|
-
const baseButtonClasses =
|
|
27
|
-
'inline-block rounded font-medium text-center py-3 px-6';
|
|
28
|
-
|
|
29
|
-
const variants = {
|
|
30
|
-
primary: `${baseButtonClasses} bg-primary text-contrast`,
|
|
31
|
-
secondary: `${baseButtonClasses} border border-primary/10 bg-contrast text-primary`,
|
|
32
|
-
inline: 'border-b border-primary/10 leading-none pb-1',
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
const widths = {
|
|
36
|
-
auto: 'w-auto',
|
|
37
|
-
full: 'w-full',
|
|
38
|
-
};
|
|
39
|
-
|
|
40
|
-
const styles = clsx(
|
|
41
|
-
missingClass(className, 'bg-') && variants[variant],
|
|
42
|
-
missingClass(className, 'w-') && widths[width],
|
|
43
|
-
className,
|
|
44
|
-
);
|
|
45
|
-
|
|
46
|
-
return (
|
|
47
|
-
<Component
|
|
48
|
-
// @todo: not supported until react-router makes it into Remix.
|
|
49
|
-
// preventScrollReset={true}
|
|
50
|
-
className={styles}
|
|
51
|
-
{...props}
|
|
52
|
-
ref={ref}
|
|
53
|
-
/>
|
|
54
|
-
);
|
|
55
|
-
},
|
|
56
|
-
);
|
|
@@ -1,431 +0,0 @@
|
|
|
1
|
-
import clsx from 'clsx';
|
|
2
|
-
import {useRef} from 'react';
|
|
3
|
-
import {useScroll} from 'react-use';
|
|
4
|
-
import {flattenConnection, Image, Money} from '@shopify/storefront-kit-react';
|
|
5
|
-
import {
|
|
6
|
-
Button,
|
|
7
|
-
Heading,
|
|
8
|
-
IconRemove,
|
|
9
|
-
Text,
|
|
10
|
-
Link,
|
|
11
|
-
FeaturedProducts,
|
|
12
|
-
} from '~/components';
|
|
13
|
-
import {getInputStyleClasses} from '~/lib/utils';
|
|
14
|
-
import type {
|
|
15
|
-
Cart as CartType,
|
|
16
|
-
CartCost,
|
|
17
|
-
CartLine,
|
|
18
|
-
CartLineUpdateInput,
|
|
19
|
-
} from '@shopify/storefront-kit-react/storefront-api-types';
|
|
20
|
-
import {useFetcher} from '@remix-run/react';
|
|
21
|
-
import {CartAction} from '~/lib/type';
|
|
22
|
-
|
|
23
|
-
type Layouts = 'page' | 'drawer';
|
|
24
|
-
|
|
25
|
-
export function Cart({
|
|
26
|
-
layout,
|
|
27
|
-
onClose,
|
|
28
|
-
cart,
|
|
29
|
-
}: {
|
|
30
|
-
layout: Layouts;
|
|
31
|
-
onClose?: () => void;
|
|
32
|
-
cart: CartType | null;
|
|
33
|
-
}) {
|
|
34
|
-
const linesCount = Boolean(cart?.lines?.edges?.length || 0);
|
|
35
|
-
|
|
36
|
-
return (
|
|
37
|
-
<>
|
|
38
|
-
<CartEmpty hidden={linesCount} onClose={onClose} layout={layout} />
|
|
39
|
-
<CartDetails cart={cart} layout={layout} />
|
|
40
|
-
</>
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
export function CartDetails({
|
|
45
|
-
layout,
|
|
46
|
-
cart,
|
|
47
|
-
}: {
|
|
48
|
-
layout: Layouts;
|
|
49
|
-
cart: CartType | null;
|
|
50
|
-
}) {
|
|
51
|
-
// @todo: get optimistic cart cost
|
|
52
|
-
const isZeroCost = !cart || cart?.cost?.subtotalAmount?.amount === '0.0';
|
|
53
|
-
|
|
54
|
-
const container = {
|
|
55
|
-
drawer: 'grid grid-cols-1 h-screen-no-nav grid-rows-[1fr_auto]',
|
|
56
|
-
page: 'w-full pb-12 grid md:grid-cols-2 md:items-start gap-8 md:gap-8 lg:gap-12',
|
|
57
|
-
};
|
|
58
|
-
|
|
59
|
-
return (
|
|
60
|
-
<div className={container[layout]}>
|
|
61
|
-
<CartLines lines={cart?.lines} layout={layout} />
|
|
62
|
-
{!isZeroCost && (
|
|
63
|
-
<CartSummary cost={cart.cost} layout={layout}>
|
|
64
|
-
<CartDiscounts discountCodes={cart.discountCodes} />
|
|
65
|
-
<CartCheckoutActions checkoutUrl={cart.checkoutUrl} />
|
|
66
|
-
</CartSummary>
|
|
67
|
-
)}
|
|
68
|
-
</div>
|
|
69
|
-
);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
/**
|
|
73
|
-
* Temporary discount UI
|
|
74
|
-
* @param discountCodes the current discount codes applied to the cart
|
|
75
|
-
* @todo rework when a design is ready
|
|
76
|
-
*/
|
|
77
|
-
function CartDiscounts({
|
|
78
|
-
discountCodes,
|
|
79
|
-
}: {
|
|
80
|
-
discountCodes: CartType['discountCodes'];
|
|
81
|
-
}) {
|
|
82
|
-
const codes = discountCodes?.map(({code}) => code).join(', ') || null;
|
|
83
|
-
|
|
84
|
-
return (
|
|
85
|
-
<>
|
|
86
|
-
{/* Have existing discount, display it with a remove option */}
|
|
87
|
-
<dl className={clsx(codes ? 'grid' : 'hidden')}>
|
|
88
|
-
<div className="flex items-center justify-between font-medium">
|
|
89
|
-
<Text as="dt">Discount(s)</Text>
|
|
90
|
-
<div className="flex items-center justify-between">
|
|
91
|
-
<UpdateDiscountForm>
|
|
92
|
-
<button>
|
|
93
|
-
<IconRemove
|
|
94
|
-
aria-hidden="true"
|
|
95
|
-
style={{height: 18, marginRight: 4}}
|
|
96
|
-
/>
|
|
97
|
-
</button>
|
|
98
|
-
</UpdateDiscountForm>
|
|
99
|
-
<Text as="dd">{codes}</Text>
|
|
100
|
-
</div>
|
|
101
|
-
</div>
|
|
102
|
-
</dl>
|
|
103
|
-
|
|
104
|
-
{/* No discounts, show an input to apply a discount */}
|
|
105
|
-
<UpdateDiscountForm>
|
|
106
|
-
<div
|
|
107
|
-
className={clsx(
|
|
108
|
-
codes ? 'hidden' : 'flex',
|
|
109
|
-
'items-center justify-between',
|
|
110
|
-
)}
|
|
111
|
-
>
|
|
112
|
-
<input
|
|
113
|
-
className={getInputStyleClasses()}
|
|
114
|
-
type="text"
|
|
115
|
-
name="discountCode"
|
|
116
|
-
/>
|
|
117
|
-
<button className="w-[150px] flex justify-end">
|
|
118
|
-
<Text size="fine">Apply Discount</Text>
|
|
119
|
-
</button>
|
|
120
|
-
</div>
|
|
121
|
-
</UpdateDiscountForm>
|
|
122
|
-
</>
|
|
123
|
-
);
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
function UpdateDiscountForm({children}: {children: React.ReactNode}) {
|
|
127
|
-
const fetcher = useFetcher();
|
|
128
|
-
return (
|
|
129
|
-
<fetcher.Form action="/cart" method="post">
|
|
130
|
-
<input
|
|
131
|
-
type="hidden"
|
|
132
|
-
name="cartAction"
|
|
133
|
-
value={CartAction.UPDATE_DISCOUNT}
|
|
134
|
-
/>
|
|
135
|
-
{children}
|
|
136
|
-
</fetcher.Form>
|
|
137
|
-
);
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
function CartLines({
|
|
141
|
-
layout = 'drawer',
|
|
142
|
-
lines: cartLines,
|
|
143
|
-
}: {
|
|
144
|
-
layout: Layouts;
|
|
145
|
-
lines: CartType['lines'] | undefined;
|
|
146
|
-
}) {
|
|
147
|
-
const currentLines = cartLines ? flattenConnection(cartLines) : [];
|
|
148
|
-
const scrollRef = useRef(null);
|
|
149
|
-
const {y} = useScroll(scrollRef);
|
|
150
|
-
|
|
151
|
-
const className = clsx([
|
|
152
|
-
y > 0 ? 'border-t' : '',
|
|
153
|
-
layout === 'page'
|
|
154
|
-
? 'flex-grow md:translate-y-4'
|
|
155
|
-
: 'px-6 pb-6 sm-max:pt-2 overflow-auto transition md:px-12',
|
|
156
|
-
]);
|
|
157
|
-
|
|
158
|
-
return (
|
|
159
|
-
<section
|
|
160
|
-
ref={scrollRef}
|
|
161
|
-
aria-labelledby="cart-contents"
|
|
162
|
-
className={className}
|
|
163
|
-
>
|
|
164
|
-
<ul className="grid gap-6 md:gap-10">
|
|
165
|
-
{currentLines.map((line) => (
|
|
166
|
-
<CartLineItem key={line.id} line={line as CartLine} />
|
|
167
|
-
))}
|
|
168
|
-
</ul>
|
|
169
|
-
</section>
|
|
170
|
-
);
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
function CartCheckoutActions({checkoutUrl}: {checkoutUrl: string}) {
|
|
174
|
-
if (!checkoutUrl) return null;
|
|
175
|
-
|
|
176
|
-
return (
|
|
177
|
-
<div className="flex flex-col mt-2">
|
|
178
|
-
<a href={checkoutUrl} target="_self">
|
|
179
|
-
<Button as="span" width="full">
|
|
180
|
-
Continue to Checkout
|
|
181
|
-
</Button>
|
|
182
|
-
</a>
|
|
183
|
-
{/* @todo: <CartShopPayButton cart={cart} /> */}
|
|
184
|
-
</div>
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
|
|
188
|
-
function CartSummary({
|
|
189
|
-
cost,
|
|
190
|
-
layout,
|
|
191
|
-
children = null,
|
|
192
|
-
}: {
|
|
193
|
-
children?: React.ReactNode;
|
|
194
|
-
cost: CartCost;
|
|
195
|
-
layout: Layouts;
|
|
196
|
-
}) {
|
|
197
|
-
const summary = {
|
|
198
|
-
drawer: 'grid gap-4 p-6 border-t md:px-12',
|
|
199
|
-
page: 'sticky top-nav grid gap-6 p-4 md:px-6 md:translate-y-4 bg-primary/5 rounded w-full',
|
|
200
|
-
};
|
|
201
|
-
|
|
202
|
-
return (
|
|
203
|
-
<section aria-labelledby="summary-heading" className={summary[layout]}>
|
|
204
|
-
<h2 id="summary-heading" className="sr-only">
|
|
205
|
-
Order summary
|
|
206
|
-
</h2>
|
|
207
|
-
<dl className="grid">
|
|
208
|
-
<div className="flex items-center justify-between font-medium">
|
|
209
|
-
<Text as="dt">Subtotal</Text>
|
|
210
|
-
<Text as="dd" data-test="subtotal">
|
|
211
|
-
{cost?.subtotalAmount?.amount ? (
|
|
212
|
-
<Money data={cost?.subtotalAmount} />
|
|
213
|
-
) : (
|
|
214
|
-
'-'
|
|
215
|
-
)}
|
|
216
|
-
</Text>
|
|
217
|
-
</div>
|
|
218
|
-
</dl>
|
|
219
|
-
{children}
|
|
220
|
-
</section>
|
|
221
|
-
);
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
function CartLineItem({line}: {line: CartLine}) {
|
|
225
|
-
if (!line?.id) return null;
|
|
226
|
-
|
|
227
|
-
const {id, quantity, merchandise} = line;
|
|
228
|
-
|
|
229
|
-
if (typeof quantity === 'undefined' || !merchandise?.product) return null;
|
|
230
|
-
|
|
231
|
-
return (
|
|
232
|
-
<li key={id} className="flex gap-4">
|
|
233
|
-
<div className="flex-shrink">
|
|
234
|
-
{merchandise.image && (
|
|
235
|
-
<Image
|
|
236
|
-
width={220}
|
|
237
|
-
height={220}
|
|
238
|
-
data={merchandise.image}
|
|
239
|
-
className="object-cover object-center w-24 h-24 border rounded md:w-28 md:h-28"
|
|
240
|
-
alt={merchandise.title}
|
|
241
|
-
/>
|
|
242
|
-
)}
|
|
243
|
-
</div>
|
|
244
|
-
|
|
245
|
-
<div className="flex justify-between flex-grow">
|
|
246
|
-
<div className="grid gap-2">
|
|
247
|
-
<Heading as="h3" size="copy">
|
|
248
|
-
{merchandise?.product?.handle ? (
|
|
249
|
-
<Link to={`/products/${merchandise.product.handle}`}>
|
|
250
|
-
{merchandise?.product?.title || ''}
|
|
251
|
-
</Link>
|
|
252
|
-
) : (
|
|
253
|
-
<Text>{merchandise?.product?.title || ''}</Text>
|
|
254
|
-
)}
|
|
255
|
-
</Heading>
|
|
256
|
-
|
|
257
|
-
<div className="grid pb-2">
|
|
258
|
-
{(merchandise?.selectedOptions || []).map((option) => (
|
|
259
|
-
<Text color="subtle" key={option.name}>
|
|
260
|
-
{option.name}: {option.value}
|
|
261
|
-
</Text>
|
|
262
|
-
))}
|
|
263
|
-
</div>
|
|
264
|
-
|
|
265
|
-
<div className="flex items-center gap-2">
|
|
266
|
-
<div className="flex justify-start text-copy">
|
|
267
|
-
<CartLineQuantityAdjust line={line} />
|
|
268
|
-
</div>
|
|
269
|
-
<ItemRemoveButton lineIds={[id]} />
|
|
270
|
-
</div>
|
|
271
|
-
</div>
|
|
272
|
-
<Text>
|
|
273
|
-
<CartLinePrice line={line} as="span" />
|
|
274
|
-
</Text>
|
|
275
|
-
</div>
|
|
276
|
-
</li>
|
|
277
|
-
);
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
function ItemRemoveButton({lineIds}: {lineIds: CartLine['id'][]}) {
|
|
281
|
-
const fetcher = useFetcher();
|
|
282
|
-
|
|
283
|
-
return (
|
|
284
|
-
<fetcher.Form action="/cart" method="post">
|
|
285
|
-
<input
|
|
286
|
-
type="hidden"
|
|
287
|
-
name="cartAction"
|
|
288
|
-
value={CartAction.REMOVE_FROM_CART}
|
|
289
|
-
/>
|
|
290
|
-
<input type="hidden" name="linesIds" value={JSON.stringify(lineIds)} />
|
|
291
|
-
<button
|
|
292
|
-
className="flex items-center justify-center w-10 h-10 border rounded"
|
|
293
|
-
type="submit"
|
|
294
|
-
>
|
|
295
|
-
<span className="sr-only">Remove</span>
|
|
296
|
-
<IconRemove aria-hidden="true" />
|
|
297
|
-
</button>
|
|
298
|
-
</fetcher.Form>
|
|
299
|
-
);
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
function CartLineQuantityAdjust({line}: {line: CartLine}) {
|
|
303
|
-
if (!line || typeof line?.quantity === 'undefined') return null;
|
|
304
|
-
const {id: lineId, quantity} = line;
|
|
305
|
-
const prevQuantity = Number(Math.max(0, quantity - 1).toFixed(0));
|
|
306
|
-
const nextQuantity = Number((quantity + 1).toFixed(0));
|
|
307
|
-
|
|
308
|
-
return (
|
|
309
|
-
<>
|
|
310
|
-
<label htmlFor={`quantity-${lineId}`} className="sr-only">
|
|
311
|
-
Quantity, {quantity}
|
|
312
|
-
</label>
|
|
313
|
-
<div className="flex items-center border rounded">
|
|
314
|
-
<UpdateCartButton lines={[{id: lineId, quantity: prevQuantity}]}>
|
|
315
|
-
<button
|
|
316
|
-
name="decrease-quantity"
|
|
317
|
-
aria-label="Decrease quantity"
|
|
318
|
-
className="w-10 h-10 transition text-primary/50 hover:text-primary disabled:text-primary/10"
|
|
319
|
-
value={prevQuantity}
|
|
320
|
-
disabled={quantity <= 1}
|
|
321
|
-
>
|
|
322
|
-
<span>−</span>
|
|
323
|
-
</button>
|
|
324
|
-
</UpdateCartButton>
|
|
325
|
-
|
|
326
|
-
<div className="px-2 text-center" data-test="item-quantity">
|
|
327
|
-
{quantity}
|
|
328
|
-
</div>
|
|
329
|
-
|
|
330
|
-
<UpdateCartButton lines={[{id: lineId, quantity: nextQuantity}]}>
|
|
331
|
-
<button
|
|
332
|
-
className="w-10 h-10 transition text-primary/50 hover:text-primary"
|
|
333
|
-
name="increase-quantity"
|
|
334
|
-
value={nextQuantity}
|
|
335
|
-
aria-label="Increase quantity"
|
|
336
|
-
>
|
|
337
|
-
<span>+</span>
|
|
338
|
-
</button>
|
|
339
|
-
</UpdateCartButton>
|
|
340
|
-
</div>
|
|
341
|
-
</>
|
|
342
|
-
);
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
function UpdateCartButton({
|
|
346
|
-
children,
|
|
347
|
-
lines,
|
|
348
|
-
}: {
|
|
349
|
-
children: React.ReactNode;
|
|
350
|
-
lines: CartLineUpdateInput[];
|
|
351
|
-
}) {
|
|
352
|
-
const fetcher = useFetcher();
|
|
353
|
-
|
|
354
|
-
return (
|
|
355
|
-
<fetcher.Form action="/cart" method="post">
|
|
356
|
-
<input type="hidden" name="cartAction" value={CartAction.UPDATE_CART} />
|
|
357
|
-
<input type="hidden" name="lines" value={JSON.stringify(lines)} />
|
|
358
|
-
{children}
|
|
359
|
-
</fetcher.Form>
|
|
360
|
-
);
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
function CartLinePrice({
|
|
364
|
-
line,
|
|
365
|
-
priceType = 'regular',
|
|
366
|
-
...passthroughProps
|
|
367
|
-
}: {
|
|
368
|
-
line: CartLine;
|
|
369
|
-
priceType?: 'regular' | 'compareAt';
|
|
370
|
-
[key: string]: any;
|
|
371
|
-
}) {
|
|
372
|
-
if (!line?.cost?.amountPerQuantity || !line?.cost?.totalAmount) return null;
|
|
373
|
-
|
|
374
|
-
const moneyV2 =
|
|
375
|
-
priceType === 'regular'
|
|
376
|
-
? line.cost.totalAmount
|
|
377
|
-
: line.cost.compareAtAmountPerQuantity;
|
|
378
|
-
|
|
379
|
-
if (moneyV2 == null) {
|
|
380
|
-
return null;
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
return <Money withoutTrailingZeros {...passthroughProps} data={moneyV2} />;
|
|
384
|
-
}
|
|
385
|
-
|
|
386
|
-
export function CartEmpty({
|
|
387
|
-
hidden = false,
|
|
388
|
-
layout = 'drawer',
|
|
389
|
-
onClose,
|
|
390
|
-
}: {
|
|
391
|
-
hidden: boolean;
|
|
392
|
-
layout?: Layouts;
|
|
393
|
-
onClose?: () => void;
|
|
394
|
-
}) {
|
|
395
|
-
const scrollRef = useRef(null);
|
|
396
|
-
const {y} = useScroll(scrollRef);
|
|
397
|
-
|
|
398
|
-
const container = {
|
|
399
|
-
drawer: clsx([
|
|
400
|
-
'content-start gap-4 px-6 pb-8 transition overflow-y-scroll md:gap-12 md:px-12 h-screen-no-nav md:pb-12',
|
|
401
|
-
y > 0 ? 'border-t' : '',
|
|
402
|
-
]),
|
|
403
|
-
page: clsx([
|
|
404
|
-
hidden ? '' : 'grid',
|
|
405
|
-
`pb-12 w-full md:items-start gap-4 md:gap-8 lg:gap-12`,
|
|
406
|
-
]),
|
|
407
|
-
};
|
|
408
|
-
|
|
409
|
-
return (
|
|
410
|
-
<div ref={scrollRef} className={container[layout]} hidden={hidden}>
|
|
411
|
-
<section className="grid gap-6">
|
|
412
|
-
<Text format>
|
|
413
|
-
Looks like you haven’t added anything yet, let’s get you
|
|
414
|
-
started!
|
|
415
|
-
</Text>
|
|
416
|
-
<div>
|
|
417
|
-
<Button onClick={onClose}>Continue shopping</Button>
|
|
418
|
-
</div>
|
|
419
|
-
</section>
|
|
420
|
-
<section className="grid gap-8 pt-4">
|
|
421
|
-
<FeaturedProducts
|
|
422
|
-
count={4}
|
|
423
|
-
heading="Shop Best Sellers"
|
|
424
|
-
layout={layout}
|
|
425
|
-
onClose={onClose}
|
|
426
|
-
sortKey="BEST_SELLING"
|
|
427
|
-
/>
|
|
428
|
-
</section>
|
|
429
|
-
</div>
|
|
430
|
-
);
|
|
431
|
-
}
|