@infrab4a/connect 4.0.2-beta.14 → 4.0.2-beta.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +2 -0
- package/index.js.map +1 -0
- package/package.json +4 -11
- package/src/domain/catalog/helpers/index.js +2 -0
- package/src/domain/catalog/helpers/index.js.map +1 -0
- package/src/domain/catalog/helpers/round-product-price.helper.js +15 -0
- package/src/domain/catalog/helpers/round-product-price.helper.js.map +1 -0
- package/src/domain/catalog/index.js +4 -0
- package/src/domain/catalog/index.js.map +1 -0
- package/src/domain/catalog/models/category-base.js +18 -0
- package/src/domain/catalog/models/category-base.js.map +1 -0
- package/src/domain/catalog/models/category-collection-children.d.ts +1 -1
- package/src/domain/catalog/models/category-collection-children.js +13 -0
- package/src/domain/catalog/models/category-collection-children.js.map +1 -0
- package/src/domain/catalog/models/category-filter.d.ts +1 -1
- package/src/domain/catalog/models/category-filter.js +19 -0
- package/src/domain/catalog/models/category-filter.js.map +1 -0
- package/src/domain/catalog/models/category-for-product.js +7 -0
- package/src/domain/catalog/models/category-for-product.js.map +1 -0
- package/src/domain/catalog/models/category.js +14 -0
- package/src/domain/catalog/models/category.js.map +1 -0
- package/src/domain/catalog/models/enums/index.js +3 -0
- package/src/domain/catalog/models/enums/index.js.map +1 -0
- package/src/domain/catalog/models/enums/product-genders.enum.js +7 -0
- package/src/domain/catalog/models/enums/product-genders.enum.js.map +1 -0
- package/src/domain/catalog/models/enums/shops.enum.js +8 -0
- package/src/domain/catalog/models/enums/shops.enum.js.map +1 -0
- package/src/domain/catalog/models/filter-option.js +7 -0
- package/src/domain/catalog/models/filter-option.js.map +1 -0
- package/src/domain/catalog/models/filter.js +7 -0
- package/src/domain/catalog/models/filter.js.map +1 -0
- package/src/domain/catalog/models/index.js +12 -0
- package/src/domain/catalog/models/index.js.map +1 -0
- package/src/domain/catalog/models/kit-product.d.ts +1 -1
- package/src/domain/catalog/models/kit-product.js +18 -0
- package/src/domain/catalog/models/kit-product.js.map +1 -0
- package/src/domain/catalog/models/product-base.js +25 -0
- package/src/domain/catalog/models/product-base.js.map +1 -0
- package/src/domain/catalog/models/product-for-category.js +14 -0
- package/src/domain/catalog/models/product-for-category.js.map +1 -0
- package/src/domain/catalog/models/product-for-kit.js +14 -0
- package/src/domain/catalog/models/product-for-kit.js.map +1 -0
- package/src/domain/catalog/models/product.js +19 -0
- package/src/domain/catalog/models/product.js.map +1 -0
- package/src/domain/catalog/models/types/category-condition.type.d.ts +1 -1
- package/src/domain/catalog/models/types/category-condition.type.js +2 -0
- package/src/domain/catalog/models/types/category-condition.type.js.map +1 -0
- package/src/domain/catalog/models/types/category-metadata.type.d.ts +1 -1
- package/src/domain/catalog/models/types/category-metadata.type.js +2 -0
- package/src/domain/catalog/models/types/category-metadata.type.js.map +1 -0
- package/src/domain/catalog/models/types/category-product.d.ts +1 -1
- package/src/domain/catalog/models/types/category-product.js +2 -0
- package/src/domain/catalog/models/types/category-product.js.map +1 -0
- package/src/domain/catalog/models/types/index.js +12 -0
- package/src/domain/catalog/models/types/index.js.map +1 -0
- package/src/domain/catalog/models/types/product-evaluation.type.d.ts +1 -1
- package/src/domain/catalog/models/types/product-evaluation.type.js +2 -0
- package/src/domain/catalog/models/types/product-evaluation.type.js.map +1 -0
- package/src/domain/catalog/models/types/product-gender.type.d.ts +1 -1
- package/src/domain/catalog/models/types/product-gender.type.js +2 -0
- package/src/domain/catalog/models/types/product-gender.type.js.map +1 -0
- package/src/domain/catalog/models/types/product-metadata.type.d.ts +1 -1
- package/src/domain/catalog/models/types/product-metadata.type.js +2 -0
- package/src/domain/catalog/models/types/product-metadata.type.js.map +1 -0
- package/src/domain/catalog/models/types/product-review.type.d.ts +1 -1
- package/src/domain/catalog/models/types/product-review.type.js +2 -0
- package/src/domain/catalog/models/types/product-review.type.js.map +1 -0
- package/src/domain/catalog/models/types/shop-description.type.d.ts +1 -1
- package/src/domain/catalog/models/types/shop-description.type.js +2 -0
- package/src/domain/catalog/models/types/shop-description.type.js.map +1 -0
- package/src/domain/catalog/models/types/shop-price.type.d.ts +1 -1
- package/src/domain/catalog/models/types/shop-price.type.js +2 -0
- package/src/domain/catalog/models/types/shop-price.type.js.map +1 -0
- package/src/domain/catalog/models/types/stock.type.d.ts +1 -1
- package/src/domain/catalog/models/types/stock.type.js +2 -0
- package/src/domain/catalog/models/types/stock.type.js.map +1 -0
- package/src/domain/catalog/models/types/variant-grade.type.d.ts +1 -1
- package/src/domain/catalog/models/types/variant-grade.type.js +2 -0
- package/src/domain/catalog/models/types/variant-grade.type.js.map +1 -0
- package/src/domain/catalog/models/variant.d.ts +1 -1
- package/src/domain/catalog/models/variant.js +7 -0
- package/src/domain/catalog/models/variant.js.map +1 -0
- package/src/domain/catalog/models/wishlist.js +7 -0
- package/src/domain/catalog/models/wishlist.js.map +1 -0
- package/src/domain/catalog/repositories/category-collection-children.repository.js +2 -0
- package/src/domain/catalog/repositories/category-collection-children.repository.js.map +1 -0
- package/src/domain/catalog/repositories/category-filter.repository.js +2 -0
- package/src/domain/catalog/repositories/category-filter.repository.js.map +1 -0
- package/src/domain/catalog/repositories/category.repository.js +2 -0
- package/src/domain/catalog/repositories/category.repository.js.map +1 -0
- package/src/domain/catalog/repositories/filter-option.repository.js +2 -0
- package/src/domain/catalog/repositories/filter-option.repository.js.map +1 -0
- package/src/domain/catalog/repositories/filter.repository.js +2 -0
- package/src/domain/catalog/repositories/filter.repository.js.map +1 -0
- package/src/domain/catalog/repositories/index.js +10 -0
- package/src/domain/catalog/repositories/index.js.map +1 -0
- package/src/domain/catalog/repositories/product.repository.d.ts +2 -2
- package/src/domain/catalog/repositories/product.repository.js +2 -0
- package/src/domain/catalog/repositories/product.repository.js.map +1 -0
- package/src/domain/catalog/repositories/subscription-product.repository.js +2 -0
- package/src/domain/catalog/repositories/subscription-product.repository.js.map +1 -0
- package/src/domain/catalog/repositories/variant.repository.js +2 -0
- package/src/domain/catalog/repositories/variant.repository.js.map +1 -0
- package/src/domain/catalog/repositories/wishlist.repository.js +2 -0
- package/src/domain/catalog/repositories/wishlist.repository.js.map +1 -0
- package/src/domain/generic/index.js +3 -0
- package/src/domain/generic/index.js.map +1 -0
- package/src/domain/generic/model/base.model.d.ts +1 -1
- package/src/domain/generic/model/base.model.js +24 -0
- package/src/domain/generic/model/base.model.js.map +1 -0
- package/src/domain/generic/model/identifier-fields.js +2 -0
- package/src/domain/generic/model/identifier-fields.js.map +1 -0
- package/src/domain/generic/model/index.js +4 -0
- package/src/domain/generic/model/index.js.map +1 -0
- package/src/domain/generic/model/types/base-model-builder.type.js +2 -0
- package/src/domain/generic/model/types/base-model-builder.type.js.map +1 -0
- package/src/domain/generic/model/types/identifier-model.type.d.ts +3 -3
- package/src/domain/generic/model/types/identifier-model.type.js +2 -0
- package/src/domain/generic/model/types/identifier-model.type.js.map +1 -0
- package/src/domain/generic/model/types/index.js +6 -0
- package/src/domain/generic/model/types/index.js.map +1 -0
- package/src/domain/generic/model/types/model-base-structure.type.d.ts +2 -2
- package/src/domain/generic/model/types/model-base-structure.type.js +2 -0
- package/src/domain/generic/model/types/model-base-structure.type.js.map +1 -0
- package/src/domain/generic/model/types/non-function-properties.type.d.ts +6 -6
- package/src/domain/generic/model/types/non-function-properties.type.js +2 -0
- package/src/domain/generic/model/types/non-function-properties.type.js.map +1 -0
- package/src/domain/generic/model/types/non-function-property-name.type.d.ts +5 -5
- package/src/domain/generic/model/types/non-function-property-name.type.js +2 -0
- package/src/domain/generic/model/types/non-function-property-name.type.js.map +1 -0
- package/src/domain/generic/repository/create.repository.d.ts +1 -1
- package/src/domain/generic/repository/create.repository.js +2 -0
- package/src/domain/generic/repository/create.repository.js.map +1 -0
- package/src/domain/generic/repository/crud.repository.d.ts +2 -2
- package/src/domain/generic/repository/crud.repository.js +2 -0
- package/src/domain/generic/repository/crud.repository.js.map +1 -0
- package/src/domain/generic/repository/delete.repository.d.ts +1 -1
- package/src/domain/generic/repository/delete.repository.js +2 -0
- package/src/domain/generic/repository/delete.repository.js.map +1 -0
- package/src/domain/generic/repository/enums/index.js +3 -0
- package/src/domain/generic/repository/enums/index.js.map +1 -0
- package/src/domain/generic/repository/enums/update-option-actions.enum.js +9 -0
- package/src/domain/generic/repository/enums/update-option-actions.enum.js.map +1 -0
- package/src/domain/generic/repository/enums/where.enum.js +16 -0
- package/src/domain/generic/repository/enums/where.enum.js.map +1 -0
- package/src/domain/generic/repository/find.repository.d.ts +1 -1
- package/src/domain/generic/repository/find.repository.js +2 -0
- package/src/domain/generic/repository/find.repository.js.map +1 -0
- package/src/domain/generic/repository/get.repository.d.ts +1 -1
- package/src/domain/generic/repository/get.repository.js +2 -0
- package/src/domain/generic/repository/get.repository.js.map +1 -0
- package/src/domain/generic/repository/index.js +10 -0
- package/src/domain/generic/repository/index.js.map +1 -0
- package/src/domain/generic/repository/read.repository.d.ts +2 -2
- package/src/domain/generic/repository/read.repository.js +2 -0
- package/src/domain/generic/repository/read.repository.js.map +1 -0
- package/src/domain/generic/repository/types/index.js +7 -0
- package/src/domain/generic/repository/types/index.js.map +1 -0
- package/src/domain/generic/repository/types/repository-find-filters.type.d.ts +4 -4
- package/src/domain/generic/repository/types/repository-find-filters.type.js +2 -0
- package/src/domain/generic/repository/types/repository-find-filters.type.js.map +1 -0
- package/src/domain/generic/repository/types/repository-find-result.type.d.ts +2 -2
- package/src/domain/generic/repository/types/repository-find-result.type.js +2 -0
- package/src/domain/generic/repository/types/repository-find-result.type.js.map +1 -0
- package/src/domain/generic/repository/types/repository-limit-options.type.d.ts +1 -1
- package/src/domain/generic/repository/types/repository-limit-options.type.js +2 -0
- package/src/domain/generic/repository/types/repository-limit-options.type.js.map +1 -0
- package/src/domain/generic/repository/types/repository-order-by-list.type.d.ts +2 -2
- package/src/domain/generic/repository/types/repository-order-by-list.type.js +2 -0
- package/src/domain/generic/repository/types/repository-order-by-list.type.js.map +1 -0
- package/src/domain/generic/repository/types/repository-update-params.type.d.ts +3 -3
- package/src/domain/generic/repository/types/repository-update-params.type.js +2 -0
- package/src/domain/generic/repository/types/repository-update-params.type.js.map +1 -0
- package/src/domain/generic/repository/types/where-options.type.d.ts +1 -1
- package/src/domain/generic/repository/types/where-options.type.js +2 -0
- package/src/domain/generic/repository/types/where-options.type.js.map +1 -0
- package/src/domain/generic/repository/update.repository.d.ts +1 -1
- package/src/domain/generic/repository/update.repository.js +2 -0
- package/src/domain/generic/repository/update.repository.js.map +1 -0
- package/src/domain/index.js +7 -0
- package/src/domain/index.js.map +1 -0
- package/src/domain/location/index.js +2 -0
- package/src/domain/location/index.js.map +1 -0
- package/src/domain/location/models/address.js +7 -0
- package/src/domain/location/models/address.js.map +1 -0
- package/src/domain/location/models/index.js +3 -0
- package/src/domain/location/models/index.js.map +1 -0
- package/src/domain/location/models/types/index.js +4 -0
- package/src/domain/location/models/types/index.js.map +1 -0
- package/src/domain/location/models/types/location-bound.type.d.ts +1 -1
- package/src/domain/location/models/types/location-bound.type.js +2 -0
- package/src/domain/location/models/types/location-bound.type.js.map +1 -0
- package/src/domain/location/models/types/location-geometry.type.d.ts +1 -1
- package/src/domain/location/models/types/location-geometry.type.js +2 -0
- package/src/domain/location/models/types/location-geometry.type.js.map +1 -0
- package/src/domain/location/models/types/location-lat-lng.type.d.ts +1 -1
- package/src/domain/location/models/types/location-lat-lng.type.js +2 -0
- package/src/domain/location/models/types/location-lat-lng.type.js.map +1 -0
- package/src/domain/shop-settings/enums/filter-type.enum.js +21 -0
- package/src/domain/shop-settings/enums/filter-type.enum.js.map +1 -0
- package/src/domain/shop-settings/enums/index.js +3 -0
- package/src/domain/shop-settings/enums/index.js.map +1 -0
- package/src/domain/shop-settings/enums/questions-filters.enum.js +21 -0
- package/src/domain/shop-settings/enums/questions-filters.enum.js.map +1 -0
- package/src/domain/shop-settings/helpers/beauty-questions.helper.d.ts +1 -1
- package/src/domain/shop-settings/helpers/beauty-questions.helper.js +47 -0
- package/src/domain/shop-settings/helpers/beauty-questions.helper.js.map +1 -0
- package/src/domain/shop-settings/helpers/index.js +2 -0
- package/src/domain/shop-settings/helpers/index.js.map +1 -0
- package/src/domain/shop-settings/index.js +5 -0
- package/src/domain/shop-settings/index.js.map +1 -0
- package/src/domain/shop-settings/models/home.js +7 -0
- package/src/domain/shop-settings/models/home.js.map +1 -0
- package/src/domain/shop-settings/models/index.js +5 -0
- package/src/domain/shop-settings/models/index.js.map +1 -0
- package/src/domain/shop-settings/models/shop-menu.js +7 -0
- package/src/domain/shop-settings/models/shop-menu.js.map +1 -0
- package/src/domain/shop-settings/models/shop-settings.js +7 -0
- package/src/domain/shop-settings/models/shop-settings.js.map +1 -0
- package/src/domain/shop-settings/models/types/banner.type.d.ts +1 -1
- package/src/domain/shop-settings/models/types/banner.type.js +2 -0
- package/src/domain/shop-settings/models/types/banner.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/benefit.type.d.ts +1 -1
- package/src/domain/shop-settings/models/types/benefit.type.js +2 -0
- package/src/domain/shop-settings/models/types/benefit.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/home-data.type.d.ts +3 -3
- package/src/domain/shop-settings/models/types/home-data.type.js +2 -0
- package/src/domain/shop-settings/models/types/home-data.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/index.js +11 -0
- package/src/domain/shop-settings/models/types/index.js.map +1 -0
- package/src/domain/shop-settings/models/types/menu-nav.type.d.ts +1 -1
- package/src/domain/shop-settings/models/types/menu-nav.type.js +2 -0
- package/src/domain/shop-settings/models/types/menu-nav.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/shop-banner.type.js +2 -0
- package/src/domain/shop-settings/models/types/shop-banner.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/shop-brands.type.js +2 -0
- package/src/domain/shop-settings/models/types/shop-brands.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/shop-carousel.type.js +2 -0
- package/src/domain/shop-settings/models/types/shop-carousel.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/shop-collection.type.js +2 -0
- package/src/domain/shop-settings/models/types/shop-collection.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/shop-section.type.d.ts +1 -1
- package/src/domain/shop-settings/models/types/shop-section.type.js +2 -0
- package/src/domain/shop-settings/models/types/shop-section.type.js.map +1 -0
- package/src/domain/shop-settings/models/types/sub-menu.type.d.ts +2 -2
- package/src/domain/shop-settings/models/types/sub-menu.type.js +2 -0
- package/src/domain/shop-settings/models/types/sub-menu.type.js.map +1 -0
- package/src/domain/shop-settings/repositories/home.repository.js +2 -0
- package/src/domain/shop-settings/repositories/home.repository.js.map +1 -0
- package/src/domain/shop-settings/repositories/index.js +4 -0
- package/src/domain/shop-settings/repositories/index.js.map +1 -0
- package/src/domain/shop-settings/repositories/shop-menu.repository.js +2 -0
- package/src/domain/shop-settings/repositories/shop-menu.repository.js.map +1 -0
- package/src/domain/shop-settings/repositories/shop-settings.repository.js +2 -0
- package/src/domain/shop-settings/repositories/shop-settings.repository.js.map +1 -0
- package/src/domain/shopping/index.js +3 -0
- package/src/domain/shopping/index.js.map +1 -0
- package/src/domain/shopping/models/buy-2-win.js +14 -0
- package/src/domain/shopping/models/buy-2-win.js.map +1 -0
- package/src/domain/shopping/models/campaign-dashboard.js +7 -0
- package/src/domain/shopping/models/campaign-dashboard.js.map +1 -0
- package/src/domain/shopping/models/campaign-hashtag.js +7 -0
- package/src/domain/shopping/models/campaign-hashtag.js.map +1 -0
- package/src/domain/shopping/models/checkout.js +37 -0
- package/src/domain/shopping/models/checkout.js.map +1 -0
- package/src/domain/shopping/models/coupons/coupon.js +38 -0
- package/src/domain/shopping/models/coupons/coupon.js.map +1 -0
- package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js +7 -0
- package/src/domain/shopping/models/coupons/enums/coupon-club-mens.enum.js.map +1 -0
- package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js +6 -0
- package/src/domain/shopping/models/coupons/enums/coupon-subtypes.enum.js.map +1 -0
- package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js +10 -0
- package/src/domain/shopping/models/coupons/enums/coupon-types.enum.js.map +1 -0
- package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js +10 -0
- package/src/domain/shopping/models/coupons/enums/exclusivities.enum.js.map +1 -0
- package/src/domain/shopping/models/coupons/enums/index.js +4 -0
- package/src/domain/shopping/models/coupons/enums/index.js.map +1 -0
- package/src/domain/shopping/models/coupons/index.js +3 -0
- package/src/domain/shopping/models/coupons/index.js.map +1 -0
- package/src/domain/shopping/models/enums/checkout-types.enum.js +7 -0
- package/src/domain/shopping/models/enums/checkout-types.enum.js.map +1 -0
- package/src/domain/shopping/models/enums/index.js +3 -0
- package/src/domain/shopping/models/enums/index.js.map +1 -0
- package/src/domain/shopping/models/enums/order-status.enum.js +12 -0
- package/src/domain/shopping/models/enums/order-status.enum.js.map +1 -0
- package/src/domain/shopping/models/index.js +13 -0
- package/src/domain/shopping/models/index.js.map +1 -0
- package/src/domain/shopping/models/line-item.js +4 -0
- package/src/domain/shopping/models/line-item.js.map +1 -0
- package/src/domain/shopping/models/order.js +11 -0
- package/src/domain/shopping/models/order.js.map +1 -0
- package/src/domain/shopping/models/payment.js +169 -0
- package/src/domain/shopping/models/payment.js.map +1 -0
- package/src/domain/shopping/models/shipping-method.js +7 -0
- package/src/domain/shopping/models/shipping-method.js.map +1 -0
- package/src/domain/shopping/models/subscription/checkout.js +28 -0
- package/src/domain/shopping/models/subscription/checkout.js.map +1 -0
- package/src/domain/shopping/models/subscription/index.js +3 -0
- package/src/domain/shopping/models/subscription/index.js.map +1 -0
- package/src/domain/shopping/models/subscription/plan.js +7 -0
- package/src/domain/shopping/models/subscription/plan.js.map +1 -0
- package/src/domain/shopping/models/types/index.js +8 -0
- package/src/domain/shopping/models/types/index.js.map +1 -0
- package/src/domain/shopping/models/types/payment-address.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-address.type.js +2 -0
- package/src/domain/shopping/models/types/payment-address.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-billing.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-billing.type.js +2 -0
- package/src/domain/shopping/models/types/payment-billing.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-card.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-card.type.js +2 -0
- package/src/domain/shopping/models/types/payment-card.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-customer.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-customer.type.js +2 -0
- package/src/domain/shopping/models/types/payment-customer.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-document.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-document.type.js +2 -0
- package/src/domain/shopping/models/types/payment-document.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-item.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-item.type.js +2 -0
- package/src/domain/shopping/models/types/payment-item.type.js.map +1 -0
- package/src/domain/shopping/models/types/payment-shipping.type.d.ts +1 -1
- package/src/domain/shopping/models/types/payment-shipping.type.js +2 -0
- package/src/domain/shopping/models/types/payment-shipping.type.js.map +1 -0
- package/src/domain/shopping/repositories/buy-2-win.repository.js +2 -0
- package/src/domain/shopping/repositories/buy-2-win.repository.js.map +1 -0
- package/src/domain/shopping/repositories/campaign-dashboard.repository.js +2 -0
- package/src/domain/shopping/repositories/campaign-dashboard.repository.js.map +1 -0
- package/src/domain/shopping/repositories/campaign-hashtag.repository.js +2 -0
- package/src/domain/shopping/repositories/campaign-hashtag.repository.js.map +1 -0
- package/src/domain/shopping/repositories/checkout.repository.js +2 -0
- package/src/domain/shopping/repositories/checkout.repository.js.map +1 -0
- package/src/domain/shopping/repositories/coupon.repository.js +2 -0
- package/src/domain/shopping/repositories/coupon.repository.js.map +1 -0
- package/src/domain/shopping/repositories/index.js +10 -0
- package/src/domain/shopping/repositories/index.js.map +1 -0
- package/src/domain/shopping/repositories/legacy-order.repository.js +2 -0
- package/src/domain/shopping/repositories/legacy-order.repository.js.map +1 -0
- package/src/domain/shopping/repositories/order.repository.js +2 -0
- package/src/domain/shopping/repositories/order.repository.js.map +1 -0
- package/src/domain/shopping/repositories/payment.repository.js +2 -0
- package/src/domain/shopping/repositories/payment.repository.js.map +1 -0
- package/src/domain/shopping/repositories/subscription/checkout.repository.js +2 -0
- package/src/domain/shopping/repositories/subscription/checkout.repository.js.map +1 -0
- package/src/domain/shopping/repositories/subscription/index.js +3 -0
- package/src/domain/shopping/repositories/subscription/index.js.map +1 -0
- package/src/domain/shopping/repositories/subscription/plan.repository.js +2 -0
- package/src/domain/shopping/repositories/subscription/plan.repository.js.map +1 -0
- package/src/domain/users/errors/index.js +4 -0
- package/src/domain/users/errors/index.js.map +1 -0
- package/src/domain/users/errors/unauthorized.error.js +7 -0
- package/src/domain/users/errors/unauthorized.error.js.map +1 -0
- package/src/domain/users/errors/user-already-registered.error.js +7 -0
- package/src/domain/users/errors/user-already-registered.error.js.map +1 -0
- package/src/domain/users/errors/weak-password.error.js +7 -0
- package/src/domain/users/errors/weak-password.error.js.map +1 -0
- package/src/domain/users/index.js +6 -0
- package/src/domain/users/index.js.map +1 -0
- package/src/domain/users/models/beauty-profile.d.ts +1 -1
- package/src/domain/users/models/beauty-profile.js +12 -0
- package/src/domain/users/models/beauty-profile.js.map +1 -0
- package/src/domain/users/models/enums/accessory-importances.enum.js +7 -0
- package/src/domain/users/models/enums/accessory-importances.enum.js.map +1 -0
- package/src/domain/users/models/enums/area.enum.js +13 -0
- package/src/domain/users/models/enums/area.enum.js.map +1 -0
- package/src/domain/users/models/enums/beard-problems.enum.js +11 -0
- package/src/domain/users/models/enums/beard-problems.enum.js.map +1 -0
- package/src/domain/users/models/enums/beard-sizes.enum.js +9 -0
- package/src/domain/users/models/enums/beard-sizes.enum.js.map +1 -0
- package/src/domain/users/models/enums/beauty-product-importances.enum.js +8 -0
- package/src/domain/users/models/enums/beauty-product-importances.enum.js.map +1 -0
- package/src/domain/users/models/enums/body-problems.enum.js +13 -0
- package/src/domain/users/models/enums/body-problems.enum.js.map +1 -0
- package/src/domain/users/models/enums/body-shapes.enum.js +9 -0
- package/src/domain/users/models/enums/body-shapes.enum.js.map +1 -0
- package/src/domain/users/models/enums/body-tattoos.enum.js +7 -0
- package/src/domain/users/models/enums/body-tattoos.enum.js.map +1 -0
- package/src/domain/users/models/enums/face-skin-oilinesses.enum.js +9 -0
- package/src/domain/users/models/enums/face-skin-oilinesses.enum.js.map +1 -0
- package/src/domain/users/models/enums/face-skin-problems.enum.js +12 -0
- package/src/domain/users/models/enums/face-skin-problems.enum.js.map +1 -0
- package/src/domain/users/models/enums/face-skin-tones.enum.js +10 -0
- package/src/domain/users/models/enums/face-skin-tones.enum.js.map +1 -0
- package/src/domain/users/models/enums/family-incomes.enum.js +10 -0
- package/src/domain/users/models/enums/family-incomes.enum.js.map +1 -0
- package/src/domain/users/models/enums/fragrance-importances.enum.js +7 -0
- package/src/domain/users/models/enums/fragrance-importances.enum.js.map +1 -0
- package/src/domain/users/models/enums/hair-colors.enum.js +12 -0
- package/src/domain/users/models/enums/hair-colors.enum.js.map +1 -0
- package/src/domain/users/models/enums/hair-problems.enum.js +12 -0
- package/src/domain/users/models/enums/hair-problems.enum.js.map +1 -0
- package/src/domain/users/models/enums/hair-strands.enum.js +10 -0
- package/src/domain/users/models/enums/hair-strands.enum.js.map +1 -0
- package/src/domain/users/models/enums/hair-types.enum.js +9 -0
- package/src/domain/users/models/enums/hair-types.enum.js.map +1 -0
- package/src/domain/users/models/enums/index.js +21 -0
- package/src/domain/users/models/enums/index.js.map +1 -0
- package/src/domain/users/models/enums/office-position.enum.js +8 -0
- package/src/domain/users/models/enums/office-position.enum.js.map +1 -0
- package/src/domain/users/models/enums/product-spents.enum.js +10 -0
- package/src/domain/users/models/enums/product-spents.enum.js.map +1 -0
- package/src/domain/users/models/enums/user-type.enum.js +10 -0
- package/src/domain/users/models/enums/user-type.enum.js.map +1 -0
- package/src/domain/users/models/index.js +8 -0
- package/src/domain/users/models/index.js.map +1 -0
- package/src/domain/users/models/lead.js +7 -0
- package/src/domain/users/models/lead.js.map +1 -0
- package/src/domain/users/models/subscription/edition.d.ts +1 -1
- package/src/domain/users/models/subscription/edition.js +7 -0
- package/src/domain/users/models/subscription/edition.js.map +1 -0
- package/src/domain/users/models/subscription/enums/billing-status.enum.js +5 -0
- package/src/domain/users/models/subscription/enums/billing-status.enum.js.map +1 -0
- package/src/domain/users/models/subscription/enums/edition-status.enum.js +6 -0
- package/src/domain/users/models/subscription/enums/edition-status.enum.js.map +1 -0
- package/src/domain/users/models/subscription/enums/index.js +5 -0
- package/src/domain/users/models/subscription/enums/index.js.map +1 -0
- package/src/domain/users/models/subscription/enums/payment-type.enum.js +7 -0
- package/src/domain/users/models/subscription/enums/payment-type.enum.js.map +1 -0
- package/src/domain/users/models/subscription/enums/status.enum.js +6 -0
- package/src/domain/users/models/subscription/enums/status.enum.js.map +1 -0
- package/src/domain/users/models/subscription/index.js +5 -0
- package/src/domain/users/models/subscription/index.js.map +1 -0
- package/src/domain/users/models/subscription/payment.d.ts +1 -1
- package/src/domain/users/models/subscription/payment.js +14 -0
- package/src/domain/users/models/subscription/payment.js.map +1 -0
- package/src/domain/users/models/subscription/subscription.js +43 -0
- package/src/domain/users/models/subscription/subscription.js.map +1 -0
- package/src/domain/users/models/user-address.d.ts +1 -1
- package/src/domain/users/models/user-address.js +7 -0
- package/src/domain/users/models/user-address.js.map +1 -0
- package/src/domain/users/models/user-payment-method.d.ts +1 -1
- package/src/domain/users/models/user-payment-method.js +7 -0
- package/src/domain/users/models/user-payment-method.js.map +1 -0
- package/src/domain/users/models/user.js +26 -0
- package/src/domain/users/models/user.js.map +1 -0
- package/src/domain/users/repositories/beauty-profile.repository.js +2 -0
- package/src/domain/users/repositories/beauty-profile.repository.js.map +1 -0
- package/src/domain/users/repositories/edition.repository.js +2 -0
- package/src/domain/users/repositories/edition.repository.js.map +1 -0
- package/src/domain/users/repositories/index.js +9 -0
- package/src/domain/users/repositories/index.js.map +1 -0
- package/src/domain/users/repositories/lead.repository.js +2 -0
- package/src/domain/users/repositories/lead.repository.js.map +1 -0
- package/src/domain/users/repositories/subscription-payment.repository.js +2 -0
- package/src/domain/users/repositories/subscription-payment.repository.js.map +1 -0
- package/src/domain/users/repositories/subscription.repository.js +2 -0
- package/src/domain/users/repositories/subscription.repository.js.map +1 -0
- package/src/domain/users/repositories/user-address.repository.js +2 -0
- package/src/domain/users/repositories/user-address.repository.js.map +1 -0
- package/src/domain/users/repositories/user-payment-method.repository.js +2 -0
- package/src/domain/users/repositories/user-payment-method.repository.js.map +1 -0
- package/src/domain/users/repositories/user.repository.js +2 -0
- package/src/domain/users/repositories/user.repository.js.map +1 -0
- package/src/domain/users/services/authentication.service.d.ts +1 -1
- package/src/domain/users/services/authentication.service.js +2 -0
- package/src/domain/users/services/authentication.service.js.map +1 -0
- package/src/domain/users/services/index.js +4 -0
- package/src/domain/users/services/index.js.map +1 -0
- package/src/domain/users/services/register.service.d.ts +1 -1
- package/src/domain/users/services/register.service.js +2 -0
- package/src/domain/users/services/register.service.js.map +1 -0
- package/src/domain/users/services/types/basic-user-data.type.d.ts +1 -1
- package/src/domain/users/services/types/basic-user-data.type.js +2 -0
- package/src/domain/users/services/types/basic-user-data.type.js.map +1 -0
- package/src/domain/users/services/types/index.js +2 -0
- package/src/domain/users/services/types/index.js.map +1 -0
- package/src/domain/users/use-cases/authentication.d.ts +2 -2
- package/src/domain/users/use-cases/authentication.js +35 -0
- package/src/domain/users/use-cases/authentication.js.map +1 -0
- package/src/domain/users/use-cases/index.js +5 -0
- package/src/domain/users/use-cases/index.js.map +1 -0
- package/src/domain/users/use-cases/recovery-password.js +9 -0
- package/src/domain/users/use-cases/recovery-password.js.map +1 -0
- package/src/domain/users/use-cases/register.d.ts +1 -1
- package/src/domain/users/use-cases/register.js +31 -0
- package/src/domain/users/use-cases/register.js.map +1 -0
- package/src/domain/users/use-cases/signout.js +9 -0
- package/src/domain/users/use-cases/signout.js.map +1 -0
- package/src/errors/duplicated-results.error.js +7 -0
- package/src/errors/duplicated-results.error.js.map +1 -0
- package/src/errors/index.js +5 -0
- package/src/errors/index.js.map +1 -0
- package/src/errors/invalid-argument.error.js +7 -0
- package/src/errors/invalid-argument.error.js.map +1 -0
- package/src/errors/not-found.error.js +7 -0
- package/src/errors/not-found.error.js.map +1 -0
- package/src/errors/required-argument.error.js +9 -0
- package/src/errors/required-argument.error.js.map +1 -0
- package/src/index.js +6 -0
- package/src/index.js.map +1 -0
- package/src/infra/elasticsearch/adapters/axios.adapter.d.ts +1 -1
- package/src/infra/elasticsearch/adapters/axios.adapter.js +67 -0
- package/src/infra/elasticsearch/adapters/axios.adapter.js.map +1 -0
- package/src/infra/elasticsearch/adapters/elastic-search.adapter.js +2 -0
- package/src/infra/elasticsearch/adapters/elastic-search.adapter.js.map +1 -0
- package/src/infra/elasticsearch/adapters/index.js +3 -0
- package/src/infra/elasticsearch/adapters/index.js.map +1 -0
- package/src/infra/elasticsearch/index.js +4 -0
- package/src/infra/elasticsearch/index.js.map +1 -0
- package/src/infra/elasticsearch/indexes/index.js +2 -0
- package/src/infra/elasticsearch/indexes/index.js.map +1 -0
- package/src/infra/elasticsearch/indexes/products-index.js +105 -0
- package/src/infra/elasticsearch/indexes/products-index.js.map +1 -0
- package/src/infra/elasticsearch/types/elastic-search-result.d.ts +1 -1
- package/src/infra/elasticsearch/types/elastic-search-result.js +2 -0
- package/src/infra/elasticsearch/types/elastic-search-result.js.map +1 -0
- package/src/infra/elasticsearch/types/index.js +2 -0
- package/src/infra/elasticsearch/types/index.js.map +1 -0
- package/src/infra/firebase/auth/authentication-firebase-auth.service.js +41 -0
- package/src/infra/firebase/auth/authentication-firebase-auth.service.js.map +1 -0
- package/src/infra/firebase/auth/index.js +3 -0
- package/src/infra/firebase/auth/index.js.map +1 -0
- package/src/infra/firebase/auth/register-firebase-auth.service.js +33 -0
- package/src/infra/firebase/auth/register-firebase-auth.service.js.map +1 -0
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.d.ts +1 -1
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.js +2 -0
- package/src/infra/firebase/auth/types/firebase-user-with-id.type.js.map +1 -0
- package/src/infra/firebase/auth/types/index.js +2 -0
- package/src/infra/firebase/auth/types/index.js.map +1 -0
- package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js +10 -0
- package/src/infra/firebase/firestore/enums/firestore-field-type.enum.js.map +1 -0
- package/src/infra/firebase/firestore/enums/index.js +2 -0
- package/src/infra/firebase/firestore/enums/index.js.map +1 -0
- package/src/infra/firebase/firestore/index.js +4 -0
- package/src/infra/firebase/firestore/index.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/index.js +10 -0
- package/src/infra/firebase/firestore/mixins/index.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js +33 -0
- package/src/infra/firebase/firestore/mixins/with-create-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js +10 -0
- package/src/infra/firebase/firestore/mixins/with-crud-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js +19 -0
- package/src/infra/firebase/firestore/mixins/with-delete-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js +109 -0
- package/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.d.ts +1 -1
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js +77 -0
- package/src/infra/firebase/firestore/mixins/with-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js +24 -0
- package/src/infra/firebase/firestore/mixins/with-get-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js +17 -0
- package/src/infra/firebase/firestore/mixins/with-helpers.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.d.ts +1 -1
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js +13 -0
- package/src/infra/firebase/firestore/mixins/with-sub-collection.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.d.ts +1 -1
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js +52 -0
- package/src/infra/firebase/firestore/mixins/with-update-firestore.mixin.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js +67 -0
- package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/catalog/index.js +5 -0
- package/src/infra/firebase/firestore/repositories/catalog/index.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js +56 -0
- package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/index.js +5 -0
- package/src/infra/firebase/firestore/repositories/index.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js +66 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/index.js +4 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/index.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js +31 -0
- package/src/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/index.js +11 -0
- package/src/infra/firebase/firestore/repositories/shopping/index.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js +11 -0
- package/src/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js +41 -0
- package/src/infra/firebase/firestore/repositories/shopping/order-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/index.js +9 -0
- package/src/infra/firebase/firestore/repositories/users/index.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/users/lead-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js +14 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/users/user-address-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js +50 -0
- package/src/infra/firebase/firestore/repositories/users/user-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js +16 -0
- package/src/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.js.map +1 -0
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.d.ts +1 -1
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.js +2 -0
- package/src/infra/firebase/firestore/types/firestore-interceptors.type.js.map +1 -0
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.d.ts +1 -1
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js +2 -0
- package/src/infra/firebase/firestore/types/firestore-sub.repository.type.js.map +1 -0
- package/src/infra/firebase/firestore/types/firestore.helpers.type.js +2 -0
- package/src/infra/firebase/firestore/types/firestore.helpers.type.js.map +1 -0
- package/src/infra/firebase/firestore/types/firestore.repository.type.d.ts +1 -1
- package/src/infra/firebase/firestore/types/firestore.repository.type.js +2 -0
- package/src/infra/firebase/firestore/types/firestore.repository.type.js.map +1 -0
- package/src/infra/firebase/firestore/types/index.js +5 -0
- package/src/infra/firebase/firestore/types/index.js.map +1 -0
- package/src/infra/firebase/index.js +3 -0
- package/src/infra/firebase/index.js.map +1 -0
- package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js +13 -0
- package/src/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.js.map +1 -0
- package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js +17 -0
- package/src/infra/hasura-graphql/enums/hasura-graphql-where.enum.js.map +1 -0
- package/src/infra/hasura-graphql/enums/index.js +3 -0
- package/src/infra/hasura-graphql/enums/index.js.map +1 -0
- package/src/infra/hasura-graphql/index.js +5 -0
- package/src/infra/hasura-graphql/index.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.d.ts +1 -1
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js +32 -0
- package/src/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js +56 -0
- package/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js +22 -0
- package/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.d.ts +1 -1
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js +104 -0
- package/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/helpers/index.js +5 -0
- package/src/infra/hasura-graphql/mixins/helpers/index.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/index.js +8 -0
- package/src/infra/hasura-graphql/mixins/index.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.d.ts +1 -1
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js +41 -0
- package/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js +10 -0
- package/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.d.ts +1 -1
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js +28 -0
- package/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +143 -0
- package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +1 -1
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js +35 -0
- package/src/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.d.ts +3 -3
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js +105 -0
- package/src/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.d.ts +2 -2
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js +57 -0
- package/src/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.js.map +1 -0
- package/src/infra/hasura-graphql/models/category-hasura-graphql.js +4 -0
- package/src/infra/hasura-graphql/models/category-hasura-graphql.js.map +1 -0
- package/src/infra/hasura-graphql/models/index.js +5 -0
- package/src/infra/hasura-graphql/models/index.js.map +1 -0
- package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js +15 -0
- package/src/infra/hasura-graphql/models/kit-product-hasura-graphql.js.map +1 -0
- package/src/infra/hasura-graphql/models/product-hasura-graphql.js +11 -0
- package/src/infra/hasura-graphql/models/product-hasura-graphql.js.map +1 -0
- package/src/infra/hasura-graphql/models/variant-hasura-graphql.js +9 -0
- package/src/infra/hasura-graphql/models/variant-hasura-graphql.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js +39 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +107 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +330 -0
- package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js +106 -0
- package/src/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js +22 -0
- package/src/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/index.js +9 -0
- package/src/infra/hasura-graphql/repositories/catalog/index.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +461 -0
- package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js +107 -0
- package/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js +228 -0
- package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js.map +1 -0
- package/src/infra/hasura-graphql/repositories/index.js +2 -0
- package/src/infra/hasura-graphql/repositories/index.js.map +1 -0
- package/src/infra/hasura-graphql/types/fields.type.d.ts +1 -1
- package/src/infra/hasura-graphql/types/fields.type.js +2 -0
- package/src/infra/hasura-graphql/types/fields.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/graphql.repository.type.d.ts +2 -2
- package/src/infra/hasura-graphql/types/graphql.repository.type.js +2 -0
- package/src/infra/hasura-graphql/types/graphql.repository.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.d.ts +1 -1
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js +2 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-auth-options.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.d.ts +6 -6
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js +2 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-fields.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.d.ts +1 -1
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js +2 -0
- package/src/infra/hasura-graphql/types/hasura-graphql-headers.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/index.js +9 -0
- package/src/infra/hasura-graphql/types/index.js.map +1 -0
- package/src/infra/hasura-graphql/types/nested-field.type.d.ts +1 -1
- package/src/infra/hasura-graphql/types/nested-field.type.js +2 -0
- package/src/infra/hasura-graphql/types/nested-field.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/query-builder-options.type.js +2 -0
- package/src/infra/hasura-graphql/types/query-builder-options.type.js.map +1 -0
- package/src/infra/hasura-graphql/types/variable-options.type.d.ts +1 -1
- package/src/infra/hasura-graphql/types/variable-options.type.js +2 -0
- package/src/infra/hasura-graphql/types/variable-options.type.js.map +1 -0
- package/src/infra/index.js +4 -0
- package/src/infra/index.js.map +1 -0
- package/src/utils/decorators/debug.class.decorator.js +7 -0
- package/src/utils/decorators/debug.class.decorator.js.map +1 -0
- package/src/utils/decorators/index.js +3 -0
- package/src/utils/decorators/index.js.map +1 -0
- package/src/utils/decorators/trace.method.decorator.d.ts +3 -3
- package/src/utils/decorators/trace.method.decorator.js +81 -0
- package/src/utils/decorators/trace.method.decorator.js.map +1 -0
- package/src/utils/get.js +3 -0
- package/src/utils/get.js.map +1 -0
- package/src/utils/helpers/class-name.helper.js +15 -0
- package/src/utils/helpers/class-name.helper.js.map +1 -0
- package/src/utils/helpers/debug-decorator.helper.d.ts +1 -1
- package/src/utils/helpers/debug-decorator.helper.js +18 -0
- package/src/utils/helpers/debug-decorator.helper.js.map +1 -0
- package/src/utils/helpers/debug.helper.d.ts +3 -3
- package/src/utils/helpers/debug.helper.js +150 -0
- package/src/utils/helpers/debug.helper.js.map +1 -0
- package/src/utils/helpers/index.js +5 -0
- package/src/utils/helpers/index.js.map +1 -0
- package/src/utils/helpers/reflect.helper.d.ts +7 -7
- package/src/utils/helpers/reflect.helper.js +165 -0
- package/src/utils/helpers/reflect.helper.js.map +1 -0
- package/src/utils/index.d.ts +1 -1
- package/src/utils/index.js +13 -0
- package/src/utils/index.js.map +1 -0
- package/src/utils/is-uuid.js +3 -0
- package/src/utils/is-uuid.js.map +1 -0
- package/src/utils/is.js +4 -0
- package/src/utils/is.js.map +1 -0
- package/src/utils/log.utils.js +9 -0
- package/src/utils/log.utils.js.map +1 -0
- package/src/utils/mixins/base.mixin.js +6 -0
- package/src/utils/mixins/base.mixin.js.map +1 -0
- package/src/utils/mixins/index.js +4 -0
- package/src/utils/mixins/index.js.map +1 -0
- package/src/utils/mixins/merge-constructor-params.type.d.ts +2 -2
- package/src/utils/mixins/merge-constructor-params.type.js +2 -0
- package/src/utils/mixins/merge-constructor-params.type.js.map +1 -0
- package/src/utils/mixins/mixin-ctor.type.d.ts +1 -1
- package/src/utils/mixins/mixin-ctor.type.js +2 -0
- package/src/utils/mixins/mixin-ctor.type.js.map +1 -0
- package/src/utils/parse-datetime.js +14 -0
- package/src/utils/parse-datetime.js.map +1 -0
- package/src/utils/types/array-element.type.d.ts +1 -1
- package/src/utils/types/array-element.type.js +2 -0
- package/src/utils/types/array-element.type.js.map +1 -0
- package/src/utils/types/index.js +3 -0
- package/src/utils/types/index.js.map +1 -0
- package/src/utils/types/prop.type.d.ts +1 -1
- package/src/utils/types/prop.type.js +2 -0
- package/src/utils/types/prop.type.js.map +1 -0
- package/index.cjs.d.ts +0 -1
- package/index.cjs.default.js +0 -1
- package/index.cjs.js +0 -5730
- package/index.cjs.mjs +0 -2
- package/index.esm.js +0 -5479
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { Where, } from '../../../../domain';
|
|
2
|
+
import { is, isNil, isObject } from '../../../../utils';
|
|
3
|
+
import { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums';
|
|
4
|
+
import { AttributeOptionHelper } from './attribute-option.helper';
|
|
5
|
+
import { FilterOptionHelper } from './filter-option.helper';
|
|
6
|
+
export class BindFilterQueryHelper {
|
|
7
|
+
}
|
|
8
|
+
BindFilterQueryHelper.MakeGraphQLWhere = (filter, fields) => Object.keys(filter).reduce((variables, fieldName) => {
|
|
9
|
+
const columnOption = AttributeOptionHelper.FindByAttribute(fieldName, fields);
|
|
10
|
+
if (!columnOption.bindFindFilter)
|
|
11
|
+
return Object.assign(Object.assign({}, variables), {
|
|
12
|
+
[columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, filter[fieldName], fields),
|
|
13
|
+
});
|
|
14
|
+
const builtFilter = columnOption.bindFindFilter(filter[fieldName]);
|
|
15
|
+
return Object.assign(Object.assign({}, variables), Object.keys(builtFilter).reduce((variablesList, columnName) => (Object.assign(Object.assign({}, variablesList), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, builtFilter[columnName], fields) })), {}));
|
|
16
|
+
}, {});
|
|
17
|
+
BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
|
|
18
|
+
const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute(field, fields);
|
|
19
|
+
const isNestedField = !Array.isArray(options) &&
|
|
20
|
+
isObject(options) &&
|
|
21
|
+
isNil(options === null || options === void 0 ? void 0 : options.operator) &&
|
|
22
|
+
isNil(options === null || options === void 0 ? void 0 : options.value) &&
|
|
23
|
+
isNil(fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.to);
|
|
24
|
+
if (isNestedField)
|
|
25
|
+
return Object.keys(options).reduce((variables, key) => {
|
|
26
|
+
const fieldOptions = AttributeOptionHelper.FindByAttribute(key, (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || fields);
|
|
27
|
+
const columnName = fieldOptions.columnName;
|
|
28
|
+
const columnFields = fieldOptions.fields;
|
|
29
|
+
return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || columnFields || fields) });
|
|
30
|
+
}, {});
|
|
31
|
+
if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
|
|
32
|
+
return {
|
|
33
|
+
[fieldSentenceOptions.fields[0]]: BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions),
|
|
34
|
+
};
|
|
35
|
+
if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))
|
|
36
|
+
options = Object.values(options)[0];
|
|
37
|
+
return Array.isArray(options)
|
|
38
|
+
? options.reduce((whereSentence, option) => (Object.assign(Object.assign({}, whereSentence), BindFilterQueryHelper.BuildOperatorSentence(option, fieldSentenceOptions))), {})
|
|
39
|
+
: BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions);
|
|
40
|
+
};
|
|
41
|
+
BindFilterQueryHelper.BuildOperatorSentence = (options, fieldOption) => ({
|
|
42
|
+
[BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(options, fieldOption),
|
|
43
|
+
});
|
|
44
|
+
BindFilterQueryHelper.GetHasuraOperator = (options, fieldOption) => FilterOptionHelper.CheckIfIsFilterOption(options)
|
|
45
|
+
? fieldOption.type === HasuraGraphQLColumnType.Jsonb
|
|
46
|
+
? BindFilterQueryHelper.GetHasuraJsonbOperator(options)
|
|
47
|
+
: HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
|
|
48
|
+
Object.keys(Where).find((operator) => Where[operator] === (options === null || options === void 0 ? void 0 : options.operator)))]
|
|
49
|
+
: HasuraGraphQLWhere.EQUALS;
|
|
50
|
+
BindFilterQueryHelper.GetHasuraJsonbOperator = (options) => options.operator === Where.IN
|
|
51
|
+
? HasuraGraphQLWhere.JSON_CONTAINS
|
|
52
|
+
: options.operator === Where.LIKE
|
|
53
|
+
? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY
|
|
54
|
+
: HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
|
|
55
|
+
Object.keys(Where).find((operator) => Where[operator] === (options === null || options === void 0 ? void 0 : options.operator)))];
|
|
56
|
+
//# sourceMappingURL=bind-filter-query.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bind-filter-query.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n NonFunctionPropertyNames,\r\n RepositoryFindFielters,\r\n RepositoryFindFieltersOptions,\r\n Where,\r\n} from '../../../../domain'\r\nimport { is, isNil, isObject } from '../../../../utils'\r\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\r\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\r\nimport { AttributeOptionHelper } from './attribute-option.helper'\r\nimport { FilterOptionHelper } from './filter-option.helper'\r\n\r\nexport class BindFilterQueryHelper {\r\n static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\r\n filter: RepositoryFindFielters<MBase>,\r\n fields: HasuraGraphQLFields<MBase>,\r\n ): VariableOptions =>\r\n Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\r\n const columnOption = AttributeOptionHelper.FindByAttribute(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n fields,\r\n )\r\n\r\n if (!columnOption.bindFindFilter)\r\n return {\r\n ...variables,\r\n ...{\r\n [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n filter[fieldName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionAndIdentifierPropertyNames<MBase>\r\n >,\r\n fields,\r\n ),\r\n },\r\n }\r\n\r\n const builtFilter: RepositoryFindFielters<MBase> = columnOption.bindFindFilter(\r\n filter[fieldName as NonFunctionPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionPropertyNames<MBase>\r\n >,\r\n )\r\n\r\n return {\r\n ...variables,\r\n ...Object.keys(builtFilter).reduce(\r\n (variablesList: VariableOptions, columnName: string) => ({\r\n ...variablesList,\r\n [columnName]: BindFilterQueryHelper.BuildWhereSentence(\r\n fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n builtFilter[columnName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\r\n MBase,\r\n NonFunctionAndIdentifierPropertyNames<MBase>\r\n >,\r\n fields,\r\n ),\r\n }),\r\n {},\r\n ),\r\n }\r\n }, {})\r\n\r\n static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\r\n field: NonFunctionAndIdentifierPropertyNames<MBase>,\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>,\r\n fields: HasuraGraphQLFields<MBase>,\r\n ): VariableOptions => {\r\n const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\r\n const isNestedField =\r\n !Array.isArray(options) &&\r\n isObject(options) &&\r\n isNil(options?.operator) &&\r\n isNil(options?.value) &&\r\n isNil(fieldSentenceOptions?.to)\r\n\r\n if (isNestedField)\r\n return Object.keys(options).reduce((variables, key) => {\r\n const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\r\n key as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n fieldSentenceOptions?.fields || (fields as any),\r\n )\r\n const columnName = fieldOptions.columnName\r\n const columnFields = fieldOptions.fields\r\n\r\n return {\r\n ...variables,\r\n [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\r\n key as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n is<RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>>(\r\n is<RepositoryFindFielters<MBase>>(options)[key as NonFunctionAndIdentifierPropertyNames<MBase>],\r\n ),\r\n fieldSentenceOptions?.fields || columnFields || (fields as any),\r\n ),\r\n }\r\n }, {})\r\n\r\n if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\r\n return {\r\n [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\r\n BindFilterQueryHelper.BuildOperatorSentence(\r\n options,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n ),\r\n }\r\n\r\n if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\r\n options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\r\n\r\n return Array.isArray(options)\r\n ? options.reduce(\r\n (whereSentence, option) => ({\r\n ...whereSentence,\r\n ...BindFilterQueryHelper.BuildOperatorSentence(\r\n option,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n ),\r\n }),\r\n {},\r\n )\r\n : BindFilterQueryHelper.BuildOperatorSentence(\r\n options,\r\n fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\r\n )\r\n }\r\n\r\n static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, any>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): VariableOptions => ({\r\n [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\r\n options,\r\n fieldOption,\r\n ),\r\n })\r\n\r\n static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): HasuraGraphQLWhere =>\r\n FilterOptionHelper.CheckIfIsFilterOption(options)\r\n ? fieldOption.type === HasuraGraphQLColumnType.Jsonb\r\n ? BindFilterQueryHelper.GetHasuraJsonbOperator(options)\r\n : HasuraGraphQLWhere[\r\n Object.keys(HasuraGraphQLWhere).find(\r\n (graphQLOperator) =>\r\n graphQLOperator ===\r\n Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\r\n ) as keyof typeof HasuraGraphQLWhere\r\n ]\r\n : HasuraGraphQLWhere.EQUALS\r\n\r\n static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\r\n options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\r\n ): HasuraGraphQLWhere =>\r\n options.operator === Where.IN\r\n ? HasuraGraphQLWhere.JSON_CONTAINS\r\n : options.operator === Where.LIKE\r\n ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY\r\n : HasuraGraphQLWhere[\r\n Object.keys(HasuraGraphQLWhere).find(\r\n (graphQLOperator) =>\r\n graphQLOperator ===\r\n Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\r\n ) as keyof typeof HasuraGraphQLWhere\r\n ]\r\n}\r\n"]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Where } from '../../../../domain';
|
|
2
|
+
import { isNil } from '../../../../utils';
|
|
3
|
+
export class FilterOptionHelper {
|
|
4
|
+
}
|
|
5
|
+
FilterOptionHelper.CheckIfIsFilterOption = (filter) => !isNil(filter === null || filter === void 0 ? void 0 : filter.operator);
|
|
6
|
+
FilterOptionHelper.GetValueFromFilter = (filter, fieldOption) => {
|
|
7
|
+
if (!FilterOptionHelper.CheckIfIsFilterOption(filter))
|
|
8
|
+
return filter;
|
|
9
|
+
if (filter.operator === Where.ISNULL)
|
|
10
|
+
return true;
|
|
11
|
+
if (filter.operator === Where.ISNOTNULL)
|
|
12
|
+
return false;
|
|
13
|
+
const converter = fieldOption.to
|
|
14
|
+
? fieldOption.to
|
|
15
|
+
: (value) => filter.operator === Where.LIKE && !Array.isArray(filter.value) && value.indexOf('%') < 0
|
|
16
|
+
? `%${value}%`
|
|
17
|
+
: value;
|
|
18
|
+
return Array.isArray(filter.value) && !fieldOption.fields && [Where.IN, Where.NOTIN].includes(filter.operator)
|
|
19
|
+
? filter.value.map((fieldValue) => converter(fieldValue))
|
|
20
|
+
: converter(filter.value);
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=filter-option.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"filter-option.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/filter-option.helper.ts"],"names":[],"mappings":"AAAA,OAAO,EAAqD,KAAK,EAAE,MAAM,oBAAoB,CAAA;AAC7F,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAGzC,MAAM,OAAO,kBAAkB;;AACtB,wCAAqB,GAAG,CAC7B,MAAW,EAC0C,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,CAAC,CAAA;AAE3E,qCAAkB,GAAG,CAC1B,MAAiD,EACjD,WAAoC,EAC/B,EAAE;IACP,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC,MAAM,CAAC;QAAE,OAAO,MAAM,CAAA;IACpE,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,MAAM;QAAE,OAAO,IAAI,CAAA;IACjD,IAAI,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,SAAS;QAAE,OAAO,KAAK,CAAA;IAErD,MAAM,SAAS,GAAG,WAAW,CAAC,EAAE;QAC9B,CAAC,CAAC,WAAW,CAAC,EAAE;QAChB,CAAC,CAAC,CAAC,KAAU,EAAE,EAAE,CACb,MAAM,CAAC,QAAQ,KAAK,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;YACtF,CAAC,CAAC,IAAI,KAAK,GAAG;YACd,CAAC,CAAC,KAAK,CAAA;IAEf,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC;QAC5G,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QACzD,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,KAAY,CAAC,CAAA;AACpC,CAAC,CAAA","sourcesContent":["import { ModelBaseStructure, RepositoryFindFieltersOptions, Where } from '../../../../domain'\r\nimport { isNil } from '../../../../utils'\r\nimport { ColumnOptions } from '../../types'\r\n\r\nexport class FilterOptionHelper {\r\n static CheckIfIsFilterOption = <Model extends ModelBaseStructure>(\r\n filter: any,\r\n ): filter is RepositoryFindFieltersOptions<Model, any> => !isNil(filter?.operator)\r\n\r\n static GetValueFromFilter = <Model extends ModelBaseStructure<Model>>(\r\n filter: RepositoryFindFieltersOptions<Model, any>,\r\n fieldOption: ColumnOptions<any, any>,\r\n ): any => {\r\n if (!FilterOptionHelper.CheckIfIsFilterOption(filter)) return filter\r\n if (filter.operator === Where.ISNULL) return true\r\n if (filter.operator === Where.ISNOTNULL) return false\r\n\r\n const converter = fieldOption.to\r\n ? fieldOption.to\r\n : (value: any) =>\r\n filter.operator === Where.LIKE && !Array.isArray(filter.value) && value.indexOf('%') < 0\r\n ? `%${value}%`\r\n : value\r\n\r\n return Array.isArray(filter.value) && !fieldOption.fields && [Where.IN, Where.NOTIN].includes(filter.operator)\r\n ? filter.value.map((fieldValue) => converter(fieldValue))\r\n : converter(filter.value as any)\r\n }\r\n}\r\n"]}
|
|
@@ -6,7 +6,7 @@ export declare class GraphQLFieldHelper {
|
|
|
6
6
|
static ConvertModelFieldsToGraphQLFields: <Model extends ModelBaseStructure<Model, Model["identifiersFields"][number]>>(fields: HasuraGraphQLFields<Model>) => Fields;
|
|
7
7
|
static ConvertFieldValueFrom: <Model extends ModelBaseStructure<Record<string, any> & {
|
|
8
8
|
identifiersFields: any[];
|
|
9
|
-
}, any>, RecordDataType extends string | number |
|
|
9
|
+
}, any>, RecordDataType extends string | number | Date | DataType, DataType extends Record<string, RecordDataType | RecordDataType[]>>(data: DataType, fields: HasuraGraphQLFields<Model>) => NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | Partial<import("../../../../domain").IdentifiersModel<Model>>;
|
|
10
10
|
static ConvertFieldValueTo: <Model extends ModelBaseStructure<Model, Model["identifiersFields"][number]>, DataType extends Record<string, string | number | Date | DataType>>(instance: Model, fields: HasuraGraphQLFields<Model>, update?: boolean) => DataType;
|
|
11
11
|
private static ConvertNestedFieldsToGraphQLFields;
|
|
12
12
|
}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { BaseModel, } from '../../../../domain';
|
|
2
|
+
import { is, isDate, isEmpty, isNil, isObject, isString, parseDateTime } from '../../../../utils';
|
|
3
|
+
import { AttributeOptionHelper } from './attribute-option.helper';
|
|
4
|
+
import { BindFilterQueryHelper } from './bind-filter-query.helper';
|
|
5
|
+
export class GraphQLFieldHelper {
|
|
6
|
+
}
|
|
7
|
+
GraphQLFieldHelper.CheckIsGraphQLParams = (params) => !isString(params) && Array.isArray(params) && params.length >= 0 && !!params[0].operation;
|
|
8
|
+
GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields = (fields) => {
|
|
9
|
+
return fields === null || fields === void 0 ? void 0 : fields.map((field) => {
|
|
10
|
+
if (isString(field))
|
|
11
|
+
return field.toString();
|
|
12
|
+
if (field === 'affected_rows')
|
|
13
|
+
return field;
|
|
14
|
+
const fieldName = Object.keys(field).shift();
|
|
15
|
+
const fieldValue = is(field[fieldName]);
|
|
16
|
+
if (Array.isArray(fieldValue))
|
|
17
|
+
return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) };
|
|
18
|
+
if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue))
|
|
19
|
+
return;
|
|
20
|
+
const isNestedField = !!fieldValue.fields;
|
|
21
|
+
if (isNestedField)
|
|
22
|
+
return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue);
|
|
23
|
+
return fieldValue.columnName;
|
|
24
|
+
}).filter((field) => !!field);
|
|
25
|
+
};
|
|
26
|
+
GraphQLFieldHelper.ConvertFieldValueFrom = (data, fields) => Object.keys(data).reduce((result, columnName) => {
|
|
27
|
+
const { attributeName, fields: attributeFields, from, } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields);
|
|
28
|
+
if (!!attributeFields && Array.isArray(attributeFields)) {
|
|
29
|
+
if (Array.isArray(data[columnName]))
|
|
30
|
+
return Object.assign(Object.assign({}, result), { [attributeName]: from
|
|
31
|
+
? from(data[columnName], data)
|
|
32
|
+
: is(data[columnName]).map((value) => GraphQLFieldHelper.ConvertFieldValueFrom(is(value), attributeFields)) });
|
|
33
|
+
if (isObject(data[columnName]))
|
|
34
|
+
return Object.assign(Object.assign({}, result), { [attributeName]: !!from
|
|
35
|
+
? from(data[columnName])
|
|
36
|
+
: GraphQLFieldHelper.ConvertFieldValueFrom(is(data[columnName]), attributeFields) });
|
|
37
|
+
}
|
|
38
|
+
if (!!from)
|
|
39
|
+
return Object.assign(Object.assign({}, result), { [attributeName]: from(data[columnName], data) });
|
|
40
|
+
return Object.assign(Object.assign({}, result), { [attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName] });
|
|
41
|
+
}, {});
|
|
42
|
+
GraphQLFieldHelper.ConvertFieldValueTo = (instance, fields, update = false) => {
|
|
43
|
+
var _a;
|
|
44
|
+
const data = ((_a = instance.toPlain) === null || _a === void 0 ? void 0 : _a.call(instance)) || instance;
|
|
45
|
+
return Object.keys(data).reduce((result, attributeName) => {
|
|
46
|
+
const { columnName, fields: attributeFields, foreignKeyColumn, to, bindPersistData, } = AttributeOptionHelper.FindByAttribute(attributeName, fields);
|
|
47
|
+
if (bindPersistData)
|
|
48
|
+
return Object.assign(Object.assign({}, result), bindPersistData(data[attributeName], instance));
|
|
49
|
+
if (isNil(columnName))
|
|
50
|
+
return result;
|
|
51
|
+
if (!!foreignKeyColumn &&
|
|
52
|
+
!isEmpty(foreignKeyColumn) &&
|
|
53
|
+
!Object.keys(foreignKeyColumn).filter((key) => { var _a; return !((_a = is(data[attributeName])) === null || _a === void 0 ? void 0 : _a[key]); }).length)
|
|
54
|
+
return Object.keys(foreignKeyColumn).reduce((object, current) => {
|
|
55
|
+
var _a;
|
|
56
|
+
const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(foreignKeyColumn[current], fields);
|
|
57
|
+
return Object.assign(Object.assign({}, object), { [foreignColumnName]: (_a = data[attributeName]) === null || _a === void 0 ? void 0 : _a[current] });
|
|
58
|
+
}, Object.assign({}, result));
|
|
59
|
+
if (update &&
|
|
60
|
+
isObject(data[attributeName]) &&
|
|
61
|
+
!isNil(attributeFields) &&
|
|
62
|
+
!isDate(data[attributeName]))
|
|
63
|
+
return result;
|
|
64
|
+
if (!!columnName &&
|
|
65
|
+
Array.isArray(attributeFields) &&
|
|
66
|
+
isObject(data[attributeName])) {
|
|
67
|
+
const converted = !isNil(columnName) && to
|
|
68
|
+
? to(instance[attributeName], instance)
|
|
69
|
+
: data[attributeName];
|
|
70
|
+
return Object.assign(Object.assign({}, result), (converted !== undefined
|
|
71
|
+
? {
|
|
72
|
+
[columnName]: {
|
|
73
|
+
data: instance[attributeName] instanceof BaseModel
|
|
74
|
+
? GraphQLFieldHelper.ConvertFieldValueTo(data[attributeName], attributeFields)
|
|
75
|
+
: converted,
|
|
76
|
+
},
|
|
77
|
+
}
|
|
78
|
+
: {}));
|
|
79
|
+
}
|
|
80
|
+
if (!!to)
|
|
81
|
+
return Object.assign(Object.assign({}, result), { [columnName]: to(instance[attributeName], instance) });
|
|
82
|
+
return Object.assign(Object.assign({}, result), { [columnName]: data[attributeName] });
|
|
83
|
+
}, {});
|
|
84
|
+
};
|
|
85
|
+
GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields = (fieldName, fieldValue) => {
|
|
86
|
+
const hasCustomFilters = !!fieldValue.filters;
|
|
87
|
+
if (hasCustomFilters)
|
|
88
|
+
return {
|
|
89
|
+
operation: fieldValue.columnName || fieldName,
|
|
90
|
+
fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
|
|
91
|
+
variables: {
|
|
92
|
+
[`${fieldValue.columnName}_where`]: {
|
|
93
|
+
name: 'where',
|
|
94
|
+
type: fieldValue.filters.filterType,
|
|
95
|
+
value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),
|
|
96
|
+
required: true,
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
};
|
|
100
|
+
return {
|
|
101
|
+
[fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
|
|
102
|
+
};
|
|
103
|
+
};
|
|
104
|
+
//# sourceMappingURL=graphql-field.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graphql-field.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { IOperation } from 'gql-query-builder/build/IQueryBuilderOptions'\r\nimport {\r\n BaseModel,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertiesWithNoPartial,\r\n NonFunctionAndIdentifierPropertyNames,\r\n PartialIdentifiersModel,\r\n} from '../../../../domain'\r\nimport { is, isDate, isEmpty, isNil, isObject, isString, parseDateTime } from '../../../../utils'\r\nimport { ColumnOptions, Fields, GraphQLParams, HasuraGraphQLFields } from '../../types'\r\nimport { AttributeOptionHelper } from './attribute-option.helper'\r\nimport { BindFilterQueryHelper } from './bind-filter-query.helper'\r\n\r\nexport class GraphQLFieldHelper {\r\n static CheckIsGraphQLParams = <Model extends ModelBaseStructure<Model>>(\r\n params: string | IOperation | GraphQLParams<Model>[],\r\n ): params is GraphQLParams<Model>[] =>\r\n !isString(params) && Array.isArray(params) && params.length >= 0 && !!params[0].operation\r\n\r\n static ConvertModelFieldsToGraphQLFields = <Model extends ModelBaseStructure<Model>>(\r\n fields: HasuraGraphQLFields<Model>,\r\n ): Fields => {\r\n return fields\r\n ?.map((field) => {\r\n if (isString(field)) return field.toString()\r\n if (field === 'affected_rows') return field\r\n\r\n const fieldName = Object.keys(field).shift()\r\n const fieldValue = is<ColumnOptions<any, Model>>(field[fieldName as keyof typeof field])\r\n\r\n if (Array.isArray(fieldValue))\r\n return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) }\r\n if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue)) return\r\n\r\n const isNestedField = !!fieldValue.fields\r\n\r\n if (isNestedField) return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue as any)\r\n\r\n return fieldValue.columnName\r\n })\r\n .filter((field) => !!field)\r\n }\r\n\r\n static ConvertFieldValueFrom = <\r\n Model extends ModelBaseStructure,\r\n RecordDataType extends string | number | DataType | Date,\r\n DataType extends Record<string, RecordDataType | RecordDataType[]>,\r\n >(\r\n data: DataType,\r\n fields: HasuraGraphQLFields<Model>,\r\n ): NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | PartialIdentifiersModel<Model> =>\r\n Object.keys(data).reduce((result, columnName) => {\r\n const {\r\n attributeName,\r\n fields: attributeFields,\r\n from,\r\n } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields)\r\n\r\n if (!!attributeFields && Array.isArray(attributeFields)) {\r\n if (Array.isArray(data[columnName]))\r\n return {\r\n ...result,\r\n [attributeName]: from\r\n ? from(data[columnName], data)\r\n : is<RecordDataType[]>(data[columnName]).map((value) =>\r\n GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(value), attributeFields),\r\n ),\r\n }\r\n if (isObject(data[columnName]))\r\n return {\r\n ...result,\r\n [attributeName]: !!from\r\n ? from(data[columnName])\r\n : GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(data[columnName]), attributeFields),\r\n }\r\n }\r\n\r\n if (!!from) return { ...result, [attributeName]: from(data[columnName], data) }\r\n\r\n return {\r\n ...result,\r\n [attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName],\r\n }\r\n }, {})\r\n\r\n static ConvertFieldValueTo = <\r\n Model extends ModelBaseStructure<Model>,\r\n DataType extends Record<string, string | number | DataType | Date>,\r\n >(\r\n instance: Model,\r\n fields: HasuraGraphQLFields<Model>,\r\n update = false,\r\n ): DataType => {\r\n const data: Partial<Model> = instance.toPlain?.() || instance\r\n\r\n return Object.keys(data).reduce((result, attributeName) => {\r\n const {\r\n columnName,\r\n fields: attributeFields,\r\n foreignKeyColumn,\r\n to,\r\n bindPersistData,\r\n } = AttributeOptionHelper.FindByAttribute(attributeName as NonFunctionAndIdentifierPropertyNames<Model>, fields)\r\n\r\n if (bindPersistData)\r\n return {\r\n ...result,\r\n ...bindPersistData(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>], instance),\r\n }\r\n if (isNil(columnName)) return result\r\n if (\r\n !!foreignKeyColumn &&\r\n !isEmpty(foreignKeyColumn) &&\r\n !Object.keys(foreignKeyColumn).filter(\r\n (key) =>\r\n !is<Record<string, string>>(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>])?.[key],\r\n ).length\r\n )\r\n return Object.keys(foreignKeyColumn).reduce(\r\n (object, current) => {\r\n const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(\r\n foreignKeyColumn[current as keyof HasuraGraphQLFields<Model>[number]],\r\n fields,\r\n )\r\n\r\n return {\r\n ...object,\r\n [foreignColumnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]]?.[current],\r\n }\r\n },\r\n { ...result },\r\n )\r\n\r\n if (\r\n update &&\r\n isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]]) &&\r\n !isNil(attributeFields) &&\r\n !isDate(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n )\r\n return result\r\n\r\n if (\r\n !!columnName &&\r\n Array.isArray(attributeFields) &&\r\n isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n ) {\r\n const converted =\r\n !isNil(columnName) && to\r\n ? to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance)\r\n : data[attributeName as keyof HasuraGraphQLFields<Model>[number]]\r\n\r\n return {\r\n ...result,\r\n ...(converted !== undefined\r\n ? {\r\n [columnName]: {\r\n data:\r\n instance[attributeName as NonFunctionAndIdentifierPropertyNames<Model>] instanceof BaseModel\r\n ? GraphQLFieldHelper.ConvertFieldValueTo(\r\n data[attributeName as keyof HasuraGraphQLFields<Model>[number]],\r\n attributeFields as HasuraGraphQLFields<Model>,\r\n )\r\n : converted,\r\n },\r\n }\r\n : {}),\r\n }\r\n }\r\n\r\n if (!!to)\r\n return {\r\n ...result,\r\n [columnName]: to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance),\r\n }\r\n\r\n return { ...result, [columnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]] }\r\n }, {} as DataType)\r\n }\r\n\r\n private static ConvertNestedFieldsToGraphQLFields = <\r\n T extends ModelBaseStructure<T>,\r\n P extends ModelBaseStructure<P>,\r\n >(\r\n fieldName: string,\r\n fieldValue: ColumnOptions<T, P>,\r\n ) => {\r\n const hasCustomFilters = !!fieldValue.filters\r\n\r\n if (hasCustomFilters)\r\n return {\r\n operation: fieldValue.columnName || fieldName,\r\n fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n variables: {\r\n [`${fieldValue.columnName}_where`]: {\r\n name: 'where',\r\n type: fieldValue.filters.filterType,\r\n value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),\r\n required: true,\r\n },\r\n },\r\n }\r\n\r\n return {\r\n [fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n }\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,2BAA2B,CAAA;AACzC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,wBAAwB,CAAA","sourcesContent":["export * from './attribute-option.helper'\r\nexport * from './bind-filter-query.helper'\r\nexport * from './filter-option.helper'\r\nexport * from './graphql-field.helper'\r\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './with-create-hasura-graphql.mixin';
|
|
2
|
+
export * from './with-delete-hasura-graphql.mixin';
|
|
3
|
+
export * from './with-hasura-graphql.mixin';
|
|
4
|
+
export * from './with-update-hasura-graphql.mixin';
|
|
5
|
+
export * from './with-get-hasura-graphql.mixin';
|
|
6
|
+
export * from './with-find-hasura-graphql.mixin';
|
|
7
|
+
export * from './with-crud-hasura-graphql.mixin';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/index.ts"],"names":[],"mappings":"AAAA,cAAc,oCAAoC,CAAA;AAClD,cAAc,oCAAoC,CAAA;AAClD,cAAc,6BAA6B,CAAA;AAC3C,cAAc,oCAAoC,CAAA;AAClD,cAAc,iCAAiC,CAAA;AAC/C,cAAc,kCAAkC,CAAA;AAChD,cAAc,kCAAkC,CAAA","sourcesContent":["export * from './with-create-hasura-graphql.mixin'\r\nexport * from './with-delete-hasura-graphql.mixin'\r\nexport * from './with-hasura-graphql.mixin'\r\nexport * from './with-update-hasura-graphql.mixin'\r\nexport * from './with-get-hasura-graphql.mixin'\r\nexport * from './with-find-hasura-graphql.mixin'\r\nexport * from './with-crud-hasura-graphql.mixin'\r\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../domain';
|
|
2
2
|
import { MergeConstructorParams, MixinCtor } from '../../../utils';
|
|
3
3
|
import { GraphQLRepository } from '../types';
|
|
4
|
-
export type CreateConstructorParams = {
|
|
4
|
+
export declare type CreateConstructorParams = {
|
|
5
5
|
insertGraphQLOperation?: string;
|
|
6
6
|
insertAllGraphQLOperation?: string;
|
|
7
7
|
insertGraphQLObjectType?: string;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { DebugHelper } from '../../../utils';
|
|
2
|
+
import { AttributeOptionHelper } from './helpers';
|
|
3
|
+
export const withCreateHasuraGraphQL = (MixinBase) => {
|
|
4
|
+
return class CreateHasuraGraphQLMixin extends MixinBase {
|
|
5
|
+
constructor(...params) {
|
|
6
|
+
const options = params === null || params === void 0 ? void 0 : params[0];
|
|
7
|
+
super(...params);
|
|
8
|
+
this.insertGraphQLOperation = (options === null || options === void 0 ? void 0 : options.insertGraphQLOperation) || `insert_${this.tableName}_one`;
|
|
9
|
+
this.insertGraphQLObjectType = (options === null || options === void 0 ? void 0 : options.insertGraphQLObjectType) || `${this.tableName}_insert_input`;
|
|
10
|
+
}
|
|
11
|
+
async create(data) {
|
|
12
|
+
this.logger = DebugHelper.from(this, 'create');
|
|
13
|
+
const newData = await this.save(this.model.toInstance(data));
|
|
14
|
+
return this.model.toInstance(newData);
|
|
15
|
+
}
|
|
16
|
+
async save(data) {
|
|
17
|
+
const primaryKeyColumns = this.model.identifiersFields.map((field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName);
|
|
18
|
+
const foreignKeyColumns = this.fields
|
|
19
|
+
.map((field) => {
|
|
20
|
+
const columnOptions = Object.values(field).shift();
|
|
21
|
+
return (AttributeOptionHelper.CheckIsColumnOption(columnOptions) &&
|
|
22
|
+
columnOptions.foreignKeyColumn && [
|
|
23
|
+
...Object.values(columnOptions.foreignKeyColumn).map((foreignKeyName) => { var _a; return (_a = AttributeOptionHelper.FindByAttribute(foreignKeyName, this.fields)) === null || _a === void 0 ? void 0 : _a.columnName; }),
|
|
24
|
+
{
|
|
25
|
+
[columnOptions.columnName]: Object.keys(columnOptions.foreignKeyColumn).map((foreignKeyField) => {
|
|
26
|
+
var _a;
|
|
27
|
+
return ((_a = AttributeOptionHelper.FindByAttribute(foreignKeyField, columnOptions === null || columnOptions === void 0 ? void 0 : columnOptions.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || foreignKeyField;
|
|
28
|
+
}),
|
|
29
|
+
},
|
|
30
|
+
]);
|
|
31
|
+
})
|
|
32
|
+
.filter(Boolean)
|
|
33
|
+
.reduce((keys, current) => [...keys, ...current], []);
|
|
34
|
+
const result = await this.mutation(this.insertGraphQLOperation, [...primaryKeyColumns, ...foreignKeyColumns], {
|
|
35
|
+
object: { type: this.insertGraphQLObjectType, required: true, value: this.convertDataToHasura(data) },
|
|
36
|
+
});
|
|
37
|
+
return Object.assign(Object.assign({}, data.toPlain()), this.convertDataFromHasura(result[this.insertGraphQLOperation]).toPlain());
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=with-create-hasura-graphql.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"with-create-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { CreateRepository, CreateRepositoryParams, ModelBaseStructure } from '../../../domain'\r\nimport { DebugHelper, MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository, HasuraGraphQLFields } from '../types'\r\n\r\nimport { AttributeOptionHelper } from './helpers'\r\n\r\nexport type CreateConstructorParams = {\r\n insertGraphQLOperation?: string\r\n insertAllGraphQLOperation?: string\r\n insertGraphQLObjectType?: string\r\n}\r\n\r\nexport const withCreateHasuraGraphQL = <\r\n MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\r\n TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<MBase> & InstanceType<TMixinBase> & CreateRepository<MBase>,\r\n MergeConstructorParams<[CreateConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>\r\n> => {\r\n return class CreateHasuraGraphQLMixin extends MixinBase implements CreateRepository<MBase> {\r\n insertGraphQLOperation: string\r\n insertGraphQLObjectType: string\r\n\r\n constructor(...params: any[]) {\r\n const options: CreateConstructorParams = params?.[0]\r\n\r\n super(...params)\r\n\r\n this.insertGraphQLOperation = options?.insertGraphQLOperation || `insert_${this.tableName}_one`\r\n this.insertGraphQLObjectType = options?.insertGraphQLObjectType || `${this.tableName}_insert_input`\r\n }\r\n\r\n async create(data: CreateRepositoryParams<MBase>): Promise<MBase> {\r\n this.logger = DebugHelper.from(this, 'create')\r\n\r\n const newData = await this.save(this.model.toInstance(data))\r\n\r\n return this.model.toInstance(newData)\r\n }\r\n\r\n async save(data: MBase): Promise<Partial<MBase>> {\r\n const primaryKeyColumns = this.model.identifiersFields.map(\r\n (field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName,\r\n ) as HasuraGraphQLFields<MBase>\r\n const foreignKeyColumns = this.fields\r\n .map((field) => {\r\n const columnOptions = Object.values(field).shift()\r\n\r\n return (\r\n AttributeOptionHelper.CheckIsColumnOption(columnOptions) &&\r\n columnOptions.foreignKeyColumn && [\r\n ...Object.values(columnOptions.foreignKeyColumn).map(\r\n (foreignKeyName) =>\r\n AttributeOptionHelper.FindByAttribute(foreignKeyName as any, this.fields)?.columnName,\r\n ),\r\n {\r\n [columnOptions.columnName]: Object.keys(columnOptions.foreignKeyColumn).map(\r\n (foreignKeyField) =>\r\n AttributeOptionHelper.FindByAttribute(foreignKeyField as any, columnOptions?.fields as any)\r\n ?.columnName || foreignKeyField,\r\n ),\r\n },\r\n ]\r\n )\r\n })\r\n .filter(Boolean)\r\n .reduce((keys, current) => [...keys, ...current], [])\r\n\r\n const result = await this.mutation<Record<string, Record<string, any>>>(\r\n this.insertGraphQLOperation,\r\n [...primaryKeyColumns, ...foreignKeyColumns] as HasuraGraphQLFields<MBase>,\r\n {\r\n object: { type: this.insertGraphQLObjectType, required: true, value: this.convertDataToHasura(data) },\r\n },\r\n )\r\n\r\n return { ...data.toPlain(), ...this.convertDataFromHasura(result[this.insertGraphQLOperation]).toPlain() }\r\n }\r\n } as any\r\n}\r\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { withCreateHasuraGraphQL } from './with-create-hasura-graphql.mixin';
|
|
2
|
+
import { withDeleteHasuraGraphQL } from './with-delete-hasura-graphql.mixin';
|
|
3
|
+
import { withFindHasuraGraphQL } from './with-find-hasura-graphql.mixin';
|
|
4
|
+
import { withGetHasuraGraphQL } from './with-get-hasura-graphql.mixin';
|
|
5
|
+
import { withUpdateHasuraGraphQL, } from './with-update-hasura-graphql.mixin';
|
|
6
|
+
export const withCrudHasuraGraphQL = (MixinBase) => {
|
|
7
|
+
return class CrudHasuraGraphQLMixin extends withUpdateHasuraGraphQL(withGetHasuraGraphQL(withFindHasuraGraphQL(withDeleteHasuraGraphQL(withCreateHasuraGraphQL(MixinBase))))) {
|
|
8
|
+
};
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=with-crud-hasura-graphql.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"with-crud-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.ts"],"names":[],"mappings":"AAIA,OAAO,EAA2B,uBAAuB,EAAE,MAAM,oCAAoC,CAAA;AACrG,OAAO,EAA2B,uBAAuB,EAAE,MAAM,oCAAoC,CAAA;AACrG,OAAO,EAAE,qBAAqB,EAAE,MAAM,kCAAkC,CAAA;AACxE,OAAO,EAAwB,oBAAoB,EAAE,MAAM,iCAAiC,CAAA;AAE5F,OAAO,EAGL,uBAAuB,GACxB,MAAM,oCAAoC,CAAA;AAE3C,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAKnC,SAA2D,EAc3D,EAAE;IACF,OAAO,MAAM,sBACX,SAAQ,uBAAuB,CAC7B,oBAAoB,CAClB,qBAAqB,CACnB,uBAAuB,CAAC,uBAAuB,CAAC,SAAgD,CAAC,CAAC,CACnG,CACF,CACF;KACyC,CAAA;AAC9C,CAAC,CAAA","sourcesContent":["import { CrudRepository, ModelBaseStructure } from '../../../domain'\r\nimport { MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository } from '../types'\r\n\r\nimport { CreateConstructorParams, withCreateHasuraGraphQL } from './with-create-hasura-graphql.mixin'\r\nimport { DeleteConstructorParams, withDeleteHasuraGraphQL } from './with-delete-hasura-graphql.mixin'\r\nimport { withFindHasuraGraphQL } from './with-find-hasura-graphql.mixin'\r\nimport { GetConstructorParams, withGetHasuraGraphQL } from './with-get-hasura-graphql.mixin'\r\nimport { HasuraConstructorParams } from './with-hasura-graphql.mixin'\r\nimport {\r\n UpdateConstructorParams,\r\n UpdateHasuraGraphQLRepositoryType,\r\n withUpdateHasuraGraphQL,\r\n} from './with-update-hasura-graphql.mixin'\r\n\r\nexport const withCrudHasuraGraphQL = <\r\n TBase extends ModelBaseStructure<TBase, TBase['identifiersFields'][number]>,\r\n Repository = CrudRepository<TBase>,\r\n TMixinBase extends MixinCtor = MixinCtor,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<TBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<TBase> & Repository & UpdateHasuraGraphQLRepositoryType<TBase>,\r\n MergeConstructorParams<\r\n [\r\n HasuraConstructorParams<TBase> &\r\n CreateConstructorParams &\r\n DeleteConstructorParams &\r\n GetConstructorParams &\r\n UpdateConstructorParams,\r\n ...any[],\r\n ],\r\n ConstructorParameters<TMixinBase>\r\n >\r\n> => {\r\n return class CrudHasuraGraphQLMixin\r\n extends withUpdateHasuraGraphQL(\r\n withGetHasuraGraphQL(\r\n withFindHasuraGraphQL(\r\n withDeleteHasuraGraphQL(withCreateHasuraGraphQL(MixinBase as MixinCtor<GraphQLRepository<TBase>>)),\r\n ),\r\n ),\r\n )\r\n implements CrudRepository<TBase> {} as any\r\n}\r\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { DeleteRepository, DeleteRepositoryParams, ModelBaseStructure } from '../../../domain';
|
|
2
2
|
import { MergeConstructorParams, MixinCtor } from '../../../utils';
|
|
3
3
|
import { GraphQLRepository } from '../types';
|
|
4
|
-
export type DeleteConstructorParams = {
|
|
4
|
+
export declare type DeleteConstructorParams = {
|
|
5
5
|
deleteGraphQLOperation?: string;
|
|
6
6
|
};
|
|
7
7
|
export declare const withDeleteHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>, any[]>>(MixinBase: MixinCtor<GraphQLRepository<MBase>, any[]> & TMixinBase) => MixinCtor<GraphQLRepository<MBase> & DeleteRepository<MBase, DeleteRepositoryParams<MBase>> & InstanceType<TMixinBase>, MergeConstructorParams<[DeleteConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>>;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { DebugHelper, isNil } from '../../../utils';
|
|
2
|
+
import { AttributeOptionHelper } from './helpers';
|
|
3
|
+
export const withDeleteHasuraGraphQL = (MixinBase) => {
|
|
4
|
+
return class DeleteHasuraGraphQLMixin extends MixinBase {
|
|
5
|
+
constructor(...params) {
|
|
6
|
+
const options = params === null || params === void 0 ? void 0 : params[0];
|
|
7
|
+
super(...params);
|
|
8
|
+
this.deleteGraphQLOperation = (options === null || options === void 0 ? void 0 : options.deleteGraphQLOperation) || `delete_${this.tableName}_by_pk`;
|
|
9
|
+
}
|
|
10
|
+
async delete(identifiers) {
|
|
11
|
+
this.logger = DebugHelper.from(this, 'delete');
|
|
12
|
+
const instance = this.model.toInstance(identifiers);
|
|
13
|
+
await this.mutation(this.deleteGraphQLOperation, this.model.identifiersFields.map((field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName), this.model.identifiersFields.reduce((ids, identifier) => {
|
|
14
|
+
const identifierBinded = identifier;
|
|
15
|
+
if (isNil(instance.identifier[identifierBinded]))
|
|
16
|
+
return ids;
|
|
17
|
+
const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields);
|
|
18
|
+
const value = columnOption.to(identifiers[identifier], instance);
|
|
19
|
+
return Object.assign(Object.assign({}, ids), { [columnOption.columnName]: {
|
|
20
|
+
type: this.getAttributeGraphQLTypeOf(columnOption.type || value),
|
|
21
|
+
value,
|
|
22
|
+
required: true,
|
|
23
|
+
} });
|
|
24
|
+
}, {}));
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=with-delete-hasura-graphql.mixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"with-delete-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAE,KAAK,EAAqC,MAAM,gBAAgB,CAAA;AAGtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAMjD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAIrC,SAA2D,EAI3D,EAAE;IACF,OAAO,MAAM,wBAAyB,SAAQ,SAAS;QAGrD,YAAY,GAAG,MAAa;YAC1B,MAAM,OAAO,GAA4B,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,CAAC,CAAC,CAAA;YAEpD,KAAK,CAAC,GAAG,MAAM,CAAC,CAAA;YAEhB,IAAI,CAAC,sBAAsB,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,sBAAsB,KAAI,UAAU,IAAI,CAAC,SAAS,QAAQ,CAAA;QACnG,CAAC;QAED,KAAK,CAAC,MAAM,CAAC,WAA0C;YACrD,IAAI,CAAC,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;YAE9C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,WAAW,CAAC,CAAA;YAEnD,MAAM,IAAI,CAAC,QAAQ,CACjB,IAAI,CAAC,sBAAsB,EAC3B,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,CAC9B,CAAC,KAAK,EAAE,EAAE,CAAC,qBAAqB,CAAC,eAAe,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,UAAU,CAClD,EAC/B,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,UAAU,EAAE,EAAE;gBACtD,MAAM,gBAAgB,GAGlB,UAAU,CAAA;gBAEd,IAAI,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;oBAAE,OAAO,GAAG,CAAA;gBAE5D,MAAM,YAAY,GAAG,qBAAqB,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;gBACnF,MAAM,KAAK,GAAG,YAAY,CAAC,EAAE,CAAC,WAAW,CAAC,UAAiD,CAAC,EAAE,QAAQ,CAAC,CAAA;gBAEvG,uCACK,GAAG,KACN,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE;wBACzB,IAAI,EAAE,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,IAAI,IAAI,KAAK,CAAC;wBAChE,KAAK;wBACL,QAAQ,EAAE,IAAI;qBACf,IACF;YACH,CAAC,EAAE,EAAE,CAAC,CACP,CAAA;QACH,CAAC;KACK,CAAA;AACV,CAAC,CAAA","sourcesContent":["import {\r\n DeleteRepository,\r\n DeleteRepositoryParams,\r\n ModelBaseStructure,\r\n NonFunctionAndIdentifierPropertyNames,\r\n} from '../../../domain'\r\nimport { DebugHelper, isNil, MergeConstructorParams, MixinCtor } from '../../../utils'\r\nimport { GraphQLRepository, HasuraGraphQLFields } from '../types'\r\n\r\nimport { AttributeOptionHelper } from './helpers'\r\n\r\nexport type DeleteConstructorParams = {\r\n deleteGraphQLOperation?: string\r\n}\r\n\r\nexport const withDeleteHasuraGraphQL = <\r\n MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\r\n TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\r\n>(\r\n MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\r\n): MixinCtor<\r\n GraphQLRepository<MBase> & DeleteRepository<MBase> & InstanceType<TMixinBase>,\r\n MergeConstructorParams<[DeleteConstructorParams, ...any[]], ConstructorParameters<TMixinBase>>\r\n> => {\r\n return class DeleteHasuraGraphQLMixin extends MixinBase implements DeleteRepository<MBase> {\r\n deleteGraphQLOperation: string\r\n\r\n constructor(...params: any[]) {\r\n const options: DeleteConstructorParams = params?.[0]\r\n\r\n super(...params)\r\n\r\n this.deleteGraphQLOperation = options?.deleteGraphQLOperation || `delete_${this.tableName}_by_pk`\r\n }\r\n\r\n async delete(identifiers: DeleteRepositoryParams<MBase>): Promise<void> {\r\n this.logger = DebugHelper.from(this, 'delete')\r\n\r\n const instance = this.model.toInstance(identifiers)\r\n\r\n await this.mutation(\r\n this.deleteGraphQLOperation,\r\n this.model.identifiersFields.map(\r\n (field) => AttributeOptionHelper.FindByAttribute(field, this.fields).columnName,\r\n ) as HasuraGraphQLFields<MBase>,\r\n this.model.identifiersFields.reduce((ids, identifier) => {\r\n const identifierBinded: Extract<\r\n NonFunctionAndIdentifierPropertyNames<MBase>,\r\n MBase['identifiersFields'][number]\r\n > = identifier\r\n\r\n if (isNil(instance.identifier[identifierBinded])) return ids\r\n\r\n const columnOption = AttributeOptionHelper.FindByAttribute(identifier, this.fields)\r\n const value = columnOption.to(identifiers[identifier as keyof DeleteRepositoryParams<MBase>], instance)\r\n\r\n return {\r\n ...ids,\r\n [columnOption.columnName]: {\r\n type: this.getAttributeGraphQLTypeOf(columnOption.type || value),\r\n value,\r\n required: true,\r\n },\r\n }\r\n }, {}),\r\n )\r\n }\r\n } as any\r\n}\r\n"]}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { DebugHelper, isNil, set } from '../../../utils';
|
|
2
|
+
import { AttributeOptionHelper, BindFilterQueryHelper } from './helpers';
|
|
3
|
+
export const withFindHasuraGraphQL = (MixinBase) => {
|
|
4
|
+
return class FindHasuraGraphQLMixin extends MixinBase {
|
|
5
|
+
constructor() {
|
|
6
|
+
super(...arguments);
|
|
7
|
+
this.bindOrderByAttributes = (orderBy, fields) => Object.keys(orderBy).reduce((acc, current) => [
|
|
8
|
+
...acc,
|
|
9
|
+
{
|
|
10
|
+
[AttributeOptionHelper.FindByAttribute(current, fields)
|
|
11
|
+
.columnName]: orderBy[current] === 'asc'
|
|
12
|
+
? 'asc_nulls_last'
|
|
13
|
+
: 'desc_nulls_last',
|
|
14
|
+
},
|
|
15
|
+
], []);
|
|
16
|
+
this.bindAggretageAttributes = (aggregates, fields) => {
|
|
17
|
+
var _a, _b;
|
|
18
|
+
return [
|
|
19
|
+
...(((_a = aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal) === null || _a === void 0 ? void 0 : _a.length)
|
|
20
|
+
? [
|
|
21
|
+
{
|
|
22
|
+
min: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal, fields),
|
|
23
|
+
},
|
|
24
|
+
]
|
|
25
|
+
: []),
|
|
26
|
+
...(((_b = aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum) === null || _b === void 0 ? void 0 : _b.length)
|
|
27
|
+
? [
|
|
28
|
+
{
|
|
29
|
+
max: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum, fields),
|
|
30
|
+
},
|
|
31
|
+
]
|
|
32
|
+
: []),
|
|
33
|
+
];
|
|
34
|
+
};
|
|
35
|
+
this.bindDistinctAttributes = (distinct, fields) => this.bindAttributesToColumns(distinct, fields);
|
|
36
|
+
this.bindAttributesToColumns = (attributes, fields) => attributes.map((attr) => {
|
|
37
|
+
var _a;
|
|
38
|
+
return ((_a = AttributeOptionHelper.FindByAttribute(attr.toString().split('.').pop(), fields)) === null || _a === void 0 ? void 0 : _a.columnName) || attr;
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
async find(params) {
|
|
42
|
+
var _a, _b, _c, _d, _e, _f, _g, _h;
|
|
43
|
+
this.logger = DebugHelper.from(this, 'find');
|
|
44
|
+
const { filters, limits, orderBy, options } = params || {};
|
|
45
|
+
const enableCount = (_a = options === null || options === void 0 ? void 0 : options.enableCount) !== null && _a !== void 0 ? _a : true;
|
|
46
|
+
const variablesFilters = isNil(filters)
|
|
47
|
+
? {}
|
|
48
|
+
: {
|
|
49
|
+
where: {
|
|
50
|
+
value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),
|
|
51
|
+
type: `${this.tableName}_bool_exp`,
|
|
52
|
+
required: true,
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
const variablesCount = Object.assign(Object.assign({}, (isNil(orderBy)
|
|
56
|
+
? {}
|
|
57
|
+
: {
|
|
58
|
+
order_by: {
|
|
59
|
+
type: `${this.tableName}_order_by!`,
|
|
60
|
+
list: true,
|
|
61
|
+
value: this.bindOrderByAttributes(orderBy, this.fields),
|
|
62
|
+
},
|
|
63
|
+
})), variablesFilters);
|
|
64
|
+
const variables = Object.assign(Object.assign({}, (isNil(limits) ? {} : limits)), variablesCount);
|
|
65
|
+
const aggregateFields = [
|
|
66
|
+
...(enableCount ? ['count'] : []),
|
|
67
|
+
...this.bindAggretageAttributes(params.options, this.fields),
|
|
68
|
+
];
|
|
69
|
+
const result = await this.query([
|
|
70
|
+
{
|
|
71
|
+
operation: this.tableName,
|
|
72
|
+
fields: params.fields
|
|
73
|
+
? params.fields
|
|
74
|
+
.map((fieldName) => {
|
|
75
|
+
var _a;
|
|
76
|
+
return (_a = this.fields.find((fieldOption) => fieldOption === fieldName)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName);
|
|
77
|
+
})
|
|
78
|
+
.filter(Boolean)
|
|
79
|
+
: this.fields,
|
|
80
|
+
variables,
|
|
81
|
+
},
|
|
82
|
+
...(aggregateFields.length > 0
|
|
83
|
+
? [
|
|
84
|
+
{
|
|
85
|
+
operation: `${this.tableName}_aggregate`,
|
|
86
|
+
fields: [
|
|
87
|
+
{
|
|
88
|
+
aggregate: aggregateFields,
|
|
89
|
+
},
|
|
90
|
+
],
|
|
91
|
+
variables: variablesCount,
|
|
92
|
+
},
|
|
93
|
+
]
|
|
94
|
+
: []),
|
|
95
|
+
...((!((_b = params.limits) === null || _b === void 0 ? void 0 : _b.offset) &&
|
|
96
|
+
((_d = (_c = params.options) === null || _c === void 0 ? void 0 : _c.distinct) === null || _d === void 0 ? void 0 : _d.map((distinct) => {
|
|
97
|
+
var _a, _b;
|
|
98
|
+
const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === distinct)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct);
|
|
99
|
+
const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || distinct;
|
|
100
|
+
return {
|
|
101
|
+
operation: {
|
|
102
|
+
name: `${this.tableName}`,
|
|
103
|
+
alias: `${this.tableName}_${distinct.toString()}_distinct`,
|
|
104
|
+
},
|
|
105
|
+
fields: [distinctOption],
|
|
106
|
+
variables: Object.assign(Object.assign({}, variablesFilters), { [`${this.tableName}_${fieldName}_distinct`]: {
|
|
107
|
+
type: `${this.tableName}_select_column!`,
|
|
108
|
+
list: true,
|
|
109
|
+
value: fieldName,
|
|
110
|
+
name: 'distinct_on',
|
|
111
|
+
} }),
|
|
112
|
+
};
|
|
113
|
+
}))) ||
|
|
114
|
+
[]),
|
|
115
|
+
]);
|
|
116
|
+
const data = result[this.tableName].map((row) => this.convertDataFromHasura(row));
|
|
117
|
+
return Object.assign(Object.assign(Object.assign({ data, count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity }, (((_e = options === null || options === void 0 ? void 0 : options.minimal) === null || _e === void 0 ? void 0 : _e.length)
|
|
118
|
+
? {
|
|
119
|
+
minimal: options.minimal.reduce((minimals, current) => {
|
|
120
|
+
var _a;
|
|
121
|
+
return (Object.assign(Object.assign({}, minimals), set(minimals, current, result[`${this.tableName}_aggregate`].aggregate.min[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
|
|
122
|
+
}, {}),
|
|
123
|
+
}
|
|
124
|
+
: {})), (((_f = options === null || options === void 0 ? void 0 : options.maximum) === null || _f === void 0 ? void 0 : _f.length)
|
|
125
|
+
? {
|
|
126
|
+
maximum: options.maximum.reduce((maximums, current) => {
|
|
127
|
+
var _a;
|
|
128
|
+
return (Object.assign(Object.assign({}, maximums), set(maximums, current, result[`${this.tableName}_aggregate`].aggregate.max[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
|
|
129
|
+
}, {}),
|
|
130
|
+
}
|
|
131
|
+
: {})), (!((_g = params.limits) === null || _g === void 0 ? void 0 : _g.offset) &&
|
|
132
|
+
((_h = options === null || options === void 0 ? void 0 : options.distinct) === null || _h === void 0 ? void 0 : _h.length) && {
|
|
133
|
+
distinct: options === null || options === void 0 ? void 0 : options.distinct.reduce((distinct, current) => {
|
|
134
|
+
var _a, _b;
|
|
135
|
+
const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === current)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current);
|
|
136
|
+
const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || current;
|
|
137
|
+
return Object.assign(Object.assign({}, distinct), { [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map((obj) => obj[fieldName]) });
|
|
138
|
+
}, {}),
|
|
139
|
+
}));
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
};
|
|
143
|
+
//# sourceMappingURL=with-find-hasura-graphql.mixin.js.map
|