@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,33 @@
1
+ import { addDoc, doc, getDoc, setDoc } from 'firebase/firestore';
2
+ import { isEmpty } from '../../../../utils';
3
+ export const withCreateFirestore = (MixinBase) => {
4
+ return class CreateFirestore extends MixinBase {
5
+ async create(data) {
6
+ var _a, _b, _c, _d;
7
+ const instance = this.model.toInstance(data);
8
+ const intercepted = await ((_b = (_a = this.interceptors) === null || _a === void 0 ? void 0 : _a.request) === null || _b === void 0 ? void 0 : _b.call(_a, { instance }));
9
+ const builded = (intercepted === null || intercepted === void 0 ? void 0 : intercepted.instance) || instance;
10
+ const docRef = await this.save(builded);
11
+ const doc = await getDoc(docRef);
12
+ const docBuilded = (await ((_d = (_c = this.interceptors) === null || _c === void 0 ? void 0 : _c.response) === null || _d === void 0 ? void 0 : _d.call(_c, doc.data(), intercepted))) || doc.data();
13
+ return docBuilded;
14
+ }
15
+ async save(data) {
16
+ var _a, _b;
17
+ const id = (_b = (_a = Object.values(data.identifier)) === null || _a === void 0 ? void 0 : _a.shift()) === null || _b === void 0 ? void 0 : _b.toString();
18
+ const collectionPath = this.buildCollectionPathForAdd(data);
19
+ const collection = this.collection(collectionPath);
20
+ if (isEmpty(id))
21
+ return addDoc(collection, data);
22
+ const docRef = doc(collection, id);
23
+ await setDoc(docRef, data);
24
+ return docRef;
25
+ }
26
+ buildCollectionPathForAdd(identifiers) {
27
+ return this.isSubCollection(this)
28
+ ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`
29
+ : this.collectionName;
30
+ }
31
+ };
32
+ };
33
+ //# sourceMappingURL=with-create-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-create-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,GAAG,EAAqB,MAAM,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAGnF,OAAO,EAAE,OAAO,EAAa,MAAM,mBAAmB,CAAA;AAGtD,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAIjC,SAAgF,EAIhF,EAAE;IACF,OAAO,MAAM,eAAgB,SAAQ,SAAS;QAC5C,KAAK,CAAC,MAAM,CAAC,IAAmC;;YAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAW,CAAC,CAAA;YACnD,MAAM,WAAW,GAAG,MAAM,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,mDAAG,EAAE,QAAQ,EAAE,CAAC,CAAA,CAAA;YACpE,MAAM,OAAO,GAAG,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,KAAI,QAAQ,CAAA;YACjD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;YACvC,MAAM,GAAG,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,CAAA;YAChC,MAAM,UAAU,GAAG,CAAC,MAAM,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,QAAQ,mDAAG,GAAG,CAAC,IAAI,EAAE,EAAE,WAAW,CAAC,CAAA,CAAC,IAAI,GAAG,CAAC,IAAI,EAAE,CAAA;YAE/F,OAAO,UAAU,CAAA;QACnB,CAAC;QAED,KAAK,CAAC,IAAI,CAAC,IAAW;;YACpB,MAAM,EAAE,GAAG,MAAA,MAAA,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,0CAAE,KAAK,EAAE,0CAAE,QAAQ,EAAE,CAAA;YAC9D,MAAM,cAAc,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,CAAA;YAC3D,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,CAAA;YAElD,IAAI,OAAO,CAAC,EAAE,CAAC;gBAAE,OAAO,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;YAEhD,MAAM,MAAM,GAAG,GAAG,CAAC,UAAU,EAAE,EAAE,CAAC,CAAA;YAClC,MAAM,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;YAE1B,OAAO,MAAM,CAAA;QACf,CAAC;QAED,yBAAyB,CAAC,WAA2B;YACnD,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBAC/B,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,IAAI,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE;gBACrG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAA;QACzB,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import { addDoc, doc, DocumentReference, getDoc, setDoc } from 'firebase/firestore'\r\n\r\nimport { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../../domain'\r\nimport { isEmpty, MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\n\r\nexport const withCreateFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<\r\n FirestoreRepository<TBase> & InstanceType<TMixinBase> & CreateRepository<TBase> & FirestoreHelpers,\r\n []\r\n> => {\r\n return class CreateFirestore extends MixinBase implements CreateRepository<TBase> {\r\n async create(data: CreateRepositoryParams<TBase>): Promise<TBase> {\r\n const instance = this.model.toInstance(data as any)\r\n const intercepted = await this.interceptors?.request?.({ instance })\r\n const builded = intercepted?.instance || instance\r\n const docRef = await this.save(builded)\r\n const doc = await getDoc(docRef)\r\n const docBuilded = (await this.interceptors?.response?.(doc.data(), intercepted)) || doc.data()\r\n\r\n return docBuilded\r\n }\r\n\r\n async save(data: TBase): Promise<DocumentReference<TBase>> {\r\n const id = Object.values(data.identifier)?.shift()?.toString()\r\n const collectionPath = this.buildCollectionPathForAdd(data)\r\n const collection = this.collection(collectionPath)\r\n\r\n if (isEmpty(id)) return addDoc(collection, data)\r\n\r\n const docRef = doc(collection, id)\r\n await setDoc(docRef, data)\r\n\r\n return docRef\r\n }\r\n\r\n buildCollectionPathForAdd(identifiers: Partial<TBase>): string {\r\n return this.isSubCollection(this)\r\n ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`\r\n : this.collectionName\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,5 @@
1
+ import { CrudRepository, ModelBaseStructure } from '../../../../domain';
2
+ import { MergeConstructorParams, MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository } from '../types';
4
+ import { FirestoreConstructorParams } from './with-firestore.mixin';
5
+ export declare const withCrudFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, Repository = CrudRepository<TBase, import("../../../../domain").CrudParams<TBase>>, TMixinBase extends MixinCtor<any, any[]> = MixinCtor<any, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers, any[]> & TMixinBase) => MixinCtor<FirestoreRepository<TBase> & Repository & FirestoreHelpers, MergeConstructorParams<[FirestoreConstructorParams<TBase>, ...any[]], ConstructorParameters<TMixinBase>>>;
@@ -0,0 +1,10 @@
1
+ import { withCreateFirestore } from './with-create-firestore.mixin';
2
+ import { withDeleteFirestore } from './with-delete-firestore.mixin';
3
+ import { withFindFirestore } from './with-find-firestore.mixin';
4
+ import { withGetFirestore } from './with-get-firestore.mixin';
5
+ import { withUpdateFirestore } from './with-update-firestore.mixin';
6
+ export const withCrudFirestore = (MixinBase) => {
7
+ return class CrudFirestore extends withUpdateFirestore(withGetFirestore(withFindFirestore(withDeleteFirestore(withCreateFirestore(MixinBase))))) {
8
+ };
9
+ };
10
+ //# sourceMappingURL=with-crud-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-crud-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAA;AACnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAA;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAA;AAE/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAA;AAEnE,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAK/B,SAAgF,EAIhF,EAAE;IACF,OAAO,MAAM,aACX,SAAQ,mBAAmB,CACzB,gBAAgB,CACd,iBAAiB,CACf,mBAAmB,CACjB,mBAAmB,CAAC,SAAqE,CAAC,CAC3F,CACF,CACF,CACF;KACyC,CAAA;AAC9C,CAAC,CAAA","sourcesContent":["import { CrudRepository, ModelBaseStructure } from '../../../../domain'\r\nimport { MergeConstructorParams, MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\nimport { withCreateFirestore } from './with-create-firestore.mixin'\r\nimport { withDeleteFirestore } from './with-delete-firestore.mixin'\r\nimport { withFindFirestore } from './with-find-firestore.mixin'\r\nimport { FirestoreConstructorParams } from './with-firestore.mixin'\r\nimport { withGetFirestore } from './with-get-firestore.mixin'\r\nimport { withUpdateFirestore } from './with-update-firestore.mixin'\r\n\r\nexport const withCrudFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n Repository = CrudRepository<TBase>,\r\n TMixinBase extends MixinCtor = MixinCtor,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<\r\n FirestoreRepository<TBase> & Repository & FirestoreHelpers,\r\n MergeConstructorParams<[FirestoreConstructorParams<TBase>, ...any[]], ConstructorParameters<TMixinBase>>\r\n> => {\r\n return class CrudFirestore\r\n extends withUpdateFirestore(\r\n withGetFirestore(\r\n withFindFirestore(\r\n withDeleteFirestore(\r\n withCreateFirestore(MixinBase as MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers>),\r\n ),\r\n ),\r\n ),\r\n )\r\n implements CrudRepository<TBase> {} as any\r\n}\r\n"]}
@@ -0,0 +1,4 @@
1
+ import { DeleteRepository, DeleteRepositoryParams, ModelBaseStructure } from '../../../../domain';
2
+ import { MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository } from '../types';
4
+ export declare const withDeleteFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<FirestoreRepository<TBase>, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers, any[]> & TMixinBase) => MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & DeleteRepository<TBase, DeleteRepositoryParams<TBase>> & FirestoreHelpers, []>;
@@ -0,0 +1,19 @@
1
+ import { deleteDoc, doc } from 'firebase/firestore';
2
+ export const withDeleteFirestore = (MixinBase) => {
3
+ return class DeleteFirestore extends MixinBase {
4
+ async delete(identifiers) {
5
+ var _a, _b, _c, _d;
6
+ const instance = this.model.toInstance(this.model.identifiersFields.reduce((acc, field) => (Object.assign(Object.assign({}, acc), { [field]: identifiers[field] })), {}));
7
+ const intercepted = await ((_b = (_a = this.interceptors) === null || _a === void 0 ? void 0 : _a.request) === null || _b === void 0 ? void 0 : _b.call(_a, { instance }));
8
+ const builded = (intercepted === null || intercepted === void 0 ? void 0 : intercepted.instance) || instance;
9
+ await deleteDoc(doc(this.collection(this.buildCollectionPathForRemove(identifiers)), Object.values(builded.identifier).shift().toString()));
10
+ await ((_d = (_c = this.interceptors) === null || _c === void 0 ? void 0 : _c.response) === null || _d === void 0 ? void 0 : _d.call(_c, instance, intercepted));
11
+ }
12
+ buildCollectionPathForRemove(identifiers) {
13
+ return this.isSubCollection(this)
14
+ ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`
15
+ : this.collectionName;
16
+ }
17
+ };
18
+ };
19
+ //# sourceMappingURL=with-delete-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-delete-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAA;AAMnD,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAIjC,SAAgF,EAIhF,EAAE;IACF,OAAO,MAAM,eAAgB,SAAQ,SAAS;QAC5C,KAAK,CAAC,MAAM,CAAC,WAA0C;;YACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CACpC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CACjC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,iCAAM,GAAG,KAAE,CAAC,KAAK,CAAC,EAAE,WAAW,CAAC,KAAsC,CAAC,IAAG,EAC1F,EAAE,CACH,CACF,CAAA;YACD,MAAM,WAAW,GAAG,MAAM,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,mDAAG,EAAE,QAAQ,EAAE,CAAC,CAAA,CAAA;YACpE,MAAM,OAAO,GAAG,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,KAAI,QAAQ,CAAA;YAEjD,MAAM,SAAS,CACb,GAAG,CACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,4BAA4B,CAAC,WAAW,CAAC,CAAC,EAC/D,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,CACrD,CACF,CAAA;YAED,MAAM,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,QAAQ,mDAAG,QAAQ,EAAE,WAAW,CAAC,CAAA,CAAA;QAC5D,CAAC;QAED,4BAA4B,CAAC,WAAoC;YAC/D,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBAC/B,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,IAAI,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE;gBACrG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAA;QACzB,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import { deleteDoc, doc } from 'firebase/firestore'\r\n\r\nimport { DeleteRepository, DeleteRepositoryParams, IdentifiersModel, ModelBaseStructure } from '../../../../domain'\r\nimport { MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\n\r\nexport const withDeleteFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<\r\n FirestoreRepository<TBase> & InstanceType<TMixinBase> & DeleteRepository<TBase> & FirestoreHelpers,\r\n []\r\n> => {\r\n return class DeleteFirestore extends MixinBase implements DeleteRepository<TBase> {\r\n async delete(identifiers: DeleteRepositoryParams<TBase>): Promise<void> {\r\n const instance = this.model.toInstance(\r\n this.model.identifiersFields.reduce(\r\n (acc, field) => ({ ...acc, [field]: identifiers[field as keyof IdentifiersModel<TBase>] }),\r\n {},\r\n ),\r\n )\r\n const intercepted = await this.interceptors?.request?.({ instance })\r\n const builded = intercepted?.instance || instance\r\n\r\n await deleteDoc(\r\n doc(\r\n this.collection(this.buildCollectionPathForRemove(identifiers)),\r\n Object.values(builded.identifier).shift().toString(),\r\n ),\r\n )\r\n\r\n await this.interceptors?.response?.(instance, intercepted)\r\n }\r\n\r\n buildCollectionPathForRemove(identifiers: IdentifiersModel<TBase>): string {\r\n return this.isSubCollection(this)\r\n ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`\r\n : this.collectionName\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,4 @@
1
+ import { FindRepository, ModelBaseStructure } from '../../../../domain';
2
+ import { MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository } from '../types';
4
+ export declare const withFindFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<FirestoreRepository<TBase>, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers, any[]> & TMixinBase) => MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & FindRepository<TBase, import("../../../../domain").FindRepositoryParams<TBase>> & FirestoreHelpers, []>;
@@ -0,0 +1,109 @@
1
+ import { doc, getDoc, getDocs, limit, orderBy, query, startAfter, startAt, where, } from 'firebase/firestore';
2
+ import { Where, } from '../../../../domain';
3
+ import { is, isDate, isNil, isNumber, isObject, isString, set } from '../../../../utils';
4
+ import { FirestoreFieldType } from '../enums';
5
+ export const withFindFirestore = (MixinBase) => {
6
+ const checkIfIsFilterOption = (filter) => !isNil(filter === null || filter === void 0 ? void 0 : filter.operator);
7
+ const getValueFromFilter = (filter) => {
8
+ return checkIfIsFilterOption(filter) ? filter.value : filter;
9
+ };
10
+ const getFinalValueFrom = (value) => isNumber(value) || isString(value) || isDate(value) || Array.isArray(value)
11
+ ? value
12
+ : Object.values(getFinalValueFrom);
13
+ return class FindFirestore extends MixinBase {
14
+ constructor() {
15
+ super(...arguments);
16
+ this.makeFirestoreWhere = (filter) => Object.keys(filter).reduce((queries, fieldName) => [
17
+ ...queries,
18
+ ...this.buildWhereSentence(fieldName, is(filter[fieldName])),
19
+ ], []);
20
+ this.buildWhereSentence = (fieldName, options) => {
21
+ if (this.isSubCollection(this) && fieldName === this.parentIdField)
22
+ return [];
23
+ const value = (options === null || options === void 0 ? void 0 : options.value) || options;
24
+ const object = {};
25
+ set(object, fieldName, value);
26
+ const plainInstance = new this.model(object).toPlain();
27
+ const firestoreFieldName = fieldName.toString().indexOf('.') > -1
28
+ ? fieldName.toString()
29
+ : Object.keys(plainInstance).find((key) => plainInstance[key]);
30
+ if ((options === null || options === void 0 ? void 0 : options.operator) === Where.LIKE) {
31
+ if (Array.isArray(options === null || options === void 0 ? void 0 : options.value) &&
32
+ (this.fields[firestoreFieldName] ===
33
+ FirestoreFieldType.Array ||
34
+ !this.fields[firestoreFieldName]))
35
+ return [where(firestoreFieldName, 'array-contains-any', options.value)];
36
+ return [where(firestoreFieldName, '>=', options.value), where(firestoreFieldName, '<=', `${options.value}~`)];
37
+ }
38
+ if ((options === null || options === void 0 ? void 0 : options.operator) === Where.IN &&
39
+ Array.isArray(options === null || options === void 0 ? void 0 : options.value) &&
40
+ (this.fields[firestoreFieldName] === FirestoreFieldType.Array ||
41
+ !this.fields[firestoreFieldName]))
42
+ return [where(firestoreFieldName, 'array-contains', options.value)];
43
+ if (isObject(options) && isNil(options === null || options === void 0 ? void 0 : options.operator) && isNil(options === null || options === void 0 ? void 0 : options.value)) {
44
+ return Object.keys(options).reduce((queries, key) => [
45
+ ...queries,
46
+ ...this.buildWhereSentence(`${fieldName.toString()}.${key}`, is(options)[key]),
47
+ ], []);
48
+ }
49
+ return [where(firestoreFieldName, (options === null || options === void 0 ? void 0 : options.operator) || '==', (options === null || options === void 0 ? void 0 : options.value) || options)];
50
+ };
51
+ this.makeFirestoreOrderBy = (filters, fieldsToOrderBy) => {
52
+ const orderByKeys = Object.keys(fieldsToOrderBy || {});
53
+ if (!orderByKeys.length)
54
+ return [];
55
+ const filtersKeysWithUnordered = Object.keys(filters || {}).filter((filterKey) => !orderByKeys.includes(filterKey));
56
+ if (filtersKeysWithUnordered.length)
57
+ filtersKeysWithUnordered.forEach((filterKey) => (fieldsToOrderBy = Object.assign(Object.assign({}, (![Where.EQUALS].includes(is(filters[filterKey]).operator)
58
+ ? { [filterKey]: 'asc' }
59
+ : {})), fieldsToOrderBy)));
60
+ return Object.keys(fieldsToOrderBy).map((fieldName) => orderBy(fieldName, fieldsToOrderBy[fieldName]));
61
+ };
62
+ }
63
+ async find(find = {}) {
64
+ var _a, _b, _c, _d, _e, _f;
65
+ const collection = this.collection(this.buildCollectionPathForFind(find.filters));
66
+ const enableCount = (_b = (_a = find === null || find === void 0 ? void 0 : find.options) === null || _a === void 0 ? void 0 : _a.enableCount) !== null && _b !== void 0 ? _b : true;
67
+ const intercepted = await ((_d = (_c = this.interceptors) === null || _c === void 0 ? void 0 : _c.request) === null || _d === void 0 ? void 0 : _d.call(_c, { find }));
68
+ const { filters, limits, orderBy } = intercepted.find || find;
69
+ const queries = this.makeFirestoreWhere(filters || {});
70
+ const ordination = this.makeFirestoreOrderBy(filters, orderBy);
71
+ const offsets = await this.defineLimits(filters, limits);
72
+ const queryArgumments = [...queries, ...ordination, ...offsets];
73
+ const docs = await getDocs(query(collection, ...queryArgumments));
74
+ const data = docs.docs.map((doc) => doc.data());
75
+ return {
76
+ data: (await ((_f = (_e = this.interceptors) === null || _e === void 0 ? void 0 : _e.response) === null || _f === void 0 ? void 0 : _f.call(_e, data, intercepted))) || data,
77
+ count: enableCount ? this.calculateCount(data, limits) : Infinity,
78
+ };
79
+ }
80
+ buildCollectionPathForFind(filters) {
81
+ if (!this.isSubCollection(this))
82
+ return this.collectionName;
83
+ const parentIdField = this.parentIdField;
84
+ const parentId = getValueFromFilter(filters === null || filters === void 0 ? void 0 : filters[parentIdField]);
85
+ return `${this.parentRepository.collectionName}/${parentId}/${this.collectionName}`;
86
+ }
87
+ async defineLimits(filters, limits) {
88
+ var _a;
89
+ const queries = [];
90
+ if (limits === null || limits === void 0 ? void 0 : limits.offset) {
91
+ if (this.model.isModel(limits.offset))
92
+ queries.push(startAfter(await getDoc(doc(this.collection(this.buildCollectionPathForFind(filters)), (_a = Object.values(limits.offset.identifier).shift()) === null || _a === void 0 ? void 0 : _a.toString()))));
93
+ else if (isNumber(limits.offset) || isString(limits.offset))
94
+ queries.push(startAt(limits.offset));
95
+ }
96
+ if (limits === null || limits === void 0 ? void 0 : limits.limit)
97
+ queries.push(limit(limits.limit));
98
+ return queries;
99
+ }
100
+ calculateCount(data, limits) {
101
+ if (data.length <= 0)
102
+ return 0;
103
+ if (data.length < (limits === null || limits === void 0 ? void 0 : limits.limit))
104
+ return data.length;
105
+ return Infinity;
106
+ }
107
+ };
108
+ };
109
+ //# sourceMappingURL=with-find-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-find-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n CollectionReference,\r\n doc,\r\n getDoc,\r\n getDocs,\r\n limit,\r\n orderBy,\r\n query,\r\n QueryConstraint,\r\n startAfter,\r\n startAt,\r\n where,\r\n WhereFilterOp,\r\n} from 'firebase/firestore'\r\n\r\nimport {\r\n FindRepository,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n NonFunctionPropertyNames,\r\n RepositoryFindField,\r\n RepositoryFindFielters,\r\n RepositoryFindFieltersOptions,\r\n RepositoryFindResult,\r\n RepositoryLimitOptions,\r\n RepositoryOrderBy,\r\n Where,\r\n} from '../../../../domain'\r\nimport { is, isDate, isNil, isNumber, isObject, isString, MixinCtor, set } from '../../../../utils'\r\nimport { FirestoreFieldType } from '../enums'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\n\r\nexport const withFindFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & FindRepository<TBase> & FirestoreHelpers, []> => {\r\n const checkIfIsFilterOption = (filter: any): filter is RepositoryFindFieltersOptions<TBase, any> =>\r\n !isNil(filter?.operator)\r\n const getValueFromFilter = (filter: RepositoryFindField<TBase, any>): any => {\r\n return checkIfIsFilterOption(filter) ? filter.value : filter\r\n }\r\n const getFinalValueFrom = (value: any) =>\r\n isNumber(value) || isString(value) || isDate(value) || Array.isArray(value)\r\n ? value\r\n : Object.values(getFinalValueFrom)\r\n\r\n return class FindFirestore extends MixinBase implements FindRepository<TBase> {\r\n async find(\r\n find: {\r\n filters?: RepositoryFindFielters<TBase>\r\n limits?: RepositoryLimitOptions<TBase>\r\n orderBy?: RepositoryOrderBy<TBase>\r\n options?: { enableCount?: boolean }\r\n } = {},\r\n ): Promise<RepositoryFindResult<TBase>> {\r\n const collection: CollectionReference<TBase> = this.collection(this.buildCollectionPathForFind(find.filters))\r\n const enableCount = find?.options?.enableCount ?? true\r\n const intercepted = await this.interceptors?.request?.({ find })\r\n const { filters, limits, orderBy } = intercepted.find || find\r\n const queries = this.makeFirestoreWhere(filters || {})\r\n const ordination = this.makeFirestoreOrderBy(filters, orderBy)\r\n const offsets = await this.defineLimits(filters, limits)\r\n const queryArgumments: QueryConstraint[] = [...queries, ...ordination, ...offsets]\r\n const docs = await getDocs(query(collection, ...queryArgumments))\r\n const data = docs.docs.map((doc) => doc.data())\r\n\r\n return {\r\n data: (await this.interceptors?.response?.(data, intercepted)) || data,\r\n count: enableCount ? this.calculateCount(data, limits) : Infinity,\r\n }\r\n }\r\n\r\n buildCollectionPathForFind(filters: RepositoryFindFielters<TBase>): string {\r\n if (!this.isSubCollection(this)) return this.collectionName\r\n\r\n const parentIdField = this.parentIdField as NonFunctionAndIdentifierPropertyNames<TBase>\r\n const parentId = getValueFromFilter(filters?.[parentIdField])\r\n\r\n return `${this.parentRepository.collectionName}/${parentId}/${this.collectionName}`\r\n }\r\n\r\n makeFirestoreWhere = (filter: RepositoryFindFielters<TBase>): QueryConstraint[] =>\r\n Object.keys(filter).reduce(\r\n (queries: QueryConstraint[], fieldName: string) => [\r\n ...queries,\r\n ...this.buildWhereSentence(fieldName, is(filter[fieldName as NonFunctionPropertyNames<TBase>])),\r\n ],\r\n [],\r\n )\r\n\r\n buildWhereSentence = (\r\n fieldName: NonFunctionPropertyNames<TBase> | string,\r\n options: RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>,\r\n ): QueryConstraint[] => {\r\n if (this.isSubCollection(this) && fieldName === this.parentIdField) return []\r\n\r\n const value = options?.value || options\r\n const object = {}\r\n\r\n set(object, fieldName, value)\r\n\r\n const plainInstance = new this.model(object).toPlain()\r\n const firestoreFieldName =\r\n fieldName.toString().indexOf('.') > -1\r\n ? fieldName.toString()\r\n : Object.keys(plainInstance).find((key) => plainInstance[key])\r\n\r\n if (options?.operator === Where.LIKE) {\r\n if (\r\n Array.isArray(options?.value) &&\r\n (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] ===\r\n FirestoreFieldType.Array ||\r\n !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\r\n )\r\n return [where(firestoreFieldName, 'array-contains-any', options.value)]\r\n\r\n return [where(firestoreFieldName, '>=', options.value), where(firestoreFieldName, '<=', `${options.value}~`)]\r\n }\r\n if (\r\n options?.operator === Where.IN &&\r\n Array.isArray(options?.value) &&\r\n (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] === FirestoreFieldType.Array ||\r\n !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\r\n )\r\n return [where(firestoreFieldName, 'array-contains', options.value)]\r\n if (isObject(options) && isNil(options?.operator) && isNil(options?.value)) {\r\n return Object.keys(options).reduce(\r\n (queries, key) => [\r\n ...queries,\r\n ...this.buildWhereSentence(`${fieldName.toString()}.${key}`, is<Record<string, any>>(options)[key]),\r\n ],\r\n [],\r\n )\r\n }\r\n\r\n return [where(firestoreFieldName, (options?.operator as WhereFilterOp) || '==', options?.value || options)]\r\n }\r\n\r\n makeFirestoreOrderBy = (\r\n filters: RepositoryFindFielters<TBase>,\r\n fieldsToOrderBy?: RepositoryOrderBy<TBase>,\r\n ): QueryConstraint[] => {\r\n const orderByKeys = Object.keys(fieldsToOrderBy || {})\r\n\r\n if (!orderByKeys.length) return []\r\n\r\n const filtersKeysWithUnordered = Object.keys(filters || {}).filter(\r\n (filterKey) => !orderByKeys.includes(filterKey),\r\n )\r\n\r\n if (filtersKeysWithUnordered.length)\r\n filtersKeysWithUnordered.forEach(\r\n (filterKey) =>\r\n (fieldsToOrderBy = {\r\n ...(![Where.EQUALS].includes(\r\n is<RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>>(\r\n filters[filterKey as NonFunctionPropertyNames<TBase>],\r\n ).operator,\r\n )\r\n ? { [filterKey]: 'asc' }\r\n : {}),\r\n ...fieldsToOrderBy,\r\n }),\r\n )\r\n\r\n return Object.keys(fieldsToOrderBy).map((fieldName) =>\r\n orderBy(fieldName, fieldsToOrderBy[fieldName as NonFunctionPropertyNames<TBase>]),\r\n )\r\n }\r\n\r\n async defineLimits(\r\n filters: RepositoryFindFielters<TBase>,\r\n limits: RepositoryLimitOptions<TBase>,\r\n ): Promise<QueryConstraint[]> {\r\n const queries = []\r\n\r\n if (limits?.offset) {\r\n if (this.model.isModel(limits.offset))\r\n queries.push(\r\n startAfter(\r\n await getDoc(\r\n doc(\r\n this.collection(this.buildCollectionPathForFind(filters)),\r\n Object.values(limits.offset.identifier).shift()?.toString(),\r\n ),\r\n ),\r\n ),\r\n )\r\n else if (isNumber(limits.offset) || isString(limits.offset)) queries.push(startAt(limits.offset))\r\n }\r\n if (limits?.limit) queries.push(limit(limits.limit))\r\n\r\n return queries\r\n }\r\n\r\n calculateCount(data: TBase[], limits: RepositoryLimitOptions<TBase>): number {\r\n if (data.length <= 0) return 0\r\n if (data.length < limits?.limit) return data.length\r\n\r\n return Infinity\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,13 @@
1
+ import { Firestore } from 'firebase/firestore';
2
+ import { BaseModelBuilder, ModelBaseStructure, NonFunctionAndIdentifierPropertyNames } from '../../../../domain';
3
+ import { MergeConstructorParams, MixinCtor } from '../../../../utils';
4
+ import { FirestoreFieldType } from '../enums';
5
+ import { FirestoreInterceptors, FirestoreRepository } from '../types';
6
+ export declare type FirestoreConstructorParams<Model extends ModelBaseStructure<Model>> = {
7
+ firestore: Firestore;
8
+ collectionName: string;
9
+ model: BaseModelBuilder<Model>;
10
+ fields?: Partial<Record<NonFunctionAndIdentifierPropertyNames<Model>, FirestoreFieldType>>;
11
+ interceptors?: FirestoreInterceptors<Model>;
12
+ };
13
+ export declare const withFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, T extends MixinCtor<any, any[]> = MixinCtor<any, any[]>>(MixinBase: T) => MixinCtor<FirestoreRepository<TBase>, any[]>;
@@ -0,0 +1,77 @@
1
+ import { collection } from 'firebase/firestore';
2
+ import { each, isObject, unset } from '../../../../utils';
3
+ export const withFirestore = (MixinBase) => {
4
+ const isObjectsAndNoDate = (data) => data &&
5
+ !Array.isArray(data) &&
6
+ typeof data === 'object' &&
7
+ (data === null || data === void 0 ? void 0 : data.constructor.name) !== 'Timestamp' &&
8
+ !('seconds' in data);
9
+ const bindDate = (data, keyName) => {
10
+ if ((data === null || data === void 0 ? void 0 : data.constructor.name) === 'Timestamp')
11
+ return data.toDate();
12
+ if (data && typeof data === 'object' && 'seconds' in data)
13
+ return new Date(data.seconds * 1000);
14
+ if (typeof data === 'number' && ['createdAt', 'updatedAt'].includes(keyName))
15
+ return new Date(data);
16
+ return data;
17
+ };
18
+ const bindAllDateFromObject = (data) => {
19
+ return Object.keys(data).reduce((object, key) => (Object.assign(Object.assign({}, object), { [key]: isObjectsAndNoDate(data[key])
20
+ ? bindAllDateFromObject(data[key])
21
+ : Array.isArray(data[key])
22
+ ? data[key].map((element) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))
23
+ : bindDate(data[key], key) })), {});
24
+ };
25
+ const omitByRecursivelyInPlace = (value, iteratee) => {
26
+ each(value, (v, k) => {
27
+ if (iteratee(v, k)) {
28
+ unset(value, k);
29
+ }
30
+ else if (isObject(v)) {
31
+ omitByRecursivelyInPlace(v, iteratee);
32
+ }
33
+ });
34
+ return value;
35
+ };
36
+ return class extends MixinBase {
37
+ constructor(...params) {
38
+ super(...params);
39
+ this.fields = {};
40
+ this.interceptors = {};
41
+ this.collectionName = '';
42
+ const options = params[0];
43
+ this.firestore = options.firestore;
44
+ this.collectionName = options.collectionName;
45
+ this.model = options.model;
46
+ this.fields = options.fields;
47
+ this.interceptors = options.interceptors;
48
+ }
49
+ collection(path) {
50
+ return collection(this.firestore, path || this.collectionName).withConverter(this.buildModelInstance());
51
+ }
52
+ buildModelInstance() {
53
+ return {
54
+ toFirestore: (data) => {
55
+ const plain = (data === null || data === void 0 ? void 0 : data.toPlain) ? data.toPlain() : data;
56
+ return omitByRecursivelyInPlace(plain, (value) => value === undefined);
57
+ },
58
+ fromFirestore: (snap) => {
59
+ const data = snap.data();
60
+ let bindedData = null;
61
+ try {
62
+ const ids = { id: snap.id };
63
+ bindedData = bindAllDateFromObject(data);
64
+ return this.model.toInstance(Object.assign(Object.assign({}, bindedData), ids));
65
+ }
66
+ catch (error) {
67
+ console.info('id', snap.id);
68
+ console.info('data', JSON.stringify(bindedData));
69
+ console.error(error);
70
+ throw error;
71
+ }
72
+ },
73
+ };
74
+ }
75
+ };
76
+ };
77
+ //# sourceMappingURL=with-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { collection, CollectionReference, DocumentData, Firestore, QueryDocumentSnapshot } from 'firebase/firestore'\r\nimport {\r\n BaseModelBuilder,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertiesWithNoPartial,\r\n NonFunctionAndIdentifierPropertyNames,\r\n} from '../../../../domain'\r\nimport { each, isObject, MergeConstructorParams, MixinCtor, unset } from '../../../../utils'\r\nimport { FirestoreFieldType } from '../enums'\r\nimport { FirestoreInterceptors, FirestoreRepository } from '../types'\r\n\r\nexport type FirestoreConstructorParams<Model extends ModelBaseStructure<Model>> = {\r\n firestore: Firestore\r\n collectionName: string\r\n model: BaseModelBuilder<Model>\r\n fields?: Partial<Record<NonFunctionAndIdentifierPropertyNames<Model>, FirestoreFieldType>>\r\n interceptors?: FirestoreInterceptors<Model>\r\n}\r\n\r\nexport const withFirestore = <TBase extends ModelBaseStructure<TBase>, T extends MixinCtor = MixinCtor>(\r\n MixinBase: T,\r\n): MixinCtor<FirestoreRepository<TBase>, MergeConstructorParams<any[], FirestoreConstructorParams<TBase>[]>> => {\r\n const isObjectsAndNoDate = (data: any): boolean =>\r\n data &&\r\n !Array.isArray(data) &&\r\n typeof data === 'object' &&\r\n data?.constructor.name !== 'Timestamp' &&\r\n !('seconds' in data)\r\n const bindDate = (data: any, keyName: string): Record<string, any> => {\r\n if (data?.constructor.name === 'Timestamp') return data.toDate()\r\n if (data && typeof data === 'object' && 'seconds' in data) return new Date(data.seconds * 1000)\r\n if (typeof data === 'number' && ['createdAt', 'updatedAt'].includes(keyName)) return new Date(data)\r\n\r\n return data\r\n }\r\n const bindAllDateFromObject = (data: Record<string, any>): NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> => {\r\n return Object.keys(data).reduce(\r\n (object, key) => ({\r\n ...object,\r\n [key]: isObjectsAndNoDate(data[key])\r\n ? bindAllDateFromObject(data[key])\r\n : Array.isArray(data[key])\r\n ? data[key].map((element: any) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))\r\n : bindDate(data[key], key),\r\n }),\r\n {} as NonFunctionAndIdentifierPropertiesWithNoPartial<TBase>,\r\n )\r\n }\r\n const omitByRecursivelyInPlace = (value: any, iteratee: (value: any, key: string) => boolean): any => {\r\n each(value, (v, k) => {\r\n if (iteratee(v, k)) {\r\n unset(value, k)\r\n } else if (isObject(v)) {\r\n omitByRecursivelyInPlace(v, iteratee)\r\n }\r\n })\r\n\r\n return value\r\n }\r\n\r\n return class extends MixinBase implements FirestoreRepository<TBase> {\r\n firestore: Firestore\r\n fields: Partial<Record<NonFunctionAndIdentifierPropertyNames<TBase>, FirestoreFieldType>> = {}\r\n interceptors: FirestoreInterceptors<TBase> = {}\r\n collectionName: string = ''\r\n model: BaseModelBuilder<TBase>\r\n\r\n constructor(...params: any[]) {\r\n super(...params)\r\n\r\n const options: FirestoreConstructorParams<TBase> = params[0]\r\n\r\n this.firestore = options.firestore\r\n this.collectionName = options.collectionName\r\n this.model = options.model\r\n this.fields = options.fields\r\n this.interceptors = options.interceptors\r\n }\r\n\r\n collection(path?: string): CollectionReference<TBase> {\r\n return collection(this.firestore, path || this.collectionName).withConverter(this.buildModelInstance())\r\n }\r\n\r\n buildModelInstance(): {\r\n toFirestore: (data: TBase) => DocumentData\r\n fromFirestore: (snap: QueryDocumentSnapshot<TBase>) => TBase\r\n } {\r\n return {\r\n toFirestore: (data: TBase): DocumentData => {\r\n const plain = data?.toPlain ? data.toPlain() : data\r\n\r\n return omitByRecursivelyInPlace(plain, (value) => value === undefined)\r\n },\r\n fromFirestore: (snap: QueryDocumentSnapshot<TBase>): TBase => {\r\n const data = snap.data()\r\n let bindedData: NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> = null\r\n\r\n try {\r\n const ids = { id: snap.id }\r\n\r\n bindedData = bindAllDateFromObject(data)\r\n\r\n return this.model.toInstance({ ...bindedData, ...ids })\r\n } catch (error) {\r\n console.info('id', snap.id)\r\n console.info('data', JSON.stringify(bindedData))\r\n console.error(error)\r\n\r\n throw error\r\n }\r\n },\r\n }\r\n }\r\n }\r\n}\r\n"]}
@@ -0,0 +1,4 @@
1
+ import { GetRepository, ModelBaseStructure } from '../../../../domain';
2
+ import { MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository } from '../types';
4
+ export declare const withGetFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<FirestoreRepository<TBase>, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers, any[]> & TMixinBase) => MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & GetRepository<TBase, import("../../../../domain").GetRepositoryParams<TBase>> & FirestoreHelpers, []>;
@@ -0,0 +1,24 @@
1
+ import { doc, getDoc } from 'firebase/firestore';
2
+ import { NotFoundError } from '../../../../errors';
3
+ import { isNil } from '../../../../utils';
4
+ export const withGetFirestore = (MixinBase) => {
5
+ return class GetFirestore extends MixinBase {
6
+ async get(identifiers) {
7
+ var _a, _b, _c, _d;
8
+ const instance = this.model.toInstance(this.model.identifiersFields.reduce((acc, field) => (Object.assign(Object.assign({}, acc), { [field]: identifiers[field] })), {}));
9
+ const intercepted = await ((_b = (_a = this.interceptors) === null || _a === void 0 ? void 0 : _a.request) === null || _b === void 0 ? void 0 : _b.call(_a, { instance }));
10
+ const builded = (intercepted === null || intercepted === void 0 ? void 0 : intercepted.instance) || instance;
11
+ const docRef = await getDoc(doc(await this.collection(this.buildCollectionPathForGet(identifiers)), Object.values(builded.identifier).shift().toString()));
12
+ const data = docRef.data();
13
+ if (isNil(data))
14
+ throw new NotFoundError(`Document ${JSON.stringify(identifiers)} not found`);
15
+ return ((_d = (_c = this.interceptors) === null || _c === void 0 ? void 0 : _c.response) === null || _d === void 0 ? void 0 : _d.call(_c, data, intercepted)) || data;
16
+ }
17
+ buildCollectionPathForGet(identifiers) {
18
+ return this.isSubCollection(this)
19
+ ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`
20
+ : this.collectionName;
21
+ }
22
+ };
23
+ };
24
+ //# sourceMappingURL=with-get-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-get-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAGhD,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAClD,OAAO,EAAE,KAAK,EAAa,MAAM,mBAAmB,CAAA;AAGpD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAI9B,SAAgF,EACgC,EAAE;IAClH,OAAO,MAAM,YAAa,SAAQ,SAAS;QACzC,KAAK,CAAC,GAAG,CAAC,WAAoC;;YAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CACpC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CACjC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,iCAAM,GAAG,KAAE,CAAC,KAAK,CAAC,EAAE,WAAW,CAAC,KAAsC,CAAC,IAAG,EAC1F,EAAE,CACH,CACF,CAAA;YACD,MAAM,WAAW,GAAG,MAAM,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,OAAO,mDAAG,EAAE,QAAQ,EAAE,CAAC,CAAA,CAAA;YACpE,MAAM,OAAO,GAAG,CAAA,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,KAAI,QAAQ,CAAA;YACjD,MAAM,MAAM,GAAG,MAAM,MAAM,CACzB,GAAG,CACD,MAAM,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,yBAAyB,CAAC,WAAW,CAAC,CAAC,EAClE,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE,CACrD,CACF,CAAA;YACD,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,EAAE,CAAA;YAE1B,IAAI,KAAK,CAAC,IAAI,CAAC;gBAAE,MAAM,IAAI,aAAa,CAAC,YAAY,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;YAE7F,OAAO,CAAA,MAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,QAAQ,mDAAG,IAAI,EAAE,WAAW,CAAC,KAAI,IAAI,CAAA;QACjE,CAAC;QAED,yBAAyB,CAAC,WAAoC;YAC5D,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;gBAC/B,CAAC,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,IAAI,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE;gBACrG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAA;QACzB,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import { doc, getDoc } from 'firebase/firestore'\r\n\r\nimport { GetRepository, IdentifiersModel, ModelBaseStructure } from '../../../../domain'\r\nimport { NotFoundError } from '../../../../errors'\r\nimport { isNil, MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\n\r\nexport const withGetFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & GetRepository<TBase> & FirestoreHelpers, []> => {\r\n return class GetFirestore extends MixinBase implements GetRepository<TBase> {\r\n async get(identifiers: IdentifiersModel<TBase>): Promise<TBase> {\r\n const instance = this.model.toInstance(\r\n this.model.identifiersFields.reduce(\r\n (acc, field) => ({ ...acc, [field]: identifiers[field as keyof IdentifiersModel<TBase>] }),\r\n {},\r\n ),\r\n )\r\n const intercepted = await this.interceptors?.request?.({ instance })\r\n const builded = intercepted?.instance || instance\r\n const docRef = await getDoc(\r\n doc(\r\n await this.collection(this.buildCollectionPathForGet(identifiers)),\r\n Object.values(builded.identifier).shift().toString(),\r\n ),\r\n )\r\n const data = docRef.data()\r\n\r\n if (isNil(data)) throw new NotFoundError(`Document ${JSON.stringify(identifiers)} not found`)\r\n\r\n return this.interceptors?.response?.(data, intercepted) || data\r\n }\r\n\r\n buildCollectionPathForGet(identifiers: IdentifiersModel<TBase>): string {\r\n return this.isSubCollection(this)\r\n ? `${this.parentRepository.collectionName}/${identifiers[this.parentIdField]}/${this.collectionName}`\r\n : this.collectionName\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,11 @@
1
+ import { QueryDocumentSnapshot, QuerySnapshot } from 'firebase/firestore';
2
+ import { ModelBaseStructure } from '../../../../domain';
3
+ import { MixinCtor } from '../../../../utils';
4
+ import { FirestoreRepository, FirestoreSubRepository } from '../types';
5
+ export declare const withHelpers: <TMixinBase extends MixinCtor<any, any[]> = MixinCtor<any, any[]>>(MixinBase: MixinCtor<any, any[]> & TMixinBase) => {
6
+ new (...args: any[]): {
7
+ [x: string]: any;
8
+ toArray<T extends ModelBaseStructure<T, T["identifiersFields"][number]>>(snapShot: QuerySnapshot<T> | QueryDocumentSnapshot<T>[]): T[];
9
+ isSubCollection<T_1 extends ModelBaseStructure<T_1, T_1["identifiersFields"][number]>, E extends ModelBaseStructure<E, E["identifiersFields"][number]>>(repository: FirestoreRepository<T_1> | FirestoreSubRepository<T_1, E>): repository is FirestoreSubRepository<T_1, E>;
10
+ };
11
+ } & TMixinBase;
@@ -0,0 +1,17 @@
1
+ import { isNil } from '../../../../utils';
2
+ export const withHelpers = (MixinBase) => {
3
+ return class extends MixinBase {
4
+ toArray(snapShot) {
5
+ if (Array.isArray(snapShot)) {
6
+ return snapShot.map((doc) => doc.data());
7
+ }
8
+ else {
9
+ return snapShot.docs.map((doc) => doc.data());
10
+ }
11
+ }
12
+ isSubCollection(repository) {
13
+ return !isNil(Object.keys(this).find((key) => key === 'parentRepository'));
14
+ }
15
+ };
16
+ };
17
+ //# sourceMappingURL=with-helpers.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-helpers.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-helpers.mixin.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,EAAa,MAAM,mBAAmB,CAAA;AAGpD,MAAM,CAAC,MAAM,WAAW,GAAG,CAA2C,SAAiC,EAAE,EAAE;IACzG,OAAO,KAAM,SAAQ,SAAS;QAC5B,OAAO,CAAkC,QAAuD;YAC9F,IAAI,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;gBAC3B,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,GAA6B,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAA;aACnE;iBAAM;gBACL,OAAO,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAA6B,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAA;aACxE;QACH,CAAC;QAED,eAAe,CACb,UAAiE;YAEjE,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,KAAK,kBAAkB,CAAC,CAAC,CAAA;QAC5E,CAAC;KACF,CAAA;AACH,CAAC,CAAA","sourcesContent":["import { QueryDocumentSnapshot, QuerySnapshot } from 'firebase/firestore'\r\n\r\nimport { ModelBaseStructure } from '../../../../domain'\r\nimport { isNil, MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository, FirestoreSubRepository } from '../types'\r\n\r\nexport const withHelpers = <TMixinBase extends MixinCtor = MixinCtor>(MixinBase: MixinCtor & TMixinBase) => {\r\n return class extends MixinBase implements FirestoreHelpers {\r\n toArray<T extends ModelBaseStructure<T>>(snapShot: QuerySnapshot<T> | QueryDocumentSnapshot<T>[]): T[] {\r\n if (Array.isArray(snapShot)) {\r\n return snapShot.map((doc: QueryDocumentSnapshot<T>) => doc.data())\r\n } else {\r\n return snapShot.docs.map((doc: QueryDocumentSnapshot<T>) => doc.data())\r\n }\r\n }\r\n\r\n isSubCollection<T extends ModelBaseStructure<T>, E extends ModelBaseStructure<E>>(\r\n repository: FirestoreRepository<T> | FirestoreSubRepository<T, E>,\r\n ): repository is FirestoreSubRepository<T, E> {\r\n return !isNil(Object.keys(this).find((key) => key === 'parentRepository'))\r\n }\r\n }\r\n}\r\n"]}
@@ -0,0 +1,11 @@
1
+ import { IdentifiersModel, ModelBaseStructure } from '../../../../domain';
2
+ import { MergeConstructorParams, MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository, FirestoreSubRepository } from '../types';
4
+ import { FirestoreConstructorParams } from './with-firestore.mixin';
5
+ export declare type FirestoreSubCollectionConstructorParams<TBase extends ModelBaseStructure> = {
6
+ parentIdField: keyof IdentifiersModel<TBase>;
7
+ };
8
+ export declare const withSubCollection: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, TBaseParent extends ModelBaseStructure<TBaseParent, TBaseParent["identifiersFields"][number]>, TMixinBase extends MixinCtor<FirestoreRepository<TBase>, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase>, any[]> & TMixinBase, ParentModel: new () => TBaseParent) => MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & {
9
+ readonly parentRepository: FirestoreRepository<TBaseParent>;
10
+ parentIdField: Extract<import("../../../../domain").NonFunctionAndIdentifierPropertyNames<TBase>, import("../../../../utils").PropType<TBase, "identifiersFields">[number]>;
11
+ } & FirestoreHelpers, MergeConstructorParams<[FirestoreConstructorParams<TBase> & FirestoreSubCollectionConstructorParams<TBase>, ...any[]], ConstructorParameters<TMixinBase>>>;
@@ -0,0 +1,13 @@
1
+ export const withSubCollection = (MixinBase, ParentModel) => {
2
+ return class SubCollectionMix extends MixinBase {
3
+ constructor(...params) {
4
+ const options = params[0];
5
+ super(...params);
6
+ this.parentIdField = options.parentIdField;
7
+ }
8
+ collection(path) {
9
+ return super.collection(path);
10
+ }
11
+ };
12
+ };
13
+ //# sourceMappingURL=with-sub-collection.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-sub-collection.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.ts"],"names":[],"mappings":"AAWA,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAK/B,SAA6D,EAC7D,WAAkC,EAUlC,EAAE;IACF,OAAO,MAAM,gBACX,SAAQ,SAAS;QAMjB,YAAY,GAAG,MAAa;YAC1B,MAAM,OAAO,GAAmD,MAAM,CAAC,CAAC,CAAC,CAAA;YAEzE,KAAK,CAAC,GAAG,MAAM,CAAC,CAAA;YAEhB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,CAAA;QAC5C,CAAC;QAEQ,UAAU,CAAC,IAAa;YAC/B,OAAO,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;QAC/B,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import { CollectionReference } from 'firebase/firestore'\r\n\r\nimport { IdentifiersModel, ModelBaseStructure } from '../../../../domain'\r\nimport { MergeConstructorParams, MixinCtor } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository, FirestoreSubRepository } from '../types'\r\nimport { FirestoreConstructorParams } from './with-firestore.mixin'\r\n\r\nexport type FirestoreSubCollectionConstructorParams<TBase extends ModelBaseStructure> = {\r\n parentIdField: keyof IdentifiersModel<TBase>\r\n}\r\n\r\nexport const withSubCollection = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TBaseParent extends ModelBaseStructure<TBaseParent>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase>> & TMixinBase,\r\n ParentModel: new () => TBaseParent,\r\n): MixinCtor<\r\n FirestoreRepository<TBase> &\r\n InstanceType<TMixinBase> &\r\n FirestoreSubRepository<TBase, InstanceType<typeof ParentModel>> &\r\n FirestoreHelpers,\r\n MergeConstructorParams<\r\n [FirestoreConstructorParams<TBase> & FirestoreSubCollectionConstructorParams<TBase>, ...any[]],\r\n ConstructorParameters<TMixinBase>\r\n >\r\n> => {\r\n return class SubCollectionMix\r\n extends MixinBase\r\n implements FirestoreSubRepository<TBase, InstanceType<typeof ParentModel>>\r\n {\r\n readonly parentRepository: FirestoreRepository<InstanceType<typeof ParentModel>>\r\n parentIdField: keyof IdentifiersModel<TBase>\r\n\r\n constructor(...params: any[]) {\r\n const options: FirestoreSubCollectionConstructorParams<TBase> = params[0]\r\n\r\n super(...params)\r\n\r\n this.parentIdField = options.parentIdField\r\n }\r\n\r\n override collection(path?: string): CollectionReference<TBase> {\r\n return super.collection(path)\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,7 @@
1
+ import { ModelBaseStructure, RepositoryUpdateParams, UpdateRepository } from '../../../../domain';
2
+ import { MixinCtor } from '../../../../utils';
3
+ import { FirestoreHelpers, FirestoreRepository } from '../types';
4
+ export declare type UpdateFirestoreRepositoryType<MBase extends ModelBaseStructure<MBase>> = UpdateRepository<MBase> & {
5
+ paramsToPlain(params: RepositoryUpdateParams<MBase>): Partial<MBase>;
6
+ };
7
+ export declare const withUpdateFirestore: <TBase extends ModelBaseStructure<TBase, TBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<FirestoreRepository<TBase>, any[]>>(MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers, any[]> & TMixinBase) => MixinCtor<FirestoreRepository<TBase> & UpdateRepository<TBase, RepositoryUpdateParams<TBase>> & InstanceType<TMixinBase> & FirestoreHelpers, []>;
@@ -0,0 +1,52 @@
1
+ import { arrayRemove, arrayUnion, deleteField, doc, getDoc, setDoc } from 'firebase/firestore';
2
+ import { UpdateOptionActions, } from '../../../../domain';
3
+ import { is, isNil } from '../../../../utils';
4
+ export const withUpdateFirestore = (MixinBase) => {
5
+ const getValueFromParams = (params, field) => {
6
+ var _a;
7
+ return (isNil((_a = is(params[field])) === null || _a === void 0 ? void 0 : _a.value)
8
+ ? is(params[field])
9
+ : is(params[field]).value) || null;
10
+ };
11
+ const getValueByAction = (options) => {
12
+ if (isNil(options === null || options === void 0 ? void 0 : options.action))
13
+ return options;
14
+ if ((options === null || options === void 0 ? void 0 : options.action) === UpdateOptionActions.REMOVE_FIELD)
15
+ return deleteField();
16
+ if ((options === null || options === void 0 ? void 0 : options.action) === UpdateOptionActions.NULL)
17
+ return null;
18
+ if (Array.isArray(options === null || options === void 0 ? void 0 : options.value)) {
19
+ if ((options === null || options === void 0 ? void 0 : options.action) === UpdateOptionActions.MERGE)
20
+ return arrayUnion(...options.value);
21
+ if ((options === null || options === void 0 ? void 0 : options.action) === UpdateOptionActions.REMOVE)
22
+ return arrayRemove(...options.value);
23
+ }
24
+ return options === null || options === void 0 ? void 0 : options.value;
25
+ };
26
+ return class UpdateFirestore extends MixinBase {
27
+ async update(data) {
28
+ var _a, _b, _c, _d;
29
+ const model = new this.model();
30
+ const keyField = model.identifiersFields.shift();
31
+ const docRef = doc(this.collection(this.buildCollectionPathForUpdate(data)), getValueFromParams(data, keyField).toString());
32
+ const plainFromData = this.model.toInstance(this.paramsToPlain(data));
33
+ const intercepted = await ((_b = (_a = this.interceptors) === null || _a === void 0 ? void 0 : _a.request) === null || _b === void 0 ? void 0 : _b.call(_a, { instance: plainFromData }));
34
+ const builded = (intercepted === null || intercepted === void 0 ? void 0 : intercepted.instance) || plainFromData;
35
+ await setDoc(docRef, builded.toPlain(), { merge: true });
36
+ const docData = await getDoc(docRef).then((doc) => doc.data());
37
+ return ((_d = (_c = this.interceptors) === null || _c === void 0 ? void 0 : _c.response) === null || _d === void 0 ? void 0 : _d.call(_c, docData, intercepted)) || docData;
38
+ }
39
+ buildCollectionPathForUpdate(identifiers) {
40
+ return this.isSubCollection(this)
41
+ ? `${this.parentRepository.collectionName}/${getValueFromParams(identifiers, this.parentIdField)}/${this.collectionName}`
42
+ : this.collectionName;
43
+ }
44
+ paramsToPlain(params) {
45
+ const model = this.model;
46
+ if (model.isModel(params))
47
+ return params.toPlain();
48
+ return Object.keys(params).reduce((data, currentKey) => (Object.assign(Object.assign({}, data), ((value) => (value === undefined ? {} : { [currentKey]: value }))(getValueByAction(params[currentKey])))), {});
49
+ }
50
+ };
51
+ };
52
+ //# sourceMappingURL=with-update-firestore.mixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"with-update-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { arrayRemove, arrayUnion, deleteField, doc, FieldValue, getDoc, setDoc } from 'firebase/firestore'\r\n\r\nimport {\r\n IdentifierModel,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n RepositoryUpdateParams,\r\n UpdateOptionActions,\r\n UpdateOptions,\r\n UpdateRepository,\r\n} from '../../../../domain'\r\nimport { is, isNil, MixinCtor, PropType } from '../../../../utils'\r\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\r\n\r\nexport type UpdateFirestoreRepositoryType<MBase extends ModelBaseStructure<MBase>> = UpdateRepository<MBase> & {\r\n paramsToPlain(params: RepositoryUpdateParams<MBase>): Partial<MBase>\r\n}\r\n\r\nexport const withUpdateFirestore = <\r\n TBase extends ModelBaseStructure<TBase>,\r\n TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\r\n>(\r\n MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\r\n): MixinCtor<\r\n FirestoreRepository<TBase> & UpdateRepository<TBase> & InstanceType<TMixinBase> & FirestoreHelpers,\r\n []\r\n> => {\r\n const getValueFromParams = (\r\n params: RepositoryUpdateParams<TBase>,\r\n field: NonFunctionAndIdentifierPropertyNames<TBase> | IdentifierModel<TBase>,\r\n ): PropType<TBase, NonFunctionAndIdentifierPropertyNames<TBase>> =>\r\n (isNil(is<UpdateOptions<PropType<TBase, NonFunctionAndIdentifierPropertyNames<TBase>>>>(params[field])?.value)\r\n ? is<PropType<TBase, NonFunctionAndIdentifierPropertyNames<TBase>>>(params[field])\r\n : is<UpdateOptions<PropType<TBase, NonFunctionAndIdentifierPropertyNames<TBase>>>>(params[field]).value) || null\r\n const getValueByAction = (options: UpdateOptions<TBase>): FieldValue | unknown => {\r\n if (isNil(options?.action)) return options\r\n if (options?.action === UpdateOptionActions.REMOVE_FIELD) return deleteField()\r\n if (options?.action === UpdateOptionActions.NULL) return null\r\n if (Array.isArray(options?.value)) {\r\n if (options?.action === UpdateOptionActions.MERGE) return arrayUnion(...options.value)\r\n if (options?.action === UpdateOptionActions.REMOVE) return arrayRemove(...options.value)\r\n }\r\n\r\n return options?.value\r\n }\r\n\r\n return class UpdateFirestore extends MixinBase implements UpdateRepository<TBase> {\r\n async update(data: RepositoryUpdateParams<TBase>): Promise<TBase> {\r\n const model = new this.model()\r\n const keyField = model.identifiersFields.shift()\r\n const docRef = doc(\r\n this.collection(this.buildCollectionPathForUpdate(data)),\r\n getValueFromParams(data, keyField as IdentifierModel<TBase>).toString(),\r\n )\r\n const plainFromData = this.model.toInstance(this.paramsToPlain(data))\r\n const intercepted = await this.interceptors?.request?.({ instance: plainFromData })\r\n const builded = intercepted?.instance || plainFromData\r\n\r\n await setDoc(docRef, builded.toPlain(), { merge: true })\r\n\r\n const docData = await getDoc(docRef).then((doc) => doc.data())\r\n\r\n return this.interceptors?.response?.(docData, intercepted) || docData\r\n }\r\n\r\n buildCollectionPathForUpdate(identifiers: RepositoryUpdateParams<TBase>): string {\r\n return this.isSubCollection(this)\r\n ? `${this.parentRepository.collectionName}/${getValueFromParams(identifiers, this.parentIdField)}/${\r\n this.collectionName\r\n }`\r\n : this.collectionName\r\n }\r\n\r\n paramsToPlain(params: RepositoryUpdateParams<TBase>): Partial<TBase> {\r\n const model = this.model\r\n\r\n if (model.isModel(params)) return params.toPlain()\r\n\r\n return Object.keys(params).reduce(\r\n (data, currentKey) => ({\r\n ...data,\r\n ...((value): Record<string, any> => (value === undefined ? {} : { [currentKey]: value }))(\r\n getValueByAction(params[currentKey as never]),\r\n ),\r\n }),\r\n {},\r\n )\r\n }\r\n } as any\r\n}\r\n"]}
@@ -0,0 +1,20 @@
1
+ import { Category, CategoryRepository, Product, Shops } from '../../../../../domain';
2
+ import { FirestoreConstructorParams } from '../../mixins';
3
+ declare const CategoryFirestoreRepository_base: import("../../../../../utils").MixinCtor<import("../..").FirestoreRepository<Category> & import("../../../../../domain").CrudRepository<Category, import("../../../../../domain").CrudParams<Category>> & import("../..").FirestoreHelpers, [FirestoreConstructorParams<Category>, ...any[]]>;
4
+ export declare class CategoryFirestoreRepository extends CategoryFirestoreRepository_base implements CategoryRepository {
5
+ constructor({ firestore, interceptors }: Pick<FirestoreConstructorParams<Category>, 'firestore' | 'interceptors'>);
6
+ getCategoryBySlug(slug: string, shop: Shops): Promise<Category>;
7
+ getCategoriesForHome(categoryIds: string[], limit?: number, gender?: string): Promise<{
8
+ category: Category;
9
+ products: Product[];
10
+ }[]>;
11
+ mountCategory(category: Category, options?: {
12
+ limit?: number;
13
+ hasStock?: boolean;
14
+ gender?: string;
15
+ }): Promise<Product[]>;
16
+ getCategoryByShop(shop: string): Promise<Category[]>;
17
+ getChildren(parentId: number): Promise<Category[]>;
18
+ isChild(id: number, parentId: number): Promise<boolean>;
19
+ }
20
+ export {};