@akinon/projectzero 2.0.0-beta.2 → 2.0.0-beta.21

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.
Files changed (300) hide show
  1. package/CHANGELOG.md +155 -6
  2. package/app-template/.env.example +8 -0
  3. package/app-template/.github/instructions/account.instructions.md +749 -0
  4. package/app-template/.github/instructions/checkout.instructions.md +678 -0
  5. package/app-template/.github/instructions/default.instructions.md +279 -0
  6. package/app-template/.github/instructions/edge-cases.instructions.md +73 -0
  7. package/app-template/.github/instructions/routing.instructions.md +603 -0
  8. package/app-template/.github/instructions/settings.instructions.md +338 -0
  9. package/app-template/.gitignore +5 -0
  10. package/app-template/AGENTS.md +7 -0
  11. package/app-template/CHANGELOG.md +1783 -61
  12. package/app-template/Procfile +1 -1
  13. package/app-template/README.md +6 -0
  14. package/app-template/akinon.json +1 -4
  15. package/app-template/build.sh +10 -0
  16. package/app-template/config/prebuild-tests.json +5 -0
  17. package/app-template/docs/advanced-usage.md +111 -0
  18. package/app-template/docs/plugins.md +60 -25
  19. package/app-template/docs/sentry-usage.md +35 -0
  20. package/app-template/jest.config.ts +2 -2
  21. package/app-template/next-env.d.ts +1 -0
  22. package/app-template/next.config.mjs +8 -6
  23. package/app-template/package.json +61 -50
  24. package/app-template/postcss.config.mjs +5 -0
  25. package/app-template/public/amex.svg +12 -0
  26. package/app-template/public/apple-pay.svg +16 -0
  27. package/app-template/public/assets/images/product-placeholder-1.jpg +0 -0
  28. package/app-template/public/assets/images/product-placeholder-2.jpg +0 -0
  29. package/app-template/public/assets/images/product-placeholder-3.jpg +0 -0
  30. package/app-template/public/assets/images/product-placeholder-4.jpg +0 -0
  31. package/app-template/public/google-pay.svg +16 -0
  32. package/app-template/public/locales/en/account.json +13 -4
  33. package/app-template/public/locales/en/auth.json +6 -7
  34. package/app-template/public/locales/en/basket.json +6 -6
  35. package/app-template/public/locales/en/blog.json +7 -0
  36. package/app-template/public/locales/en/category.json +3 -1
  37. package/app-template/public/locales/en/checkout.json +17 -4
  38. package/app-template/public/locales/en/common.json +71 -3
  39. package/app-template/public/locales/en/forgot_password.json +6 -7
  40. package/app-template/public/locales/en/product.json +84 -4
  41. package/app-template/public/locales/tr/account.json +13 -4
  42. package/app-template/public/locales/tr/auth.json +16 -17
  43. package/app-template/public/locales/tr/basket.json +4 -4
  44. package/app-template/public/locales/tr/blog.json +7 -0
  45. package/app-template/public/locales/tr/category.json +3 -1
  46. package/app-template/public/locales/tr/checkout.json +48 -36
  47. package/app-template/public/locales/tr/common.json +70 -2
  48. package/app-template/public/locales/tr/forgot_password.json +12 -13
  49. package/app-template/public/locales/tr/product.json +82 -0
  50. package/app-template/public/logo.svg +3 -27
  51. package/app-template/public/mastercard.svg +14 -0
  52. package/app-template/public/masterpass-javascript-sdk-web.min.js +1 -0
  53. package/app-template/public/promotion-banner.jpg +0 -0
  54. package/app-template/public/shop-pay.svg +12 -0
  55. package/app-template/public/visa.svg +12 -0
  56. package/app-template/src/__tests__/middleware-matcher.test.ts +135 -0
  57. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/[...prettyurl]/page.tsx +11 -11
  58. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/layout.tsx +4 -3
  59. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/orders/[id]/cancellation/page.tsx +105 -13
  60. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/orders/[id]/page.tsx +136 -52
  61. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/profile/page.tsx +2 -2
  62. package/app-template/src/app/[pz]/blog/[slug]/page.tsx +120 -0
  63. package/app-template/src/app/[pz]/category/[pk]/page.tsx +37 -0
  64. package/app-template/src/app/[pz]/error.tsx +17 -0
  65. package/app-template/src/app/[pz]/flat-page/[pk]/page.tsx +23 -0
  66. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/forms/[pk]/generate/page.tsx +1 -2
  67. package/app-template/src/app/[pz]/group-product/[pk]/page.tsx +93 -0
  68. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/landing-page/[pk]/page.tsx +2 -4
  69. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/layout.tsx +6 -11
  70. package/app-template/src/app/[pz]/list/page.tsx +26 -0
  71. package/app-template/src/app/{[commerce]/[locale]/[currency]/pz-not-found/page.tsx → [pz]/not-found.tsx} +5 -7
  72. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/orders/checkout/page.tsx +7 -4
  73. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/orders/completed/[token]/page.tsx +6 -4
  74. package/app-template/src/app/[pz]/page.tsx +28 -0
  75. package/app-template/src/app/[pz]/pages/[slug]/page.tsx +19 -0
  76. package/app-template/src/app/[pz]/product/[pk]/page.tsx +102 -0
  77. package/app-template/src/app/[pz]/special-page/[pk]/page.tsx +35 -0
  78. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/users/email-set-primary/[[...id]]/page.tsx +3 -4
  79. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/users/registration/account-confirm-email/[[...id]]/page.tsx +3 -3
  80. package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/users/reset/[[...id]]/page.tsx +41 -5
  81. package/app-template/src/app/[pz]/xml-sitemap/[node]/route.ts +73 -0
  82. package/app-template/src/app/api/auth/[...nextauth]/route.ts +3 -0
  83. package/app-template/src/app/api/barcode-search/route.ts +1 -0
  84. package/app-template/src/app/api/cache/route.ts +1 -1
  85. package/app-template/src/app/api/form/[...id]/route.ts +1 -7
  86. package/app-template/src/app/api/image-proxy/route.ts +1 -0
  87. package/app-template/src/app/api/logout/route.ts +1 -1
  88. package/app-template/src/app/api/product-categories/route.ts +1 -0
  89. package/app-template/src/app/api/similar-product-list/route.ts +1 -0
  90. package/app-template/src/app/api/similar-products/route.ts +1 -0
  91. package/app-template/src/app/api/theme-settings/route.ts +12 -0
  92. package/app-template/src/app/api/virtual-try-on/limited-categories/route.ts +1 -0
  93. package/app-template/src/app/api/virtual-try-on/route.ts +1 -0
  94. package/app-template/src/app/api/web-vitals/route.ts +1 -1
  95. package/app-template/src/assets/fonts/pz-icon.css +211 -49
  96. package/app-template/src/assets/fonts/pz-icon.eot +0 -0
  97. package/app-template/src/assets/fonts/pz-icon.html +486 -0
  98. package/app-template/src/assets/fonts/pz-icon.scss +373 -49
  99. package/app-template/src/assets/fonts/pz-icon.svg +215 -53
  100. package/app-template/src/assets/fonts/pz-icon.ttf +0 -0
  101. package/app-template/src/assets/fonts/pz-icon.woff +0 -0
  102. package/app-template/src/assets/fonts/pz-icon.woff2 +0 -0
  103. package/app-template/src/assets/globals.scss +37 -34
  104. package/app-template/src/assets/icons/arrow-right.svg +3 -0
  105. package/app-template/src/assets/icons/cart.svg +4 -12
  106. package/app-template/src/assets/icons/check.svg +2 -18
  107. package/app-template/src/assets/icons/chevron-down.svg +2 -7
  108. package/app-template/src/assets/icons/delete.svg +3 -0
  109. package/app-template/src/assets/icons/facebook.svg +2 -8
  110. package/app-template/src/assets/icons/fav-off.svg +5 -0
  111. package/app-template/src/assets/icons/fav-on.svg +5 -0
  112. package/app-template/src/assets/icons/filter-and-sort.svg +3 -0
  113. package/app-template/src/assets/icons/heart.svg +3 -0
  114. package/app-template/src/assets/icons/instagram.svg +2 -13
  115. package/app-template/src/assets/icons/materials.svg +3 -0
  116. package/app-template/src/assets/icons/person.svg +4 -0
  117. package/app-template/src/assets/icons/pinterest.svg +5 -11
  118. package/app-template/src/assets/icons/ruler.svg +3 -0
  119. package/app-template/src/assets/icons/search.svg +8 -11
  120. package/app-template/src/assets/icons/share.svg +2 -9
  121. package/app-template/src/assets/icons/snapchat.svg +3 -0
  122. package/app-template/src/assets/icons/tiktok.svg +3 -0
  123. package/app-template/src/assets/icons/tumblr.svg +6 -0
  124. package/app-template/src/assets/icons/twitter.svg +2 -10
  125. package/app-template/src/assets/icons/vimeo.svg +3 -0
  126. package/app-template/src/assets/icons/youtube.svg +3 -0
  127. package/app-template/src/assets/icons/zoom.svg +8 -0
  128. package/app-template/src/auth.ts +3 -0
  129. package/app-template/src/components/__tests__/link.test.tsx +2 -0
  130. package/app-template/src/components/accordion.tsx +48 -23
  131. package/app-template/src/components/action-tooltip.tsx +160 -0
  132. package/app-template/src/components/button.tsx +50 -35
  133. package/app-template/src/components/carousel-core.tsx +4 -11
  134. package/app-template/src/components/checkbox.tsx +2 -1
  135. package/app-template/src/components/currency-select.tsx +150 -4
  136. package/app-template/src/components/file-input.tsx +64 -2
  137. package/app-template/src/components/generate-form-fields.tsx +49 -10
  138. package/app-template/src/components/icon.tsx +5 -6
  139. package/app-template/src/components/index.ts +4 -1
  140. package/app-template/src/components/input.tsx +8 -2
  141. package/app-template/src/components/language-select.tsx +88 -2
  142. package/app-template/src/components/modal.tsx +34 -16
  143. package/app-template/src/components/pagination.tsx +133 -20
  144. package/app-template/src/components/price.tsx +1 -1
  145. package/app-template/src/components/pwa-tags.tsx +1 -0
  146. package/app-template/src/components/quantity-input.tsx +63 -0
  147. package/app-template/src/components/quantity-selector.tsx +215 -0
  148. package/app-template/src/components/route-handler.tsx +50 -0
  149. package/app-template/src/components/select.tsx +86 -54
  150. package/app-template/src/components/tabs.tsx +2 -2
  151. package/app-template/src/components/types/index.ts +55 -2
  152. package/app-template/src/components/widget-content.tsx +323 -0
  153. package/app-template/src/data/server/theme.ts +70 -0
  154. package/app-template/src/hooks/use-fav-button.tsx +9 -10
  155. package/app-template/src/hooks/use-product-cart.ts +80 -0
  156. package/app-template/src/hooks/use-stock-alert.ts +74 -0
  157. package/app-template/src/hooks/use-theme-settings.ts +42 -0
  158. package/app-template/src/lib/fonts.ts +149 -0
  159. package/app-template/src/middleware.ts +1 -0
  160. package/app-template/src/plugins.js +13 -2
  161. package/app-template/src/redux/middlewares/category.ts +6 -5
  162. package/app-template/src/redux/reducers/category.ts +1 -1
  163. package/app-template/src/redux/store.ts +21 -1
  164. package/app-template/src/routes/index.ts +8 -7
  165. package/app-template/src/settings.js +5 -3
  166. package/app-template/src/types/hookform-resolvers-yup.d.ts +28 -0
  167. package/app-template/src/types/index.ts +74 -3
  168. package/app-template/src/types/next-auth.d.ts +2 -2
  169. package/app-template/src/types/widget.ts +169 -0
  170. package/app-template/src/utils/__tests__/theme-page-context.test.ts +145 -0
  171. package/app-template/src/utils/convert-facet-search-params.ts +1 -1
  172. package/app-template/src/utils/formatDate.ts +48 -0
  173. package/app-template/src/utils/styles.ts +71 -0
  174. package/app-template/src/utils/theme-page-context.ts +309 -0
  175. package/app-template/src/utils/variant-validation.ts +41 -0
  176. package/app-template/src/views/account/address-form.tsx +8 -4
  177. package/app-template/src/views/account/contact-form.tsx +148 -136
  178. package/app-template/src/views/account/content-header.tsx +2 -2
  179. package/app-template/src/views/account/faq/faq-tabs.tsx +8 -2
  180. package/app-template/src/views/account/favorite-item.tsx +1 -1
  181. package/app-template/src/views/account/order.tsx +10 -8
  182. package/app-template/src/views/account/orders/order-cancellation-item.tsx +4 -3
  183. package/app-template/src/views/account/orders/order-detail-header.tsx +1 -1
  184. package/app-template/src/views/anonymous-tracking/order-detail/index.tsx +44 -37
  185. package/app-template/src/views/basket/basket-item.tsx +7 -1
  186. package/app-template/src/views/basket/summary.tsx +16 -0
  187. package/app-template/src/views/breadcrumb.tsx +2 -2
  188. package/app-template/src/views/category/category-active-filters.tsx +1 -1
  189. package/app-template/src/views/category/category-banner.tsx +4 -23
  190. package/app-template/src/views/category/category-header.tsx +12 -6
  191. package/app-template/src/views/category/category-info.tsx +4 -3
  192. package/app-template/src/views/category/filters/filter-item.tsx +138 -42
  193. package/app-template/src/views/category/filters/index.tsx +3 -3
  194. package/app-template/src/views/category/layout.tsx +1 -0
  195. package/app-template/src/views/checkout/auth.tsx +64 -40
  196. package/app-template/src/views/checkout/layout/header.tsx +9 -5
  197. package/app-template/src/views/checkout/steps/payment/index.tsx +1 -1
  198. package/app-template/src/views/checkout/steps/payment/options/credit-card/index.tsx +21 -5
  199. package/app-template/src/views/checkout/steps/payment/options/funds-transfer.tsx +25 -5
  200. package/app-template/src/views/checkout/steps/payment/options/loyalty.tsx +21 -2
  201. package/app-template/src/views/checkout/steps/payment/options/redirection.tsx +27 -5
  202. package/app-template/src/views/checkout/steps/payment/options/store-credit.tsx +464 -0
  203. package/app-template/src/views/checkout/steps/shipping/address-box.tsx +30 -17
  204. package/app-template/src/views/checkout/steps/shipping/addresses.tsx +1 -1
  205. package/app-template/src/views/checkout/summary.tsx +10 -0
  206. package/app-template/src/views/find-in-store/index.tsx +2 -2
  207. package/app-template/src/views/guest-login/index.tsx +62 -58
  208. package/app-template/src/views/header/action-menu.tsx +7 -4
  209. package/app-template/src/views/header/index.tsx +1 -1
  210. package/app-template/src/views/header/mini-basket.tsx +14 -3
  211. package/app-template/src/views/header/mobile-hamburger-button.tsx +5 -8
  212. package/app-template/src/views/header/mobile-menu.tsx +12 -0
  213. package/app-template/src/views/header/search/index.tsx +23 -1
  214. package/app-template/src/views/installment-options/index.tsx +1 -1
  215. package/app-template/src/views/login/index.tsx +89 -56
  216. package/app-template/src/views/otp-login/index.tsx +23 -20
  217. package/app-template/src/views/product/index.ts +1 -0
  218. package/app-template/src/views/product/layout.tsx +26 -6
  219. package/app-template/src/views/product/price-wrapper.tsx +3 -24
  220. package/app-template/src/views/product/product-actions.tsx +165 -0
  221. package/app-template/src/views/product/product-info.tsx +75 -237
  222. package/app-template/src/views/product/product-share.tsx +58 -0
  223. package/app-template/src/views/product/product-variants.tsx +26 -0
  224. package/app-template/src/views/product/slider.tsx +21 -0
  225. package/app-template/src/views/product/variant.tsx +69 -41
  226. package/app-template/src/views/register/index.tsx +54 -44
  227. package/app-template/src/views/share/index.tsx +9 -6
  228. package/app-template/src/views/widgets/home-hero-slider-content.tsx +41 -39
  229. package/app-template/src/widgets/flatpages/about-us/index.tsx +78 -0
  230. package/app-template/src/widgets/flatpages/blog-list/index.tsx +129 -0
  231. package/app-template/src/widgets/footer-menu.tsx +6 -2
  232. package/app-template/src/widgets/footer-subscription/footer-subscription-form.tsx +17 -14
  233. package/app-template/src/widgets/home-stories-eng.tsx +42 -34
  234. package/app-template/src/widgets/index.ts +7 -0
  235. package/app-template/src/widgets/schemas/about-us.json +46 -0
  236. package/app-template/src/widgets/schemas/blog-list.json +37 -0
  237. package/app-template/src/widgets/schemas/blog.json +29 -0
  238. package/app-template/tailwind.config.js +19 -7
  239. package/app-template/tsconfig.json +29 -11
  240. package/codemods/migrate-segments/index.js +591 -0
  241. package/codemods/sentry-9/index.js +30 -0
  242. package/codemods/sentry-9/remove-sentry-configs.js +14 -0
  243. package/codemods/sentry-9/remove-sentry-dependency.js +25 -0
  244. package/codemods/sentry-9/replace-error-page.js +32 -0
  245. package/codemods/update-tailwind-config/index.js +30 -0
  246. package/codemods/update-tailwind-config/transform.js +102 -0
  247. package/commands/codemod.ts +17 -0
  248. package/commands/index.ts +3 -1
  249. package/commands/plugins.ts +115 -46
  250. package/dist/codemods/sentry-9/templates/error.js +14 -0
  251. package/dist/commands/codemod.js +15 -0
  252. package/dist/commands/index.js +3 -1
  253. package/dist/commands/plugins.js +108 -36
  254. package/package.json +3 -2
  255. package/app-template/postcss.config.js +0 -6
  256. package/app-template/sentry.client.config.ts +0 -16
  257. package/app-template/sentry.edge.config.ts +0 -3
  258. package/app-template/sentry.properties +0 -4
  259. package/app-template/sentry.server.config.ts +0 -3
  260. package/app-template/src/app/[commerce]/[locale]/[currency]/category/[pk]/page.tsx +0 -22
  261. package/app-template/src/app/[commerce]/[locale]/[currency]/error.tsx +0 -20
  262. package/app-template/src/app/[commerce]/[locale]/[currency]/flat-page/[pk]/page.tsx +0 -20
  263. package/app-template/src/app/[commerce]/[locale]/[currency]/group-product/[pk]/page.tsx +0 -74
  264. package/app-template/src/app/[commerce]/[locale]/[currency]/list/page.tsx +0 -18
  265. package/app-template/src/app/[commerce]/[locale]/[currency]/page.tsx +0 -50
  266. package/app-template/src/app/[commerce]/[locale]/[currency]/product/[pk]/loading.tsx +0 -67
  267. package/app-template/src/app/[commerce]/[locale]/[currency]/product/[pk]/page.tsx +0 -84
  268. package/app-template/src/app/[commerce]/[locale]/[currency]/special-page/[pk]/page.tsx +0 -27
  269. package/app-template/src/app/[commerce]/[locale]/[currency]/xml-sitemap/[node]/route.ts +0 -25
  270. package/app-template/src/pages/api/auth/[...nextauth].ts +0 -3
  271. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/address/page.tsx +0 -0
  272. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/change-email/page.tsx +0 -0
  273. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/change-password/page.tsx +0 -0
  274. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/contact/page.tsx +0 -0
  275. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/coupons/page.tsx +0 -0
  276. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/email-verification/page.tsx +0 -0
  277. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/faq/page.tsx +0 -0
  278. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/favourite-products/page.tsx +0 -0
  279. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/my-quotations/page.tsx +0 -0
  280. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/orders/[id]/layout.tsx +0 -0
  281. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/orders/page.tsx +0 -0
  282. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/account/page.tsx +0 -0
  283. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/address/stores/page.tsx +0 -0
  284. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/anonymous-tracking/page.tsx +0 -0
  285. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/auth/oauth-login/page.tsx +0 -0
  286. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/auth/page.tsx +0 -0
  287. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/basket/page.tsx +0 -0
  288. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/basket-b2b/page.tsx +0 -0
  289. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/category/[pk]/loading.tsx +0 -0
  290. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/client-root.tsx +0 -0
  291. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/contact-us/page.tsx +0 -0
  292. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/flat-page/[pk]/loading.tsx +0 -0
  293. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/group-product/[pk]/loading.tsx +0 -0
  294. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/landing-page/[pk]/loading.tsx +0 -0
  295. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/list/loading.tsx +0 -0
  296. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/orders/completed/[token]/layout.tsx +0 -0
  297. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/special-page/[pk]/loading.tsx +0 -0
  298. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/template.tsx +0 -0
  299. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/users/password/reset/page.tsx +0 -0
  300. /package/app-template/src/app/{[commerce]/[locale]/[currency] → [pz]}/xml-sitemap/route.ts +0 -0
@@ -6,6 +6,41 @@ import { getWidgetData } from '@akinon/next/data/server';
6
6
  import { Link } from '@theme/components';
7
7
  import { Image } from '@akinon/next/components/image';
8
8
 
9
+ function TitleSection({
10
+ mobileTitle,
11
+ mobileSubtitle
12
+ }: {
13
+ mobileTitle?: { value: string };
14
+ mobileSubtitle?: { value: string };
15
+ }) {
16
+ return (
17
+ <>
18
+ {mobileTitle ? (
19
+ <h2 className="text-5xl text-center font-light px-11 mb-2 lg:hidden">
20
+ {mobileTitle.value}
21
+ </h2>
22
+ ) : null}
23
+ {mobileSubtitle ? (
24
+ <p className="text-sm text-center mb-2 lg:hidden">
25
+ {mobileSubtitle.value}
26
+ </p>
27
+ ) : null}
28
+ </>
29
+ );
30
+ }
31
+
32
+ function MobileLinks({ mobileLinks }: { mobileLinks?: MobileLink[] }) {
33
+ return (
34
+ <ul className="flex justify-center text-sm font-medium underline mb-4 lg:hidden">
35
+ {mobileLinks?.map((item, index) => (
36
+ <li className="mr-4 first:ml-4" key={`${item?.value?.text}__${index}`}>
37
+ <Link href={item?.value?.url}>{item?.value?.text}</Link>
38
+ </li>
39
+ ))}
40
+ </ul>
41
+ );
42
+ }
43
+
9
44
  type StoryData = {
10
45
  value: {
11
46
  url: string;
@@ -20,7 +55,7 @@ type StoryData = {
20
55
  };
21
56
  };
22
57
 
23
- type MobileLinks = {
58
+ type MobileLink = {
24
59
  value: {
25
60
  url: string;
26
61
  text: string;
@@ -35,7 +70,7 @@ type HomeStoriesEngType = {
35
70
  value: string;
36
71
  };
37
72
  stories: StoryData[];
38
- mobileLinks: MobileLinks[];
73
+ mobileLinks: MobileLink[];
39
74
  };
40
75
 
41
76
  export default async function HomeStoriesEng() {
@@ -43,40 +78,13 @@ export default async function HomeStoriesEng() {
43
78
  slug: 'home-storieseng'
44
79
  });
45
80
 
46
- const TitleSection = () => (
47
- <>
48
- {data?.attributes?.mobileTitle ? (
49
- <h2 className="text-5xl text-center font-light px-11 mb-2 lg:hidden">
50
- {data?.attributes?.mobileTitle?.value}
51
- </h2>
52
- ) : null}
53
- {data?.attributes?.mobileSubtitle ? (
54
- <p className="text-sm text-center mb-2 lg:hidden">
55
- {data?.attributes?.mobileSubtitle?.value}
56
- </p>
57
- ) : null}
58
- </>
59
- );
60
-
61
- const MobileLinks = () => (
62
- <ul className="flex justify-center text-sm font-medium underline mb-4 lg:hidden">
63
- {data?.attributes?.mobileLinks?.map((item, index) => {
64
- return (
65
- <li
66
- className="mr-4 first:ml-4"
67
- key={`${item?.value?.text}__${index}`}
68
- >
69
- <Link href={item?.value?.url}>{item?.value?.text}</Link>
70
- </li>
71
- );
72
- })}
73
- </ul>
74
- );
75
-
76
81
  return (
77
82
  <section className="my-8">
78
- <TitleSection />
79
- <MobileLinks />
83
+ <TitleSection
84
+ mobileTitle={data?.attributes?.mobileTitle}
85
+ mobileSubtitle={data?.attributes?.mobileSubtitle}
86
+ />
87
+ <MobileLinks mobileLinks={data?.attributes?.mobileLinks} />
80
88
 
81
89
  <div className="flex items-center overflow-x-auto pb-4 md:justify-center">
82
90
  {data?.attributes?.stories?.map((story, index) => {
@@ -23,3 +23,10 @@ export const HOME_WIDGETS: {
23
23
  async () => import('@theme/widgets/home-stories-eng')
24
24
  )
25
25
  };
26
+
27
+ export const FLATPAGE_COMPONENT: {
28
+ [key: string]: ComponentType<WidgetResultType<unknown>>;
29
+ } = {
30
+ 'about-us': dynamic(async () => import('@theme/widgets/flatpages/about-us')),
31
+ 'blog-list': dynamic(async () => import('@theme/widgets/flatpages/blog-list'))
32
+ };
@@ -0,0 +1,46 @@
1
+ {
2
+ "title": {
3
+ "key": "title",
4
+ "label": "Title",
5
+ "data_type": "text",
6
+ "is_localizable": true
7
+ },
8
+ "content": {
9
+ "key": "content",
10
+ "label": "Content",
11
+ "display": "html-editor",
12
+ "data_type": "area",
13
+ "is_localizable": true
14
+ },
15
+ "image_1": {
16
+ "key": "image_1",
17
+ "label": "Banner Image 1* (Ex: 350x330px)",
18
+ "data_type": "image",
19
+ "is_localizable": true
20
+ },
21
+ "image_2": {
22
+ "key": "image_2",
23
+ "label": "Banner Image 2* (Ex: 350x330px)",
24
+ "data_type": "image",
25
+ "is_localizable": true
26
+ },
27
+ "image_3": {
28
+ "key": "image_3",
29
+ "label": "Banner Image 3* (Ex: 350x330px)",
30
+ "data_type": "image",
31
+ "is_localizable": true
32
+ },
33
+ "highlight_section": {
34
+ "key": "highlight_section",
35
+ "label": "Highlight Section Content",
36
+ "display": "html-editor",
37
+ "data_type": "area",
38
+ "is_localizable": true
39
+ },
40
+ "highlight_section_title": {
41
+ "key": "highlight_section_title",
42
+ "label": "Highlight Section Title",
43
+ "data_type": "text",
44
+ "is_localizable": true
45
+ }
46
+ }
@@ -0,0 +1,37 @@
1
+ {
2
+ "blogs": {
3
+ "key": "blogs",
4
+ "label": "Blogs",
5
+ "is_localizable": true,
6
+ "multi": true,
7
+ "data_type": "nested",
8
+ "schema": {
9
+ "title": {
10
+ "key": "title",
11
+ "label": "Title",
12
+ "data_type": "text"
13
+ },
14
+ "description": {
15
+ "key": "description",
16
+ "label": "Description",
17
+ "data_type": "text"
18
+ },
19
+ "date": {
20
+ "key": "date",
21
+ "display": "date_picker",
22
+ "label": "Date",
23
+ "data_type": "text"
24
+ },
25
+ "image": {
26
+ "key": "image",
27
+ "label": "Image* (Ex: 370x250px)",
28
+ "data_type": "image"
29
+ },
30
+ "link": {
31
+ "key": "link",
32
+ "label": "Link",
33
+ "data_type": "text"
34
+ }
35
+ }
36
+ }
37
+ }
@@ -0,0 +1,29 @@
1
+ {
2
+ "title": {
3
+ "key": "title",
4
+ "label": "Title",
5
+ "data_type": "text"
6
+ },
7
+ "description": {
8
+ "key": "description",
9
+ "label": "Description",
10
+ "display": "html-editor",
11
+ "data_type": "area"
12
+ },
13
+ "date": {
14
+ "key": "date",
15
+ "display": "date_picker",
16
+ "label": "Date",
17
+ "data_type": "text"
18
+ },
19
+ "image": {
20
+ "key": "image",
21
+ "label": "Image* (Ex: 1072x923px)",
22
+ "data_type": "image"
23
+ },
24
+ "link": {
25
+ "key": "link",
26
+ "label": "Product Link",
27
+ "data_type": "text"
28
+ }
29
+ }
@@ -1,3 +1,4 @@
1
+ const getAkinonNextContent = require('@akinon/next/tailwind/content');
1
2
  const deepMerge = require('@akinon/next/utils/deep-merge');
2
3
  const defaultTheme = require('tailwindcss/defaultTheme');
3
4
  const plugins = require('./src/plugins');
@@ -19,6 +20,8 @@ if (themeName !== 'default' && fs.existsSync(themeConfigPath)) {
19
20
 
20
21
  const defaultConfig = {
21
22
  content: [
23
+ './node_modules/@akinon/next/**/*.{js,ts,jsx,tsx}',
24
+ '../../node_modules/@akinon/next/**/*.{js,ts,jsx,tsx}',
22
25
  './src/app/**/*.{js,ts,jsx,tsx}',
23
26
  './src/pages/**/*.{js,ts,jsx,tsx}',
24
27
  './src/components/**/*.{js,ts,jsx,tsx}',
@@ -26,12 +29,7 @@ const defaultConfig = {
26
29
  './src/widgets/**/*.{js,ts,jsx,tsx}',
27
30
  './src/hooks/**/*.{js,ts,jsx,tsx}',
28
31
  './src/utils/**/*.{js,ts,jsx,tsx}',
29
- ...plugins
30
- .map((plugin) => [
31
- `./node_modules/@akinon/${plugin}/**/*.{js,ts,jsx,tsx}`,
32
- `../../node_modules/@akinon/${plugin}/**/*.{js,ts,jsx,tsx}`
33
- ])
34
- .flat()
32
+ ...getAkinonNextContent(plugins)
35
33
  ],
36
34
  theme: {
37
35
  extend: {
@@ -64,10 +62,20 @@ const defaultConfig = {
64
62
  '100%': {
65
63
  transform: 'translateX(100%)'
66
64
  }
65
+ },
66
+ 'slide-in': {
67
+ '0%': { transform: 'translateX(100%)' },
68
+ '100%': { transform: 'translateX(0)' }
69
+ },
70
+ 'slide-out': {
71
+ '0%': { transform: 'translateX(0)' },
72
+ '100%': { transform: 'translateX(-100%)' }
67
73
  }
68
74
  },
69
75
  animation: {
70
- 'skeleton-shimmer': 'skeleton-shimmer 2s linear infinite'
76
+ 'skeleton-shimmer': 'skeleton-shimmer 2s linear infinite',
77
+ 'slide-in': 'slide-in 0.4s ease-out forwards',
78
+ 'slide-out': 'slide-out 0.4s ease-out forwards'
71
79
  }
72
80
  },
73
81
  colors: {
@@ -110,12 +118,15 @@ const defaultConfig = {
110
118
  500: '#2d2d2d',
111
119
  600: '#292929',
112
120
  700: '#2b2b2b',
121
+ 750: '#121212',
113
122
  800: '#181818',
123
+ 850: '#0a0a0a',
114
124
  900: '#000000'
115
125
  },
116
126
  gray: {
117
127
  DEFAULT: '#ebebeb',
118
128
  25: '#fdfdfd',
129
+ 30: '#fafafa',
119
130
  50: '#f7f7f7',
120
131
  100: '#f5f5f5',
121
132
  150: '#f4f4f4',
@@ -125,6 +136,7 @@ const defaultConfig = {
125
136
  450: '#d4d4d4',
126
137
  500: '#c9c9c9',
127
138
  600: '#9d9d9d',
139
+ 650: '#7d7d7d',
128
140
  700: '#686868',
129
141
  800: '#615f62',
130
142
  850: '#58585a',
@@ -4,17 +4,27 @@
4
4
  "compilerOptions": {
5
5
  "baseUrl": "./src",
6
6
  "paths": {
7
- "@theme/*": ["./*"],
8
- "@root/*": ["./app/[commerce]/[locale]/[currency]/*"],
9
- "@product/*": ["./app/[commerce]/[locale]/[currency]/product/*"],
7
+ "@theme/*": [
8
+ "./*"
9
+ ],
10
+ "@root/*": [
11
+ "./app/[pz]/*"
12
+ ],
13
+ "@product/*": [
14
+ "./app/[pz]/product/*"
15
+ ],
10
16
  "@group-product/*": [
11
- "./app/[commerce]/[locale]/[currency]/group-product/*"
17
+ "./app/[pz]/group-product/*"
18
+ ],
19
+ "@category/*": [
20
+ "./app/[pz]/category/*"
12
21
  ],
13
- "@category/*": ["./app/[commerce]/[locale]/[currency]/category/*"],
14
22
  "@special-page/*": [
15
- "./app/[commerce]/[locale]/[currency]/special-page/*"
23
+ "./app/[pz]/special-page/*"
16
24
  ],
17
- "@flat-page/*": ["./app/[commerce]/[locale]/[currency]/flat-page/*"]
25
+ "@flat-page/*": [
26
+ "./app/[pz]/flat-page/*"
27
+ ]
18
28
  },
19
29
  "allowSyntheticDefaultImports": true,
20
30
  "composite": false,
@@ -26,7 +36,11 @@
26
36
  "noUnusedParameters": false,
27
37
  "preserveWatchOutput": true,
28
38
  "target": "es5",
29
- "lib": ["dom", "dom.iterable", "esnext"],
39
+ "lib": [
40
+ "dom",
41
+ "dom.iterable",
42
+ "esnext"
43
+ ],
30
44
  "allowJs": true,
31
45
  "skipLibCheck": true,
32
46
  "strict": false,
@@ -37,7 +51,7 @@
37
51
  "module": "esnext",
38
52
  "resolveJsonModule": true,
39
53
  "isolatedModules": true,
40
- "jsx": "preserve",
54
+ "jsx": "react-jsx",
41
55
  "plugins": [
42
56
  {
43
57
  "name": "next"
@@ -50,7 +64,11 @@
50
64
  "**/*.ts",
51
65
  "**/*.tsx",
52
66
  ".next/types/**/*.ts",
53
- "../../packages/**/*"
67
+ "../../packages/**/*",
68
+ ".next/dev/types/**/*.ts"
54
69
  ],
55
- "exclude": ["node_modules", "../../packages/projectzero/app-template"]
70
+ "exclude": [
71
+ "node_modules",
72
+ "../../packages/projectzero/app-template"
73
+ ]
56
74
  }