@evershop/evershop 2.1.1 → 2.1.2

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 (695) hide show
  1. package/dist/components/common/Area.js +199 -12
  2. package/dist/components/common/Area.js.map +1 -1
  3. package/dist/components/common/Editor.js +2 -1
  4. package/dist/components/common/Editor.js.map +1 -1
  5. package/dist/components/common/ExtendableTable.js +1 -1
  6. package/dist/components/common/ExtendableTable.js.map +1 -1
  7. package/dist/components/common/StaticImage.js +2 -2
  8. package/dist/components/common/StaticImage.js.map +1 -1
  9. package/dist/components/common/form/Editor.scss +3 -1
  10. package/dist/components/common/form/ReactSelectCreatableField.d.ts +1 -1
  11. package/dist/components/common/form/SelectField.js +3 -3
  12. package/dist/components/common/form/SelectField.js.map +1 -1
  13. package/dist/components/common/ui/Badge.d.ts +1 -1
  14. package/dist/components/common/ui/Item.js +1 -1
  15. package/dist/components/common/ui/Item.js.map +1 -1
  16. package/dist/components/common/ui/Sonner.d.ts +5 -0
  17. package/dist/components/common/ui/Sonner.js +24 -0
  18. package/dist/components/common/ui/Sonner.js.map +1 -0
  19. package/dist/components/common/ui/Tabs.d.ts +1 -1
  20. package/dist/components/frontStore/Footer.js +3 -1
  21. package/dist/components/frontStore/Footer.js.map +1 -1
  22. package/dist/components/frontStore/Pagination.js +1 -1
  23. package/dist/components/frontStore/Pagination.js.map +1 -1
  24. package/dist/components/frontStore/cart/CartContext.d.ts +2 -2
  25. package/dist/components/frontStore/cart/DefaultCartItemList.js +5 -5
  26. package/dist/components/frontStore/cart/DefaultCartItemList.js.map +1 -1
  27. package/dist/components/frontStore/cart/DefaultMiniCartDropdown.js +2 -19
  28. package/dist/components/frontStore/cart/DefaultMiniCartDropdown.js.map +1 -1
  29. package/dist/components/frontStore/cart/DefaultMinicartDropdownSummary.d.ts +7 -0
  30. package/dist/components/frontStore/cart/DefaultMinicartDropdownSummary.js +29 -0
  31. package/dist/components/frontStore/cart/DefaultMinicartDropdownSummary.js.map +1 -0
  32. package/dist/components/frontStore/catalog/CategoryInfo.js +2 -2
  33. package/dist/components/frontStore/catalog/CategoryInfo.js.map +1 -1
  34. package/dist/components/frontStore/catalog/DefaultCategoryFilterRender.js +1 -1
  35. package/dist/components/frontStore/catalog/DefaultCategoryFilterRender.js.map +1 -1
  36. package/dist/components/frontStore/catalog/DefaultProductFilterRender.js +3 -3
  37. package/dist/components/frontStore/catalog/DefaultProductFilterRender.js.map +1 -1
  38. package/dist/components/frontStore/catalog/ProductSorting.d.ts +2 -1
  39. package/dist/components/frontStore/catalog/ProductSorting.js +7 -3
  40. package/dist/components/frontStore/catalog/ProductSorting.js.map +1 -1
  41. package/dist/components/frontStore/catalog/SearchBox.d.ts +1 -1
  42. package/dist/components/frontStore/checkout/CheckoutButton.js +19 -12
  43. package/dist/components/frontStore/checkout/CheckoutButton.js.map +1 -1
  44. package/dist/components/frontStore/checkout/CheckoutContext.d.ts +10 -9
  45. package/dist/components/frontStore/checkout/CheckoutContext.js +39 -25
  46. package/dist/components/frontStore/checkout/CheckoutContext.js.map +1 -1
  47. package/dist/components/frontStore/checkout/ContactInformation.js +12 -8
  48. package/dist/components/frontStore/checkout/ContactInformation.js.map +1 -1
  49. package/dist/components/frontStore/checkout/Payment.js +19 -12
  50. package/dist/components/frontStore/checkout/Payment.js.map +1 -1
  51. package/dist/components/frontStore/checkout/Shipment.js +19 -13
  52. package/dist/components/frontStore/checkout/Shipment.js.map +1 -1
  53. package/dist/components/frontStore/checkout/payment/PaymentMethods.js +1 -1
  54. package/dist/components/frontStore/checkout/payment/PaymentMethods.js.map +1 -1
  55. package/dist/components/frontStore/checkout/shipment/ShippingMethods.js +2 -2
  56. package/dist/components/frontStore/checkout/shipment/ShippingMethods.js.map +1 -1
  57. package/dist/components/frontStore/customer/CustomerContext.d.ts +3 -3
  58. package/dist/components/frontStore/customer/RegistrationForm.js +1 -1
  59. package/dist/components/frontStore/customer/address/addressForm/AddressForm.js +1 -1
  60. package/dist/components/frontStore/customer/address/addressForm/AddressForm.js.map +1 -1
  61. package/dist/lib/componee/scanForComponents.js.map +1 -1
  62. package/dist/lib/event/EventProcessor.d.ts +17 -0
  63. package/dist/lib/event/EventProcessor.js +63 -0
  64. package/dist/lib/event/EventProcessor.js.map +1 -0
  65. package/dist/lib/event/EventStorage.d.ts +36 -0
  66. package/dist/lib/event/EventStorage.js +49 -0
  67. package/dist/lib/event/EventStorage.js.map +1 -0
  68. package/dist/lib/event/callSubscibers.d.ts +1 -1
  69. package/dist/lib/event/callSubscibers.js +7 -11
  70. package/dist/lib/event/callSubscibers.js.map +1 -1
  71. package/dist/lib/event/event-manager.js +38 -71
  72. package/dist/lib/event/event-manager.js.map +1 -1
  73. package/dist/lib/event/loadSubscribers.d.ts +10 -1
  74. package/dist/lib/event/loadSubscribers.js +2 -4
  75. package/dist/lib/event/loadSubscribers.js.map +1 -1
  76. package/dist/lib/event/tests/unit/EventProcessor.test.d.ts +1 -0
  77. package/dist/lib/event/tests/unit/EventProcessor.test.js +196 -0
  78. package/dist/lib/event/tests/unit/EventProcessor.test.js.map +1 -0
  79. package/dist/lib/event/tests/unit/callSubscribers.test.d.ts +1 -0
  80. package/dist/lib/event/tests/unit/callSubscribers.test.js +57 -0
  81. package/dist/lib/event/tests/unit/callSubscribers.test.js.map +1 -0
  82. package/dist/lib/mail/emailHelper.d.ts +2 -2
  83. package/dist/lib/postgres/connection.d.ts +3 -1
  84. package/dist/lib/postgres/connection.js +10 -6
  85. package/dist/lib/postgres/connection.js.map +1 -1
  86. package/dist/lib/postgres/query.d.ts +296 -0
  87. package/dist/lib/postgres/query.js +42 -0
  88. package/dist/lib/postgres/query.js.map +1 -0
  89. package/dist/lib/util/getConfig.d.ts +6 -6
  90. package/dist/lib/util/registry.d.ts +17 -2
  91. package/dist/lib/util/registry.js.map +1 -1
  92. package/dist/lib/util/sanitizeHtml.d.ts +16 -0
  93. package/dist/lib/util/sanitizeHtml.js +45 -0
  94. package/dist/lib/util/sanitizeHtml.js.map +1 -0
  95. package/dist/lib/webpack/loaders/AreaLoader.js +0 -1
  96. package/dist/lib/webpack/loaders/AreaLoader.js.map +1 -1
  97. package/dist/lib/webpack/util/getTailwindSources.js +1 -1
  98. package/dist/lib/webpack/util/getTailwindSources.js.map +1 -1
  99. package/dist/modules/auth/api/refreshUserToken/refreshToken.js +4 -6
  100. package/dist/modules/auth/api/refreshUserToken/refreshToken.js.map +1 -1
  101. package/dist/modules/auth/bootstrap.d.ts +1 -1
  102. package/dist/modules/auth/bootstrap.js +16 -14
  103. package/dist/modules/auth/bootstrap.js.map +1 -1
  104. package/dist/modules/auth/services/buildAdminUserPayload.d.ts +10 -0
  105. package/dist/modules/auth/services/buildAdminUserPayload.js +19 -0
  106. package/dist/modules/auth/services/buildAdminUserPayload.js.map +1 -0
  107. package/dist/modules/auth/services/loginUserWithEmail.d.ts +3 -7
  108. package/dist/modules/auth/services/loginUserWithEmail.js +15 -6
  109. package/dist/modules/auth/services/loginUserWithEmail.js.map +1 -1
  110. package/dist/modules/auth/services/logoutUser.d.ts +3 -4
  111. package/dist/modules/auth/services/logoutUser.js +12 -1
  112. package/dist/modules/auth/services/logoutUser.js.map +1 -1
  113. package/dist/modules/base/api/global/[apiResponse]apiErrorHandler.d.ts +3 -1
  114. package/dist/modules/base/api/global/[apiResponse]apiErrorHandler.js.map +1 -1
  115. package/dist/modules/base/api/global/[auth]apiResponse[apiErrorHandler].d.ts +3 -1
  116. package/dist/modules/base/api/global/[auth]apiResponse[apiErrorHandler].js.map +1 -1
  117. package/dist/modules/base/api/global/[auth]payloadValidate.d.ts +3 -1
  118. package/dist/modules/base/api/global/[auth]payloadValidate.js +3 -2
  119. package/dist/modules/base/api/global/[auth]payloadValidate.js.map +1 -1
  120. package/dist/modules/base/api/global/[payloadValidate]escapeHtml.d.ts +3 -1
  121. package/dist/modules/base/api/global/[payloadValidate]escapeHtml.js +0 -2
  122. package/dist/modules/base/api/global/[payloadValidate]escapeHtml.js.map +1 -1
  123. package/dist/modules/base/migration/Version-1.0.2.d.ts +2 -0
  124. package/dist/modules/base/migration/Version-1.0.2.js +22 -0
  125. package/dist/modules/base/migration/Version-1.0.2.js.map +1 -0
  126. package/dist/modules/base/pages/admin/all/global.scss +1 -1
  127. package/dist/modules/base/services/escapePayload.js +20 -13
  128. package/dist/modules/base/services/escapePayload.js.map +1 -1
  129. package/dist/modules/base/services/markSkipEscape.d.ts +5 -0
  130. package/dist/modules/base/services/markSkipEscape.js +25 -20
  131. package/dist/modules/base/services/markSkipEscape.js.map +1 -1
  132. package/dist/modules/catalog/api/createAttribute/createAttribute[finish].d.ts +3 -1
  133. package/dist/modules/catalog/api/createCategory/[context]bodyParser[auth].d.ts +1 -1
  134. package/dist/modules/catalog/api/createCategory/[context]bodyParser[auth].js.map +1 -1
  135. package/dist/modules/catalog/api/createCategory/createCategory[finish].d.ts +5 -1
  136. package/dist/modules/catalog/api/createCategory/createCategory[finish].js.map +1 -1
  137. package/dist/modules/catalog/api/createCategory/finish[apiResponse].d.ts +3 -1
  138. package/dist/modules/catalog/api/createCategory/finish[apiResponse].js +2 -2
  139. package/dist/modules/catalog/api/createCategory/finish[apiResponse].js.map +1 -1
  140. package/dist/modules/catalog/api/createCategory/payloadSchema.json +76 -0
  141. package/dist/modules/catalog/api/createCollection/[context]bodyParser[auth].d.ts +1 -1
  142. package/dist/modules/catalog/api/createCollection/[context]bodyParser[auth].js.map +1 -1
  143. package/dist/modules/catalog/api/createCollection/createCollection[finish].d.ts +4 -1
  144. package/dist/modules/catalog/api/createCollection/createCollection[finish].js.map +1 -1
  145. package/dist/modules/catalog/api/createCollection/finish[apiResponse].d.ts +3 -1
  146. package/dist/modules/catalog/api/createCollection/finish[apiResponse].js +1 -1
  147. package/dist/modules/catalog/api/createCollection/finish[apiResponse].js.map +1 -1
  148. package/dist/modules/catalog/{services/collection/collectionDataSchema.json → api/createCollection/payloadSchema.json} +1 -0
  149. package/dist/modules/catalog/api/createProduct/[context]bodyParser[auth].d.ts +1 -1
  150. package/dist/modules/catalog/api/createProduct/[context]bodyParser[auth].js.map +1 -1
  151. package/dist/modules/catalog/api/createProduct/createProduct[finish].d.ts +5 -1
  152. package/dist/modules/catalog/api/createProduct/createProduct[finish].js.map +1 -1
  153. package/dist/modules/catalog/api/createProduct/finish[apiResponse].d.ts +3 -1
  154. package/dist/modules/catalog/api/createProduct/finish[apiResponse].js +2 -2
  155. package/dist/modules/catalog/api/createProduct/finish[apiResponse].js.map +1 -1
  156. package/dist/modules/catalog/api/createProduct/payloadSchema.json +76 -0
  157. package/dist/modules/catalog/api/updateAttribute/updateAttribute[finish].d.ts +3 -1
  158. package/dist/modules/catalog/api/updateCategory/[context]bodyParser[auth].d.ts +1 -1
  159. package/dist/modules/catalog/api/updateCategory/[context]bodyParser[auth].js.map +1 -1
  160. package/dist/modules/catalog/api/updateCategory/finish[apiResponse].d.ts +3 -1
  161. package/dist/modules/catalog/api/updateCategory/finish[apiResponse].js +2 -2
  162. package/dist/modules/catalog/api/updateCategory/finish[apiResponse].js.map +1 -1
  163. package/dist/modules/catalog/api/updateCategory/payloadSchema.json +76 -0
  164. package/dist/modules/catalog/api/updateCategory/updateCategory[finish].d.ts +5 -1
  165. package/dist/modules/catalog/api/updateCategory/updateCategory[finish].js +1 -1
  166. package/dist/modules/catalog/api/updateCategory/updateCategory[finish].js.map +1 -1
  167. package/dist/modules/catalog/api/updateCollection/[context]bodyParser[auth].d.ts +1 -1
  168. package/dist/modules/catalog/api/updateCollection/[context]bodyParser[auth].js.map +1 -1
  169. package/dist/modules/catalog/api/updateCollection/finish[apiResponse].d.ts +3 -1
  170. package/dist/modules/catalog/api/updateCollection/finish[apiResponse].js +1 -1
  171. package/dist/modules/catalog/api/updateCollection/finish[apiResponse].js.map +1 -1
  172. package/{src/modules/catalog/services/collection/collectionDataSchema.json → dist/modules/catalog/api/updateCollection/payloadSchema.json} +1 -0
  173. package/dist/modules/catalog/api/updateCollection/updateCollection[finish].d.ts +5 -1
  174. package/dist/modules/catalog/api/updateCollection/updateCollection[finish].js +1 -1
  175. package/dist/modules/catalog/api/updateCollection/updateCollection[finish].js.map +1 -1
  176. package/dist/modules/catalog/api/updateProduct/[context]bodyParser[auth].d.ts +1 -1
  177. package/dist/modules/catalog/api/updateProduct/[context]bodyParser[auth].js.map +1 -1
  178. package/dist/modules/catalog/api/updateProduct/finish[apiResponse].d.ts +3 -1
  179. package/dist/modules/catalog/api/updateProduct/finish[apiResponse].js +2 -2
  180. package/dist/modules/catalog/api/updateProduct/finish[apiResponse].js.map +1 -1
  181. package/dist/modules/catalog/api/updateProduct/payloadSchema.json +76 -0
  182. package/dist/modules/catalog/api/updateProduct/updateProduct[finish].d.ts +5 -1
  183. package/dist/modules/catalog/api/updateProduct/updateProduct[finish].js +1 -1
  184. package/dist/modules/catalog/api/updateProduct/updateProduct[finish].js.map +1 -1
  185. package/dist/modules/catalog/graphql/types/Category/Category.resolvers.d.ts +36 -37
  186. package/dist/modules/catalog/graphql/types/Category/Category.resolvers.js +0 -18
  187. package/dist/modules/catalog/graphql/types/Category/Category.resolvers.js.map +1 -1
  188. package/dist/modules/catalog/graphql/types/Collection/Collection.resolvers.js +1 -8
  189. package/dist/modules/catalog/graphql/types/Collection/Collection.resolvers.js.map +1 -1
  190. package/dist/modules/catalog/graphql/types/Product/Product.resolvers.js +0 -18
  191. package/dist/modules/catalog/graphql/types/Product/Product.resolvers.js.map +1 -1
  192. package/dist/modules/catalog/pages/admin/productEdit/variants/CreateVariant.js +4 -3
  193. package/dist/modules/catalog/pages/admin/productEdit/variants/CreateVariant.js.map +1 -1
  194. package/dist/modules/catalog/pages/admin/productEdit/variants/CreateVariantGroup.d.ts +1 -0
  195. package/dist/modules/catalog/pages/admin/productEdit/variants/CreateVariantGroup.js +12 -6
  196. package/dist/modules/catalog/pages/admin/productEdit/variants/CreateVariantGroup.js.map +1 -1
  197. package/dist/modules/catalog/pages/admin/productEdit/variants/EditVariant.js +4 -3
  198. package/dist/modules/catalog/pages/admin/productEdit/variants/EditVariant.js.map +1 -1
  199. package/dist/modules/catalog/pages/admin/productEdit/variants/New.js +6 -10
  200. package/dist/modules/catalog/pages/admin/productEdit/variants/New.js.map +1 -1
  201. package/dist/modules/catalog/pages/admin/productEdit/variants/VariantModal.d.ts +2 -0
  202. package/dist/modules/catalog/pages/admin/productEdit/variants/VariantModal.js +8 -2
  203. package/dist/modules/catalog/pages/admin/productEdit/variants/VariantModal.js.map +1 -1
  204. package/dist/modules/catalog/pages/admin/productEdit+productNew/General.js +4 -1
  205. package/dist/modules/catalog/pages/admin/productEdit+productNew/General.js.map +1 -1
  206. package/dist/modules/catalog/pages/frontStore/categoryView/CategoryView.js +1 -6
  207. package/dist/modules/catalog/pages/frontStore/categoryView/CategoryView.js.map +1 -1
  208. package/dist/modules/catalog/pages/frontStore/productView/ProductView.js +7 -1
  209. package/dist/modules/catalog/pages/frontStore/productView/ProductView.js.map +1 -1
  210. package/dist/modules/catalog/services/attribute/createProductAttribute.d.ts +78 -2
  211. package/dist/modules/catalog/services/attribute/createProductAttribute.js +25 -1
  212. package/dist/modules/catalog/services/attribute/createProductAttribute.js.map +1 -1
  213. package/dist/modules/catalog/services/attribute/deleteProductAttribute.d.ts +7 -1
  214. package/dist/modules/catalog/services/attribute/deleteProductAttribute.js +13 -1
  215. package/dist/modules/catalog/services/attribute/deleteProductAttribute.js.map +1 -1
  216. package/dist/modules/catalog/services/attribute/updateProductAttribute.d.ts +56 -2
  217. package/dist/modules/catalog/services/attribute/updateProductAttribute.js +28 -6
  218. package/dist/modules/catalog/services/attribute/updateProductAttribute.js.map +1 -1
  219. package/dist/modules/catalog/services/category/createCategory.d.ts +28 -2
  220. package/dist/modules/catalog/services/category/createCategory.js +18 -1
  221. package/dist/modules/catalog/services/category/createCategory.js.map +1 -1
  222. package/dist/modules/catalog/services/category/deleteCategory.d.ts +7 -1
  223. package/dist/modules/catalog/services/category/deleteCategory.js +13 -1
  224. package/dist/modules/catalog/services/category/deleteCategory.js.map +1 -1
  225. package/dist/modules/catalog/services/category/updateCategory.d.ts +25 -1
  226. package/dist/modules/catalog/services/category/updateCategory.js +26 -4
  227. package/dist/modules/catalog/services/category/updateCategory.js.map +1 -1
  228. package/dist/modules/catalog/services/collection/createCollection.d.ts +12 -3
  229. package/dist/modules/catalog/services/collection/createCollection.js +20 -20
  230. package/dist/modules/catalog/services/collection/createCollection.js.map +1 -1
  231. package/dist/modules/catalog/services/collection/deleteCollection.d.ts +7 -1
  232. package/dist/modules/catalog/services/collection/deleteCollection.js +13 -1
  233. package/dist/modules/catalog/services/collection/deleteCollection.js.map +1 -1
  234. package/dist/modules/catalog/services/collection/updateCollection.d.ts +9 -1
  235. package/dist/modules/catalog/services/collection/updateCollection.js +22 -24
  236. package/dist/modules/catalog/services/collection/updateCollection.js.map +1 -1
  237. package/dist/modules/catalog/services/index.d.ts +29 -18
  238. package/dist/modules/catalog/services/index.js +35 -18
  239. package/dist/modules/catalog/services/index.js.map +1 -1
  240. package/dist/modules/catalog/services/product/createProduct.d.ts +56 -4
  241. package/dist/modules/catalog/services/product/createProduct.js +36 -1
  242. package/dist/modules/catalog/services/product/createProduct.js.map +1 -1
  243. package/dist/modules/catalog/services/product/deleteProduct.d.ts +7 -2
  244. package/dist/modules/catalog/services/product/deleteProduct.js +13 -1
  245. package/dist/modules/catalog/services/product/deleteProduct.js.map +1 -1
  246. package/dist/modules/catalog/services/product/updateProduct.d.ts +58 -2
  247. package/dist/modules/catalog/services/product/updateProduct.js +43 -4
  248. package/dist/modules/catalog/services/product/updateProduct.js.map +1 -1
  249. package/dist/modules/checkout/pages/frontStore/cart/ShoppingCart.js +1 -3
  250. package/dist/modules/checkout/pages/frontStore/cart/ShoppingCart.js.map +1 -1
  251. package/dist/modules/checkout/pages/frontStore/checkout/Checkout.js +3 -1
  252. package/dist/modules/checkout/pages/frontStore/checkout/Checkout.js.map +1 -1
  253. package/dist/modules/checkout/services/addBillingAddress.d.ts +15 -0
  254. package/dist/modules/checkout/services/addBillingAddress.js +24 -6
  255. package/dist/modules/checkout/services/addBillingAddress.js.map +1 -1
  256. package/dist/modules/checkout/services/addCartItem.d.ts +12 -0
  257. package/dist/modules/checkout/services/addCartItem.js +7 -1
  258. package/dist/modules/checkout/services/addCartItem.js.map +1 -1
  259. package/dist/modules/checkout/services/addShippingAddress.d.ts +13 -0
  260. package/dist/modules/checkout/services/addShippingAddress.js +18 -6
  261. package/dist/modules/checkout/services/addShippingAddress.js.map +1 -1
  262. package/dist/modules/checkout/services/checkout.d.ts +19 -1
  263. package/dist/modules/checkout/services/checkout.js +12 -6
  264. package/dist/modules/checkout/services/checkout.js.map +1 -1
  265. package/dist/modules/checkout/services/index.d.ts +5 -3
  266. package/dist/modules/checkout/services/index.js +5 -3
  267. package/dist/modules/checkout/services/index.js.map +1 -1
  268. package/dist/modules/checkout/services/orderCreator.d.ts +48 -0
  269. package/dist/modules/checkout/services/orderCreator.js +25 -1
  270. package/dist/modules/checkout/services/orderCreator.js.map +1 -1
  271. package/dist/modules/checkout/services/removeCartItem.d.ts +8 -0
  272. package/dist/modules/checkout/services/removeCartItem.js +7 -1
  273. package/dist/modules/checkout/services/removeCartItem.js.map +1 -1
  274. package/dist/modules/checkout/services/updateCartItemQty.d.ts +14 -0
  275. package/dist/modules/checkout/services/updateCartItemQty.js +7 -1
  276. package/dist/modules/checkout/services/updateCartItemQty.js.map +1 -1
  277. package/dist/modules/cms/api/createCmsPage/[context]bodyParser[auth].d.ts +1 -1
  278. package/dist/modules/cms/api/createCmsPage/[context]bodyParser[auth].js.map +1 -1
  279. package/dist/modules/cms/api/createCmsPage/createPage[finish].d.ts +3 -1
  280. package/dist/modules/cms/api/createCmsPage/createPage[finish].js +1 -1
  281. package/dist/modules/cms/api/createCmsPage/createPage[finish].js.map +1 -1
  282. package/dist/modules/cms/api/createCmsPage/finish[apiResponse].d.ts +3 -1
  283. package/dist/modules/cms/api/createCmsPage/finish[apiResponse].js +2 -2
  284. package/dist/modules/cms/api/createCmsPage/finish[apiResponse].js.map +1 -1
  285. package/dist/modules/cms/api/createCmsPage/payloadSchema.json +76 -0
  286. package/dist/modules/cms/api/deleteCmsPage/deleteCmsPage.d.ts +3 -1
  287. package/dist/modules/cms/api/deleteCmsPage/deleteCmsPage.js +1 -1
  288. package/dist/modules/cms/api/deleteCmsPage/deleteCmsPage.js.map +1 -1
  289. package/dist/modules/cms/api/updateCmsPage/[context]bodyParser[auth].d.ts +1 -1
  290. package/dist/modules/cms/api/updateCmsPage/[context]bodyParser[auth].js.map +1 -1
  291. package/dist/modules/cms/api/updateCmsPage/finish[apiResponse].d.ts +3 -1
  292. package/dist/modules/cms/api/updateCmsPage/finish[apiResponse].js +2 -2
  293. package/dist/modules/cms/api/updateCmsPage/finish[apiResponse].js.map +1 -1
  294. package/dist/modules/cms/api/updateCmsPage/payloadSchema.json +76 -0
  295. package/dist/modules/cms/api/updateCmsPage/updatePage[finish].d.ts +2 -1
  296. package/dist/modules/cms/api/updateCmsPage/updatePage[finish].js.map +1 -1
  297. package/dist/modules/cms/bootstrap.d.ts +1 -1
  298. package/dist/modules/cms/bootstrap.js +18 -0
  299. package/dist/modules/cms/bootstrap.js.map +1 -1
  300. package/dist/modules/cms/components/BasicMenu.js +1 -1
  301. package/dist/modules/cms/components/BasicMenu.js.map +1 -1
  302. package/dist/modules/cms/graphql/types/CmsPage/CmsPage.resolvers.js +0 -18
  303. package/dist/modules/cms/graphql/types/CmsPage/CmsPage.resolvers.js.map +1 -1
  304. package/dist/modules/cms/graphql/types/Widget/Widget.resolvers.js +0 -17
  305. package/dist/modules/cms/graphql/types/Widget/Widget.resolvers.js.map +1 -1
  306. package/dist/modules/cms/services/index.d.ts +3 -0
  307. package/dist/modules/cms/services/index.js +3 -0
  308. package/dist/modules/cms/services/index.js.map +1 -1
  309. package/dist/modules/cms/services/page/createPage.d.ts +18 -2
  310. package/dist/modules/cms/services/page/createPage.js +25 -7
  311. package/dist/modules/cms/services/page/createPage.js.map +1 -1
  312. package/dist/modules/cms/services/page/deletePage.d.ts +6 -2
  313. package/dist/modules/cms/services/page/deletePage.js +18 -6
  314. package/dist/modules/cms/services/page/deletePage.js.map +1 -1
  315. package/dist/modules/cms/services/page/pageDataSchema.json +9 -1
  316. package/dist/modules/cms/services/page/updatePage.d.ts +22 -1
  317. package/dist/modules/cms/services/page/updatePage.js +19 -2
  318. package/dist/modules/cms/services/page/updatePage.js.map +1 -1
  319. package/dist/modules/cms/services/widget/createWidget.d.ts +12 -1
  320. package/dist/modules/cms/services/widget/createWidget.js +14 -2
  321. package/dist/modules/cms/services/widget/createWidget.js.map +1 -1
  322. package/dist/modules/cms/services/widget/deleteWidget.d.ts +7 -1
  323. package/dist/modules/cms/services/widget/deleteWidget.js +13 -1
  324. package/dist/modules/cms/services/widget/deleteWidget.js.map +1 -1
  325. package/dist/modules/cms/services/widget/updateWidget.d.ts +7 -1
  326. package/dist/modules/cms/services/widget/updateWidget.js +15 -3
  327. package/dist/modules/cms/services/widget/updateWidget.js.map +1 -1
  328. package/dist/modules/cod/pages/frontStore/checkout/CashOnDelivery.js +2 -2
  329. package/dist/modules/cod/pages/frontStore/checkout/CashOnDelivery.js.map +1 -1
  330. package/dist/modules/customer/api/refreshCustomerToken/refreshToken.js +4 -6
  331. package/dist/modules/customer/api/refreshCustomerToken/refreshToken.js.map +1 -1
  332. package/dist/modules/customer/pages/frontStore/login/LoginPage.js +10 -9
  333. package/dist/modules/customer/pages/frontStore/login/LoginPage.js.map +1 -1
  334. package/dist/modules/customer/pages/frontStore/register/RegisterPage.js +14 -13
  335. package/dist/modules/customer/pages/frontStore/register/RegisterPage.js.map +1 -1
  336. package/dist/modules/customer/services/customer/address/createCustomerAddress.d.ts +13 -0
  337. package/dist/modules/customer/services/customer/address/createCustomerAddress.js +13 -1
  338. package/dist/modules/customer/services/customer/address/createCustomerAddress.js.map +1 -1
  339. package/dist/modules/customer/services/customer/address/deleteCustomerAddress.d.ts +5 -0
  340. package/dist/modules/customer/services/customer/address/deleteCustomerAddress.js +13 -1
  341. package/dist/modules/customer/services/customer/address/deleteCustomerAddress.js.map +1 -1
  342. package/dist/modules/customer/services/customer/address/updateCustomerAddress.d.ts +13 -0
  343. package/dist/modules/customer/services/customer/address/updateCustomerAddress.js +13 -1
  344. package/dist/modules/customer/services/customer/address/updateCustomerAddress.js.map +1 -1
  345. package/dist/modules/customer/services/customer/buildCustomerPayload.d.ts +8 -0
  346. package/dist/modules/customer/services/customer/buildCustomerPayload.js +19 -0
  347. package/dist/modules/customer/services/customer/buildCustomerPayload.js.map +1 -0
  348. package/dist/modules/customer/services/customer/createCustomer.d.ts +19 -1
  349. package/dist/modules/customer/services/customer/createCustomer.js +17 -4
  350. package/dist/modules/customer/services/customer/createCustomer.js.map +1 -1
  351. package/dist/modules/customer/services/customer/deleteCustomer.d.ts +7 -2
  352. package/dist/modules/customer/services/customer/deleteCustomer.js +13 -1
  353. package/dist/modules/customer/services/customer/deleteCustomer.js.map +1 -1
  354. package/dist/modules/customer/services/customer/loginCustomerWithEmail.js +3 -4
  355. package/dist/modules/customer/services/customer/loginCustomerWithEmail.js.map +1 -1
  356. package/dist/modules/customer/services/customer/updateCustomer.d.ts +23 -1
  357. package/dist/modules/customer/services/customer/updateCustomer.js +13 -1
  358. package/dist/modules/customer/services/customer/updateCustomer.js.map +1 -1
  359. package/dist/modules/customer/services/customer/updatePassword.d.ts +13 -0
  360. package/dist/modules/customer/services/customer/updatePassword.js +13 -1
  361. package/dist/modules/customer/services/customer/updatePassword.js.map +1 -1
  362. package/dist/modules/customer/services/index.d.ts +17 -11
  363. package/dist/modules/customer/services/index.js +26 -11
  364. package/dist/modules/customer/services/index.js.map +1 -1
  365. package/dist/modules/oms/bootstrap.js +8 -8
  366. package/dist/modules/oms/bootstrap.js.map +1 -1
  367. package/dist/modules/oms/services/addOrderActivityLog.d.ts +20 -0
  368. package/dist/modules/oms/services/addOrderActivityLog.js +7 -1
  369. package/dist/modules/oms/services/addOrderActivityLog.js.map +1 -1
  370. package/dist/modules/oms/services/addPaymentTransaction.d.ts +3 -0
  371. package/dist/modules/oms/services/addPaymentTransaction.js +16 -0
  372. package/dist/modules/oms/services/addPaymentTransaction.js.map +1 -0
  373. package/dist/modules/oms/services/cancelOrder.d.ts +61 -0
  374. package/dist/modules/oms/services/cancelOrder.js +31 -1
  375. package/dist/modules/oms/services/cancelOrder.js.map +1 -1
  376. package/dist/modules/oms/services/createShipment.d.ts +20 -0
  377. package/dist/modules/oms/services/createShipment.js +7 -1
  378. package/dist/modules/oms/services/createShipment.js.map +1 -1
  379. package/dist/modules/oms/services/index.d.ts +4 -0
  380. package/dist/modules/oms/services/index.js +4 -0
  381. package/dist/modules/oms/services/index.js.map +1 -1
  382. package/dist/modules/oms/services/orderLoader.d.ts +8 -0
  383. package/dist/modules/oms/services/orderLoader.js +57 -0
  384. package/dist/modules/oms/services/orderLoader.js.map +1 -0
  385. package/dist/modules/oms/services/statusManager.d.ts +54 -0
  386. package/dist/modules/oms/services/statusManager.js +101 -0
  387. package/dist/modules/oms/services/statusManager.js.map +1 -0
  388. package/dist/modules/oms/services/updateOrderStatus.d.ts +37 -0
  389. package/dist/modules/oms/services/updateOrderStatus.js +34 -9
  390. package/dist/modules/oms/services/updateOrderStatus.js.map +1 -1
  391. package/dist/modules/oms/services/updatePaymentStatus.d.ts +26 -0
  392. package/dist/modules/oms/services/updatePaymentStatus.js +13 -1
  393. package/dist/modules/oms/services/updatePaymentStatus.js.map +1 -1
  394. package/dist/modules/oms/services/updateShipmentStatus.d.ts +26 -0
  395. package/dist/modules/oms/services/updateShipmentStatus.js +13 -1
  396. package/dist/modules/oms/services/updateShipmentStatus.js.map +1 -1
  397. package/dist/modules/paypal/api/paypalAuthorizePayment/[bodyParser]authorize.js +1 -1
  398. package/dist/modules/paypal/api/paypalAuthorizePayment/[bodyParser]authorize.js.map +1 -1
  399. package/dist/modules/paypal/api/paypalCaptureAuthorizedPayment/[bodyParser]capture.js +2 -2
  400. package/dist/modules/paypal/api/paypalCaptureAuthorizedPayment/[bodyParser]capture.js.map +1 -1
  401. package/dist/modules/paypal/api/paypalCapturePayment/[bodyParser]capture.js +1 -1
  402. package/dist/modules/paypal/api/paypalCapturePayment/[bodyParser]capture.js.map +1 -1
  403. package/dist/modules/paypal/bootstrap.d.ts +1 -1
  404. package/dist/modules/paypal/bootstrap.js +22 -2
  405. package/dist/modules/paypal/bootstrap.js.map +1 -1
  406. package/dist/modules/paypal/graphql/types/PaypalSetting/PaypalSetting.admin.resolvers.d.ts +1 -1
  407. package/dist/modules/paypal/migration/Version-1.0.0.d.ts +3 -0
  408. package/dist/modules/paypal/migration/Version-1.0.0.js +19 -0
  409. package/dist/modules/paypal/migration/Version-1.0.0.js.map +1 -0
  410. package/dist/modules/paypal/pages/admin/orderEdit/PaypalCaptureButton.js +1 -1
  411. package/dist/modules/paypal/pages/admin/orderEdit/PaypalCaptureButton.js.map +1 -1
  412. package/dist/modules/paypal/pages/frontStore/checkout/Paypal.js +8 -3
  413. package/dist/modules/paypal/pages/frontStore/checkout/Paypal.js.map +1 -1
  414. package/dist/modules/promotion/api/createCoupon/createCoupon[finish].d.ts +1 -1
  415. package/dist/modules/promotion/api/updateCoupon/updateCoupon[finish].d.ts +1 -1
  416. package/dist/modules/promotion/services/coupon/createCoupon.d.ts +45 -1
  417. package/dist/modules/promotion/services/coupon/createCoupon.js +17 -5
  418. package/dist/modules/promotion/services/coupon/createCoupon.js.map +1 -1
  419. package/dist/modules/promotion/services/coupon/deleteCoupon.d.ts +8 -1
  420. package/dist/modules/promotion/services/coupon/deleteCoupon.js +16 -4
  421. package/dist/modules/promotion/services/coupon/deleteCoupon.js.map +1 -1
  422. package/dist/modules/promotion/services/coupon/updateCoupon.d.ts +8 -1
  423. package/dist/modules/promotion/services/coupon/updateCoupon.js +27 -13
  424. package/dist/modules/promotion/services/coupon/updateCoupon.js.map +1 -1
  425. package/dist/modules/promotion/services/index.d.ts +6 -0
  426. package/dist/modules/promotion/services/index.js +10 -0
  427. package/dist/modules/promotion/services/index.js.map +1 -0
  428. package/dist/modules/setting/services/setting.d.ts +10 -1
  429. package/dist/modules/setting/services/setting.js +27 -0
  430. package/dist/modules/setting/services/setting.js.map +1 -1
  431. package/dist/modules/stripe/api/capturePaymentIntent/[context]bodyParser[auth].d.ts +1 -1
  432. package/dist/modules/stripe/api/capturePaymentIntent/[context]bodyParser[auth].js.map +1 -1
  433. package/dist/modules/stripe/api/capturePaymentIntent/capturePaymentIntent.d.ts +4 -1
  434. package/dist/modules/stripe/api/capturePaymentIntent/capturePaymentIntent.js +6 -4
  435. package/dist/modules/stripe/api/capturePaymentIntent/capturePaymentIntent.js.map +1 -1
  436. package/dist/modules/stripe/api/createPaymentIntent/[context]bodyParser[auth].d.ts +1 -1
  437. package/dist/modules/stripe/api/createPaymentIntent/[context]bodyParser[auth].js.map +1 -1
  438. package/dist/modules/stripe/api/createPaymentIntent/createPaymentIntent.d.ts +3 -1
  439. package/dist/modules/stripe/api/createPaymentIntent/createPaymentIntent.js +4 -4
  440. package/dist/modules/stripe/api/createPaymentIntent/createPaymentIntent.js.map +1 -1
  441. package/dist/modules/stripe/api/refundPaymentIntent/[context]bodyParser[auth].d.ts +1 -1
  442. package/dist/modules/stripe/api/refundPaymentIntent/[context]bodyParser[auth].js.map +1 -1
  443. package/dist/modules/stripe/api/refundPaymentIntent/refundPaymentIntent.d.ts +1 -1
  444. package/dist/modules/stripe/api/refundPaymentIntent/refundPaymentIntent.js +11 -7
  445. package/dist/modules/stripe/api/refundPaymentIntent/refundPaymentIntent.js.map +1 -1
  446. package/dist/modules/stripe/api/stripeWebHook/[bodyJson]webhook.d.ts +3 -1
  447. package/dist/modules/stripe/api/stripeWebHook/[bodyJson]webhook.js +6 -6
  448. package/dist/modules/stripe/api/stripeWebHook/[bodyJson]webhook.js.map +1 -1
  449. package/dist/modules/stripe/api/stripeWebHook/bodyJson.d.ts +1 -1
  450. package/dist/modules/stripe/api/stripeWebHook/bodyJson.js.map +1 -1
  451. package/dist/modules/stripe/bootstrap.d.ts +1 -1
  452. package/dist/modules/stripe/bootstrap.js +31 -15
  453. package/dist/modules/stripe/bootstrap.js.map +1 -1
  454. package/dist/modules/stripe/graphql/types/StripeSetting/StripeSetting.resolvers.d.ts +1 -1
  455. package/dist/modules/stripe/migration/Version-1.0.0.d.ts +3 -0
  456. package/dist/modules/stripe/migration/Version-1.0.0.js +19 -0
  457. package/dist/modules/stripe/migration/Version-1.0.0.js.map +1 -0
  458. package/dist/modules/stripe/pages/admin/orderEdit/StripeCaptureButton.js +1 -1
  459. package/dist/modules/stripe/pages/admin/orderEdit/StripeCaptureButton.js.map +1 -1
  460. package/dist/modules/stripe/pages/admin/orderEdit/StripeRefundButton.js +7 -3
  461. package/dist/modules/stripe/pages/admin/orderEdit/StripeRefundButton.js.map +1 -1
  462. package/dist/modules/stripe/pages/frontStore/checkout/Stripe.js +16 -7
  463. package/dist/modules/stripe/pages/frontStore/checkout/Stripe.js.map +1 -1
  464. package/dist/modules/stripe/pages/frontStore/stripeReturn/index.d.ts +3 -1
  465. package/dist/modules/stripe/pages/frontStore/stripeReturn/index.js +8 -4
  466. package/dist/modules/stripe/pages/frontStore/stripeReturn/index.js.map +1 -1
  467. package/dist/modules/stripe/services/cancelPayment.d.ts +1 -1
  468. package/dist/modules/stripe/services/cancelPayment.js +3 -3
  469. package/dist/modules/stripe/services/cancelPayment.js.map +1 -1
  470. package/dist/types/apiResponse.d.ts +1 -1
  471. package/dist/types/appContext.d.ts +7 -4
  472. package/dist/types/customerAddress.d.ts +1 -1
  473. package/dist/types/db/index.d.ts +61 -61
  474. package/dist/types/event.d.ts +27 -14
  475. package/dist/types/registry.d.ts +119 -0
  476. package/dist/types/registry.js +2 -0
  477. package/dist/types/registry.js.map +1 -0
  478. package/dist/types/widget.d.ts +3 -0
  479. package/package.json +21 -12
  480. package/src/components/common/Area.tsx +256 -40
  481. package/src/components/common/Editor.tsx +6 -3
  482. package/src/components/common/ExtendableTable.tsx +1 -1
  483. package/src/components/common/StaticImage.tsx +2 -2
  484. package/src/components/common/form/Editor.scss +3 -1
  485. package/src/components/common/form/ReactSelectCreatableField.tsx +1 -1
  486. package/src/components/common/form/SelectField.tsx +1 -1
  487. package/src/components/common/ui/Item.tsx +1 -1
  488. package/src/components/common/ui/Sonner.tsx +43 -0
  489. package/src/components/frontStore/Footer.tsx +2 -0
  490. package/src/components/frontStore/Pagination.tsx +1 -1
  491. package/src/components/frontStore/cart/CartContext.tsx +2 -2
  492. package/src/components/frontStore/cart/DefaultCartItemList.tsx +5 -5
  493. package/src/components/frontStore/cart/DefaultMiniCartDropdown.tsx +7 -37
  494. package/src/components/frontStore/cart/DefaultMinicartDropdownSummary.tsx +57 -0
  495. package/src/components/frontStore/catalog/CategoryInfo.tsx +2 -2
  496. package/src/components/frontStore/catalog/DefaultCategoryFilterRender.tsx +1 -1
  497. package/src/components/frontStore/catalog/DefaultProductFilterRender.tsx +3 -3
  498. package/src/components/frontStore/catalog/ProductSorting.tsx +13 -4
  499. package/src/components/frontStore/catalog/SearchBox.tsx +1 -1
  500. package/src/components/frontStore/checkout/CheckoutButton.tsx +40 -31
  501. package/src/components/frontStore/checkout/CheckoutContext.tsx +55 -36
  502. package/src/components/frontStore/checkout/ContactInformation.tsx +28 -23
  503. package/src/components/frontStore/checkout/Payment.tsx +36 -27
  504. package/src/components/frontStore/checkout/Shipment.tsx +35 -28
  505. package/src/components/frontStore/checkout/payment/PaymentMethods.tsx +1 -1
  506. package/src/components/frontStore/checkout/shipment/ShippingMethods.tsx +6 -2
  507. package/src/components/frontStore/customer/CustomerContext.tsx +5 -5
  508. package/src/components/frontStore/customer/RegistrationForm.tsx +1 -1
  509. package/src/components/frontStore/customer/address/addressForm/AddressForm.tsx +1 -0
  510. package/src/lib/componee/scanForComponents.ts +0 -1
  511. package/src/lib/event/EventProcessor.ts +78 -0
  512. package/src/lib/event/EventStorage.ts +74 -0
  513. package/src/lib/event/callSubscibers.ts +13 -0
  514. package/src/lib/event/event-manager.ts +96 -0
  515. package/src/lib/event/{loadSubscribers.js → loadSubscribers.ts} +20 -8
  516. package/src/lib/event/tests/unit/EventProcessor.test.js +262 -0
  517. package/src/lib/event/tests/unit/callSubscribers.test.js +77 -0
  518. package/src/lib/mail/emailHelper.ts +2 -2
  519. package/src/lib/postgres/connection.ts +11 -7
  520. package/src/lib/postgres/query.ts +582 -0
  521. package/src/lib/util/getConfig.ts +6 -6
  522. package/src/lib/util/registry.ts +31 -0
  523. package/src/lib/util/sanitizeHtml.ts +59 -0
  524. package/src/lib/webpack/loaders/AreaLoader.js +0 -1
  525. package/src/lib/webpack/util/getTailwindSources.ts +1 -1
  526. package/src/modules/auth/api/refreshUserToken/refreshToken.ts +4 -6
  527. package/src/modules/auth/bootstrap.ts +33 -0
  528. package/src/modules/auth/services/buildAdminUserPayload.ts +22 -0
  529. package/src/modules/auth/services/loginUserWithEmail.ts +36 -6
  530. package/src/modules/auth/services/logoutUser.ts +22 -1
  531. package/src/modules/base/api/global/{[apiResponse]apiErrorHandler.js → [apiResponse]apiErrorHandler.ts} +8 -1
  532. package/src/modules/base/api/global/{[auth]apiResponse[apiErrorHandler].js → [auth]apiResponse[apiErrorHandler].ts} +7 -1
  533. package/src/modules/base/api/global/{[auth]payloadValidate.js → [auth]payloadValidate.ts} +10 -3
  534. package/src/modules/base/api/global/[payloadValidate]escapeHtml.ts +12 -0
  535. package/src/modules/base/migration/Version-1.0.2.js +37 -0
  536. package/src/modules/base/pages/admin/all/global.scss +1 -1
  537. package/src/modules/base/services/{escapePayload.js → escapePayload.ts} +17 -11
  538. package/src/modules/base/services/markSkipEscape.ts +43 -0
  539. package/src/modules/catalog/api/createCategory/createCategory[finish].ts +10 -0
  540. package/src/modules/catalog/api/createCategory/{finish[apiResponse].js → finish[apiResponse].ts} +13 -4
  541. package/src/modules/catalog/api/createCategory/payloadSchema.json +76 -0
  542. package/src/modules/catalog/api/createCollection/{createCollection[finish].js → createCollection[finish].ts} +2 -1
  543. package/src/modules/catalog/api/{updateCollection/finish[apiResponse].js → createCollection/finish[apiResponse].ts} +12 -3
  544. package/src/modules/catalog/api/createCollection/payloadSchema.json +94 -0
  545. package/src/modules/catalog/api/createProduct/createProduct[finish].ts +10 -0
  546. package/src/modules/catalog/api/createProduct/{finish[apiResponse].js → finish[apiResponse].ts} +13 -4
  547. package/src/modules/catalog/api/createProduct/payloadSchema.json +76 -0
  548. package/src/modules/catalog/api/updateCategory/{finish[apiResponse].js → finish[apiResponse].ts} +13 -4
  549. package/src/modules/catalog/api/updateCategory/payloadSchema.json +76 -0
  550. package/src/modules/catalog/api/updateCategory/updateCategory[finish].ts +14 -0
  551. package/src/modules/catalog/api/{createCollection/finish[apiResponse].js → updateCollection/finish[apiResponse].ts} +12 -3
  552. package/src/modules/catalog/api/updateCollection/payloadSchema.json +94 -0
  553. package/src/modules/catalog/api/updateCollection/updateCollection[finish].ts +14 -0
  554. package/src/modules/catalog/api/updateProduct/{finish[apiResponse].js → finish[apiResponse].ts} +13 -4
  555. package/src/modules/catalog/api/updateProduct/payloadSchema.json +76 -0
  556. package/src/modules/catalog/api/updateProduct/updateProduct[finish].ts +14 -0
  557. package/src/modules/catalog/graphql/types/Category/{Category.resolvers.js → Category.resolvers.ts} +0 -21
  558. package/src/modules/catalog/graphql/types/Collection/Collection.resolvers.js +1 -8
  559. package/src/modules/catalog/graphql/types/Product/Product.resolvers.ts +0 -20
  560. package/src/modules/catalog/pages/admin/productEdit/variants/CreateVariant.tsx +6 -2
  561. package/src/modules/catalog/pages/admin/productEdit/variants/CreateVariantGroup.tsx +22 -11
  562. package/src/modules/catalog/pages/admin/productEdit/variants/EditVariant.tsx +10 -3
  563. package/src/modules/catalog/pages/admin/productEdit/variants/New.tsx +8 -23
  564. package/src/modules/catalog/pages/admin/productEdit/variants/VariantModal.tsx +10 -2
  565. package/src/modules/catalog/pages/admin/productEdit+productNew/General.tsx +5 -2
  566. package/src/modules/catalog/pages/frontStore/categoryView/CategoryView.tsx +4 -8
  567. package/src/modules/catalog/pages/frontStore/productView/ProductView.tsx +10 -1
  568. package/src/modules/catalog/services/attribute/createProductAttribute.ts +146 -8
  569. package/src/modules/catalog/services/attribute/deleteProductAttribute.ts +58 -4
  570. package/src/modules/catalog/services/attribute/updateProductAttribute.ts +128 -12
  571. package/src/modules/catalog/services/category/createCategory.ts +66 -6
  572. package/src/modules/catalog/services/category/deleteCategory.ts +61 -4
  573. package/src/modules/catalog/services/category/updateCategory.ts +75 -10
  574. package/src/modules/catalog/services/collection/createCollection.ts +71 -30
  575. package/src/modules/catalog/services/collection/deleteCollection.ts +58 -4
  576. package/src/modules/catalog/services/collection/updateCollection.ts +70 -35
  577. package/src/modules/catalog/services/index.ts +46 -35
  578. package/src/modules/catalog/services/product/createProduct.ts +155 -11
  579. package/src/modules/catalog/services/product/deleteProduct.ts +58 -4
  580. package/src/modules/catalog/services/product/updateProduct.ts +168 -17
  581. package/src/modules/checkout/pages/frontStore/cart/ShoppingCart.tsx +0 -2
  582. package/src/modules/checkout/pages/frontStore/checkout/Checkout.tsx +2 -0
  583. package/src/modules/checkout/services/addBillingAddress.ts +74 -6
  584. package/src/modules/checkout/services/addCartItem.ts +31 -1
  585. package/src/modules/checkout/services/addShippingAddress.ts +54 -6
  586. package/src/modules/checkout/services/checkout.ts +35 -7
  587. package/src/modules/checkout/services/index.ts +17 -3
  588. package/src/modules/checkout/services/orderCreator.ts +105 -1
  589. package/src/modules/checkout/services/removeCartItem.ts +27 -1
  590. package/src/modules/checkout/services/updateCartItemQty.ts +33 -1
  591. package/src/modules/cms/api/createCmsPage/createPage[finish].ts +12 -0
  592. package/src/modules/cms/api/createCmsPage/{finish[apiResponse].js → finish[apiResponse].ts} +10 -4
  593. package/src/modules/cms/api/createCmsPage/payloadSchema.json +76 -0
  594. package/src/modules/cms/api/deleteCmsPage/{deleteCmsPage.js → deleteCmsPage.ts} +8 -2
  595. package/src/modules/cms/api/updateCmsPage/{finish[apiResponse].js → finish[apiResponse].ts} +10 -4
  596. package/src/modules/cms/api/updateCmsPage/payloadSchema.json +76 -0
  597. package/src/modules/cms/api/updateCmsPage/{updatePage[finish].js → updatePage[finish].ts} +2 -1
  598. package/src/modules/cms/{bootstrap.js → bootstrap.ts} +24 -3
  599. package/src/modules/cms/components/BasicMenu.tsx +1 -1
  600. package/src/modules/cms/graphql/types/CmsPage/CmsPage.resolvers.ts +0 -21
  601. package/src/modules/cms/graphql/types/Widget/Widget.resolvers.js +0 -20
  602. package/src/modules/cms/services/index.ts +3 -0
  603. package/src/modules/cms/services/page/{createPage.js → createPage.ts} +65 -8
  604. package/src/modules/cms/services/page/deletePage.ts +109 -0
  605. package/src/modules/cms/services/page/pageDataSchema.json +9 -1
  606. package/src/modules/cms/services/page/{updatePage.js → updatePage.ts} +68 -6
  607. package/src/modules/cms/services/widget/createWidget.ts +120 -0
  608. package/src/modules/cms/services/widget/deleteWidget.ts +97 -0
  609. package/src/modules/cms/services/widget/updateWidget.js +17 -1
  610. package/src/modules/cms/services/widget/updateWidget.ts +139 -0
  611. package/src/modules/cod/pages/frontStore/checkout/CashOnDelivery.tsx +4 -2
  612. package/src/modules/customer/api/refreshCustomerToken/refreshToken.ts +4 -6
  613. package/src/modules/customer/pages/frontStore/login/LoginPage.tsx +26 -24
  614. package/src/modules/customer/pages/frontStore/register/RegisterPage.tsx +24 -22
  615. package/src/modules/customer/services/customer/address/createCustomerAddress.ts +54 -2
  616. package/src/modules/customer/services/customer/address/deleteCustomerAddress.ts +49 -2
  617. package/src/modules/customer/services/customer/address/updateCustomerAddress.ts +55 -3
  618. package/src/modules/customer/services/customer/buildCustomerPayload.ts +20 -0
  619. package/src/modules/customer/services/customer/createCustomer.ts +60 -7
  620. package/src/modules/customer/services/customer/deleteCustomer.ts +55 -5
  621. package/src/modules/customer/services/customer/loginCustomerWithEmail.ts +3 -4
  622. package/src/modules/customer/services/customer/updateCustomer.ts +62 -5
  623. package/src/modules/customer/services/customer/updatePassword.ts +56 -3
  624. package/src/modules/customer/services/index.ts +34 -27
  625. package/src/modules/oms/bootstrap.ts +9 -8
  626. package/src/modules/oms/services/addOrderActivityLog.ts +31 -1
  627. package/src/modules/oms/services/addPaymentTransaction.ts +26 -0
  628. package/src/modules/oms/services/cancelOrder.ts +131 -1
  629. package/src/modules/oms/services/createShipment.ts +31 -1
  630. package/src/modules/oms/services/index.ts +4 -0
  631. package/src/modules/oms/services/orderLoader.ts +73 -0
  632. package/src/modules/oms/services/statusManager.ts +159 -0
  633. package/src/modules/oms/services/updateOrderStatus.ts +101 -9
  634. package/src/modules/oms/services/updatePaymentStatus.ts +53 -1
  635. package/src/modules/oms/services/updateShipmentStatus.ts +53 -1
  636. package/src/modules/paypal/api/paypalAuthorizePayment/[bodyParser]authorize.ts +1 -1
  637. package/src/modules/paypal/api/paypalCaptureAuthorizedPayment/[bodyParser]capture.ts +10 -2
  638. package/src/modules/paypal/api/paypalCapturePayment/[bodyParser]capture.ts +5 -1
  639. package/src/modules/paypal/{bootstrap.js → bootstrap.ts} +23 -2
  640. package/src/modules/paypal/migration/Version-1.0.0.ts +24 -0
  641. package/src/modules/paypal/pages/admin/orderEdit/PaypalCaptureButton.tsx +1 -1
  642. package/src/modules/paypal/pages/frontStore/checkout/Paypal.tsx +9 -3
  643. package/src/modules/promotion/services/coupon/createCoupon.ts +147 -0
  644. package/src/modules/promotion/services/coupon/deleteCoupon.ts +100 -0
  645. package/src/modules/promotion/services/coupon/updateCoupon.ts +130 -0
  646. package/src/modules/promotion/services/index.ts +11 -0
  647. package/src/modules/setting/services/setting.ts +40 -2
  648. package/src/modules/stripe/api/capturePaymentIntent/{capturePaymentIntent.js → capturePaymentIntent.ts} +14 -5
  649. package/src/modules/stripe/api/createPaymentIntent/{createPaymentIntent.js → createPaymentIntent.ts} +11 -5
  650. package/src/modules/stripe/api/refundPaymentIntent/{refundPaymentIntent.js → refundPaymentIntent.ts} +11 -7
  651. package/src/modules/stripe/api/stripeWebHook/{[bodyJson]webhook.js → [bodyJson]webhook.ts} +30 -10
  652. package/src/modules/stripe/{bootstrap.js → bootstrap.ts} +40 -15
  653. package/src/modules/stripe/migration/Version-1.0.0.ts +24 -0
  654. package/src/modules/stripe/pages/admin/orderEdit/StripeCaptureButton.jsx +1 -1
  655. package/src/modules/stripe/pages/admin/orderEdit/StripeRefundButton.tsx +9 -3
  656. package/src/modules/stripe/pages/frontStore/checkout/Stripe.tsx +16 -7
  657. package/src/modules/stripe/pages/frontStore/stripeReturn/{index.js → index.ts} +15 -5
  658. package/src/modules/stripe/services/{cancelPayment.js → cancelPayment.ts} +4 -4
  659. package/src/types/apiResponse.ts +1 -1
  660. package/src/types/appContext.tsx +9 -4
  661. package/src/types/customerAddress.ts +1 -1
  662. package/src/types/db/index.ts +61 -61
  663. package/src/types/event.ts +29 -15
  664. package/src/types/registry.ts +160 -0
  665. package/src/types/widget.ts +3 -0
  666. package/src/lib/event/callSubscibers.js +0 -19
  667. package/src/lib/event/event-manager.js +0 -134
  668. package/src/modules/auth/bootstrap.js +0 -28
  669. package/src/modules/base/api/global/[payloadValidate]escapeHtml.js +0 -12
  670. package/src/modules/base/services/markSkipEscape.js +0 -30
  671. package/src/modules/catalog/api/createCategory/createCategory[finish].js +0 -8
  672. package/src/modules/catalog/api/createProduct/createProduct[finish].js +0 -8
  673. package/src/modules/catalog/api/updateCategory/updateCategory[finish].js +0 -8
  674. package/src/modules/catalog/api/updateCollection/updateCollection[finish].js +0 -8
  675. package/src/modules/catalog/api/updateProduct/updateProduct[finish].js +0 -8
  676. package/src/modules/cms/api/createCmsPage/createPage[finish].js +0 -10
  677. package/src/modules/cms/services/page/deletePage.js +0 -55
  678. package/src/modules/cms/services/widget/createWidget.js +0 -71
  679. package/src/modules/cms/services/widget/deleteWidget.js +0 -47
  680. package/src/modules/promotion/services/coupon/createCoupon.js +0 -75
  681. package/src/modules/promotion/services/coupon/deleteCoupon.js +0 -49
  682. package/src/modules/promotion/services/coupon/updateCoupon.js +0 -94
  683. package/src/types/request.d.ts +0 -7
  684. /package/src/modules/catalog/api/createCategory/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  685. /package/src/modules/catalog/api/createCollection/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  686. /package/src/modules/catalog/api/createProduct/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  687. /package/src/modules/catalog/api/updateCategory/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  688. /package/src/modules/catalog/api/updateCollection/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  689. /package/src/modules/catalog/api/updateProduct/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  690. /package/src/modules/cms/api/createCmsPage/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  691. /package/src/modules/cms/api/updateCmsPage/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  692. /package/src/modules/stripe/api/capturePaymentIntent/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  693. /package/src/modules/stripe/api/createPaymentIntent/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  694. /package/src/modules/stripe/api/refundPaymentIntent/{[context]bodyParser[auth].js → [context]bodyParser[auth].ts} +0 -0
  695. /package/src/modules/stripe/api/stripeWebHook/{bodyJson.js → bodyJson.ts} +0 -0
@@ -10,8 +10,9 @@ import {
10
10
  insert
11
11
  } from '@evershop/postgres-query-builder';
12
12
  import { getConnection } from '../../../../lib/postgres/connection.js';
13
- import { hookable } from '../../../../lib/util/hookable.js';
13
+ import { hookable, hookBefore, hookAfter } from '../../../../lib/util/hookable.js';
14
14
  import { getValueSync, getValue } from '../../../../lib/util/registry.js';
15
+ import type { AttributeRow } from '../../../../types/db/index.js';
15
16
  import { getAjv } from '../../../base/services/getAjv.js';
16
17
  import attributeDataSchema from './attributeDataSchema.json' with { type: 'json' };
17
18
 
@@ -20,10 +21,10 @@ export type AttributeData = {
20
21
  type?: string;
21
22
  groups: number[];
22
23
  options: { option_text: string, option_id: string | number }[];
23
- [key: string]: any;
24
+ [key: string]: unknown;
24
25
  };
25
26
 
26
- function validateAttributeDataBeforeInsert(data: AttributeData) {
27
+ function validateAttributeDataBeforeInsert(data: AttributeData): AttributeData {
27
28
  const ajv = getAjv();
28
29
  attributeDataSchema.required = [];
29
30
  const jsonSchema = getValueSync(
@@ -46,7 +47,7 @@ async function updateAttributeOptions(
46
47
  attributeCode: string,
47
48
  options: { option_text: string, option_id: string | number }[],
48
49
  connection: PoolClient
49
- ) {
50
+ ): Promise<void> {
50
51
  // Ignore updating options if it is not present in the data or if the attribute type is not select or multiselect
51
52
  if (
52
53
  !['select', 'multiselect'].includes(attributeType)
@@ -101,7 +102,7 @@ async function updateAttributeOptions(
101
102
  );
102
103
  }
103
104
 
104
- async function updateAttributeGroups(attributeId: number, groups: number[], connection: PoolClient) {
105
+ async function updateAttributeGroups(attributeId: number, groups: number[], connection: PoolClient): Promise<void> {
105
106
  // Ignore updating groups if it is not present in the data
106
107
  if (groups.length === 0) {
107
108
  return;
@@ -140,7 +141,7 @@ async function updateAttributeGroups(attributeId: number, groups: number[], conn
140
141
  .execute(connection);
141
142
  }
142
143
 
143
- async function updateAttributeData(uuid: string, data: AttributeData, connection: PoolClient) {
144
+ async function updateAttributeData(uuid: string, data: AttributeData, connection: PoolClient): Promise<AttributeRow & { updatedId?: number }> {
144
145
  const attribute = await select()
145
146
  .from('attribute')
146
147
  .where('uuid', '=', uuid)
@@ -150,18 +151,17 @@ async function updateAttributeData(uuid: string, data: AttributeData, connection
150
151
  throw new Error('Requested attribute not found');
151
152
  }
152
153
  try {
153
- const attribute = await update('attribute')
154
+ const updatedAttribute = await update('attribute')
154
155
  .given(data)
155
156
  .where('uuid', '=', uuid)
156
157
  .execute(connection);
157
- return attribute;
158
+ Object.assign(attribute, updatedAttribute);
158
159
  } catch (e) {
159
160
  if (!e.message.includes('No data was provided')) {
160
161
  throw e;
161
- } else {
162
- return attribute;
163
162
  }
164
163
  }
164
+ return attribute;
165
165
  }
166
166
 
167
167
  /**
@@ -170,7 +170,7 @@ async function updateAttributeData(uuid: string, data: AttributeData, connection
170
170
  * @param {Object} data
171
171
  * @param {Object} context
172
172
  */
173
- async function updateAttribute(uuid: string, data: AttributeData, context: Record<string, any>) {
173
+ async function updateAttribute(uuid: string, data: AttributeData, context: Record<string, any>): Promise<AttributeRow & { updatedId?: number }> {
174
174
  const connection = await getConnection();
175
175
  await startTransaction(connection);
176
176
  try {
@@ -222,7 +222,7 @@ async function updateAttribute(uuid: string, data: AttributeData, context: Recor
222
222
  * @param {Object} data
223
223
  * @param {Object} context
224
224
  */
225
- export default async (uuid: string, data: AttributeData, context: Record<string, any>) => {
225
+ export default async (uuid: string, data: AttributeData, context: Record<string, any>): Promise<AttributeRow & { updatedId?: number }> => {
226
226
  // Make sure the context is either not provided or is an object
227
227
  if (context && typeof context !== 'object') {
228
228
  throw new Error('Context must be an object');
@@ -234,3 +234,119 @@ export default async (uuid: string, data: AttributeData, context: Record<string,
234
234
  );
235
235
  return attribute;
236
236
  };
237
+
238
+ export function hookBeforeUpdateAttributeData(
239
+ callback: (
240
+ this: Record<string, any>,
241
+ ...args: [
242
+ uuid: string,
243
+ data: AttributeData,
244
+ connection: PoolClient
245
+ ]
246
+ ) => void | Promise<void>,
247
+ priority: number = 10
248
+ ): void {
249
+ hookBefore('updateAttributeData', callback, priority);
250
+ }
251
+
252
+ export function hookAfterUpdateAttributeData(
253
+ callback: (
254
+ this: Record<string, any>,
255
+ ...args: [
256
+ uuid: string,
257
+ data: AttributeData,
258
+ connection: PoolClient
259
+ ]
260
+ ) => void | Promise<void>,
261
+ priority: number = 10
262
+ ): void {
263
+ hookAfter('updateAttributeData', callback, priority);
264
+ }
265
+
266
+ export function hookBeforeUpdateAttributeGroups(
267
+ callback: (
268
+ this: Record<string, any>,
269
+ ...args: [
270
+ attributeId: number,
271
+ groups: number[],
272
+ connection: PoolClient
273
+ ]
274
+ ) => void | Promise<void>,
275
+ priority: number = 10
276
+ ): void {
277
+ hookBefore('updateAttributeGroups', callback, priority);
278
+ }
279
+
280
+ export function hookAfterUpdateAttributeGroups(
281
+ callback: (
282
+ this: Record<string, any>,
283
+ ...args: [
284
+ attributeId: number,
285
+ groups: number[],
286
+ connection: PoolClient
287
+ ]
288
+ ) => void | Promise<void>,
289
+ priority: number = 10
290
+ ): void {
291
+ hookAfter('updateAttributeGroups', callback, priority);
292
+ }
293
+
294
+ export function hookBeforeUpdateAttributeOptions(
295
+ callback: (
296
+ this: Record<string, any>,
297
+ ...args: [
298
+ attributeId: number,
299
+ attributeType: string,
300
+ attributeCode: string,
301
+ options: { option_text: string; option_id: string | number }[],
302
+ connection: PoolClient
303
+ ]
304
+ ) => void | Promise<void>,
305
+ priority: number = 10
306
+ ): void {
307
+ hookBefore('updateAttributeOptions', callback, priority);
308
+ }
309
+
310
+ export function hookAfterUpdateAttributeOptions(
311
+ callback: (
312
+ this: Record<string, any>,
313
+ ...args: [
314
+ attributeId: number,
315
+ attributeType: string,
316
+ attributeCode: string,
317
+ options: { option_text: string; option_id: string | number }[],
318
+ connection: PoolClient
319
+ ]
320
+ ) => void | Promise<void>,
321
+ priority: number = 10
322
+ ): void {
323
+ hookAfter('updateAttributeOptions', callback, priority);
324
+ }
325
+
326
+ export function hookBeforeUpdateAttribute(
327
+ callback: (
328
+ this: Record<string, any>,
329
+ ...args: [
330
+ uuid: string,
331
+ data: AttributeData,
332
+ context: Record<string, any>
333
+ ]
334
+ ) => void | Promise<void>,
335
+ priority: number = 10
336
+ ): void {
337
+ hookBefore('updateAttribute', callback, priority);
338
+ }
339
+
340
+ export function hookAfterUpdateAttribute(
341
+ callback: (
342
+ this: Record<string, any>,
343
+ ...args: [
344
+ uuid: string,
345
+ data: AttributeData,
346
+ context: Record<string, any>
347
+ ]
348
+ ) => void | Promise<void>,
349
+ priority: number = 10
350
+ ): void {
351
+ hookAfter('updateAttribute', callback, priority);
352
+ }
@@ -1,3 +1,4 @@
1
+ import { Row } from '@components/common/form/Editor.js';
1
2
  import {
2
3
  commit,
3
4
  insert,
@@ -8,21 +9,24 @@ import {
8
9
  import type { PoolClient } from '@evershop/postgres-query-builder';
9
10
  import { JSONSchemaType } from 'ajv';
10
11
  import { getConnection } from '../../../../lib/postgres/connection.js';
11
- import { hookable } from '../../../../lib/util/hookable.js';
12
+ import { hookable, hookBefore, hookAfter } from '../../../../lib/util/hookable.js';
12
13
  import {
13
14
  getValue,
14
15
  getValueSync
15
16
  } from '../../../../lib/util/registry.js';
17
+ import { sanitizeRawHtml } from '../../../../lib/util/sanitizeHtml.js';
18
+ import type { CategoryDescriptionRow, CategoryRow } from '../../../../types/db/index.js';
16
19
  import { getAjv } from '../../../base/services/getAjv.js';
17
20
  import categoryDataSchema from './categoryDataSchema.json' with { type: 'json' };
18
21
 
19
22
  export type CategoryData = {
20
23
  name: string;
21
24
  url_key: string;
22
- [key: string]: any;
25
+ description?: Row[];
26
+ [key: string]: unknown;
23
27
  };
24
28
 
25
- function validateCategoryDataBeforeInsert(data: CategoryData) {
29
+ function validateCategoryDataBeforeInsert(data: CategoryData): CategoryData {
26
30
  const ajv = getAjv();
27
31
  (categoryDataSchema as JSONSchemaType<any>).required = ['name', 'url_key'];
28
32
  const jsonSchema = getValueSync(
@@ -39,7 +43,7 @@ function validateCategoryDataBeforeInsert(data: CategoryData) {
39
43
  }
40
44
  }
41
45
 
42
- async function insertCategoryData(data: CategoryData & { parent_id?: number }, connection: PoolClient) {
46
+ async function insertCategoryData(data: CategoryData & { parent_id?: number }, connection: PoolClient): Promise<CategoryRow & CategoryDescriptionRow & { insertId: number }> {
43
47
  const parentId = data.parent_id;
44
48
  if (parentId) {
45
49
  // Load the parent category
@@ -70,7 +74,7 @@ async function insertCategoryData(data: CategoryData & { parent_id?: number }, c
70
74
  * @param {Object} data
71
75
  * @param {Object} context
72
76
  */
73
- async function createCategory(data: CategoryData, context: Record<string, any>) {
77
+ async function createCategory(data: CategoryData, context: Record<string, any>): Promise<CategoryRow & CategoryDescriptionRow & { insertId: number }> {
74
78
  const connection = await getConnection();
75
79
  await startTransaction(connection);
76
80
  try {
@@ -78,6 +82,10 @@ async function createCategory(data: CategoryData, context: Record<string, any>)
78
82
  // Validate category data
79
83
  validateCategoryDataBeforeInsert(categoryData);
80
84
 
85
+ // Sanitize raw HTML blocks in EditorJS content
86
+ if (categoryData.description) {
87
+ sanitizeRawHtml(categoryData.description);
88
+ }
81
89
  // Insert category data
82
90
  const category = await hookable(insertCategoryData, context)(
83
91
  categoryData,
@@ -97,7 +105,7 @@ async function createCategory(data: CategoryData, context: Record<string, any>)
97
105
  * @param {Object} data
98
106
  * @param {Object} context
99
107
  */
100
- export default async (data: CategoryData, context: Record<string, any>) => {
108
+ export default async (data: CategoryData, context: Record<string, any>): Promise<CategoryRow & CategoryDescriptionRow & { insertId: number }> => {
101
109
  // Make sure the context is either not provided or is an object
102
110
  if (context && typeof context !== 'object') {
103
111
  throw new Error('Context must be an object');
@@ -105,3 +113,55 @@ export default async (data: CategoryData, context: Record<string, any>) => {
105
113
  const category = await hookable(createCategory, context)(data, context);
106
114
  return category;
107
115
  };
116
+
117
+ export function hookBeforeInsertCategoryData(
118
+ callback: (
119
+ this: Record<string, any>,
120
+ ...args: [
121
+ data: CategoryData & { parent_id?: number },
122
+ connection: PoolClient
123
+ ]
124
+ ) => void | Promise<void>,
125
+ priority: number = 10
126
+ ): void {
127
+ hookBefore('insertCategoryData', callback, priority);
128
+ }
129
+
130
+ export function hookAfterInsertCategoryData(
131
+ callback: (
132
+ this: Record<string, any>,
133
+ ...args: [
134
+ data: CategoryData & { parent_id?: number },
135
+ connection: PoolClient
136
+ ]
137
+ ) => void | Promise<void>,
138
+ priority: number = 10
139
+ ): void {
140
+ hookAfter('insertCategoryData', callback, priority);
141
+ }
142
+
143
+ export function hookBeforeCreateCategory(
144
+ callback: (
145
+ this: Record<string, any>,
146
+ ...args: [
147
+ data: CategoryData,
148
+ context: Record<string, any>
149
+ ]
150
+ ) => void | Promise<void>,
151
+ priority: number = 10
152
+ ): void {
153
+ hookBefore('createCategory', callback, priority);
154
+ }
155
+
156
+ export function hookAfterCreateCategory(
157
+ callback: (
158
+ this: Record<string, any>,
159
+ ...args: [
160
+ data: CategoryData,
161
+ context: Record<string, any>
162
+ ]
163
+ ) => void | Promise<void>,
164
+ priority: number = 10
165
+ ): void {
166
+ hookAfter('createCategory', callback, priority);
167
+ }
@@ -7,9 +7,20 @@ import {
7
7
  } from '@evershop/postgres-query-builder';
8
8
  import type { PoolClient } from '@evershop/postgres-query-builder';
9
9
  import { getConnection } from '../../../../lib/postgres/connection.js';
10
- import { hookable } from '../../../../lib/util/hookable.js';
10
+ import {
11
+ hookable,
12
+ hookBefore,
13
+ hookAfter
14
+ } from '../../../../lib/util/hookable.js';
15
+ import type {
16
+ CategoryDescriptionRow,
17
+ CategoryRow
18
+ } from '../../../../types/db/index.js';
11
19
 
12
- async function deleteCategoryData(uuid: string, connection: PoolClient) {
20
+ async function deleteCategoryData(
21
+ uuid: string,
22
+ connection: PoolClient
23
+ ): Promise<void> {
13
24
  await del('category').where('uuid', '=', uuid).execute(connection);
14
25
  }
15
26
  /**
@@ -17,7 +28,10 @@ async function deleteCategoryData(uuid: string, connection: PoolClient) {
17
28
  * @param {String} uuid
18
29
  * @param {Object} context
19
30
  */
20
- async function deleteCategory(uuid: string, context: Record<string, any>) {
31
+ async function deleteCategory(
32
+ uuid: string,
33
+ context: Record<string, any>
34
+ ): Promise<CategoryRow & CategoryDescriptionRow> {
21
35
  const connection = await getConnection();
22
36
  await startTransaction(connection);
23
37
  try {
@@ -53,7 +67,10 @@ async function deleteCategory(uuid: string, context: Record<string, any>) {
53
67
  * @param {String} uuid
54
68
  * @param {Object} context
55
69
  */
56
- export default async (uuid: string, context: Record<string, any>) => {
70
+ export default async (
71
+ uuid: string,
72
+ context: Record<string, any>
73
+ ): Promise<CategoryRow & CategoryDescriptionRow> => {
57
74
  // Make sure the context is either not provided or is an object
58
75
  if (context && typeof context !== 'object') {
59
76
  throw new Error('Context must be an object');
@@ -61,3 +78,43 @@ export default async (uuid: string, context: Record<string, any>) => {
61
78
  const category = await hookable(deleteCategory, context)(uuid, context);
62
79
  return category;
63
80
  };
81
+
82
+ export function hookBeforeDeleteCategoryData(
83
+ callback: (
84
+ this: Record<string, any>,
85
+ ...args: [uuid: string, connection: PoolClient]
86
+ ) => void | Promise<void>,
87
+ priority: number = 10
88
+ ): void {
89
+ hookBefore('deleteCategoryData', callback, priority);
90
+ }
91
+
92
+ export function hookAfterDeleteCategoryData(
93
+ callback: (
94
+ this: Record<string, any>,
95
+ ...args: [uuid: string, connection: PoolClient]
96
+ ) => void | Promise<void>,
97
+ priority: number = 10
98
+ ): void {
99
+ hookAfter('deleteCategoryData', callback, priority);
100
+ }
101
+
102
+ export function hookBeforeDeleteCategory(
103
+ callback: (
104
+ this: Record<string, any>,
105
+ ...args: [uuid: string, context: Record<string, any>]
106
+ ) => void | Promise<void>,
107
+ priority: number = 10
108
+ ): void {
109
+ hookBefore('deleteCategory', callback, priority);
110
+ }
111
+
112
+ export function hookAfterDeleteCategory(
113
+ callback: (
114
+ this: Record<string, any>,
115
+ ...args: [uuid: string, context: Record<string, any>]
116
+ ) => void | Promise<void>,
117
+ priority: number = 10
118
+ ): void {
119
+ hookAfter('deleteCategory', callback, priority);
120
+ }
@@ -6,19 +6,20 @@ import {
6
6
  update
7
7
  } from '@evershop/postgres-query-builder';
8
8
  import type { PoolClient } from '@evershop/postgres-query-builder';
9
- import { JSONSchemaType } from 'ajv';
10
9
  import { getConnection } from '../../../../lib/postgres/connection.js';
11
- import { hookable } from '../../../../lib/util/hookable.js';
10
+ import { hookable, hookBefore, hookAfter } from '../../../../lib/util/hookable.js';
12
11
  import {
13
12
  getValue,
14
13
  getValueSync
15
14
  } from '../../../../lib/util/registry.js';
15
+ import { sanitizeRawHtml } from '../../../../lib/util/sanitizeHtml.js';
16
+ import type { CategoryDescriptionRow, CategoryRow } from '../../../../types/db/index.js';
16
17
  import { getAjv } from '../../../base/services/getAjv.js';
17
18
  import categoryDataSchema from './categoryDataSchema.json' with { type: 'json' };
18
19
  import { CategoryData } from './createCategory.js';
19
20
 
20
21
 
21
- function validateCategoryDataBeforeInsert(data: CategoryData) {
22
+ function validateCategoryDataBeforeInsert(data: CategoryData): CategoryData {
22
23
  const ajv = getAjv();
23
24
  categoryDataSchema.required = [];
24
25
  const jsonSchema = getValueSync(
@@ -35,7 +36,7 @@ function validateCategoryDataBeforeInsert(data: CategoryData) {
35
36
  }
36
37
  }
37
38
 
38
- async function updateCategoryData(uuid: string, data: CategoryData, connection: PoolClient) {
39
+ async function updateCategoryData(uuid: string, data: CategoryData, connection: PoolClient): Promise<CategoryRow & CategoryDescriptionRow & { updatedId?: number }> {
39
40
  const query = select().from('category');
40
41
  query
41
42
  .leftJoin('category_description')
@@ -48,9 +49,9 @@ async function updateCategoryData(uuid: string, data: CategoryData, connection:
48
49
  if (!category) {
49
50
  throw new Error('Requested category not found');
50
51
  }
51
-
52
+ let newCategory;
52
53
  try {
53
- const newCategory = await update('category')
54
+ newCategory = await update('category')
54
55
  .given(data)
55
56
  .where('uuid', '=', uuid)
56
57
  .execute(connection);
@@ -60,8 +61,9 @@ async function updateCategoryData(uuid: string, data: CategoryData, connection:
60
61
  throw e;
61
62
  }
62
63
  }
64
+ let description;
63
65
  try {
64
- const description = await update('category_description')
66
+ description = await update('category_description')
65
67
  .given(data)
66
68
  .where('category_description_category_id', '=', category.category_id)
67
69
  .execute(connection);
@@ -72,7 +74,11 @@ async function updateCategoryData(uuid: string, data: CategoryData, connection:
72
74
  }
73
75
  }
74
76
 
75
- return category;
77
+ return {
78
+ ...description,
79
+ ...newCategory,
80
+ updatedId: category.category_id
81
+ };
76
82
  }
77
83
 
78
84
  /**
@@ -81,7 +87,7 @@ async function updateCategoryData(uuid: string, data: CategoryData, connection:
81
87
  * @param {Object} data
82
88
  * @param {Object} context
83
89
  */
84
- async function updateCategory(uuid: string, data: CategoryData, context: Record<string, any>) {
90
+ async function updateCategory(uuid: string, data: CategoryData, context: Record<string, any>): Promise<CategoryRow & CategoryDescriptionRow & { updatedId?: number }> {
85
91
  const connection = await getConnection();
86
92
  await startTransaction(connection);
87
93
  try {
@@ -89,6 +95,9 @@ async function updateCategory(uuid: string, data: CategoryData, context: Record<
89
95
  // Validate category data
90
96
  validateCategoryDataBeforeInsert(categoryData);
91
97
 
98
+ if (categoryData.description) {
99
+ sanitizeRawHtml(categoryData.description);
100
+ }
92
101
  // Insert category data
93
102
  const category = await hookable(updateCategoryData, {
94
103
  ...context,
@@ -109,7 +118,7 @@ async function updateCategory(uuid: string, data: CategoryData, context: Record<
109
118
  * @param {Object} data
110
119
  * @param {Object} context
111
120
  */
112
- export default async (uuid: string, data: CategoryData, context: Record<string, any>) => {
121
+ export default async (uuid: string, data: CategoryData, context: Record<string, any>): Promise<CategoryRow & CategoryDescriptionRow & { updatedId?: number }> => {
113
122
  // Make sure the context is either not provided or is an object
114
123
  if (context && typeof context !== 'object') {
115
124
  throw new Error('Context must be an object');
@@ -117,3 +126,59 @@ export default async (uuid: string, data: CategoryData, context: Record<string,
117
126
  const category = await hookable(updateCategory, context)(uuid, data, context);
118
127
  return category;
119
128
  };
129
+
130
+ export function hookBeforeUpdateCategoryData(
131
+ callback: (
132
+ this: Record<string, any>,
133
+ ...args: [
134
+ uuid: string,
135
+ data: CategoryData,
136
+ connection: PoolClient
137
+ ]
138
+ ) => void | Promise<void>,
139
+ priority: number = 10
140
+ ): void {
141
+ hookBefore('updateCategoryData', callback, priority);
142
+ }
143
+
144
+ export function hookAfterUpdateCategoryData(
145
+ callback: (
146
+ this: Record<string, any>,
147
+ ...args: [
148
+ uuid: string,
149
+ data: CategoryData,
150
+ connection: PoolClient
151
+ ]
152
+ ) => void | Promise<void>,
153
+ priority: number = 10
154
+ ): void {
155
+ hookAfter('updateCategoryData', callback, priority);
156
+ }
157
+
158
+ export function hookBeforeUpdateCategory(
159
+ callback: (
160
+ this: Record<string, any>,
161
+ ...args: [
162
+ uuid: string,
163
+ data: CategoryData,
164
+ context: Record<string, any>
165
+ ]
166
+ ) => void | Promise<void>,
167
+ priority: number = 10
168
+ ): void {
169
+ hookBefore('updateCategory', callback, priority);
170
+ }
171
+
172
+ export function hookAfterUpdateCategory(
173
+ callback: (
174
+ this: Record<string, any>,
175
+ ...args: [
176
+ uuid: string,
177
+ data: CategoryData,
178
+ context: Record<string, any>
179
+ ]
180
+ ) => void | Promise<void>,
181
+ priority: number = 10
182
+ ): void {
183
+ hookAfter('updateCategory', callback, priority);
184
+ }