@infrab4a/connect 4.0.2-beta.4 → 4.0.2-beta.5

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 (1018) hide show
  1. package/index.d.ts +1 -0
  2. package/index.js +2 -5154
  3. package/index.js.map +1 -0
  4. package/package.json +36 -29
  5. package/src/domain/catalog/helpers/index.d.ts +1 -0
  6. package/src/domain/catalog/helpers/index.js +2 -0
  7. package/src/domain/catalog/helpers/index.js.map +1 -0
  8. package/src/domain/catalog/helpers/round-product-price.helper.d.ts +4 -0
  9. package/src/domain/catalog/helpers/round-product-price.helper.js +15 -0
  10. package/src/domain/catalog/helpers/round-product-price.helper.js.map +1 -0
  11. package/src/domain/catalog/index.d.ts +3 -0
  12. package/src/domain/catalog/index.js +4 -0
  13. package/src/domain/catalog/index.js.map +1 -0
  14. package/src/domain/catalog/models/category-base.d.ts +30 -0
  15. package/src/domain/catalog/models/category-base.js +18 -0
  16. package/src/domain/catalog/models/category-base.js.map +1 -0
  17. package/src/domain/catalog/models/category-collection-children.d.ts +13 -0
  18. package/src/domain/catalog/models/category-collection-children.js +13 -0
  19. package/src/domain/catalog/models/category-collection-children.js.map +1 -0
  20. package/src/domain/catalog/models/category-filter.d.ts +13 -0
  21. package/src/domain/catalog/models/category-filter.js +19 -0
  22. package/src/domain/catalog/models/category-filter.js.map +1 -0
  23. package/src/domain/catalog/models/category-for-product.d.ts +5 -0
  24. package/src/domain/catalog/models/category-for-product.js +7 -0
  25. package/src/domain/catalog/models/category-for-product.js.map +1 -0
  26. package/src/domain/catalog/models/category.d.ts +7 -0
  27. package/src/domain/catalog/models/category.js +14 -0
  28. package/src/domain/catalog/models/category.js.map +1 -0
  29. package/src/domain/catalog/models/enums/index.d.ts +2 -0
  30. package/src/domain/catalog/models/enums/index.js +3 -0
  31. package/src/domain/catalog/models/enums/index.js.map +1 -0
  32. package/src/domain/catalog/models/enums/product-genders.enum.d.ts +5 -0
  33. package/src/domain/catalog/models/enums/product-genders.enum.js +7 -0
  34. package/src/domain/catalog/models/enums/product-genders.enum.js.map +1 -0
  35. package/src/domain/catalog/models/enums/shops.enum.d.ts +6 -0
  36. package/src/domain/catalog/models/enums/shops.enum.js +8 -0
  37. package/src/domain/catalog/models/enums/shops.enum.js.map +1 -0
  38. package/src/domain/catalog/models/filter-option.d.ts +9 -0
  39. package/src/domain/catalog/models/filter-option.js +7 -0
  40. package/src/domain/catalog/models/filter-option.js.map +1 -0
  41. package/src/domain/catalog/models/filter.d.ts +12 -0
  42. package/src/domain/catalog/models/filter.js +7 -0
  43. package/src/domain/catalog/models/filter.js.map +1 -0
  44. package/src/domain/catalog/models/index.d.ts +11 -0
  45. package/src/domain/catalog/models/index.js +12 -0
  46. package/src/domain/catalog/models/index.js.map +1 -0
  47. package/src/domain/catalog/models/kit-product.d.ts +12 -0
  48. package/src/domain/catalog/models/kit-product.js +18 -0
  49. package/src/domain/catalog/models/kit-product.js.map +1 -0
  50. package/src/domain/catalog/models/product-base.d.ts +40 -0
  51. package/src/domain/catalog/models/product-base.js +25 -0
  52. package/src/domain/catalog/models/product-base.js.map +1 -0
  53. package/src/domain/catalog/models/product-for-category.d.ts +7 -0
  54. package/src/domain/catalog/models/product-for-category.js +14 -0
  55. package/src/domain/catalog/models/product-for-category.js.map +1 -0
  56. package/src/domain/catalog/models/product-for-kit.d.ts +7 -0
  57. package/src/domain/catalog/models/product-for-kit.js +14 -0
  58. package/src/domain/catalog/models/product-for-kit.js.map +1 -0
  59. package/src/domain/catalog/models/product.d.ts +9 -0
  60. package/src/domain/catalog/models/product.js +19 -0
  61. package/src/domain/catalog/models/product.js.map +1 -0
  62. package/src/domain/catalog/models/types/category-condition.type.d.ts +4 -0
  63. package/src/domain/catalog/models/types/category-condition.type.js +2 -0
  64. package/src/domain/catalog/models/types/category-condition.type.js.map +1 -0
  65. package/src/domain/catalog/models/types/category-metadata.type.d.ts +4 -0
  66. package/src/domain/catalog/models/types/category-metadata.type.js +2 -0
  67. package/src/domain/catalog/models/types/category-metadata.type.js.map +1 -0
  68. package/src/domain/catalog/models/types/category-product.d.ts +4 -0
  69. package/src/domain/catalog/models/types/category-product.js +2 -0
  70. package/src/domain/catalog/models/types/category-product.js.map +1 -0
  71. package/src/domain/catalog/models/types/index.d.ts +11 -0
  72. package/src/domain/catalog/models/types/index.js +12 -0
  73. package/src/domain/catalog/models/types/index.js.map +1 -0
  74. package/src/domain/catalog/models/types/product-evaluation.type.d.ts +6 -0
  75. package/src/domain/catalog/models/types/product-evaluation.type.js +2 -0
  76. package/src/domain/catalog/models/types/product-evaluation.type.js.map +1 -0
  77. package/src/domain/catalog/models/types/product-gender.type.d.ts +1 -0
  78. package/src/domain/catalog/models/types/product-gender.type.js +2 -0
  79. package/src/domain/catalog/models/types/product-gender.type.js.map +1 -0
  80. package/src/domain/catalog/models/types/product-metadata.type.d.ts +4 -0
  81. package/src/domain/catalog/models/types/product-metadata.type.js +2 -0
  82. package/src/domain/catalog/models/types/product-metadata.type.js.map +1 -0
  83. package/src/domain/catalog/models/types/product-review.type.d.ts +17 -0
  84. package/src/domain/catalog/models/types/product-review.type.js +2 -0
  85. package/src/domain/catalog/models/types/product-review.type.js.map +1 -0
  86. package/src/domain/catalog/models/types/shop-description.type.d.ts +8 -0
  87. package/src/domain/catalog/models/types/shop-description.type.js +2 -0
  88. package/src/domain/catalog/models/types/shop-description.type.js.map +1 -0
  89. package/src/domain/catalog/models/types/shop-price.type.d.ts +6 -0
  90. package/src/domain/catalog/models/types/shop-price.type.js +2 -0
  91. package/src/domain/catalog/models/types/shop-price.type.js.map +1 -0
  92. package/src/domain/catalog/models/types/stock.type.d.ts +3 -0
  93. package/src/domain/catalog/models/types/stock.type.js +2 -0
  94. package/src/domain/catalog/models/types/stock.type.js.map +1 -0
  95. package/src/domain/catalog/models/types/variant-grade.type.d.ts +4 -0
  96. package/src/domain/catalog/models/types/variant-grade.type.js +2 -0
  97. package/src/domain/catalog/models/types/variant-grade.type.js.map +1 -0
  98. package/src/domain/catalog/models/variant.d.ts +17 -0
  99. package/src/domain/catalog/models/variant.js +7 -0
  100. package/src/domain/catalog/models/variant.js.map +1 -0
  101. package/src/domain/catalog/models/wishlist.d.ts +6 -0
  102. package/src/domain/catalog/models/wishlist.js +7 -0
  103. package/src/domain/catalog/models/wishlist.js.map +1 -0
  104. package/src/domain/catalog/repositories/category-collection-children.repository.d.ts +4 -0
  105. package/src/domain/catalog/repositories/category-collection-children.repository.js +2 -0
  106. package/src/domain/catalog/repositories/category-collection-children.repository.js.map +1 -0
  107. package/src/domain/catalog/repositories/category-filter.repository.d.ts +6 -0
  108. package/src/domain/catalog/repositories/category-filter.repository.js +2 -0
  109. package/src/domain/catalog/repositories/category-filter.repository.js.map +1 -0
  110. package/src/domain/catalog/repositories/category.repository.d.ts +18 -0
  111. package/src/domain/catalog/repositories/category.repository.js +2 -0
  112. package/src/domain/catalog/repositories/category.repository.js.map +1 -0
  113. package/src/domain/catalog/repositories/filter-option.repository.d.ts +4 -0
  114. package/src/domain/catalog/repositories/filter-option.repository.js +2 -0
  115. package/src/domain/catalog/repositories/filter-option.repository.js.map +1 -0
  116. package/src/domain/catalog/repositories/filter.repository.d.ts +4 -0
  117. package/src/domain/catalog/repositories/filter.repository.js +2 -0
  118. package/src/domain/catalog/repositories/filter.repository.js.map +1 -0
  119. package/src/domain/catalog/repositories/index.d.ts +9 -0
  120. package/src/domain/catalog/repositories/index.js +10 -0
  121. package/src/domain/catalog/repositories/index.js.map +1 -0
  122. package/src/domain/catalog/repositories/product.repository.d.ts +15 -0
  123. package/src/domain/catalog/repositories/product.repository.js +2 -0
  124. package/src/domain/catalog/repositories/product.repository.js.map +1 -0
  125. package/src/domain/catalog/repositories/subscription-product.repository.d.ts +4 -0
  126. package/src/domain/catalog/repositories/subscription-product.repository.js +2 -0
  127. package/src/domain/catalog/repositories/subscription-product.repository.js.map +1 -0
  128. package/src/domain/catalog/repositories/variant.repository.d.ts +4 -0
  129. package/src/domain/catalog/repositories/variant.repository.js +2 -0
  130. package/src/domain/catalog/repositories/variant.repository.js.map +1 -0
  131. package/src/domain/catalog/repositories/wishlist.repository.d.ts +6 -0
  132. package/src/domain/catalog/repositories/wishlist.repository.js +2 -0
  133. package/src/domain/catalog/repositories/wishlist.repository.js.map +1 -0
  134. package/src/domain/generic/index.d.ts +2 -0
  135. package/src/domain/generic/index.js +3 -0
  136. package/src/domain/generic/index.js.map +1 -0
  137. package/src/domain/generic/model/base.model.d.ts +14 -0
  138. package/src/domain/generic/model/base.model.js +24 -0
  139. package/src/domain/generic/model/base.model.js.map +1 -0
  140. package/src/domain/generic/model/identifier-fields.d.ts +4 -0
  141. package/src/domain/generic/model/identifier-fields.js +2 -0
  142. package/src/domain/generic/model/identifier-fields.js.map +1 -0
  143. package/src/domain/generic/model/index.d.ts +3 -0
  144. package/src/domain/generic/model/index.js +4 -0
  145. package/src/domain/generic/model/index.js.map +1 -0
  146. package/src/domain/generic/model/types/base-model-builder.type.d.ts +17 -0
  147. package/src/domain/generic/model/types/base-model-builder.type.js +2 -0
  148. package/src/domain/generic/model/types/base-model-builder.type.js.map +1 -0
  149. package/src/domain/generic/model/types/identifier-model.type.d.ts +8 -0
  150. package/src/domain/generic/model/types/identifier-model.type.js +2 -0
  151. package/src/domain/generic/model/types/identifier-model.type.js.map +1 -0
  152. package/src/domain/generic/model/types/index.d.ts +5 -0
  153. package/src/domain/generic/model/types/index.js +6 -0
  154. package/src/domain/generic/model/types/index.js.map +1 -0
  155. package/src/domain/generic/model/types/model-base-structure.type.d.ts +12 -0
  156. package/src/domain/generic/model/types/model-base-structure.type.js +2 -0
  157. package/src/domain/generic/model/types/model-base-structure.type.js.map +1 -0
  158. package/src/domain/generic/model/types/non-function-properties.type.d.ts +12 -0
  159. package/src/domain/generic/model/types/non-function-properties.type.js +2 -0
  160. package/src/domain/generic/model/types/non-function-properties.type.js.map +1 -0
  161. package/src/domain/generic/model/types/non-function-property-name.type.d.ts +13 -0
  162. package/src/domain/generic/model/types/non-function-property-name.type.js +2 -0
  163. package/src/domain/generic/model/types/non-function-property-name.type.js.map +1 -0
  164. package/src/domain/generic/repository/create.repository.d.ts +8 -0
  165. package/src/domain/generic/repository/create.repository.js +2 -0
  166. package/src/domain/generic/repository/create.repository.js.map +1 -0
  167. package/src/domain/generic/repository/crud.repository.d.ts +19 -0
  168. package/src/domain/generic/repository/crud.repository.js +2 -0
  169. package/src/domain/generic/repository/crud.repository.js.map +1 -0
  170. package/src/domain/generic/repository/delete.repository.d.ts +7 -0
  171. package/src/domain/generic/repository/delete.repository.js +2 -0
  172. package/src/domain/generic/repository/delete.repository.js.map +1 -0
  173. package/src/domain/generic/repository/enums/index.d.ts +2 -0
  174. package/src/domain/generic/repository/enums/index.js +3 -0
  175. package/src/domain/generic/repository/enums/index.js.map +1 -0
  176. package/src/domain/generic/repository/enums/update-option-actions.enum.d.ts +7 -0
  177. package/src/domain/generic/repository/enums/update-option-actions.enum.js +9 -0
  178. package/src/domain/generic/repository/enums/update-option-actions.enum.js.map +1 -0
  179. package/src/domain/generic/repository/enums/where.enum.d.ts +14 -0
  180. package/src/domain/generic/repository/enums/where.enum.js +16 -0
  181. package/src/domain/generic/repository/enums/where.enum.js.map +1 -0
  182. package/src/domain/generic/repository/find.repository.d.ts +17 -0
  183. package/src/domain/generic/repository/find.repository.js +2 -0
  184. package/src/domain/generic/repository/find.repository.js.map +1 -0
  185. package/src/domain/generic/repository/get.repository.d.ts +5 -0
  186. package/src/domain/generic/repository/get.repository.js +2 -0
  187. package/src/domain/generic/repository/get.repository.js.map +1 -0
  188. package/src/domain/generic/repository/index.d.ts +9 -0
  189. package/src/domain/generic/repository/index.js +10 -0
  190. package/src/domain/generic/repository/index.js.map +1 -0
  191. package/src/domain/generic/repository/read.repository.d.ts +14 -0
  192. package/src/domain/generic/repository/read.repository.js +2 -0
  193. package/src/domain/generic/repository/read.repository.js.map +1 -0
  194. package/src/domain/generic/repository/types/index.d.ts +6 -0
  195. package/src/domain/generic/repository/types/index.js +7 -0
  196. package/src/domain/generic/repository/types/index.js.map +1 -0
  197. package/src/domain/generic/repository/types/repository-find-filters.type.d.ts +13 -0
  198. package/src/domain/generic/repository/types/repository-find-filters.type.js +2 -0
  199. package/src/domain/generic/repository/types/repository-find-filters.type.js.map +1 -0
  200. package/src/domain/generic/repository/types/repository-find-result.type.d.ts +14 -0
  201. package/src/domain/generic/repository/types/repository-find-result.type.js +2 -0
  202. package/src/domain/generic/repository/types/repository-find-result.type.js.map +1 -0
  203. package/src/domain/generic/repository/types/repository-limit-options.type.d.ts +4 -0
  204. package/src/domain/generic/repository/types/repository-limit-options.type.js +2 -0
  205. package/src/domain/generic/repository/types/repository-limit-options.type.js.map +1 -0
  206. package/src/domain/generic/repository/types/repository-order-by-list.type.d.ts +5 -0
  207. package/src/domain/generic/repository/types/repository-order-by-list.type.js +2 -0
  208. package/src/domain/generic/repository/types/repository-order-by-list.type.js.map +1 -0
  209. package/src/domain/generic/repository/types/repository-update-params.type.d.ts +11 -0
  210. package/src/domain/generic/repository/types/repository-update-params.type.js +2 -0
  211. package/src/domain/generic/repository/types/repository-update-params.type.js.map +1 -0
  212. package/src/domain/generic/repository/types/where-options.type.d.ts +2 -0
  213. package/src/domain/generic/repository/types/where-options.type.js +2 -0
  214. package/src/domain/generic/repository/types/where-options.type.js.map +1 -0
  215. package/src/domain/generic/repository/update.repository.d.ts +6 -0
  216. package/src/domain/generic/repository/update.repository.js +2 -0
  217. package/src/domain/generic/repository/update.repository.js.map +1 -0
  218. package/src/domain/index.d.ts +6 -0
  219. package/src/domain/index.js +7 -0
  220. package/src/domain/index.js.map +1 -0
  221. package/src/domain/location/index.d.ts +1 -0
  222. package/src/domain/location/index.js +2 -0
  223. package/src/domain/location/index.js.map +1 -0
  224. package/src/domain/location/models/address.d.ts +24 -0
  225. package/src/domain/location/models/address.js +7 -0
  226. package/src/domain/location/models/address.js.map +1 -0
  227. package/src/domain/location/models/index.d.ts +2 -0
  228. package/src/domain/location/models/index.js +3 -0
  229. package/src/domain/location/models/index.js.map +1 -0
  230. package/src/domain/location/models/types/index.d.ts +3 -0
  231. package/src/domain/location/models/types/index.js +4 -0
  232. package/src/domain/location/models/types/index.js.map +1 -0
  233. package/src/domain/location/models/types/location-bound.type.d.ts +6 -0
  234. package/src/domain/location/models/types/location-bound.type.js +2 -0
  235. package/src/domain/location/models/types/location-bound.type.js.map +1 -0
  236. package/src/domain/location/models/types/location-geometry.type.d.ts +7 -0
  237. package/src/domain/location/models/types/location-geometry.type.js +2 -0
  238. package/src/domain/location/models/types/location-geometry.type.js.map +1 -0
  239. package/src/domain/location/models/types/location-lat-lng.type.d.ts +4 -0
  240. package/src/domain/location/models/types/location-lat-lng.type.js +2 -0
  241. package/src/domain/location/models/types/location-lat-lng.type.js.map +1 -0
  242. package/src/domain/shop-settings/enums/filter-type.enum.d.ts +19 -0
  243. package/src/domain/shop-settings/enums/filter-type.enum.js +21 -0
  244. package/src/domain/shop-settings/enums/filter-type.enum.js.map +1 -0
  245. package/src/domain/shop-settings/enums/index.d.ts +2 -0
  246. package/src/domain/shop-settings/enums/index.js +3 -0
  247. package/src/domain/shop-settings/enums/index.js.map +1 -0
  248. package/src/domain/shop-settings/enums/questions-filters.enum.d.ts +19 -0
  249. package/src/domain/shop-settings/enums/questions-filters.enum.js +21 -0
  250. package/src/domain/shop-settings/enums/questions-filters.enum.js.map +1 -0
  251. package/src/domain/shop-settings/helpers/beauty-questions.helper.d.ts +9 -0
  252. package/src/domain/shop-settings/helpers/beauty-questions.helper.js +47 -0
  253. package/src/domain/shop-settings/helpers/beauty-questions.helper.js.map +1 -0
  254. package/src/domain/shop-settings/helpers/index.d.ts +1 -0
  255. package/src/domain/shop-settings/helpers/index.js +2 -0
  256. package/src/domain/shop-settings/helpers/index.js.map +1 -0
  257. package/src/domain/shop-settings/index.d.ts +4 -0
  258. package/src/domain/shop-settings/index.js +5 -0
  259. package/src/domain/shop-settings/index.js.map +1 -0
  260. package/src/domain/shop-settings/models/home.d.ts +18 -0
  261. package/src/domain/shop-settings/models/home.js +7 -0
  262. package/src/domain/shop-settings/models/home.js.map +1 -0
  263. package/src/domain/shop-settings/models/index.d.ts +4 -0
  264. package/src/domain/shop-settings/models/index.js +5 -0
  265. package/src/domain/shop-settings/models/index.js.map +1 -0
  266. package/src/domain/shop-settings/models/shop-menu.d.ts +7 -0
  267. package/src/domain/shop-settings/models/shop-menu.js +7 -0
  268. package/src/domain/shop-settings/models/shop-menu.js.map +1 -0
  269. package/src/domain/shop-settings/models/shop-settings.d.ts +9 -0
  270. package/src/domain/shop-settings/models/shop-settings.js +7 -0
  271. package/src/domain/shop-settings/models/shop-settings.js.map +1 -0
  272. package/src/domain/shop-settings/models/types/banner.type.d.ts +6 -0
  273. package/src/domain/shop-settings/models/types/banner.type.js +2 -0
  274. package/src/domain/shop-settings/models/types/banner.type.js.map +1 -0
  275. package/src/domain/shop-settings/models/types/benefit.type.d.ts +5 -0
  276. package/src/domain/shop-settings/models/types/benefit.type.js +2 -0
  277. package/src/domain/shop-settings/models/types/benefit.type.js.map +1 -0
  278. package/src/domain/shop-settings/models/types/home-data.type.d.ts +15 -0
  279. package/src/domain/shop-settings/models/types/home-data.type.js +2 -0
  280. package/src/domain/shop-settings/models/types/home-data.type.js.map +1 -0
  281. package/src/domain/shop-settings/models/types/index.d.ts +10 -0
  282. package/src/domain/shop-settings/models/types/index.js +11 -0
  283. package/src/domain/shop-settings/models/types/index.js.map +1 -0
  284. package/src/domain/shop-settings/models/types/menu-nav.type.d.ts +8 -0
  285. package/src/domain/shop-settings/models/types/menu-nav.type.js +2 -0
  286. package/src/domain/shop-settings/models/types/menu-nav.type.js.map +1 -0
  287. package/src/domain/shop-settings/models/types/shop-banner.type.d.ts +12 -0
  288. package/src/domain/shop-settings/models/types/shop-banner.type.js +2 -0
  289. package/src/domain/shop-settings/models/types/shop-banner.type.js.map +1 -0
  290. package/src/domain/shop-settings/models/types/shop-brands.type.d.ts +10 -0
  291. package/src/domain/shop-settings/models/types/shop-brands.type.js +2 -0
  292. package/src/domain/shop-settings/models/types/shop-brands.type.js.map +1 -0
  293. package/src/domain/shop-settings/models/types/shop-carousel.type.d.ts +5 -0
  294. package/src/domain/shop-settings/models/types/shop-carousel.type.js +2 -0
  295. package/src/domain/shop-settings/models/types/shop-carousel.type.js.map +1 -0
  296. package/src/domain/shop-settings/models/types/shop-collection.type.d.ts +9 -0
  297. package/src/domain/shop-settings/models/types/shop-collection.type.js +2 -0
  298. package/src/domain/shop-settings/models/types/shop-collection.type.js.map +1 -0
  299. package/src/domain/shop-settings/models/types/shop-section.type.d.ts +9 -0
  300. package/src/domain/shop-settings/models/types/shop-section.type.js +2 -0
  301. package/src/domain/shop-settings/models/types/shop-section.type.js.map +1 -0
  302. package/src/domain/shop-settings/models/types/sub-menu.type.d.ts +8 -0
  303. package/src/domain/shop-settings/models/types/sub-menu.type.js +2 -0
  304. package/src/domain/shop-settings/models/types/sub-menu.type.js.map +1 -0
  305. package/src/domain/shop-settings/repositories/home.repository.d.ts +4 -0
  306. package/src/domain/shop-settings/repositories/home.repository.js +2 -0
  307. package/src/domain/shop-settings/repositories/home.repository.js.map +1 -0
  308. package/src/domain/shop-settings/repositories/index.d.ts +3 -0
  309. package/src/domain/shop-settings/repositories/index.js +4 -0
  310. package/src/domain/shop-settings/repositories/index.js.map +1 -0
  311. package/src/domain/shop-settings/repositories/shop-menu.repository.d.ts +4 -0
  312. package/src/domain/shop-settings/repositories/shop-menu.repository.js +2 -0
  313. package/src/domain/shop-settings/repositories/shop-menu.repository.js.map +1 -0
  314. package/src/domain/shop-settings/repositories/shop-settings.repository.d.ts +4 -0
  315. package/src/domain/shop-settings/repositories/shop-settings.repository.js +2 -0
  316. package/src/domain/shop-settings/repositories/shop-settings.repository.js.map +1 -0
  317. package/src/domain/shopping/index.d.ts +2 -0
  318. package/src/domain/shopping/index.js +3 -0
  319. package/src/domain/shopping/index.js.map +1 -0
  320. package/src/domain/shopping/models/buy-2-win.d.ts +18 -0
  321. package/src/domain/shopping/models/buy-2-win.js +14 -0
  322. package/src/domain/shopping/models/buy-2-win.js.map +1 -0
  323. package/src/domain/shopping/models/campaign-dashboard.d.ts +15 -0
  324. package/src/domain/shopping/models/campaign-dashboard.js +7 -0
  325. package/src/domain/shopping/models/campaign-dashboard.js.map +1 -0
  326. package/src/domain/shopping/models/campaign-hashtag.d.ts +18 -0
  327. package/src/domain/shopping/models/campaign-hashtag.js +7 -0
  328. package/src/domain/shopping/models/campaign-hashtag.js.map +1 -0
  329. package/src/domain/shopping/models/checkout.d.ts +26 -0
  330. package/src/domain/shopping/models/checkout.js +37 -0
  331. package/src/domain/shopping/models/checkout.js.map +1 -0
  332. package/src/domain/shopping/models/coupons/coupon.d.ts +60 -0
  333. package/src/domain/shopping/models/coupons/coupon.js +38 -0
  334. package/src/domain/shopping/models/coupons/coupon.js.map +1 -0
  335. package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.d.ts +5 -0
  336. package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js +7 -0
  337. package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js.map +1 -0
  338. package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.d.ts +4 -0
  339. package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js +6 -0
  340. package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js.map +1 -0
  341. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.d.ts +4 -0
  342. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js +10 -0
  343. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js.map +1 -0
  344. package/src/domain/shopping/models/coupons/enums/exclusivities.enum.d.ts +8 -0
  345. package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js +10 -0
  346. package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js.map +1 -0
  347. package/src/domain/shopping/models/coupons/enums/index.d.ts +3 -0
  348. package/src/domain/shopping/models/coupons/enums/index.js +4 -0
  349. package/src/domain/shopping/models/coupons/enums/index.js.map +1 -0
  350. package/src/domain/shopping/models/coupons/index.d.ts +2 -0
  351. package/src/domain/shopping/models/coupons/index.js +3 -0
  352. package/src/domain/shopping/models/coupons/index.js.map +1 -0
  353. package/src/domain/shopping/models/enums/checkout-types.enum.d.ts +5 -0
  354. package/src/domain/shopping/models/enums/checkout-types.enum.js +7 -0
  355. package/src/domain/shopping/models/enums/checkout-types.enum.js.map +1 -0
  356. package/src/domain/shopping/models/enums/index.d.ts +2 -0
  357. package/src/domain/shopping/models/enums/index.js +3 -0
  358. package/src/domain/shopping/models/enums/index.js.map +1 -0
  359. package/src/domain/shopping/models/enums/order-status.enum.d.ts +10 -0
  360. package/src/domain/shopping/models/enums/order-status.enum.js +12 -0
  361. package/src/domain/shopping/models/enums/order-status.enum.js.map +1 -0
  362. package/src/domain/shopping/models/index.d.ts +12 -0
  363. package/src/domain/shopping/models/index.js +13 -0
  364. package/src/domain/shopping/models/index.js.map +1 -0
  365. package/src/domain/shopping/models/line-item.d.ts +8 -0
  366. package/src/domain/shopping/models/line-item.js +4 -0
  367. package/src/domain/shopping/models/line-item.js.map +1 -0
  368. package/src/domain/shopping/models/order.d.ts +10 -0
  369. package/src/domain/shopping/models/order.js +11 -0
  370. package/src/domain/shopping/models/order.js.map +1 -0
  371. package/src/domain/shopping/models/payment.d.ts +67 -0
  372. package/src/domain/shopping/models/payment.js +169 -0
  373. package/src/domain/shopping/models/payment.js.map +1 -0
  374. package/src/domain/shopping/models/shipping-method.d.ts +17 -0
  375. package/src/domain/shopping/models/shipping-method.js +7 -0
  376. package/src/domain/shopping/models/shipping-method.js.map +1 -0
  377. package/src/domain/shopping/models/subscription/checkout.d.ts +20 -0
  378. package/src/domain/shopping/models/subscription/checkout.js +28 -0
  379. package/src/domain/shopping/models/subscription/checkout.js.map +1 -0
  380. package/src/domain/shopping/models/subscription/index.d.ts +2 -0
  381. package/src/domain/shopping/models/subscription/index.js +3 -0
  382. package/src/domain/shopping/models/subscription/index.js.map +1 -0
  383. package/src/domain/shopping/models/subscription/plan.d.ts +10 -0
  384. package/src/domain/shopping/models/subscription/plan.js +7 -0
  385. package/src/domain/shopping/models/subscription/plan.js.map +1 -0
  386. package/src/domain/shopping/models/types/index.d.ts +7 -0
  387. package/src/domain/shopping/models/types/index.js +8 -0
  388. package/src/domain/shopping/models/types/index.js.map +1 -0
  389. package/src/domain/shopping/models/types/payment-address.type.d.ts +12 -0
  390. package/src/domain/shopping/models/types/payment-address.type.js +2 -0
  391. package/src/domain/shopping/models/types/payment-address.type.js.map +1 -0
  392. package/src/domain/shopping/models/types/payment-billing.type.d.ts +7 -0
  393. package/src/domain/shopping/models/types/payment-billing.type.js +2 -0
  394. package/src/domain/shopping/models/types/payment-billing.type.js.map +1 -0
  395. package/src/domain/shopping/models/types/payment-card.type.d.ts +14 -0
  396. package/src/domain/shopping/models/types/payment-card.type.js +2 -0
  397. package/src/domain/shopping/models/types/payment-card.type.js.map +1 -0
  398. package/src/domain/shopping/models/types/payment-customer.type.d.ts +18 -0
  399. package/src/domain/shopping/models/types/payment-customer.type.js +2 -0
  400. package/src/domain/shopping/models/types/payment-customer.type.js.map +1 -0
  401. package/src/domain/shopping/models/types/payment-document.type.d.ts +6 -0
  402. package/src/domain/shopping/models/types/payment-document.type.js +2 -0
  403. package/src/domain/shopping/models/types/payment-document.type.js.map +1 -0
  404. package/src/domain/shopping/models/types/payment-item.type.d.ts +11 -0
  405. package/src/domain/shopping/models/types/payment-item.type.js +2 -0
  406. package/src/domain/shopping/models/types/payment-item.type.js.map +1 -0
  407. package/src/domain/shopping/models/types/payment-shipping.type.d.ts +10 -0
  408. package/src/domain/shopping/models/types/payment-shipping.type.js +2 -0
  409. package/src/domain/shopping/models/types/payment-shipping.type.js.map +1 -0
  410. package/src/domain/shopping/repositories/buy-2-win.repository.d.ts +4 -0
  411. package/src/domain/shopping/repositories/buy-2-win.repository.js +2 -0
  412. package/src/domain/shopping/repositories/buy-2-win.repository.js.map +1 -0
  413. package/src/domain/shopping/repositories/campaign-dashboard.repository.d.ts +4 -0
  414. package/src/domain/shopping/repositories/campaign-dashboard.repository.js +2 -0
  415. package/src/domain/shopping/repositories/campaign-dashboard.repository.js.map +1 -0
  416. package/src/domain/shopping/repositories/campaign-hashtag.repository.d.ts +4 -0
  417. package/src/domain/shopping/repositories/campaign-hashtag.repository.js +2 -0
  418. package/src/domain/shopping/repositories/campaign-hashtag.repository.js.map +1 -0
  419. package/src/domain/shopping/repositories/checkout.repository.d.ts +4 -0
  420. package/src/domain/shopping/repositories/checkout.repository.js +2 -0
  421. package/src/domain/shopping/repositories/checkout.repository.js.map +1 -0
  422. package/src/domain/shopping/repositories/coupon.repository.d.ts +4 -0
  423. package/src/domain/shopping/repositories/coupon.repository.js +2 -0
  424. package/src/domain/shopping/repositories/coupon.repository.js.map +1 -0
  425. package/src/domain/shopping/repositories/index.d.ts +9 -0
  426. package/src/domain/shopping/repositories/index.js +10 -0
  427. package/src/domain/shopping/repositories/index.js.map +1 -0
  428. package/src/domain/shopping/repositories/legacy-order.repository.d.ts +3 -0
  429. package/src/domain/shopping/repositories/legacy-order.repository.js +2 -0
  430. package/src/domain/shopping/repositories/legacy-order.repository.js.map +1 -0
  431. package/src/domain/shopping/repositories/order.repository.d.ts +4 -0
  432. package/src/domain/shopping/repositories/order.repository.js +2 -0
  433. package/src/domain/shopping/repositories/order.repository.js.map +1 -0
  434. package/src/domain/shopping/repositories/payment.repository.d.ts +4 -0
  435. package/src/domain/shopping/repositories/payment.repository.js +2 -0
  436. package/src/domain/shopping/repositories/payment.repository.js.map +1 -0
  437. package/src/domain/shopping/repositories/subscription/checkout.repository.d.ts +4 -0
  438. package/src/domain/shopping/repositories/subscription/checkout.repository.js +2 -0
  439. package/src/domain/shopping/repositories/subscription/checkout.repository.js.map +1 -0
  440. package/src/domain/shopping/repositories/subscription/index.d.ts +2 -0
  441. package/src/domain/shopping/repositories/subscription/index.js +3 -0
  442. package/src/domain/shopping/repositories/subscription/index.js.map +1 -0
  443. package/src/domain/shopping/repositories/subscription/plan.repository.d.ts +4 -0
  444. package/src/domain/shopping/repositories/subscription/plan.repository.js +2 -0
  445. package/src/domain/shopping/repositories/subscription/plan.repository.js.map +1 -0
  446. package/src/domain/users/errors/index.d.ts +3 -0
  447. package/src/domain/users/errors/index.js +4 -0
  448. package/src/domain/users/errors/index.js.map +1 -0
  449. package/src/domain/users/errors/unauthorized.error.d.ts +4 -0
  450. package/src/domain/users/errors/unauthorized.error.js +7 -0
  451. package/src/domain/users/errors/unauthorized.error.js.map +1 -0
  452. package/src/domain/users/errors/user-already-registered.error.d.ts +4 -0
  453. package/src/domain/users/errors/user-already-registered.error.js +7 -0
  454. package/src/domain/users/errors/user-already-registered.error.js.map +1 -0
  455. package/src/domain/users/errors/weak-password.error.d.ts +4 -0
  456. package/src/domain/users/errors/weak-password.error.js +7 -0
  457. package/src/domain/users/errors/weak-password.error.js.map +1 -0
  458. package/src/domain/users/index.d.ts +5 -0
  459. package/src/domain/users/index.js +6 -0
  460. package/src/domain/users/index.js.map +1 -0
  461. package/src/domain/users/models/beauty-profile.d.ts +11 -0
  462. package/src/domain/users/models/beauty-profile.js +12 -0
  463. package/src/domain/users/models/beauty-profile.js.map +1 -0
  464. package/src/domain/users/models/enums/accessory-importances.enum.d.ts +5 -0
  465. package/src/domain/users/models/enums/accessory-importances.enum.js +7 -0
  466. package/src/domain/users/models/enums/accessory-importances.enum.js.map +1 -0
  467. package/src/domain/users/models/enums/area.enum.d.ts +11 -0
  468. package/src/domain/users/models/enums/area.enum.js +13 -0
  469. package/src/domain/users/models/enums/area.enum.js.map +1 -0
  470. package/src/domain/users/models/enums/beard-problems.enum.d.ts +9 -0
  471. package/src/domain/users/models/enums/beard-problems.enum.js +11 -0
  472. package/src/domain/users/models/enums/beard-problems.enum.js.map +1 -0
  473. package/src/domain/users/models/enums/beard-sizes.enum.d.ts +7 -0
  474. package/src/domain/users/models/enums/beard-sizes.enum.js +9 -0
  475. package/src/domain/users/models/enums/beard-sizes.enum.js.map +1 -0
  476. package/src/domain/users/models/enums/beauty-product-importances.enum.d.ts +6 -0
  477. package/src/domain/users/models/enums/beauty-product-importances.enum.js +8 -0
  478. package/src/domain/users/models/enums/beauty-product-importances.enum.js.map +1 -0
  479. package/src/domain/users/models/enums/body-problems.enum.d.ts +11 -0
  480. package/src/domain/users/models/enums/body-problems.enum.js +13 -0
  481. package/src/domain/users/models/enums/body-problems.enum.js.map +1 -0
  482. package/src/domain/users/models/enums/body-shapes.enum.d.ts +7 -0
  483. package/src/domain/users/models/enums/body-shapes.enum.js +9 -0
  484. package/src/domain/users/models/enums/body-shapes.enum.js.map +1 -0
  485. package/src/domain/users/models/enums/body-tattoos.enum.d.ts +5 -0
  486. package/src/domain/users/models/enums/body-tattoos.enum.js +7 -0
  487. package/src/domain/users/models/enums/body-tattoos.enum.js.map +1 -0
  488. package/src/domain/users/models/enums/face-skin-oilinesses.enum.d.ts +7 -0
  489. package/src/domain/users/models/enums/face-skin-oilinesses.enum.js +9 -0
  490. package/src/domain/users/models/enums/face-skin-oilinesses.enum.js.map +1 -0
  491. package/src/domain/users/models/enums/face-skin-problems.enum.d.ts +10 -0
  492. package/src/domain/users/models/enums/face-skin-problems.enum.js +12 -0
  493. package/src/domain/users/models/enums/face-skin-problems.enum.js.map +1 -0
  494. package/src/domain/users/models/enums/face-skin-tones.enum.d.ts +8 -0
  495. package/src/domain/users/models/enums/face-skin-tones.enum.js +10 -0
  496. package/src/domain/users/models/enums/face-skin-tones.enum.js.map +1 -0
  497. package/src/domain/users/models/enums/family-incomes.enum.d.ts +8 -0
  498. package/src/domain/users/models/enums/family-incomes.enum.js +10 -0
  499. package/src/domain/users/models/enums/family-incomes.enum.js.map +1 -0
  500. package/src/domain/users/models/enums/fragrance-importances.enum.d.ts +5 -0
  501. package/src/domain/users/models/enums/fragrance-importances.enum.js +7 -0
  502. package/src/domain/users/models/enums/fragrance-importances.enum.js.map +1 -0
  503. package/src/domain/users/models/enums/hair-colors.enum.d.ts +10 -0
  504. package/src/domain/users/models/enums/hair-colors.enum.js +12 -0
  505. package/src/domain/users/models/enums/hair-colors.enum.js.map +1 -0
  506. package/src/domain/users/models/enums/hair-problems.enum.d.ts +10 -0
  507. package/src/domain/users/models/enums/hair-problems.enum.js +12 -0
  508. package/src/domain/users/models/enums/hair-problems.enum.js.map +1 -0
  509. package/src/domain/users/models/enums/hair-strands.enum.d.ts +8 -0
  510. package/src/domain/users/models/enums/hair-strands.enum.js +10 -0
  511. package/src/domain/users/models/enums/hair-strands.enum.js.map +1 -0
  512. package/src/domain/users/models/enums/hair-types.enum.d.ts +7 -0
  513. package/src/domain/users/models/enums/hair-types.enum.js +9 -0
  514. package/src/domain/users/models/enums/hair-types.enum.js.map +1 -0
  515. package/src/domain/users/models/enums/index.d.ts +20 -0
  516. package/src/domain/users/models/enums/index.js +21 -0
  517. package/src/domain/users/models/enums/index.js.map +1 -0
  518. package/src/domain/users/models/enums/office-position.enum.d.ts +6 -0
  519. package/src/domain/users/models/enums/office-position.enum.js +8 -0
  520. package/src/domain/users/models/enums/office-position.enum.js.map +1 -0
  521. package/src/domain/users/models/enums/product-spents.enum.d.ts +8 -0
  522. package/src/domain/users/models/enums/product-spents.enum.js +10 -0
  523. package/src/domain/users/models/enums/product-spents.enum.js.map +1 -0
  524. package/src/domain/users/models/enums/user-type.enum.d.ts +8 -0
  525. package/src/domain/users/models/enums/user-type.enum.js +10 -0
  526. package/src/domain/users/models/enums/user-type.enum.js.map +1 -0
  527. package/src/domain/users/models/index.d.ts +7 -0
  528. package/src/domain/users/models/index.js +8 -0
  529. package/src/domain/users/models/index.js.map +1 -0
  530. package/src/domain/users/models/lead.d.ts +8 -0
  531. package/src/domain/users/models/lead.js +7 -0
  532. package/src/domain/users/models/lead.js.map +1 -0
  533. package/src/domain/users/models/subscription/edition.d.ts +16 -0
  534. package/src/domain/users/models/subscription/edition.js +7 -0
  535. package/src/domain/users/models/subscription/edition.js.map +1 -0
  536. package/src/domain/users/models/subscription/enums/billing-status.enum.d.ts +3 -0
  537. package/src/domain/users/models/subscription/enums/billing-status.enum.js +5 -0
  538. package/src/domain/users/models/subscription/enums/billing-status.enum.js.map +1 -0
  539. package/src/domain/users/models/subscription/enums/edition-status.enum.d.ts +4 -0
  540. package/src/domain/users/models/subscription/enums/edition-status.enum.js +6 -0
  541. package/src/domain/users/models/subscription/enums/edition-status.enum.js.map +1 -0
  542. package/src/domain/users/models/subscription/enums/index.d.ts +4 -0
  543. package/src/domain/users/models/subscription/enums/index.js +5 -0
  544. package/src/domain/users/models/subscription/enums/index.js.map +1 -0
  545. package/src/domain/users/models/subscription/enums/payment-type.enum.d.ts +5 -0
  546. package/src/domain/users/models/subscription/enums/payment-type.enum.js +7 -0
  547. package/src/domain/users/models/subscription/enums/payment-type.enum.js.map +1 -0
  548. package/src/domain/users/models/subscription/enums/status.enum.d.ts +4 -0
  549. package/src/domain/users/models/subscription/enums/status.enum.js +6 -0
  550. package/src/domain/users/models/subscription/enums/status.enum.js.map +1 -0
  551. package/src/domain/users/models/subscription/index.d.ts +4 -0
  552. package/src/domain/users/models/subscription/index.js +5 -0
  553. package/src/domain/users/models/subscription/index.js.map +1 -0
  554. package/src/domain/users/models/subscription/payment.d.ts +13 -0
  555. package/src/domain/users/models/subscription/payment.js +14 -0
  556. package/src/domain/users/models/subscription/payment.js.map +1 -0
  557. package/src/domain/users/models/subscription/subscription.d.ts +28 -0
  558. package/src/domain/users/models/subscription/subscription.js +43 -0
  559. package/src/domain/users/models/subscription/subscription.js.map +1 -0
  560. package/src/domain/users/models/user-address.d.ts +6 -0
  561. package/src/domain/users/models/user-address.js +7 -0
  562. package/src/domain/users/models/user-address.js.map +1 -0
  563. package/src/domain/users/models/user-payment-method.d.ts +14 -0
  564. package/src/domain/users/models/user-payment-method.js +7 -0
  565. package/src/domain/users/models/user-payment-method.js.map +1 -0
  566. package/src/domain/users/models/user.d.ts +27 -0
  567. package/src/domain/users/models/user.js +26 -0
  568. package/src/domain/users/models/user.js.map +1 -0
  569. package/src/domain/users/repositories/beauty-profile.repository.d.ts +4 -0
  570. package/src/domain/users/repositories/beauty-profile.repository.js +2 -0
  571. package/src/domain/users/repositories/beauty-profile.repository.js.map +1 -0
  572. package/src/domain/users/repositories/edition.repository.d.ts +4 -0
  573. package/src/domain/users/repositories/edition.repository.js +2 -0
  574. package/src/domain/users/repositories/edition.repository.js.map +1 -0
  575. package/src/domain/users/repositories/index.d.ts +8 -0
  576. package/src/domain/users/repositories/index.js +9 -0
  577. package/src/domain/users/repositories/index.js.map +1 -0
  578. package/src/domain/users/repositories/lead.repository.d.ts +4 -0
  579. package/src/domain/users/repositories/lead.repository.js +2 -0
  580. package/src/domain/users/repositories/lead.repository.js.map +1 -0
  581. package/src/domain/users/repositories/subscription-payment.repository.d.ts +4 -0
  582. package/src/domain/users/repositories/subscription-payment.repository.js +2 -0
  583. package/src/domain/users/repositories/subscription-payment.repository.js.map +1 -0
  584. package/src/domain/users/repositories/subscription.repository.d.ts +4 -0
  585. package/src/domain/users/repositories/subscription.repository.js +2 -0
  586. package/src/domain/users/repositories/subscription.repository.js.map +1 -0
  587. package/src/domain/users/repositories/user-address.repository.d.ts +4 -0
  588. package/src/domain/users/repositories/user-address.repository.js +2 -0
  589. package/src/domain/users/repositories/user-address.repository.js.map +1 -0
  590. package/src/domain/users/repositories/user-payment-method.repository.d.ts +4 -0
  591. package/src/domain/users/repositories/user-payment-method.repository.js +2 -0
  592. package/src/domain/users/repositories/user-payment-method.repository.js.map +1 -0
  593. package/src/domain/users/repositories/user.repository.d.ts +6 -0
  594. package/src/domain/users/repositories/user.repository.js +2 -0
  595. package/src/domain/users/repositories/user.repository.js.map +1 -0
  596. package/src/domain/users/services/authentication.service.d.ts +12 -0
  597. package/src/domain/users/services/authentication.service.js +2 -0
  598. package/src/domain/users/services/authentication.service.js.map +1 -0
  599. package/src/domain/users/services/index.d.ts +3 -0
  600. package/src/domain/users/services/index.js +4 -0
  601. package/src/domain/users/services/index.js.map +1 -0
  602. package/src/domain/users/services/register.service.d.ts +7 -0
  603. package/src/domain/users/services/register.service.js +2 -0
  604. package/src/domain/users/services/register.service.js.map +1 -0
  605. package/src/domain/users/services/types/basic-user-data.type.d.ts +4 -0
  606. package/src/domain/users/services/types/basic-user-data.type.js +2 -0
  607. package/src/domain/users/services/types/basic-user-data.type.js.map +1 -0
  608. package/src/domain/users/services/types/index.d.ts +1 -0
  609. package/src/domain/users/services/types/index.js +2 -0
  610. package/src/domain/users/services/types/index.js.map +1 -0
  611. package/src/domain/users/use-cases/authentication.d.ts +21 -0
  612. package/src/domain/users/use-cases/authentication.js +35 -0
  613. package/src/domain/users/use-cases/authentication.js.map +1 -0
  614. package/src/domain/users/use-cases/index.d.ts +4 -0
  615. package/src/domain/users/use-cases/index.js +5 -0
  616. package/src/domain/users/use-cases/index.js.map +1 -0
  617. package/src/domain/users/use-cases/recovery-password.d.ts +6 -0
  618. package/src/domain/users/use-cases/recovery-password.js +9 -0
  619. package/src/domain/users/use-cases/recovery-password.js.map +1 -0
  620. package/src/domain/users/use-cases/register.d.ts +13 -0
  621. package/src/domain/users/use-cases/register.js +31 -0
  622. package/src/domain/users/use-cases/register.js.map +1 -0
  623. package/src/domain/users/use-cases/signout.d.ts +6 -0
  624. package/src/domain/users/use-cases/signout.js +9 -0
  625. package/src/domain/users/use-cases/signout.js.map +1 -0
  626. package/src/errors/duplicated-results.error.d.ts +4 -0
  627. package/src/errors/duplicated-results.error.js +7 -0
  628. package/src/errors/duplicated-results.error.js.map +1 -0
  629. package/src/errors/index.d.ts +4 -0
  630. package/src/errors/index.js +5 -0
  631. package/src/errors/index.js.map +1 -0
  632. package/src/errors/invalid-argument.error.d.ts +4 -0
  633. package/src/errors/invalid-argument.error.js +7 -0
  634. package/src/errors/invalid-argument.error.js.map +1 -0
  635. package/src/errors/not-found.error.d.ts +4 -0
  636. package/src/errors/not-found.error.js +7 -0
  637. package/src/errors/not-found.error.js.map +1 -0
  638. package/src/errors/required-argument.error.d.ts +6 -0
  639. package/src/errors/required-argument.error.js +9 -0
  640. package/src/errors/required-argument.error.js.map +1 -0
  641. package/src/index.d.ts +5 -0
  642. package/src/index.js +6 -0
  643. package/src/index.js.map +1 -0
  644. package/src/infra/elasticsearch/adapters/axios.adapter.d.ts +16 -0
  645. package/src/infra/elasticsearch/adapters/axios.adapter.js +67 -0
  646. package/src/infra/elasticsearch/adapters/axios.adapter.js.map +1 -0
  647. package/src/infra/elasticsearch/adapters/elastic-search.adapter.d.ts +8 -0
  648. package/src/infra/elasticsearch/adapters/elastic-search.adapter.js +2 -0
  649. package/src/infra/elasticsearch/adapters/elastic-search.adapter.js.map +1 -0
  650. package/src/infra/elasticsearch/adapters/index.d.ts +2 -0
  651. package/src/infra/elasticsearch/adapters/index.js +3 -0
  652. package/src/infra/elasticsearch/adapters/index.js.map +1 -0
  653. package/src/infra/elasticsearch/index.d.ts +3 -0
  654. package/src/infra/elasticsearch/index.js +4 -0
  655. package/src/infra/elasticsearch/index.js.map +1 -0
  656. package/src/infra/elasticsearch/indexes/index.d.ts +1 -0
  657. package/src/infra/elasticsearch/indexes/index.js +2 -0
  658. package/src/infra/elasticsearch/indexes/index.js.map +1 -0
  659. package/src/infra/elasticsearch/indexes/products-index.d.ts +13 -0
  660. package/src/infra/elasticsearch/indexes/products-index.js +105 -0
  661. package/src/infra/elasticsearch/indexes/products-index.js.map +1 -0
  662. package/src/infra/elasticsearch/types/elastic-search-result.d.ts +9 -0
  663. package/src/infra/elasticsearch/types/elastic-search-result.js +2 -0
  664. package/src/infra/elasticsearch/types/elastic-search-result.js.map +1 -0
  665. package/src/infra/elasticsearch/types/index.d.ts +1 -0
  666. package/src/infra/elasticsearch/types/index.js +2 -0
  667. package/src/infra/elasticsearch/types/index.js.map +1 -0
  668. package/src/infra/firebase/auth/authentication-firebase-auth.service.d.ts +12 -0
  669. package/src/infra/firebase/auth/authentication-firebase-auth.service.js +41 -0
  670. package/src/infra/firebase/auth/authentication-firebase-auth.service.js.map +1 -0
  671. package/src/infra/firebase/auth/index.d.ts +2 -0
  672. package/src/infra/firebase/auth/index.js +3 -0
  673. package/src/infra/firebase/auth/index.js.map +1 -0
  674. package/src/infra/firebase/auth/register-firebase-auth.service.d.ts +8 -0
  675. package/src/infra/firebase/auth/register-firebase-auth.service.js +33 -0
  676. package/src/infra/firebase/auth/register-firebase-auth.service.js.map +1 -0
  677. package/src/infra/firebase/auth/types/firebase-user-with-id.type.d.ts +5 -0
  678. package/src/infra/firebase/auth/types/firebase-user-with-id.type.js +2 -0
  679. package/src/infra/firebase/auth/types/firebase-user-with-id.type.js.map +1 -0
  680. package/src/infra/firebase/auth/types/index.d.ts +1 -0
  681. package/src/infra/firebase/auth/types/index.js +2 -0
  682. package/src/infra/firebase/auth/types/index.js.map +1 -0
  683. package/src/infra/firebase/firestore/enums/firestore-field-type.enum.d.ts +8 -0
  684. package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js +10 -0
  685. package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js.map +1 -0
  686. package/src/infra/firebase/firestore/enums/index.d.ts +1 -0
  687. package/src/infra/firebase/firestore/enums/index.js +2 -0
  688. package/src/infra/firebase/firestore/enums/index.js.map +1 -0
  689. package/src/infra/firebase/firestore/index.d.ts +3 -0
  690. package/src/infra/firebase/firestore/index.js +4 -0
  691. package/src/infra/firebase/firestore/index.js.map +1 -0
  692. package/src/infra/firebase/firestore/mixins/index.d.ts +9 -0
  693. package/src/infra/firebase/firestore/mixins/index.js +10 -0
  694. package/src/infra/firebase/firestore/mixins/index.js.map +1 -0
  695. package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.d.ts +4 -0
  696. package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js +33 -0
  697. package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js.map +1 -0
  698. package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.d.ts +5 -0
  699. package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js +10 -0
  700. package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js.map +1 -0
  701. package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.d.ts +4 -0
  702. package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js +19 -0
  703. package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js.map +1 -0
  704. package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.d.ts +4 -0
  705. package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js +109 -0
  706. package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js.map +1 -0
  707. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.d.ts +13 -0
  708. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js +77 -0
  709. package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js.map +1 -0
  710. package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.d.ts +4 -0
  711. package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js +24 -0
  712. package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js.map +1 -0
  713. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.d.ts +11 -0
  714. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js +17 -0
  715. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js.map +1 -0
  716. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.d.ts +11 -0
  717. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js +13 -0
  718. package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js.map +1 -0
  719. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.d.ts +7 -0
  720. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js +52 -0
  721. package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js.map +1 -0
  722. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.d.ts +20 -0
  723. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js +67 -0
  724. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js.map +1 -0
  725. package/src/infra/firebase/firestore/repositories/catalog/index.d.ts +4 -0
  726. package/src/infra/firebase/firestore/repositories/catalog/index.js +5 -0
  727. package/src/infra/firebase/firestore/repositories/catalog/index.js.map +1 -0
  728. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.d.ts +12 -0
  729. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js +56 -0
  730. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js.map +1 -0
  731. package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.d.ts +12 -0
  732. package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js +16 -0
  733. package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js.map +1 -0
  734. package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.d.ts +7 -0
  735. package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js +14 -0
  736. package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js.map +1 -0
  737. package/src/infra/firebase/firestore/repositories/index.d.ts +4 -0
  738. package/src/infra/firebase/firestore/repositories/index.js +5 -0
  739. package/src/infra/firebase/firestore/repositories/index.js.map +1 -0
  740. package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.d.ts +16 -0
  741. package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js +66 -0
  742. package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js.map +1 -0
  743. package/src/infra/firebase/firestore/repositories/shop-settings/index.d.ts +3 -0
  744. package/src/infra/firebase/firestore/repositories/shop-settings/index.js +4 -0
  745. package/src/infra/firebase/firestore/repositories/shop-settings/index.js.map +1 -0
  746. package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.d.ts +7 -0
  747. package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js +14 -0
  748. package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js.map +1 -0
  749. package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.d.ts +7 -0
  750. package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js +14 -0
  751. package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js.map +1 -0
  752. package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.d.ts +7 -0
  753. package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js +14 -0
  754. package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js.map +1 -0
  755. package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.d.ts +8 -0
  756. package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js +14 -0
  757. package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js.map +1 -0
  758. package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.d.ts +8 -0
  759. package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js +14 -0
  760. package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js.map +1 -0
  761. package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.d.ts +7 -0
  762. package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js +14 -0
  763. package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js.map +1 -0
  764. package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.d.ts +7 -0
  765. package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js +14 -0
  766. package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js.map +1 -0
  767. package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.d.ts +12 -0
  768. package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js +31 -0
  769. package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js.map +1 -0
  770. package/src/infra/firebase/firestore/repositories/shopping/index.d.ts +10 -0
  771. package/src/infra/firebase/firestore/repositories/shopping/index.js +11 -0
  772. package/src/infra/firebase/firestore/repositories/shopping/index.js.map +1 -0
  773. package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.d.ts +6 -0
  774. package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js +11 -0
  775. package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js.map +1 -0
  776. package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.d.ts +13 -0
  777. package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js +41 -0
  778. package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js.map +1 -0
  779. package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.d.ts +7 -0
  780. package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js +14 -0
  781. package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js.map +1 -0
  782. package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.d.ts +7 -0
  783. package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js +14 -0
  784. package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js.map +1 -0
  785. package/src/infra/firebase/firestore/repositories/users/index.d.ts +8 -0
  786. package/src/infra/firebase/firestore/repositories/users/index.js +9 -0
  787. package/src/infra/firebase/firestore/repositories/users/index.js.map +1 -0
  788. package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.d.ts +7 -0
  789. package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js +14 -0
  790. package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js.map +1 -0
  791. package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.d.ts +12 -0
  792. package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js +16 -0
  793. package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js.map +1 -0
  794. package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.d.ts +7 -0
  795. package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js +14 -0
  796. package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js.map +1 -0
  797. package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.d.ts +12 -0
  798. package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js +16 -0
  799. package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js.map +1 -0
  800. package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.d.ts +12 -0
  801. package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js +16 -0
  802. package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js.map +1 -0
  803. package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.d.ts +12 -0
  804. package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js +16 -0
  805. package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js.map +1 -0
  806. package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.d.ts +17 -0
  807. package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js +50 -0
  808. package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js.map +1 -0
  809. package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.d.ts +12 -0
  810. package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js +16 -0
  811. package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js.map +1 -0
  812. package/src/infra/firebase/firestore/types/firestore-interceptors.type.d.ts +14 -0
  813. package/src/infra/firebase/firestore/types/firestore-interceptors.type.js +2 -0
  814. package/src/infra/firebase/firestore/types/firestore-interceptors.type.js.map +1 -0
  815. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.d.ts +6 -0
  816. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js +2 -0
  817. package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js.map +1 -0
  818. package/src/infra/firebase/firestore/types/firestore.helpers.type.d.ts +8 -0
  819. package/src/infra/firebase/firestore/types/firestore.helpers.type.js +2 -0
  820. package/src/infra/firebase/firestore/types/firestore.helpers.type.js.map +1 -0
  821. package/src/infra/firebase/firestore/types/firestore.repository.type.d.ts +16 -0
  822. package/src/infra/firebase/firestore/types/firestore.repository.type.js +2 -0
  823. package/src/infra/firebase/firestore/types/firestore.repository.type.js.map +1 -0
  824. package/src/infra/firebase/firestore/types/index.d.ts +4 -0
  825. package/src/infra/firebase/firestore/types/index.js +5 -0
  826. package/src/infra/firebase/firestore/types/index.js.map +1 -0
  827. package/src/infra/firebase/index.d.ts +2 -0
  828. package/src/infra/firebase/index.js +3 -0
  829. package/src/infra/firebase/index.js.map +1 -0
  830. package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.d.ts +11 -0
  831. package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js +13 -0
  832. package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js.map +1 -0
  833. package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.d.ts +15 -0
  834. package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js +17 -0
  835. package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js.map +1 -0
  836. package/src/infra/hasura-graphql/enums/index.d.ts +2 -0
  837. package/src/infra/hasura-graphql/enums/index.js +3 -0
  838. package/src/infra/hasura-graphql/enums/index.js.map +1 -0
  839. package/src/infra/hasura-graphql/index.d.ts +4 -0
  840. package/src/infra/hasura-graphql/index.js +5 -0
  841. package/src/infra/hasura-graphql/index.js.map +1 -0
  842. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.d.ts +19 -0
  843. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js +32 -0
  844. package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js.map +1 -0
  845. package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.d.ts +10 -0
  846. package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js +56 -0
  847. package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js.map +1 -0
  848. package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.d.ts +8 -0
  849. package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js +22 -0
  850. package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js.map +1 -0
  851. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.d.ts +12 -0
  852. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js +104 -0
  853. package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js.map +1 -0
  854. package/src/infra/hasura-graphql/mixins/helpers/index.d.ts +4 -0
  855. package/src/infra/hasura-graphql/mixins/helpers/index.js +5 -0
  856. package/src/infra/hasura-graphql/mixins/helpers/index.js.map +1 -0
  857. package/src/infra/hasura-graphql/mixins/index.d.ts +7 -0
  858. package/src/infra/hasura-graphql/mixins/index.js +8 -0
  859. package/src/infra/hasura-graphql/mixins/index.js.map +1 -0
  860. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.d.ts +9 -0
  861. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js +41 -0
  862. package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js.map +1 -0
  863. package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.d.ts +11 -0
  864. package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js +10 -0
  865. package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js.map +1 -0
  866. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.d.ts +7 -0
  867. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js +28 -0
  868. package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js.map +1 -0
  869. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +34 -0
  870. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +143 -0
  871. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js.map +1 -0
  872. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +25 -0
  873. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js +35 -0
  874. package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js.map +1 -0
  875. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.d.ts +23 -0
  876. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js +105 -0
  877. package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js.map +1 -0
  878. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.d.ts +14 -0
  879. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js +57 -0
  880. package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js.map +1 -0
  881. package/src/infra/hasura-graphql/models/category-hasura-graphql.d.ts +6 -0
  882. package/src/infra/hasura-graphql/models/category-hasura-graphql.js +4 -0
  883. package/src/infra/hasura-graphql/models/category-hasura-graphql.js.map +1 -0
  884. package/src/infra/hasura-graphql/models/index.d.ts +4 -0
  885. package/src/infra/hasura-graphql/models/index.js +5 -0
  886. package/src/infra/hasura-graphql/models/index.js.map +1 -0
  887. package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.d.ts +6 -0
  888. package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js +15 -0
  889. package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js.map +1 -0
  890. package/src/infra/hasura-graphql/models/product-hasura-graphql.d.ts +18 -0
  891. package/src/infra/hasura-graphql/models/product-hasura-graphql.js +11 -0
  892. package/src/infra/hasura-graphql/models/product-hasura-graphql.js.map +1 -0
  893. package/src/infra/hasura-graphql/models/variant-hasura-graphql.d.ts +10 -0
  894. package/src/infra/hasura-graphql/models/variant-hasura-graphql.js +9 -0
  895. package/src/infra/hasura-graphql/models/variant-hasura-graphql.js.map +1 -0
  896. package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.d.ts +10 -0
  897. package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js +39 -0
  898. package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js.map +1 -0
  899. package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.d.ts +12 -0
  900. package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +107 -0
  901. package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js.map +1 -0
  902. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.d.ts +34 -0
  903. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +330 -0
  904. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js.map +1 -0
  905. package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.d.ts +18 -0
  906. package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js +106 -0
  907. package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js.map +1 -0
  908. package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.d.ts +10 -0
  909. package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js +22 -0
  910. package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js.map +1 -0
  911. package/src/infra/hasura-graphql/repositories/catalog/index.d.ts +8 -0
  912. package/src/infra/hasura-graphql/repositories/catalog/index.js +9 -0
  913. package/src/infra/hasura-graphql/repositories/catalog/index.js.map +1 -0
  914. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.d.ts +30 -0
  915. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +461 -0
  916. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js.map +1 -0
  917. package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.d.ts +14 -0
  918. package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js +107 -0
  919. package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js.map +1 -0
  920. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.d.ts +27 -0
  921. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js +228 -0
  922. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js.map +1 -0
  923. package/src/infra/hasura-graphql/repositories/index.d.ts +1 -0
  924. package/src/infra/hasura-graphql/repositories/index.js +2 -0
  925. package/src/infra/hasura-graphql/repositories/index.js.map +1 -0
  926. package/src/infra/hasura-graphql/types/fields.type.d.ts +2 -0
  927. package/src/infra/hasura-graphql/types/fields.type.js +2 -0
  928. package/src/infra/hasura-graphql/types/fields.type.js.map +1 -0
  929. package/src/infra/hasura-graphql/types/graphql.repository.type.d.ts +24 -0
  930. package/src/infra/hasura-graphql/types/graphql.repository.type.js +2 -0
  931. package/src/infra/hasura-graphql/types/graphql.repository.type.js.map +1 -0
  932. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.d.ts +8 -0
  933. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js +2 -0
  934. package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js.map +1 -0
  935. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.d.ts +44 -0
  936. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js +2 -0
  937. package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js.map +1 -0
  938. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.d.ts +7 -0
  939. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js +2 -0
  940. package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js.map +1 -0
  941. package/src/infra/hasura-graphql/types/index.d.ts +8 -0
  942. package/src/infra/hasura-graphql/types/index.js +9 -0
  943. package/src/infra/hasura-graphql/types/index.js.map +1 -0
  944. package/src/infra/hasura-graphql/types/nested-field.type.d.ts +7 -0
  945. package/src/infra/hasura-graphql/types/nested-field.type.js +2 -0
  946. package/src/infra/hasura-graphql/types/nested-field.type.js.map +1 -0
  947. package/src/infra/hasura-graphql/types/query-builder-options.type.d.ts +7 -0
  948. package/src/infra/hasura-graphql/types/query-builder-options.type.js +2 -0
  949. package/src/infra/hasura-graphql/types/query-builder-options.type.js.map +1 -0
  950. package/src/infra/hasura-graphql/types/variable-options.type.d.ts +9 -0
  951. package/src/infra/hasura-graphql/types/variable-options.type.js +2 -0
  952. package/src/infra/hasura-graphql/types/variable-options.type.js.map +1 -0
  953. package/src/infra/index.d.ts +3 -0
  954. package/src/infra/index.js +4 -0
  955. package/src/infra/index.js.map +1 -0
  956. package/src/utils/decorators/debug.class.decorator.d.ts +2 -0
  957. package/src/utils/decorators/debug.class.decorator.js +7 -0
  958. package/src/utils/decorators/debug.class.decorator.js.map +1 -0
  959. package/src/utils/decorators/index.d.ts +2 -0
  960. package/src/utils/decorators/index.js +3 -0
  961. package/src/utils/decorators/index.js.map +1 -0
  962. package/src/utils/decorators/trace.method.decorator.d.ts +14 -0
  963. package/src/utils/decorators/trace.method.decorator.js +81 -0
  964. package/src/utils/decorators/trace.method.decorator.js.map +1 -0
  965. package/src/utils/get.d.ts +1 -0
  966. package/src/utils/get.js +3 -0
  967. package/src/utils/get.js.map +1 -0
  968. package/src/utils/helpers/class-name.helper.d.ts +3 -0
  969. package/src/utils/helpers/class-name.helper.js +15 -0
  970. package/src/utils/helpers/class-name.helper.js.map +1 -0
  971. package/src/utils/helpers/debug-decorator.helper.d.ts +9 -0
  972. package/src/utils/helpers/debug-decorator.helper.js +18 -0
  973. package/src/utils/helpers/debug-decorator.helper.js.map +1 -0
  974. package/src/utils/helpers/debug.helper.d.ts +60 -0
  975. package/src/utils/helpers/debug.helper.js +150 -0
  976. package/src/utils/helpers/debug.helper.js.map +1 -0
  977. package/src/utils/helpers/index.d.ts +4 -0
  978. package/src/utils/helpers/index.js +5 -0
  979. package/src/utils/helpers/index.js.map +1 -0
  980. package/src/utils/helpers/reflect.helper.d.ts +50 -0
  981. package/src/utils/helpers/reflect.helper.js +165 -0
  982. package/src/utils/helpers/reflect.helper.js.map +1 -0
  983. package/src/utils/index.d.ts +13 -0
  984. package/src/utils/index.js +13 -0
  985. package/src/utils/index.js.map +1 -0
  986. package/src/utils/is-uuid.d.ts +1 -0
  987. package/src/utils/is-uuid.js +3 -0
  988. package/src/utils/is-uuid.js.map +1 -0
  989. package/src/utils/is.d.ts +1 -0
  990. package/src/utils/is.js +4 -0
  991. package/src/utils/is.js.map +1 -0
  992. package/src/utils/log.utils.d.ts +7 -0
  993. package/src/utils/log.utils.js +9 -0
  994. package/src/utils/log.utils.js.map +1 -0
  995. package/src/utils/mixins/base.mixin.d.ts +3 -0
  996. package/src/utils/mixins/base.mixin.js +6 -0
  997. package/src/utils/mixins/base.mixin.js.map +1 -0
  998. package/src/utils/mixins/index.d.ts +3 -0
  999. package/src/utils/mixins/index.js +4 -0
  1000. package/src/utils/mixins/index.js.map +1 -0
  1001. package/src/utils/mixins/merge-constructor-params.type.d.ts +3 -0
  1002. package/src/utils/mixins/merge-constructor-params.type.js +2 -0
  1003. package/src/utils/mixins/merge-constructor-params.type.js.map +1 -0
  1004. package/src/utils/mixins/mixin-ctor.type.d.ts +1 -0
  1005. package/src/utils/mixins/mixin-ctor.type.js +2 -0
  1006. package/src/utils/mixins/mixin-ctor.type.js.map +1 -0
  1007. package/src/utils/parse-datetime.d.ts +1 -0
  1008. package/src/utils/parse-datetime.js +14 -0
  1009. package/src/utils/parse-datetime.js.map +1 -0
  1010. package/src/utils/types/array-element.type.d.ts +1 -0
  1011. package/src/utils/types/array-element.type.js +2 -0
  1012. package/src/utils/types/array-element.type.js.map +1 -0
  1013. package/src/utils/types/index.d.ts +2 -0
  1014. package/src/utils/types/index.js +3 -0
  1015. package/src/utils/types/index.js.map +1 -0
  1016. package/src/utils/types/prop.type.d.ts +1 -0
  1017. package/src/utils/types/prop.type.js +2 -0
  1018. package/src/utils/types/prop.type.js.map +1 -0
@@ -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":"AACA,OAAO,EACL,SAAS,GAKV,MAAM,oBAAoB,CAAA;AAC3B,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AAEjG,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAA;AACjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAElE,MAAM,OAAO,kBAAkB;;AACtB,uCAAoB,GAAG,CAC5B,MAAoD,EAClB,EAAE,CACpC,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;AAEpF,oDAAiC,GAAG,CACzC,MAAkC,EAC1B,EAAE;IACV,OAAO,MAAM,aAAN,MAAM,uBAAN,MAAM,CACT,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACd,IAAI,QAAQ,CAAC,KAAK,CAAC;YAAE,OAAO,KAAK,CAAC,QAAQ,EAAE,CAAA;QAC5C,IAAI,KAAK,KAAK,eAAe;YAAE,OAAO,KAAK,CAAA;QAE3C,MAAM,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAA;QAC5C,MAAM,UAAU,GAAG,EAAE,CAA4B,KAAK,CAAC,SAA+B,CAAC,CAAC,CAAA;QAExF,IAAI,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;YAC3B,OAAO,EAAE,CAAC,SAAS,CAAC,EAAE,kBAAkB,CAAC,iCAAiC,CAAC,UAAU,CAAC,EAAE,CAAA;QAC1F,IAAI,CAAC,qBAAqB,CAAC,mBAAmB,CAAC,UAAU,CAAC;YAAE,OAAM;QAElE,MAAM,aAAa,GAAG,CAAC,CAAC,UAAU,CAAC,MAAM,CAAA;QAEzC,IAAI,aAAa;YAAE,OAAO,kBAAkB,CAAC,kCAAkC,CAAC,SAAS,EAAE,UAAiB,CAAC,CAAA;QAE7G,OAAO,UAAU,CAAC,UAAU,CAAA;IAC9B,CAAC,EACA,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;AAC/B,CAAC,CAAA;AAEM,wCAAqB,GAAG,CAK7B,IAAc,EACd,MAAkC,EACuD,EAAE,CAC3F,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE;IAC9C,MAAM,EACJ,aAAa,EACb,MAAM,EAAE,eAAe,EACvB,IAAI,GACL,GAAG,qBAAqB,CAAC,wBAAwB,CAAC,UAAU,EAAE,MAAM,CAAC,CAAA;IAEtE,IAAI,CAAC,CAAC,eAAe,IAAI,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE;QACvD,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjC,uCACK,MAAM,KACT,CAAC,aAAa,CAAC,EAAE,IAAI;oBACnB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC;oBAC9B,CAAC,CAAC,EAAE,CAAmB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CACnD,kBAAkB,CAAC,qBAAqB,CAAC,EAAE,CAAW,KAAK,CAAC,EAAE,eAAe,CAAC,CAC/E,IACN;QACH,IAAI,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5B,uCACK,MAAM,KACT,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,IAAI;oBACrB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;oBACxB,CAAC,CAAC,kBAAkB,CAAC,qBAAqB,CAAC,EAAE,CAAW,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,eAAe,CAAC,IAC9F;KACJ;IAED,IAAI,CAAC,CAAC,IAAI;QAAE,uCAAY,MAAM,KAAE,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,IAAE;IAE/E,uCACK,MAAM,KACT,CAAC,aAAa,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,IAC5G;AACH,CAAC,EAAE,EAAE,CAAC,CAAA;AAED,sCAAmB,GAAG,CAI3B,QAAe,EACf,MAAkC,EAClC,MAAM,GAAG,KAAK,EACJ,EAAE;;IACZ,MAAM,IAAI,GAAmB,CAAA,MAAA,QAAQ,CAAC,OAAO,wDAAI,KAAI,QAAQ,CAAA;IAE7D,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,aAAa,EAAE,EAAE;QACxD,MAAM,EACJ,UAAU,EACV,MAAM,EAAE,eAAe,EACvB,gBAAgB,EAChB,EAAE,EACF,eAAe,GAChB,GAAG,qBAAqB,CAAC,eAAe,CAAC,aAA6D,EAAE,MAAM,CAAC,CAAA;QAEhH,IAAI,eAAe;YACjB,uCACK,MAAM,GACN,eAAe,CAAC,IAAI,CAAC,aAA6D,CAAC,EAAE,QAAQ,CAAC,EAClG;QACH,IAAI,KAAK,CAAC,UAAU,CAAC;YAAE,OAAO,MAAM,CAAA;QACpC,IACE,CAAC,CAAC,gBAAgB;YAClB,CAAC,OAAO,CAAC,gBAAgB,CAAC;YAC1B,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,EAAE,WACN,OAAA,CAAC,CAAA,MAAA,EAAE,CAAyB,IAAI,CAAC,aAA6D,CAAC,CAAC,0CAAG,GAAG,CAAC,CAAA,CAAA,EAAA,CAC1G,CAAC,MAAM;YAER,OAAO,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,MAAM,CACzC,CAAC,MAAM,EAAE,OAAO,EAAE,EAAE;;gBAClB,MAAM,EAAE,UAAU,EAAE,iBAAiB,EAAE,GAAG,qBAAqB,CAAC,eAAe,CAC7E,gBAAgB,CAAC,OAAmD,CAAC,EACrE,MAAM,CACP,CAAA;gBAED,uCACK,MAAM,KACT,CAAC,iBAAiB,CAAC,EAAE,MAAA,IAAI,CAAC,aAAyD,CAAC,0CAAG,OAAO,CAAC,IAChG;YACH,CAAC,oBACI,MAAM,EACZ,CAAA;QAEH,IACE,MAAM;YACN,QAAQ,CAAC,IAAI,CAAC,aAAyD,CAAC,CAAC;YACzE,CAAC,KAAK,CAAC,eAAe,CAAC;YACvB,CAAC,MAAM,CAAC,IAAI,CAAC,aAAyD,CAAC,CAAC;YAExE,OAAO,MAAM,CAAA;QAEf,IACE,CAAC,CAAC,UAAU;YACZ,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC;YAC9B,QAAQ,CAAC,IAAI,CAAC,aAAyD,CAAC,CAAC,EACzE;YACA,MAAM,SAAS,GACb,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,EAAE;gBACtB,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,aAAyD,CAAC,EAAE,QAAQ,CAAC;gBACnF,CAAC,CAAC,IAAI,CAAC,aAAyD,CAAC,CAAA;YAErE,uCACK,MAAM,GACN,CAAC,SAAS,KAAK,SAAS;gBACzB,CAAC,CAAC;oBACE,CAAC,UAAU,CAAC,EAAE;wBACZ,IAAI,EACF,QAAQ,CAAC,aAA6D,CAAC,YAAY,SAAS;4BAC1F,CAAC,CAAC,kBAAkB,CAAC,mBAAmB,CACpC,IAAI,CAAC,aAAyD,CAAC,EAC/D,eAA6C,CAC9C;4BACH,CAAC,CAAC,SAAS;qBAChB;iBACF;gBACH,CAAC,CAAC,EAAE,CAAC,EACR;SACF;QAED,IAAI,CAAC,CAAC,EAAE;YACN,uCACK,MAAM,KACT,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,aAAyD,CAAC,EAAE,QAAQ,CAAC,IAChG;QAEH,uCAAY,MAAM,KAAE,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,aAAyD,CAAC,IAAE;IACrG,CAAC,EAAE,EAAc,CAAC,CAAA;AACpB,CAAC,CAAA;AAEc,qDAAkC,GAAG,CAIlD,SAAiB,EACjB,UAA+B,EAC/B,EAAE;IACF,MAAM,gBAAgB,GAAG,CAAC,CAAC,UAAU,CAAC,OAAO,CAAA;IAE7C,IAAI,gBAAgB;QAClB,OAAO;YACL,SAAS,EAAE,UAAU,CAAC,UAAU,IAAI,SAAS;YAC7C,MAAM,EAAE,kBAAkB,CAAC,iCAAiC,CAAC,UAAU,CAAC,MAAM,CAAC;YAC/E,SAAS,EAAE;gBACT,CAAC,GAAG,UAAU,CAAC,UAAU,QAAQ,CAAC,EAAE;oBAClC,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,UAAU,CAAC,OAAO,CAAC,UAAU;oBACnC,KAAK,EAAE,qBAAqB,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,EAAE,UAAU,CAAC,MAAM,CAAC;oBAC5F,QAAQ,EAAE,IAAI;iBACf;aACF;SACF,CAAA;IAEH,OAAO;QACL,CAAC,UAAU,CAAC,UAAU,IAAI,SAAS,CAAC,EAAE,kBAAkB,CAAC,iCAAiC,CAAC,UAAU,CAAC,MAAM,CAAC;KAC9G,CAAA;AACH,CAAC,CAAA","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,4 @@
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';
@@ -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,7 @@
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';
@@ -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"]}
@@ -0,0 +1,9 @@
1
+ import { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../domain';
2
+ import { MergeConstructorParams, MixinCtor } from '../../../utils';
3
+ import { GraphQLRepository } from '../types';
4
+ export declare type CreateConstructorParams = {
5
+ insertGraphQLOperation?: string;
6
+ insertAllGraphQLOperation?: string;
7
+ insertGraphQLObjectType?: string;
8
+ };
9
+ export declare const withCreateHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>, any[]>>(MixinBase: MixinCtor<GraphQLRepository<MBase>, any[]> & TMixinBase) => MixinCtor<GraphQLRepository<MBase> & InstanceType<TMixinBase> & CreateRepository<MBase, CreateRepositoryParams<MBase>>, MergeConstructorParams<[CreateConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>>;
@@ -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,11 @@
1
+ import { CrudRepository, ModelBaseStructure } from '../../../domain';
2
+ import { MergeConstructorParams, MixinCtor } from '../../../utils';
3
+ import { GraphQLRepository } from '../types';
4
+ import { CreateConstructorParams } from './with-create-hasura-graphql.mixin';
5
+ import { DeleteConstructorParams } from './with-delete-hasura-graphql.mixin';
6
+ import { GetConstructorParams } from './with-get-hasura-graphql.mixin';
7
+ import { HasuraConstructorParams } from './with-hasura-graphql.mixin';
8
+ import { UpdateConstructorParams, UpdateHasuraGraphQLRepositoryType } from './with-update-hasura-graphql.mixin';
9
+ export declare const withCrudHasuraGraphQL: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, Repository = CrudRepository<TBase, import("../../../domain").CrudParams<TBase>>, TMixinBase extends MixinCtor<any, any[]> = MixinCtor<any, any[]>>(MixinBase: MixinCtor<GraphQLRepository<TBase>, any[]> & TMixinBase) => MixinCtor<GraphQLRepository<TBase> & Repository & import("../../../domain").UpdateRepository<TBase, import("../../../domain").RepositoryUpdateParams<TBase>> & {
10
+ paramsToPlain(params: import("../../../domain").RepositoryUpdateParams<TBase>): Partial<TBase>;
11
+ }, MergeConstructorParams<[HasuraConstructorParams<TBase> & CreateConstructorParams & DeleteConstructorParams & GetConstructorParams & UpdateConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>>;
@@ -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"]}
@@ -0,0 +1,7 @@
1
+ import { DeleteRepository, DeleteRepositoryParams, ModelBaseStructure } from '../../../domain';
2
+ import { MergeConstructorParams, MixinCtor } from '../../../utils';
3
+ import { GraphQLRepository } from '../types';
4
+ export declare type DeleteConstructorParams = {
5
+ deleteGraphQLOperation?: string;
6
+ };
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,34 @@
1
+ import { FindRepositoryParams, ModelBaseStructure, NonFunctionAndIdentifierPropertyNames, RepositoryFindResult, RepositoryOrderBy } from '../../../domain';
2
+ import { DebugHelper, MixinCtor } from '../../../utils';
3
+ import { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types';
4
+ export declare const withFindHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>, any[]>>(MixinBase: MixinCtor<GraphQLRepository<MBase>, any[]> & TMixinBase) => {
5
+ new (...args: any[]): {
6
+ find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>>;
7
+ bindOrderByAttributes: (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) => any[];
8
+ bindAggretageAttributes: (aggregates: {
9
+ minimal?: ({} | NonFunctionAndIdentifierPropertyNames<MBase>)[];
10
+ maximum?: ({} | NonFunctionAndIdentifierPropertyNames<MBase>)[];
11
+ }, fields: HasuraGraphQLFields<MBase>) => ({
12
+ min: {}[];
13
+ max?: undefined;
14
+ } | {
15
+ max: {}[];
16
+ min?: undefined;
17
+ })[];
18
+ bindDistinctAttributes: (distinct: ({} | NonFunctionAndIdentifierPropertyNames<MBase>)[], fields: HasuraGraphQLFields<MBase>) => {}[];
19
+ bindAttributesToColumns: (attributes: ({} | NonFunctionAndIdentifierPropertyNames<MBase>)[], fields: HasuraGraphQLFields<MBase>) => {}[];
20
+ tableName: string;
21
+ model: import("../../../domain").BaseModelBuilder<MBase, any, MBase & {
22
+ prototype: unknown;
23
+ }>;
24
+ fields: HasuraGraphQLFields<MBase>;
25
+ endpoint: string;
26
+ authOptions: import("../types").HasuraGraphQLAuthOptions;
27
+ logger: DebugHelper;
28
+ mutation: <ReturnFields = any>(operation: string | import("gql-query-builder/build/IQueryBuilderOptions").IOperation, fields?: string[] | HasuraGraphQLFields<MBase>, variables?: import("../types").VariableOptions) => Promise<ReturnFields>;
29
+ query: <ReturnFields_1 = any>(operation: string | import("gql-query-builder/build/IQueryBuilderOptions").IOperation | GraphQLParams<MBase>[], fields?: string[] | HasuraGraphQLFields<MBase>, variables?: import("../types").VariableOptions) => Promise<ReturnFields_1>;
30
+ getAttributeGraphQLTypeOf: <FieldValue>(value: FieldValue) => string;
31
+ convertDataFromHasura(data: Record<string, string | number>, fields?: string[] | HasuraGraphQLFields<MBase>): MBase;
32
+ convertDataToHasura(instance: MBase, update?: boolean): Record<string, string | number>;
33
+ };
34
+ } & TMixinBase;
@@ -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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-find-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n FindRepository,\r\n FindRepositoryParams,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n RepositoryFindResult,\r\n RepositoryOrderBy,\r\n} from '../../../domain'\r\nimport { DebugHelper, isNil, MixinCtor, set } from '../../../utils'\r\nimport { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types'\r\nimport { AttributeOptionHelper, BindFilterQueryHelper } from './helpers'\r\n\r\nexport const withFindHasuraGraphQL = <\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) => {\r\n return class FindHasuraGraphQLMixin extends MixinBase implements FindRepository<MBase> {\r\n async find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>> {\r\n this.logger = DebugHelper.from(this, 'find')\r\n\r\n const { filters, limits, orderBy, options } = params || {}\r\n const enableCount = options?.enableCount ?? true\r\n const variablesFilters = isNil(filters)\r\n ? {}\r\n : {\r\n where: {\r\n value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),\r\n type: `${this.tableName}_bool_exp`,\r\n required: true,\r\n },\r\n }\r\n const variablesCount = {\r\n ...(isNil(orderBy)\r\n ? {}\r\n : {\r\n order_by: {\r\n type: `${this.tableName}_order_by!`,\r\n list: true,\r\n value: this.bindOrderByAttributes(orderBy, this.fields),\r\n },\r\n }),\r\n ...variablesFilters,\r\n }\r\n const variables = {\r\n ...(isNil(limits) ? {} : limits),\r\n ...variablesCount,\r\n }\r\n const aggregateFields = [\r\n ...(enableCount ? ['count'] : []),\r\n ...this.bindAggretageAttributes(params.options, this.fields),\r\n ]\r\n const result = await this.query([\r\n {\r\n operation: this.tableName,\r\n fields: params.fields\r\n ? params.fields\r\n .map(\r\n (fieldName) =>\r\n this.fields.find((fieldOption) => fieldOption === fieldName) ??\r\n this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName),\r\n )\r\n .filter(Boolean)\r\n : this.fields,\r\n variables,\r\n },\r\n ...(aggregateFields.length > 0\r\n ? [\r\n {\r\n operation: `${this.tableName}_aggregate`,\r\n fields: [\r\n {\r\n aggregate: aggregateFields,\r\n },\r\n ],\r\n variables: variablesCount,\r\n } as GraphQLParams<MBase>,\r\n ]\r\n : []),\r\n ...((!params.limits?.offset &&\r\n params.options?.distinct?.map((distinct) => {\r\n const distinctOption =\r\n this.fields.find((fieldOption) => fieldOption === distinct) ??\r\n this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct)\r\n const fieldName = Object.values(distinctOption).shift()?.columnName || distinct\r\n\r\n return {\r\n operation: {\r\n name: `${this.tableName}`,\r\n alias: `${this.tableName}_${distinct.toString()}_distinct`,\r\n },\r\n fields: [distinctOption],\r\n variables: {\r\n ...variablesFilters,\r\n [`${this.tableName}_${fieldName}_distinct`]: {\r\n type: `${this.tableName}_select_column!`,\r\n list: true,\r\n value: fieldName,\r\n name: 'distinct_on',\r\n },\r\n },\r\n } as GraphQLParams<MBase>\r\n })) ||\r\n []),\r\n ])\r\n const data: MBase[] = result[this.tableName].map((row: Record<string, string | number>) =>\r\n this.convertDataFromHasura(row),\r\n )\r\n\r\n return {\r\n data,\r\n count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity,\r\n ...(options?.minimal?.length\r\n ? {\r\n minimal: options.minimal.reduce(\r\n (minimals, current) => ({\r\n ...(minimals as any),\r\n ...set(\r\n minimals as any,\r\n current as any,\r\n result[`${this.tableName}_aggregate`].aggregate.min[\r\n AttributeOptionHelper.FindByAttribute(\r\n current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n this.fields,\r\n )?.columnName || (current as any)\r\n ],\r\n ),\r\n }),\r\n {},\r\n ) as RepositoryFindResult<MBase>['minimal'],\r\n }\r\n : {}),\r\n ...(options?.maximum?.length\r\n ? {\r\n maximum: options.maximum.reduce(\r\n (maximums, current) => ({\r\n ...(maximums as any),\r\n ...set(\r\n maximums as any,\r\n current as any,\r\n result[`${this.tableName}_aggregate`].aggregate.max[\r\n AttributeOptionHelper.FindByAttribute(\r\n current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n this.fields,\r\n )?.columnName || (current as any)\r\n ],\r\n ),\r\n }),\r\n {},\r\n ) as RepositoryFindResult<MBase>['maximum'],\r\n }\r\n : {}),\r\n ...(!params.limits?.offset &&\r\n options?.distinct?.length && {\r\n distinct: options?.distinct.reduce((distinct, current) => {\r\n const distinctOption =\r\n this.fields.find((fieldOption) => fieldOption === current) ??\r\n this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current)\r\n const fieldName = Object.values(distinctOption).shift()?.columnName || current\r\n\r\n return {\r\n ...distinct,\r\n [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map(\r\n (obj: Record<string, string | number>) => obj[fieldName],\r\n ),\r\n }\r\n }, {} as any),\r\n }),\r\n }\r\n }\r\n\r\n bindOrderByAttributes = (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) =>\r\n Object.keys(orderBy).reduce(\r\n (acc, current) => [\r\n ...acc,\r\n {\r\n [AttributeOptionHelper.FindByAttribute(current as NonFunctionAndIdentifierPropertyNames<MBase>, fields)\r\n .columnName]:\r\n orderBy[current as NonFunctionAndIdentifierPropertyNames<MBase>] === 'asc'\r\n ? 'asc_nulls_last'\r\n : 'desc_nulls_last',\r\n },\r\n ],\r\n [],\r\n )\r\n\r\n bindAggretageAttributes = (\r\n aggregates: {\r\n minimal?: FindRepositoryParams<MBase>['options']['minimal']\r\n maximum?: FindRepositoryParams<MBase>['options']['maximum']\r\n },\r\n fields: HasuraGraphQLFields<MBase>,\r\n ) => [\r\n ...(aggregates?.minimal?.length\r\n ? [\r\n {\r\n min: this.bindAttributesToColumns(aggregates?.minimal, fields),\r\n },\r\n ]\r\n : []),\r\n ...(aggregates?.maximum?.length\r\n ? [\r\n {\r\n max: this.bindAttributesToColumns(aggregates?.maximum, fields),\r\n },\r\n ]\r\n : []),\r\n ]\r\n\r\n bindDistinctAttributes = (\r\n distinct: FindRepositoryParams<MBase>['options']['distinct'],\r\n fields: HasuraGraphQLFields<MBase>,\r\n ) => this.bindAttributesToColumns(distinct, fields)\r\n\r\n bindAttributesToColumns = (\r\n attributes: Array<NonFunctionAndIdentifierPropertyNames<MBase> | {}>,\r\n fields: HasuraGraphQLFields<MBase>,\r\n ) =>\r\n attributes.map(\r\n (attr) =>\r\n AttributeOptionHelper.FindByAttribute(\r\n attr.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n fields,\r\n )?.columnName || attr,\r\n )\r\n }\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { GetRepositoryParams, ModelBaseStructure } from '../../../domain';
2
+ import { DebugHelper, MixinCtor } from '../../../utils';
3
+ import { GraphQLRepository } from '../types';
4
+ export declare type GetConstructorParams = {
5
+ getGraphQLOperation?: string;
6
+ };
7
+ export declare const withGetHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>, any[]>>(MixinBase: MixinCtor<GraphQLRepository<MBase>, any[]> & TMixinBase) => {
8
+ new (...params: any[]): {
9
+ getGraphQLOperation: string;
10
+ get(identifiers: GetRepositoryParams<MBase>): Promise<MBase>;
11
+ tableName: string;
12
+ model: import("../../../domain").BaseModelBuilder<MBase, any, MBase & {
13
+ prototype: unknown;
14
+ }>;
15
+ fields: import("../types").HasuraGraphQLFields<MBase>;
16
+ endpoint: string;
17
+ authOptions: import("../types").HasuraGraphQLAuthOptions;
18
+ logger: DebugHelper;
19
+ mutation: <ReturnFields = any>(operation: string | import("gql-query-builder/build/IQueryBuilderOptions").IOperation, fields?: string[] | import("../types").HasuraGraphQLFields<MBase>, variables?: import("../types").VariableOptions) => Promise<ReturnFields>;
20
+ query: <ReturnFields_1 = any>(operation: string | import("gql-query-builder/build/IQueryBuilderOptions").IOperation | import("../types").GraphQLParams<MBase>[], fields?: string[] | import("../types").HasuraGraphQLFields<MBase>, variables?: import("../types").VariableOptions) => Promise<ReturnFields_1>;
21
+ getAttributeGraphQLTypeOf: <FieldValue>(value: FieldValue) => string;
22
+ convertDataFromHasura(data: Record<string, string | number>, fields?: string[] | import("../types").HasuraGraphQLFields<MBase>): MBase;
23
+ convertDataToHasura(instance: MBase, update?: boolean): Record<string, string | number>;
24
+ };
25
+ } & TMixinBase;
@@ -0,0 +1,35 @@
1
+ import { NotFoundError } from '../../../errors';
2
+ import { DebugHelper, isNil } from '../../../utils';
3
+ import { AttributeOptionHelper } from './helpers';
4
+ export const withGetHasuraGraphQL = (MixinBase) => {
5
+ return class GetHasuraGraphQLMixin extends MixinBase {
6
+ constructor(...params) {
7
+ const options = params === null || params === void 0 ? void 0 : params[0];
8
+ super(...params);
9
+ this.getGraphQLOperation = (options === null || options === void 0 ? void 0 : options.getGraphQLOperation) || `${this.tableName}_by_pk`;
10
+ }
11
+ async get(identifiers) {
12
+ this.logger = DebugHelper.from(this, 'get');
13
+ const instance = this.model.toInstance(identifiers);
14
+ const result = await this.query(this.getGraphQLOperation, this.fields, this.model.identifiersFields.reduce((ids, identifier) => {
15
+ var _a;
16
+ const identifierBinded = identifier;
17
+ if (isNil(instance[identifierBinded]))
18
+ return ids;
19
+ const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields);
20
+ const value = ((_a = columnOption === null || columnOption === void 0 ? void 0 : columnOption.to) === null || _a === void 0 ? void 0 : _a.call(columnOption, identifiers[identifier], instance)) ||
21
+ identifiers[identifier];
22
+ return Object.assign(Object.assign({}, ids), { [columnOption.columnName]: {
23
+ type: this.getAttributeGraphQLTypeOf(columnOption.type || value),
24
+ value,
25
+ required: true,
26
+ } });
27
+ }, {}));
28
+ const data = result[this.getGraphQLOperation];
29
+ if (isNil(data))
30
+ throw new NotFoundError(`${instance.constructor.name} not found`);
31
+ return this.convertDataFromHasura(result[this.getGraphQLOperation]);
32
+ }
33
+ };
34
+ };
35
+ //# sourceMappingURL=with-get-hasura-graphql.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-get-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAa,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAG9D,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAMjD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAIlC,SAA2D,EAC3D,EAAE;IACF,OAAO,MAAM,qBAAsB,SAAQ,SAAS;QAGlD,YAAY,GAAG,MAAa;YAC1B,MAAM,OAAO,GAAyB,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,CAAC,CAAC,CAAA;YAEjD,KAAK,CAAC,GAAG,MAAM,CAAC,CAAA;YAEhB,IAAI,CAAC,mBAAmB,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,mBAAmB,KAAI,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAA;QACtF,CAAC;QAED,KAAK,CAAC,GAAG,CAAC,WAAuC;YAC/C,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;YAE3C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;YACnD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAC7B,IAAI,CAAC,mBAAmB,EACxB,IAAI,CAAC,MAAM,EACX,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,gBAAgB,CAAC,CAAC;oBAAE,OAAO,GAAG,CAAA;gBAEjD,MAAM,YAAY,GAAG,qBAAqB,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;gBACnF,MAAM,KAAK,GACT,CAAA,MAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,EAAE,6DAAG,WAAW,CAAC,UAAsC,CAAC,EAAE,QAAQ,CAAC;oBACjF,WAAW,CAAC,UAAsC,CAAC,CAAA;gBAErD,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;YACD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAA;YAE7C,IAAI,KAAK,CAAC,IAAI,CAAC;gBAAE,MAAM,IAAI,aAAa,CAAC,GAAG,QAAQ,CAAC,WAAW,CAAC,IAAI,YAAY,CAAC,CAAA;YAElF,OAAO,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAA;QACrE,CAAC;KACF,CAAA;AACH,CAAC,CAAA","sourcesContent":["import {\r\n GetRepository,\r\n GetRepositoryParams,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n} from '../../../domain'\r\nimport { NotFoundError } from '../../../errors'\r\nimport { DebugHelper, MixinCtor, isNil } from '../../../utils'\r\nimport { GraphQLRepository } from '../types'\r\n\r\nimport { AttributeOptionHelper } from './helpers'\r\n\r\nexport type GetConstructorParams = {\r\n getGraphQLOperation?: string\r\n}\r\n\r\nexport const withGetHasuraGraphQL = <\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) => {\r\n return class GetHasuraGraphQLMixin extends MixinBase implements GetRepository<MBase> {\r\n getGraphQLOperation: string\r\n\r\n constructor(...params: any[]) {\r\n const options: GetConstructorParams = params?.[0]\r\n\r\n super(...params)\r\n\r\n this.getGraphQLOperation = options?.getGraphQLOperation || `${this.tableName}_by_pk`\r\n }\r\n\r\n async get(identifiers: GetRepositoryParams<MBase>): Promise<MBase> {\r\n this.logger = DebugHelper.from(this, 'get')\r\n\r\n const instance = this.model.toInstance(identifiers)\r\n const result = await this.query(\r\n this.getGraphQLOperation,\r\n this.fields,\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[identifierBinded])) return ids\r\n\r\n const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields)\r\n const value =\r\n columnOption?.to?.(identifiers[identifier as keyof typeof identifiers], instance) ||\r\n identifiers[identifier as keyof typeof identifiers]\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 const data = result[this.getGraphQLOperation]\r\n\r\n if (isNil(data)) throw new NotFoundError(`${instance.constructor.name} not found`)\r\n\r\n return this.convertDataFromHasura(result[this.getGraphQLOperation])\r\n }\r\n }\r\n}\r\n"]}
@@ -0,0 +1,23 @@
1
+ import { IOperation } from 'gql-query-builder/build/IQueryBuilderOptions';
2
+ import { BaseModelBuilder, ModelBaseStructure } from '../../../domain';
3
+ import { MergeConstructorParams, MixinCtor } from '../../../utils';
4
+ import { Fields, GraphQLRepository, HasuraGraphQLAuthOptions, HasuraGraphQLFields, VariableOptions } from '../types';
5
+ declare type QueryBuilderOptions = {
6
+ operation: string | IOperation;
7
+ fields: Fields;
8
+ variables?: VariableOptions;
9
+ };
10
+ declare type HasuraGraphQLInterceptors<P = QueryBuilderOptions | QueryBuilderOptions[]> = {
11
+ request?: <R>(request: P) => Promise<P & R>;
12
+ response?: <R>(response: R, request: P) => Promise<R>;
13
+ };
14
+ export declare type HasuraConstructorParams<Model extends ModelBaseStructure<Model, Model['identifiersFields'][number]>> = {
15
+ tableName: string;
16
+ model: BaseModelBuilder<Model>;
17
+ fields: HasuraGraphQLFields<Model>;
18
+ endpoint: string;
19
+ interceptors?: HasuraGraphQLInterceptors;
20
+ authOptions: HasuraGraphQLAuthOptions;
21
+ };
22
+ export declare const withHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, T extends MixinCtor<any, any[]> = MixinCtor<any, any[]>>(MixinBase: T) => MixinCtor<GraphQLRepository<MBase>, any[]>;
23
+ export {};