@infrab4a/connect 4.0.2-beta.6 → 4.0.2-beta.7
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.
- package/index.js +5154 -2
- package/package.json +29 -36
- package/index.d.ts +0 -1
- package/index.js.map +0 -1
- package/src/domain/catalog/helpers/index.d.ts +0 -1
- package/src/domain/catalog/helpers/index.js +0 -2
- package/src/domain/catalog/helpers/index.js.map +0 -1
- package/src/domain/catalog/helpers/round-product-price.helper.d.ts +0 -4
- package/src/domain/catalog/helpers/round-product-price.helper.js +0 -15
- package/src/domain/catalog/helpers/round-product-price.helper.js.map +0 -1
- package/src/domain/catalog/index.d.ts +0 -3
- package/src/domain/catalog/index.js +0 -4
- package/src/domain/catalog/index.js.map +0 -1
- package/src/domain/catalog/models/category-base.d.ts +0 -30
- package/src/domain/catalog/models/category-base.js +0 -18
- package/src/domain/catalog/models/category-base.js.map +0 -1
- package/src/domain/catalog/models/category-collection-children.d.ts +0 -13
- package/src/domain/catalog/models/category-collection-children.js +0 -13
- package/src/domain/catalog/models/category-collection-children.js.map +0 -1
- package/src/domain/catalog/models/category-filter.d.ts +0 -13
- package/src/domain/catalog/models/category-filter.js +0 -19
- package/src/domain/catalog/models/category-filter.js.map +0 -1
- package/src/domain/catalog/models/category-for-product.d.ts +0 -5
- package/src/domain/catalog/models/category-for-product.js +0 -7
- package/src/domain/catalog/models/category-for-product.js.map +0 -1
- package/src/domain/catalog/models/category.d.ts +0 -7
- package/src/domain/catalog/models/category.js +0 -14
- package/src/domain/catalog/models/category.js.map +0 -1
- package/src/domain/catalog/models/enums/index.d.ts +0 -2
- package/src/domain/catalog/models/enums/index.js +0 -3
- package/src/domain/catalog/models/enums/index.js.map +0 -1
- package/src/domain/catalog/models/enums/product-genders.enum.d.ts +0 -5
- package/src/domain/catalog/models/enums/product-genders.enum.js +0 -7
- package/src/domain/catalog/models/enums/product-genders.enum.js.map +0 -1
- package/src/domain/catalog/models/enums/shops.enum.d.ts +0 -6
- package/src/domain/catalog/models/enums/shops.enum.js +0 -8
- package/src/domain/catalog/models/enums/shops.enum.js.map +0 -1
- package/src/domain/catalog/models/filter-option.d.ts +0 -9
- package/src/domain/catalog/models/filter-option.js +0 -7
- package/src/domain/catalog/models/filter-option.js.map +0 -1
- package/src/domain/catalog/models/filter.d.ts +0 -12
- package/src/domain/catalog/models/filter.js +0 -7
- package/src/domain/catalog/models/filter.js.map +0 -1
- package/src/domain/catalog/models/index.d.ts +0 -11
- package/src/domain/catalog/models/index.js +0 -12
- package/src/domain/catalog/models/index.js.map +0 -1
- package/src/domain/catalog/models/kit-product.d.ts +0 -12
- package/src/domain/catalog/models/kit-product.js +0 -18
- package/src/domain/catalog/models/kit-product.js.map +0 -1
- package/src/domain/catalog/models/product-base.d.ts +0 -40
- package/src/domain/catalog/models/product-base.js +0 -25
- package/src/domain/catalog/models/product-base.js.map +0 -1
- package/src/domain/catalog/models/product-for-category.d.ts +0 -7
- package/src/domain/catalog/models/product-for-category.js +0 -14
- package/src/domain/catalog/models/product-for-category.js.map +0 -1
- package/src/domain/catalog/models/product-for-kit.d.ts +0 -7
- package/src/domain/catalog/models/product-for-kit.js +0 -14
- package/src/domain/catalog/models/product-for-kit.js.map +0 -1
- package/src/domain/catalog/models/product.d.ts +0 -9
- package/src/domain/catalog/models/product.js +0 -19
- package/src/domain/catalog/models/product.js.map +0 -1
- package/src/domain/catalog/models/types/category-condition.type.d.ts +0 -4
- package/src/domain/catalog/models/types/category-condition.type.js +0 -2
- package/src/domain/catalog/models/types/category-condition.type.js.map +0 -1
- package/src/domain/catalog/models/types/category-metadata.type.d.ts +0 -4
- package/src/domain/catalog/models/types/category-metadata.type.js +0 -2
- package/src/domain/catalog/models/types/category-metadata.type.js.map +0 -1
- package/src/domain/catalog/models/types/category-product.d.ts +0 -4
- package/src/domain/catalog/models/types/category-product.js +0 -2
- package/src/domain/catalog/models/types/category-product.js.map +0 -1
- package/src/domain/catalog/models/types/index.d.ts +0 -11
- package/src/domain/catalog/models/types/index.js +0 -12
- package/src/domain/catalog/models/types/index.js.map +0 -1
- package/src/domain/catalog/models/types/product-evaluation.type.d.ts +0 -6
- package/src/domain/catalog/models/types/product-evaluation.type.js +0 -2
- package/src/domain/catalog/models/types/product-evaluation.type.js.map +0 -1
- package/src/domain/catalog/models/types/product-gender.type.d.ts +0 -1
- package/src/domain/catalog/models/types/product-gender.type.js +0 -2
- package/src/domain/catalog/models/types/product-gender.type.js.map +0 -1
- package/src/domain/catalog/models/types/product-metadata.type.d.ts +0 -4
- package/src/domain/catalog/models/types/product-metadata.type.js +0 -2
- package/src/domain/catalog/models/types/product-metadata.type.js.map +0 -1
- package/src/domain/catalog/models/types/product-review.type.d.ts +0 -17
- package/src/domain/catalog/models/types/product-review.type.js +0 -2
- package/src/domain/catalog/models/types/product-review.type.js.map +0 -1
- package/src/domain/catalog/models/types/shop-description.type.d.ts +0 -8
- package/src/domain/catalog/models/types/shop-description.type.js +0 -2
- package/src/domain/catalog/models/types/shop-description.type.js.map +0 -1
- package/src/domain/catalog/models/types/shop-price.type.d.ts +0 -6
- package/src/domain/catalog/models/types/shop-price.type.js +0 -2
- package/src/domain/catalog/models/types/shop-price.type.js.map +0 -1
- package/src/domain/catalog/models/types/stock.type.d.ts +0 -3
- package/src/domain/catalog/models/types/stock.type.js +0 -2
- package/src/domain/catalog/models/types/stock.type.js.map +0 -1
- package/src/domain/catalog/models/types/variant-grade.type.d.ts +0 -4
- package/src/domain/catalog/models/types/variant-grade.type.js +0 -2
- package/src/domain/catalog/models/types/variant-grade.type.js.map +0 -1
- package/src/domain/catalog/models/variant.d.ts +0 -17
- package/src/domain/catalog/models/variant.js +0 -7
- package/src/domain/catalog/models/variant.js.map +0 -1
- package/src/domain/catalog/models/wishlist.d.ts +0 -6
- package/src/domain/catalog/models/wishlist.js +0 -7
- package/src/domain/catalog/models/wishlist.js.map +0 -1
- package/src/domain/catalog/repositories/category-collection-children.repository.d.ts +0 -4
- package/src/domain/catalog/repositories/category-collection-children.repository.js +0 -2
- package/src/domain/catalog/repositories/category-collection-children.repository.js.map +0 -1
- package/src/domain/catalog/repositories/category-filter.repository.d.ts +0 -6
- package/src/domain/catalog/repositories/category-filter.repository.js +0 -2
- package/src/domain/catalog/repositories/category-filter.repository.js.map +0 -1
- package/src/domain/catalog/repositories/category.repository.d.ts +0 -18
- package/src/domain/catalog/repositories/category.repository.js +0 -2
- package/src/domain/catalog/repositories/category.repository.js.map +0 -1
- package/src/domain/catalog/repositories/filter-option.repository.d.ts +0 -4
- package/src/domain/catalog/repositories/filter-option.repository.js +0 -2
- package/src/domain/catalog/repositories/filter-option.repository.js.map +0 -1
- package/src/domain/catalog/repositories/filter.repository.d.ts +0 -4
- package/src/domain/catalog/repositories/filter.repository.js +0 -2
- package/src/domain/catalog/repositories/filter.repository.js.map +0 -1
- package/src/domain/catalog/repositories/index.d.ts +0 -9
- package/src/domain/catalog/repositories/index.js +0 -10
- package/src/domain/catalog/repositories/index.js.map +0 -1
- package/src/domain/catalog/repositories/product.repository.d.ts +0 -15
- package/src/domain/catalog/repositories/product.repository.js +0 -2
- package/src/domain/catalog/repositories/product.repository.js.map +0 -1
- package/src/domain/catalog/repositories/subscription-product.repository.d.ts +0 -4
- package/src/domain/catalog/repositories/subscription-product.repository.js +0 -2
- package/src/domain/catalog/repositories/subscription-product.repository.js.map +0 -1
- package/src/domain/catalog/repositories/variant.repository.d.ts +0 -4
- package/src/domain/catalog/repositories/variant.repository.js +0 -2
- package/src/domain/catalog/repositories/variant.repository.js.map +0 -1
- package/src/domain/catalog/repositories/wishlist.repository.d.ts +0 -6
- package/src/domain/catalog/repositories/wishlist.repository.js +0 -2
- package/src/domain/catalog/repositories/wishlist.repository.js.map +0 -1
- package/src/domain/generic/index.d.ts +0 -2
- package/src/domain/generic/index.js +0 -3
- package/src/domain/generic/index.js.map +0 -1
- package/src/domain/generic/model/base.model.d.ts +0 -14
- package/src/domain/generic/model/base.model.js +0 -24
- package/src/domain/generic/model/base.model.js.map +0 -1
- package/src/domain/generic/model/identifier-fields.d.ts +0 -4
- package/src/domain/generic/model/identifier-fields.js +0 -2
- package/src/domain/generic/model/identifier-fields.js.map +0 -1
- package/src/domain/generic/model/index.d.ts +0 -3
- package/src/domain/generic/model/index.js +0 -4
- package/src/domain/generic/model/index.js.map +0 -1
- package/src/domain/generic/model/types/base-model-builder.type.d.ts +0 -17
- package/src/domain/generic/model/types/base-model-builder.type.js +0 -2
- package/src/domain/generic/model/types/base-model-builder.type.js.map +0 -1
- package/src/domain/generic/model/types/identifier-model.type.d.ts +0 -8
- package/src/domain/generic/model/types/identifier-model.type.js +0 -2
- package/src/domain/generic/model/types/identifier-model.type.js.map +0 -1
- package/src/domain/generic/model/types/index.d.ts +0 -5
- package/src/domain/generic/model/types/index.js +0 -6
- package/src/domain/generic/model/types/index.js.map +0 -1
- package/src/domain/generic/model/types/model-base-structure.type.d.ts +0 -12
- package/src/domain/generic/model/types/model-base-structure.type.js +0 -2
- package/src/domain/generic/model/types/model-base-structure.type.js.map +0 -1
- package/src/domain/generic/model/types/non-function-properties.type.d.ts +0 -12
- package/src/domain/generic/model/types/non-function-properties.type.js +0 -2
- package/src/domain/generic/model/types/non-function-properties.type.js.map +0 -1
- package/src/domain/generic/model/types/non-function-property-name.type.d.ts +0 -13
- package/src/domain/generic/model/types/non-function-property-name.type.js +0 -2
- package/src/domain/generic/model/types/non-function-property-name.type.js.map +0 -1
- package/src/domain/generic/repository/create.repository.d.ts +0 -8
- package/src/domain/generic/repository/create.repository.js +0 -2
- package/src/domain/generic/repository/create.repository.js.map +0 -1
- package/src/domain/generic/repository/crud.repository.d.ts +0 -19
- package/src/domain/generic/repository/crud.repository.js +0 -2
- package/src/domain/generic/repository/crud.repository.js.map +0 -1
- package/src/domain/generic/repository/delete.repository.d.ts +0 -7
- package/src/domain/generic/repository/delete.repository.js +0 -2
- package/src/domain/generic/repository/delete.repository.js.map +0 -1
- package/src/domain/generic/repository/enums/index.d.ts +0 -2
- package/src/domain/generic/repository/enums/index.js +0 -3
- package/src/domain/generic/repository/enums/index.js.map +0 -1
- package/src/domain/generic/repository/enums/update-option-actions.enum.d.ts +0 -7
- package/src/domain/generic/repository/enums/update-option-actions.enum.js +0 -9
- package/src/domain/generic/repository/enums/update-option-actions.enum.js.map +0 -1
- package/src/domain/generic/repository/enums/where.enum.d.ts +0 -14
- package/src/domain/generic/repository/enums/where.enum.js +0 -16
- package/src/domain/generic/repository/enums/where.enum.js.map +0 -1
- package/src/domain/generic/repository/find.repository.d.ts +0 -17
- package/src/domain/generic/repository/find.repository.js +0 -2
- package/src/domain/generic/repository/find.repository.js.map +0 -1
- package/src/domain/generic/repository/get.repository.d.ts +0 -5
- package/src/domain/generic/repository/get.repository.js +0 -2
- package/src/domain/generic/repository/get.repository.js.map +0 -1
- package/src/domain/generic/repository/index.d.ts +0 -9
- package/src/domain/generic/repository/index.js +0 -10
- package/src/domain/generic/repository/index.js.map +0 -1
- package/src/domain/generic/repository/read.repository.d.ts +0 -14
- package/src/domain/generic/repository/read.repository.js +0 -2
- package/src/domain/generic/repository/read.repository.js.map +0 -1
- package/src/domain/generic/repository/types/index.d.ts +0 -6
- package/src/domain/generic/repository/types/index.js +0 -7
- package/src/domain/generic/repository/types/index.js.map +0 -1
- package/src/domain/generic/repository/types/repository-find-filters.type.d.ts +0 -13
- package/src/domain/generic/repository/types/repository-find-filters.type.js +0 -2
- package/src/domain/generic/repository/types/repository-find-filters.type.js.map +0 -1
- package/src/domain/generic/repository/types/repository-find-result.type.d.ts +0 -14
- package/src/domain/generic/repository/types/repository-find-result.type.js +0 -2
- package/src/domain/generic/repository/types/repository-find-result.type.js.map +0 -1
- package/src/domain/generic/repository/types/repository-limit-options.type.d.ts +0 -4
- package/src/domain/generic/repository/types/repository-limit-options.type.js +0 -2
- package/src/domain/generic/repository/types/repository-limit-options.type.js.map +0 -1
- package/src/domain/generic/repository/types/repository-order-by-list.type.d.ts +0 -5
- package/src/domain/generic/repository/types/repository-order-by-list.type.js +0 -2
- package/src/domain/generic/repository/types/repository-order-by-list.type.js.map +0 -1
- package/src/domain/generic/repository/types/repository-update-params.type.d.ts +0 -11
- package/src/domain/generic/repository/types/repository-update-params.type.js +0 -2
- package/src/domain/generic/repository/types/repository-update-params.type.js.map +0 -1
- package/src/domain/generic/repository/types/where-options.type.d.ts +0 -2
- package/src/domain/generic/repository/types/where-options.type.js +0 -2
- package/src/domain/generic/repository/types/where-options.type.js.map +0 -1
- package/src/domain/generic/repository/update.repository.d.ts +0 -6
- package/src/domain/generic/repository/update.repository.js +0 -2
- package/src/domain/generic/repository/update.repository.js.map +0 -1
- package/src/domain/index.d.ts +0 -6
- package/src/domain/index.js +0 -7
- package/src/domain/index.js.map +0 -1
- package/src/domain/location/index.d.ts +0 -1
- package/src/domain/location/index.js +0 -2
- package/src/domain/location/index.js.map +0 -1
- package/src/domain/location/models/address.d.ts +0 -24
- package/src/domain/location/models/address.js +0 -7
- package/src/domain/location/models/address.js.map +0 -1
- package/src/domain/location/models/index.d.ts +0 -2
- package/src/domain/location/models/index.js +0 -3
- package/src/domain/location/models/index.js.map +0 -1
- package/src/domain/location/models/types/index.d.ts +0 -3
- package/src/domain/location/models/types/index.js +0 -4
- package/src/domain/location/models/types/index.js.map +0 -1
- package/src/domain/location/models/types/location-bound.type.d.ts +0 -6
- package/src/domain/location/models/types/location-bound.type.js +0 -2
- package/src/domain/location/models/types/location-bound.type.js.map +0 -1
- package/src/domain/location/models/types/location-geometry.type.d.ts +0 -7
- package/src/domain/location/models/types/location-geometry.type.js +0 -2
- package/src/domain/location/models/types/location-geometry.type.js.map +0 -1
- package/src/domain/location/models/types/location-lat-lng.type.d.ts +0 -4
- package/src/domain/location/models/types/location-lat-lng.type.js +0 -2
- package/src/domain/location/models/types/location-lat-lng.type.js.map +0 -1
- package/src/domain/shop-settings/enums/filter-type.enum.d.ts +0 -19
- package/src/domain/shop-settings/enums/filter-type.enum.js +0 -21
- package/src/domain/shop-settings/enums/filter-type.enum.js.map +0 -1
- package/src/domain/shop-settings/enums/index.d.ts +0 -2
- package/src/domain/shop-settings/enums/index.js +0 -3
- package/src/domain/shop-settings/enums/index.js.map +0 -1
- package/src/domain/shop-settings/enums/questions-filters.enum.d.ts +0 -19
- package/src/domain/shop-settings/enums/questions-filters.enum.js +0 -21
- package/src/domain/shop-settings/enums/questions-filters.enum.js.map +0 -1
- package/src/domain/shop-settings/helpers/beauty-questions.helper.d.ts +0 -9
- package/src/domain/shop-settings/helpers/beauty-questions.helper.js +0 -47
- package/src/domain/shop-settings/helpers/beauty-questions.helper.js.map +0 -1
- package/src/domain/shop-settings/helpers/index.d.ts +0 -1
- package/src/domain/shop-settings/helpers/index.js +0 -2
- package/src/domain/shop-settings/helpers/index.js.map +0 -1
- package/src/domain/shop-settings/index.d.ts +0 -4
- package/src/domain/shop-settings/index.js +0 -5
- package/src/domain/shop-settings/index.js.map +0 -1
- package/src/domain/shop-settings/models/home.d.ts +0 -18
- package/src/domain/shop-settings/models/home.js +0 -7
- package/src/domain/shop-settings/models/home.js.map +0 -1
- package/src/domain/shop-settings/models/index.d.ts +0 -4
- package/src/domain/shop-settings/models/index.js +0 -5
- package/src/domain/shop-settings/models/index.js.map +0 -1
- package/src/domain/shop-settings/models/shop-menu.d.ts +0 -7
- package/src/domain/shop-settings/models/shop-menu.js +0 -7
- package/src/domain/shop-settings/models/shop-menu.js.map +0 -1
- package/src/domain/shop-settings/models/shop-settings.d.ts +0 -9
- package/src/domain/shop-settings/models/shop-settings.js +0 -7
- package/src/domain/shop-settings/models/shop-settings.js.map +0 -1
- package/src/domain/shop-settings/models/types/banner.type.d.ts +0 -6
- package/src/domain/shop-settings/models/types/banner.type.js +0 -2
- package/src/domain/shop-settings/models/types/banner.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/benefit.type.d.ts +0 -5
- package/src/domain/shop-settings/models/types/benefit.type.js +0 -2
- package/src/domain/shop-settings/models/types/benefit.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/home-data.type.d.ts +0 -15
- package/src/domain/shop-settings/models/types/home-data.type.js +0 -2
- package/src/domain/shop-settings/models/types/home-data.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/index.d.ts +0 -10
- package/src/domain/shop-settings/models/types/index.js +0 -11
- package/src/domain/shop-settings/models/types/index.js.map +0 -1
- package/src/domain/shop-settings/models/types/menu-nav.type.d.ts +0 -8
- package/src/domain/shop-settings/models/types/menu-nav.type.js +0 -2
- package/src/domain/shop-settings/models/types/menu-nav.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/shop-banner.type.d.ts +0 -12
- package/src/domain/shop-settings/models/types/shop-banner.type.js +0 -2
- package/src/domain/shop-settings/models/types/shop-banner.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/shop-brands.type.d.ts +0 -10
- package/src/domain/shop-settings/models/types/shop-brands.type.js +0 -2
- package/src/domain/shop-settings/models/types/shop-brands.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/shop-carousel.type.d.ts +0 -5
- package/src/domain/shop-settings/models/types/shop-carousel.type.js +0 -2
- package/src/domain/shop-settings/models/types/shop-carousel.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/shop-collection.type.d.ts +0 -9
- package/src/domain/shop-settings/models/types/shop-collection.type.js +0 -2
- package/src/domain/shop-settings/models/types/shop-collection.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/shop-section.type.d.ts +0 -9
- package/src/domain/shop-settings/models/types/shop-section.type.js +0 -2
- package/src/domain/shop-settings/models/types/shop-section.type.js.map +0 -1
- package/src/domain/shop-settings/models/types/sub-menu.type.d.ts +0 -8
- package/src/domain/shop-settings/models/types/sub-menu.type.js +0 -2
- package/src/domain/shop-settings/models/types/sub-menu.type.js.map +0 -1
- package/src/domain/shop-settings/repositories/home.repository.d.ts +0 -4
- package/src/domain/shop-settings/repositories/home.repository.js +0 -2
- package/src/domain/shop-settings/repositories/home.repository.js.map +0 -1
- package/src/domain/shop-settings/repositories/index.d.ts +0 -3
- package/src/domain/shop-settings/repositories/index.js +0 -4
- package/src/domain/shop-settings/repositories/index.js.map +0 -1
- package/src/domain/shop-settings/repositories/shop-menu.repository.d.ts +0 -4
- package/src/domain/shop-settings/repositories/shop-menu.repository.js +0 -2
- package/src/domain/shop-settings/repositories/shop-menu.repository.js.map +0 -1
- package/src/domain/shop-settings/repositories/shop-settings.repository.d.ts +0 -4
- package/src/domain/shop-settings/repositories/shop-settings.repository.js +0 -2
- package/src/domain/shop-settings/repositories/shop-settings.repository.js.map +0 -1
- package/src/domain/shopping/index.d.ts +0 -2
- package/src/domain/shopping/index.js +0 -3
- package/src/domain/shopping/index.js.map +0 -1
- package/src/domain/shopping/models/buy-2-win.d.ts +0 -18
- package/src/domain/shopping/models/buy-2-win.js +0 -14
- package/src/domain/shopping/models/buy-2-win.js.map +0 -1
- package/src/domain/shopping/models/campaign-dashboard.d.ts +0 -15
- package/src/domain/shopping/models/campaign-dashboard.js +0 -7
- package/src/domain/shopping/models/campaign-dashboard.js.map +0 -1
- package/src/domain/shopping/models/campaign-hashtag.d.ts +0 -18
- package/src/domain/shopping/models/campaign-hashtag.js +0 -7
- package/src/domain/shopping/models/campaign-hashtag.js.map +0 -1
- package/src/domain/shopping/models/checkout.d.ts +0 -26
- package/src/domain/shopping/models/checkout.js +0 -37
- package/src/domain/shopping/models/checkout.js.map +0 -1
- package/src/domain/shopping/models/coupons/coupon.d.ts +0 -60
- package/src/domain/shopping/models/coupons/coupon.js +0 -38
- package/src/domain/shopping/models/coupons/coupon.js.map +0 -1
- package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.d.ts +0 -5
- package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js +0 -7
- package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js.map +0 -1
- package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.d.ts +0 -4
- package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js +0 -6
- package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js.map +0 -1
- package/src/domain/shopping/models/coupons/enums/coupon-types.enum.d.ts +0 -4
- package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js +0 -10
- package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js.map +0 -1
- package/src/domain/shopping/models/coupons/enums/exclusivities.enum.d.ts +0 -8
- package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js +0 -10
- package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js.map +0 -1
- package/src/domain/shopping/models/coupons/enums/index.d.ts +0 -3
- package/src/domain/shopping/models/coupons/enums/index.js +0 -4
- package/src/domain/shopping/models/coupons/enums/index.js.map +0 -1
- package/src/domain/shopping/models/coupons/index.d.ts +0 -2
- package/src/domain/shopping/models/coupons/index.js +0 -3
- package/src/domain/shopping/models/coupons/index.js.map +0 -1
- package/src/domain/shopping/models/enums/checkout-types.enum.d.ts +0 -5
- package/src/domain/shopping/models/enums/checkout-types.enum.js +0 -7
- package/src/domain/shopping/models/enums/checkout-types.enum.js.map +0 -1
- package/src/domain/shopping/models/enums/index.d.ts +0 -2
- package/src/domain/shopping/models/enums/index.js +0 -3
- package/src/domain/shopping/models/enums/index.js.map +0 -1
- package/src/domain/shopping/models/enums/order-status.enum.d.ts +0 -10
- package/src/domain/shopping/models/enums/order-status.enum.js +0 -12
- package/src/domain/shopping/models/enums/order-status.enum.js.map +0 -1
- package/src/domain/shopping/models/index.d.ts +0 -12
- package/src/domain/shopping/models/index.js +0 -13
- package/src/domain/shopping/models/index.js.map +0 -1
- package/src/domain/shopping/models/line-item.d.ts +0 -8
- package/src/domain/shopping/models/line-item.js +0 -4
- package/src/domain/shopping/models/line-item.js.map +0 -1
- package/src/domain/shopping/models/order.d.ts +0 -10
- package/src/domain/shopping/models/order.js +0 -11
- package/src/domain/shopping/models/order.js.map +0 -1
- package/src/domain/shopping/models/payment.d.ts +0 -67
- package/src/domain/shopping/models/payment.js +0 -169
- package/src/domain/shopping/models/payment.js.map +0 -1
- package/src/domain/shopping/models/shipping-method.d.ts +0 -17
- package/src/domain/shopping/models/shipping-method.js +0 -7
- package/src/domain/shopping/models/shipping-method.js.map +0 -1
- package/src/domain/shopping/models/subscription/checkout.d.ts +0 -20
- package/src/domain/shopping/models/subscription/checkout.js +0 -28
- package/src/domain/shopping/models/subscription/checkout.js.map +0 -1
- package/src/domain/shopping/models/subscription/index.d.ts +0 -2
- package/src/domain/shopping/models/subscription/index.js +0 -3
- package/src/domain/shopping/models/subscription/index.js.map +0 -1
- package/src/domain/shopping/models/subscription/plan.d.ts +0 -10
- package/src/domain/shopping/models/subscription/plan.js +0 -7
- package/src/domain/shopping/models/subscription/plan.js.map +0 -1
- package/src/domain/shopping/models/types/index.d.ts +0 -7
- package/src/domain/shopping/models/types/index.js +0 -8
- package/src/domain/shopping/models/types/index.js.map +0 -1
- package/src/domain/shopping/models/types/payment-address.type.d.ts +0 -12
- package/src/domain/shopping/models/types/payment-address.type.js +0 -2
- package/src/domain/shopping/models/types/payment-address.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-billing.type.d.ts +0 -7
- package/src/domain/shopping/models/types/payment-billing.type.js +0 -2
- package/src/domain/shopping/models/types/payment-billing.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-card.type.d.ts +0 -14
- package/src/domain/shopping/models/types/payment-card.type.js +0 -2
- package/src/domain/shopping/models/types/payment-card.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-customer.type.d.ts +0 -18
- package/src/domain/shopping/models/types/payment-customer.type.js +0 -2
- package/src/domain/shopping/models/types/payment-customer.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-document.type.d.ts +0 -6
- package/src/domain/shopping/models/types/payment-document.type.js +0 -2
- package/src/domain/shopping/models/types/payment-document.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-item.type.d.ts +0 -11
- package/src/domain/shopping/models/types/payment-item.type.js +0 -2
- package/src/domain/shopping/models/types/payment-item.type.js.map +0 -1
- package/src/domain/shopping/models/types/payment-shipping.type.d.ts +0 -10
- package/src/domain/shopping/models/types/payment-shipping.type.js +0 -2
- package/src/domain/shopping/models/types/payment-shipping.type.js.map +0 -1
- package/src/domain/shopping/repositories/buy-2-win.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/buy-2-win.repository.js +0 -2
- package/src/domain/shopping/repositories/buy-2-win.repository.js.map +0 -1
- package/src/domain/shopping/repositories/campaign-dashboard.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/campaign-dashboard.repository.js +0 -2
- package/src/domain/shopping/repositories/campaign-dashboard.repository.js.map +0 -1
- package/src/domain/shopping/repositories/campaign-hashtag.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/campaign-hashtag.repository.js +0 -2
- package/src/domain/shopping/repositories/campaign-hashtag.repository.js.map +0 -1
- package/src/domain/shopping/repositories/checkout.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/checkout.repository.js +0 -2
- package/src/domain/shopping/repositories/checkout.repository.js.map +0 -1
- package/src/domain/shopping/repositories/coupon.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/coupon.repository.js +0 -2
- package/src/domain/shopping/repositories/coupon.repository.js.map +0 -1
- package/src/domain/shopping/repositories/index.d.ts +0 -9
- package/src/domain/shopping/repositories/index.js +0 -10
- package/src/domain/shopping/repositories/index.js.map +0 -1
- package/src/domain/shopping/repositories/legacy-order.repository.d.ts +0 -3
- package/src/domain/shopping/repositories/legacy-order.repository.js +0 -2
- package/src/domain/shopping/repositories/legacy-order.repository.js.map +0 -1
- package/src/domain/shopping/repositories/order.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/order.repository.js +0 -2
- package/src/domain/shopping/repositories/order.repository.js.map +0 -1
- package/src/domain/shopping/repositories/payment.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/payment.repository.js +0 -2
- package/src/domain/shopping/repositories/payment.repository.js.map +0 -1
- package/src/domain/shopping/repositories/subscription/checkout.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/subscription/checkout.repository.js +0 -2
- package/src/domain/shopping/repositories/subscription/checkout.repository.js.map +0 -1
- package/src/domain/shopping/repositories/subscription/index.d.ts +0 -2
- package/src/domain/shopping/repositories/subscription/index.js +0 -3
- package/src/domain/shopping/repositories/subscription/index.js.map +0 -1
- package/src/domain/shopping/repositories/subscription/plan.repository.d.ts +0 -4
- package/src/domain/shopping/repositories/subscription/plan.repository.js +0 -2
- package/src/domain/shopping/repositories/subscription/plan.repository.js.map +0 -1
- package/src/domain/users/errors/index.d.ts +0 -3
- package/src/domain/users/errors/index.js +0 -4
- package/src/domain/users/errors/index.js.map +0 -1
- package/src/domain/users/errors/unauthorized.error.d.ts +0 -4
- package/src/domain/users/errors/unauthorized.error.js +0 -7
- package/src/domain/users/errors/unauthorized.error.js.map +0 -1
- package/src/domain/users/errors/user-already-registered.error.d.ts +0 -4
- package/src/domain/users/errors/user-already-registered.error.js +0 -7
- package/src/domain/users/errors/user-already-registered.error.js.map +0 -1
- package/src/domain/users/errors/weak-password.error.d.ts +0 -4
- package/src/domain/users/errors/weak-password.error.js +0 -7
- package/src/domain/users/errors/weak-password.error.js.map +0 -1
- package/src/domain/users/index.d.ts +0 -5
- package/src/domain/users/index.js +0 -6
- package/src/domain/users/index.js.map +0 -1
- package/src/domain/users/models/beauty-profile.d.ts +0 -11
- package/src/domain/users/models/beauty-profile.js +0 -12
- package/src/domain/users/models/beauty-profile.js.map +0 -1
- package/src/domain/users/models/enums/accessory-importances.enum.d.ts +0 -5
- package/src/domain/users/models/enums/accessory-importances.enum.js +0 -7
- package/src/domain/users/models/enums/accessory-importances.enum.js.map +0 -1
- package/src/domain/users/models/enums/area.enum.d.ts +0 -11
- package/src/domain/users/models/enums/area.enum.js +0 -13
- package/src/domain/users/models/enums/area.enum.js.map +0 -1
- package/src/domain/users/models/enums/beard-problems.enum.d.ts +0 -9
- package/src/domain/users/models/enums/beard-problems.enum.js +0 -11
- package/src/domain/users/models/enums/beard-problems.enum.js.map +0 -1
- package/src/domain/users/models/enums/beard-sizes.enum.d.ts +0 -7
- package/src/domain/users/models/enums/beard-sizes.enum.js +0 -9
- package/src/domain/users/models/enums/beard-sizes.enum.js.map +0 -1
- package/src/domain/users/models/enums/beauty-product-importances.enum.d.ts +0 -6
- package/src/domain/users/models/enums/beauty-product-importances.enum.js +0 -8
- package/src/domain/users/models/enums/beauty-product-importances.enum.js.map +0 -1
- package/src/domain/users/models/enums/body-problems.enum.d.ts +0 -11
- package/src/domain/users/models/enums/body-problems.enum.js +0 -13
- package/src/domain/users/models/enums/body-problems.enum.js.map +0 -1
- package/src/domain/users/models/enums/body-shapes.enum.d.ts +0 -7
- package/src/domain/users/models/enums/body-shapes.enum.js +0 -9
- package/src/domain/users/models/enums/body-shapes.enum.js.map +0 -1
- package/src/domain/users/models/enums/body-tattoos.enum.d.ts +0 -5
- package/src/domain/users/models/enums/body-tattoos.enum.js +0 -7
- package/src/domain/users/models/enums/body-tattoos.enum.js.map +0 -1
- package/src/domain/users/models/enums/face-skin-oilinesses.enum.d.ts +0 -7
- package/src/domain/users/models/enums/face-skin-oilinesses.enum.js +0 -9
- package/src/domain/users/models/enums/face-skin-oilinesses.enum.js.map +0 -1
- package/src/domain/users/models/enums/face-skin-problems.enum.d.ts +0 -10
- package/src/domain/users/models/enums/face-skin-problems.enum.js +0 -12
- package/src/domain/users/models/enums/face-skin-problems.enum.js.map +0 -1
- package/src/domain/users/models/enums/face-skin-tones.enum.d.ts +0 -8
- package/src/domain/users/models/enums/face-skin-tones.enum.js +0 -10
- package/src/domain/users/models/enums/face-skin-tones.enum.js.map +0 -1
- package/src/domain/users/models/enums/family-incomes.enum.d.ts +0 -8
- package/src/domain/users/models/enums/family-incomes.enum.js +0 -10
- package/src/domain/users/models/enums/family-incomes.enum.js.map +0 -1
- package/src/domain/users/models/enums/fragrance-importances.enum.d.ts +0 -5
- package/src/domain/users/models/enums/fragrance-importances.enum.js +0 -7
- package/src/domain/users/models/enums/fragrance-importances.enum.js.map +0 -1
- package/src/domain/users/models/enums/hair-colors.enum.d.ts +0 -10
- package/src/domain/users/models/enums/hair-colors.enum.js +0 -12
- package/src/domain/users/models/enums/hair-colors.enum.js.map +0 -1
- package/src/domain/users/models/enums/hair-problems.enum.d.ts +0 -10
- package/src/domain/users/models/enums/hair-problems.enum.js +0 -12
- package/src/domain/users/models/enums/hair-problems.enum.js.map +0 -1
- package/src/domain/users/models/enums/hair-strands.enum.d.ts +0 -8
- package/src/domain/users/models/enums/hair-strands.enum.js +0 -10
- package/src/domain/users/models/enums/hair-strands.enum.js.map +0 -1
- package/src/domain/users/models/enums/hair-types.enum.d.ts +0 -7
- package/src/domain/users/models/enums/hair-types.enum.js +0 -9
- package/src/domain/users/models/enums/hair-types.enum.js.map +0 -1
- package/src/domain/users/models/enums/index.d.ts +0 -20
- package/src/domain/users/models/enums/index.js +0 -21
- package/src/domain/users/models/enums/index.js.map +0 -1
- package/src/domain/users/models/enums/office-position.enum.d.ts +0 -6
- package/src/domain/users/models/enums/office-position.enum.js +0 -8
- package/src/domain/users/models/enums/office-position.enum.js.map +0 -1
- package/src/domain/users/models/enums/product-spents.enum.d.ts +0 -8
- package/src/domain/users/models/enums/product-spents.enum.js +0 -10
- package/src/domain/users/models/enums/product-spents.enum.js.map +0 -1
- package/src/domain/users/models/enums/user-type.enum.d.ts +0 -8
- package/src/domain/users/models/enums/user-type.enum.js +0 -10
- package/src/domain/users/models/enums/user-type.enum.js.map +0 -1
- package/src/domain/users/models/index.d.ts +0 -7
- package/src/domain/users/models/index.js +0 -8
- package/src/domain/users/models/index.js.map +0 -1
- package/src/domain/users/models/lead.d.ts +0 -8
- package/src/domain/users/models/lead.js +0 -7
- package/src/domain/users/models/lead.js.map +0 -1
- package/src/domain/users/models/subscription/edition.d.ts +0 -16
- package/src/domain/users/models/subscription/edition.js +0 -7
- package/src/domain/users/models/subscription/edition.js.map +0 -1
- package/src/domain/users/models/subscription/enums/billing-status.enum.d.ts +0 -3
- package/src/domain/users/models/subscription/enums/billing-status.enum.js +0 -5
- package/src/domain/users/models/subscription/enums/billing-status.enum.js.map +0 -1
- package/src/domain/users/models/subscription/enums/edition-status.enum.d.ts +0 -4
- package/src/domain/users/models/subscription/enums/edition-status.enum.js +0 -6
- package/src/domain/users/models/subscription/enums/edition-status.enum.js.map +0 -1
- package/src/domain/users/models/subscription/enums/index.d.ts +0 -4
- package/src/domain/users/models/subscription/enums/index.js +0 -5
- package/src/domain/users/models/subscription/enums/index.js.map +0 -1
- package/src/domain/users/models/subscription/enums/payment-type.enum.d.ts +0 -5
- package/src/domain/users/models/subscription/enums/payment-type.enum.js +0 -7
- package/src/domain/users/models/subscription/enums/payment-type.enum.js.map +0 -1
- package/src/domain/users/models/subscription/enums/status.enum.d.ts +0 -4
- package/src/domain/users/models/subscription/enums/status.enum.js +0 -6
- package/src/domain/users/models/subscription/enums/status.enum.js.map +0 -1
- package/src/domain/users/models/subscription/index.d.ts +0 -4
- package/src/domain/users/models/subscription/index.js +0 -5
- package/src/domain/users/models/subscription/index.js.map +0 -1
- package/src/domain/users/models/subscription/payment.d.ts +0 -13
- package/src/domain/users/models/subscription/payment.js +0 -14
- package/src/domain/users/models/subscription/payment.js.map +0 -1
- package/src/domain/users/models/subscription/subscription.d.ts +0 -28
- package/src/domain/users/models/subscription/subscription.js +0 -43
- package/src/domain/users/models/subscription/subscription.js.map +0 -1
- package/src/domain/users/models/user-address.d.ts +0 -6
- package/src/domain/users/models/user-address.js +0 -7
- package/src/domain/users/models/user-address.js.map +0 -1
- package/src/domain/users/models/user-payment-method.d.ts +0 -14
- package/src/domain/users/models/user-payment-method.js +0 -7
- package/src/domain/users/models/user-payment-method.js.map +0 -1
- package/src/domain/users/models/user.d.ts +0 -27
- package/src/domain/users/models/user.js +0 -26
- package/src/domain/users/models/user.js.map +0 -1
- package/src/domain/users/repositories/beauty-profile.repository.d.ts +0 -4
- package/src/domain/users/repositories/beauty-profile.repository.js +0 -2
- package/src/domain/users/repositories/beauty-profile.repository.js.map +0 -1
- package/src/domain/users/repositories/edition.repository.d.ts +0 -4
- package/src/domain/users/repositories/edition.repository.js +0 -2
- package/src/domain/users/repositories/edition.repository.js.map +0 -1
- package/src/domain/users/repositories/index.d.ts +0 -8
- package/src/domain/users/repositories/index.js +0 -9
- package/src/domain/users/repositories/index.js.map +0 -1
- package/src/domain/users/repositories/lead.repository.d.ts +0 -4
- package/src/domain/users/repositories/lead.repository.js +0 -2
- package/src/domain/users/repositories/lead.repository.js.map +0 -1
- package/src/domain/users/repositories/subscription-payment.repository.d.ts +0 -4
- package/src/domain/users/repositories/subscription-payment.repository.js +0 -2
- package/src/domain/users/repositories/subscription-payment.repository.js.map +0 -1
- package/src/domain/users/repositories/subscription.repository.d.ts +0 -4
- package/src/domain/users/repositories/subscription.repository.js +0 -2
- package/src/domain/users/repositories/subscription.repository.js.map +0 -1
- package/src/domain/users/repositories/user-address.repository.d.ts +0 -4
- package/src/domain/users/repositories/user-address.repository.js +0 -2
- package/src/domain/users/repositories/user-address.repository.js.map +0 -1
- package/src/domain/users/repositories/user-payment-method.repository.d.ts +0 -4
- package/src/domain/users/repositories/user-payment-method.repository.js +0 -2
- package/src/domain/users/repositories/user-payment-method.repository.js.map +0 -1
- package/src/domain/users/repositories/user.repository.d.ts +0 -6
- package/src/domain/users/repositories/user.repository.js +0 -2
- package/src/domain/users/repositories/user.repository.js.map +0 -1
- package/src/domain/users/services/authentication.service.d.ts +0 -12
- package/src/domain/users/services/authentication.service.js +0 -2
- package/src/domain/users/services/authentication.service.js.map +0 -1
- package/src/domain/users/services/index.d.ts +0 -3
- package/src/domain/users/services/index.js +0 -4
- package/src/domain/users/services/index.js.map +0 -1
- package/src/domain/users/services/register.service.d.ts +0 -7
- package/src/domain/users/services/register.service.js +0 -2
- package/src/domain/users/services/register.service.js.map +0 -1
- package/src/domain/users/services/types/basic-user-data.type.d.ts +0 -4
- package/src/domain/users/services/types/basic-user-data.type.js +0 -2
- package/src/domain/users/services/types/basic-user-data.type.js.map +0 -1
- package/src/domain/users/services/types/index.d.ts +0 -1
- package/src/domain/users/services/types/index.js +0 -2
- package/src/domain/users/services/types/index.js.map +0 -1
- package/src/domain/users/use-cases/authentication.d.ts +0 -21
- package/src/domain/users/use-cases/authentication.js +0 -35
- package/src/domain/users/use-cases/authentication.js.map +0 -1
- package/src/domain/users/use-cases/index.d.ts +0 -4
- package/src/domain/users/use-cases/index.js +0 -5
- package/src/domain/users/use-cases/index.js.map +0 -1
- package/src/domain/users/use-cases/recovery-password.d.ts +0 -6
- package/src/domain/users/use-cases/recovery-password.js +0 -9
- package/src/domain/users/use-cases/recovery-password.js.map +0 -1
- package/src/domain/users/use-cases/register.d.ts +0 -13
- package/src/domain/users/use-cases/register.js +0 -31
- package/src/domain/users/use-cases/register.js.map +0 -1
- package/src/domain/users/use-cases/signout.d.ts +0 -6
- package/src/domain/users/use-cases/signout.js +0 -9
- package/src/domain/users/use-cases/signout.js.map +0 -1
- package/src/errors/duplicated-results.error.d.ts +0 -4
- package/src/errors/duplicated-results.error.js +0 -7
- package/src/errors/duplicated-results.error.js.map +0 -1
- package/src/errors/index.d.ts +0 -4
- package/src/errors/index.js +0 -5
- package/src/errors/index.js.map +0 -1
- package/src/errors/invalid-argument.error.d.ts +0 -4
- package/src/errors/invalid-argument.error.js +0 -7
- package/src/errors/invalid-argument.error.js.map +0 -1
- package/src/errors/not-found.error.d.ts +0 -4
- package/src/errors/not-found.error.js +0 -7
- package/src/errors/not-found.error.js.map +0 -1
- package/src/errors/required-argument.error.d.ts +0 -6
- package/src/errors/required-argument.error.js +0 -9
- package/src/errors/required-argument.error.js.map +0 -1
- package/src/index.d.ts +0 -5
- package/src/index.js +0 -6
- package/src/index.js.map +0 -1
- package/src/infra/elasticsearch/adapters/axios.adapter.d.ts +0 -16
- package/src/infra/elasticsearch/adapters/axios.adapter.js +0 -67
- package/src/infra/elasticsearch/adapters/axios.adapter.js.map +0 -1
- package/src/infra/elasticsearch/adapters/elastic-search.adapter.d.ts +0 -8
- package/src/infra/elasticsearch/adapters/elastic-search.adapter.js +0 -2
- package/src/infra/elasticsearch/adapters/elastic-search.adapter.js.map +0 -1
- package/src/infra/elasticsearch/adapters/index.d.ts +0 -2
- package/src/infra/elasticsearch/adapters/index.js +0 -3
- package/src/infra/elasticsearch/adapters/index.js.map +0 -1
- package/src/infra/elasticsearch/index.d.ts +0 -3
- package/src/infra/elasticsearch/index.js +0 -4
- package/src/infra/elasticsearch/index.js.map +0 -1
- package/src/infra/elasticsearch/indexes/index.d.ts +0 -1
- package/src/infra/elasticsearch/indexes/index.js +0 -2
- package/src/infra/elasticsearch/indexes/index.js.map +0 -1
- package/src/infra/elasticsearch/indexes/products-index.d.ts +0 -13
- package/src/infra/elasticsearch/indexes/products-index.js +0 -105
- package/src/infra/elasticsearch/indexes/products-index.js.map +0 -1
- package/src/infra/elasticsearch/types/elastic-search-result.d.ts +0 -9
- package/src/infra/elasticsearch/types/elastic-search-result.js +0 -2
- package/src/infra/elasticsearch/types/elastic-search-result.js.map +0 -1
- package/src/infra/elasticsearch/types/index.d.ts +0 -1
- package/src/infra/elasticsearch/types/index.js +0 -2
- package/src/infra/elasticsearch/types/index.js.map +0 -1
- package/src/infra/firebase/auth/authentication-firebase-auth.service.d.ts +0 -12
- package/src/infra/firebase/auth/authentication-firebase-auth.service.js +0 -41
- package/src/infra/firebase/auth/authentication-firebase-auth.service.js.map +0 -1
- package/src/infra/firebase/auth/index.d.ts +0 -2
- package/src/infra/firebase/auth/index.js +0 -3
- package/src/infra/firebase/auth/index.js.map +0 -1
- package/src/infra/firebase/auth/register-firebase-auth.service.d.ts +0 -8
- package/src/infra/firebase/auth/register-firebase-auth.service.js +0 -33
- package/src/infra/firebase/auth/register-firebase-auth.service.js.map +0 -1
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.d.ts +0 -5
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.js +0 -2
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.js.map +0 -1
- package/src/infra/firebase/auth/types/index.d.ts +0 -1
- package/src/infra/firebase/auth/types/index.js +0 -2
- package/src/infra/firebase/auth/types/index.js.map +0 -1
- package/src/infra/firebase/firestore/enums/firestore-field-type.enum.d.ts +0 -8
- package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js +0 -10
- package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js.map +0 -1
- package/src/infra/firebase/firestore/enums/index.d.ts +0 -1
- package/src/infra/firebase/firestore/enums/index.js +0 -2
- package/src/infra/firebase/firestore/enums/index.js.map +0 -1
- package/src/infra/firebase/firestore/index.d.ts +0 -3
- package/src/infra/firebase/firestore/index.js +0 -4
- package/src/infra/firebase/firestore/index.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/index.d.ts +0 -9
- package/src/infra/firebase/firestore/mixins/index.js +0 -10
- package/src/infra/firebase/firestore/mixins/index.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.d.ts +0 -4
- package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js +0 -33
- package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.d.ts +0 -5
- package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js +0 -10
- package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.d.ts +0 -4
- package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js +0 -19
- package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.d.ts +0 -4
- package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js +0 -109
- package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.d.ts +0 -13
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js +0 -77
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.d.ts +0 -4
- package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js +0 -24
- package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-helpers.mixin.d.ts +0 -11
- package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js +0 -17
- package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.d.ts +0 -11
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js +0 -13
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.d.ts +0 -7
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js +0 -52
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.d.ts +0 -20
- package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js +0 -67
- package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/catalog/index.d.ts +0 -4
- package/src/infra/firebase/firestore/repositories/catalog/index.js +0 -5
- package/src/infra/firebase/firestore/repositories/catalog/index.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js +0 -56
- package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/index.d.ts +0 -4
- package/src/infra/firebase/firestore/repositories/index.js +0 -5
- package/src/infra/firebase/firestore/repositories/index.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.d.ts +0 -16
- package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js +0 -66
- package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shop-settings/index.d.ts +0 -3
- package/src/infra/firebase/firestore/repositories/shop-settings/index.js +0 -4
- package/src/infra/firebase/firestore/repositories/shop-settings/index.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.d.ts +0 -8
- package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.d.ts +0 -8
- package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js +0 -31
- package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/index.d.ts +0 -10
- package/src/infra/firebase/firestore/repositories/shopping/index.js +0 -11
- package/src/infra/firebase/firestore/repositories/shopping/index.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.d.ts +0 -6
- package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js +0 -11
- package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.d.ts +0 -13
- package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js +0 -41
- package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/index.d.ts +0 -8
- package/src/infra/firebase/firestore/repositories/users/index.js +0 -9
- package/src/infra/firebase/firestore/repositories/users/index.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.d.ts +0 -7
- package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js +0 -14
- package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.d.ts +0 -17
- package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js +0 -50
- package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.d.ts +0 -12
- package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js +0 -16
- package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js.map +0 -1
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.d.ts +0 -14
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.js +0 -2
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.js.map +0 -1
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.d.ts +0 -6
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js +0 -2
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js.map +0 -1
- package/src/infra/firebase/firestore/types/firestore.helpers.type.d.ts +0 -8
- package/src/infra/firebase/firestore/types/firestore.helpers.type.js +0 -2
- package/src/infra/firebase/firestore/types/firestore.helpers.type.js.map +0 -1
- package/src/infra/firebase/firestore/types/firestore.repository.type.d.ts +0 -16
- package/src/infra/firebase/firestore/types/firestore.repository.type.js +0 -2
- package/src/infra/firebase/firestore/types/firestore.repository.type.js.map +0 -1
- package/src/infra/firebase/firestore/types/index.d.ts +0 -4
- package/src/infra/firebase/firestore/types/index.js +0 -5
- package/src/infra/firebase/firestore/types/index.js.map +0 -1
- package/src/infra/firebase/index.d.ts +0 -2
- package/src/infra/firebase/index.js +0 -3
- package/src/infra/firebase/index.js.map +0 -1
- package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.d.ts +0 -11
- package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js +0 -13
- package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js.map +0 -1
- package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.d.ts +0 -15
- package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js +0 -17
- package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js.map +0 -1
- package/src/infra/hasura-graphql/enums/index.d.ts +0 -2
- package/src/infra/hasura-graphql/enums/index.js +0 -3
- package/src/infra/hasura-graphql/enums/index.js.map +0 -1
- package/src/infra/hasura-graphql/index.d.ts +0 -4
- package/src/infra/hasura-graphql/index.js +0 -5
- package/src/infra/hasura-graphql/index.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.d.ts +0 -19
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js +0 -32
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.d.ts +0 -10
- package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js +0 -56
- package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.d.ts +0 -8
- package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js +0 -22
- package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.d.ts +0 -12
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js +0 -104
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/helpers/index.d.ts +0 -4
- package/src/infra/hasura-graphql/mixins/helpers/index.js +0 -5
- package/src/infra/hasura-graphql/mixins/helpers/index.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/index.d.ts +0 -7
- package/src/infra/hasura-graphql/mixins/index.js +0 -8
- package/src/infra/hasura-graphql/mixins/index.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.d.ts +0 -9
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js +0 -41
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.d.ts +0 -11
- package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js +0 -10
- package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.d.ts +0 -7
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js +0 -28
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +0 -34
- package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +0 -143
- package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +0 -25
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js +0 -35
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.d.ts +0 -23
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js +0 -105
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.d.ts +0 -14
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js +0 -57
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js.map +0 -1
- package/src/infra/hasura-graphql/models/category-hasura-graphql.d.ts +0 -6
- package/src/infra/hasura-graphql/models/category-hasura-graphql.js +0 -4
- package/src/infra/hasura-graphql/models/category-hasura-graphql.js.map +0 -1
- package/src/infra/hasura-graphql/models/index.d.ts +0 -4
- package/src/infra/hasura-graphql/models/index.js +0 -5
- package/src/infra/hasura-graphql/models/index.js.map +0 -1
- package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.d.ts +0 -6
- package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js +0 -15
- package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js.map +0 -1
- package/src/infra/hasura-graphql/models/product-hasura-graphql.d.ts +0 -18
- package/src/infra/hasura-graphql/models/product-hasura-graphql.js +0 -11
- package/src/infra/hasura-graphql/models/product-hasura-graphql.js.map +0 -1
- package/src/infra/hasura-graphql/models/variant-hasura-graphql.d.ts +0 -10
- package/src/infra/hasura-graphql/models/variant-hasura-graphql.js +0 -9
- package/src/infra/hasura-graphql/models/variant-hasura-graphql.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.d.ts +0 -10
- package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js +0 -39
- package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.d.ts +0 -12
- package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +0 -107
- package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.d.ts +0 -34
- package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +0 -330
- package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.d.ts +0 -18
- package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js +0 -106
- package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.d.ts +0 -10
- package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js +0 -22
- package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/index.d.ts +0 -8
- package/src/infra/hasura-graphql/repositories/catalog/index.js +0 -9
- package/src/infra/hasura-graphql/repositories/catalog/index.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.d.ts +0 -30
- package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +0 -461
- package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.d.ts +0 -14
- package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js +0 -107
- package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.d.ts +0 -27
- package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js +0 -228
- package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js.map +0 -1
- package/src/infra/hasura-graphql/repositories/index.d.ts +0 -1
- package/src/infra/hasura-graphql/repositories/index.js +0 -2
- package/src/infra/hasura-graphql/repositories/index.js.map +0 -1
- package/src/infra/hasura-graphql/types/fields.type.d.ts +0 -2
- package/src/infra/hasura-graphql/types/fields.type.js +0 -2
- package/src/infra/hasura-graphql/types/fields.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/graphql.repository.type.d.ts +0 -24
- package/src/infra/hasura-graphql/types/graphql.repository.type.js +0 -2
- package/src/infra/hasura-graphql/types/graphql.repository.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.d.ts +0 -8
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js +0 -2
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.d.ts +0 -44
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js +0 -2
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.d.ts +0 -7
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js +0 -2
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/index.d.ts +0 -8
- package/src/infra/hasura-graphql/types/index.js +0 -9
- package/src/infra/hasura-graphql/types/index.js.map +0 -1
- package/src/infra/hasura-graphql/types/nested-field.type.d.ts +0 -7
- package/src/infra/hasura-graphql/types/nested-field.type.js +0 -2
- package/src/infra/hasura-graphql/types/nested-field.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/query-builder-options.type.d.ts +0 -7
- package/src/infra/hasura-graphql/types/query-builder-options.type.js +0 -2
- package/src/infra/hasura-graphql/types/query-builder-options.type.js.map +0 -1
- package/src/infra/hasura-graphql/types/variable-options.type.d.ts +0 -9
- package/src/infra/hasura-graphql/types/variable-options.type.js +0 -2
- package/src/infra/hasura-graphql/types/variable-options.type.js.map +0 -1
- package/src/infra/index.d.ts +0 -3
- package/src/infra/index.js +0 -4
- package/src/infra/index.js.map +0 -1
- package/src/utils/decorators/debug.class.decorator.d.ts +0 -2
- package/src/utils/decorators/debug.class.decorator.js +0 -7
- package/src/utils/decorators/debug.class.decorator.js.map +0 -1
- package/src/utils/decorators/index.d.ts +0 -2
- package/src/utils/decorators/index.js +0 -3
- package/src/utils/decorators/index.js.map +0 -1
- package/src/utils/decorators/trace.method.decorator.d.ts +0 -14
- package/src/utils/decorators/trace.method.decorator.js +0 -81
- package/src/utils/decorators/trace.method.decorator.js.map +0 -1
- package/src/utils/get.d.ts +0 -1
- package/src/utils/get.js +0 -3
- package/src/utils/get.js.map +0 -1
- package/src/utils/helpers/class-name.helper.d.ts +0 -3
- package/src/utils/helpers/class-name.helper.js +0 -15
- package/src/utils/helpers/class-name.helper.js.map +0 -1
- package/src/utils/helpers/debug-decorator.helper.d.ts +0 -9
- package/src/utils/helpers/debug-decorator.helper.js +0 -18
- package/src/utils/helpers/debug-decorator.helper.js.map +0 -1
- package/src/utils/helpers/debug.helper.d.ts +0 -60
- package/src/utils/helpers/debug.helper.js +0 -150
- package/src/utils/helpers/debug.helper.js.map +0 -1
- package/src/utils/helpers/index.d.ts +0 -4
- package/src/utils/helpers/index.js +0 -5
- package/src/utils/helpers/index.js.map +0 -1
- package/src/utils/helpers/reflect.helper.d.ts +0 -50
- package/src/utils/helpers/reflect.helper.js +0 -165
- package/src/utils/helpers/reflect.helper.js.map +0 -1
- package/src/utils/index.d.ts +0 -13
- package/src/utils/index.js +0 -13
- package/src/utils/index.js.map +0 -1
- package/src/utils/is-uuid.d.ts +0 -1
- package/src/utils/is-uuid.js +0 -3
- package/src/utils/is-uuid.js.map +0 -1
- package/src/utils/is.d.ts +0 -1
- package/src/utils/is.js +0 -4
- package/src/utils/is.js.map +0 -1
- package/src/utils/log.utils.d.ts +0 -7
- package/src/utils/log.utils.js +0 -9
- package/src/utils/log.utils.js.map +0 -1
- package/src/utils/mixins/base.mixin.d.ts +0 -3
- package/src/utils/mixins/base.mixin.js +0 -6
- package/src/utils/mixins/base.mixin.js.map +0 -1
- package/src/utils/mixins/index.d.ts +0 -3
- package/src/utils/mixins/index.js +0 -4
- package/src/utils/mixins/index.js.map +0 -1
- package/src/utils/mixins/merge-constructor-params.type.d.ts +0 -3
- package/src/utils/mixins/merge-constructor-params.type.js +0 -2
- package/src/utils/mixins/merge-constructor-params.type.js.map +0 -1
- package/src/utils/mixins/mixin-ctor.type.d.ts +0 -1
- package/src/utils/mixins/mixin-ctor.type.js +0 -2
- package/src/utils/mixins/mixin-ctor.type.js.map +0 -1
- package/src/utils/parse-datetime.d.ts +0 -1
- package/src/utils/parse-datetime.js +0 -14
- package/src/utils/parse-datetime.js.map +0 -1
- package/src/utils/types/array-element.type.d.ts +0 -1
- package/src/utils/types/array-element.type.js +0 -2
- package/src/utils/types/array-element.type.js.map +0 -1
- package/src/utils/types/index.d.ts +0 -2
- package/src/utils/types/index.js +0 -3
- package/src/utils/types/index.js.map +0 -1
- package/src/utils/types/prop.type.d.ts +0 -1
- package/src/utils/types/prop.type.js +0 -2
- package/src/utils/types/prop.type.js.map +0 -1
|
@@ -1,33 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,5 +0,0 @@
|
|
|
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>>>;
|
|
@@ -1,10 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
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, []>;
|
|
@@ -1,19 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
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, []>;
|
|
@@ -1,109 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,13 +0,0 @@
|
|
|
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[]>;
|
|
@@ -1,77 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
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, []>;
|
|
@@ -1,24 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,11 +0,0 @@
|
|
|
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;
|
|
@@ -1,17 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,11 +0,0 @@
|
|
|
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>>>;
|
|
@@ -1,13 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
|
@@ -1,7 +0,0 @@
|
|
|
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, []>;
|
|
@@ -1,52 +0,0 @@
|
|
|
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
|
|
@@ -1 +0,0 @@
|
|
|
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"]}
|
package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.d.ts
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
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 {};
|