@infrab4a/connect 4.0.2-beta.14 → 4.0.2-beta.3

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 (777) hide show
  1. package/index.js +2 -0
  2. package/index.js.map +1 -0
  3. package/package.json +4 -11
  4. package/src/domain/catalog/helpers/index.js +2 -0
  5. package/src/domain/catalog/helpers/index.js.map +1 -0
  6. package/src/domain/catalog/helpers/round-product-price.helper.js +15 -0
  7. package/src/domain/catalog/helpers/round-product-price.helper.js.map +1 -0
  8. package/src/domain/catalog/index.js +4 -0
  9. package/src/domain/catalog/index.js.map +1 -0
  10. package/src/domain/catalog/models/category-base.js +18 -0
  11. package/src/domain/catalog/models/category-base.js.map +1 -0
  12. package/src/domain/catalog/models/category-collection-children.d.ts +1 -1
  13. package/src/domain/catalog/models/category-collection-children.js +13 -0
  14. package/src/domain/catalog/models/category-collection-children.js.map +1 -0
  15. package/src/domain/catalog/models/category-filter.d.ts +1 -1
  16. package/src/domain/catalog/models/category-filter.js +19 -0
  17. package/src/domain/catalog/models/category-filter.js.map +1 -0
  18. package/src/domain/catalog/models/category-for-product.js +7 -0
  19. package/src/domain/catalog/models/category-for-product.js.map +1 -0
  20. package/src/domain/catalog/models/category.js +14 -0
  21. package/src/domain/catalog/models/category.js.map +1 -0
  22. package/src/domain/catalog/models/enums/index.js +3 -0
  23. package/src/domain/catalog/models/enums/index.js.map +1 -0
  24. package/src/domain/catalog/models/enums/product-genders.enum.js +7 -0
  25. package/src/domain/catalog/models/enums/product-genders.enum.js.map +1 -0
  26. package/src/domain/catalog/models/enums/shops.enum.js +8 -0
  27. package/src/domain/catalog/models/enums/shops.enum.js.map +1 -0
  28. package/src/domain/catalog/models/filter-option.js +7 -0
  29. package/src/domain/catalog/models/filter-option.js.map +1 -0
  30. package/src/domain/catalog/models/filter.js +7 -0
  31. package/src/domain/catalog/models/filter.js.map +1 -0
  32. package/src/domain/catalog/models/index.js +12 -0
  33. package/src/domain/catalog/models/index.js.map +1 -0
  34. package/src/domain/catalog/models/kit-product.d.ts +1 -1
  35. package/src/domain/catalog/models/kit-product.js +18 -0
  36. package/src/domain/catalog/models/kit-product.js.map +1 -0
  37. package/src/domain/catalog/models/product-base.js +25 -0
  38. package/src/domain/catalog/models/product-base.js.map +1 -0
  39. package/src/domain/catalog/models/product-for-category.js +14 -0
  40. package/src/domain/catalog/models/product-for-category.js.map +1 -0
  41. package/src/domain/catalog/models/product-for-kit.js +14 -0
  42. package/src/domain/catalog/models/product-for-kit.js.map +1 -0
  43. package/src/domain/catalog/models/product.js +19 -0
  44. package/src/domain/catalog/models/product.js.map +1 -0
  45. package/src/domain/catalog/models/types/category-condition.type.d.ts +1 -1
  46. package/src/domain/catalog/models/types/category-condition.type.js +2 -0
  47. package/src/domain/catalog/models/types/category-condition.type.js.map +1 -0
  48. package/src/domain/catalog/models/types/category-metadata.type.d.ts +1 -1
  49. package/src/domain/catalog/models/types/category-metadata.type.js +2 -0
  50. package/src/domain/catalog/models/types/category-metadata.type.js.map +1 -0
  51. package/src/domain/catalog/models/types/category-product.d.ts +1 -1
  52. package/src/domain/catalog/models/types/category-product.js +2 -0
  53. package/src/domain/catalog/models/types/category-product.js.map +1 -0
  54. package/src/domain/catalog/models/types/index.js +12 -0
  55. package/src/domain/catalog/models/types/index.js.map +1 -0
  56. package/src/domain/catalog/models/types/product-evaluation.type.d.ts +1 -1
  57. package/src/domain/catalog/models/types/product-evaluation.type.js +2 -0
  58. package/src/domain/catalog/models/types/product-evaluation.type.js.map +1 -0
  59. package/src/domain/catalog/models/types/product-gender.type.d.ts +1 -1
  60. package/src/domain/catalog/models/types/product-gender.type.js +2 -0
  61. package/src/domain/catalog/models/types/product-gender.type.js.map +1 -0
  62. package/src/domain/catalog/models/types/product-metadata.type.d.ts +1 -1
  63. package/src/domain/catalog/models/types/product-metadata.type.js +2 -0
  64. package/src/domain/catalog/models/types/product-metadata.type.js.map +1 -0
  65. package/src/domain/catalog/models/types/product-review.type.d.ts +1 -1
  66. package/src/domain/catalog/models/types/product-review.type.js +2 -0
  67. package/src/domain/catalog/models/types/product-review.type.js.map +1 -0
  68. package/src/domain/catalog/models/types/shop-description.type.d.ts +1 -1
  69. package/src/domain/catalog/models/types/shop-description.type.js +2 -0
  70. package/src/domain/catalog/models/types/shop-description.type.js.map +1 -0
  71. package/src/domain/catalog/models/types/shop-price.type.d.ts +1 -1
  72. package/src/domain/catalog/models/types/shop-price.type.js +2 -0
  73. package/src/domain/catalog/models/types/shop-price.type.js.map +1 -0
  74. package/src/domain/catalog/models/types/stock.type.d.ts +1 -1
  75. package/src/domain/catalog/models/types/stock.type.js +2 -0
  76. package/src/domain/catalog/models/types/stock.type.js.map +1 -0
  77. package/src/domain/catalog/models/types/variant-grade.type.d.ts +1 -1
  78. package/src/domain/catalog/models/types/variant-grade.type.js +2 -0
  79. package/src/domain/catalog/models/types/variant-grade.type.js.map +1 -0
  80. package/src/domain/catalog/models/variant.d.ts +1 -1
  81. package/src/domain/catalog/models/variant.js +7 -0
  82. package/src/domain/catalog/models/variant.js.map +1 -0
  83. package/src/domain/catalog/models/wishlist.js +7 -0
  84. package/src/domain/catalog/models/wishlist.js.map +1 -0
  85. package/src/domain/catalog/repositories/category-collection-children.repository.js +2 -0
  86. package/src/domain/catalog/repositories/category-collection-children.repository.js.map +1 -0
  87. package/src/domain/catalog/repositories/category-filter.repository.js +2 -0
  88. package/src/domain/catalog/repositories/category-filter.repository.js.map +1 -0
  89. package/src/domain/catalog/repositories/category.repository.js +2 -0
  90. package/src/domain/catalog/repositories/category.repository.js.map +1 -0
  91. package/src/domain/catalog/repositories/filter-option.repository.js +2 -0
  92. package/src/domain/catalog/repositories/filter-option.repository.js.map +1 -0
  93. package/src/domain/catalog/repositories/filter.repository.js +2 -0
  94. package/src/domain/catalog/repositories/filter.repository.js.map +1 -0
  95. package/src/domain/catalog/repositories/index.js +10 -0
  96. package/src/domain/catalog/repositories/index.js.map +1 -0
  97. package/src/domain/catalog/repositories/product.repository.d.ts +2 -2
  98. package/src/domain/catalog/repositories/product.repository.js +2 -0
  99. package/src/domain/catalog/repositories/product.repository.js.map +1 -0
  100. package/src/domain/catalog/repositories/subscription-product.repository.js +2 -0
  101. package/src/domain/catalog/repositories/subscription-product.repository.js.map +1 -0
  102. package/src/domain/catalog/repositories/variant.repository.js +2 -0
  103. package/src/domain/catalog/repositories/variant.repository.js.map +1 -0
  104. package/src/domain/catalog/repositories/wishlist.repository.js +2 -0
  105. package/src/domain/catalog/repositories/wishlist.repository.js.map +1 -0
  106. package/src/domain/generic/index.js +3 -0
  107. package/src/domain/generic/index.js.map +1 -0
  108. package/src/domain/generic/model/base.model.d.ts +1 -1
  109. package/src/domain/generic/model/base.model.js +24 -0
  110. package/src/domain/generic/model/base.model.js.map +1 -0
  111. package/src/domain/generic/model/identifier-fields.js +2 -0
  112. package/src/domain/generic/model/identifier-fields.js.map +1 -0
  113. package/src/domain/generic/model/index.js +4 -0
  114. package/src/domain/generic/model/index.js.map +1 -0
  115. package/src/domain/generic/model/types/base-model-builder.type.js +2 -0
  116. package/src/domain/generic/model/types/base-model-builder.type.js.map +1 -0
  117. package/src/domain/generic/model/types/identifier-model.type.d.ts +3 -3
  118. package/src/domain/generic/model/types/identifier-model.type.js +2 -0
  119. package/src/domain/generic/model/types/identifier-model.type.js.map +1 -0
  120. package/src/domain/generic/model/types/index.js +6 -0
  121. package/src/domain/generic/model/types/index.js.map +1 -0
  122. package/src/domain/generic/model/types/model-base-structure.type.d.ts +2 -2
  123. package/src/domain/generic/model/types/model-base-structure.type.js +2 -0
  124. package/src/domain/generic/model/types/model-base-structure.type.js.map +1 -0
  125. package/src/domain/generic/model/types/non-function-properties.type.d.ts +6 -6
  126. package/src/domain/generic/model/types/non-function-properties.type.js +2 -0
  127. package/src/domain/generic/model/types/non-function-properties.type.js.map +1 -0
  128. package/src/domain/generic/model/types/non-function-property-name.type.d.ts +5 -5
  129. package/src/domain/generic/model/types/non-function-property-name.type.js +2 -0
  130. package/src/domain/generic/model/types/non-function-property-name.type.js.map +1 -0
  131. package/src/domain/generic/repository/create.repository.d.ts +1 -1
  132. package/src/domain/generic/repository/create.repository.js +2 -0
  133. package/src/domain/generic/repository/create.repository.js.map +1 -0
  134. package/src/domain/generic/repository/crud.repository.d.ts +2 -2
  135. package/src/domain/generic/repository/crud.repository.js +2 -0
  136. package/src/domain/generic/repository/crud.repository.js.map +1 -0
  137. package/src/domain/generic/repository/delete.repository.d.ts +1 -1
  138. package/src/domain/generic/repository/delete.repository.js +2 -0
  139. package/src/domain/generic/repository/delete.repository.js.map +1 -0
  140. package/src/domain/generic/repository/enums/index.js +3 -0
  141. package/src/domain/generic/repository/enums/index.js.map +1 -0
  142. package/src/domain/generic/repository/enums/update-option-actions.enum.js +9 -0
  143. package/src/domain/generic/repository/enums/update-option-actions.enum.js.map +1 -0
  144. package/src/domain/generic/repository/enums/where.enum.js +16 -0
  145. package/src/domain/generic/repository/enums/where.enum.js.map +1 -0
  146. package/src/domain/generic/repository/find.repository.d.ts +1 -1
  147. package/src/domain/generic/repository/find.repository.js +2 -0
  148. package/src/domain/generic/repository/find.repository.js.map +1 -0
  149. package/src/domain/generic/repository/get.repository.d.ts +1 -1
  150. package/src/domain/generic/repository/get.repository.js +2 -0
  151. package/src/domain/generic/repository/get.repository.js.map +1 -0
  152. package/src/domain/generic/repository/index.js +10 -0
  153. package/src/domain/generic/repository/index.js.map +1 -0
  154. package/src/domain/generic/repository/read.repository.d.ts +2 -2
  155. package/src/domain/generic/repository/read.repository.js +2 -0
  156. package/src/domain/generic/repository/read.repository.js.map +1 -0
  157. package/src/domain/generic/repository/types/index.js +7 -0
  158. package/src/domain/generic/repository/types/index.js.map +1 -0
  159. package/src/domain/generic/repository/types/repository-find-filters.type.d.ts +4 -4
  160. package/src/domain/generic/repository/types/repository-find-filters.type.js +2 -0
  161. package/src/domain/generic/repository/types/repository-find-filters.type.js.map +1 -0
  162. package/src/domain/generic/repository/types/repository-find-result.type.d.ts +2 -2
  163. package/src/domain/generic/repository/types/repository-find-result.type.js +2 -0
  164. package/src/domain/generic/repository/types/repository-find-result.type.js.map +1 -0
  165. package/src/domain/generic/repository/types/repository-limit-options.type.d.ts +1 -1
  166. package/src/domain/generic/repository/types/repository-limit-options.type.js +2 -0
  167. package/src/domain/generic/repository/types/repository-limit-options.type.js.map +1 -0
  168. package/src/domain/generic/repository/types/repository-order-by-list.type.d.ts +2 -2
  169. package/src/domain/generic/repository/types/repository-order-by-list.type.js +2 -0
  170. package/src/domain/generic/repository/types/repository-order-by-list.type.js.map +1 -0
  171. package/src/domain/generic/repository/types/repository-update-params.type.d.ts +3 -3
  172. package/src/domain/generic/repository/types/repository-update-params.type.js +2 -0
  173. package/src/domain/generic/repository/types/repository-update-params.type.js.map +1 -0
  174. package/src/domain/generic/repository/types/where-options.type.d.ts +1 -1
  175. package/src/domain/generic/repository/types/where-options.type.js +2 -0
  176. package/src/domain/generic/repository/types/where-options.type.js.map +1 -0
  177. package/src/domain/generic/repository/update.repository.d.ts +1 -1
  178. package/src/domain/generic/repository/update.repository.js +2 -0
  179. package/src/domain/generic/repository/update.repository.js.map +1 -0
  180. package/src/domain/index.js +7 -0
  181. package/src/domain/index.js.map +1 -0
  182. package/src/domain/location/index.js +2 -0
  183. package/src/domain/location/index.js.map +1 -0
  184. package/src/domain/location/models/address.js +7 -0
  185. package/src/domain/location/models/address.js.map +1 -0
  186. package/src/domain/location/models/index.js +3 -0
  187. package/src/domain/location/models/index.js.map +1 -0
  188. package/src/domain/location/models/types/index.js +4 -0
  189. package/src/domain/location/models/types/index.js.map +1 -0
  190. package/src/domain/location/models/types/location-bound.type.d.ts +1 -1
  191. package/src/domain/location/models/types/location-bound.type.js +2 -0
  192. package/src/domain/location/models/types/location-bound.type.js.map +1 -0
  193. package/src/domain/location/models/types/location-geometry.type.d.ts +1 -1
  194. package/src/domain/location/models/types/location-geometry.type.js +2 -0
  195. package/src/domain/location/models/types/location-geometry.type.js.map +1 -0
  196. package/src/domain/location/models/types/location-lat-lng.type.d.ts +1 -1
  197. package/src/domain/location/models/types/location-lat-lng.type.js +2 -0
  198. package/src/domain/location/models/types/location-lat-lng.type.js.map +1 -0
  199. package/src/domain/shop-settings/enums/filter-type.enum.js +21 -0
  200. package/src/domain/shop-settings/enums/filter-type.enum.js.map +1 -0
  201. package/src/domain/shop-settings/enums/index.js +3 -0
  202. package/src/domain/shop-settings/enums/index.js.map +1 -0
  203. package/src/domain/shop-settings/enums/questions-filters.enum.js +21 -0
  204. package/src/domain/shop-settings/enums/questions-filters.enum.js.map +1 -0
  205. package/src/domain/shop-settings/helpers/beauty-questions.helper.d.ts +1 -1
  206. package/src/domain/shop-settings/helpers/beauty-questions.helper.js +47 -0
  207. package/src/domain/shop-settings/helpers/beauty-questions.helper.js.map +1 -0
  208. package/src/domain/shop-settings/helpers/index.js +2 -0
  209. package/src/domain/shop-settings/helpers/index.js.map +1 -0
  210. package/src/domain/shop-settings/index.js +5 -0
  211. package/src/domain/shop-settings/index.js.map +1 -0
  212. package/src/domain/shop-settings/models/home.js +7 -0
  213. package/src/domain/shop-settings/models/home.js.map +1 -0
  214. package/src/domain/shop-settings/models/index.js +5 -0
  215. package/src/domain/shop-settings/models/index.js.map +1 -0
  216. package/src/domain/shop-settings/models/shop-menu.js +7 -0
  217. package/src/domain/shop-settings/models/shop-menu.js.map +1 -0
  218. package/src/domain/shop-settings/models/shop-settings.js +7 -0
  219. package/src/domain/shop-settings/models/shop-settings.js.map +1 -0
  220. package/src/domain/shop-settings/models/types/banner.type.d.ts +1 -1
  221. package/src/domain/shop-settings/models/types/banner.type.js +2 -0
  222. package/src/domain/shop-settings/models/types/banner.type.js.map +1 -0
  223. package/src/domain/shop-settings/models/types/benefit.type.d.ts +1 -1
  224. package/src/domain/shop-settings/models/types/benefit.type.js +2 -0
  225. package/src/domain/shop-settings/models/types/benefit.type.js.map +1 -0
  226. package/src/domain/shop-settings/models/types/home-data.type.d.ts +3 -3
  227. package/src/domain/shop-settings/models/types/home-data.type.js +2 -0
  228. package/src/domain/shop-settings/models/types/home-data.type.js.map +1 -0
  229. package/src/domain/shop-settings/models/types/index.js +11 -0
  230. package/src/domain/shop-settings/models/types/index.js.map +1 -0
  231. package/src/domain/shop-settings/models/types/menu-nav.type.d.ts +1 -1
  232. package/src/domain/shop-settings/models/types/menu-nav.type.js +2 -0
  233. package/src/domain/shop-settings/models/types/menu-nav.type.js.map +1 -0
  234. package/src/domain/shop-settings/models/types/shop-banner.type.js +2 -0
  235. package/src/domain/shop-settings/models/types/shop-banner.type.js.map +1 -0
  236. package/src/domain/shop-settings/models/types/shop-brands.type.js +2 -0
  237. package/src/domain/shop-settings/models/types/shop-brands.type.js.map +1 -0
  238. package/src/domain/shop-settings/models/types/shop-carousel.type.js +2 -0
  239. package/src/domain/shop-settings/models/types/shop-carousel.type.js.map +1 -0
  240. package/src/domain/shop-settings/models/types/shop-collection.type.js +2 -0
  241. package/src/domain/shop-settings/models/types/shop-collection.type.js.map +1 -0
  242. package/src/domain/shop-settings/models/types/shop-section.type.d.ts +1 -1
  243. package/src/domain/shop-settings/models/types/shop-section.type.js +2 -0
  244. package/src/domain/shop-settings/models/types/shop-section.type.js.map +1 -0
  245. package/src/domain/shop-settings/models/types/sub-menu.type.d.ts +2 -2
  246. package/src/domain/shop-settings/models/types/sub-menu.type.js +2 -0
  247. package/src/domain/shop-settings/models/types/sub-menu.type.js.map +1 -0
  248. package/src/domain/shop-settings/repositories/home.repository.js +2 -0
  249. package/src/domain/shop-settings/repositories/home.repository.js.map +1 -0
  250. package/src/domain/shop-settings/repositories/index.js +4 -0
  251. package/src/domain/shop-settings/repositories/index.js.map +1 -0
  252. package/src/domain/shop-settings/repositories/shop-menu.repository.js +2 -0
  253. package/src/domain/shop-settings/repositories/shop-menu.repository.js.map +1 -0
  254. package/src/domain/shop-settings/repositories/shop-settings.repository.js +2 -0
  255. package/src/domain/shop-settings/repositories/shop-settings.repository.js.map +1 -0
  256. package/src/domain/shopping/index.js +3 -0
  257. package/src/domain/shopping/index.js.map +1 -0
  258. package/src/domain/shopping/models/buy-2-win.js +14 -0
  259. package/src/domain/shopping/models/buy-2-win.js.map +1 -0
  260. package/src/domain/shopping/models/campaign-dashboard.js +7 -0
  261. package/src/domain/shopping/models/campaign-dashboard.js.map +1 -0
  262. package/src/domain/shopping/models/campaign-hashtag.js +7 -0
  263. package/src/domain/shopping/models/campaign-hashtag.js.map +1 -0
  264. package/src/domain/shopping/models/checkout.js +37 -0
  265. package/src/domain/shopping/models/checkout.js.map +1 -0
  266. package/src/domain/shopping/models/coupons/coupon.js +38 -0
  267. package/src/domain/shopping/models/coupons/coupon.js.map +1 -0
  268. package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js +7 -0
  269. package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js.map +1 -0
  270. package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js +6 -0
  271. package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js.map +1 -0
  272. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js +10 -0
  273. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js.map +1 -0
  274. package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js +10 -0
  275. package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js.map +1 -0
  276. package/src/domain/shopping/models/coupons/enums/index.js +4 -0
  277. package/src/domain/shopping/models/coupons/enums/index.js.map +1 -0
  278. package/src/domain/shopping/models/coupons/index.js +3 -0
  279. package/src/domain/shopping/models/coupons/index.js.map +1 -0
  280. package/src/domain/shopping/models/enums/checkout-types.enum.js +7 -0
  281. package/src/domain/shopping/models/enums/checkout-types.enum.js.map +1 -0
  282. package/src/domain/shopping/models/enums/index.js +3 -0
  283. package/src/domain/shopping/models/enums/index.js.map +1 -0
  284. package/src/domain/shopping/models/enums/order-status.enum.js +12 -0
  285. package/src/domain/shopping/models/enums/order-status.enum.js.map +1 -0
  286. package/src/domain/shopping/models/index.js +13 -0
  287. package/src/domain/shopping/models/index.js.map +1 -0
  288. package/src/domain/shopping/models/line-item.js +4 -0
  289. package/src/domain/shopping/models/line-item.js.map +1 -0
  290. package/src/domain/shopping/models/order.js +11 -0
  291. package/src/domain/shopping/models/order.js.map +1 -0
  292. package/src/domain/shopping/models/payment.js +169 -0
  293. package/src/domain/shopping/models/payment.js.map +1 -0
  294. package/src/domain/shopping/models/shipping-method.js +7 -0
  295. package/src/domain/shopping/models/shipping-method.js.map +1 -0
  296. package/src/domain/shopping/models/subscription/checkout.js +28 -0
  297. package/src/domain/shopping/models/subscription/checkout.js.map +1 -0
  298. package/src/domain/shopping/models/subscription/index.js +3 -0
  299. package/src/domain/shopping/models/subscription/index.js.map +1 -0
  300. package/src/domain/shopping/models/subscription/plan.js +7 -0
  301. package/src/domain/shopping/models/subscription/plan.js.map +1 -0
  302. package/src/domain/shopping/models/types/index.js +8 -0
  303. package/src/domain/shopping/models/types/index.js.map +1 -0
  304. package/src/domain/shopping/models/types/payment-address.type.d.ts +1 -1
  305. package/src/domain/shopping/models/types/payment-address.type.js +2 -0
  306. package/src/domain/shopping/models/types/payment-address.type.js.map +1 -0
  307. package/src/domain/shopping/models/types/payment-billing.type.d.ts +1 -1
  308. package/src/domain/shopping/models/types/payment-billing.type.js +2 -0
  309. package/src/domain/shopping/models/types/payment-billing.type.js.map +1 -0
  310. package/src/domain/shopping/models/types/payment-card.type.d.ts +1 -1
  311. package/src/domain/shopping/models/types/payment-card.type.js +2 -0
  312. package/src/domain/shopping/models/types/payment-card.type.js.map +1 -0
  313. package/src/domain/shopping/models/types/payment-customer.type.d.ts +1 -1
  314. package/src/domain/shopping/models/types/payment-customer.type.js +2 -0
  315. package/src/domain/shopping/models/types/payment-customer.type.js.map +1 -0
  316. package/src/domain/shopping/models/types/payment-document.type.d.ts +1 -1
  317. package/src/domain/shopping/models/types/payment-document.type.js +2 -0
  318. package/src/domain/shopping/models/types/payment-document.type.js.map +1 -0
  319. package/src/domain/shopping/models/types/payment-item.type.d.ts +1 -1
  320. package/src/domain/shopping/models/types/payment-item.type.js +2 -0
  321. package/src/domain/shopping/models/types/payment-item.type.js.map +1 -0
  322. package/src/domain/shopping/models/types/payment-shipping.type.d.ts +1 -1
  323. package/src/domain/shopping/models/types/payment-shipping.type.js +2 -0
  324. package/src/domain/shopping/models/types/payment-shipping.type.js.map +1 -0
  325. package/src/domain/shopping/repositories/buy-2-win.repository.js +2 -0
  326. package/src/domain/shopping/repositories/buy-2-win.repository.js.map +1 -0
  327. package/src/domain/shopping/repositories/campaign-dashboard.repository.js +2 -0
  328. package/src/domain/shopping/repositories/campaign-dashboard.repository.js.map +1 -0
  329. package/src/domain/shopping/repositories/campaign-hashtag.repository.js +2 -0
  330. package/src/domain/shopping/repositories/campaign-hashtag.repository.js.map +1 -0
  331. package/src/domain/shopping/repositories/checkout.repository.js +2 -0
  332. package/src/domain/shopping/repositories/checkout.repository.js.map +1 -0
  333. package/src/domain/shopping/repositories/coupon.repository.js +2 -0
  334. package/src/domain/shopping/repositories/coupon.repository.js.map +1 -0
  335. package/src/domain/shopping/repositories/index.js +10 -0
  336. package/src/domain/shopping/repositories/index.js.map +1 -0
  337. package/src/domain/shopping/repositories/legacy-order.repository.js +2 -0
  338. package/src/domain/shopping/repositories/legacy-order.repository.js.map +1 -0
  339. package/src/domain/shopping/repositories/order.repository.js +2 -0
  340. package/src/domain/shopping/repositories/order.repository.js.map +1 -0
  341. package/src/domain/shopping/repositories/payment.repository.js +2 -0
  342. package/src/domain/shopping/repositories/payment.repository.js.map +1 -0
  343. package/src/domain/shopping/repositories/subscription/checkout.repository.js +2 -0
  344. package/src/domain/shopping/repositories/subscription/checkout.repository.js.map +1 -0
  345. package/src/domain/shopping/repositories/subscription/index.js +3 -0
  346. package/src/domain/shopping/repositories/subscription/index.js.map +1 -0
  347. package/src/domain/shopping/repositories/subscription/plan.repository.js +2 -0
  348. package/src/domain/shopping/repositories/subscription/plan.repository.js.map +1 -0
  349. package/src/domain/users/errors/index.js +4 -0
  350. package/src/domain/users/errors/index.js.map +1 -0
  351. package/src/domain/users/errors/unauthorized.error.js +7 -0
  352. package/src/domain/users/errors/unauthorized.error.js.map +1 -0
  353. package/src/domain/users/errors/user-already-registered.error.js +7 -0
  354. package/src/domain/users/errors/user-already-registered.error.js.map +1 -0
  355. package/src/domain/users/errors/weak-password.error.js +7 -0
  356. package/src/domain/users/errors/weak-password.error.js.map +1 -0
  357. package/src/domain/users/index.js +6 -0
  358. package/src/domain/users/index.js.map +1 -0
  359. package/src/domain/users/models/beauty-profile.d.ts +1 -1
  360. package/src/domain/users/models/beauty-profile.js +12 -0
  361. package/src/domain/users/models/beauty-profile.js.map +1 -0
  362. package/src/domain/users/models/enums/accessory-importances.enum.js +7 -0
  363. package/src/domain/users/models/enums/accessory-importances.enum.js.map +1 -0
  364. package/src/domain/users/models/enums/area.enum.js +13 -0
  365. package/src/domain/users/models/enums/area.enum.js.map +1 -0
  366. package/src/domain/users/models/enums/beard-problems.enum.js +11 -0
  367. package/src/domain/users/models/enums/beard-problems.enum.js.map +1 -0
  368. package/src/domain/users/models/enums/beard-sizes.enum.js +9 -0
  369. package/src/domain/users/models/enums/beard-sizes.enum.js.map +1 -0
  370. package/src/domain/users/models/enums/beauty-product-importances.enum.js +8 -0
  371. package/src/domain/users/models/enums/beauty-product-importances.enum.js.map +1 -0
  372. package/src/domain/users/models/enums/body-problems.enum.js +13 -0
  373. package/src/domain/users/models/enums/body-problems.enum.js.map +1 -0
  374. package/src/domain/users/models/enums/body-shapes.enum.js +9 -0
  375. package/src/domain/users/models/enums/body-shapes.enum.js.map +1 -0
  376. package/src/domain/users/models/enums/body-tattoos.enum.js +7 -0
  377. package/src/domain/users/models/enums/body-tattoos.enum.js.map +1 -0
  378. package/src/domain/users/models/enums/face-skin-oilinesses.enum.js +9 -0
  379. package/src/domain/users/models/enums/face-skin-oilinesses.enum.js.map +1 -0
  380. package/src/domain/users/models/enums/face-skin-problems.enum.js +12 -0
  381. package/src/domain/users/models/enums/face-skin-problems.enum.js.map +1 -0
  382. package/src/domain/users/models/enums/face-skin-tones.enum.js +10 -0
  383. package/src/domain/users/models/enums/face-skin-tones.enum.js.map +1 -0
  384. package/src/domain/users/models/enums/family-incomes.enum.js +10 -0
  385. package/src/domain/users/models/enums/family-incomes.enum.js.map +1 -0
  386. package/src/domain/users/models/enums/fragrance-importances.enum.js +7 -0
  387. package/src/domain/users/models/enums/fragrance-importances.enum.js.map +1 -0
  388. package/src/domain/users/models/enums/hair-colors.enum.js +12 -0
  389. package/src/domain/users/models/enums/hair-colors.enum.js.map +1 -0
  390. package/src/domain/users/models/enums/hair-problems.enum.js +12 -0
  391. package/src/domain/users/models/enums/hair-problems.enum.js.map +1 -0
  392. package/src/domain/users/models/enums/hair-strands.enum.js +10 -0
  393. package/src/domain/users/models/enums/hair-strands.enum.js.map +1 -0
  394. package/src/domain/users/models/enums/hair-types.enum.js +9 -0
  395. package/src/domain/users/models/enums/hair-types.enum.js.map +1 -0
  396. package/src/domain/users/models/enums/index.js +21 -0
  397. package/src/domain/users/models/enums/index.js.map +1 -0
  398. package/src/domain/users/models/enums/office-position.enum.js +8 -0
  399. package/src/domain/users/models/enums/office-position.enum.js.map +1 -0
  400. package/src/domain/users/models/enums/product-spents.enum.js +10 -0
  401. package/src/domain/users/models/enums/product-spents.enum.js.map +1 -0
  402. package/src/domain/users/models/enums/user-type.enum.js +10 -0
  403. package/src/domain/users/models/enums/user-type.enum.js.map +1 -0
  404. package/src/domain/users/models/index.js +8 -0
  405. package/src/domain/users/models/index.js.map +1 -0
  406. package/src/domain/users/models/lead.js +7 -0
  407. package/src/domain/users/models/lead.js.map +1 -0
  408. package/src/domain/users/models/subscription/edition.d.ts +1 -1
  409. package/src/domain/users/models/subscription/edition.js +7 -0
  410. package/src/domain/users/models/subscription/edition.js.map +1 -0
  411. package/src/domain/users/models/subscription/enums/billing-status.enum.js +5 -0
  412. package/src/domain/users/models/subscription/enums/billing-status.enum.js.map +1 -0
  413. package/src/domain/users/models/subscription/enums/edition-status.enum.js +6 -0
  414. package/src/domain/users/models/subscription/enums/edition-status.enum.js.map +1 -0
  415. package/src/domain/users/models/subscription/enums/index.js +5 -0
  416. package/src/domain/users/models/subscription/enums/index.js.map +1 -0
  417. package/src/domain/users/models/subscription/enums/payment-type.enum.js +7 -0
  418. package/src/domain/users/models/subscription/enums/payment-type.enum.js.map +1 -0
  419. package/src/domain/users/models/subscription/enums/status.enum.js +6 -0
  420. package/src/domain/users/models/subscription/enums/status.enum.js.map +1 -0
  421. package/src/domain/users/models/subscription/index.js +5 -0
  422. package/src/domain/users/models/subscription/index.js.map +1 -0
  423. package/src/domain/users/models/subscription/payment.d.ts +1 -1
  424. package/src/domain/users/models/subscription/payment.js +14 -0
  425. package/src/domain/users/models/subscription/payment.js.map +1 -0
  426. package/src/domain/users/models/subscription/subscription.js +43 -0
  427. package/src/domain/users/models/subscription/subscription.js.map +1 -0
  428. package/src/domain/users/models/user-address.d.ts +1 -1
  429. package/src/domain/users/models/user-address.js +7 -0
  430. package/src/domain/users/models/user-address.js.map +1 -0
  431. package/src/domain/users/models/user-payment-method.d.ts +1 -1
  432. package/src/domain/users/models/user-payment-method.js +7 -0
  433. package/src/domain/users/models/user-payment-method.js.map +1 -0
  434. package/src/domain/users/models/user.js +26 -0
  435. package/src/domain/users/models/user.js.map +1 -0
  436. package/src/domain/users/repositories/beauty-profile.repository.js +2 -0
  437. package/src/domain/users/repositories/beauty-profile.repository.js.map +1 -0
  438. package/src/domain/users/repositories/edition.repository.js +2 -0
  439. package/src/domain/users/repositories/edition.repository.js.map +1 -0
  440. package/src/domain/users/repositories/index.js +9 -0
  441. package/src/domain/users/repositories/index.js.map +1 -0
  442. package/src/domain/users/repositories/lead.repository.js +2 -0
  443. package/src/domain/users/repositories/lead.repository.js.map +1 -0
  444. package/src/domain/users/repositories/subscription-payment.repository.js +2 -0
  445. package/src/domain/users/repositories/subscription-payment.repository.js.map +1 -0
  446. package/src/domain/users/repositories/subscription.repository.js +2 -0
  447. package/src/domain/users/repositories/subscription.repository.js.map +1 -0
  448. package/src/domain/users/repositories/user-address.repository.js +2 -0
  449. package/src/domain/users/repositories/user-address.repository.js.map +1 -0
  450. package/src/domain/users/repositories/user-payment-method.repository.js +2 -0
  451. package/src/domain/users/repositories/user-payment-method.repository.js.map +1 -0
  452. package/src/domain/users/repositories/user.repository.js +2 -0
  453. package/src/domain/users/repositories/user.repository.js.map +1 -0
  454. package/src/domain/users/services/authentication.service.d.ts +1 -1
  455. package/src/domain/users/services/authentication.service.js +2 -0
  456. package/src/domain/users/services/authentication.service.js.map +1 -0
  457. package/src/domain/users/services/index.js +4 -0
  458. package/src/domain/users/services/index.js.map +1 -0
  459. package/src/domain/users/services/register.service.d.ts +1 -1
  460. package/src/domain/users/services/register.service.js +2 -0
  461. package/src/domain/users/services/register.service.js.map +1 -0
  462. package/src/domain/users/services/types/basic-user-data.type.d.ts +1 -1
  463. package/src/domain/users/services/types/basic-user-data.type.js +2 -0
  464. package/src/domain/users/services/types/basic-user-data.type.js.map +1 -0
  465. package/src/domain/users/services/types/index.js +2 -0
  466. package/src/domain/users/services/types/index.js.map +1 -0
  467. package/src/domain/users/use-cases/authentication.d.ts +2 -2
  468. package/src/domain/users/use-cases/authentication.js +35 -0
  469. package/src/domain/users/use-cases/authentication.js.map +1 -0
  470. package/src/domain/users/use-cases/index.js +5 -0
  471. package/src/domain/users/use-cases/index.js.map +1 -0
  472. package/src/domain/users/use-cases/recovery-password.js +9 -0
  473. package/src/domain/users/use-cases/recovery-password.js.map +1 -0
  474. package/src/domain/users/use-cases/register.d.ts +1 -1
  475. package/src/domain/users/use-cases/register.js +31 -0
  476. package/src/domain/users/use-cases/register.js.map +1 -0
  477. package/src/domain/users/use-cases/signout.js +9 -0
  478. package/src/domain/users/use-cases/signout.js.map +1 -0
  479. package/src/errors/duplicated-results.error.js +7 -0
  480. package/src/errors/duplicated-results.error.js.map +1 -0
  481. package/src/errors/index.js +5 -0
  482. package/src/errors/index.js.map +1 -0
  483. package/src/errors/invalid-argument.error.js +7 -0
  484. package/src/errors/invalid-argument.error.js.map +1 -0
  485. package/src/errors/not-found.error.js +7 -0
  486. package/src/errors/not-found.error.js.map +1 -0
  487. package/src/errors/required-argument.error.js +9 -0
  488. package/src/errors/required-argument.error.js.map +1 -0
  489. package/src/index.js +6 -0
  490. package/src/index.js.map +1 -0
  491. package/src/infra/elasticsearch/adapters/axios.adapter.d.ts +1 -1
  492. package/src/infra/elasticsearch/adapters/axios.adapter.js +67 -0
  493. package/src/infra/elasticsearch/adapters/axios.adapter.js.map +1 -0
  494. package/src/infra/elasticsearch/adapters/elastic-search.adapter.js +2 -0
  495. package/src/infra/elasticsearch/adapters/elastic-search.adapter.js.map +1 -0
  496. package/src/infra/elasticsearch/adapters/index.js +3 -0
  497. package/src/infra/elasticsearch/adapters/index.js.map +1 -0
  498. package/src/infra/elasticsearch/index.js +4 -0
  499. package/src/infra/elasticsearch/index.js.map +1 -0
  500. package/src/infra/elasticsearch/indexes/index.js +2 -0
  501. package/src/infra/elasticsearch/indexes/index.js.map +1 -0
  502. package/src/infra/elasticsearch/indexes/products-index.js +105 -0
  503. package/src/infra/elasticsearch/indexes/products-index.js.map +1 -0
  504. package/src/infra/elasticsearch/types/elastic-search-result.d.ts +1 -1
  505. package/src/infra/elasticsearch/types/elastic-search-result.js +2 -0
  506. package/src/infra/elasticsearch/types/elastic-search-result.js.map +1 -0
  507. package/src/infra/elasticsearch/types/index.js +2 -0
  508. package/src/infra/elasticsearch/types/index.js.map +1 -0
  509. package/src/infra/firebase/auth/authentication-firebase-auth.service.js +41 -0
  510. package/src/infra/firebase/auth/authentication-firebase-auth.service.js.map +1 -0
  511. package/src/infra/firebase/auth/index.js +3 -0
  512. package/src/infra/firebase/auth/index.js.map +1 -0
  513. package/src/infra/firebase/auth/register-firebase-auth.service.js +33 -0
  514. package/src/infra/firebase/auth/register-firebase-auth.service.js.map +1 -0
  515. package/src/infra/firebase/auth/types/firebase-user-with-id.type.d.ts +1 -1
  516. package/src/infra/firebase/auth/types/firebase-user-with-id.type.js +2 -0
  517. package/src/infra/firebase/auth/types/firebase-user-with-id.type.js.map +1 -0
  518. package/src/infra/firebase/auth/types/index.js +2 -0
  519. package/src/infra/firebase/auth/types/index.js.map +1 -0
  520. package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js +10 -0
  521. package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js.map +1 -0
  522. package/src/infra/firebase/firestore/enums/index.js +2 -0
  523. package/src/infra/firebase/firestore/enums/index.js.map +1 -0
  524. package/src/infra/firebase/firestore/index.js +4 -0
  525. package/src/infra/firebase/firestore/index.js.map +1 -0
  526. package/src/infra/firebase/firestore/mixins/index.js +10 -0
  527. package/src/infra/firebase/firestore/mixins/index.js.map +1 -0
  528. package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js +33 -0
  529. package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js.map +1 -0
  530. package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js +10 -0
  531. package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js.map +1 -0
  532. package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js +19 -0
  533. package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js.map +1 -0
  534. package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js +109 -0
  535. package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js.map +1 -0
  536. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.d.ts +1 -1
  537. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js +77 -0
  538. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js.map +1 -0
  539. package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js +24 -0
  540. package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js.map +1 -0
  541. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js +17 -0
  542. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js.map +1 -0
  543. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.d.ts +1 -1
  544. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js +13 -0
  545. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js.map +1 -0
  546. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.d.ts +1 -1
  547. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js +52 -0
  548. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js.map +1 -0
  549. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js +67 -0
  550. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js.map +1 -0
  551. package/src/infra/firebase/firestore/repositories/catalog/index.js +5 -0
  552. package/src/infra/firebase/firestore/repositories/catalog/index.js.map +1 -0
  553. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js +56 -0
  554. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js.map +1 -0
  555. package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js +16 -0
  556. package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js.map +1 -0
  557. package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js +14 -0
  558. package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js.map +1 -0
  559. package/src/infra/firebase/firestore/repositories/index.js +5 -0
  560. package/src/infra/firebase/firestore/repositories/index.js.map +1 -0
  561. package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js +66 -0
  562. package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js.map +1 -0
  563. package/src/infra/firebase/firestore/repositories/shop-settings/index.js +4 -0
  564. package/src/infra/firebase/firestore/repositories/shop-settings/index.js.map +1 -0
  565. package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js +14 -0
  566. package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js.map +1 -0
  567. package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js +14 -0
  568. package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js.map +1 -0
  569. package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js +14 -0
  570. package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js.map +1 -0
  571. package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js +14 -0
  572. package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js.map +1 -0
  573. package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js +14 -0
  574. package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js.map +1 -0
  575. package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js +14 -0
  576. package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js.map +1 -0
  577. package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js +14 -0
  578. package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js.map +1 -0
  579. package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js +31 -0
  580. package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js.map +1 -0
  581. package/src/infra/firebase/firestore/repositories/shopping/index.js +11 -0
  582. package/src/infra/firebase/firestore/repositories/shopping/index.js.map +1 -0
  583. package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js +11 -0
  584. package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js.map +1 -0
  585. package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js +41 -0
  586. package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js.map +1 -0
  587. package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js +14 -0
  588. package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js.map +1 -0
  589. package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js +14 -0
  590. package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js.map +1 -0
  591. package/src/infra/firebase/firestore/repositories/users/index.js +9 -0
  592. package/src/infra/firebase/firestore/repositories/users/index.js.map +1 -0
  593. package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js +14 -0
  594. package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js.map +1 -0
  595. package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js +16 -0
  596. package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js.map +1 -0
  597. package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js +14 -0
  598. package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js.map +1 -0
  599. package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js +16 -0
  600. package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js.map +1 -0
  601. package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js +16 -0
  602. package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js.map +1 -0
  603. package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js +16 -0
  604. package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js.map +1 -0
  605. package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js +50 -0
  606. package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js.map +1 -0
  607. package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js +16 -0
  608. package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js.map +1 -0
  609. package/src/infra/firebase/firestore/types/firestore-interceptors.type.d.ts +1 -1
  610. package/src/infra/firebase/firestore/types/firestore-interceptors.type.js +2 -0
  611. package/src/infra/firebase/firestore/types/firestore-interceptors.type.js.map +1 -0
  612. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.d.ts +1 -1
  613. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js +2 -0
  614. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js.map +1 -0
  615. package/src/infra/firebase/firestore/types/firestore.helpers.type.js +2 -0
  616. package/src/infra/firebase/firestore/types/firestore.helpers.type.js.map +1 -0
  617. package/src/infra/firebase/firestore/types/firestore.repository.type.d.ts +1 -1
  618. package/src/infra/firebase/firestore/types/firestore.repository.type.js +2 -0
  619. package/src/infra/firebase/firestore/types/firestore.repository.type.js.map +1 -0
  620. package/src/infra/firebase/firestore/types/index.js +5 -0
  621. package/src/infra/firebase/firestore/types/index.js.map +1 -0
  622. package/src/infra/firebase/index.js +3 -0
  623. package/src/infra/firebase/index.js.map +1 -0
  624. package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js +13 -0
  625. package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js.map +1 -0
  626. package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js +17 -0
  627. package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js.map +1 -0
  628. package/src/infra/hasura-graphql/enums/index.js +3 -0
  629. package/src/infra/hasura-graphql/enums/index.js.map +1 -0
  630. package/src/infra/hasura-graphql/index.js +5 -0
  631. package/src/infra/hasura-graphql/index.js.map +1 -0
  632. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.d.ts +1 -1
  633. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js +32 -0
  634. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js.map +1 -0
  635. package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js +56 -0
  636. package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js.map +1 -0
  637. package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js +22 -0
  638. package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js.map +1 -0
  639. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.d.ts +1 -1
  640. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js +104 -0
  641. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js.map +1 -0
  642. package/src/infra/hasura-graphql/mixins/helpers/index.js +5 -0
  643. package/src/infra/hasura-graphql/mixins/helpers/index.js.map +1 -0
  644. package/src/infra/hasura-graphql/mixins/index.js +8 -0
  645. package/src/infra/hasura-graphql/mixins/index.js.map +1 -0
  646. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.d.ts +1 -1
  647. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js +41 -0
  648. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js.map +1 -0
  649. package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js +10 -0
  650. package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js.map +1 -0
  651. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.d.ts +1 -1
  652. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js +28 -0
  653. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js.map +1 -0
  654. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +143 -0
  655. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js.map +1 -0
  656. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +1 -1
  657. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js +35 -0
  658. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js.map +1 -0
  659. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.d.ts +3 -3
  660. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js +105 -0
  661. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js.map +1 -0
  662. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.d.ts +2 -2
  663. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js +57 -0
  664. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js.map +1 -0
  665. package/src/infra/hasura-graphql/models/category-hasura-graphql.js +4 -0
  666. package/src/infra/hasura-graphql/models/category-hasura-graphql.js.map +1 -0
  667. package/src/infra/hasura-graphql/models/index.js +5 -0
  668. package/src/infra/hasura-graphql/models/index.js.map +1 -0
  669. package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js +15 -0
  670. package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js.map +1 -0
  671. package/src/infra/hasura-graphql/models/product-hasura-graphql.js +11 -0
  672. package/src/infra/hasura-graphql/models/product-hasura-graphql.js.map +1 -0
  673. package/src/infra/hasura-graphql/models/variant-hasura-graphql.js +9 -0
  674. package/src/infra/hasura-graphql/models/variant-hasura-graphql.js.map +1 -0
  675. package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js +39 -0
  676. package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js.map +1 -0
  677. package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +107 -0
  678. package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js.map +1 -0
  679. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +330 -0
  680. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js.map +1 -0
  681. package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js +106 -0
  682. package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js.map +1 -0
  683. package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js +22 -0
  684. package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js.map +1 -0
  685. package/src/infra/hasura-graphql/repositories/catalog/index.js +9 -0
  686. package/src/infra/hasura-graphql/repositories/catalog/index.js.map +1 -0
  687. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +461 -0
  688. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js.map +1 -0
  689. package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js +107 -0
  690. package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js.map +1 -0
  691. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js +228 -0
  692. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js.map +1 -0
  693. package/src/infra/hasura-graphql/repositories/index.js +2 -0
  694. package/src/infra/hasura-graphql/repositories/index.js.map +1 -0
  695. package/src/infra/hasura-graphql/types/fields.type.d.ts +1 -1
  696. package/src/infra/hasura-graphql/types/fields.type.js +2 -0
  697. package/src/infra/hasura-graphql/types/fields.type.js.map +1 -0
  698. package/src/infra/hasura-graphql/types/graphql.repository.type.d.ts +2 -2
  699. package/src/infra/hasura-graphql/types/graphql.repository.type.js +2 -0
  700. package/src/infra/hasura-graphql/types/graphql.repository.type.js.map +1 -0
  701. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.d.ts +1 -1
  702. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js +2 -0
  703. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js.map +1 -0
  704. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.d.ts +6 -6
  705. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js +2 -0
  706. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js.map +1 -0
  707. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.d.ts +1 -1
  708. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js +2 -0
  709. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js.map +1 -0
  710. package/src/infra/hasura-graphql/types/index.js +9 -0
  711. package/src/infra/hasura-graphql/types/index.js.map +1 -0
  712. package/src/infra/hasura-graphql/types/nested-field.type.d.ts +1 -1
  713. package/src/infra/hasura-graphql/types/nested-field.type.js +2 -0
  714. package/src/infra/hasura-graphql/types/nested-field.type.js.map +1 -0
  715. package/src/infra/hasura-graphql/types/query-builder-options.type.js +2 -0
  716. package/src/infra/hasura-graphql/types/query-builder-options.type.js.map +1 -0
  717. package/src/infra/hasura-graphql/types/variable-options.type.d.ts +1 -1
  718. package/src/infra/hasura-graphql/types/variable-options.type.js +2 -0
  719. package/src/infra/hasura-graphql/types/variable-options.type.js.map +1 -0
  720. package/src/infra/index.js +4 -0
  721. package/src/infra/index.js.map +1 -0
  722. package/src/utils/decorators/debug.class.decorator.js +7 -0
  723. package/src/utils/decorators/debug.class.decorator.js.map +1 -0
  724. package/src/utils/decorators/index.js +3 -0
  725. package/src/utils/decorators/index.js.map +1 -0
  726. package/src/utils/decorators/trace.method.decorator.d.ts +3 -3
  727. package/src/utils/decorators/trace.method.decorator.js +81 -0
  728. package/src/utils/decorators/trace.method.decorator.js.map +1 -0
  729. package/src/utils/get.js +3 -0
  730. package/src/utils/get.js.map +1 -0
  731. package/src/utils/helpers/class-name.helper.js +15 -0
  732. package/src/utils/helpers/class-name.helper.js.map +1 -0
  733. package/src/utils/helpers/debug-decorator.helper.d.ts +1 -1
  734. package/src/utils/helpers/debug-decorator.helper.js +18 -0
  735. package/src/utils/helpers/debug-decorator.helper.js.map +1 -0
  736. package/src/utils/helpers/debug.helper.d.ts +3 -3
  737. package/src/utils/helpers/debug.helper.js +150 -0
  738. package/src/utils/helpers/debug.helper.js.map +1 -0
  739. package/src/utils/helpers/index.js +5 -0
  740. package/src/utils/helpers/index.js.map +1 -0
  741. package/src/utils/helpers/reflect.helper.d.ts +7 -7
  742. package/src/utils/helpers/reflect.helper.js +165 -0
  743. package/src/utils/helpers/reflect.helper.js.map +1 -0
  744. package/src/utils/index.d.ts +1 -1
  745. package/src/utils/index.js +13 -0
  746. package/src/utils/index.js.map +1 -0
  747. package/src/utils/is-uuid.js +3 -0
  748. package/src/utils/is-uuid.js.map +1 -0
  749. package/src/utils/is.js +4 -0
  750. package/src/utils/is.js.map +1 -0
  751. package/src/utils/log.utils.js +9 -0
  752. package/src/utils/log.utils.js.map +1 -0
  753. package/src/utils/mixins/base.mixin.js +6 -0
  754. package/src/utils/mixins/base.mixin.js.map +1 -0
  755. package/src/utils/mixins/index.js +4 -0
  756. package/src/utils/mixins/index.js.map +1 -0
  757. package/src/utils/mixins/merge-constructor-params.type.d.ts +2 -2
  758. package/src/utils/mixins/merge-constructor-params.type.js +2 -0
  759. package/src/utils/mixins/merge-constructor-params.type.js.map +1 -0
  760. package/src/utils/mixins/mixin-ctor.type.d.ts +1 -1
  761. package/src/utils/mixins/mixin-ctor.type.js +2 -0
  762. package/src/utils/mixins/mixin-ctor.type.js.map +1 -0
  763. package/src/utils/parse-datetime.js +14 -0
  764. package/src/utils/parse-datetime.js.map +1 -0
  765. package/src/utils/types/array-element.type.d.ts +1 -1
  766. package/src/utils/types/array-element.type.js +2 -0
  767. package/src/utils/types/array-element.type.js.map +1 -0
  768. package/src/utils/types/index.js +3 -0
  769. package/src/utils/types/index.js.map +1 -0
  770. package/src/utils/types/prop.type.d.ts +1 -1
  771. package/src/utils/types/prop.type.js +2 -0
  772. package/src/utils/types/prop.type.js.map +1 -0
  773. package/index.cjs.d.ts +0 -1
  774. package/index.cjs.default.js +0 -1
  775. package/index.cjs.js +0 -5730
  776. package/index.cjs.mjs +0 -2
  777. package/index.esm.js +0 -5479
@@ -0,0 +1,56 @@
1
+ import { Where, } from '../../../../domain';
2
+ import { is, isNil, isObject } from '../../../../utils';
3
+ import { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums';
4
+ import { AttributeOptionHelper } from './attribute-option.helper';
5
+ import { FilterOptionHelper } from './filter-option.helper';
6
+ export class BindFilterQueryHelper {
7
+ }
8
+ BindFilterQueryHelper.MakeGraphQLWhere = (filter, fields) => Object.keys(filter).reduce((variables, fieldName) => {
9
+ const columnOption = AttributeOptionHelper.FindByAttribute(fieldName, fields);
10
+ if (!columnOption.bindFindFilter)
11
+ return Object.assign(Object.assign({}, variables), {
12
+ [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, filter[fieldName], fields),
13
+ });
14
+ const builtFilter = columnOption.bindFindFilter(filter[fieldName]);
15
+ return Object.assign(Object.assign({}, variables), Object.keys(builtFilter).reduce((variablesList, columnName) => (Object.assign(Object.assign({}, variablesList), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, builtFilter[columnName], fields) })), {}));
16
+ }, {});
17
+ BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
18
+ const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute(field, fields);
19
+ const isNestedField = !Array.isArray(options) &&
20
+ isObject(options) &&
21
+ isNil(options === null || options === void 0 ? void 0 : options.operator) &&
22
+ isNil(options === null || options === void 0 ? void 0 : options.value) &&
23
+ isNil(fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.to);
24
+ if (isNestedField)
25
+ return Object.keys(options).reduce((variables, key) => {
26
+ const fieldOptions = AttributeOptionHelper.FindByAttribute(key, (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || fields);
27
+ const columnName = fieldOptions.columnName;
28
+ const columnFields = fieldOptions.fields;
29
+ return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || columnFields || fields) });
30
+ }, {});
31
+ if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
32
+ return {
33
+ [fieldSentenceOptions.fields[0]]: BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions),
34
+ };
35
+ if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))
36
+ options = Object.values(options)[0];
37
+ return Array.isArray(options)
38
+ ? options.reduce((whereSentence, option) => (Object.assign(Object.assign({}, whereSentence), BindFilterQueryHelper.BuildOperatorSentence(option, fieldSentenceOptions))), {})
39
+ : BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions);
40
+ };
41
+ BindFilterQueryHelper.BuildOperatorSentence = (options, fieldOption) => ({
42
+ [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(options, fieldOption),
43
+ });
44
+ BindFilterQueryHelper.GetHasuraOperator = (options, fieldOption) => FilterOptionHelper.CheckIfIsFilterOption(options)
45
+ ? fieldOption.type === HasuraGraphQLColumnType.Jsonb
46
+ ? BindFilterQueryHelper.GetHasuraJsonbOperator(options)
47
+ : HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
48
+ Object.keys(Where).find((operator) => Where[operator] === (options === null || options === void 0 ? void 0 : options.operator)))]
49
+ : HasuraGraphQLWhere.EQUALS;
50
+ BindFilterQueryHelper.GetHasuraJsonbOperator = (options) => options.operator === Where.IN
51
+ ? HasuraGraphQLWhere.JSON_CONTAINS
52
+ : options.operator === Where.LIKE
53
+ ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY
54
+ : HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
55
+ Object.keys(Where).find((operator) => Where[operator] === (options === null || options === void 0 ? void 0 : options.operator)))];
56
+ //# sourceMappingURL=bind-filter-query.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bind-filter-query.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n NonFunctionPropertyNames,\r\n RepositoryFindFielters,\r\n RepositoryFindFieltersOptions,\r\n Where,\r\n} from '../../../../domain'\r\nimport { is, isNil, isObject } from '../../../../utils'\r\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\r\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\r\nimport { AttributeOptionHelper } from './attribute-option.helper'\r\nimport { FilterOptionHelper } from './filter-option.helper'\r\n\r\nexport class BindFilterQueryHelper {\r\n static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\r\n filter: RepositoryFindFielters<MBase>,\r\n fields: HasuraGraphQLFields<MBase>,\r\n ): VariableOptions =>\r\n Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\r\n const columnOption = AttributeOptionHelper.FindByAttribute(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n fields,\r\n )\r\n\r\n if (!columnOption.bindFindFilter)\r\n return {\r\n ...variables,\r\n ...{\r\n [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n filter[fieldName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionAndIdentifierPropertyNames<MBase>\r\n >,\r\n fields,\r\n ),\r\n },\r\n }\r\n\r\n const builtFilter: RepositoryFindFielters<MBase> = columnOption.bindFindFilter(\r\n filter[fieldName as NonFunctionPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionPropertyNames<MBase>\r\n >,\r\n )\r\n\r\n return {\r\n ...variables,\r\n ...Object.keys(builtFilter).reduce(\r\n (variablesList: VariableOptions, columnName: string) => ({\r\n ...variablesList,\r\n [columnName]: BindFilterQueryHelper.BuildWhereSentence(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n builtFilter[columnName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionAndIdentifierPropertyNames<MBase>\r\n >,\r\n fields,\r\n ),\r\n }),\r\n {},\r\n ),\r\n }\r\n }, {})\r\n\r\n static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\r\n field: NonFunctionAndIdentifierPropertyNames<MBase>,\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>,\r\n fields: HasuraGraphQLFields<MBase>,\r\n ): VariableOptions => {\r\n const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\r\n const isNestedField =\r\n !Array.isArray(options) &&\r\n isObject(options) &&\r\n isNil(options?.operator) &&\r\n isNil(options?.value) &&\r\n isNil(fieldSentenceOptions?.to)\r\n\r\n if (isNestedField)\r\n return Object.keys(options).reduce((variables, key) => {\r\n const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\r\n key as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n fieldSentenceOptions?.fields || (fields as any),\r\n )\r\n const columnName = fieldOptions.columnName\r\n const columnFields = fieldOptions.fields\r\n\r\n return {\r\n ...variables,\r\n [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\r\n key as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n is<RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>>(\r\n is<RepositoryFindFielters<MBase>>(options)[key as NonFunctionAndIdentifierPropertyNames<MBase>],\r\n ),\r\n fieldSentenceOptions?.fields || columnFields || (fields as any),\r\n ),\r\n }\r\n }, {})\r\n\r\n if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\r\n return {\r\n [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\r\n BindFilterQueryHelper.BuildOperatorSentence(\r\n options,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n ),\r\n }\r\n\r\n if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\r\n options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\r\n\r\n return Array.isArray(options)\r\n ? options.reduce(\r\n (whereSentence, option) => ({\r\n ...whereSentence,\r\n ...BindFilterQueryHelper.BuildOperatorSentence(\r\n option,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n ),\r\n }),\r\n {},\r\n )\r\n : BindFilterQueryHelper.BuildOperatorSentence(\r\n options,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n )\r\n }\r\n\r\n static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, any>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): VariableOptions => ({\r\n [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\r\n options,\r\n fieldOption,\r\n ),\r\n })\r\n\r\n static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): HasuraGraphQLWhere =>\r\n FilterOptionHelper.CheckIfIsFilterOption(options)\r\n ? fieldOption.type === HasuraGraphQLColumnType.Jsonb\r\n ? BindFilterQueryHelper.GetHasuraJsonbOperator(options)\r\n : HasuraGraphQLWhere[\r\n Object.keys(HasuraGraphQLWhere).find(\r\n (graphQLOperator) =>\r\n graphQLOperator ===\r\n Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\r\n ) as keyof typeof HasuraGraphQLWhere\r\n ]\r\n : HasuraGraphQLWhere.EQUALS\r\n\r\n static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\r\n ): HasuraGraphQLWhere =>\r\n options.operator === Where.IN\r\n ? HasuraGraphQLWhere.JSON_CONTAINS\r\n : options.operator === Where.LIKE\r\n ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY\r\n : HasuraGraphQLWhere[\r\n Object.keys(HasuraGraphQLWhere).find(\r\n (graphQLOperator) =>\r\n graphQLOperator ===\r\n Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\r\n ) as keyof typeof HasuraGraphQLWhere\r\n ]\r\n}\r\n"]}
@@ -0,0 +1,22 @@
1
+ import { Where } from '../../../../domain';
2
+ import { isNil } from '../../../../utils';
3
+ export class FilterOptionHelper {
4
+ }
5
+ FilterOptionHelper.CheckIfIsFilterOption = (filter) => !isNil(filter === null || filter === void 0 ? void 0 : filter.operator);
6
+ FilterOptionHelper.GetValueFromFilter = (filter, fieldOption) => {
7
+ if (!FilterOptionHelper.CheckIfIsFilterOption(filter))
8
+ return filter;
9
+ if (filter.operator === Where.ISNULL)
10
+ return true;
11
+ if (filter.operator === Where.ISNOTNULL)
12
+ return false;
13
+ const converter = fieldOption.to
14
+ ? fieldOption.to
15
+ : (value) => filter.operator === Where.LIKE && !Array.isArray(filter.value) && value.indexOf('%') < 0
16
+ ? `%${value}%`
17
+ : value;
18
+ return Array.isArray(filter.value) && !fieldOption.fields && [Where.IN, Where.NOTIN].includes(filter.operator)
19
+ ? filter.value.map((fieldValue) => converter(fieldValue))
20
+ : converter(filter.value);
21
+ };
22
+ //# sourceMappingURL=filter-option.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filter-option.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqD,KAAK,EAAE,MAAM,oBAAoB,CAAA;AAC7F,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAGzC,MAAM,OAAO,kBAAkB;;AACtB,wCAAqB,GAAG,CAC7B,MAAW,EAC0C,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,CAAC,CAAA;AAE3E,qCAAkB,GAAG,CAC1B,MAAiD,EACjD,WAAoC,EAC/B,EAAE;IACP,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC,MAAM,CAAC;QAAE,OAAO,MAAM,CAAA;IACpE,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,MAAM;QAAE,OAAO,IAAI,CAAA;IACjD,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,SAAS;QAAE,OAAO,KAAK,CAAA;IAErD,MAAM,SAAS,GAAG,WAAW,CAAC,EAAE;QAC9B,CAAC,CAAC,WAAW,CAAC,EAAE;QAChB,CAAC,CAAC,CAAC,KAAU,EAAE,EAAE,CACb,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;YACtF,CAAC,CAAC,IAAI,KAAK,GAAG;YACd,CAAC,CAAC,KAAK,CAAA;IAEf,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC;QAC5G,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACzD,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,KAAY,CAAC,CAAA;AACpC,CAAC,CAAA","sourcesContent":["import { ModelBaseStructure, RepositoryFindFieltersOptions, Where } from '../../../../domain'\r\nimport { isNil } from '../../../../utils'\r\nimport { ColumnOptions } from '../../types'\r\n\r\nexport class FilterOptionHelper {\r\n static CheckIfIsFilterOption = <Model extends ModelBaseStructure>(\r\n filter: any,\r\n ): filter is RepositoryFindFieltersOptions<Model, any> => !isNil(filter?.operator)\r\n\r\n static GetValueFromFilter = <Model extends ModelBaseStructure<Model>>(\r\n filter: RepositoryFindFieltersOptions<Model, any>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): any => {\r\n if (!FilterOptionHelper.CheckIfIsFilterOption(filter)) return filter\r\n if (filter.operator === Where.ISNULL) return true\r\n if (filter.operator === Where.ISNOTNULL) return false\r\n\r\n const converter = fieldOption.to\r\n ? fieldOption.to\r\n : (value: any) =>\r\n filter.operator === Where.LIKE && !Array.isArray(filter.value) && value.indexOf('%') < 0\r\n ? `%${value}%`\r\n : value\r\n\r\n return Array.isArray(filter.value) && !fieldOption.fields && [Where.IN, Where.NOTIN].includes(filter.operator)\r\n ? filter.value.map((fieldValue) => converter(fieldValue))\r\n : converter(filter.value as any)\r\n }\r\n}\r\n"]}
@@ -6,7 +6,7 @@ export declare class GraphQLFieldHelper {
6
6
  static ConvertModelFieldsToGraphQLFields: <Model extends ModelBaseStructure<Model, Model["identifiersFields"][number]>>(fields: HasuraGraphQLFields<Model>) => Fields;
7
7
  static ConvertFieldValueFrom: <Model extends ModelBaseStructure<Record<string, any> & {
8
8
  identifiersFields: any[];
9
- }, any>, RecordDataType extends string | number | DataType | Date, DataType extends Record<string, RecordDataType | RecordDataType[]>>(data: DataType, fields: HasuraGraphQLFields<Model>) => NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | Partial<import("../../../../domain").IdentifiersModel<Model>>;
9
+ }, any>, RecordDataType extends string | number | Date | DataType, DataType extends Record<string, RecordDataType | RecordDataType[]>>(data: DataType, fields: HasuraGraphQLFields<Model>) => NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | Partial<import("../../../../domain").IdentifiersModel<Model>>;
10
10
  static ConvertFieldValueTo: <Model extends ModelBaseStructure<Model, Model["identifiersFields"][number]>, DataType extends Record<string, string | number | Date | DataType>>(instance: Model, fields: HasuraGraphQLFields<Model>, update?: boolean) => DataType;
11
11
  private static ConvertNestedFieldsToGraphQLFields;
12
12
  }
@@ -0,0 +1,104 @@
1
+ import { BaseModel, } from '../../../../domain';
2
+ import { is, isDate, isEmpty, isNil, isObject, isString, parseDateTime } from '../../../../utils';
3
+ import { AttributeOptionHelper } from './attribute-option.helper';
4
+ import { BindFilterQueryHelper } from './bind-filter-query.helper';
5
+ export class GraphQLFieldHelper {
6
+ }
7
+ GraphQLFieldHelper.CheckIsGraphQLParams = (params) => !isString(params) && Array.isArray(params) && params.length >= 0 && !!params[0].operation;
8
+ GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields = (fields) => {
9
+ return fields === null || fields === void 0 ? void 0 : fields.map((field) => {
10
+ if (isString(field))
11
+ return field.toString();
12
+ if (field === 'affected_rows')
13
+ return field;
14
+ const fieldName = Object.keys(field).shift();
15
+ const fieldValue = is(field[fieldName]);
16
+ if (Array.isArray(fieldValue))
17
+ return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) };
18
+ if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue))
19
+ return;
20
+ const isNestedField = !!fieldValue.fields;
21
+ if (isNestedField)
22
+ return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue);
23
+ return fieldValue.columnName;
24
+ }).filter((field) => !!field);
25
+ };
26
+ GraphQLFieldHelper.ConvertFieldValueFrom = (data, fields) => Object.keys(data).reduce((result, columnName) => {
27
+ const { attributeName, fields: attributeFields, from, } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields);
28
+ if (!!attributeFields && Array.isArray(attributeFields)) {
29
+ if (Array.isArray(data[columnName]))
30
+ return Object.assign(Object.assign({}, result), { [attributeName]: from
31
+ ? from(data[columnName], data)
32
+ : is(data[columnName]).map((value) => GraphQLFieldHelper.ConvertFieldValueFrom(is(value), attributeFields)) });
33
+ if (isObject(data[columnName]))
34
+ return Object.assign(Object.assign({}, result), { [attributeName]: !!from
35
+ ? from(data[columnName])
36
+ : GraphQLFieldHelper.ConvertFieldValueFrom(is(data[columnName]), attributeFields) });
37
+ }
38
+ if (!!from)
39
+ return Object.assign(Object.assign({}, result), { [attributeName]: from(data[columnName], data) });
40
+ return Object.assign(Object.assign({}, result), { [attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName] });
41
+ }, {});
42
+ GraphQLFieldHelper.ConvertFieldValueTo = (instance, fields, update = false) => {
43
+ var _a;
44
+ const data = ((_a = instance.toPlain) === null || _a === void 0 ? void 0 : _a.call(instance)) || instance;
45
+ return Object.keys(data).reduce((result, attributeName) => {
46
+ const { columnName, fields: attributeFields, foreignKeyColumn, to, bindPersistData, } = AttributeOptionHelper.FindByAttribute(attributeName, fields);
47
+ if (bindPersistData)
48
+ return Object.assign(Object.assign({}, result), bindPersistData(data[attributeName], instance));
49
+ if (isNil(columnName))
50
+ return result;
51
+ if (!!foreignKeyColumn &&
52
+ !isEmpty(foreignKeyColumn) &&
53
+ !Object.keys(foreignKeyColumn).filter((key) => { var _a; return !((_a = is(data[attributeName])) === null || _a === void 0 ? void 0 : _a[key]); }).length)
54
+ return Object.keys(foreignKeyColumn).reduce((object, current) => {
55
+ var _a;
56
+ const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(foreignKeyColumn[current], fields);
57
+ return Object.assign(Object.assign({}, object), { [foreignColumnName]: (_a = data[attributeName]) === null || _a === void 0 ? void 0 : _a[current] });
58
+ }, Object.assign({}, result));
59
+ if (update &&
60
+ isObject(data[attributeName]) &&
61
+ !isNil(attributeFields) &&
62
+ !isDate(data[attributeName]))
63
+ return result;
64
+ if (!!columnName &&
65
+ Array.isArray(attributeFields) &&
66
+ isObject(data[attributeName])) {
67
+ const converted = !isNil(columnName) && to
68
+ ? to(instance[attributeName], instance)
69
+ : data[attributeName];
70
+ return Object.assign(Object.assign({}, result), (converted !== undefined
71
+ ? {
72
+ [columnName]: {
73
+ data: instance[attributeName] instanceof BaseModel
74
+ ? GraphQLFieldHelper.ConvertFieldValueTo(data[attributeName], attributeFields)
75
+ : converted,
76
+ },
77
+ }
78
+ : {}));
79
+ }
80
+ if (!!to)
81
+ return Object.assign(Object.assign({}, result), { [columnName]: to(instance[attributeName], instance) });
82
+ return Object.assign(Object.assign({}, result), { [columnName]: data[attributeName] });
83
+ }, {});
84
+ };
85
+ GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields = (fieldName, fieldValue) => {
86
+ const hasCustomFilters = !!fieldValue.filters;
87
+ if (hasCustomFilters)
88
+ return {
89
+ operation: fieldValue.columnName || fieldName,
90
+ fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
91
+ variables: {
92
+ [`${fieldValue.columnName}_where`]: {
93
+ name: 'where',
94
+ type: fieldValue.filters.filterType,
95
+ value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),
96
+ required: true,
97
+ },
98
+ },
99
+ };
100
+ return {
101
+ [fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
102
+ };
103
+ };
104
+ //# sourceMappingURL=graphql-field.helper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"graphql-field.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { IOperation } from 'gql-query-builder/build/IQueryBuilderOptions'\r\nimport {\r\n BaseModel,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertiesWithNoPartial,\r\n NonFunctionAndIdentifierPropertyNames,\r\n PartialIdentifiersModel,\r\n} from '../../../../domain'\r\nimport { is, isDate, isEmpty, isNil, isObject, isString, parseDateTime } from '../../../../utils'\r\nimport { ColumnOptions, Fields, GraphQLParams, HasuraGraphQLFields } from '../../types'\r\nimport { AttributeOptionHelper } from './attribute-option.helper'\r\nimport { BindFilterQueryHelper } from './bind-filter-query.helper'\r\n\r\nexport class GraphQLFieldHelper {\r\n static CheckIsGraphQLParams = <Model extends ModelBaseStructure<Model>>(\r\n params: string | IOperation | GraphQLParams<Model>[],\r\n ): params is GraphQLParams<Model>[] =>\r\n !isString(params) && Array.isArray(params) && params.length >= 0 && !!params[0].operation\r\n\r\n static ConvertModelFieldsToGraphQLFields = <Model extends ModelBaseStructure<Model>>(\r\n fields: HasuraGraphQLFields<Model>,\r\n ): Fields => {\r\n return fields\r\n ?.map((field) => {\r\n if (isString(field)) return field.toString()\r\n if (field === 'affected_rows') return field\r\n\r\n const fieldName = Object.keys(field).shift()\r\n const fieldValue = is<ColumnOptions<any, Model>>(field[fieldName as keyof typeof field])\r\n\r\n if (Array.isArray(fieldValue))\r\n return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) }\r\n if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue)) return\r\n\r\n const isNestedField = !!fieldValue.fields\r\n\r\n if (isNestedField) return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue as any)\r\n\r\n return fieldValue.columnName\r\n })\r\n .filter((field) => !!field)\r\n }\r\n\r\n static ConvertFieldValueFrom = <\r\n Model extends ModelBaseStructure,\r\n RecordDataType extends string | number | DataType | Date,\r\n DataType extends Record<string, RecordDataType | RecordDataType[]>,\r\n >(\r\n data: DataType,\r\n fields: HasuraGraphQLFields<Model>,\r\n ): NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | PartialIdentifiersModel<Model> =>\r\n Object.keys(data).reduce((result, columnName) => {\r\n const {\r\n attributeName,\r\n fields: attributeFields,\r\n from,\r\n } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields)\r\n\r\n if (!!attributeFields && Array.isArray(attributeFields)) {\r\n if (Array.isArray(data[columnName]))\r\n return {\r\n ...result,\r\n [attributeName]: from\r\n ? from(data[columnName], data)\r\n : is<RecordDataType[]>(data[columnName]).map((value) =>\r\n GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(value), attributeFields),\r\n ),\r\n }\r\n if (isObject(data[columnName]))\r\n return {\r\n ...result,\r\n [attributeName]: !!from\r\n ? from(data[columnName])\r\n : GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(data[columnName]), attributeFields),\r\n }\r\n }\r\n\r\n if (!!from) return { ...result, [attributeName]: from(data[columnName], data) }\r\n\r\n return {\r\n ...result,\r\n [attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName],\r\n }\r\n }, {})\r\n\r\n static ConvertFieldValueTo = <\r\n Model extends ModelBaseStructure<Model>,\r\n DataType extends Record<string, string | number | DataType | Date>,\r\n >(\r\n instance: Model,\r\n fields: HasuraGraphQLFields<Model>,\r\n update = false,\r\n ): DataType => {\r\n const data: Partial<Model> = instance.toPlain?.() || instance\r\n\r\n return Object.keys(data).reduce((result, attributeName) => {\r\n const {\r\n columnName,\r\n fields: attributeFields,\r\n foreignKeyColumn,\r\n to,\r\n bindPersistData,\r\n } = AttributeOptionHelper.FindByAttribute(attributeName as NonFunctionAndIdentifierPropertyNames<Model>, fields)\r\n\r\n if (bindPersistData)\r\n return {\r\n ...result,\r\n ...bindPersistData(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>], instance),\r\n }\r\n if (isNil(columnName)) return result\r\n if (\r\n !!foreignKeyColumn &&\r\n !isEmpty(foreignKeyColumn) &&\r\n !Object.keys(foreignKeyColumn).filter(\r\n (key) =>\r\n !is<Record<string, string>>(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>])?.[key],\r\n ).length\r\n )\r\n return Object.keys(foreignKeyColumn).reduce(\r\n (object, current) => {\r\n const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(\r\n foreignKeyColumn[current as keyof HasuraGraphQLFields<Model>[number]],\r\n fields,\r\n )\r\n\r\n return {\r\n ...object,\r\n [foreignColumnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]]?.[current],\r\n }\r\n },\r\n { ...result },\r\n )\r\n\r\n if (\r\n update &&\r\n isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]]) &&\r\n !isNil(attributeFields) &&\r\n !isDate(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n )\r\n return result\r\n\r\n if (\r\n !!columnName &&\r\n Array.isArray(attributeFields) &&\r\n isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n ) {\r\n const converted =\r\n !isNil(columnName) && to\r\n ? to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance)\r\n : data[attributeName as keyof HasuraGraphQLFields<Model>[number]]\r\n\r\n return {\r\n ...result,\r\n ...(converted !== undefined\r\n ? {\r\n [columnName]: {\r\n data:\r\n instance[attributeName as NonFunctionAndIdentifierPropertyNames<Model>] instanceof BaseModel\r\n ? GraphQLFieldHelper.ConvertFieldValueTo(\r\n data[attributeName as keyof HasuraGraphQLFields<Model>[number]],\r\n attributeFields as HasuraGraphQLFields<Model>,\r\n )\r\n : converted,\r\n },\r\n }\r\n : {}),\r\n }\r\n }\r\n\r\n if (!!to)\r\n return {\r\n ...result,\r\n [columnName]: to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance),\r\n }\r\n\r\n return { ...result, [columnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]] }\r\n }, {} as DataType)\r\n }\r\n\r\n private static ConvertNestedFieldsToGraphQLFields = <\r\n T extends ModelBaseStructure<T>,\r\n P extends ModelBaseStructure<P>,\r\n >(\r\n fieldName: string,\r\n fieldValue: ColumnOptions<T, P>,\r\n ) => {\r\n const hasCustomFilters = !!fieldValue.filters\r\n\r\n if (hasCustomFilters)\r\n return {\r\n operation: fieldValue.columnName || fieldName,\r\n fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n variables: {\r\n [`${fieldValue.columnName}_where`]: {\r\n name: 'where',\r\n type: fieldValue.filters.filterType,\r\n value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),\r\n required: true,\r\n },\r\n },\r\n }\r\n\r\n return {\r\n [fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n }\r\n }\r\n}\r\n"]}
@@ -0,0 +1,5 @@
1
+ export * from './attribute-option.helper';
2
+ export * from './bind-filter-query.helper';
3
+ export * from './filter-option.helper';
4
+ export * from './graphql-field.helper';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,wBAAwB,CAAA","sourcesContent":["export * from './attribute-option.helper'\r\nexport * from './bind-filter-query.helper'\r\nexport * from './filter-option.helper'\r\nexport * from './graphql-field.helper'\r\n"]}
@@ -0,0 +1,8 @@
1
+ export * from './with-create-hasura-graphql.mixin';
2
+ export * from './with-delete-hasura-graphql.mixin';
3
+ export * from './with-hasura-graphql.mixin';
4
+ export * from './with-update-hasura-graphql.mixin';
5
+ export * from './with-get-hasura-graphql.mixin';
6
+ export * from './with-find-hasura-graphql.mixin';
7
+ export * from './with-crud-hasura-graphql.mixin';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/index.ts"],"names":[],"mappings":"AAAA,cAAc,oCAAoC,CAAA;AAClD,cAAc,oCAAoC,CAAA;AAClD,cAAc,6BAA6B,CAAA;AAC3C,cAAc,oCAAoC,CAAA;AAClD,cAAc,iCAAiC,CAAA;AAC/C,cAAc,kCAAkC,CAAA;AAChD,cAAc,kCAAkC,CAAA","sourcesContent":["export * from './with-create-hasura-graphql.mixin'\r\nexport * from './with-delete-hasura-graphql.mixin'\r\nexport * from './with-hasura-graphql.mixin'\r\nexport * from './with-update-hasura-graphql.mixin'\r\nexport * from './with-get-hasura-graphql.mixin'\r\nexport * from './with-find-hasura-graphql.mixin'\r\nexport * from './with-crud-hasura-graphql.mixin'\r\n"]}
@@ -1,7 +1,7 @@
1
1
  import { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../domain';
2
2
  import { MergeConstructorParams, MixinCtor } from '../../../utils';
3
3
  import { GraphQLRepository } from '../types';
4
- export type CreateConstructorParams = {
4
+ export declare type CreateConstructorParams = {
5
5
  insertGraphQLOperation?: string;
6
6
  insertAllGraphQLOperation?: string;
7
7
  insertGraphQLObjectType?: string;
@@ -0,0 +1,41 @@
1
+ import { DebugHelper } from '../../../utils';
2
+ import { AttributeOptionHelper } from './helpers';
3
+ export const withCreateHasuraGraphQL = (MixinBase) => {
4
+ return class CreateHasuraGraphQLMixin extends MixinBase {
5
+ constructor(...params) {
6
+ const options = params === null || params === void 0 ? void 0 : params[0];
7
+ super(...params);
8
+ this.insertGraphQLOperation = (options === null || options === void 0 ? void 0 : options.insertGraphQLOperation) || `insert_${this.tableName}_one`;
9
+ this.insertGraphQLObjectType = (options === null || options === void 0 ? void 0 : options.insertGraphQLObjectType) || `${this.tableName}_insert_input`;
10
+ }
11
+ async create(data) {
12
+ this.logger = DebugHelper.from(this, 'create');
13
+ const newData = await this.save(this.model.toInstance(data));
14
+ return this.model.toInstance(newData);
15
+ }
16
+ async save(data) {
17
+ const primaryKeyColumns = this.model.identifiersFields.map((field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName);
18
+ const foreignKeyColumns = this.fields
19
+ .map((field) => {
20
+ const columnOptions = Object.values(field).shift();
21
+ return (AttributeOptionHelper.CheckIsColumnOption(columnOptions) &&
22
+ columnOptions.foreignKeyColumn && [
23
+ ...Object.values(columnOptions.foreignKeyColumn).map((foreignKeyName) => { var _a; return (_a = AttributeOptionHelper.FindByAttribute(foreignKeyName, this.fields)) === null || _a === void 0 ? void 0 : _a.columnName; }),
24
+ {
25
+ [columnOptions.columnName]: Object.keys(columnOptions.foreignKeyColumn).map((foreignKeyField) => {
26
+ var _a;
27
+ return ((_a = AttributeOptionHelper.FindByAttribute(foreignKeyField, columnOptions === null || columnOptions === void 0 ? void 0 : columnOptions.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || foreignKeyField;
28
+ }),
29
+ },
30
+ ]);
31
+ })
32
+ .filter(Boolean)
33
+ .reduce((keys, current) => [...keys, ...current], []);
34
+ const result = await this.mutation(this.insertGraphQLOperation, [...primaryKeyColumns, ...foreignKeyColumns], {
35
+ object: { type: this.insertGraphQLObjectType, required: true, value: this.convertDataToHasura(data) },
36
+ });
37
+ return Object.assign(Object.assign({}, data.toPlain()), this.convertDataFromHasura(result[this.insertGraphQLOperation]).toPlain());
38
+ }
39
+ };
40
+ };
41
+ //# sourceMappingURL=with-create-hasura-graphql.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-create-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../domain'\r\nimport { DebugHelper, MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository, HasuraGraphQLFields } from '../types'\r\n\r\nimport { AttributeOptionHelper } from './helpers'\r\n\r\nexport type CreateConstructorParams = {\r\n insertGraphQLOperation?: string\r\n insertAllGraphQLOperation?: string\r\n insertGraphQLObjectType?: string\r\n}\r\n\r\nexport const withCreateHasuraGraphQL = <\r\n MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\r\n TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<MBase> & InstanceType<TMixinBase> & CreateRepository<MBase>,\r\n MergeConstructorParams<[CreateConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>\r\n> => {\r\n return class CreateHasuraGraphQLMixin extends MixinBase implements CreateRepository<MBase> {\r\n insertGraphQLOperation: string\r\n insertGraphQLObjectType: string\r\n\r\n constructor(...params: any[]) {\r\n const options: CreateConstructorParams = params?.[0]\r\n\r\n super(...params)\r\n\r\n this.insertGraphQLOperation = options?.insertGraphQLOperation || `insert_${this.tableName}_one`\r\n this.insertGraphQLObjectType = options?.insertGraphQLObjectType || `${this.tableName}_insert_input`\r\n }\r\n\r\n async create(data: CreateRepositoryParams<MBase>): Promise<MBase> {\r\n this.logger = DebugHelper.from(this, 'create')\r\n\r\n const newData = await this.save(this.model.toInstance(data))\r\n\r\n return this.model.toInstance(newData)\r\n }\r\n\r\n async save(data: MBase): Promise<Partial<MBase>> {\r\n const primaryKeyColumns = this.model.identifiersFields.map(\r\n (field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName,\r\n ) as HasuraGraphQLFields<MBase>\r\n const foreignKeyColumns = this.fields\r\n .map((field) => {\r\n const columnOptions = Object.values(field).shift()\r\n\r\n return (\r\n AttributeOptionHelper.CheckIsColumnOption(columnOptions) &&\r\n columnOptions.foreignKeyColumn && [\r\n ...Object.values(columnOptions.foreignKeyColumn).map(\r\n (foreignKeyName) =>\r\n AttributeOptionHelper.FindByAttribute(foreignKeyName as any, this.fields)?.columnName,\r\n ),\r\n {\r\n [columnOptions.columnName]: Object.keys(columnOptions.foreignKeyColumn).map(\r\n (foreignKeyField) =>\r\n AttributeOptionHelper.FindByAttribute(foreignKeyField as any, columnOptions?.fields as any)\r\n ?.columnName || foreignKeyField,\r\n ),\r\n },\r\n ]\r\n )\r\n })\r\n .filter(Boolean)\r\n .reduce((keys, current) => [...keys, ...current], [])\r\n\r\n const result = await this.mutation<Record<string, Record<string, any>>>(\r\n this.insertGraphQLOperation,\r\n [...primaryKeyColumns, ...foreignKeyColumns] as HasuraGraphQLFields<MBase>,\r\n {\r\n object: { type: this.insertGraphQLObjectType, required: true, value: this.convertDataToHasura(data) },\r\n },\r\n )\r\n\r\n return { ...data.toPlain(), ...this.convertDataFromHasura(result[this.insertGraphQLOperation]).toPlain() }\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,10 @@
1
+ import { withCreateHasuraGraphQL } from './with-create-hasura-graphql.mixin';
2
+ import { withDeleteHasuraGraphQL } from './with-delete-hasura-graphql.mixin';
3
+ import { withFindHasuraGraphQL } from './with-find-hasura-graphql.mixin';
4
+ import { withGetHasuraGraphQL } from './with-get-hasura-graphql.mixin';
5
+ import { withUpdateHasuraGraphQL, } from './with-update-hasura-graphql.mixin';
6
+ export const withCrudHasuraGraphQL = (MixinBase) => {
7
+ return class CrudHasuraGraphQLMixin extends withUpdateHasuraGraphQL(withGetHasuraGraphQL(withFindHasuraGraphQL(withDeleteHasuraGraphQL(withCreateHasuraGraphQL(MixinBase))))) {
8
+ };
9
+ };
10
+ //# sourceMappingURL=with-crud-hasura-graphql.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-crud-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.ts"],"names":[],"mappings":"AAIA,OAAO,EAA2B,uBAAuB,EAAE,MAAM,oCAAoC,CAAA;AACrG,OAAO,EAA2B,uBAAuB,EAAE,MAAM,oCAAoC,CAAA;AACrG,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AACxE,OAAO,EAAwB,oBAAoB,EAAE,MAAM,iCAAiC,CAAA;AAE5F,OAAO,EAGL,uBAAuB,GACxB,MAAM,oCAAoC,CAAA;AAE3C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAKnC,SAA2D,EAc3D,EAAE;IACF,OAAO,MAAM,sBACX,SAAQ,uBAAuB,CAC7B,oBAAoB,CAClB,qBAAqB,CACnB,uBAAuB,CAAC,uBAAuB,CAAC,SAAgD,CAAC,CAAC,CACnG,CACF,CACF;KACyC,CAAA;AAC9C,CAAC,CAAA","sourcesContent":["import { CrudRepository, ModelBaseStructure } from '../../../domain'\r\nimport { MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository } from '../types'\r\n\r\nimport { CreateConstructorParams, withCreateHasuraGraphQL } from './with-create-hasura-graphql.mixin'\r\nimport { DeleteConstructorParams, withDeleteHasuraGraphQL } from './with-delete-hasura-graphql.mixin'\r\nimport { withFindHasuraGraphQL } from './with-find-hasura-graphql.mixin'\r\nimport { GetConstructorParams, withGetHasuraGraphQL } from './with-get-hasura-graphql.mixin'\r\nimport { HasuraConstructorParams } from './with-hasura-graphql.mixin'\r\nimport {\r\n UpdateConstructorParams,\r\n UpdateHasuraGraphQLRepositoryType,\r\n withUpdateHasuraGraphQL,\r\n} from './with-update-hasura-graphql.mixin'\r\n\r\nexport const withCrudHasuraGraphQL = <\r\n TBase extends ModelBaseStructure<TBase, TBase['identifiersFields'][number]>,\r\n Repository = CrudRepository<TBase>,\r\n TMixinBase extends MixinCtor = MixinCtor,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<TBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<TBase> & Repository & UpdateHasuraGraphQLRepositoryType<TBase>,\r\n MergeConstructorParams<\r\n [\r\n HasuraConstructorParams<TBase> &\r\n CreateConstructorParams &\r\n DeleteConstructorParams &\r\n GetConstructorParams &\r\n UpdateConstructorParams,\r\n ...any[],\r\n ],\r\n ConstructorParameters<TMixinBase>\r\n >\r\n> => {\r\n return class CrudHasuraGraphQLMixin\r\n extends withUpdateHasuraGraphQL(\r\n withGetHasuraGraphQL(\r\n withFindHasuraGraphQL(\r\n withDeleteHasuraGraphQL(withCreateHasuraGraphQL(MixinBase as MixinCtor<GraphQLRepository<TBase>>)),\r\n ),\r\n ),\r\n )\r\n implements CrudRepository<TBase> {} as any\r\n}\r\n"]}
@@ -1,7 +1,7 @@
1
1
  import { DeleteRepository, DeleteRepositoryParams, ModelBaseStructure } from '../../../domain';
2
2
  import { MergeConstructorParams, MixinCtor } from '../../../utils';
3
3
  import { GraphQLRepository } from '../types';
4
- export type DeleteConstructorParams = {
4
+ export declare type DeleteConstructorParams = {
5
5
  deleteGraphQLOperation?: string;
6
6
  };
7
7
  export declare const withDeleteHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>, any[]>>(MixinBase: MixinCtor<GraphQLRepository<MBase>, any[]> & TMixinBase) => MixinCtor<GraphQLRepository<MBase> & DeleteRepository<MBase, DeleteRepositoryParams<MBase>> & InstanceType<TMixinBase>, MergeConstructorParams<[DeleteConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>>;
@@ -0,0 +1,28 @@
1
+ import { DebugHelper, isNil } from '../../../utils';
2
+ import { AttributeOptionHelper } from './helpers';
3
+ export const withDeleteHasuraGraphQL = (MixinBase) => {
4
+ return class DeleteHasuraGraphQLMixin extends MixinBase {
5
+ constructor(...params) {
6
+ const options = params === null || params === void 0 ? void 0 : params[0];
7
+ super(...params);
8
+ this.deleteGraphQLOperation = (options === null || options === void 0 ? void 0 : options.deleteGraphQLOperation) || `delete_${this.tableName}_by_pk`;
9
+ }
10
+ async delete(identifiers) {
11
+ this.logger = DebugHelper.from(this, 'delete');
12
+ const instance = this.model.toInstance(identifiers);
13
+ await this.mutation(this.deleteGraphQLOperation, this.model.identifiersFields.map((field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName), this.model.identifiersFields.reduce((ids, identifier) => {
14
+ const identifierBinded = identifier;
15
+ if (isNil(instance.identifier[identifierBinded]))
16
+ return ids;
17
+ const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields);
18
+ const value = columnOption.to(identifiers[identifier], instance);
19
+ return Object.assign(Object.assign({}, ids), { [columnOption.columnName]: {
20
+ type: this.getAttributeGraphQLTypeOf(columnOption.type || value),
21
+ value,
22
+ required: true,
23
+ } });
24
+ }, {}));
25
+ }
26
+ };
27
+ };
28
+ //# sourceMappingURL=with-delete-hasura-graphql.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-delete-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,KAAK,EAAqC,MAAM,gBAAgB,CAAA;AAGtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAMjD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAIrC,SAA2D,EAI3D,EAAE;IACF,OAAO,MAAM,wBAAyB,SAAQ,SAAS;QAGrD,YAAY,GAAG,MAAa;YAC1B,MAAM,OAAO,GAA4B,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,CAAC,CAAC,CAAA;YAEpD,KAAK,CAAC,GAAG,MAAM,CAAC,CAAA;YAEhB,IAAI,CAAC,sBAAsB,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,sBAAsB,KAAI,UAAU,IAAI,CAAC,SAAS,QAAQ,CAAA;QACnG,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,WAA0C;YACrD,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;YAE9C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;YAEnD,MAAM,IAAI,CAAC,QAAQ,CACjB,IAAI,CAAC,sBAAsB,EAC3B,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,CAC9B,CAAC,KAAK,EAAE,EAAE,CAAC,qBAAqB,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,UAAU,CAClD,EAC/B,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE;gBACtD,MAAM,gBAAgB,GAGlB,UAAU,CAAA;gBAEd,IAAI,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;oBAAE,OAAO,GAAG,CAAA;gBAE5D,MAAM,YAAY,GAAG,qBAAqB,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;gBACnF,MAAM,KAAK,GAAG,YAAY,CAAC,EAAE,CAAC,WAAW,CAAC,UAAiD,CAAC,EAAE,QAAQ,CAAC,CAAA;gBAEvG,uCACK,GAAG,KACN,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE;wBACzB,IAAI,EAAE,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,IAAI,IAAI,KAAK,CAAC;wBAChE,KAAK;wBACL,QAAQ,EAAE,IAAI;qBACf,IACF;YACH,CAAC,EAAE,EAAE,CAAC,CACP,CAAA;QACH,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import {\r\n DeleteRepository,\r\n DeleteRepositoryParams,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n} from '../../../domain'\r\nimport { DebugHelper, isNil, MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository, HasuraGraphQLFields } from '../types'\r\n\r\nimport { AttributeOptionHelper } from './helpers'\r\n\r\nexport type DeleteConstructorParams = {\r\n deleteGraphQLOperation?: string\r\n}\r\n\r\nexport const withDeleteHasuraGraphQL = <\r\n MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\r\n TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<MBase> & DeleteRepository<MBase> & InstanceType<TMixinBase>,\r\n MergeConstructorParams<[DeleteConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>\r\n> => {\r\n return class DeleteHasuraGraphQLMixin extends MixinBase implements DeleteRepository<MBase> {\r\n deleteGraphQLOperation: string\r\n\r\n constructor(...params: any[]) {\r\n const options: DeleteConstructorParams = params?.[0]\r\n\r\n super(...params)\r\n\r\n this.deleteGraphQLOperation = options?.deleteGraphQLOperation || `delete_${this.tableName}_by_pk`\r\n }\r\n\r\n async delete(identifiers: DeleteRepositoryParams<MBase>): Promise<void> {\r\n this.logger = DebugHelper.from(this, 'delete')\r\n\r\n const instance = this.model.toInstance(identifiers)\r\n\r\n await this.mutation(\r\n this.deleteGraphQLOperation,\r\n this.model.identifiersFields.map(\r\n (field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName,\r\n ) as HasuraGraphQLFields<MBase>,\r\n this.model.identifiersFields.reduce((ids, identifier) => {\r\n const identifierBinded: Extract<\r\n NonFunctionAndIdentifierPropertyNames<MBase>,\r\n MBase['identifiersFields'][number]\r\n > = identifier\r\n\r\n if (isNil(instance.identifier[identifierBinded])) return ids\r\n\r\n const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields)\r\n const value = columnOption.to(identifiers[identifier as keyof DeleteRepositoryParams<MBase>], instance)\r\n\r\n return {\r\n ...ids,\r\n [columnOption.columnName]: {\r\n type: this.getAttributeGraphQLTypeOf(columnOption.type || value),\r\n value,\r\n required: true,\r\n },\r\n }\r\n }, {}),\r\n )\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,143 @@
1
+ import { DebugHelper, isNil, set } from '../../../utils';
2
+ import { AttributeOptionHelper, BindFilterQueryHelper } from './helpers';
3
+ export const withFindHasuraGraphQL = (MixinBase) => {
4
+ return class FindHasuraGraphQLMixin extends MixinBase {
5
+ constructor() {
6
+ super(...arguments);
7
+ this.bindOrderByAttributes = (orderBy, fields) => Object.keys(orderBy).reduce((acc, current) => [
8
+ ...acc,
9
+ {
10
+ [AttributeOptionHelper.FindByAttribute(current, fields)
11
+ .columnName]: orderBy[current] === 'asc'
12
+ ? 'asc_nulls_last'
13
+ : 'desc_nulls_last',
14
+ },
15
+ ], []);
16
+ this.bindAggretageAttributes = (aggregates, fields) => {
17
+ var _a, _b;
18
+ return [
19
+ ...(((_a = aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal) === null || _a === void 0 ? void 0 : _a.length)
20
+ ? [
21
+ {
22
+ min: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal, fields),
23
+ },
24
+ ]
25
+ : []),
26
+ ...(((_b = aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum) === null || _b === void 0 ? void 0 : _b.length)
27
+ ? [
28
+ {
29
+ max: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum, fields),
30
+ },
31
+ ]
32
+ : []),
33
+ ];
34
+ };
35
+ this.bindDistinctAttributes = (distinct, fields) => this.bindAttributesToColumns(distinct, fields);
36
+ this.bindAttributesToColumns = (attributes, fields) => attributes.map((attr) => {
37
+ var _a;
38
+ return ((_a = AttributeOptionHelper.FindByAttribute(attr.toString().split('.').pop(), fields)) === null || _a === void 0 ? void 0 : _a.columnName) || attr;
39
+ });
40
+ }
41
+ async find(params) {
42
+ var _a, _b, _c, _d, _e, _f, _g, _h;
43
+ this.logger = DebugHelper.from(this, 'find');
44
+ const { filters, limits, orderBy, options } = params || {};
45
+ const enableCount = (_a = options === null || options === void 0 ? void 0 : options.enableCount) !== null && _a !== void 0 ? _a : true;
46
+ const variablesFilters = isNil(filters)
47
+ ? {}
48
+ : {
49
+ where: {
50
+ value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),
51
+ type: `${this.tableName}_bool_exp`,
52
+ required: true,
53
+ },
54
+ };
55
+ const variablesCount = Object.assign(Object.assign({}, (isNil(orderBy)
56
+ ? {}
57
+ : {
58
+ order_by: {
59
+ type: `${this.tableName}_order_by!`,
60
+ list: true,
61
+ value: this.bindOrderByAttributes(orderBy, this.fields),
62
+ },
63
+ })), variablesFilters);
64
+ const variables = Object.assign(Object.assign({}, (isNil(limits) ? {} : limits)), variablesCount);
65
+ const aggregateFields = [
66
+ ...(enableCount ? ['count'] : []),
67
+ ...this.bindAggretageAttributes(params.options, this.fields),
68
+ ];
69
+ const result = await this.query([
70
+ {
71
+ operation: this.tableName,
72
+ fields: params.fields
73
+ ? params.fields
74
+ .map((fieldName) => {
75
+ var _a;
76
+ return (_a = this.fields.find((fieldOption) => fieldOption === fieldName)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName);
77
+ })
78
+ .filter(Boolean)
79
+ : this.fields,
80
+ variables,
81
+ },
82
+ ...(aggregateFields.length > 0
83
+ ? [
84
+ {
85
+ operation: `${this.tableName}_aggregate`,
86
+ fields: [
87
+ {
88
+ aggregate: aggregateFields,
89
+ },
90
+ ],
91
+ variables: variablesCount,
92
+ },
93
+ ]
94
+ : []),
95
+ ...((!((_b = params.limits) === null || _b === void 0 ? void 0 : _b.offset) &&
96
+ ((_d = (_c = params.options) === null || _c === void 0 ? void 0 : _c.distinct) === null || _d === void 0 ? void 0 : _d.map((distinct) => {
97
+ var _a, _b;
98
+ const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === distinct)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct);
99
+ const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || distinct;
100
+ return {
101
+ operation: {
102
+ name: `${this.tableName}`,
103
+ alias: `${this.tableName}_${distinct.toString()}_distinct`,
104
+ },
105
+ fields: [distinctOption],
106
+ variables: Object.assign(Object.assign({}, variablesFilters), { [`${this.tableName}_${fieldName}_distinct`]: {
107
+ type: `${this.tableName}_select_column!`,
108
+ list: true,
109
+ value: fieldName,
110
+ name: 'distinct_on',
111
+ } }),
112
+ };
113
+ }))) ||
114
+ []),
115
+ ]);
116
+ const data = result[this.tableName].map((row) => this.convertDataFromHasura(row));
117
+ return Object.assign(Object.assign(Object.assign({ data, count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity }, (((_e = options === null || options === void 0 ? void 0 : options.minimal) === null || _e === void 0 ? void 0 : _e.length)
118
+ ? {
119
+ minimal: options.minimal.reduce((minimals, current) => {
120
+ var _a;
121
+ return (Object.assign(Object.assign({}, minimals), set(minimals, current, result[`${this.tableName}_aggregate`].aggregate.min[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
122
+ }, {}),
123
+ }
124
+ : {})), (((_f = options === null || options === void 0 ? void 0 : options.maximum) === null || _f === void 0 ? void 0 : _f.length)
125
+ ? {
126
+ maximum: options.maximum.reduce((maximums, current) => {
127
+ var _a;
128
+ return (Object.assign(Object.assign({}, maximums), set(maximums, current, result[`${this.tableName}_aggregate`].aggregate.max[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
129
+ }, {}),
130
+ }
131
+ : {})), (!((_g = params.limits) === null || _g === void 0 ? void 0 : _g.offset) &&
132
+ ((_h = options === null || options === void 0 ? void 0 : options.distinct) === null || _h === void 0 ? void 0 : _h.length) && {
133
+ distinct: options === null || options === void 0 ? void 0 : options.distinct.reduce((distinct, current) => {
134
+ var _a, _b;
135
+ const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === current)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current);
136
+ const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || current;
137
+ return Object.assign(Object.assign({}, distinct), { [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map((obj) => obj[fieldName]) });
138
+ }, {}),
139
+ }));
140
+ }
141
+ };
142
+ };
143
+ //# sourceMappingURL=with-find-hasura-graphql.mixin.js.map