@akinon/projectzero 1.32.0-rc.2 → 1.32.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.
Files changed (509) hide show
  1. package/CHANGELOG.md +2 -8
  2. package/commands/create.ts +118 -49
  3. package/dist/commands/create.js +68 -32
  4. package/package.json +1 -1
  5. package/tsconfig.json +8 -9
  6. package/app-template/.editorconfig +0 -7
  7. package/app-template/.env.example +0 -9
  8. package/app-template/.eslintignore +0 -1
  9. package/app-template/.eslintrc.js +0 -31
  10. package/app-template/.gitattributes +0 -18
  11. package/app-template/.husky/pre-commit +0 -4
  12. package/app-template/.lintstagedrc.js +0 -12
  13. package/app-template/.prettierrc +0 -13
  14. package/app-template/.releaserc.json +0 -49
  15. package/app-template/.stylelintrc.json +0 -37
  16. package/app-template/.vscode/extensions.json +0 -11
  17. package/app-template/.vscode/launch.json +0 -29
  18. package/app-template/.yarnrc +0 -1
  19. package/app-template/CHANGELOG.md +0 -655
  20. package/app-template/LICENSE +0 -21
  21. package/app-template/Procfile +0 -1
  22. package/app-template/README.md +0 -29
  23. package/app-template/akinon.json +0 -28
  24. package/app-template/bitbucket-pipelines.yml +0 -54
  25. package/app-template/build.sh +0 -7
  26. package/app-template/docs/CHANGELOG.md +0 -85
  27. package/app-template/docs/advanced-usage.md +0 -43
  28. package/app-template/docs/basic-setup.md +0 -59
  29. package/app-template/docs/data-fetching/client/account.md +0 -1064
  30. package/app-template/docs/data-fetching/client/address.md +0 -805
  31. package/app-template/docs/data-fetching/client/basket.md +0 -107
  32. package/app-template/docs/data-fetching/client/checkout.md +0 -904
  33. package/app-template/docs/data-fetching/client/misc.md +0 -135
  34. package/app-template/docs/data-fetching/client/product.md +0 -284
  35. package/app-template/docs/data-fetching/client/user.md +0 -56
  36. package/app-template/docs/data-fetching/client/wishlist.md +0 -111
  37. package/app-template/docs/data-fetching/server/category.md +0 -324
  38. package/app-template/docs/data-fetching/server/flat-page.md +0 -42
  39. package/app-template/docs/data-fetching/server/list.md +0 -353
  40. package/app-template/docs/data-fetching/server/menu.md +0 -363
  41. package/app-template/docs/data-fetching/server/product.md +0 -131
  42. package/app-template/docs/data-fetching/server/seo.md +0 -44
  43. package/app-template/docs/data-fetching/server/special-page.md +0 -79
  44. package/app-template/docs/data-fetching/server/widget.md +0 -218
  45. package/app-template/docs/delete-account.md +0 -25
  46. package/app-template/docs/deployment.md +0 -46
  47. package/app-template/docs/dynamic-route.md +0 -33
  48. package/app-template/docs/icons.md +0 -52
  49. package/app-template/docs/localization.md +0 -204
  50. package/app-template/docs/logging.md +0 -48
  51. package/app-template/docs/plugins.md +0 -76
  52. package/app-template/docs/seo-management.md +0 -125
  53. package/app-template/docs/static-assets.md +0 -36
  54. package/app-template/docs/widgets.md +0 -127
  55. package/app-template/global.d.ts +0 -1
  56. package/app-template/jest.config.ts +0 -34
  57. package/app-template/next-env.d.ts +0 -6
  58. package/app-template/next.config.mjs +0 -34
  59. package/app-template/package.json +0 -97
  60. package/app-template/plugins.d.ts +0 -1
  61. package/app-template/postcss.config.js +0 -6
  62. package/app-template/public/404.png +0 -0
  63. package/app-template/public/500.png +0 -0
  64. package/app-template/public/apple-splash-1125-2436.jpg +0 -0
  65. package/app-template/public/apple-splash-1136-640.jpg +0 -0
  66. package/app-template/public/apple-splash-1170-2532.jpg +0 -0
  67. package/app-template/public/apple-splash-1242-2208.jpg +0 -0
  68. package/app-template/public/apple-splash-1242-2688.jpg +0 -0
  69. package/app-template/public/apple-splash-1284-2778.jpg +0 -0
  70. package/app-template/public/apple-splash-1334-750.jpg +0 -0
  71. package/app-template/public/apple-splash-1536-2048.jpg +0 -0
  72. package/app-template/public/apple-splash-1620-2160.jpg +0 -0
  73. package/app-template/public/apple-splash-1668-2224.jpg +0 -0
  74. package/app-template/public/apple-splash-1668-2388.jpg +0 -0
  75. package/app-template/public/apple-splash-1792-828.jpg +0 -0
  76. package/app-template/public/apple-splash-2048-1536.jpg +0 -0
  77. package/app-template/public/apple-splash-2048-2732.jpg +0 -0
  78. package/app-template/public/apple-splash-2160-1620.jpg +0 -0
  79. package/app-template/public/apple-splash-2208-1242.jpg +0 -0
  80. package/app-template/public/apple-splash-2224-1668.jpg +0 -0
  81. package/app-template/public/apple-splash-2388-1668.jpg +0 -0
  82. package/app-template/public/apple-splash-2436-1125.jpg +0 -0
  83. package/app-template/public/apple-splash-2532-1170.jpg +0 -0
  84. package/app-template/public/apple-splash-2688-1242.jpg +0 -0
  85. package/app-template/public/apple-splash-2732-2048.jpg +0 -0
  86. package/app-template/public/apple-splash-2778-1284.jpg +0 -0
  87. package/app-template/public/apple-splash-640-1136.jpg +0 -0
  88. package/app-template/public/apple-splash-750-1334.jpg +0 -0
  89. package/app-template/public/apple-splash-828-1792.jpg +0 -0
  90. package/app-template/public/apple-touch-icon-152x152.png +0 -0
  91. package/app-template/public/apple-touch-icon-167x167.png +0 -0
  92. package/app-template/public/apple-touch-icon-180x180.png +0 -0
  93. package/app-template/public/apple-touch-icon.png +0 -0
  94. package/app-template/public/apple.svg +0 -47
  95. package/app-template/public/cvv.jpg +0 -0
  96. package/app-template/public/facebook.svg +0 -3
  97. package/app-template/public/google.svg +0 -12
  98. package/app-template/public/icon-192x192.png +0 -0
  99. package/app-template/public/icon-256x256.png +0 -0
  100. package/app-template/public/icon-384x384.png +0 -0
  101. package/app-template/public/icon-512x512.png +0 -0
  102. package/app-template/public/icon-sprite.svg +0 -528
  103. package/app-template/public/locales/en/account.json +0 -487
  104. package/app-template/public/locales/en/auth.json +0 -100
  105. package/app-template/public/locales/en/basket.json +0 -50
  106. package/app-template/public/locales/en/category.json +0 -26
  107. package/app-template/public/locales/en/checkout.json +0 -152
  108. package/app-template/public/locales/en/common.json +0 -65
  109. package/app-template/public/locales/en/forgot_password.json +0 -41
  110. package/app-template/public/locales/en/form.json +0 -5
  111. package/app-template/public/locales/en/not_found.json +0 -5
  112. package/app-template/public/locales/en/product.json +0 -39
  113. package/app-template/public/locales/tr/account.json +0 -487
  114. package/app-template/public/locales/tr/auth.json +0 -100
  115. package/app-template/public/locales/tr/basket.json +0 -50
  116. package/app-template/public/locales/tr/category.json +0 -26
  117. package/app-template/public/locales/tr/checkout.json +0 -152
  118. package/app-template/public/locales/tr/common.json +0 -65
  119. package/app-template/public/locales/tr/forgot_password.json +0 -41
  120. package/app-template/public/locales/tr/form.json +0 -5
  121. package/app-template/public/locales/tr/not_found.json +0 -5
  122. package/app-template/public/locales/tr/product.json +0 -39
  123. package/app-template/public/logo.svg +0 -29
  124. package/app-template/public/manifest.json +0 -35
  125. package/app-template/public/mastercard.png +0 -0
  126. package/app-template/public/mastersecure.png +0 -0
  127. package/app-template/public/mfs-client.min.js +0 -3
  128. package/app-template/public/noimage.jpg +0 -0
  129. package/app-template/public/safari-pinned-tab.svg +0 -320
  130. package/app-template/public/ssl-secure.png +0 -0
  131. package/app-template/public/vbv.png +0 -0
  132. package/app-template/public/visa.png +0 -0
  133. package/app-template/public/zepto.min.js +0 -2
  134. package/app-template/sentry.client.config.ts +0 -16
  135. package/app-template/sentry.edge.config.ts +0 -3
  136. package/app-template/sentry.properties +0 -4
  137. package/app-template/sentry.server.config.ts +0 -3
  138. package/app-template/setupTests.ts +0 -4
  139. package/app-template/src/__tests__/index.test.tsx +0 -7
  140. package/app-template/src/__tests__/tsconfig.json +0 -7
  141. package/app-template/src/app/[commerce]/[locale]/[currency]/account/address/page.tsx +0 -74
  142. package/app-template/src/app/[commerce]/[locale]/[currency]/account/change-email/page.tsx +0 -174
  143. package/app-template/src/app/[commerce]/[locale]/[currency]/account/change-password/page.tsx +0 -206
  144. package/app-template/src/app/[commerce]/[locale]/[currency]/account/contact/page.tsx +0 -7
  145. package/app-template/src/app/[commerce]/[locale]/[currency]/account/coupons/page.tsx +0 -210
  146. package/app-template/src/app/[commerce]/[locale]/[currency]/account/email-verification/page.tsx +0 -5
  147. package/app-template/src/app/[commerce]/[locale]/[currency]/account/faq/page.tsx +0 -23
  148. package/app-template/src/app/[commerce]/[locale]/[currency]/account/favourite-products/page.tsx +0 -32
  149. package/app-template/src/app/[commerce]/[locale]/[currency]/account/layout.tsx +0 -28
  150. package/app-template/src/app/[commerce]/[locale]/[currency]/account/my-quotations/page.tsx +0 -7
  151. package/app-template/src/app/[commerce]/[locale]/[currency]/account/orders/[id]/cancellation/page.tsx +0 -255
  152. package/app-template/src/app/[commerce]/[locale]/[currency]/account/orders/[id]/layout.tsx +0 -5
  153. package/app-template/src/app/[commerce]/[locale]/[currency]/account/orders/[id]/page.tsx +0 -309
  154. package/app-template/src/app/[commerce]/[locale]/[currency]/account/orders/page.tsx +0 -137
  155. package/app-template/src/app/[commerce]/[locale]/[currency]/account/page.tsx +0 -226
  156. package/app-template/src/app/[commerce]/[locale]/[currency]/account/profile/page.tsx +0 -400
  157. package/app-template/src/app/[commerce]/[locale]/[currency]/address/stores/page.tsx +0 -271
  158. package/app-template/src/app/[commerce]/[locale]/[currency]/anonymous-tracking/page.tsx +0 -33
  159. package/app-template/src/app/[commerce]/[locale]/[currency]/auth/oauth-login/page.tsx +0 -3
  160. package/app-template/src/app/[commerce]/[locale]/[currency]/auth/page.tsx +0 -76
  161. package/app-template/src/app/[commerce]/[locale]/[currency]/basket/page.tsx +0 -77
  162. package/app-template/src/app/[commerce]/[locale]/[currency]/basket-b2b/page.tsx +0 -7
  163. package/app-template/src/app/[commerce]/[locale]/[currency]/category/[pk]/loading.tsx +0 -53
  164. package/app-template/src/app/[commerce]/[locale]/[currency]/category/[pk]/page.tsx +0 -16
  165. package/app-template/src/app/[commerce]/[locale]/[currency]/client-root.tsx +0 -9
  166. package/app-template/src/app/[commerce]/[locale]/[currency]/contact-us/page.tsx +0 -11
  167. package/app-template/src/app/[commerce]/[locale]/[currency]/error.tsx +0 -20
  168. package/app-template/src/app/[commerce]/[locale]/[currency]/flat-page/[pk]/loading.tsx +0 -5
  169. package/app-template/src/app/[commerce]/[locale]/[currency]/flat-page/[pk]/page.tsx +0 -18
  170. package/app-template/src/app/[commerce]/[locale]/[currency]/forms/[pk]/generate/page.tsx +0 -48
  171. package/app-template/src/app/[commerce]/[locale]/[currency]/group-product/[pk]/loading.tsx +0 -5
  172. package/app-template/src/app/[commerce]/[locale]/[currency]/group-product/[pk]/page.tsx +0 -72
  173. package/app-template/src/app/[commerce]/[locale]/[currency]/landing-page/[pk]/loading.tsx +0 -5
  174. package/app-template/src/app/[commerce]/[locale]/[currency]/landing-page/[pk]/page.tsx +0 -23
  175. package/app-template/src/app/[commerce]/[locale]/[currency]/layout.tsx +0 -78
  176. package/app-template/src/app/[commerce]/[locale]/[currency]/list/loading.tsx +0 -53
  177. package/app-template/src/app/[commerce]/[locale]/[currency]/list/page.tsx +0 -16
  178. package/app-template/src/app/[commerce]/[locale]/[currency]/orders/checkout/page.tsx +0 -140
  179. package/app-template/src/app/[commerce]/[locale]/[currency]/orders/completed/[token]/layout.tsx +0 -5
  180. package/app-template/src/app/[commerce]/[locale]/[currency]/orders/completed/[token]/page.tsx +0 -284
  181. package/app-template/src/app/[commerce]/[locale]/[currency]/page.tsx +0 -50
  182. package/app-template/src/app/[commerce]/[locale]/[currency]/product/[pk]/loading.tsx +0 -67
  183. package/app-template/src/app/[commerce]/[locale]/[currency]/product/[pk]/page.tsx +0 -81
  184. package/app-template/src/app/[commerce]/[locale]/[currency]/pz-not-found/page.tsx +0 -24
  185. package/app-template/src/app/[commerce]/[locale]/[currency]/special-page/[pk]/loading.tsx +0 -53
  186. package/app-template/src/app/[commerce]/[locale]/[currency]/special-page/[pk]/page.tsx +0 -25
  187. package/app-template/src/app/[commerce]/[locale]/[currency]/template.tsx +0 -75
  188. package/app-template/src/app/[commerce]/[locale]/[currency]/users/email-set-primary/[[...id]]/page.tsx +0 -43
  189. package/app-template/src/app/[commerce]/[locale]/[currency]/users/password/reset/page.tsx +0 -79
  190. package/app-template/src/app/[commerce]/[locale]/[currency]/users/registration/account-confirm-email/[[...id]]/page.tsx +0 -43
  191. package/app-template/src/app/[commerce]/[locale]/[currency]/users/reset/[[...id]]/page.tsx +0 -110
  192. package/app-template/src/app/[commerce]/[locale]/[currency]/xml-sitemap/[node]/route.ts +0 -25
  193. package/app-template/src/app/[commerce]/[locale]/[currency]/xml-sitemap/route.ts +0 -37
  194. package/app-template/src/app/api/cache/route.ts +0 -1
  195. package/app-template/src/app/api/client/[...slug]/route.ts +0 -1
  196. package/app-template/src/app/api/form/[...id]/route.ts +0 -7
  197. package/app-template/src/app/api/logout/route.ts +0 -1
  198. package/app-template/src/app/api/sentry/route.ts +0 -9
  199. package/app-template/src/app/api/web-vitals/route.ts +0 -1
  200. package/app-template/src/app/favicon.ico +0 -0
  201. package/app-template/src/assets/fonts/Jost/Jost-Black.eot +0 -0
  202. package/app-template/src/assets/fonts/Jost/Jost-Black.ttf +0 -0
  203. package/app-template/src/assets/fonts/Jost/Jost-Black.woff +0 -0
  204. package/app-template/src/assets/fonts/Jost/Jost-Black.woff2 +0 -0
  205. package/app-template/src/assets/fonts/Jost/Jost-BlackItalic.eot +0 -0
  206. package/app-template/src/assets/fonts/Jost/Jost-BlackItalic.ttf +0 -0
  207. package/app-template/src/assets/fonts/Jost/Jost-BlackItalic.woff +0 -0
  208. package/app-template/src/assets/fonts/Jost/Jost-BlackItalic.woff2 +0 -0
  209. package/app-template/src/assets/fonts/Jost/Jost-Bold.eot +0 -0
  210. package/app-template/src/assets/fonts/Jost/Jost-Bold.ttf +0 -0
  211. package/app-template/src/assets/fonts/Jost/Jost-Bold.woff +0 -0
  212. package/app-template/src/assets/fonts/Jost/Jost-Bold.woff2 +0 -0
  213. package/app-template/src/assets/fonts/Jost/Jost-BoldItalic.eot +0 -0
  214. package/app-template/src/assets/fonts/Jost/Jost-BoldItalic.ttf +0 -0
  215. package/app-template/src/assets/fonts/Jost/Jost-BoldItalic.woff +0 -0
  216. package/app-template/src/assets/fonts/Jost/Jost-BoldItalic.woff2 +0 -0
  217. package/app-template/src/assets/fonts/Jost/Jost-ExtraBold.eot +0 -0
  218. package/app-template/src/assets/fonts/Jost/Jost-ExtraBold.ttf +0 -0
  219. package/app-template/src/assets/fonts/Jost/Jost-ExtraBold.woff +0 -0
  220. package/app-template/src/assets/fonts/Jost/Jost-ExtraBold.woff2 +0 -0
  221. package/app-template/src/assets/fonts/Jost/Jost-ExtraBoldItalic.eot +0 -0
  222. package/app-template/src/assets/fonts/Jost/Jost-ExtraBoldItalic.ttf +0 -0
  223. package/app-template/src/assets/fonts/Jost/Jost-ExtraBoldItalic.woff +0 -0
  224. package/app-template/src/assets/fonts/Jost/Jost-ExtraBoldItalic.woff2 +0 -0
  225. package/app-template/src/assets/fonts/Jost/Jost-ExtraLight.eot +0 -0
  226. package/app-template/src/assets/fonts/Jost/Jost-ExtraLight.ttf +0 -0
  227. package/app-template/src/assets/fonts/Jost/Jost-ExtraLight.woff +0 -0
  228. package/app-template/src/assets/fonts/Jost/Jost-ExtraLight.woff2 +0 -0
  229. package/app-template/src/assets/fonts/Jost/Jost-ExtraLightItalic.eot +0 -0
  230. package/app-template/src/assets/fonts/Jost/Jost-ExtraLightItalic.ttf +0 -0
  231. package/app-template/src/assets/fonts/Jost/Jost-ExtraLightItalic.woff +0 -0
  232. package/app-template/src/assets/fonts/Jost/Jost-ExtraLightItalic.woff2 +0 -0
  233. package/app-template/src/assets/fonts/Jost/Jost-Italic.eot +0 -0
  234. package/app-template/src/assets/fonts/Jost/Jost-Italic.ttf +0 -0
  235. package/app-template/src/assets/fonts/Jost/Jost-Italic.woff +0 -0
  236. package/app-template/src/assets/fonts/Jost/Jost-Italic.woff2 +0 -0
  237. package/app-template/src/assets/fonts/Jost/Jost-Light.eot +0 -0
  238. package/app-template/src/assets/fonts/Jost/Jost-Light.ttf +0 -0
  239. package/app-template/src/assets/fonts/Jost/Jost-Light.woff +0 -0
  240. package/app-template/src/assets/fonts/Jost/Jost-Light.woff2 +0 -0
  241. package/app-template/src/assets/fonts/Jost/Jost-LightItalic.eot +0 -0
  242. package/app-template/src/assets/fonts/Jost/Jost-LightItalic.ttf +0 -0
  243. package/app-template/src/assets/fonts/Jost/Jost-LightItalic.woff +0 -0
  244. package/app-template/src/assets/fonts/Jost/Jost-LightItalic.woff2 +0 -0
  245. package/app-template/src/assets/fonts/Jost/Jost-Medium.eot +0 -0
  246. package/app-template/src/assets/fonts/Jost/Jost-Medium.ttf +0 -0
  247. package/app-template/src/assets/fonts/Jost/Jost-Medium.woff +0 -0
  248. package/app-template/src/assets/fonts/Jost/Jost-Medium.woff2 +0 -0
  249. package/app-template/src/assets/fonts/Jost/Jost-MediumItalic.eot +0 -0
  250. package/app-template/src/assets/fonts/Jost/Jost-MediumItalic.ttf +0 -0
  251. package/app-template/src/assets/fonts/Jost/Jost-MediumItalic.woff +0 -0
  252. package/app-template/src/assets/fonts/Jost/Jost-MediumItalic.woff2 +0 -0
  253. package/app-template/src/assets/fonts/Jost/Jost-Regular.eot +0 -0
  254. package/app-template/src/assets/fonts/Jost/Jost-Regular.ttf +0 -0
  255. package/app-template/src/assets/fonts/Jost/Jost-Regular.woff +0 -0
  256. package/app-template/src/assets/fonts/Jost/Jost-Regular.woff2 +0 -0
  257. package/app-template/src/assets/fonts/Jost/Jost-SemiBold.eot +0 -0
  258. package/app-template/src/assets/fonts/Jost/Jost-SemiBold.ttf +0 -0
  259. package/app-template/src/assets/fonts/Jost/Jost-SemiBold.woff +0 -0
  260. package/app-template/src/assets/fonts/Jost/Jost-SemiBold.woff2 +0 -0
  261. package/app-template/src/assets/fonts/Jost/Jost-SemiBoldItalic.eot +0 -0
  262. package/app-template/src/assets/fonts/Jost/Jost-SemiBoldItalic.ttf +0 -0
  263. package/app-template/src/assets/fonts/Jost/Jost-SemiBoldItalic.woff +0 -0
  264. package/app-template/src/assets/fonts/Jost/Jost-SemiBoldItalic.woff2 +0 -0
  265. package/app-template/src/assets/fonts/Jost/Jost-Thin.eot +0 -0
  266. package/app-template/src/assets/fonts/Jost/Jost-Thin.ttf +0 -0
  267. package/app-template/src/assets/fonts/Jost/Jost-Thin.woff +0 -0
  268. package/app-template/src/assets/fonts/Jost/Jost-Thin.woff2 +0 -0
  269. package/app-template/src/assets/fonts/Jost/Jost-ThinItalic.eot +0 -0
  270. package/app-template/src/assets/fonts/Jost/Jost-ThinItalic.ttf +0 -0
  271. package/app-template/src/assets/fonts/Jost/Jost-ThinItalic.woff +0 -0
  272. package/app-template/src/assets/fonts/Jost/Jost-ThinItalic.woff2 +0 -0
  273. package/app-template/src/assets/fonts/Jost/index.scss +0 -269
  274. package/app-template/src/assets/fonts/index.scss +0 -1
  275. package/app-template/src/assets/fonts/pz-icon.css +0 -154
  276. package/app-template/src/assets/fonts/pz-icon.eot +0 -0
  277. package/app-template/src/assets/fonts/pz-icon.html +0 -456
  278. package/app-template/src/assets/fonts/pz-icon.scss +0 -300
  279. package/app-template/src/assets/fonts/pz-icon.svg +0 -144
  280. package/app-template/src/assets/fonts/pz-icon.ttf +0 -0
  281. package/app-template/src/assets/fonts/pz-icon.woff +0 -0
  282. package/app-template/src/assets/fonts/pz-icon.woff2 +0 -0
  283. package/app-template/src/assets/globals.scss +0 -65
  284. package/app-template/src/assets/icons/akinon.svg +0 -11
  285. package/app-template/src/assets/icons/arrow-up.svg +0 -11
  286. package/app-template/src/assets/icons/bell.svg +0 -1
  287. package/app-template/src/assets/icons/cart.svg +0 -13
  288. package/app-template/src/assets/icons/check.svg +0 -19
  289. package/app-template/src/assets/icons/chevron-down.svg +0 -8
  290. package/app-template/src/assets/icons/chevron-end.svg +0 -8
  291. package/app-template/src/assets/icons/chevron-start.svg +0 -8
  292. package/app-template/src/assets/icons/chevron-up.svg +0 -8
  293. package/app-template/src/assets/icons/close.svg +0 -12
  294. package/app-template/src/assets/icons/cvc.svg +0 -54
  295. package/app-template/src/assets/icons/default.svg +0 -6
  296. package/app-template/src/assets/icons/directions.svg +0 -14
  297. package/app-template/src/assets/icons/eye-off.svg +0 -10
  298. package/app-template/src/assets/icons/eye-on.svg +0 -17
  299. package/app-template/src/assets/icons/facebook-login.svg +0 -11
  300. package/app-template/src/assets/icons/facebook.svg +0 -9
  301. package/app-template/src/assets/icons/giftbox.svg +0 -22
  302. package/app-template/src/assets/icons/globe.svg +0 -12
  303. package/app-template/src/assets/icons/google-login.svg +0 -19
  304. package/app-template/src/assets/icons/google.svg +0 -9
  305. package/app-template/src/assets/icons/hamburger.svg +0 -5
  306. package/app-template/src/assets/icons/heart-full.svg +0 -20
  307. package/app-template/src/assets/icons/heart-stroke.svg +0 -22
  308. package/app-template/src/assets/icons/info.svg +0 -1
  309. package/app-template/src/assets/icons/instagram.svg +0 -14
  310. package/app-template/src/assets/icons/layout-2.svg +0 -7
  311. package/app-template/src/assets/icons/layout-3.svg +0 -4
  312. package/app-template/src/assets/icons/logo.svg +0 -24
  313. package/app-template/src/assets/icons/mail.svg +0 -1
  314. package/app-template/src/assets/icons/minus.svg +0 -4
  315. package/app-template/src/assets/icons/money.svg +0 -4
  316. package/app-template/src/assets/icons/mp-otp.svg +0 -1
  317. package/app-template/src/assets/icons/pin.svg +0 -16
  318. package/app-template/src/assets/icons/pinterest.svg +0 -12
  319. package/app-template/src/assets/icons/plus.svg +0 -5
  320. package/app-template/src/assets/icons/search.svg +0 -13
  321. package/app-template/src/assets/icons/share.svg +0 -10
  322. package/app-template/src/assets/icons/spinner.svg +0 -6
  323. package/app-template/src/assets/icons/store-pin.svg +0 -14
  324. package/app-template/src/assets/icons/track-order.svg +0 -1
  325. package/app-template/src/assets/icons/twitter.svg +0 -11
  326. package/app-template/src/assets/icons/user.svg +0 -14
  327. package/app-template/src/assets/icons/whatsapp.svg +0 -45
  328. package/app-template/src/components/__tests__/Modal.test.tsx +0 -103
  329. package/app-template/src/components/__tests__/accordion.test.tsx +0 -65
  330. package/app-template/src/components/__tests__/badge.test.tsx +0 -20
  331. package/app-template/src/components/__tests__/button.test.tsx +0 -59
  332. package/app-template/src/components/__tests__/checkbox.test.tsx +0 -57
  333. package/app-template/src/components/__tests__/file-input.test.tsx +0 -42
  334. package/app-template/src/components/__tests__/icon.test.tsx +0 -39
  335. package/app-template/src/components/__tests__/input.test.tsx +0 -69
  336. package/app-template/src/components/__tests__/language-select.test.tsx +0 -81
  337. package/app-template/src/components/__tests__/link.test.tsx +0 -65
  338. package/app-template/src/components/__tests__/price.test.tsx +0 -72
  339. package/app-template/src/components/__tests__/radio.test.tsx +0 -52
  340. package/app-template/src/components/__tests__/select.test.tsx +0 -115
  341. package/app-template/src/components/__tests__/tab.test.tsx +0 -101
  342. package/app-template/src/components/accordion.tsx +0 -64
  343. package/app-template/src/components/badge.tsx +0 -21
  344. package/app-template/src/components/button.tsx +0 -46
  345. package/app-template/src/components/canonical-url.tsx +0 -21
  346. package/app-template/src/components/carousel-core.tsx +0 -42
  347. package/app-template/src/components/checkbox.tsx +0 -29
  348. package/app-template/src/components/currency-select.tsx +0 -81
  349. package/app-template/src/components/custom-loader.tsx +0 -21
  350. package/app-template/src/components/dynamic-form.tsx +0 -17
  351. package/app-template/src/components/file-input.tsx +0 -8
  352. package/app-template/src/components/generate-form-fields.tsx +0 -349
  353. package/app-template/src/components/icon.tsx +0 -18
  354. package/app-template/src/components/index.ts +0 -41
  355. package/app-template/src/components/input.tsx +0 -122
  356. package/app-template/src/components/language-select.tsx +0 -33
  357. package/app-template/src/components/link.tsx +0 -53
  358. package/app-template/src/components/loader-spinner.tsx +0 -23
  359. package/app-template/src/components/modal.tsx +0 -66
  360. package/app-template/src/components/pagination.tsx +0 -267
  361. package/app-template/src/components/password-rules-feedback.tsx +0 -60
  362. package/app-template/src/components/price.tsx +0 -54
  363. package/app-template/src/components/pwa-tags.tsx +0 -233
  364. package/app-template/src/components/radio.tsx +0 -18
  365. package/app-template/src/components/react-portal.tsx +0 -47
  366. package/app-template/src/components/select.tsx +0 -70
  367. package/app-template/src/components/shimmer.tsx +0 -21
  368. package/app-template/src/components/skeleton-article.tsx +0 -15
  369. package/app-template/src/components/skeleton-product.tsx +0 -14
  370. package/app-template/src/components/skeleton-profile.tsx +0 -19
  371. package/app-template/src/components/skeleton-wrapper.tsx +0 -19
  372. package/app-template/src/components/skeleton.tsx +0 -37
  373. package/app-template/src/components/source.tsx +0 -12
  374. package/app-template/src/components/tab-panel.tsx +0 -10
  375. package/app-template/src/components/tab.tsx +0 -58
  376. package/app-template/src/components/tabs.tsx +0 -58
  377. package/app-template/src/components/types/index.ts +0 -89
  378. package/app-template/src/hooks/index.ts +0 -1
  379. package/app-template/src/hooks/use-add-product-to-basket.ts +0 -48
  380. package/app-template/src/hooks/use-contract.tsx +0 -58
  381. package/app-template/src/hooks/use-fav-button.tsx +0 -99
  382. package/app-template/src/instrumentation.ts +0 -1
  383. package/app-template/src/middleware.ts +0 -33
  384. package/app-template/src/pages/_error.js +0 -14
  385. package/app-template/src/pages/api/auth/[...nextauth].ts +0 -3
  386. package/app-template/src/plugins.js +0 -14
  387. package/app-template/src/redux/middlewares/category.ts +0 -42
  388. package/app-template/src/redux/reducers/category.ts +0 -67
  389. package/app-template/src/redux/store.ts +0 -47
  390. package/app-template/src/routes/index.ts +0 -46
  391. package/app-template/src/settings.js +0 -63
  392. package/app-template/src/theme.js +0 -1
  393. package/app-template/src/types/index.ts +0 -72
  394. package/app-template/src/types/next-auth.d.ts +0 -24
  395. package/app-template/src/types/widgets.ts +0 -115
  396. package/app-template/src/utils/convert-facet-search-params.ts +0 -15
  397. package/app-template/src/utils/generate-jsonld.ts +0 -23
  398. package/app-template/src/utils/gtm.ts +0 -247
  399. package/app-template/src/utils/index.ts +0 -60
  400. package/app-template/src/views/account/account-menu.tsx +0 -117
  401. package/app-template/src/views/account/address-card.tsx +0 -107
  402. package/app-template/src/views/account/address-form.tsx +0 -374
  403. package/app-template/src/views/account/back-button.tsx +0 -27
  404. package/app-template/src/views/account/contact-form.tsx +0 -283
  405. package/app-template/src/views/account/content-header.tsx +0 -52
  406. package/app-template/src/views/account/faq/faq-footer.tsx +0 -30
  407. package/app-template/src/views/account/faq/faq-search.tsx +0 -35
  408. package/app-template/src/views/account/faq/faq-tabs.tsx +0 -54
  409. package/app-template/src/views/account/faq/index.ts +0 -3
  410. package/app-template/src/views/account/favorite-item.tsx +0 -191
  411. package/app-template/src/views/account/favourite-products/favourite-products-list.tsx +0 -65
  412. package/app-template/src/views/account/index.ts +0 -4
  413. package/app-template/src/views/account/order.tsx +0 -89
  414. package/app-template/src/views/account/orders/order-cancellation-item.tsx +0 -99
  415. package/app-template/src/views/account/orders/order-detail-header.tsx +0 -39
  416. package/app-template/src/views/anonymous-tracking/index.tsx +0 -109
  417. package/app-template/src/views/anonymous-tracking/order-detail/index.tsx +0 -318
  418. package/app-template/src/views/basket/basket-item.tsx +0 -231
  419. package/app-template/src/views/basket/index.ts +0 -2
  420. package/app-template/src/views/basket/summary.tsx +0 -220
  421. package/app-template/src/views/breadcrumb.tsx +0 -35
  422. package/app-template/src/views/category/category-active-filters.tsx +0 -98
  423. package/app-template/src/views/category/category-banner.tsx +0 -34
  424. package/app-template/src/views/category/category-header.tsx +0 -143
  425. package/app-template/src/views/category/category-info.tsx +0 -123
  426. package/app-template/src/views/category/filters/index.tsx +0 -177
  427. package/app-template/src/views/category/filters/size-filter.tsx +0 -27
  428. package/app-template/src/views/category/layout.tsx +0 -38
  429. package/app-template/src/views/checkout/auth.tsx +0 -54
  430. package/app-template/src/views/checkout/index.tsx +0 -3
  431. package/app-template/src/views/checkout/layout/footer.tsx +0 -48
  432. package/app-template/src/views/checkout/layout/header.tsx +0 -38
  433. package/app-template/src/views/checkout/step-button.tsx +0 -69
  434. package/app-template/src/views/checkout/step-list.tsx +0 -51
  435. package/app-template/src/views/checkout/steps/payment/agreements.tsx +0 -42
  436. package/app-template/src/views/checkout/steps/payment/index.tsx +0 -31
  437. package/app-template/src/views/checkout/steps/payment/options/credit-card/index.tsx +0 -382
  438. package/app-template/src/views/checkout/steps/payment/options/credit-card/installments.tsx +0 -100
  439. package/app-template/src/views/checkout/steps/payment/options/credit-payment.tsx +0 -14
  440. package/app-template/src/views/checkout/steps/payment/options/funds-transfer.tsx +0 -174
  441. package/app-template/src/views/checkout/steps/payment/options/loyalty.tsx +0 -19
  442. package/app-template/src/views/checkout/steps/payment/options/pay-on-delivery.tsx +0 -15
  443. package/app-template/src/views/checkout/steps/payment/options/redirection.tsx +0 -94
  444. package/app-template/src/views/checkout/steps/payment/payment-header.tsx +0 -17
  445. package/app-template/src/views/checkout/steps/payment/payment-option-buttons.tsx +0 -73
  446. package/app-template/src/views/checkout/steps/shipping/address-box.tsx +0 -204
  447. package/app-template/src/views/checkout/steps/shipping/addresses.tsx +0 -189
  448. package/app-template/src/views/checkout/steps/shipping/index.tsx +0 -27
  449. package/app-template/src/views/checkout/steps/shipping/shipping-options.tsx +0 -72
  450. package/app-template/src/views/checkout/summary.tsx +0 -181
  451. package/app-template/src/views/coupon-item/index.tsx +0 -80
  452. package/app-template/src/views/find-in-store/index.tsx +0 -183
  453. package/app-template/src/views/footer.tsx +0 -21
  454. package/app-template/src/views/guest-login/index.tsx +0 -130
  455. package/app-template/src/views/header/action-menu.tsx +0 -117
  456. package/app-template/src/views/header/band.tsx +0 -32
  457. package/app-template/src/views/header/index.tsx +0 -66
  458. package/app-template/src/views/header/mini-basket.tsx +0 -267
  459. package/app-template/src/views/header/mobile-hamburger-button.tsx +0 -35
  460. package/app-template/src/views/header/mobile-menu.tsx +0 -144
  461. package/app-template/src/views/header/navbar.tsx +0 -186
  462. package/app-template/src/views/header/pwa-back-button.tsx +0 -60
  463. package/app-template/src/views/header/search/index.tsx +0 -82
  464. package/app-template/src/views/header/search/results.tsx +0 -123
  465. package/app-template/src/views/header/user-menu.tsx +0 -72
  466. package/app-template/src/views/index.tsx +0 -2
  467. package/app-template/src/views/installment-options/index.tsx +0 -127
  468. package/app-template/src/views/login/index.tsx +0 -233
  469. package/app-template/src/views/otp-login/index.tsx +0 -152
  470. package/app-template/src/views/page-loader-spinner/index.tsx +0 -9
  471. package/app-template/src/views/product/accordion-wrapper.tsx +0 -59
  472. package/app-template/src/views/product/combine-product-card.tsx +0 -82
  473. package/app-template/src/views/product/index.ts +0 -8
  474. package/app-template/src/views/product/layout.tsx +0 -40
  475. package/app-template/src/views/product/misc-buttons.tsx +0 -65
  476. package/app-template/src/views/product/price-wrapper.tsx +0 -41
  477. package/app-template/src/views/product/product-group-info.tsx +0 -63
  478. package/app-template/src/views/product/product-info.tsx +0 -273
  479. package/app-template/src/views/product/slider.tsx +0 -124
  480. package/app-template/src/views/product/variant.tsx +0 -104
  481. package/app-template/src/views/product-item/index.tsx +0 -96
  482. package/app-template/src/views/product-pointer-banner-item.tsx +0 -243
  483. package/app-template/src/views/register/index.tsx +0 -417
  484. package/app-template/src/views/root-modal.tsx +0 -21
  485. package/app-template/src/views/sales-contract-modal/index.tsx +0 -288
  486. package/app-template/src/views/share/index.tsx +0 -71
  487. package/app-template/src/views/widgets/home-hero-slider-content.tsx +0 -54
  488. package/app-template/src/views/widgets/recommendation-content.tsx +0 -86
  489. package/app-template/src/widgets/footer-copyright.tsx +0 -25
  490. package/app-template/src/widgets/footer-info.tsx +0 -78
  491. package/app-template/src/widgets/footer-menu.tsx +0 -258
  492. package/app-template/src/widgets/footer-social.tsx +0 -53
  493. package/app-template/src/widgets/footer-subscription/footer-subscription-form.tsx +0 -110
  494. package/app-template/src/widgets/footer-subscription/index.tsx +0 -30
  495. package/app-template/src/widgets/header-band-text.tsx +0 -21
  496. package/app-template/src/widgets/home-discovery.tsx +0 -191
  497. package/app-template/src/widgets/home-hero-slider.tsx +0 -36
  498. package/app-template/src/widgets/home-product-recommendation.tsx +0 -18
  499. package/app-template/src/widgets/home-single-banner.tsx +0 -87
  500. package/app-template/src/widgets/home-stories-eng.tsx +0 -112
  501. package/app-template/src/widgets/index.ts +0 -25
  502. package/app-template/src/widgets/product-pointer-banners.tsx +0 -35
  503. package/app-template/src/widgets/special-page-banner.tsx +0 -49
  504. package/app-template/src/widgets/special-page-carousel.tsx +0 -68
  505. package/app-template/src/widgets/widget-order.tsx +0 -1
  506. package/app-template/tailwind.config.js +0 -170
  507. package/app-template/tsconfig.json +0 -44
  508. package/app-template/tsconfig.test.json +0 -6
  509. package/app-template/yarn.lock +0 -11278
@@ -1,382 +0,0 @@
1
- import { yupResolver } from '@hookform/resolvers/yup';
2
- import clsx from 'clsx';
3
- import { useEffect, useState } from 'react';
4
- import { SubmitHandler, useForm } from 'react-hook-form';
5
- import { useAppSelector } from '@akinon/next/redux/hooks';
6
- import { RootState } from '@theme/redux/store';
7
- import {
8
- useCompleteCreditCardPaymentMutation,
9
- useSetBinNumberMutation
10
- } from '@akinon/next/data/client/checkout';
11
- import { CreditCardForm } from '@theme/types';
12
- import { Button, Icon, Input, Select } from '@theme/components';
13
- import * as yup from 'yup';
14
- import CheckoutAgreements from '../../agreements';
15
- import PaymentHeader from '../../payment-header';
16
- import CreditCardInstallments from './installments';
17
- import { useLocalization } from '@akinon/next/hooks';
18
- import { Image } from '@akinon/next/components/image';
19
- import { getPosError } from '@akinon/next/utils';
20
- import PluginModule, { Component } from '@akinon/next/components/plugin-module';
21
- import { PaymentOption } from '@akinon/next/types';
22
-
23
- const creditCardFormSchema = (
24
- t,
25
- payment_option: PaymentOption,
26
- isMasterpassDirectPurchase?: boolean
27
- ) => {
28
- if (
29
- payment_option?.payment_type === 'masterpass' &&
30
- isMasterpassDirectPurchase === false
31
- ) {
32
- return yup.object().shape({
33
- agreement: yup
34
- .boolean()
35
- .oneOf([true], t('checkout.payment.credit_card.form.error.required'))
36
- });
37
- }
38
-
39
- return yup.object().shape({
40
- card_holder: yup
41
- .string()
42
- .required(t('checkout.payment.credit_card.form.error.required'))
43
- .matches(
44
- /^[a-zA-ZğüşöçıİĞÜŞÖÇ\s]+$/,
45
- t('checkout.payment.credit_card.form.error.card_holder_matches')
46
- ),
47
- card_number: yup
48
- .string()
49
- .transform((value: string) => value.replace(/_/g, '').replace(/ /g, ''))
50
- .length(
51
- 16,
52
- t('checkout.payment.credit_card.form.error.card_number_length')
53
- )
54
- .required(t('checkout.payment.credit_card.form.error.required')),
55
- card_month: yup
56
- .string()
57
- .required(t('checkout.payment.credit_card.form.error.required')),
58
- card_year: yup
59
- .string()
60
- .required(t('checkout.payment.credit_card.form.error.required')),
61
- card_cvv: yup
62
- .string()
63
- .transform((value: string) => value.replace(/_/g, '').replace(/ /g, ''))
64
- .length(3, t('checkout.payment.credit_card.form.error.cvv_length'))
65
- .required(t('checkout.payment.credit_card.form.error.required')),
66
- installment: yup
67
- .number()
68
- .required(t('checkout.payment.credit_card.form.error.installment')),
69
- agreement: yup
70
- .boolean()
71
- .oneOf([true], t('checkout.payment.credit_card.form.error.required'))
72
- });
73
- };
74
-
75
- const CheckoutCreditCard = () => {
76
- const { installment, payment_option } = useAppSelector(
77
- (state: RootState) => state.checkout.preOrder
78
- );
79
- const { cardType } = useAppSelector((state: RootState) => state.checkout);
80
- const masterpass = useAppSelector((state: RootState) => state.masterpass);
81
- const { t } = useLocalization();
82
- const {
83
- register,
84
- handleSubmit,
85
- setValue: setFormValue,
86
- trigger: validateInput,
87
- control,
88
- formState: { errors },
89
- setError,
90
- getValues
91
- } = useForm<CreditCardForm>({
92
- resolver: yupResolver(
93
- creditCardFormSchema(t, payment_option, masterpass?.isDirectPurchase)
94
- )
95
- });
96
- const [months, setMonths] = useState([]);
97
- const [years, setYears] = useState([]);
98
- const [formError, setFormError] = useState(null);
99
- const [cardBinNumber, setCardBinNumber] = useState(null);
100
- const [setBinNumber] = useSetBinNumberMutation();
101
- const [completeCreditCardPayment] = useCompleteCreditCardPaymentMutation();
102
-
103
- const handleCardNumberChange = (value) => {
104
- const binNumber = value.replace(/\D/g, '').substring(0, 6);
105
-
106
- if (binNumber.length === 6) {
107
- if (cardBinNumber !== binNumber) {
108
- setBinNumber(binNumber);
109
- setCardBinNumber(binNumber);
110
- }
111
- } else if (cardBinNumber && binNumber.length < 6) {
112
- setCardBinNumber(null);
113
- }
114
- };
115
-
116
- const onSubmit: SubmitHandler<CreditCardForm> = async (data) => {
117
- const response = await completeCreditCardPayment(data).unwrap();
118
-
119
- setFormError(response?.errors);
120
- };
121
-
122
- useEffect(() => {
123
- const posErrors = getPosError();
124
-
125
- if (posErrors) {
126
- setFormError(posErrors);
127
- }
128
-
129
- const months = [
130
- {
131
- label: t('checkout.payment.credit_card.form.month.placeholder'),
132
- value: ''
133
- }
134
- ];
135
- const years = [
136
- {
137
- label: t('checkout.payment.credit_card.form.year.placeholder'),
138
- value: ''
139
- }
140
- ];
141
- const date = new Date();
142
- const currentYear = date.getFullYear();
143
-
144
- for (let i = 1; i <= 12; i++) {
145
- months.push({ label: i.toString(), value: i.toString() });
146
- }
147
-
148
- for (let i = currentYear; i < currentYear + 13; i++) {
149
- years.push({ label: i.toString(), value: i.toString() });
150
- }
151
-
152
- setMonths(months);
153
- setYears(years);
154
- }, []);
155
-
156
- useEffect(() => {
157
- if (installment?.pk) {
158
- setFormValue('installment', installment?.pk);
159
- validateInput('installment');
160
- }
161
- }, [installment?.pk, setFormValue, validateInput]);
162
-
163
- useEffect(() => {
164
- Object.keys(formError ?? {})
165
- .filter((key) => key !== 'non_field_errors')
166
- .forEach((item: keyof CreditCardForm) => {
167
- setError(item, {
168
- type: 'custom',
169
- message: formError[item].join(', ')
170
- });
171
- });
172
- }, [formError, setError]);
173
-
174
- return (
175
- <form
176
- className={clsx('flex flex-row flex-wrap w-full')}
177
- onSubmit={handleSubmit(onSubmit)}
178
- >
179
- <div className="w-full flex flex-col xl:w-6/10">
180
- {(payment_option?.payment_type === 'credit_card' ||
181
- (payment_option?.payment_type === 'masterpass' &&
182
- masterpass?.isDirectPurchase)) && (
183
- <>
184
- <PaymentHeader title={t('checkout.payment.credit_card.title')} />
185
-
186
- <div className="w-full bg-white">
187
- <div className="text-xs text-black-800 p-4 sm:p-6">
188
- {t('checkout.payment.credit_card.description')}
189
- </div>
190
-
191
- <div className="px-4 my-2 w-full flex justify-between flex-wrap pb-4 sm:px-6 sm:py-6">
192
- <div className="my-2 w-full sm:px-4">
193
- <Input
194
- label={t(
195
- 'checkout.payment.credit_card.form.cardholder_name.placeholder'
196
- )}
197
- {...register('card_holder')}
198
- error={errors.card_holder}
199
- data-testid="checkout-credit-card-holder"
200
- />
201
- </div>
202
-
203
- <div className="my-2 w-full flex flex-col sm:px-4">
204
- <div className="text-xs text-gray-800 mb-2 w-full flex justify-between items-center">
205
- <span>
206
- {t(
207
- 'checkout.payment.credit_card.form.card_number.placeholder'
208
- )}
209
- </span>
210
-
211
- {cardType?.logo && cardBinNumber && (
212
- <Image
213
- width={50}
214
- height={30}
215
- src={cardType?.logo}
216
- alt="bankLogo"
217
- />
218
- )}
219
- </div>
220
-
221
- <Input
222
- format="#### #### #### ####"
223
- mask="_"
224
- allowEmptyFormatting={true}
225
- control={control}
226
- onValueChange={(values) => {
227
- const { value } = values;
228
-
229
- handleCardNumberChange(value);
230
- }}
231
- {...register('card_number')}
232
- error={errors.card_number}
233
- data-testid="checkout-credit-card-number"
234
- />
235
- </div>
236
-
237
- <div className="w-full my-2 sm:flex">
238
- <div className="sm:w-2/3 sm:px-4">
239
- <label
240
- className="flex w-full text-xs text-start text-black-400 mb-1.5"
241
- htmlFor="card_month"
242
- >
243
- {t(
244
- 'checkout.payment.credit_card.form.expiration_date.title'
245
- )}
246
- </label>
247
-
248
- <div className="flex w-full h-10 space-x-2.5">
249
- <div className="w-2/4">
250
- <Select
251
- className="w-full text-xs border-gray-400 sm:text-sm"
252
- options={months}
253
- {...register('card_month')}
254
- error={errors.card_month}
255
- data-testid="checkout-credit-card-month"
256
- />
257
- </div>
258
-
259
- <div className="w-2/4">
260
- <Select
261
- className="w-full text-xs border-gray-400 sm:text-sm"
262
- options={years}
263
- {...register('card_year')}
264
- error={errors.card_year}
265
- data-testid="checkout-credit-card-year"
266
- />
267
- </div>
268
- </div>
269
- </div>
270
-
271
- <div className="my-2 sm:w-1/3 sm:px-4 sm:my-0">
272
- <label
273
- className="flex w-full text-xs text-start text-black-400 mb-1.5"
274
- htmlFor="card_cvv"
275
- >
276
- {t(
277
- 'checkout.payment.credit_card.form.security_code.title'
278
- )}
279
- </label>
280
- <Input
281
- format="###"
282
- mask="_"
283
- control={control}
284
- allowEmptyFormatting={true}
285
- {...register('card_cvv')}
286
- error={errors.card_cvv}
287
- data-testid="checkout-credit-card-cvv"
288
- />
289
- <div className="group relative flex items-center justify-start text-gray-600 cursor-pointer mt-2 transition-all hover:text-secondary">
290
- <span className="text-xs underline">
291
- {t(
292
- 'checkout.payment.credit_card.form.security_code.cvc'
293
- )}
294
- </span>
295
- <Icon
296
- name="cvc"
297
- size={16}
298
- className="leading-none ml-2"
299
- />
300
- <div className="hidden group-hover:block absolute right-0 bottom-5 w-[11rem] lg:w-[21rem] lg:left-auto lg:right-auto border-2">
301
- {/* TODO: Fix this */}
302
- <Image
303
- src="/cvv.jpg"
304
- alt="Cvv"
305
- width={385}
306
- height={262}
307
- />
308
- </div>
309
- </div>
310
- </div>
311
- </div>
312
- </div>
313
- </div>
314
- </>
315
- )}
316
-
317
- <PluginModule
318
- component={Component.MasterpassCardList}
319
- props={{
320
- className: 'p-10'
321
- }}
322
- />
323
-
324
- <PluginModule
325
- component={Component.MasterpassCardRegistration}
326
- props={{
327
- className: 'mt-5 mb-10 sm:px-10',
328
- getValues
329
- }}
330
- />
331
- </div>
332
-
333
- <div className="w-full flex flex-col border-gray-400 border-solid xl:w-4/10 xl:border-l xl:border-t-0">
334
- <PaymentHeader
335
- title={t('checkout.payment.installment_options.title')}
336
- />
337
-
338
- <div className="w-full border-solid border-gray-400 bg-white">
339
- <CreditCardInstallments error={errors.installment} />
340
-
341
- <div className="flex flex-col text-xs pb-4 px-4 sm:px-6 sm:pb-6 md:mt-0 mt-4">
342
- <CheckoutAgreements
343
- control={control}
344
- fieldId="agreement"
345
- error={errors.agreement}
346
- />
347
- {formError?.non_field_errors && (
348
- <div
349
- className="w-full text-xs text-start px-1 mt-3 text-error"
350
- data-testid="checkout-form-error"
351
- >
352
- {formError.non_field_errors}
353
- </div>
354
- )}
355
- {formError?.status && (
356
- <div
357
- className="w-full text-xs text-start px-1 mt-3 text-error"
358
- data-testid="checkout-form-error"
359
- >
360
- {formError.status}
361
- </div>
362
- )}
363
- <Button
364
- className="group uppercase mt-4 inline-flex items-center justify-center"
365
- type="submit"
366
- data-testid="checkout-credit-card-place-order"
367
- >
368
- <span>{t('checkout.payment.credit_card.form.button')}</span>
369
- <Icon
370
- name="chevron-end"
371
- size={12}
372
- className="fill-primary-foreground ml-2 h-3 group-hover:fill-primary"
373
- />
374
- </Button>
375
- </div>
376
- </div>
377
- </div>
378
- </form>
379
- );
380
- };
381
-
382
- export default CheckoutCreditCard;
@@ -1,100 +0,0 @@
1
- import { useAppSelector } from '@akinon/next/redux/hooks';
2
- import { RootState } from '@theme/redux/store';
3
- import { useSetInstallmentOptionMutation } from '@akinon/next/data/client/checkout';
4
- import { Radio, Price } from '@theme/components';
5
- import { useLocalization } from '@akinon/next/hooks';
6
-
7
- const CreditCardInstallments = ({ error }) => {
8
- const { t } = useLocalization();
9
- const { preOrder, cardType, installmentOptions } = useAppSelector(
10
- (state: RootState) => state.checkout
11
- );
12
- const [setInstallmentOption] = useSetInstallmentOptionMutation();
13
-
14
- const errorMessage = (
15
- <div className="px-6 mt-4 text-sm text-error">{error?.message}</div>
16
- );
17
-
18
- if (installmentOptions.length === 0) {
19
- return (
20
- <>
21
- <div className="text-xs text-black-800 p-4 sm:p-6">
22
- {t('checkout.payment.installment_options.description')}
23
- </div>
24
- </>
25
- );
26
- }
27
-
28
- return (
29
- <>
30
- <div>
31
- <div className="text-xs text-black-800 p-4">
32
- {t('checkout.payment.installment_options.installment')}:{' '}
33
- {cardType?.name ?? 'Other'}
34
- </div>
35
-
36
- <div className="px-4 mb-4 sm:px-6 sm:mb-6">
37
- <table className="w-full border-t border-b border-solid border-gray-400">
38
- <thead>
39
- <tr>
40
- <th
41
- scope="col"
42
- className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 border-0 text-start"
43
- >
44
- {t('checkout.payment.installment_options.payments')}
45
- </th>
46
- <th
47
- scope="col"
48
- className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 border-0 text-right"
49
- >
50
- {t('checkout.payment.installment_options.per_month')}
51
- </th>
52
- <th
53
- scope="col"
54
- className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 border-0 text-right"
55
- >
56
- {t('checkout.payment.installment_options.total')}
57
- </th>
58
- </tr>
59
- </thead>
60
- <tbody>
61
- {installmentOptions.map((option) => (
62
- <tr
63
- key={`installment-${option.pk}`}
64
- className="border-t border-solid border-gray-400"
65
- >
66
- <td className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 text-left">
67
- <Radio
68
- value={option.pk}
69
- name="installment"
70
- checked={option.pk === preOrder?.installment?.pk}
71
- onChange={() => {
72
- setInstallmentOption(option.pk);
73
- }}
74
- data-testid={`checkout-credit-card-installment-${option.pk}`}
75
- >
76
- <span className="w-full flex items-center justify-start pl-2">
77
- <span className="text-xs text-black-800 transition-all">
78
- {option.label}
79
- </span>
80
- </span>
81
- </Radio>
82
- </td>
83
- <td className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 text-right">
84
- <Price value={option.monthly_price_with_accrued_interest} />
85
- </td>
86
- <td className="text-xs font-normal border-e border-solid border-gray-400 px-2 py-2 text-right">
87
- <Price value={option.price_with_accrued_interest} />
88
- </td>
89
- </tr>
90
- ))}
91
- </tbody>
92
- </table>
93
- </div>
94
- {error && errorMessage}
95
- </div>
96
- </>
97
- );
98
- };
99
-
100
- export default CreditCardInstallments;
@@ -1,14 +0,0 @@
1
- import PluginModule, { Component } from '@akinon/next/components/plugin-module';
2
- import CheckoutAgreements from '../agreements';
3
-
4
- export default function CreditPayment() {
5
-
6
- return <PluginModule
7
- component={Component.CreditPayment}
8
- props={{
9
- agreementCheckbox: (
10
- <CheckoutAgreements control={null} error={null} fieldId="agreement" />
11
- )
12
- }}
13
- />
14
- }
@@ -1,174 +0,0 @@
1
- import { yupResolver } from '@hookform/resolvers/yup';
2
- import { useEffect, useState } from 'react';
3
- import { SubmitHandler, useForm } from 'react-hook-form';
4
- import { useAppSelector } from '@akinon/next/redux/hooks';
5
- import { RootState } from '@theme/redux/store';
6
- import {
7
- useCompleteFundsTransferMutation,
8
- useSetFundsTransferOptionMutation
9
- } from '@akinon/next/data/client/checkout';
10
- import { Button, Icon, Price, Radio } from '@theme/components';
11
- import * as yup from 'yup';
12
- import CheckoutAgreements from '../agreements';
13
- import PaymentHeader from '../payment-header';
14
- import { useLocalization } from '@akinon/next/hooks';
15
- import { Image } from '@akinon/next/components/image';
16
- import PaymentOptionButtons from '../payment-option-buttons';
17
- import { Trans } from '@akinon/next/components/trans';
18
-
19
- const fundsTransferFormSchema = (t) =>
20
- yup.object().shape({
21
- agreement: yup.boolean().oneOf([true], 'This field is required.')
22
- });
23
-
24
- const CheckoutFundsTransfer = () => {
25
- const { t } = useLocalization();
26
- const {
27
- handleSubmit,
28
- control,
29
- formState: { errors }
30
- } = useForm({
31
- resolver: yupResolver(fundsTransferFormSchema(t))
32
- });
33
- const [formError, setFormError] = useState(null);
34
- const { bankAccounts, selectedBankAccountPk, preOrder } = useAppSelector(
35
- (state: RootState) => state.checkout
36
- );
37
- const [setFundsTransferOption] = useSetFundsTransferOptionMutation();
38
- const [completeFundsTransfer] = useCompleteFundsTransferMutation();
39
-
40
- const onSubmit: SubmitHandler<null> = async () => {
41
- const response = await completeFundsTransfer().unwrap();
42
-
43
- setFormError(response?.errors?.non_field_errors);
44
- };
45
-
46
- useEffect(() => {
47
- if (!selectedBankAccountPk && bankAccounts?.length) {
48
- setFundsTransferOption(bankAccounts[0].pk);
49
- }
50
- }, [bankAccounts, selectedBankAccountPk, setFundsTransferOption]);
51
-
52
- return (
53
- <form className="flex flex-col w-full" onSubmit={handleSubmit(onSubmit)}>
54
- <PaymentHeader title={t('checkout.payment.fund_transfer.title')} />
55
-
56
- <div className="w-full bg-white">
57
- <div className="text-xs text-black-800 p-4 sm:p-6">
58
- <p className="w-full mb-2">
59
- {t('checkout.payment.fund_transfer.description')}
60
- </p>
61
-
62
- <p className="w-full">
63
- <span className="text-soft block sm:inline-block">
64
- {t('checkout.payment.fund_transfer.account_title')}{' '}
65
- <b>
66
- {t('checkout.payment.fund_transfer.receiver')}: Project Zero
67
- Ltd. Sti
68
- </b>
69
- </span>
70
- </p>
71
- </div>
72
- </div>
73
- <div className="px-4 sm:px-6">
74
- {bankAccounts.map((bankAccount) => (
75
- <div
76
- key={`bank-account-${bankAccount.pk}`}
77
- className="w-full border-t border-solid border-gray-400 py-4 last:border-b"
78
- >
79
- <label className="w-full flex items-center justify-start">
80
- <Radio
81
- name="bank_account"
82
- type="radio"
83
- value={bankAccount.pk}
84
- checked={bankAccount.pk === selectedBankAccountPk}
85
- onChange={() => {
86
- setFundsTransferOption(bankAccount.pk);
87
- }}
88
- data-testid={`checkout-bank-account-${bankAccount.pk}`}
89
- ></Radio>
90
-
91
- <span className="w-full flex items-start justify-start flex-col pl-3 sm:flex-row sm:items-center sm:pl-0">
92
- <div className="flex items-center justify-start sm:w-32 sm:px-3">
93
- <Image
94
- src={bankAccount.bank.logo}
95
- alt={bankAccount.bank.name}
96
- width={80}
97
- height={24}
98
- className="object-contain"
99
- />
100
- </div>
101
-
102
- <div className="flex flex-1 items-start justify-start flex-col sm:flex-row sm:items-center">
103
- <span className="min-w-max text-black-800 text-xs">
104
- {bankAccount.bank.name} IBAN:
105
- </span>
106
- <span className="text-black-800 text-xs sm:pl-1">
107
- {bankAccount.iban}
108
- </span>
109
- </div>
110
- </span>
111
- </label>
112
- </div>
113
- ))}
114
- </div>
115
- <div className="flex flex-1 items-start justify-start flex-col sm:flex-row sm:items-center">
116
- <div className="text-xs text-black-800 p-4 sm:p-6">
117
- <p className="w-full mb-1">
118
- {t('checkout.payment.fund_transfer.attention')}
119
- </p>
120
-
121
- <p className="w-full mb-1">
122
- {t('checkout.payment.fund_transfer.transfer_amount_title')}
123
-
124
- <Price className="ml-1" value={preOrder?.total_amount} />
125
- </p>
126
-
127
- <p className="w-full mb-2 soft text-[#508bc9]">
128
- <Trans
129
- i18nKey="checkout.payment.fund_transfer.info_first"
130
- components={{
131
- BoldTitle: (
132
- <b>{t('checkout.payment.fund_transfer.bold_title')}</b>
133
- )
134
- }}
135
- />
136
- </p>
137
-
138
- <p className="w-full mb-1">
139
- <i>{t('checkout.payment.fund_transfer.info_second')}</i>
140
- </p>
141
- </div>
142
- </div>
143
-
144
- <div className="px-4 sm:px-6">
145
- <div className="flex items-start flex-col border-t border-solid border-gray-400 py-4 space-y-4">
146
- <CheckoutAgreements
147
- control={control}
148
- fieldId="agreement"
149
- error={errors.agreement}
150
- />
151
- {formError && (
152
- <div className="w-full text-xs text-start px-1 mt-3 text-error">
153
- {formError}
154
- </div>
155
- )}
156
- <Button
157
- className="group uppercase mt-4 inline-flex items-center justify-center w-full"
158
- type="submit"
159
- data-testid="checkout-bank-account-place-order"
160
- >
161
- <span> {t('checkout.payment.fund_transfer.button')}</span>
162
- <Icon
163
- name="chevron-end"
164
- size={12}
165
- className="fill-primary-foreground ml-2 h-3 group-hover:fill-primary"
166
- />
167
- </Button>
168
- </div>
169
- </div>
170
- </form>
171
- );
172
- };
173
-
174
- export default CheckoutFundsTransfer;
@@ -1,19 +0,0 @@
1
- 'use client';
2
-
3
- import { useCompleteLoyaltyPaymentMutation } from '@akinon/next/data/client/checkout';
4
- import { useAppSelector } from '@akinon/next/redux/hooks';
5
- import { useForm } from 'react-hook-form';
6
-
7
- export default function LoyaltyPayment() {
8
- const { payment_option } = useAppSelector((state) => state.checkout.preOrder);
9
- const { handleSubmit } = useForm();
10
- const [completeLoyaltyPayment] = useCompleteLoyaltyPaymentMutation();
11
-
12
- const onSubmit = async () => {
13
- completeLoyaltyPayment();
14
- };
15
-
16
- return (
17
- <form onSubmit={handleSubmit(onSubmit)} id={payment_option.slug}></form>
18
- );
19
- }