@evershop/evershop 1.0.0 → 1.2.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 (519) hide show
  1. package/bin/build/client/index.js +1 -1
  2. package/bin/build/complie.js +1 -1
  3. package/bin/build/index.js +25 -1
  4. package/bin/build/server/index.js +1 -1
  5. package/bin/build/server/useDDL.js +1 -1
  6. package/bin/dev/index.js +2 -1
  7. package/bin/evershop +8 -7
  8. package/bin/extension/index.js +3 -3
  9. package/bin/install/index.js +1 -1
  10. package/bin/lib/addDefaultMiddlewareFuncs.js +9 -4
  11. package/bin/lib/app.js +1 -1
  12. package/bin/lib/bootstrap/migrate.js +1 -1
  13. package/bin/lib/buildEntry.js +16 -1
  14. package/bin/lib/onError.js +1 -1
  15. package/bin/lib/onListening.js +7 -4
  16. package/bin/lib/startUp.js +16 -9
  17. package/bin/lib/watch/watchComponents.js +16 -26
  18. package/bin/lib/watch/watchMF.js +1 -1
  19. package/bin/lib/watch/watchMR.js +1 -1
  20. package/bin/lib/watch/watchSchema.js +1 -1
  21. package/bin/user/changePassword.js +1 -1
  22. package/bin/user/create.js +1 -1
  23. package/package.json +10 -2
  24. package/src/components/admin/catalog/productEdit/category/CategoryItem.jsx +3 -8
  25. package/src/components/admin/catalog/productEdit/category/CategoryTree.jsx +15 -8
  26. package/src/components/admin/catalog/productEdit/category/CategoryTree.scss +10 -0
  27. package/src/components/admin/catalog/productEdit/variants/CreateVariant.jsx +2 -2
  28. package/src/components/admin/catalog/productEdit/variants/CreateVariantGroup.jsx +4 -9
  29. package/src/components/admin/catalog/productEdit/variants/EditVariant.jsx +1 -1
  30. package/src/components/admin/catalog/productEdit/variants/New.jsx +2 -2
  31. package/src/components/admin/catalog/productEdit/variants/Search.jsx +1 -1
  32. package/src/components/admin/catalog/productEdit/variants/SearchModal.jsx +1 -1
  33. package/src/components/admin/catalog/productEdit/variants/Variant.jsx +1 -1
  34. package/src/components/admin/catalog/productEdit/variants/VariantModal.jsx +68 -12
  35. package/src/components/admin/catalog/productEdit/variants/Variants.jsx +1 -1
  36. package/src/components/admin/catalog/productGrid/rows/ThumbnailRow.jsx +1 -1
  37. package/src/components/admin/checkout/shippingSetting/Method.jsx +130 -0
  38. package/src/components/admin/{oms → checkout}/shippingSetting/MethodForm.jsx +127 -16
  39. package/src/components/admin/{oms → checkout}/shippingSetting/Methods.jsx +5 -5
  40. package/src/components/admin/checkout/shippingSetting/PriceBasedPrice.jsx +101 -0
  41. package/src/components/admin/checkout/shippingSetting/WeightBasedPrice.jsx +101 -0
  42. package/src/components/admin/{oms → checkout}/shippingSetting/Zone.jsx +40 -10
  43. package/src/components/admin/{oms → checkout}/shippingSetting/ZoneForm.jsx +1 -1
  44. package/src/components/admin/{oms → checkout}/shippingSetting/Zones.jsx +6 -3
  45. package/src/components/admin/cms/Card.jsx +3 -3
  46. package/src/components/admin/cms/PageHeading.jsx +3 -3
  47. package/src/components/admin/cms/widget/WidgetTypes.jsx +28 -0
  48. package/src/components/admin/cms/widget/grid/WidgetTypeRow.jsx +29 -0
  49. package/src/components/admin/oms/orderEdit/items/ItemVariantOptions.jsx +1 -1
  50. package/src/components/admin/oms/orderEdit/items/Name.jsx +1 -1
  51. package/src/components/admin/oms/orderGrid/headers/OrderDateColumnHeader.jsx +1 -1
  52. package/src/components/admin/promotion/couponEdit/AttributeGroupSelector.jsx +8 -8
  53. package/src/components/admin/promotion/couponEdit/BuyXGetY.jsx +2 -2
  54. package/src/components/admin/promotion/couponEdit/CategorySelector.jsx +10 -10
  55. package/src/components/admin/promotion/couponEdit/CollectionSelector.jsx +8 -8
  56. package/src/components/admin/promotion/couponEdit/ProductSkuSelector.jsx +30 -9
  57. package/src/components/admin/promotion/couponEdit/RequireProducts.jsx +2 -2
  58. package/src/components/admin/promotion/couponEdit/Setting.jsx +1 -1
  59. package/src/components/admin/promotion/couponEdit/TargetProducts.jsx +4 -4
  60. package/src/components/admin/tax/taxSetting/Rate.jsx +6 -6
  61. package/src/components/admin/tax/taxSetting/RateForm.jsx +5 -5
  62. package/src/components/admin/tax/taxSetting/Rates.jsx +6 -6
  63. package/src/components/admin/tax/taxSetting/TaxClass.jsx +3 -3
  64. package/src/components/admin/tax/taxSetting/TaxClassForm.jsx +1 -1
  65. package/src/components/admin/widgets/BasicMenuSetting.jsx +614 -0
  66. package/src/components/admin/widgets/BasicMenuSetting.scss +19 -0
  67. package/src/components/admin/widgets/CollectionProductsSetting.jsx +203 -0
  68. package/src/components/admin/widgets/TextBlockSetting.jsx +70 -0
  69. package/src/components/common/Area.jsx +31 -8
  70. package/src/components/common/Badge.jsx +1 -1
  71. package/src/components/common/Editor.jsx +191 -0
  72. package/src/components/common/Notification.scss +1 -0
  73. package/src/components/common/SimplePagination.jsx +2 -2
  74. package/src/components/common/context/checkout.jsx +8 -14
  75. package/src/components/common/form/Field.jsx +1 -1
  76. package/src/components/common/form/Form.jsx +1 -1
  77. package/src/components/common/form/fields/Checkbox.jsx +1 -1
  78. package/src/components/common/form/fields/Ckeditor.jsx +11 -11
  79. package/src/components/common/form/fields/Editor.jsx +326 -0
  80. package/src/components/common/form/fields/Editor.scss +29 -0
  81. package/src/components/common/form/fields/Input.jsx +2 -1
  82. package/src/components/common/form/fields/Radio.jsx +1 -1
  83. package/src/components/common/form/fields/editor/FileBrowser.jsx +419 -0
  84. package/src/components/common/form/fields/editor/FileBrowser.scss +37 -0
  85. package/src/components/common/form/fields/editor/GetColumnClasses.jsx +14 -0
  86. package/src/components/common/form/fields/editor/GetRowClasses.jsx +18 -0
  87. package/src/components/common/form/fields/editor/RowTemplates.jsx +154 -0
  88. package/src/components/common/form/validator.js +6 -2
  89. package/src/components/common/grid/Pagination.jsx +4 -4
  90. package/src/components/common/grid/headers/Dummy.jsx +1 -1
  91. package/src/components/common/grid/headers/FromTo.jsx +1 -1
  92. package/src/components/common/grid/headers/Sortable.jsx +148 -0
  93. package/src/components/common/grid/rows/StatusRow.jsx +1 -1
  94. package/src/components/common/grid/rows/ThumbnailRow.jsx +1 -1
  95. package/src/components/common/list/Filter.jsx +83 -0
  96. package/src/components/common/list/Filter.scss +39 -0
  97. package/src/components/common/modal/Alert.jsx +1 -1
  98. package/src/components/common/modal/Modal.jsx +1 -1
  99. package/src/components/frontStore/catalog/categoryView/filter/AttributeFilter.jsx +21 -7
  100. package/src/components/frontStore/catalog/categoryView/filter/CategoryFilter.jsx +61 -53
  101. package/src/components/frontStore/catalog/categoryView/filter/CategoryFilter.scss +5 -0
  102. package/src/components/frontStore/catalog/categoryView/filter/PriceFilter.jsx +20 -11
  103. package/src/components/frontStore/catalog/product/list/List.jsx +4 -4
  104. package/src/components/frontStore/catalog/product/list/Pagination.jsx +1 -1
  105. package/src/components/frontStore/catalog/product/list/SortOptions.jsx +4 -2
  106. package/src/components/frontStore/catalog/product/list/Sorting.jsx +7 -7
  107. package/src/components/frontStore/catalog/product/list/item/Name.jsx +1 -1
  108. package/src/components/frontStore/checkout/cart/Empty.jsx +3 -3
  109. package/src/components/frontStore/checkout/cart/items/ItemOptions.jsx +1 -1
  110. package/src/components/frontStore/checkout/cart/items/ItemVariantOptions.jsx +1 -1
  111. package/src/components/frontStore/checkout/cart/items/Items.jsx +20 -21
  112. package/src/components/frontStore/checkout/cart/items/Items.scss +47 -0
  113. package/src/components/frontStore/checkout/cart/items/Quantity.jsx +154 -0
  114. package/src/components/frontStore/checkout/checkout/StepTitle.jsx +1 -1
  115. package/src/components/frontStore/checkout/checkout/payment/paymentStep/StepContent.jsx +13 -10
  116. package/src/components/frontStore/checkout/checkout/shipment/StepContent.jsx +1 -1
  117. package/src/components/frontStore/checkout/checkout/summary/Cart.jsx +10 -12
  118. package/src/components/frontStore/checkout/checkout/summary/Items.jsx +9 -9
  119. package/src/components/frontStore/checkout/checkout/summary/cart/Total.jsx +6 -6
  120. package/src/components/frontStore/checkout/success/summary/items/ItemOptions.jsx +1 -1
  121. package/src/components/frontStore/checkout/success/summary/items/Items.jsx +9 -6
  122. package/src/components/frontStore/checkout/success/summary/order/OrderSummary.jsx +9 -13
  123. package/src/components/frontStore/checkout/success/summary/order/Total.jsx +5 -5
  124. package/src/components/frontStore/customer/address/addressForm/AddressFormLoadingSkeleton.jsx +2 -2
  125. package/src/components/frontStore/customer/address/addressForm/NameAndTelephone.jsx +1 -1
  126. package/src/components/frontStore/customer/address/addressForm/ProvinceAndPostcode.jsx +1 -1
  127. package/src/components/frontStore/customer/checkout/Edit.jsx +2 -2
  128. package/src/components/frontStore/customer/detail/Order.jsx +4 -4
  129. package/src/components/frontStore/stripe/checkout/CheckoutForm.jsx +9 -5
  130. package/src/components/frontStore/stripe/checkout/TestCards.jsx +1 -1
  131. package/src/components/frontStore/widgets/BasicMenu.jsx +129 -0
  132. package/src/{modules/catalog/pages/frontStore/homepage/FeaturedProducts.jsx → components/frontStore/widgets/CollectionProducts.jsx} +40 -32
  133. package/src/components/frontStore/widgets/TextBlock.jsx +46 -0
  134. package/src/lib/componee/getComponentsByRoute.js +15 -2
  135. package/src/lib/event/callSubscibers.js +14 -11
  136. package/src/lib/event/event-manager.js +2 -2
  137. package/src/lib/event/loadSubscribers.js +2 -2
  138. package/src/lib/helpers.js +3 -1
  139. package/src/lib/log/CustomColorize.js +22 -0
  140. package/src/lib/log/logger.js +153 -19
  141. package/src/lib/middleware/Handler.js +2 -3
  142. package/src/lib/middleware/async.js +5 -9
  143. package/src/lib/middleware/sync.js +5 -10
  144. package/src/lib/middleware/tests/app/app.js +1 -1
  145. package/src/lib/middleware/tests/app/modules/404page/pages/frontStore/product/route.json +2 -1
  146. package/src/lib/middlewares/static.js +3 -1
  147. package/src/lib/response/render.js +5 -6
  148. package/src/lib/router/Router.js +1 -1
  149. package/src/lib/router/buildAbsoluteUrl.js +1 -1
  150. package/src/lib/router/loadModuleRoutes.js +3 -0
  151. package/src/lib/router/registerAdminRoute.js +9 -1
  152. package/src/lib/router/registerFrontStoreRoute.js +2 -0
  153. package/src/lib/router/scanForRoutes.js +1 -0
  154. package/src/lib/router/tests/unit/unit.validateRoute.test.js +7 -1
  155. package/src/lib/util/buildFilterFromUrl.js +31 -64
  156. package/src/lib/util/defaultPaginationFilters.js +104 -0
  157. package/src/lib/util/filterOperationMapp.js +16 -0
  158. package/src/lib/util/getEnabledWidgets.js +28 -0
  159. package/src/lib/util/merge.js +67 -14
  160. package/src/lib/util/registry.js +44 -6
  161. package/src/lib/util/tests/unit/util.merge.test.js +21 -4
  162. package/src/lib/util/validateConfiguration.js +83 -0
  163. package/src/lib/webpack/createBaseConfig.js +4 -1
  164. package/src/lib/webpack/dev/createConfigClient.js +12 -2
  165. package/src/lib/webpack/loaders/AreaLoader.js +15 -4
  166. package/src/lib/webpack/loaders/loadTranslationFromCsv.js +1 -1
  167. package/src/lib/webpack/plugins/Tailwindcss.js +1 -1
  168. package/src/lib/webpack/util/parseGraphql.js +29 -16
  169. package/src/lib/webpack/util/parseGraphqlByFile.js +16 -2
  170. package/src/modules/auth/graphql/types/AdminUser/AdminUser.admin.resolvers.js +6 -6
  171. package/src/modules/auth/pages/admin/adminLogin/LoginForm.jsx +55 -36
  172. package/src/modules/auth/pages/admin/all/AdminUser.jsx +3 -3
  173. package/src/modules/base/api/global/[apiResponse]apiErrorHandler.js +2 -2
  174. package/src/modules/base/bootstrap.js +79 -0
  175. package/src/modules/base/graphql/types/Route/Route.admin.graphql +15 -0
  176. package/src/modules/base/graphql/types/Route/Route.admin.resolvers.js +10 -0
  177. package/src/modules/base/pages/global/[response]errorHandler.js +2 -2
  178. package/src/modules/base/pages/global/response[errorHandler].js +23 -0
  179. package/src/modules/catalog/api/addProductToCategory/addProducts.js +1 -1
  180. package/src/modules/catalog/api/addProductToCollection/addProducts.js +35 -22
  181. package/src/modules/catalog/api/removeProductFromCollection/removeProducts.js +20 -5
  182. package/src/modules/catalog/bootstrap.js +188 -5
  183. package/src/modules/catalog/graphql/types/Attribute/Attribute.admin.graphql +2 -2
  184. package/src/modules/catalog/graphql/types/Attribute/Attribute.admin.resolvers.js +48 -276
  185. package/src/modules/catalog/graphql/types/Category/Category.graphql +19 -5
  186. package/src/modules/catalog/graphql/types/Category/Category.resolvers.js +36 -2
  187. package/src/modules/catalog/graphql/types/Collection/Collection.graphql +2 -2
  188. package/src/modules/catalog/graphql/types/Collection/Collection.resolvers.js +36 -2
  189. package/src/modules/catalog/graphql/types/Product/Attribute/ProductAttribute.resolvers.js +1 -0
  190. package/src/modules/catalog/graphql/types/Product/Product.graphql +1 -1
  191. package/src/modules/catalog/graphql/types/Product/Product.resolvers.js +35 -1
  192. package/src/modules/catalog/graphql/types/Product/Variant/Variant.graphql +2 -2
  193. package/src/modules/catalog/graphql/types/Product/Variant/Variant.resolvers.js +68 -92
  194. package/src/modules/catalog/graphql/types/Widget/CollectionProductsWidget/CollectionProductsWidget.graphql +11 -0
  195. package/src/modules/catalog/graphql/types/Widget/CollectionProductsWidget/CollectionProductsWidget.resolvers.js +8 -0
  196. package/src/modules/catalog/migration/Version-1.0.0.js +1 -0
  197. package/src/modules/catalog/migration/Version-1.0.7.js +10 -0
  198. package/src/modules/catalog/pages/admin/attributeEdit+attributeNew/FormContent.jsx +4 -4
  199. package/src/modules/catalog/pages/admin/attributeEdit+attributeNew/General.jsx +18 -14
  200. package/src/modules/catalog/pages/admin/attributeGrid/Grid.jsx +84 -41
  201. package/src/modules/catalog/pages/admin/attributeGrid/index.js +1 -1
  202. package/src/modules/catalog/pages/admin/categoryEdit/Products.jsx +9 -9
  203. package/src/modules/catalog/pages/admin/categoryEdit+categoryNew/FormContent.jsx +4 -4
  204. package/src/modules/catalog/pages/admin/categoryEdit+categoryNew/General.jsx +16 -18
  205. package/src/modules/catalog/pages/admin/categoryEdit+categoryNew/Image.jsx +1 -2
  206. package/src/modules/catalog/pages/admin/categoryEdit+categoryNew/Status.jsx +16 -1
  207. package/src/modules/catalog/pages/admin/categoryGrid/Grid.jsx +50 -18
  208. package/src/modules/catalog/pages/admin/categoryGrid/index.js +1 -1
  209. package/src/modules/catalog/pages/admin/collectionEdit/Products.jsx +9 -9
  210. package/src/modules/catalog/pages/admin/collectionEdit+collectionNew/FormContent.jsx +2 -2
  211. package/src/modules/catalog/pages/admin/collectionEdit+collectionNew/General.jsx +2 -2
  212. package/src/modules/catalog/pages/admin/collectionGrid/Grid.jsx +48 -7
  213. package/src/modules/catalog/pages/admin/collectionGrid/index.js +1 -1
  214. package/src/modules/catalog/pages/admin/productEdit/Collection.jsx +7 -7
  215. package/src/modules/catalog/pages/admin/productEdit+productNew/Attributes.jsx +29 -25
  216. package/src/modules/catalog/pages/admin/productEdit+productNew/CustomOptions.jsss +4 -4
  217. package/src/modules/catalog/pages/admin/productEdit+productNew/FormContent.jsx +4 -4
  218. package/src/modules/catalog/pages/admin/productEdit+productNew/General.jsx +15 -17
  219. package/src/modules/catalog/pages/admin/productGrid/Grid.jsx +160 -28
  220. package/src/modules/catalog/pages/admin/productGrid/index.js +1 -2
  221. package/src/modules/catalog/pages/frontStore/all/SearchBox.jsx +2 -1
  222. package/src/modules/catalog/pages/frontStore/catalogSearch/General.jsx +2 -2
  223. package/src/modules/catalog/pages/frontStore/catalogSearch/Products.jsx +1 -1
  224. package/src/modules/catalog/pages/frontStore/catalogSearch/[index]filters.js +4 -59
  225. package/src/modules/catalog/pages/frontStore/catalogSearch/index.js +11 -0
  226. package/src/modules/catalog/pages/frontStore/catalogSearch/route.json +2 -1
  227. package/src/modules/catalog/pages/frontStore/categoryView/CategoryView.jsx +19 -2
  228. package/src/modules/catalog/pages/frontStore/categoryView/Filter.jsx +22 -6
  229. package/src/modules/catalog/pages/frontStore/categoryView/Filter.scss +3 -0
  230. package/src/modules/catalog/pages/frontStore/categoryView/General.jsx +6 -8
  231. package/src/modules/catalog/pages/frontStore/categoryView/General.scss +0 -2
  232. package/src/modules/catalog/pages/frontStore/categoryView/Pagination.jsx +6 -0
  233. package/src/modules/catalog/pages/frontStore/categoryView/Products.jsx +8 -1
  234. package/src/modules/catalog/pages/frontStore/categoryView/[index]filters.js +5 -105
  235. package/src/modules/catalog/pages/frontStore/categoryView/route.json +2 -1
  236. package/src/modules/catalog/pages/frontStore/productView/Description.jsx +3 -3
  237. package/src/modules/catalog/pages/frontStore/productView/Form.jsx +12 -7
  238. package/src/modules/catalog/pages/frontStore/productView/Form.scss +1 -0
  239. package/src/modules/catalog/pages/frontStore/productView/GeneralInfo.jsx +1 -1
  240. package/src/modules/catalog/pages/frontStore/productView/Images.jsx +1 -1
  241. package/src/modules/catalog/pages/frontStore/productView/Layout.jsx +1 -1
  242. package/src/modules/catalog/pages/frontStore/productView/Options.jsx +2 -2
  243. package/src/modules/catalog/pages/frontStore/productView/Variants.jsx +106 -44
  244. package/src/modules/catalog/pages/frontStore/productView/route.json +2 -1
  245. package/src/modules/catalog/services/AttributeCollection.js +59 -0
  246. package/src/modules/catalog/services/AttributeGroupCollection.js +100 -0
  247. package/src/modules/catalog/services/CategoryCollection.js +26 -83
  248. package/src/modules/catalog/services/CollectionCollection.js +23 -71
  249. package/src/modules/catalog/services/ProductCollection.js +50 -216
  250. package/src/modules/catalog/services/attribute/deleteProductAttribute.js +15 -0
  251. package/src/modules/catalog/services/getAttributeGroupsBaseQuery.js +3 -0
  252. package/src/modules/catalog/services/getAttributesBaseQuery.js +3 -0
  253. package/src/modules/catalog/services/getCollectionsBaseQuery.js +0 -1
  254. package/src/modules/catalog/services/product/updateProduct.js +8 -2
  255. package/src/modules/catalog/services/registerCartItemProductUrlField.js +35 -0
  256. package/src/modules/catalog/services/registerCartItemVariantOptionsField.js +51 -0
  257. package/src/modules/catalog/services/registerDefaultAttributeCollectionFilters.js +149 -0
  258. package/src/modules/catalog/services/registerDefaultCategoryCollectionFilters.js +101 -0
  259. package/src/modules/catalog/services/registerDefaultCollectionCollectionFilters.js +65 -0
  260. package/src/modules/catalog/services/registerDefaultProductCollectionFilters.js +219 -0
  261. package/src/modules/catalog/subscribers/category_created/buildUrlRewrite.js +1 -1
  262. package/src/modules/catalog/subscribers/category_deleted/deleteUrlRewrite.js +1 -1
  263. package/src/modules/catalog/subscribers/category_updated/builUrlRewrite.js +1 -1
  264. package/src/modules/catalog/subscribers/product_created/builUrlRewrite.js +1 -1
  265. package/src/modules/catalog/subscribers/product_deleted/deleteUrlRewrite.js +1 -1
  266. package/src/modules/catalog/subscribers/product_image_added/localGenerateProductImageVariant.js +3 -3
  267. package/src/modules/checkout/api/addCartShippingMethod/saveShippingMethod.js +6 -1
  268. package/src/modules/checkout/api/addShippingNote/[context]bodyParser[auth].js +5 -0
  269. package/src/modules/checkout/api/addShippingNote/payloadSchema.json +15 -0
  270. package/src/modules/checkout/api/addShippingNote/route.json +5 -0
  271. package/src/modules/checkout/api/addShippingNote/saveShippingNote.js +50 -0
  272. package/src/modules/checkout/api/createCart/[context]bodyParser[auth].js +5 -0
  273. package/src/modules/checkout/api/createCart/createNewCart.js +119 -0
  274. package/src/modules/checkout/api/createCart/payloadSchema.json +44 -0
  275. package/src/modules/checkout/api/createCart/route.json +5 -0
  276. package/src/modules/checkout/api/deleteShippingZone/deleteShippingZone.js +58 -0
  277. package/src/modules/checkout/api/deleteShippingZone/route.json +5 -0
  278. package/src/modules/checkout/api/deleteShippingZoneMethod/deleteShippingZoneMethod.js +85 -0
  279. package/src/modules/checkout/api/deleteShippingZoneMethod/route.json +5 -0
  280. package/src/modules/checkout/api/getShippingMethods/sendMethods.js +37 -0
  281. package/src/modules/checkout/api/updateCartItemQty/[bodyParser]updateQty.js +49 -0
  282. package/src/modules/checkout/api/updateCartItemQty/[context]bodyParser[auth].js +5 -0
  283. package/src/modules/checkout/api/updateCartItemQty/payloadSchema.json +21 -0
  284. package/src/modules/checkout/api/updateCartItemQty/route.json +5 -0
  285. package/src/modules/checkout/api/updateMineCartItemQty/[context]bodyParser[auth].js +5 -0
  286. package/src/modules/checkout/api/updateMineCartItemQty/[detectCurrentCart]updateQty.js +51 -0
  287. package/src/modules/checkout/api/updateMineCartItemQty/[getCurrentCustomer]detectCurrentCart.js +32 -0
  288. package/src/modules/checkout/api/updateMineCartItemQty/payloadSchema.json +21 -0
  289. package/src/modules/checkout/api/updateMineCartItemQty/route.json +5 -0
  290. package/src/modules/checkout/api/updateShippingMethod/[context]borderParser[auth].js +5 -0
  291. package/src/modules/checkout/api/updateShippingMethod/payloadSchema.json +12 -0
  292. package/src/modules/checkout/api/updateShippingMethod/route.json +5 -0
  293. package/src/modules/checkout/api/updateShippingMethod/updateShippingMethod.js +64 -0
  294. package/src/modules/checkout/api/updateShippingZoneMethod/payloadSchema.json +43 -1
  295. package/src/modules/checkout/api/updateShippingZoneMethod/updateShippingZoneMethod.js +17 -3
  296. package/src/modules/checkout/bootstrap.js +28 -1
  297. package/src/modules/checkout/graphql/types/Cart/Cart.graphql +22 -3
  298. package/src/modules/checkout/graphql/types/Cart/Cart.resolvers.js +18 -2
  299. package/src/modules/checkout/graphql/types/CheckoutSetting/CheckoutSetting.graphql +3 -0
  300. package/src/modules/checkout/graphql/types/CheckoutSetting/CheckoutSetting.resolvers.js +7 -0
  301. package/src/modules/checkout/graphql/types/ShippingMethod/ShippingMethod.graphql +1 -0
  302. package/src/modules/checkout/graphql/types/ShippingMethod/ShippingMethod.resolvers.js +4 -0
  303. package/src/modules/checkout/graphql/types/ShippingZone/ShippingZone.graphql +21 -1
  304. package/src/modules/checkout/graphql/types/ShippingZone/ShippingZone.resolvers.js +34 -4
  305. package/src/modules/checkout/graphql/types/Weight/Weight.resolvers.js +8 -11
  306. package/src/modules/checkout/migration/Version-1.0.0.js +14 -0
  307. package/src/modules/checkout/migration/Version-1.0.5.js +28 -0
  308. package/src/modules/checkout/migration/Version-1.0.6.js +201 -0
  309. package/src/modules/{oms → checkout}/pages/admin/shippingSetting/ShippingSetting.jsx +67 -44
  310. package/src/modules/checkout/pages/frontStore/all/[auth]addCustomerToCart.js +3 -3
  311. package/src/modules/checkout/pages/frontStore/all/[context]detectCurrentCart[auth].js +5 -0
  312. package/src/modules/checkout/pages/frontStore/cart/ShoppingCart.jsx +17 -8
  313. package/src/modules/checkout/pages/frontStore/cart/Summary.jsx +18 -19
  314. package/src/modules/checkout/pages/frontStore/cart/route.json +2 -1
  315. package/src/modules/checkout/pages/frontStore/checkout/Checkout.jsx +5 -5
  316. package/src/modules/checkout/pages/frontStore/checkout/Checkout.scss +4 -0
  317. package/src/modules/checkout/pages/frontStore/checkout/PaymentStep.jsx +3 -2
  318. package/src/modules/checkout/pages/frontStore/checkout/ShippingMethods.jsx +25 -12
  319. package/src/modules/checkout/pages/frontStore/checkout/ShippingNote.jsx +105 -0
  320. package/src/modules/checkout/pages/frontStore/checkout/Summary.jsx +14 -14
  321. package/src/modules/checkout/pages/frontStore/checkout/SummaryMobile.jsx +129 -0
  322. package/src/modules/checkout/pages/frontStore/checkout/SummaryMobile.scss +7 -0
  323. package/src/modules/checkout/pages/frontStore/checkout/route.json +2 -1
  324. package/src/modules/checkout/pages/frontStore/checkoutSuccess/CheckoutSuccess.jsx +1 -1
  325. package/src/modules/checkout/pages/frontStore/checkoutSuccess/CheckoutSuccess.scss +4 -0
  326. package/src/modules/checkout/pages/frontStore/checkoutSuccess/CustomerInfo.jsx +30 -32
  327. package/src/modules/checkout/pages/frontStore/checkoutSuccess/ShippingNote.jsx +47 -0
  328. package/src/modules/checkout/pages/frontStore/checkoutSuccess/Summary.jsx +12 -15
  329. package/src/modules/checkout/pages/frontStore/checkoutSuccess/route.json +2 -1
  330. package/src/modules/checkout/services/cart/Cart.js +41 -21
  331. package/src/modules/checkout/services/cart/DataObject.js +3 -3
  332. package/src/modules/checkout/services/cart/registerCartBaseFields.js +165 -41
  333. package/src/modules/checkout/services/cart/registerCartItemBaseFields.js +300 -373
  334. package/src/modules/checkout/services/toPrice.js +1 -1
  335. package/src/modules/checkout/tests/basicSetup.js +85 -0
  336. package/src/modules/checkout/tests/coupons.js +82 -0
  337. package/src/modules/checkout/tests/products.js +67 -0
  338. package/src/modules/checkout/tests/taxRates.js +3 -0
  339. package/src/modules/checkout/tests/unit/discountAmount.test.js +60 -0
  340. package/src/modules/checkout/tests/unit/grandTotal.test.js +83 -0
  341. package/src/modules/checkout/tests/unit/lineTotal.test.js +90 -0
  342. package/src/modules/checkout/tests/unit/lineTotalWithDiscount.test.js +103 -0
  343. package/src/modules/checkout/tests/unit/productPrice.test.js +67 -0
  344. package/src/modules/checkout/tests/unit/subTotal.test.js +85 -0
  345. package/src/modules/checkout/tests/unit/subTotalWithDiscount.test.js +117 -0
  346. package/src/modules/checkout/tests/unit/taxAmount.test.js +67 -0
  347. package/src/modules/checkout/tests/unit/taxAmountRounding.test.js +277 -0
  348. package/src/modules/cms/api/createWidget/[context]bodyParser[auth].js +5 -0
  349. package/src/modules/cms/api/createWidget/createWidget[finish].js +17 -0
  350. package/src/modules/cms/api/createWidget/finish[apiResponse].js +27 -0
  351. package/src/modules/cms/api/createWidget/payloadSchema.json +18 -0
  352. package/src/modules/cms/api/createWidget/route.json +5 -0
  353. package/src/modules/cms/api/deleteWidget/deleteWidget.js +27 -0
  354. package/src/modules/cms/api/deleteWidget/route.json +5 -0
  355. package/src/modules/cms/api/updateWidget/[context]bodyParser[auth].js +5 -0
  356. package/src/modules/cms/api/updateWidget/finish[apiResponse].js +27 -0
  357. package/src/modules/cms/api/updateWidget/payloadSchema.json +18 -0
  358. package/src/modules/cms/api/updateWidget/route.json +5 -0
  359. package/src/modules/cms/api/updateWidget/updateWidget[finish].js +17 -0
  360. package/src/modules/cms/bootstrap.js +239 -2
  361. package/src/modules/cms/graphql/types/CmsPage/CmsPage.graphql +1 -2
  362. package/src/modules/cms/graphql/types/CmsPage/CmsPage.resolvers.js +37 -12
  363. package/src/modules/cms/graphql/types/Widget/Widget.graphql +91 -0
  364. package/src/modules/cms/graphql/types/Widget/Widget.resolvers.js +142 -0
  365. package/src/modules/cms/migration/Version-1.1.0.js +22 -0
  366. package/src/modules/cms/migration/Version-1.1.1.js +103 -0
  367. package/src/modules/cms/pages/admin/adminNotFound/NotFound.jsx +4 -4
  368. package/src/modules/cms/pages/admin/all/CmsMenuGroup.jsx +12 -4
  369. package/src/modules/cms/pages/admin/all/Layout.scss +3 -2
  370. package/src/modules/cms/pages/admin/all/Notification.scss +1 -1
  371. package/src/modules/cms/pages/admin/all/SearchBox.jsx +1 -1
  372. package/src/modules/cms/pages/admin/all/search/NoResult.jsx +2 -2
  373. package/src/modules/cms/pages/admin/all/search/Results.jsx +3 -3
  374. package/src/modules/cms/pages/admin/cmsPageEdit+cmsPageNew/FormContent.jsx +7 -9
  375. package/src/modules/cms/pages/admin/cmsPageEdit+cmsPageNew/General.jsx +3 -3
  376. package/src/modules/cms/pages/admin/cmsPageEdit+cmsPageNew/Seo.jsx +1 -1
  377. package/src/modules/cms/pages/admin/cmsPageEdit+cmsPageNew/Status.jsx +40 -0
  378. package/src/modules/cms/pages/admin/cmsPageGrid/Grid.jsx +64 -12
  379. package/src/modules/cms/pages/admin/cmsPageGrid/index.js +1 -2
  380. package/src/modules/cms/pages/admin/dashboard/Layout.jsx +3 -3
  381. package/src/modules/cms/pages/admin/widgetEdit/WidgetForm.jsx +52 -0
  382. package/src/modules/cms/pages/admin/widgetEdit/index.js +36 -0
  383. package/src/modules/cms/pages/admin/widgetEdit/route.json +4 -0
  384. package/src/modules/cms/pages/admin/widgetEdit+widgetNew/FormContent.jsx +69 -0
  385. package/src/modules/cms/pages/admin/widgetEdit+widgetNew/FormContent.scss +7 -0
  386. package/src/modules/cms/pages/admin/widgetEdit+widgetNew/General.jsx +185 -0
  387. package/src/modules/cms/pages/admin/widgetEdit+widgetNew/PageHeading.jsx +37 -0
  388. package/src/modules/cms/pages/admin/widgetEdit+widgetNew/Setting.jsx +55 -0
  389. package/src/modules/cms/pages/admin/widgetGrid/Grid.jsx +415 -0
  390. package/src/modules/cms/pages/admin/widgetGrid/Heading.jsx +11 -0
  391. package/src/modules/cms/pages/admin/widgetGrid/NewWidgetButton.jsx +52 -0
  392. package/src/modules/cms/pages/admin/widgetGrid/index.js +15 -0
  393. package/src/modules/cms/pages/admin/widgetGrid/route.json +4 -0
  394. package/src/modules/cms/pages/admin/widgetNew/WidgetNewForm.jsx +60 -0
  395. package/src/modules/cms/pages/admin/widgetNew/index.js +11 -0
  396. package/src/modules/cms/pages/admin/widgetNew/route.json +4 -0
  397. package/src/modules/cms/pages/admin/widgetNew/typeValidate.js +21 -0
  398. package/src/modules/cms/pages/frontStore/all/Breadcrumb.jsx +1 -1
  399. package/src/modules/cms/pages/frontStore/all/Footer.jsx +2 -2
  400. package/src/modules/cms/pages/frontStore/all/Layout.jsx +3 -3
  401. package/src/modules/cms/pages/frontStore/all/Layout.scss +13 -0
  402. package/src/modules/cms/pages/frontStore/all/Logo.jsx +2 -2
  403. package/src/modules/cms/pages/frontStore/all/Logo.scss +2 -4
  404. package/src/modules/cms/pages/frontStore/all/Notification.scss +1 -1
  405. package/src/modules/cms/pages/frontStore/cmsPageView/Layout.jsx +2 -2
  406. package/src/modules/cms/pages/frontStore/cmsPageView/View.jsx +5 -3
  407. package/src/modules/cms/pages/frontStore/cmsPageView/index.js +6 -12
  408. package/src/modules/cms/pages/frontStore/cmsPageView/route.json +2 -1
  409. package/src/modules/cms/pages/frontStore/homepage/route.json +2 -1
  410. package/src/modules/cms/pages/frontStore/notFound/NotFound.jsx +4 -4
  411. package/src/modules/cms/pages/frontStore/notFound/route.json +2 -1
  412. package/src/modules/cms/pages/frontStore/staticAsset/[context]staticAssets[auth].js +1 -1
  413. package/src/modules/cms/services/CMSPageCollection.js +23 -70
  414. package/src/modules/cms/services/WidgetCollection.js +62 -0
  415. package/src/modules/cms/services/getWidgetsBaseQuery.js +7 -0
  416. package/src/modules/cms/services/page/createPage.js +1 -2
  417. package/src/modules/cms/services/page/pageDataSchema.json +0 -4
  418. package/src/modules/cms/services/registerDefaultPageCollectionFilters.js +62 -0
  419. package/src/modules/cms/services/registerDefaultWidgetCollectionFilters.js +62 -0
  420. package/src/modules/cms/services/tailwind.admin.config.js +22 -102
  421. package/src/modules/cms/services/tailwind.frontStore.config.js +23 -108
  422. package/src/modules/cms/services/widget/createWidget.js +73 -0
  423. package/src/modules/cms/services/widget/deleteWidget.js +49 -0
  424. package/src/modules/cms/services/widget/loadWidgetInstances.js +54 -0
  425. package/src/modules/cms/services/widget/updateWidget.js +86 -0
  426. package/src/modules/cms/services/widget/widgetDataSchema.json +29 -0
  427. package/src/modules/cod/pages/admin/paymentSetting/CODSetting.jsx +2 -2
  428. package/src/modules/cod/pages/frontStore/checkout/CashOnDelivery.jsx +1 -1
  429. package/src/modules/customer/api/createCustomer/[bodyParser]createCustomer.js +2 -2
  430. package/src/modules/customer/api/resetPassword/[bodyParser]resetPassword.js +2 -2
  431. package/src/modules/customer/api/updatePassword/[bodyParser]updatePassword.js +2 -2
  432. package/src/modules/customer/bootstrap.js +50 -4
  433. package/src/modules/customer/graphql/types/Customer/Customer.admin.resolvers.js +2 -4
  434. package/src/modules/customer/pages/admin/customerEdit/CustomerEditForm.jsx +3 -3
  435. package/src/modules/customer/pages/admin/customerEdit+customerNew/OrderHistory.jsx +1 -1
  436. package/src/modules/customer/pages/admin/customerGrid/Grid.jsx +110 -16
  437. package/src/modules/customer/pages/admin/customerGrid/index.js +1 -2
  438. package/src/modules/customer/pages/frontStore/account/AccountDetails.jsx +3 -3
  439. package/src/modules/customer/pages/frontStore/account/Layout.jsx +3 -3
  440. package/src/modules/customer/pages/frontStore/account/OrderHistory.jsx +1 -1
  441. package/src/modules/customer/pages/frontStore/account/route.json +2 -1
  442. package/src/modules/customer/pages/frontStore/login/LoginForm.jsx +2 -3
  443. package/src/modules/customer/pages/frontStore/login/route.json +2 -1
  444. package/src/modules/customer/pages/frontStore/register/RegisterForm.jsx +2 -2
  445. package/src/modules/customer/pages/frontStore/register/route.json +2 -1
  446. package/src/modules/customer/pages/frontStore/resetPasswordPage/ResetPasswordForm.jsx +2 -2
  447. package/src/modules/customer/pages/frontStore/resetPasswordPage/route.json +2 -1
  448. package/src/modules/customer/pages/frontStore/updatePasswordPage/UpdatePasswordForm.jsx +3 -3
  449. package/src/modules/customer/pages/frontStore/updatePasswordPage/route.json +2 -1
  450. package/src/modules/customer/services/CustomerCollection.js +22 -103
  451. package/src/modules/customer/services/CustomerGroupCollection.js +20 -69
  452. package/src/modules/customer/services/registerDefaultCustomerCollectionFilters.js +90 -0
  453. package/src/modules/customer/services/registerDefaultCustomerGroupCollectionFilters.js +50 -0
  454. package/src/modules/graphql/pages/global/[bodyParser]buildQuery[graphql].js +239 -7
  455. package/src/modules/graphql/pages/global/[buildQuery]graphql[notification].js +13 -9
  456. package/src/modules/graphql/services/graphqlMiddleware.js +1 -1
  457. package/src/modules/oms/bootstrap.js +104 -3
  458. package/src/modules/oms/graphql/types/Order/Order.admin.resolvers.js +1 -1
  459. package/src/modules/oms/graphql/types/Order/Order.graphql +11 -2
  460. package/src/modules/oms/graphql/types/Order/Order.resolvers.js +9 -2
  461. package/src/modules/oms/pages/admin/dashboard/Bestsellers.jsx +2 -2
  462. package/src/modules/oms/pages/admin/dashboard/Lifetimesales.jsx +5 -5
  463. package/src/modules/oms/pages/admin/orderEdit/AddTrackingButton.jsx +1 -1
  464. package/src/modules/oms/pages/admin/orderEdit/Items.jsx +7 -7
  465. package/src/modules/oms/pages/admin/orderEdit/Layout.jsx +3 -3
  466. package/src/modules/oms/pages/admin/orderEdit/Payment.jsx +6 -6
  467. package/src/modules/oms/pages/admin/orderEdit/ShipButton.jsx +1 -1
  468. package/src/modules/oms/pages/admin/orderGrid/Grid.jsx +154 -53
  469. package/src/modules/oms/pages/admin/orderGrid/index.js +1 -2
  470. package/src/modules/oms/services/OrderCollection.js +18 -138
  471. package/src/modules/oms/services/registerDefaultOrderCollectionFilters.js +121 -0
  472. package/src/modules/paypal/api/paypalCreateOrder/[bodyParser]createOrder.js +55 -24
  473. package/src/modules/paypal/pages/admin/paymentSetting/PaypalSetting.jsx +6 -6
  474. package/src/modules/paypal/pages/frontStore/checkout/Paypal.jsx +3 -4
  475. package/src/modules/promotion/bootstrap.js +35 -101
  476. package/src/modules/promotion/graphql/types/Coupon/Coupon.admin.resolvers.js +2 -7
  477. package/src/modules/promotion/pages/admin/couponEdit+couponNew/DiscountType.jsx +1 -1
  478. package/src/modules/promotion/pages/admin/couponEdit+couponNew/FormContent.jsx +5 -5
  479. package/src/modules/promotion/pages/admin/couponGrid/Grid.jsx +159 -35
  480. package/src/modules/promotion/pages/admin/couponGrid/index.js +1 -2
  481. package/src/modules/promotion/pages/frontStore/cart/Coupon.jsx +2 -2
  482. package/src/modules/promotion/services/CouponCollection.js +21 -130
  483. package/src/modules/promotion/services/couponValidator.js +4 -7
  484. package/src/modules/promotion/services/discountCalculator.js +2 -7
  485. package/src/modules/promotion/services/registerCartItemPromotionFields.js +80 -0
  486. package/src/modules/promotion/services/registerCartPromotionFields.js +128 -0
  487. package/src/modules/promotion/services/registerDefaultCalculators.js +48 -20
  488. package/src/modules/promotion/services/registerDefaultCouponCollectionFilters.js +72 -0
  489. package/src/modules/promotion/services/registerDefaultValidators.js +16 -4
  490. package/src/modules/setting/pages/admin/paymentSetting/PaymentSetting.jsx +2 -2
  491. package/src/modules/setting/pages/admin/storeSetting/StoreSetting.jsx +98 -35
  492. package/src/modules/stripe/api/stripeWebHook/[bodyJson]webhook.js +4 -2
  493. package/src/modules/stripe/pages/admin/paymentSetting/StripePayment.jsx +5 -5
  494. package/src/modules/stripe/pages/frontStore/checkout/Stripe.jsx +1 -1
  495. package/src/modules/tax/bootstrap.js +57 -5
  496. package/src/modules/tax/graphql/types/Product/Price/ProductPrice.resolvers.js +6 -39
  497. package/src/modules/tax/graphql/types/TaxSetting/TaxSetting.graphql +1 -2
  498. package/src/modules/tax/graphql/types/TaxSetting/TaxSetting.resolvers.js +1 -8
  499. package/src/modules/tax/pages/admin/taxSetting/TaxSetting.jsx +4 -4
  500. package/src/modules/tax/services/TaxClassCollection.js +22 -56
  501. package/src/modules/tax/services/calculateTaxAmount.js +12 -9
  502. package/src/modules/tax/services/registerCartItemTaxPercentField.js +76 -0
  503. package/src/modules/tax/services/registerDefaultTaxClassCollectionFilters.js +49 -0
  504. package/src/components/admin/oms/shippingSetting/Method.jsx +0 -73
  505. package/src/components/common/grid/headers/Basic.jsx +0 -55
  506. package/src/lib/log/debuger.js +0 -89
  507. package/src/modules/auth/services/adminSessionMiddleware.js +0 -0
  508. package/src/modules/catalog/pages/frontStore/homepage/FeaturedCategories.jsx +0 -58
  509. package/src/modules/cms/pages/admin/cmsPageEdit+cmsPageNew/StatusAndLayout.jsx +0 -61
  510. package/src/modules/cms/pages/frontStore/all/Menu.jsx +0 -46
  511. package/src/modules/cms/pages/frontStore/all/Menu.scss +0 -7
  512. package/src/modules/cms/pages/frontStore/all/MobileMenu.jsx +0 -73
  513. package/src/modules/cms/pages/frontStore/all/MobileMenu.scss +0 -35
  514. package/src/modules/cms/pages/frontStore/homepage/MainBanner.jsx +0 -31
  515. package/src/modules/cms/pages/frontStore/homepage/MainBanner.scss +0 -48
  516. package/src/modules/customer/pages/frontStore/login/LoginButton.jsx +0 -27
  517. /package/src/modules/{oms → checkout}/pages/admin/all/ShippingSettingMenu.jsx +0 -0
  518. /package/src/modules/{oms → checkout}/pages/admin/shippingSetting/index.js +0 -0
  519. /package/src/modules/{oms → checkout}/pages/admin/shippingSetting/route.json +0 -0
@@ -11,8 +11,8 @@ export function New({ createVariantGroupApi, setGroup }) {
11
11
  {action === undefined && (
12
12
  <div>
13
13
  <div className="justify-center text-center">
14
- <div className="mb-4">
15
- <span className="pr-1">
14
+ <div className="mb-16">
15
+ <span className="pr-4">
16
16
  This product has some variants like color or size?
17
17
  </span>
18
18
  <a
@@ -30,7 +30,7 @@ export function Search({ addVariant, variants }) {
30
30
  };
31
31
 
32
32
  return (
33
- <div className="flex justify-between mt-1">
33
+ <div className="flex justify-between mt-4">
34
34
  <div className="self-center">
35
35
  <div className="autocomplete-search">
36
36
  <Input
@@ -174,7 +174,7 @@ export function SearchModal({ keyword, variants, addVariant, searchAPI }) {
174
174
  </div>
175
175
  )}
176
176
  {potentialVariants.length <= 0 && (
177
- <div className="flex justify-center p-1">
177
+ <div className="flex justify-center p-4">
178
178
  There is no product to show
179
179
  </div>
180
180
  )}
@@ -22,7 +22,7 @@ export function Variant({
22
22
  </td>
23
23
  {variant.attributes.map((a) => (
24
24
  <td key={a.attributeId}>
25
- <label>{a.optionText}</label>
25
+ <label>{a.optionText || '--'}</label>
26
26
  </td>
27
27
  ))}
28
28
  <td>
@@ -2,23 +2,68 @@
2
2
  /* eslint-disable jsx-a11y/anchor-is-valid */
3
3
  import React from 'react';
4
4
  import PropTypes from 'prop-types';
5
+ import { useQuery } from 'urql';
5
6
  import ProductMediaManager from '@components/admin/catalog/productEdit/media/ProductMediaManager';
6
7
  import { Field } from '@components/common/form/Field';
8
+ import { useFormContext } from '@components/common/form/Form';
9
+ import Spinner from '@components/common/Spinner';
10
+
11
+ const AttributesQuery = `
12
+ query Query($filters: [FilterInput]) {
13
+ attributes(filters: $filters) {
14
+ items {
15
+ attributeId
16
+ attributeCode
17
+ attributeName
18
+ options {
19
+ value: attributeOptionId
20
+ text: optionText
21
+ }
22
+ }
23
+ }
24
+ }
25
+ `;
7
26
 
8
27
  export function VariantModal({
9
28
  variant,
10
29
  variantAttributes,
11
30
  productImageUploadUrl
12
31
  }) {
32
+ const formContext = useFormContext();
13
33
  const image = variant?.product?.image;
14
34
  let gallery = variant?.product?.gallery || [];
15
35
 
16
36
  if (image) {
17
37
  gallery = [image].concat(gallery);
18
38
  }
39
+ const [result] = useQuery({
40
+ query: AttributesQuery,
41
+ variables: {
42
+ filters: [
43
+ {
44
+ key: 'code',
45
+ operation: 'in',
46
+ value: variantAttributes.map((a) => a.attributeCode).join(',')
47
+ }
48
+ ]
49
+ }
50
+ });
51
+
52
+ const { data, fetching, error } = result;
53
+ if (fetching) {
54
+ return (
55
+ <div className="p-3 flex justify-center items-center border rounded border-divider">
56
+ <Spinner width={30} height={30} />
57
+ </div>
58
+ );
59
+ }
60
+
61
+ if (error) {
62
+ return <p className="text-critical">{error.message}</p>;
63
+ }
19
64
  return (
20
- <div className="variant-item pb-15 border-b border-solid border-divider mb-15 last:border-b-0 last:pb-0">
21
- <div className="grid grid-cols-2 gap-x-1">
65
+ <div className="variant-item pb-6 border-b border-solid border-divider mb-6 last:border-b-0 last:pb-0">
66
+ <div className="grid grid-cols-2 gap-x-4">
22
67
  <div className="col-span-1">
23
68
  <ProductMediaManager
24
69
  id="images"
@@ -27,30 +72,41 @@ export function VariantModal({
27
72
  />
28
73
  </div>
29
74
  <div className="col-span-1">
30
- <div className="grid grid-cols-2 gap-x-1 border-b border-divider pb-15 mb-15">
31
- {variantAttributes.map((a) => (
32
- <div key={a.attributeId} className="mt-1 col">
75
+ <div className="grid grid-cols-2 gap-x-4 border-b border-divider pb-6 mb-6">
76
+ {data?.attributes?.items.map((a, index) => (
77
+ <div key={a.attributeId} className="mt-4 col">
33
78
  <div>
34
79
  <label>{a.attributeName}</label>
35
80
  </div>
36
- <Field
81
+ <input
82
+ type="hidden"
83
+ name={`attributes[${index}][attribute_code]`}
84
+ value={a.attributeCode}
85
+ />
86
+ <input
87
+ type="hidden"
37
88
  name={a.attributeCode}
89
+ value={
90
+ formContext.fields.find(
91
+ (f) => f.name === `attributes[${index}][value]`
92
+ )?.value
93
+ }
94
+ />
95
+ <Field
96
+ name={`attributes[${index}][value]`}
38
97
  validationRules={['notEmpty']}
39
98
  value={
40
99
  variant?.attributes.find(
41
100
  (v) => v.attributeCode === a.attributeCode
42
101
  )?.optionId
43
102
  }
44
- options={a.options.map((o) => ({
45
- value: o.optionId,
46
- text: o.optionText
47
- }))}
103
+ options={a.options}
48
104
  type="select"
49
105
  />
50
106
  </div>
51
107
  ))}
52
108
  </div>
53
- <div className="grid grid-cols-3 gap-x-1 border-b border-divider pb-15 mb-15">
109
+ <div className="grid grid-cols-3 gap-x-4 border-b border-divider pb-6 mb-6">
54
110
  <div>
55
111
  <div>SKU</div>
56
112
  <Field
@@ -72,7 +128,7 @@ export function VariantModal({
72
128
  />
73
129
  </div>
74
130
  </div>
75
- <div className="grid grid-cols-3 gap-x-1">
131
+ <div className="grid grid-cols-3 gap-x-4">
76
132
  <div>
77
133
  <div>Status</div>
78
134
  <Field
@@ -4,7 +4,7 @@ import { useQuery } from 'urql';
4
4
  import { Card } from '@components/admin/cms/Card';
5
5
  import { CreateVariant } from '@components/admin/catalog/productEdit/variants/CreateVariant';
6
6
  import Spinner from '@components/common/Spinner';
7
- import { Variant } from './Variant';
7
+ import { Variant } from '@components/admin/catalog/productEdit/variants/Variant';
8
8
 
9
9
  export const VariantQuery = `
10
10
  query Query($productId: ID!) {
@@ -5,7 +5,7 @@ export default function ThumbnailRow({ src, name }) {
5
5
  return (
6
6
  <td>
7
7
  <div
8
- className="grid-thumbnail text-border border border-divider p-075 rounded flex justify-center"
8
+ className="grid-thumbnail text-border border border-divider p-3 rounded flex justify-center"
9
9
  style={{ width: '6rem', height: '6rem' }}
10
10
  >
11
11
  {src && <img className="self-center" src={src} alt={name} />}
@@ -0,0 +1,130 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { toast } from 'react-toastify';
4
+ import CogIcon from '@heroicons/react/outline/CogIcon';
5
+ import { useModal } from '@components/common/modal/useModal';
6
+ import MethodForm from '@components/admin/checkout/shippingSetting/MethodForm';
7
+
8
+ function Method({ method, getZones }) {
9
+ const modal = useModal();
10
+ return (
11
+ <>
12
+ <>
13
+ <td className="border-none py-4">{method.name}</td>
14
+ <td className="border-none py-4">
15
+ {method.isEnabled ? 'Enabled' : 'Disabled'}
16
+ </td>
17
+ <td className="border-none py-4">
18
+ {method.cost?.text || (
19
+ <a
20
+ href="#"
21
+ className="text-interactive"
22
+ onClick={(e) => {
23
+ e.preventDefault();
24
+ modal.openModal();
25
+ }}
26
+ >
27
+ <CogIcon width={22} height={22} />
28
+ </a>
29
+ )}
30
+ </td>
31
+ <td className="border-none py-4">
32
+ {method.conditionType
33
+ ? `${method.min || 0} <= ${method.conditionType} <= ${
34
+ method.max || '∞'
35
+ }`
36
+ : 'None'}
37
+ </td>
38
+ <td className="border-none py-4">
39
+ <a
40
+ href="#"
41
+ className="text-interactive"
42
+ onClick={(e) => {
43
+ e.preventDefault();
44
+ modal.openModal();
45
+ }}
46
+ >
47
+ Edit
48
+ </a>
49
+ <a
50
+ href="#"
51
+ className="text-critical ml-8"
52
+ onClick={async (e) => {
53
+ e.preventDefault();
54
+ try {
55
+ const response = await fetch(method.deleteApi, {
56
+ method: 'DELETE',
57
+ headers: {
58
+ 'Content-Type': 'application/json'
59
+ },
60
+ credentials: 'include'
61
+ });
62
+ if (response.ok) {
63
+ await getZones();
64
+ // Toast success
65
+ toast.success('Method removed successfully');
66
+ } else {
67
+ // Toast error
68
+ toast.error('Failed to remove method');
69
+ }
70
+ } catch (error) {
71
+ // Toast error
72
+ toast.error('Failed to remove method');
73
+ }
74
+ }}
75
+ >
76
+ Delete
77
+ </a>
78
+ </td>
79
+ </>
80
+ {modal.state.showing && (
81
+ <div className={modal.className} onAnimationEnd={modal.onAnimationEnd}>
82
+ <div
83
+ className="modal-wrapper flex self-center justify-center items-center"
84
+ tabIndex={-1}
85
+ role="dialog"
86
+ >
87
+ <div className="modal">
88
+ <MethodForm
89
+ saveMethodApi={method.updateApi}
90
+ closeModal={() => modal.closeModal()}
91
+ getZones={getZones}
92
+ method={method}
93
+ />
94
+ </div>
95
+ </div>
96
+ </div>
97
+ )}
98
+ </>
99
+ );
100
+ }
101
+
102
+ Method.propTypes = {
103
+ method: PropTypes.shape({
104
+ name: PropTypes.string.isRequired,
105
+ isEnabled: PropTypes.bool.isRequired,
106
+ cost: PropTypes.shape({
107
+ text: PropTypes.string.isRequired
108
+ }),
109
+ priceBasedCost: PropTypes.arrayOf(
110
+ PropTypes.shape({
111
+ minPrice: PropTypes.number.isRequired,
112
+ cost: PropTypes.number.isRequired
113
+ })
114
+ ),
115
+ weightBasedCost: PropTypes.arrayOf(
116
+ PropTypes.shape({
117
+ minWeight: PropTypes.number.isRequired,
118
+ cost: PropTypes.number.isRequired
119
+ })
120
+ ),
121
+ conditionType: PropTypes.string.isRequired,
122
+ min: PropTypes.number.isRequired,
123
+ max: PropTypes.number.isRequired,
124
+ updateApi: PropTypes.string.isRequired,
125
+ deleteApi: PropTypes.string.isRequired
126
+ }).isRequired,
127
+ getZones: PropTypes.func.isRequired
128
+ };
129
+
130
+ export default Method;
@@ -10,12 +10,16 @@ import CreatableSelect from 'react-select/creatable';
10
10
  import Spinner from '@components/common/Spinner';
11
11
  import { useQuery } from 'urql';
12
12
  import { toast } from 'react-toastify';
13
+ import PriceBasedPrice from '@components/admin/checkout/shippingSetting/PriceBasedPrice';
14
+ import WeightBasedPrice from '@components/admin/checkout/shippingSetting/WeightBasedPrice';
15
+ import { Input } from '@components/common/form/fields/Input';
13
16
 
14
17
  const MethodsQuery = `
15
18
  query Methods {
16
19
  shippingMethods {
17
20
  value: shippingMethodId
18
21
  label: name
22
+ updateApi
19
23
  }
20
24
  createShippingMethodApi: url(routeId: "createShippingMethod")
21
25
  }
@@ -25,7 +29,7 @@ function Condition({ method }) {
25
29
  const [type, setType] = React.useState(method?.conditionType || 'price');
26
30
  return (
27
31
  <div>
28
- <div className="mb-1">
32
+ <div className="mb-4">
29
33
  <Radio
30
34
  name="condition_type"
31
35
  options={[
@@ -36,7 +40,7 @@ function Condition({ method }) {
36
40
  value={type}
37
41
  />
38
42
  </div>
39
- <div className="grid grid-cols-2 gap-2">
43
+ <div className="grid grid-cols-2 gap-8">
40
44
  <div>
41
45
  <Field
42
46
  name="min"
@@ -83,9 +87,18 @@ Condition.defaultProps = {
83
87
  };
84
88
 
85
89
  function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
86
- const [type, setType] = React.useState(
87
- method?.calculateApi ? 'api' : 'flat_rate'
88
- );
90
+ const [type, setType] = React.useState(() => {
91
+ if (method?.calculateApi) {
92
+ return 'api';
93
+ }
94
+ if (method?.priceBasedCost) {
95
+ return 'price_based_rate';
96
+ }
97
+ if (method?.weightBasedCost) {
98
+ return 'weight_based_rate';
99
+ }
100
+ return 'flat_rate';
101
+ });
89
102
  const [isLoading, setIsLoading] = React.useState(false);
90
103
  const [shippingMethod, setMethod] = React.useState(
91
104
  method
@@ -98,6 +111,8 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
98
111
  const [hasCondition, setHasCondition] = React.useState(
99
112
  !!method?.conditionType
100
113
  );
114
+ const [name, setName] = React.useState(method?.name || '');
115
+ const [updatingName, setUpdatingName] = React.useState(false);
101
116
 
102
117
  const [result, reexecuteQuery] = useQuery({
103
118
  query: MethodsQuery
@@ -127,6 +142,10 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
127
142
  );
128
143
  }
129
144
 
145
+ const currentMethod = result.data.shippingMethods.find(
146
+ (m) => m.value === shippingMethod?.value
147
+ );
148
+
130
149
  return (
131
150
  <Card title="Shipping method">
132
151
  <Form
@@ -138,21 +157,78 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
138
157
  if (!response.error) {
139
158
  await getZones({ requestPolicy: 'network-only' });
140
159
  closeModal();
160
+ toast.success('Shipping method saved successfully');
141
161
  } else {
142
162
  toast.error(response.error.message);
143
163
  }
144
164
  }}
145
165
  >
146
166
  <Card.Session title="Method name">
147
- <CreatableSelect
148
- isClearable
149
- isDisabled={isLoading}
150
- isLoading={isLoading}
151
- onChange={(newValue) => setMethod(newValue)}
152
- onCreateOption={handleCreate}
153
- options={result.data.shippingMethods}
154
- value={shippingMethod}
155
- />
167
+ {!method ? (
168
+ <CreatableSelect
169
+ isClearable
170
+ isDisabled={isLoading}
171
+ isLoading={isLoading}
172
+ onChange={(newValue) => setMethod(newValue)}
173
+ onCreateOption={handleCreate}
174
+ options={result.data.shippingMethods}
175
+ value={shippingMethod}
176
+ />
177
+ ) : (
178
+ <div className="flex gap-4 justify-start items-center">
179
+ <Input
180
+ name="name"
181
+ type="text"
182
+ placeholder="Method name"
183
+ validationRules={['notEmpty']}
184
+ value={name}
185
+ disabled={!updatingName}
186
+ suffix={
187
+ <a
188
+ href="#"
189
+ onClick={(e) => {
190
+ e.preventDefault();
191
+ if (updatingName) setName(method.name);
192
+ setUpdatingName(!updatingName);
193
+ }}
194
+ >
195
+ <span className="text-interactive">
196
+ {updatingName ? 'Cancel' : 'Edit'}
197
+ </span>
198
+ </a>
199
+ }
200
+ onChange={(e) => setName(e.target.value)}
201
+ />
202
+ {updatingName && (
203
+ <Button
204
+ title="Save"
205
+ variant="primary"
206
+ onAction={async () => {
207
+ // Use fetch to call the API (method.updateApi) to update the method name
208
+ // The API should accept a PATCH request with the new name as the payload
209
+ // The API should return the updated method object
210
+ const response = await fetch(currentMethod.updateApi, {
211
+ method: 'PATCH',
212
+ headers: {
213
+ 'Content-Type': 'application/json'
214
+ },
215
+ credentials: 'same-origin',
216
+ body: JSON.stringify({
217
+ name
218
+ })
219
+ });
220
+ const data = await response.json();
221
+ if (response.ok) {
222
+ setName(data.name);
223
+ setUpdatingName(false);
224
+ } else {
225
+ toast.error(data.error.message);
226
+ }
227
+ }}
228
+ />
229
+ )}
230
+ </div>
231
+ )}
156
232
  <Field
157
233
  type="hidden"
158
234
  name="method_id"
@@ -166,6 +242,8 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
166
242
  name="calculation_type"
167
243
  options={[
168
244
  { text: 'Flat rate', value: 'flat_rate' },
245
+ { text: 'Price based rate', value: 'price_based_rate' },
246
+ { text: 'Weight based rate', value: 'weight_based_rate' },
169
247
  { text: 'API calculate', value: 'api' }
170
248
  ]}
171
249
  defaultValue={method?.calculateApi ? 'api' : 'flat_rate'}
@@ -183,6 +261,12 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
183
261
  value={method?.cost?.value}
184
262
  />
185
263
  )}
264
+ {type === 'price_based_rate' && (
265
+ <PriceBasedPrice lines={method?.priceBasedCost || []} />
266
+ )}
267
+ {type === 'weight_based_rate' && (
268
+ <WeightBasedPrice lines={method?.weightBasedCost || []} />
269
+ )}
186
270
  {type === 'api' && (
187
271
  <Field
188
272
  name="calculate_api"
@@ -209,8 +293,15 @@ function MethodForm({ saveMethodApi, closeModal, getZones, method }) {
209
293
  {hasCondition && <Condition method={method} />}
210
294
  </Card.Session>
211
295
  <Card.Session>
212
- <div className="flex justify-end gap-1">
213
- <Button title="Cancel" variant="secondary" onAction={closeModal} />
296
+ <div className="flex justify-end gap-4">
297
+ <Button
298
+ title="Cancel"
299
+ variant="secondary"
300
+ onAction={async () => {
301
+ await getZones({ requestPolicy: 'network-only' });
302
+ closeModal();
303
+ }}
304
+ />
214
305
  <Button
215
306
  title="Save"
216
307
  variant="primary"
@@ -242,6 +333,26 @@ MethodForm.propTypes = {
242
333
  cost: PropTypes.shape({
243
334
  value: PropTypes.string
244
335
  }),
336
+ priceBasedCost: PropTypes.arrayOf(
337
+ PropTypes.shape({
338
+ minPrice: PropTypes.shape({
339
+ value: PropTypes.number
340
+ }),
341
+ cost: PropTypes.shape({
342
+ value: PropTypes.number
343
+ })
344
+ })
345
+ ),
346
+ weightBasedCost: PropTypes.arrayOf(
347
+ PropTypes.shape({
348
+ minWeight: PropTypes.shape({
349
+ value: PropTypes.number
350
+ }),
351
+ cost: PropTypes.shape({
352
+ value: PropTypes.number
353
+ })
354
+ })
355
+ ),
245
356
  conditionType: PropTypes.string,
246
357
  min: PropTypes.string,
247
358
  max: PropTypes.string
@@ -1,13 +1,13 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { useModal } from '@components/common/modal/useModal';
4
- import Method from './Method';
5
- import MethodForm from './MethodForm';
4
+ import Method from '@components/admin/checkout/shippingSetting/Method';
5
+ import MethodForm from '@components/admin/checkout/shippingSetting/MethodForm';
6
6
 
7
7
  export function Methods({ getZones, methods, addMethodApi }) {
8
8
  const modal = useModal();
9
9
  return (
10
- <div className="my-2">
10
+ <div className="my-8">
11
11
  <table className="border-collapse divide-y">
12
12
  <thead>
13
13
  <tr>
@@ -19,12 +19,12 @@ export function Methods({ getZones, methods, addMethodApi }) {
19
19
  </tr>
20
20
  </thead>
21
21
  {methods.map((method) => (
22
- <tr key={method.methodId} className="border-divider py-2">
22
+ <tr key={method.methodId} className="border-divider py-8">
23
23
  <Method method={method} getZones={getZones} />
24
24
  </tr>
25
25
  ))}
26
26
  </table>
27
- <div className="mt-1">
27
+ <div className="mt-4">
28
28
  <a
29
29
  href="#"
30
30
  className="text-interactive"
@@ -0,0 +1,101 @@
1
+ import React from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { Field } from '@components/common/form/Field';
4
+
5
+ export default function PriceBasedPrice({ lines }) {
6
+ // This is a table with 3 columns: Min Price, Shipping Cost, and Action
7
+ const [rows, setRows] = React.useState(
8
+ lines.map((line) => ({
9
+ ...line,
10
+ key: Math.random().toString(36).substring(7)
11
+ }))
12
+ );
13
+ return (
14
+ <div className="my-8">
15
+ <table className="border-collapse divide-y">
16
+ <thead>
17
+ <tr>
18
+ <th className="border-none">Min Price</th>
19
+ <th className="border-none">Shipping Cost</th>
20
+ <th className="border-none">Action</th>
21
+ </tr>
22
+ </thead>
23
+ <tbody>
24
+ {rows.map((row, index) => (
25
+ // Create a random key for each row
26
+ <tr key={row.key} className="border-divider py-8">
27
+ <td className="border-none">
28
+ <Field
29
+ name={`price_based_cost[${index}][min_price]`}
30
+ placeholder="Min Price"
31
+ type="text"
32
+ value={row.minPrice?.value}
33
+ validationRules={['notEmpty', 'number']}
34
+ />
35
+ </td>
36
+ <td className="border-none">
37
+ <Field
38
+ name={`price_based_cost[${index}][cost]`}
39
+ placeholder="Shipping Cost"
40
+ type="text"
41
+ value={row.cost?.value}
42
+ validationRules={['notEmpty', 'number']}
43
+ />
44
+ </td>
45
+ <td className="border-none">
46
+ <a
47
+ href="#"
48
+ onClick={() => {
49
+ setRows(rows.filter((r) => r.key !== row.key));
50
+ }}
51
+ className="text-critical"
52
+ >
53
+ Delete
54
+ </a>
55
+ </td>
56
+ </tr>
57
+ ))}
58
+ </tbody>
59
+ <tfoot>
60
+ <tr>
61
+ <td colSpan="3" className="border-none">
62
+ <a
63
+ href="#"
64
+ className="text-interactive"
65
+ onClick={() => {
66
+ setRows([
67
+ ...rows,
68
+ {
69
+ min_price: '',
70
+ shipping_cost: '',
71
+ key: Math.random().toString(36).substring(7)
72
+ }
73
+ ]);
74
+ }}
75
+ >
76
+ + Add Line
77
+ </a>
78
+ </td>
79
+ </tr>
80
+ </tfoot>
81
+ </table>
82
+ </div>
83
+ );
84
+ }
85
+
86
+ PriceBasedPrice.propTypes = {
87
+ lines: PropTypes.arrayOf(
88
+ PropTypes.shape({
89
+ minPrice: PropTypes.shape({
90
+ value: PropTypes.number.isRequired
91
+ }),
92
+ cost: PropTypes.shape({
93
+ value: PropTypes.number.isRequired
94
+ })
95
+ })
96
+ )
97
+ };
98
+
99
+ PriceBasedPrice.defaultProps = {
100
+ lines: []
101
+ };