@infrab4a/connect 4.0.2-beta.9 → 4.0.3-beta.0
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/README.md +24 -0
- package/domain/catalog/helpers/index.d.ts +1 -0
- package/domain/catalog/helpers/round-product-price.helper.d.ts +4 -0
- package/domain/catalog/index.d.ts +3 -0
- package/domain/catalog/models/category-base.d.ts +30 -0
- package/domain/catalog/models/category-collection-children.d.ts +13 -0
- package/domain/catalog/models/category-filter.d.ts +13 -0
- package/domain/catalog/models/category-for-product.d.ts +5 -0
- package/domain/catalog/models/category.d.ts +7 -0
- package/domain/catalog/models/enums/index.d.ts +2 -0
- package/domain/catalog/models/enums/product-genders.enum.d.ts +5 -0
- package/domain/catalog/models/enums/shops.enum.d.ts +6 -0
- package/domain/catalog/models/filter-option.d.ts +9 -0
- package/domain/catalog/models/filter.d.ts +12 -0
- package/domain/catalog/models/index.d.ts +11 -0
- package/domain/catalog/models/kit-product.d.ts +12 -0
- package/domain/catalog/models/product-base.d.ts +40 -0
- package/domain/catalog/models/product-for-category.d.ts +7 -0
- package/domain/catalog/models/product-for-kit.d.ts +7 -0
- package/domain/catalog/models/product.d.ts +9 -0
- package/domain/catalog/models/types/category-condition.type.d.ts +4 -0
- package/domain/catalog/models/types/category-metadata.type.d.ts +4 -0
- package/domain/catalog/models/types/category-product.d.ts +4 -0
- package/domain/catalog/models/types/index.d.ts +11 -0
- package/domain/catalog/models/types/product-evaluation.type.d.ts +6 -0
- package/domain/catalog/models/types/product-gender.type.d.ts +1 -0
- package/domain/catalog/models/types/product-metadata.type.d.ts +4 -0
- package/domain/catalog/models/types/product-review.type.d.ts +17 -0
- package/domain/catalog/models/types/shop-description.type.d.ts +8 -0
- package/domain/catalog/models/types/shop-price.type.d.ts +6 -0
- package/domain/catalog/models/types/stock.type.d.ts +3 -0
- package/domain/catalog/models/types/variant-grade.type.d.ts +4 -0
- package/domain/catalog/models/variant.d.ts +17 -0
- package/domain/catalog/models/wishlist.d.ts +8 -0
- package/domain/catalog/repositories/category-collection-children.repository.d.ts +4 -0
- package/domain/catalog/repositories/category-filter.repository.d.ts +6 -0
- package/domain/catalog/repositories/category.repository.d.ts +18 -0
- package/domain/catalog/repositories/filter-option.repository.d.ts +4 -0
- package/domain/catalog/repositories/filter.repository.d.ts +4 -0
- package/domain/catalog/repositories/index.d.ts +9 -0
- package/domain/catalog/repositories/product.repository.d.ts +15 -0
- package/domain/catalog/repositories/subscription-product.repository.d.ts +4 -0
- package/domain/catalog/repositories/variant.repository.d.ts +4 -0
- package/domain/catalog/repositories/wishlist.repository.d.ts +6 -0
- package/domain/generic/index.d.ts +2 -0
- package/domain/generic/model/base.model.d.ts +14 -0
- package/domain/generic/model/identifier-fields.d.ts +4 -0
- package/domain/generic/model/index.d.ts +3 -0
- package/domain/generic/model/types/base-model-builder.type.d.ts +17 -0
- package/domain/generic/model/types/identifier-model.type.d.ts +8 -0
- package/domain/generic/model/types/index.d.ts +5 -0
- package/domain/generic/model/types/model-base-structure.type.d.ts +12 -0
- package/domain/generic/model/types/non-function-properties.type.d.ts +12 -0
- package/domain/generic/model/types/non-function-property-name.type.d.ts +13 -0
- package/domain/generic/repository/create.repository.d.ts +8 -0
- package/domain/generic/repository/crud.repository.d.ts +19 -0
- package/domain/generic/repository/delete.repository.d.ts +7 -0
- package/domain/generic/repository/enums/index.d.ts +2 -0
- package/domain/generic/repository/enums/update-option-actions.enum.d.ts +7 -0
- package/domain/generic/repository/enums/where.enum.d.ts +14 -0
- package/domain/generic/repository/find.repository.d.ts +17 -0
- package/domain/generic/repository/get.repository.d.ts +5 -0
- package/domain/generic/repository/index.d.ts +9 -0
- package/domain/generic/repository/read.repository.d.ts +14 -0
- package/domain/generic/repository/types/index.d.ts +6 -0
- package/domain/generic/repository/types/repository-find-filters.type.d.ts +13 -0
- package/domain/generic/repository/types/repository-find-result.type.d.ts +14 -0
- package/domain/generic/repository/types/repository-limit-options.type.d.ts +4 -0
- package/domain/generic/repository/types/repository-order-by-list.type.d.ts +5 -0
- package/domain/generic/repository/types/repository-update-params.type.d.ts +11 -0
- package/domain/generic/repository/types/where-options.type.d.ts +2 -0
- package/domain/generic/repository/update.repository.d.ts +6 -0
- package/domain/index.d.ts +6 -0
- package/domain/location/index.d.ts +1 -0
- package/domain/location/models/address.d.ts +24 -0
- package/domain/location/models/index.d.ts +2 -0
- package/domain/location/models/types/index.d.ts +3 -0
- package/domain/location/models/types/location-bound.type.d.ts +6 -0
- package/domain/location/models/types/location-geometry.type.d.ts +7 -0
- package/domain/location/models/types/location-lat-lng.type.d.ts +4 -0
- package/domain/shop-settings/enums/filter-type.enum.d.ts +19 -0
- package/domain/shop-settings/enums/index.d.ts +2 -0
- package/domain/shop-settings/enums/questions-filters.enum.d.ts +19 -0
- package/domain/shop-settings/helpers/beauty-questions.helper.d.ts +9 -0
- package/domain/shop-settings/helpers/index.d.ts +1 -0
- package/domain/shop-settings/index.d.ts +4 -0
- package/domain/shop-settings/models/home.d.ts +18 -0
- package/domain/shop-settings/models/index.d.ts +4 -0
- package/domain/shop-settings/models/shop-menu.d.ts +7 -0
- package/domain/shop-settings/models/shop-settings.d.ts +9 -0
- package/domain/shop-settings/models/types/banner.type.d.ts +6 -0
- package/domain/shop-settings/models/types/benefit.type.d.ts +5 -0
- package/domain/shop-settings/models/types/home-data.type.d.ts +15 -0
- package/domain/shop-settings/models/types/index.d.ts +10 -0
- package/domain/shop-settings/models/types/menu-nav.type.d.ts +8 -0
- package/domain/shop-settings/models/types/shop-banner.type.d.ts +12 -0
- package/domain/shop-settings/models/types/shop-brands.type.d.ts +10 -0
- package/domain/shop-settings/models/types/shop-carousel.type.d.ts +5 -0
- package/domain/shop-settings/models/types/shop-collection.type.d.ts +9 -0
- package/domain/shop-settings/models/types/shop-section.type.d.ts +9 -0
- package/domain/shop-settings/models/types/sub-menu.type.d.ts +8 -0
- package/domain/shop-settings/repositories/home.repository.d.ts +4 -0
- package/domain/shop-settings/repositories/index.d.ts +3 -0
- package/domain/shop-settings/repositories/shop-menu.repository.d.ts +4 -0
- package/domain/shop-settings/repositories/shop-settings.repository.d.ts +4 -0
- package/domain/shopping/index.d.ts +2 -0
- package/domain/shopping/models/buy-2-win.d.ts +18 -0
- package/domain/shopping/models/campaign-dashboard.d.ts +15 -0
- package/domain/shopping/models/campaign-hashtag.d.ts +18 -0
- package/domain/shopping/models/checkout.d.ts +26 -0
- package/domain/shopping/models/coupons/coupon.d.ts +60 -0
- package/domain/shopping/models/coupons/enums/coupon-club-mens.enum.d.ts +5 -0
- package/domain/shopping/models/coupons/enums/coupon-subtypes.enum.d.ts +4 -0
- package/domain/shopping/models/coupons/enums/coupon-types.enum.d.ts +4 -0
- package/domain/shopping/models/coupons/enums/exclusivities.enum.d.ts +8 -0
- package/domain/shopping/models/coupons/enums/index.d.ts +3 -0
- package/domain/shopping/models/coupons/index.d.ts +2 -0
- package/domain/shopping/models/enums/checkout-types.enum.d.ts +5 -0
- package/domain/shopping/models/enums/index.d.ts +2 -0
- package/domain/shopping/models/enums/order-status.enum.d.ts +10 -0
- package/domain/shopping/models/index.d.ts +12 -0
- package/domain/shopping/models/line-item.d.ts +8 -0
- package/domain/shopping/models/order.d.ts +10 -0
- package/domain/shopping/models/payment.d.ts +67 -0
- package/domain/shopping/models/shipping-method.d.ts +17 -0
- package/domain/shopping/models/subscription/checkout.d.ts +20 -0
- package/domain/shopping/models/subscription/index.d.ts +2 -0
- package/domain/shopping/models/subscription/plan.d.ts +10 -0
- package/domain/shopping/models/types/index.d.ts +7 -0
- package/domain/shopping/models/types/payment-address.type.d.ts +12 -0
- package/domain/shopping/models/types/payment-billing.type.d.ts +7 -0
- package/domain/shopping/models/types/payment-card.type.d.ts +14 -0
- package/domain/shopping/models/types/payment-customer.type.d.ts +18 -0
- package/domain/shopping/models/types/payment-document.type.d.ts +6 -0
- package/domain/shopping/models/types/payment-item.type.d.ts +11 -0
- package/domain/shopping/models/types/payment-shipping.type.d.ts +10 -0
- package/domain/shopping/repositories/buy-2-win.repository.d.ts +4 -0
- package/domain/shopping/repositories/campaign-dashboard.repository.d.ts +4 -0
- package/domain/shopping/repositories/campaign-hashtag.repository.d.ts +4 -0
- package/domain/shopping/repositories/checkout.repository.d.ts +4 -0
- package/domain/shopping/repositories/coupon.repository.d.ts +4 -0
- package/domain/shopping/repositories/index.d.ts +9 -0
- package/domain/shopping/repositories/legacy-order.repository.d.ts +3 -0
- package/domain/shopping/repositories/order.repository.d.ts +4 -0
- package/domain/shopping/repositories/payment.repository.d.ts +4 -0
- package/domain/shopping/repositories/subscription/checkout.repository.d.ts +4 -0
- package/domain/shopping/repositories/subscription/index.d.ts +2 -0
- package/domain/shopping/repositories/subscription/plan.repository.d.ts +4 -0
- package/domain/users/errors/index.d.ts +3 -0
- package/domain/users/errors/unauthorized.error.d.ts +4 -0
- package/domain/users/errors/user-already-registered.error.d.ts +4 -0
- package/domain/users/errors/weak-password.error.d.ts +4 -0
- package/domain/users/index.d.ts +5 -0
- package/domain/users/models/beauty-profile.d.ts +11 -0
- package/domain/users/models/enums/accessory-importances.enum.d.ts +5 -0
- package/domain/users/models/enums/area.enum.d.ts +11 -0
- package/domain/users/models/enums/beard-problems.enum.d.ts +9 -0
- package/domain/users/models/enums/beard-sizes.enum.d.ts +7 -0
- package/domain/users/models/enums/beauty-product-importances.enum.d.ts +6 -0
- package/domain/users/models/enums/body-problems.enum.d.ts +11 -0
- package/domain/users/models/enums/body-shapes.enum.d.ts +7 -0
- package/domain/users/models/enums/body-tattoos.enum.d.ts +5 -0
- package/domain/users/models/enums/face-skin-oilinesses.enum.d.ts +7 -0
- package/domain/users/models/enums/face-skin-problems.enum.d.ts +10 -0
- package/domain/users/models/enums/face-skin-tones.enum.d.ts +8 -0
- package/domain/users/models/enums/family-incomes.enum.d.ts +8 -0
- package/domain/users/models/enums/fragrance-importances.enum.d.ts +5 -0
- package/domain/users/models/enums/hair-colors.enum.d.ts +10 -0
- package/domain/users/models/enums/hair-problems.enum.d.ts +10 -0
- package/domain/users/models/enums/hair-strands.enum.d.ts +8 -0
- package/domain/users/models/enums/hair-types.enum.d.ts +7 -0
- package/domain/users/models/enums/index.d.ts +20 -0
- package/domain/users/models/enums/office-position.enum.d.ts +6 -0
- package/domain/users/models/enums/product-spents.enum.d.ts +8 -0
- package/domain/users/models/enums/user-type.enum.d.ts +8 -0
- package/domain/users/models/index.d.ts +7 -0
- package/domain/users/models/lead.d.ts +8 -0
- package/domain/users/models/subscription/edition.d.ts +16 -0
- package/domain/users/models/subscription/enums/billing-status.enum.d.ts +3 -0
- package/domain/users/models/subscription/enums/edition-status.enum.d.ts +4 -0
- package/domain/users/models/subscription/enums/index.d.ts +4 -0
- package/domain/users/models/subscription/enums/payment-type.enum.d.ts +5 -0
- package/domain/users/models/subscription/enums/status.enum.d.ts +4 -0
- package/domain/users/models/subscription/index.d.ts +4 -0
- package/domain/users/models/subscription/payment.d.ts +13 -0
- package/domain/users/models/subscription/subscription.d.ts +28 -0
- package/domain/users/models/user-address.d.ts +6 -0
- package/domain/users/models/user-payment-method.d.ts +14 -0
- package/domain/users/models/user.d.ts +27 -0
- package/domain/users/repositories/beauty-profile.repository.d.ts +4 -0
- package/domain/users/repositories/edition.repository.d.ts +4 -0
- package/domain/users/repositories/index.d.ts +8 -0
- package/domain/users/repositories/lead.repository.d.ts +4 -0
- package/domain/users/repositories/subscription-payment.repository.d.ts +4 -0
- package/domain/users/repositories/subscription.repository.d.ts +4 -0
- package/domain/users/repositories/user-address.repository.d.ts +4 -0
- package/domain/users/repositories/user-payment-method.repository.d.ts +4 -0
- package/domain/users/repositories/user.repository.d.ts +6 -0
- package/domain/users/services/authentication.service.d.ts +12 -0
- package/domain/users/services/index.d.ts +3 -0
- package/domain/users/services/register.service.d.ts +7 -0
- package/domain/users/services/types/basic-user-data.type.d.ts +4 -0
- package/domain/users/services/types/index.d.ts +1 -0
- package/domain/users/use-cases/authentication.d.ts +21 -0
- package/domain/users/use-cases/index.d.ts +4 -0
- package/domain/users/use-cases/recovery-password.d.ts +6 -0
- package/domain/users/use-cases/register.d.ts +13 -0
- package/domain/users/use-cases/signout.d.ts +6 -0
- package/errors/duplicated-results.error.d.ts +4 -0
- package/errors/index.d.ts +4 -0
- package/errors/invalid-argument.error.d.ts +4 -0
- package/errors/not-found.error.d.ts +4 -0
- package/errors/required-argument.error.d.ts +6 -0
- package/esm2020/domain/catalog/helpers/index.mjs +2 -0
- package/esm2020/domain/catalog/helpers/round-product-price.helper.mjs +15 -0
- package/esm2020/domain/catalog/index.mjs +4 -0
- package/esm2020/domain/catalog/models/category-base.mjs +18 -0
- package/esm2020/domain/catalog/models/category-collection-children.mjs +13 -0
- package/esm2020/domain/catalog/models/category-filter.mjs +19 -0
- package/esm2020/domain/catalog/models/category-for-product.mjs +7 -0
- package/esm2020/domain/catalog/models/category.mjs +14 -0
- package/esm2020/domain/catalog/models/enums/index.mjs +3 -0
- package/esm2020/domain/catalog/models/enums/product-genders.enum.mjs +7 -0
- package/esm2020/domain/catalog/models/enums/shops.enum.mjs +8 -0
- package/esm2020/domain/catalog/models/filter-option.mjs +7 -0
- package/esm2020/domain/catalog/models/filter.mjs +7 -0
- package/esm2020/domain/catalog/models/index.mjs +12 -0
- package/esm2020/domain/catalog/models/kit-product.mjs +18 -0
- package/esm2020/domain/catalog/models/product-base.mjs +25 -0
- package/esm2020/domain/catalog/models/product-for-category.mjs +14 -0
- package/esm2020/domain/catalog/models/product-for-kit.mjs +14 -0
- package/esm2020/domain/catalog/models/product.mjs +19 -0
- package/esm2020/domain/catalog/models/types/category-condition.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/category-metadata.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/category-product.mjs +2 -0
- package/esm2020/domain/catalog/models/types/index.mjs +12 -0
- package/esm2020/domain/catalog/models/types/product-evaluation.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/product-gender.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/product-metadata.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/product-review.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/shop-description.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/shop-price.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/stock.type.mjs +2 -0
- package/esm2020/domain/catalog/models/types/variant-grade.type.mjs +2 -0
- package/esm2020/domain/catalog/models/variant.mjs +7 -0
- package/esm2020/domain/catalog/models/wishlist.mjs +7 -0
- package/esm2020/domain/catalog/repositories/category-collection-children.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/category-filter.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/category.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/filter-option.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/filter.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/index.mjs +10 -0
- package/esm2020/domain/catalog/repositories/product.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/subscription-product.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/variant.repository.mjs +2 -0
- package/esm2020/domain/catalog/repositories/wishlist.repository.mjs +2 -0
- package/esm2020/domain/generic/index.mjs +3 -0
- package/esm2020/domain/generic/model/base.model.mjs +24 -0
- package/esm2020/domain/generic/model/identifier-fields.mjs +2 -0
- package/esm2020/domain/generic/model/index.mjs +4 -0
- package/esm2020/domain/generic/model/types/base-model-builder.type.mjs +2 -0
- package/esm2020/domain/generic/model/types/identifier-model.type.mjs +2 -0
- package/esm2020/domain/generic/model/types/index.mjs +6 -0
- package/esm2020/domain/generic/model/types/model-base-structure.type.mjs +2 -0
- package/esm2020/domain/generic/model/types/non-function-properties.type.mjs +2 -0
- package/esm2020/domain/generic/model/types/non-function-property-name.type.mjs +2 -0
- package/esm2020/domain/generic/repository/create.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/crud.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/delete.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/enums/index.mjs +3 -0
- package/esm2020/domain/generic/repository/enums/update-option-actions.enum.mjs +9 -0
- package/esm2020/domain/generic/repository/enums/where.enum.mjs +16 -0
- package/esm2020/domain/generic/repository/find.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/get.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/index.mjs +10 -0
- package/esm2020/domain/generic/repository/read.repository.mjs +2 -0
- package/esm2020/domain/generic/repository/types/index.mjs +7 -0
- package/esm2020/domain/generic/repository/types/repository-find-filters.type.mjs +2 -0
- package/esm2020/domain/generic/repository/types/repository-find-result.type.mjs +2 -0
- package/esm2020/domain/generic/repository/types/repository-limit-options.type.mjs +2 -0
- package/esm2020/domain/generic/repository/types/repository-order-by-list.type.mjs +2 -0
- package/esm2020/domain/generic/repository/types/repository-update-params.type.mjs +2 -0
- package/esm2020/domain/generic/repository/types/where-options.type.mjs +2 -0
- package/esm2020/domain/generic/repository/update.repository.mjs +2 -0
- package/esm2020/domain/index.mjs +7 -0
- package/esm2020/domain/location/index.mjs +2 -0
- package/esm2020/domain/location/models/address.mjs +7 -0
- package/esm2020/domain/location/models/index.mjs +3 -0
- package/esm2020/domain/location/models/types/index.mjs +4 -0
- package/esm2020/domain/location/models/types/location-bound.type.mjs +2 -0
- package/esm2020/domain/location/models/types/location-geometry.type.mjs +2 -0
- package/esm2020/domain/location/models/types/location-lat-lng.type.mjs +2 -0
- package/esm2020/domain/shop-settings/enums/filter-type.enum.mjs +21 -0
- package/esm2020/domain/shop-settings/enums/index.mjs +3 -0
- package/esm2020/domain/shop-settings/enums/questions-filters.enum.mjs +21 -0
- package/esm2020/domain/shop-settings/helpers/beauty-questions.helper.mjs +47 -0
- package/esm2020/domain/shop-settings/helpers/index.mjs +2 -0
- package/esm2020/domain/shop-settings/index.mjs +5 -0
- package/esm2020/domain/shop-settings/models/home.mjs +7 -0
- package/esm2020/domain/shop-settings/models/index.mjs +5 -0
- package/esm2020/domain/shop-settings/models/shop-menu.mjs +7 -0
- package/esm2020/domain/shop-settings/models/shop-settings.mjs +7 -0
- package/esm2020/domain/shop-settings/models/types/banner.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/benefit.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/home-data.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/index.mjs +11 -0
- package/esm2020/domain/shop-settings/models/types/menu-nav.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/shop-banner.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/shop-brands.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/shop-carousel.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/shop-collection.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/shop-section.type.mjs +2 -0
- package/esm2020/domain/shop-settings/models/types/sub-menu.type.mjs +2 -0
- package/esm2020/domain/shop-settings/repositories/home.repository.mjs +2 -0
- package/esm2020/domain/shop-settings/repositories/index.mjs +4 -0
- package/esm2020/domain/shop-settings/repositories/shop-menu.repository.mjs +2 -0
- package/esm2020/domain/shop-settings/repositories/shop-settings.repository.mjs +2 -0
- package/esm2020/domain/shopping/index.mjs +3 -0
- package/esm2020/domain/shopping/models/buy-2-win.mjs +14 -0
- package/esm2020/domain/shopping/models/campaign-dashboard.mjs +7 -0
- package/esm2020/domain/shopping/models/campaign-hashtag.mjs +7 -0
- package/esm2020/domain/shopping/models/checkout.mjs +37 -0
- package/esm2020/domain/shopping/models/coupons/coupon.mjs +38 -0
- package/esm2020/domain/shopping/models/coupons/enums/coupon-club-mens.enum.mjs +7 -0
- package/esm2020/domain/shopping/models/coupons/enums/coupon-subtypes.enum.mjs +6 -0
- package/esm2020/domain/shopping/models/coupons/enums/coupon-types.enum.mjs +10 -0
- package/esm2020/domain/shopping/models/coupons/enums/exclusivities.enum.mjs +10 -0
- package/esm2020/domain/shopping/models/coupons/enums/index.mjs +4 -0
- package/esm2020/domain/shopping/models/coupons/index.mjs +3 -0
- package/esm2020/domain/shopping/models/enums/checkout-types.enum.mjs +7 -0
- package/esm2020/domain/shopping/models/enums/index.mjs +3 -0
- package/esm2020/domain/shopping/models/enums/order-status.enum.mjs +12 -0
- package/esm2020/domain/shopping/models/index.mjs +13 -0
- package/esm2020/domain/shopping/models/line-item.mjs +4 -0
- package/esm2020/domain/shopping/models/order.mjs +11 -0
- package/esm2020/domain/shopping/models/payment.mjs +169 -0
- package/esm2020/domain/shopping/models/shipping-method.mjs +7 -0
- package/esm2020/domain/shopping/models/subscription/checkout.mjs +28 -0
- package/esm2020/domain/shopping/models/subscription/index.mjs +3 -0
- package/esm2020/domain/shopping/models/subscription/plan.mjs +7 -0
- package/esm2020/domain/shopping/models/types/index.mjs +8 -0
- package/esm2020/domain/shopping/models/types/payment-address.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-billing.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-card.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-customer.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-document.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-item.type.mjs +2 -0
- package/esm2020/domain/shopping/models/types/payment-shipping.type.mjs +2 -0
- package/esm2020/domain/shopping/repositories/buy-2-win.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/campaign-dashboard.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/campaign-hashtag.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/checkout.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/coupon.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/index.mjs +10 -0
- package/esm2020/domain/shopping/repositories/legacy-order.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/order.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/payment.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/subscription/checkout.repository.mjs +2 -0
- package/esm2020/domain/shopping/repositories/subscription/index.mjs +3 -0
- package/esm2020/domain/shopping/repositories/subscription/plan.repository.mjs +2 -0
- package/esm2020/domain/users/errors/index.mjs +4 -0
- package/esm2020/domain/users/errors/unauthorized.error.mjs +7 -0
- package/esm2020/domain/users/errors/user-already-registered.error.mjs +7 -0
- package/esm2020/domain/users/errors/weak-password.error.mjs +7 -0
- package/esm2020/domain/users/index.mjs +6 -0
- package/esm2020/domain/users/models/beauty-profile.mjs +12 -0
- package/esm2020/domain/users/models/enums/accessory-importances.enum.mjs +7 -0
- package/esm2020/domain/users/models/enums/area.enum.mjs +13 -0
- package/esm2020/domain/users/models/enums/beard-problems.enum.mjs +11 -0
- package/esm2020/domain/users/models/enums/beard-sizes.enum.mjs +9 -0
- package/esm2020/domain/users/models/enums/beauty-product-importances.enum.mjs +8 -0
- package/esm2020/domain/users/models/enums/body-problems.enum.mjs +13 -0
- package/esm2020/domain/users/models/enums/body-shapes.enum.mjs +9 -0
- package/esm2020/domain/users/models/enums/body-tattoos.enum.mjs +7 -0
- package/esm2020/domain/users/models/enums/face-skin-oilinesses.enum.mjs +9 -0
- package/esm2020/domain/users/models/enums/face-skin-problems.enum.mjs +12 -0
- package/esm2020/domain/users/models/enums/face-skin-tones.enum.mjs +10 -0
- package/esm2020/domain/users/models/enums/family-incomes.enum.mjs +10 -0
- package/esm2020/domain/users/models/enums/fragrance-importances.enum.mjs +7 -0
- package/esm2020/domain/users/models/enums/hair-colors.enum.mjs +12 -0
- package/esm2020/domain/users/models/enums/hair-problems.enum.mjs +12 -0
- package/esm2020/domain/users/models/enums/hair-strands.enum.mjs +10 -0
- package/esm2020/domain/users/models/enums/hair-types.enum.mjs +9 -0
- package/esm2020/domain/users/models/enums/index.mjs +21 -0
- package/esm2020/domain/users/models/enums/office-position.enum.mjs +8 -0
- package/esm2020/domain/users/models/enums/product-spents.enum.mjs +10 -0
- package/esm2020/domain/users/models/enums/user-type.enum.mjs +10 -0
- package/esm2020/domain/users/models/index.mjs +8 -0
- package/esm2020/domain/users/models/lead.mjs +7 -0
- package/esm2020/domain/users/models/subscription/edition.mjs +7 -0
- package/esm2020/domain/users/models/subscription/enums/billing-status.enum.mjs +5 -0
- package/esm2020/domain/users/models/subscription/enums/edition-status.enum.mjs +6 -0
- package/esm2020/domain/users/models/subscription/enums/index.mjs +5 -0
- package/esm2020/domain/users/models/subscription/enums/payment-type.enum.mjs +7 -0
- package/esm2020/domain/users/models/subscription/enums/status.enum.mjs +6 -0
- package/esm2020/domain/users/models/subscription/index.mjs +5 -0
- package/esm2020/domain/users/models/subscription/payment.mjs +14 -0
- package/esm2020/domain/users/models/subscription/subscription.mjs +43 -0
- package/esm2020/domain/users/models/user-address.mjs +7 -0
- package/esm2020/domain/users/models/user-payment-method.mjs +7 -0
- package/esm2020/domain/users/models/user.mjs +26 -0
- package/esm2020/domain/users/repositories/beauty-profile.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/edition.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/index.mjs +9 -0
- package/esm2020/domain/users/repositories/lead.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/subscription-payment.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/subscription.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/user-address.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/user-payment-method.repository.mjs +2 -0
- package/esm2020/domain/users/repositories/user.repository.mjs +2 -0
- package/esm2020/domain/users/services/authentication.service.mjs +2 -0
- package/esm2020/domain/users/services/index.mjs +4 -0
- package/esm2020/domain/users/services/register.service.mjs +2 -0
- package/esm2020/domain/users/services/types/basic-user-data.type.mjs +2 -0
- package/esm2020/domain/users/services/types/index.mjs +2 -0
- package/esm2020/domain/users/use-cases/authentication.mjs +43 -0
- package/esm2020/domain/users/use-cases/index.mjs +5 -0
- package/esm2020/domain/users/use-cases/recovery-password.mjs +9 -0
- package/esm2020/domain/users/use-cases/register.mjs +38 -0
- package/esm2020/domain/users/use-cases/signout.mjs +9 -0
- package/esm2020/errors/duplicated-results.error.mjs +7 -0
- package/esm2020/errors/index.mjs +5 -0
- package/esm2020/errors/invalid-argument.error.mjs +7 -0
- package/esm2020/errors/not-found.error.mjs +7 -0
- package/esm2020/errors/required-argument.error.mjs +9 -0
- package/esm2020/index.mjs +6 -0
- package/esm2020/infra/elasticsearch/adapters/axios.adapter.mjs +67 -0
- package/esm2020/infra/elasticsearch/adapters/elastic-search.adapter.mjs +2 -0
- package/esm2020/infra/elasticsearch/adapters/index.mjs +3 -0
- package/esm2020/infra/elasticsearch/index.mjs +4 -0
- package/esm2020/infra/elasticsearch/indexes/index.mjs +2 -0
- package/esm2020/infra/elasticsearch/indexes/products-index.mjs +93 -0
- package/esm2020/infra/elasticsearch/types/elastic-search-result.mjs +2 -0
- package/esm2020/infra/elasticsearch/types/index.mjs +2 -0
- package/esm2020/infra/firebase/auth/authentication-firebase-auth.service.mjs +41 -0
- package/esm2020/infra/firebase/auth/index.mjs +3 -0
- package/esm2020/infra/firebase/auth/register-firebase-auth.service.mjs +33 -0
- package/esm2020/infra/firebase/auth/types/firebase-user-with-id.type.mjs +2 -0
- package/esm2020/infra/firebase/firestore/enums/firestore-field-type.enum.mjs +10 -0
- package/esm2020/infra/firebase/firestore/enums/index.mjs +2 -0
- package/esm2020/infra/firebase/firestore/index.mjs +4 -0
- package/esm2020/infra/firebase/firestore/mixins/index.mjs +10 -0
- package/esm2020/infra/firebase/firestore/mixins/with-create-firestore.mixin.mjs +31 -0
- package/esm2020/infra/firebase/firestore/mixins/with-crud-firestore.mixin.mjs +10 -0
- package/esm2020/infra/firebase/firestore/mixins/with-delete-firestore.mixin.mjs +18 -0
- package/esm2020/infra/firebase/firestore/mixins/with-find-firestore.mixin.mjs +110 -0
- package/esm2020/infra/firebase/firestore/mixins/with-firestore.mixin.mjs +80 -0
- package/esm2020/infra/firebase/firestore/mixins/with-get-firestore.mixin.mjs +23 -0
- package/esm2020/infra/firebase/firestore/mixins/with-helpers.mixin.mjs +17 -0
- package/esm2020/infra/firebase/firestore/mixins/with-sub-collection.mixin.mjs +13 -0
- package/esm2020/infra/firebase/firestore/mixins/with-update-firestore.mixin.mjs +51 -0
- package/esm2020/infra/firebase/firestore/repositories/catalog/category-firestore.repository.mjs +67 -0
- package/esm2020/infra/firebase/firestore/repositories/catalog/index.mjs +5 -0
- package/esm2020/infra/firebase/firestore/repositories/catalog/product-firestore.repository.mjs +54 -0
- package/esm2020/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/index.mjs +5 -0
- package/esm2020/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.mjs +60 -0
- package/esm2020/infra/firebase/firestore/repositories/shop-settings/index.mjs +4 -0
- package/esm2020/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.mjs +31 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/index.mjs +11 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.mjs +11 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/order-firestore.repository.mjs +40 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/users/index.mjs +9 -0
- package/esm2020/infra/firebase/firestore/repositories/users/lead-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/repositories/users/subscription-firestore.repository.mjs +14 -0
- package/esm2020/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/repositories/users/user-address-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/repositories/users/user-firestore.repository.mjs +50 -0
- package/esm2020/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.mjs +16 -0
- package/esm2020/infra/firebase/firestore/types/firestore-interceptors.type.mjs +2 -0
- package/esm2020/infra/firebase/firestore/types/firestore-sub.repository.type.mjs +2 -0
- package/esm2020/infra/firebase/firestore/types/firestore.helpers.type.mjs +2 -0
- package/esm2020/infra/firebase/firestore/types/firestore.repository.type.mjs +2 -0
- package/esm2020/infra/firebase/firestore/types/index.mjs +5 -0
- package/esm2020/infra/firebase/index.mjs +3 -0
- package/esm2020/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.mjs +13 -0
- package/esm2020/infra/hasura-graphql/enums/hasura-graphql-where.enum.mjs +17 -0
- package/esm2020/infra/hasura-graphql/enums/index.mjs +3 -0
- package/esm2020/infra/hasura-graphql/index.mjs +5 -0
- package/esm2020/infra/hasura-graphql/mixins/helpers/attribute-option.helper.mjs +35 -0
- package/esm2020/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.mjs +71 -0
- package/esm2020/infra/hasura-graphql/mixins/helpers/filter-option.helper.mjs +22 -0
- package/esm2020/infra/hasura-graphql/mixins/helpers/graphql-field.helper.mjs +125 -0
- package/esm2020/infra/hasura-graphql/mixins/helpers/index.mjs +5 -0
- package/esm2020/infra/hasura-graphql/mixins/index.mjs +8 -0
- package/esm2020/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.mjs +39 -0
- package/esm2020/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.mjs +10 -0
- package/esm2020/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.mjs +31 -0
- package/esm2020/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.mjs +152 -0
- package/esm2020/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.mjs +37 -0
- package/esm2020/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.mjs +108 -0
- package/esm2020/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.mjs +62 -0
- package/esm2020/infra/hasura-graphql/models/category-hasura-graphql.mjs +4 -0
- package/esm2020/infra/hasura-graphql/models/index.mjs +5 -0
- package/esm2020/infra/hasura-graphql/models/kit-product-hasura-graphql.mjs +15 -0
- package/esm2020/infra/hasura-graphql/models/product-hasura-graphql.mjs +11 -0
- package/esm2020/infra/hasura-graphql/models/variant-hasura-graphql.mjs +9 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.mjs +39 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.mjs +107 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.mjs +338 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.mjs +105 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.mjs +22 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/index.mjs +9 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.mjs +516 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.mjs +114 -0
- package/esm2020/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.mjs +238 -0
- package/esm2020/infra/hasura-graphql/repositories/index.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/fields.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/graphql.repository.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/hasura-graphql-auth-options.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/hasura-graphql-fields.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/hasura-graphql-headers.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/index.mjs +9 -0
- package/esm2020/infra/hasura-graphql/types/nested-field.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/query-builder-options.type.mjs +2 -0
- package/esm2020/infra/hasura-graphql/types/variable-options.type.mjs +2 -0
- package/esm2020/infra/index.mjs +4 -0
- package/esm2020/infrab4a-connect.mjs +5 -0
- package/esm2020/utils/decorators/debug.class.decorator.mjs +7 -0
- package/esm2020/utils/decorators/index.mjs +3 -0
- package/esm2020/utils/decorators/trace.method.decorator.mjs +81 -0
- package/esm2020/utils/get.mjs +3 -0
- package/esm2020/utils/helpers/class-name.helper.mjs +15 -0
- package/esm2020/utils/helpers/debug-decorator.helper.mjs +18 -0
- package/esm2020/utils/helpers/debug.helper.mjs +150 -0
- package/esm2020/utils/helpers/index.mjs +5 -0
- package/esm2020/utils/helpers/reflect.helper.mjs +165 -0
- package/esm2020/utils/index.mjs +13 -0
- package/esm2020/utils/is-uuid.mjs +3 -0
- package/esm2020/utils/is.mjs +4 -0
- package/esm2020/utils/log.utils.mjs +9 -0
- package/esm2020/utils/mixins/base.mixin.mjs +6 -0
- package/esm2020/utils/mixins/index.mjs +4 -0
- package/esm2020/utils/mixins/merge-constructor-params.type.mjs +2 -0
- package/esm2020/utils/mixins/mixin-ctor.type.mjs +2 -0
- package/esm2020/utils/parse-datetime.mjs +14 -0
- package/esm2020/utils/types/array-element.type.mjs +2 -0
- package/esm2020/utils/types/index.mjs +3 -0
- package/esm2020/utils/types/prop.type.mjs +2 -0
- package/fesm2015/infrab4a-connect.mjs +4932 -0
- package/fesm2015/infrab4a-connect.mjs.map +1 -0
- package/fesm2020/infrab4a-connect.mjs +4846 -0
- package/fesm2020/infrab4a-connect.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/infra/elasticsearch/adapters/axios.adapter.d.ts +16 -0
- package/infra/elasticsearch/adapters/elastic-search.adapter.d.ts +8 -0
- package/infra/elasticsearch/adapters/index.d.ts +2 -0
- package/infra/elasticsearch/index.d.ts +3 -0
- package/infra/elasticsearch/indexes/index.d.ts +1 -0
- package/infra/elasticsearch/indexes/products-index.d.ts +13 -0
- package/infra/elasticsearch/types/elastic-search-result.d.ts +9 -0
- package/infra/elasticsearch/types/index.d.ts +1 -0
- package/infra/firebase/auth/authentication-firebase-auth.service.d.ts +12 -0
- package/infra/firebase/auth/index.d.ts +2 -0
- package/infra/firebase/auth/register-firebase-auth.service.d.ts +8 -0
- package/infra/firebase/auth/types/firebase-user-with-id.type.d.ts +5 -0
- package/infra/firebase/firestore/enums/firestore-field-type.enum.d.ts +8 -0
- package/infra/firebase/firestore/enums/index.d.ts +1 -0
- package/infra/firebase/firestore/index.d.ts +3 -0
- package/infra/firebase/firestore/mixins/index.d.ts +9 -0
- package/infra/firebase/firestore/mixins/with-create-firestore.mixin.d.ts +4 -0
- package/infra/firebase/firestore/mixins/with-crud-firestore.mixin.d.ts +5 -0
- package/infra/firebase/firestore/mixins/with-delete-firestore.mixin.d.ts +4 -0
- package/infra/firebase/firestore/mixins/with-find-firestore.mixin.d.ts +4 -0
- package/infra/firebase/firestore/mixins/with-firestore.mixin.d.ts +13 -0
- package/infra/firebase/firestore/mixins/with-get-firestore.mixin.d.ts +4 -0
- package/infra/firebase/firestore/mixins/with-helpers.mixin.d.ts +11 -0
- package/infra/firebase/firestore/mixins/with-sub-collection.mixin.d.ts +11 -0
- package/infra/firebase/firestore/mixins/with-update-firestore.mixin.d.ts +7 -0
- package/infra/firebase/firestore/repositories/catalog/category-firestore.repository.d.ts +20 -0
- package/infra/firebase/firestore/repositories/catalog/index.d.ts +4 -0
- package/infra/firebase/firestore/repositories/catalog/product-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/catalog/product-variant-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/catalog/subscription-product-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/index.d.ts +4 -0
- package/infra/firebase/firestore/repositories/shop-settings/home-firestore.repository.d.ts +16 -0
- package/infra/firebase/firestore/repositories/shop-settings/index.d.ts +3 -0
- package/infra/firebase/firestore/repositories/shop-settings/shop-menu-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shop-settings/shop-settings-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shopping/buy-2-win-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shopping/campaign-dashboard-firestore.repository.d.ts +8 -0
- package/infra/firebase/firestore/repositories/shopping/campaign-hashtag-firestore.repository.d.ts +8 -0
- package/infra/firebase/firestore/repositories/shopping/checkout-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shopping/checkout-subscription-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shopping/coupon-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/shopping/index.d.ts +10 -0
- package/infra/firebase/firestore/repositories/shopping/legacy-order-firestore.repository.d.ts +6 -0
- package/infra/firebase/firestore/repositories/shopping/order-firestore.repository.d.ts +13 -0
- package/infra/firebase/firestore/repositories/shopping/payment-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/shopping/subscription-plan-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/users/index.d.ts +8 -0
- package/infra/firebase/firestore/repositories/users/lead-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/users/subscription-edition-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/users/subscription-firestore.repository.d.ts +7 -0
- package/infra/firebase/firestore/repositories/users/subscription-payment-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/users/user-address-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/users/user-beauty-profile-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/repositories/users/user-firestore.repository.d.ts +17 -0
- package/infra/firebase/firestore/repositories/users/user-payment-method-firestore.repository.d.ts +12 -0
- package/infra/firebase/firestore/types/firestore-interceptors.type.d.ts +14 -0
- package/infra/firebase/firestore/types/firestore-sub.repository.type.d.ts +6 -0
- package/infra/firebase/firestore/types/firestore.helpers.type.d.ts +8 -0
- package/infra/firebase/firestore/types/firestore.repository.type.d.ts +16 -0
- package/infra/firebase/firestore/types/index.d.ts +4 -0
- package/infra/firebase/index.d.ts +2 -0
- package/infra/hasura-graphql/enums/hasura-graphql-column-type.enum.d.ts +11 -0
- package/infra/hasura-graphql/enums/hasura-graphql-where.enum.d.ts +15 -0
- package/infra/hasura-graphql/enums/index.d.ts +2 -0
- package/infra/hasura-graphql/index.d.ts +4 -0
- package/infra/hasura-graphql/mixins/helpers/attribute-option.helper.d.ts +19 -0
- package/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.d.ts +10 -0
- package/infra/hasura-graphql/mixins/helpers/filter-option.helper.d.ts +8 -0
- package/infra/hasura-graphql/mixins/helpers/graphql-field.helper.d.ts +12 -0
- package/infra/hasura-graphql/mixins/helpers/index.d.ts +4 -0
- package/infra/hasura-graphql/mixins/index.d.ts +7 -0
- package/infra/hasura-graphql/mixins/with-create-hasura-graphql.mixin.d.ts +9 -0
- package/infra/hasura-graphql/mixins/with-crud-hasura-graphql.mixin.d.ts +11 -0
- package/infra/hasura-graphql/mixins/with-delete-hasura-graphql.mixin.d.ts +7 -0
- package/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +34 -0
- package/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +25 -0
- package/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.d.ts +23 -0
- package/infra/hasura-graphql/mixins/with-update-hasura-graphql.mixin.d.ts +14 -0
- package/infra/hasura-graphql/models/category-hasura-graphql.d.ts +6 -0
- package/infra/hasura-graphql/models/index.d.ts +4 -0
- package/infra/hasura-graphql/models/kit-product-hasura-graphql.d.ts +6 -0
- package/infra/hasura-graphql/models/product-hasura-graphql.d.ts +18 -0
- package/infra/hasura-graphql/models/variant-hasura-graphql.d.ts +10 -0
- package/infra/hasura-graphql/repositories/catalog/category-collection-children-hasura-graphql.repository.d.ts +10 -0
- package/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.d.ts +12 -0
- package/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.d.ts +34 -0
- package/infra/hasura-graphql/repositories/catalog/filter-hasura-graphql.repository.d.ts +18 -0
- package/infra/hasura-graphql/repositories/catalog/filter-option-hasura-graphql.repository.d.ts +10 -0
- package/infra/hasura-graphql/repositories/catalog/index.d.ts +8 -0
- package/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.d.ts +30 -0
- package/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.d.ts +14 -0
- package/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.d.ts +27 -0
- package/infra/hasura-graphql/repositories/index.d.ts +1 -0
- package/infra/hasura-graphql/types/fields.type.d.ts +2 -0
- package/infra/hasura-graphql/types/graphql.repository.type.d.ts +24 -0
- package/infra/hasura-graphql/types/hasura-graphql-auth-options.type.d.ts +8 -0
- package/infra/hasura-graphql/types/hasura-graphql-fields.type.d.ts +44 -0
- package/infra/hasura-graphql/types/hasura-graphql-headers.type.d.ts +7 -0
- package/infra/hasura-graphql/types/index.d.ts +8 -0
- package/infra/hasura-graphql/types/nested-field.type.d.ts +7 -0
- package/infra/hasura-graphql/types/query-builder-options.type.d.ts +7 -0
- package/infra/hasura-graphql/types/variable-options.type.d.ts +9 -0
- package/infra/index.d.ts +3 -0
- package/package.json +44 -29
- package/utils/decorators/debug.class.decorator.d.ts +2 -0
- package/utils/decorators/index.d.ts +2 -0
- package/utils/decorators/trace.method.decorator.d.ts +14 -0
- package/utils/get.d.ts +1 -0
- package/utils/helpers/class-name.helper.d.ts +3 -0
- package/utils/helpers/debug-decorator.helper.d.ts +9 -0
- package/utils/helpers/debug.helper.d.ts +60 -0
- package/utils/helpers/index.d.ts +4 -0
- package/utils/helpers/reflect.helper.d.ts +50 -0
- package/utils/index.d.ts +13 -0
- package/utils/is-uuid.d.ts +1 -0
- package/utils/is.d.ts +1 -0
- package/utils/log.utils.d.ts +7 -0
- package/utils/mixins/base.mixin.d.ts +3 -0
- package/utils/mixins/index.d.ts +3 -0
- package/utils/mixins/merge-constructor-params.type.d.ts +3 -0
- package/utils/mixins/mixin-ctor.type.d.ts +1 -0
- package/utils/parse-datetime.d.ts +1 -0
- package/utils/types/array-element.type.d.ts +1 -0
- package/utils/types/index.d.ts +2 -0
- package/utils/types/prop.type.d.ts +1 -0
- package/index.js +0 -5154
|
@@ -0,0 +1,71 @@
|
|
|
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 {
|
|
12
|
+
...variables,
|
|
13
|
+
...{
|
|
14
|
+
[columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, filter[fieldName], fields),
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
const builtFilter = columnOption.bindFindFilter(filter[fieldName]);
|
|
18
|
+
return {
|
|
19
|
+
...variables,
|
|
20
|
+
...Object.keys(builtFilter).reduce((variablesList, columnName) => ({
|
|
21
|
+
...variablesList,
|
|
22
|
+
[columnName]: BindFilterQueryHelper.BuildWhereSentence(fieldName, builtFilter[columnName], fields),
|
|
23
|
+
}), {}),
|
|
24
|
+
};
|
|
25
|
+
}, {});
|
|
26
|
+
BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
|
|
27
|
+
const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute(field, fields);
|
|
28
|
+
const isNestedField = !Array.isArray(options) &&
|
|
29
|
+
isObject(options) &&
|
|
30
|
+
isNil(options?.operator) &&
|
|
31
|
+
isNil(options?.value) &&
|
|
32
|
+
isNil(fieldSentenceOptions?.to);
|
|
33
|
+
if (isNestedField)
|
|
34
|
+
return Object.keys(options).reduce((variables, key) => {
|
|
35
|
+
const fieldOptions = AttributeOptionHelper.FindByAttribute(key, fieldSentenceOptions?.fields || fields);
|
|
36
|
+
const columnName = fieldOptions.columnName;
|
|
37
|
+
const columnFields = fieldOptions.fields;
|
|
38
|
+
return {
|
|
39
|
+
...variables,
|
|
40
|
+
[columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), fieldSentenceOptions?.fields || columnFields || fields),
|
|
41
|
+
};
|
|
42
|
+
}, {});
|
|
43
|
+
if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
|
|
44
|
+
return {
|
|
45
|
+
[fieldSentenceOptions.fields[0]]: BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions),
|
|
46
|
+
};
|
|
47
|
+
if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))
|
|
48
|
+
options = Object.values(options)[0];
|
|
49
|
+
return Array.isArray(options)
|
|
50
|
+
? options.reduce((whereSentence, option) => ({
|
|
51
|
+
...whereSentence,
|
|
52
|
+
...BindFilterQueryHelper.BuildOperatorSentence(option, fieldSentenceOptions),
|
|
53
|
+
}), {})
|
|
54
|
+
: BindFilterQueryHelper.BuildOperatorSentence(options, fieldSentenceOptions);
|
|
55
|
+
};
|
|
56
|
+
BindFilterQueryHelper.BuildOperatorSentence = (options, fieldOption) => ({
|
|
57
|
+
[BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(options, fieldOption),
|
|
58
|
+
});
|
|
59
|
+
BindFilterQueryHelper.GetHasuraOperator = (options, fieldOption) => FilterOptionHelper.CheckIfIsFilterOption(options)
|
|
60
|
+
? fieldOption.type === HasuraGraphQLColumnType.Jsonb
|
|
61
|
+
? BindFilterQueryHelper.GetHasuraJsonbOperator(options)
|
|
62
|
+
: HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
|
|
63
|
+
Object.keys(Where).find((operator) => Where[operator] === options?.operator))]
|
|
64
|
+
: HasuraGraphQLWhere.EQUALS;
|
|
65
|
+
BindFilterQueryHelper.GetHasuraJsonbOperator = (options) => options.operator === Where.IN
|
|
66
|
+
? HasuraGraphQLWhere.JSON_CONTAINS
|
|
67
|
+
: options.operator === Where.LIKE
|
|
68
|
+
? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY
|
|
69
|
+
: HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
|
|
70
|
+
Object.keys(Where).find((operator) => Where[operator] === options?.operator))];
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"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?.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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLW9wdGlvbi5oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9taXhpbnMvaGVscGVycy9maWx0ZXItb3B0aW9uLmhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFELEtBQUssRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBQzdGLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUd6QyxNQUFNLE9BQU8sa0JBQWtCOztBQUN0Qix3Q0FBcUIsR0FBRyxDQUM3QixNQUFXLEVBQzBDLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUE7QUFFM0UscUNBQWtCLEdBQUcsQ0FDMUIsTUFBaUQsRUFDakQsV0FBb0MsRUFDL0IsRUFBRTtJQUNQLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxxQkFBcUIsQ0FBQyxNQUFNLENBQUM7UUFBRSxPQUFPLE1BQU0sQ0FBQTtJQUNwRSxJQUFJLE1BQU0sQ0FBQyxRQUFRLEtBQUssS0FBSyxDQUFDLE1BQU07UUFBRSxPQUFPLElBQUksQ0FBQTtJQUNqRCxJQUFJLE1BQU0sQ0FBQyxRQUFRLEtBQUssS0FBSyxDQUFDLFNBQVM7UUFBRSxPQUFPLEtBQUssQ0FBQTtJQUVyRCxNQUFNLFNBQVMsR0FBRyxXQUFXLENBQUMsRUFBRTtRQUM5QixDQUFDLENBQUMsV0FBVyxDQUFDLEVBQUU7UUFDaEIsQ0FBQyxDQUFDLENBQUMsS0FBVSxFQUFFLEVBQUUsQ0FDYixNQUFNLENBQUMsUUFBUSxLQUFLLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUM7WUFDdEYsQ0FBQyxDQUFDLElBQUksS0FBSyxHQUFHO1lBQ2QsQ0FBQyxDQUFDLEtBQUssQ0FBQTtJQUVmLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsRUFBRSxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDNUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDekQsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsS0FBWSxDQUFDLENBQUE7QUFDcEMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kZWxCYXNlU3RydWN0dXJlLCBSZXBvc2l0b3J5RmluZEZpZWx0ZXJzT3B0aW9ucywgV2hlcmUgfSBmcm9tICcuLi8uLi8uLi8uLi9kb21haW4nXHJcbmltcG9ydCB7IGlzTmlsIH0gZnJvbSAnLi4vLi4vLi4vLi4vdXRpbHMnXHJcbmltcG9ydCB7IENvbHVtbk9wdGlvbnMgfSBmcm9tICcuLi8uLi90eXBlcydcclxuXHJcbmV4cG9ydCBjbGFzcyBGaWx0ZXJPcHRpb25IZWxwZXIge1xyXG4gIHN0YXRpYyBDaGVja0lmSXNGaWx0ZXJPcHRpb24gPSA8TW9kZWwgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU+KFxyXG4gICAgZmlsdGVyOiBhbnksXHJcbiAgKTogZmlsdGVyIGlzIFJlcG9zaXRvcnlGaW5kRmllbHRlcnNPcHRpb25zPE1vZGVsLCBhbnk+ID0+ICFpc05pbChmaWx0ZXI/Lm9wZXJhdG9yKVxyXG5cclxuICBzdGF0aWMgR2V0VmFsdWVGcm9tRmlsdGVyID0gPE1vZGVsIGV4dGVuZHMgTW9kZWxCYXNlU3RydWN0dXJlPE1vZGVsPj4oXHJcbiAgICBmaWx0ZXI6IFJlcG9zaXRvcnlGaW5kRmllbHRlcnNPcHRpb25zPE1vZGVsLCBhbnk+LFxyXG4gICAgZmllbGRPcHRpb246IENvbHVtbk9wdGlvbnM8YW55LCBhbnk+LFxyXG4gICk6IGFueSA9PiB7XHJcbiAgICBpZiAoIUZpbHRlck9wdGlvbkhlbHBlci5DaGVja0lmSXNGaWx0ZXJPcHRpb24oZmlsdGVyKSkgcmV0dXJuIGZpbHRlclxyXG4gICAgaWYgKGZpbHRlci5vcGVyYXRvciA9PT0gV2hlcmUuSVNOVUxMKSByZXR1cm4gdHJ1ZVxyXG4gICAgaWYgKGZpbHRlci5vcGVyYXRvciA9PT0gV2hlcmUuSVNOT1ROVUxMKSByZXR1cm4gZmFsc2VcclxuXHJcbiAgICBjb25zdCBjb252ZXJ0ZXIgPSBmaWVsZE9wdGlvbi50b1xyXG4gICAgICA/IGZpZWxkT3B0aW9uLnRvXHJcbiAgICAgIDogKHZhbHVlOiBhbnkpID0+XHJcbiAgICAgICAgICBmaWx0ZXIub3BlcmF0b3IgPT09IFdoZXJlLkxJS0UgJiYgIUFycmF5LmlzQXJyYXkoZmlsdGVyLnZhbHVlKSAmJiB2YWx1ZS5pbmRleE9mKCclJykgPCAwXHJcbiAgICAgICAgICAgID8gYCUke3ZhbHVlfSVgXHJcbiAgICAgICAgICAgIDogdmFsdWVcclxuXHJcbiAgICByZXR1cm4gQXJyYXkuaXNBcnJheShmaWx0ZXIudmFsdWUpICYmICFmaWVsZE9wdGlvbi5maWVsZHMgJiYgW1doZXJlLklOLCBXaGVyZS5OT1RJTl0uaW5jbHVkZXMoZmlsdGVyLm9wZXJhdG9yKVxyXG4gICAgICA/IGZpbHRlci52YWx1ZS5tYXAoKGZpZWxkVmFsdWUpID0+IGNvbnZlcnRlcihmaWVsZFZhbHVlKSlcclxuICAgICAgOiBjb252ZXJ0ZXIoZmlsdGVyLnZhbHVlIGFzIGFueSlcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,125 @@
|
|
|
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
|
|
10
|
+
?.map((field) => {
|
|
11
|
+
if (isString(field))
|
|
12
|
+
return field.toString();
|
|
13
|
+
if (field === 'affected_rows')
|
|
14
|
+
return field;
|
|
15
|
+
const fieldName = Object.keys(field).shift();
|
|
16
|
+
const fieldValue = is(field[fieldName]);
|
|
17
|
+
if (Array.isArray(fieldValue))
|
|
18
|
+
return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) };
|
|
19
|
+
if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue))
|
|
20
|
+
return;
|
|
21
|
+
const isNestedField = !!fieldValue.fields;
|
|
22
|
+
if (isNestedField)
|
|
23
|
+
return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue);
|
|
24
|
+
return fieldValue.columnName;
|
|
25
|
+
})
|
|
26
|
+
.filter((field) => !!field);
|
|
27
|
+
};
|
|
28
|
+
GraphQLFieldHelper.ConvertFieldValueFrom = (data, fields) => Object.keys(data).reduce((result, columnName) => {
|
|
29
|
+
const { attributeName, fields: attributeFields, from, } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields);
|
|
30
|
+
if (!!attributeFields && Array.isArray(attributeFields)) {
|
|
31
|
+
if (Array.isArray(data[columnName]))
|
|
32
|
+
return {
|
|
33
|
+
...result,
|
|
34
|
+
[attributeName]: from
|
|
35
|
+
? from(data[columnName], data)
|
|
36
|
+
: is(data[columnName]).map((value) => GraphQLFieldHelper.ConvertFieldValueFrom(is(value), attributeFields)),
|
|
37
|
+
};
|
|
38
|
+
if (isObject(data[columnName]))
|
|
39
|
+
return {
|
|
40
|
+
...result,
|
|
41
|
+
[attributeName]: !!from
|
|
42
|
+
? from(data[columnName])
|
|
43
|
+
: GraphQLFieldHelper.ConvertFieldValueFrom(is(data[columnName]), attributeFields),
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
if (!!from)
|
|
47
|
+
return { ...result, [attributeName]: from(data[columnName], data) };
|
|
48
|
+
return {
|
|
49
|
+
...result,
|
|
50
|
+
[attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName],
|
|
51
|
+
};
|
|
52
|
+
}, {});
|
|
53
|
+
GraphQLFieldHelper.ConvertFieldValueTo = (instance, fields, update = false) => {
|
|
54
|
+
const data = instance.toPlain?.() || instance;
|
|
55
|
+
return Object.keys(data).reduce((result, attributeName) => {
|
|
56
|
+
const { columnName, fields: attributeFields, foreignKeyColumn, to, bindPersistData, } = AttributeOptionHelper.FindByAttribute(attributeName, fields);
|
|
57
|
+
if (bindPersistData)
|
|
58
|
+
return {
|
|
59
|
+
...result,
|
|
60
|
+
...bindPersistData(data[attributeName], instance),
|
|
61
|
+
};
|
|
62
|
+
if (isNil(columnName))
|
|
63
|
+
return result;
|
|
64
|
+
if (!!foreignKeyColumn &&
|
|
65
|
+
!isEmpty(foreignKeyColumn) &&
|
|
66
|
+
!Object.keys(foreignKeyColumn).filter((key) => !is(data[attributeName])?.[key]).length)
|
|
67
|
+
return Object.keys(foreignKeyColumn).reduce((object, current) => {
|
|
68
|
+
const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(foreignKeyColumn[current], fields);
|
|
69
|
+
return {
|
|
70
|
+
...object,
|
|
71
|
+
[foreignColumnName]: data[attributeName]?.[current],
|
|
72
|
+
};
|
|
73
|
+
}, { ...result });
|
|
74
|
+
if (update &&
|
|
75
|
+
isObject(data[attributeName]) &&
|
|
76
|
+
!isNil(attributeFields) &&
|
|
77
|
+
!isDate(data[attributeName]))
|
|
78
|
+
return result;
|
|
79
|
+
if (!!columnName &&
|
|
80
|
+
Array.isArray(attributeFields) &&
|
|
81
|
+
isObject(data[attributeName])) {
|
|
82
|
+
const converted = !isNil(columnName) && to
|
|
83
|
+
? to(instance[attributeName], instance)
|
|
84
|
+
: data[attributeName];
|
|
85
|
+
return {
|
|
86
|
+
...result,
|
|
87
|
+
...(converted !== undefined
|
|
88
|
+
? {
|
|
89
|
+
[columnName]: {
|
|
90
|
+
data: instance[attributeName] instanceof BaseModel
|
|
91
|
+
? GraphQLFieldHelper.ConvertFieldValueTo(data[attributeName], attributeFields)
|
|
92
|
+
: converted,
|
|
93
|
+
},
|
|
94
|
+
}
|
|
95
|
+
: {}),
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
if (!!to)
|
|
99
|
+
return {
|
|
100
|
+
...result,
|
|
101
|
+
[columnName]: to(instance[attributeName], instance),
|
|
102
|
+
};
|
|
103
|
+
return { ...result, [columnName]: data[attributeName] };
|
|
104
|
+
}, {});
|
|
105
|
+
};
|
|
106
|
+
GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields = (fieldName, fieldValue) => {
|
|
107
|
+
const hasCustomFilters = !!fieldValue.filters;
|
|
108
|
+
if (hasCustomFilters)
|
|
109
|
+
return {
|
|
110
|
+
operation: fieldValue.columnName || fieldName,
|
|
111
|
+
fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
|
|
112
|
+
variables: {
|
|
113
|
+
[`${fieldValue.columnName}_where`]: {
|
|
114
|
+
name: 'where',
|
|
115
|
+
type: fieldValue.filters.filterType,
|
|
116
|
+
value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),
|
|
117
|
+
required: true,
|
|
118
|
+
},
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
return {
|
|
122
|
+
[fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),
|
|
123
|
+
};
|
|
124
|
+
};
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graphql-field.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/graphql-field.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { IOperation } from 'gql-query-builder/build/IQueryBuilderOptions'\r\nimport {\r\n  BaseModel,\r\n  ModelBaseStructure,\r\n  NonFunctionAndIdentifierPropertiesWithNoPartial,\r\n  NonFunctionAndIdentifierPropertyNames,\r\n  PartialIdentifiersModel,\r\n} from '../../../../domain'\r\nimport { is, isDate, isEmpty, isNil, isObject, isString, parseDateTime } from '../../../../utils'\r\nimport { ColumnOptions, Fields, GraphQLParams, HasuraGraphQLFields } from '../../types'\r\nimport { AttributeOptionHelper } from './attribute-option.helper'\r\nimport { BindFilterQueryHelper } from './bind-filter-query.helper'\r\n\r\nexport class GraphQLFieldHelper {\r\n  static CheckIsGraphQLParams = <Model extends ModelBaseStructure<Model>>(\r\n    params: string | IOperation | GraphQLParams<Model>[],\r\n  ): params is GraphQLParams<Model>[] =>\r\n    !isString(params) && Array.isArray(params) && params.length >= 0 && !!params[0].operation\r\n\r\n  static ConvertModelFieldsToGraphQLFields = <Model extends ModelBaseStructure<Model>>(\r\n    fields: HasuraGraphQLFields<Model>,\r\n  ): Fields => {\r\n    return fields\r\n      ?.map((field) => {\r\n        if (isString(field)) return field.toString()\r\n        if (field === 'affected_rows') return field\r\n\r\n        const fieldName = Object.keys(field).shift()\r\n        const fieldValue = is<ColumnOptions<any, Model>>(field[fieldName as keyof typeof field])\r\n\r\n        if (Array.isArray(fieldValue))\r\n          return { [fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue) }\r\n        if (!AttributeOptionHelper.CheckIsColumnOption(fieldValue)) return\r\n\r\n        const isNestedField = !!fieldValue.fields\r\n\r\n        if (isNestedField) return GraphQLFieldHelper.ConvertNestedFieldsToGraphQLFields(fieldName, fieldValue as any)\r\n\r\n        return fieldValue.columnName\r\n      })\r\n      .filter((field) => !!field)\r\n  }\r\n\r\n  static ConvertFieldValueFrom = <\r\n    Model extends ModelBaseStructure,\r\n    RecordDataType extends string | number | DataType | Date,\r\n    DataType extends Record<string, RecordDataType | RecordDataType[]>,\r\n  >(\r\n    data: DataType,\r\n    fields: HasuraGraphQLFields<Model>,\r\n  ): NonFunctionAndIdentifierPropertiesWithNoPartial<Model> | PartialIdentifiersModel<Model> =>\r\n    Object.keys(data).reduce((result, columnName) => {\r\n      const {\r\n        attributeName,\r\n        fields: attributeFields,\r\n        from,\r\n      } = AttributeOptionHelper.FindColumnOptionFromList(columnName, fields)\r\n\r\n      if (!!attributeFields && Array.isArray(attributeFields)) {\r\n        if (Array.isArray(data[columnName]))\r\n          return {\r\n            ...result,\r\n            [attributeName]: from\r\n              ? from(data[columnName], data)\r\n              : is<RecordDataType[]>(data[columnName]).map((value) =>\r\n                  GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(value), attributeFields),\r\n                ),\r\n          }\r\n        if (isObject(data[columnName]))\r\n          return {\r\n            ...result,\r\n            [attributeName]: !!from\r\n              ? from(data[columnName])\r\n              : GraphQLFieldHelper.ConvertFieldValueFrom(is<DataType>(data[columnName]), attributeFields),\r\n          }\r\n      }\r\n\r\n      if (!!from) return { ...result, [attributeName]: from(data[columnName], data) }\r\n\r\n      return {\r\n        ...result,\r\n        [attributeName]: isString(data[columnName]) ? parseDateTime(data[columnName].toString()) : data[columnName],\r\n      }\r\n    }, {})\r\n\r\n  static ConvertFieldValueTo = <\r\n    Model extends ModelBaseStructure<Model>,\r\n    DataType extends Record<string, string | number | DataType | Date>,\r\n  >(\r\n    instance: Model,\r\n    fields: HasuraGraphQLFields<Model>,\r\n    update = false,\r\n  ): DataType => {\r\n    const data: Partial<Model> = instance.toPlain?.() || instance\r\n\r\n    return Object.keys(data).reduce((result, attributeName) => {\r\n      const {\r\n        columnName,\r\n        fields: attributeFields,\r\n        foreignKeyColumn,\r\n        to,\r\n        bindPersistData,\r\n      } = AttributeOptionHelper.FindByAttribute(attributeName as NonFunctionAndIdentifierPropertyNames<Model>, fields)\r\n\r\n      if (bindPersistData)\r\n        return {\r\n          ...result,\r\n          ...bindPersistData(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>], instance),\r\n        }\r\n      if (isNil(columnName)) return result\r\n      if (\r\n        !!foreignKeyColumn &&\r\n        !isEmpty(foreignKeyColumn) &&\r\n        !Object.keys(foreignKeyColumn).filter(\r\n          (key) =>\r\n            !is<Record<string, string>>(data[attributeName as NonFunctionAndIdentifierPropertyNames<Model>])?.[key],\r\n        ).length\r\n      )\r\n        return Object.keys(foreignKeyColumn).reduce(\r\n          (object, current) => {\r\n            const { columnName: foreignColumnName } = AttributeOptionHelper.FindByAttribute(\r\n              foreignKeyColumn[current as keyof HasuraGraphQLFields<Model>[number]],\r\n              fields,\r\n            )\r\n\r\n            return {\r\n              ...object,\r\n              [foreignColumnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]]?.[current],\r\n            }\r\n          },\r\n          { ...result },\r\n        )\r\n\r\n      if (\r\n        update &&\r\n        isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]]) &&\r\n        !isNil(attributeFields) &&\r\n        !isDate(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n      )\r\n        return result\r\n\r\n      if (\r\n        !!columnName &&\r\n        Array.isArray(attributeFields) &&\r\n        isObject(data[attributeName as keyof HasuraGraphQLFields<Model>[number]])\r\n      ) {\r\n        const converted =\r\n          !isNil(columnName) && to\r\n            ? to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance)\r\n            : data[attributeName as keyof HasuraGraphQLFields<Model>[number]]\r\n\r\n        return {\r\n          ...result,\r\n          ...(converted !== undefined\r\n            ? {\r\n                [columnName]: {\r\n                  data:\r\n                    instance[attributeName as NonFunctionAndIdentifierPropertyNames<Model>] instanceof BaseModel\r\n                      ? GraphQLFieldHelper.ConvertFieldValueTo(\r\n                          data[attributeName as keyof HasuraGraphQLFields<Model>[number]],\r\n                          attributeFields as HasuraGraphQLFields<Model>,\r\n                        )\r\n                      : converted,\r\n                },\r\n              }\r\n            : {}),\r\n        }\r\n      }\r\n\r\n      if (!!to)\r\n        return {\r\n          ...result,\r\n          [columnName]: to(instance[attributeName as keyof HasuraGraphQLFields<Model>[number]], instance),\r\n        }\r\n\r\n      return { ...result, [columnName]: data[attributeName as keyof HasuraGraphQLFields<Model>[number]] }\r\n    }, {} as DataType)\r\n  }\r\n\r\n  private static ConvertNestedFieldsToGraphQLFields = <\r\n    T extends ModelBaseStructure<T>,\r\n    P extends ModelBaseStructure<P>,\r\n  >(\r\n    fieldName: string,\r\n    fieldValue: ColumnOptions<T, P>,\r\n  ) => {\r\n    const hasCustomFilters = !!fieldValue.filters\r\n\r\n    if (hasCustomFilters)\r\n      return {\r\n        operation: fieldValue.columnName || fieldName,\r\n        fields: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n        variables: {\r\n          [`${fieldValue.columnName}_where`]: {\r\n            name: 'where',\r\n            type: fieldValue.filters.filterType,\r\n            value: BindFilterQueryHelper.MakeGraphQLWhere(fieldValue.filters.filters, fieldValue.fields),\r\n            required: true,\r\n          },\r\n        },\r\n      }\r\n\r\n    return {\r\n      [fieldValue.columnName || fieldName]: GraphQLFieldHelper.ConvertModelFieldsToGraphQLFields(fieldValue.fields),\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './attribute-option.helper';
|
|
2
|
+
export * from './bind-filter-query.helper';
|
|
3
|
+
export * from './filter-option.helper';
|
|
4
|
+
export * from './graphql-field.helper';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9taXhpbnMvaGVscGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJCQUEyQixDQUFBO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUE7QUFDMUMsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLHdCQUF3QixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hdHRyaWJ1dGUtb3B0aW9uLmhlbHBlcidcclxuZXhwb3J0ICogZnJvbSAnLi9iaW5kLWZpbHRlci1xdWVyeS5oZWxwZXInXHJcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLW9wdGlvbi5oZWxwZXInXHJcbmV4cG9ydCAqIGZyb20gJy4vZ3JhcGhxbC1maWVsZC5oZWxwZXInXHJcbiJdfQ==
|
|
@@ -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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9taXhpbnMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLG9DQUFvQyxDQUFBO0FBQ2xELGNBQWMsNkJBQTZCLENBQUE7QUFDM0MsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLGlDQUFpQyxDQUFBO0FBQy9DLGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYyxrQ0FBa0MsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vd2l0aC1jcmVhdGUtaGFzdXJhLWdyYXBocWwubWl4aW4nXHJcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1kZWxldGUtaGFzdXJhLWdyYXBocWwubWl4aW4nXHJcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1oYXN1cmEtZ3JhcGhxbC5taXhpbidcclxuZXhwb3J0ICogZnJvbSAnLi93aXRoLXVwZGF0ZS1oYXN1cmEtZ3JhcGhxbC5taXhpbidcclxuZXhwb3J0ICogZnJvbSAnLi93aXRoLWdldC1oYXN1cmEtZ3JhcGhxbC5taXhpbidcclxuZXhwb3J0ICogZnJvbSAnLi93aXRoLWZpbmQtaGFzdXJhLWdyYXBocWwubWl4aW4nXHJcbmV4cG9ydCAqIGZyb20gJy4vd2l0aC1jcnVkLWhhc3VyYS1ncmFwaHFsLm1peGluJ1xyXG4iXX0=
|
|
@@ -0,0 +1,39 @@
|
|
|
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?.[0];
|
|
7
|
+
super(...params);
|
|
8
|
+
this.insertGraphQLOperation = options?.insertGraphQLOperation || `insert_${this.tableName}_one`;
|
|
9
|
+
this.insertGraphQLObjectType = 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) => AttributeOptionHelper.FindByAttribute(foreignKeyName, this.fields)?.columnName),
|
|
24
|
+
{
|
|
25
|
+
[columnOptions.columnName]: Object.keys(columnOptions.foreignKeyColumn).map((foreignKeyField) => AttributeOptionHelper.FindByAttribute(foreignKeyField, columnOptions?.fields)
|
|
26
|
+
?.columnName || foreignKeyField),
|
|
27
|
+
},
|
|
28
|
+
]);
|
|
29
|
+
})
|
|
30
|
+
.filter(Boolean)
|
|
31
|
+
.reduce((keys, current) => [...keys, ...current], []);
|
|
32
|
+
const result = await this.mutation(this.insertGraphQLOperation, [...primaryKeyColumns, ...foreignKeyColumns], {
|
|
33
|
+
object: { type: this.insertGraphQLObjectType, required: true, value: this.convertDataToHasura(data) },
|
|
34
|
+
});
|
|
35
|
+
return { ...data.toPlain(), ...this.convertDataFromHasura(result[this.insertGraphQLOperation]).toPlain() };
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1jcmVhdGUtaGFzdXJhLWdyYXBocWwubWl4aW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9taXhpbnMvd2l0aC1jcmVhdGUtaGFzdXJhLWdyYXBocWwubWl4aW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBcUMsTUFBTSxnQkFBZ0IsQ0FBQTtBQUcvRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFRakQsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsQ0FJckMsU0FBMkQsRUFJM0QsRUFBRTtJQUNGLE9BQU8sTUFBTSx3QkFBeUIsU0FBUSxTQUFTO1FBSXJELFlBQVksR0FBRyxNQUFhO1lBQzFCLE1BQU0sT0FBTyxHQUE0QixNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQTtZQUVwRCxLQUFLLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQTtZQUVoQixJQUFJLENBQUMsc0JBQXNCLEdBQUcsT0FBTyxFQUFFLHNCQUFzQixJQUFJLFVBQVUsSUFBSSxDQUFDLFNBQVMsTUFBTSxDQUFBO1lBQy9GLElBQUksQ0FBQyx1QkFBdUIsR0FBRyxPQUFPLEVBQUUsdUJBQXVCLElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxlQUFlLENBQUE7UUFDckcsQ0FBQztRQUVELEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBbUM7WUFDOUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxRQUFRLENBQUMsQ0FBQTtZQUU5QyxNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQTtZQUU1RCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFBO1FBQ3ZDLENBQUM7UUFFRCxLQUFLLENBQUMsSUFBSSxDQUFDLElBQVc7WUFDcEIsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FDeEQsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLHFCQUFxQixDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FDbEQsQ0FBQTtZQUMvQixNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxNQUFNO2lCQUNsQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtnQkFDYixNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFBO2dCQUVsRCxPQUFPLENBQ0wscUJBQXFCLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDO29CQUN4RCxhQUFhLENBQUMsZ0JBQWdCLElBQUk7b0JBQ2hDLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxHQUFHLENBQ2xELENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FDakIscUJBQXFCLENBQUMsZUFBZSxDQUFDLGNBQXFCLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLFVBQVUsQ0FDeEY7b0JBQ0Q7d0JBQ0UsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxHQUFHLENBQ3pFLENBQUMsZUFBZSxFQUFFLEVBQUUsQ0FDbEIscUJBQXFCLENBQUMsZUFBZSxDQUFDLGVBQXNCLEVBQUUsYUFBYSxFQUFFLE1BQWEsQ0FBQzs0QkFDekYsRUFBRSxVQUFVLElBQUksZUFBZSxDQUNwQztxQkFDRjtpQkFDRixDQUNGLENBQUE7WUFDSCxDQUFDLENBQUM7aUJBQ0QsTUFBTSxDQUFDLE9BQU8sQ0FBQztpQkFDZixNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFBSSxFQUFFLEdBQUcsT0FBTyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFFdkQsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUNoQyxJQUFJLENBQUMsc0JBQXNCLEVBQzNCLENBQUMsR0FBRyxpQkFBaUIsRUFBRSxHQUFHLGlCQUFpQixDQUErQixFQUMxRTtnQkFDRSxNQUFNLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsRUFBRTthQUN0RyxDQUNGLENBQUE7WUFFRCxPQUFPLEVBQUUsR0FBRyxJQUFJLENBQUMsT0FBTyxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUMscUJBQXFCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQTtRQUM1RyxDQUFDO0tBQ0ssQ0FBQTtBQUNWLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENyZWF0ZVJlcG9zaXRvcnksIENyZWF0ZVJlcG9zaXRvcnlQYXJhbXMsIE1vZGVsQmFzZVN0cnVjdHVyZSB9IGZyb20gJy4uLy4uLy4uL2RvbWFpbidcclxuaW1wb3J0IHsgRGVidWdIZWxwZXIsIE1lcmdlQ29uc3RydWN0b3JQYXJhbXMsIE1peGluQ3RvciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzJ1xyXG5pbXBvcnQgeyBHcmFwaFFMUmVwb3NpdG9yeSwgSGFzdXJhR3JhcGhRTEZpZWxkcyB9IGZyb20gJy4uL3R5cGVzJ1xyXG5cclxuaW1wb3J0IHsgQXR0cmlidXRlT3B0aW9uSGVscGVyIH0gZnJvbSAnLi9oZWxwZXJzJ1xyXG5cclxuZXhwb3J0IHR5cGUgQ3JlYXRlQ29uc3RydWN0b3JQYXJhbXMgPSB7XHJcbiAgaW5zZXJ0R3JhcGhRTE9wZXJhdGlvbj86IHN0cmluZ1xyXG4gIGluc2VydEFsbEdyYXBoUUxPcGVyYXRpb24/OiBzdHJpbmdcclxuICBpbnNlcnRHcmFwaFFMT2JqZWN0VHlwZT86IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgY29uc3Qgd2l0aENyZWF0ZUhhc3VyYUdyYXBoUUwgPSA8XHJcbiAgTUJhc2UgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU8TUJhc2UsIE1CYXNlWydpZGVudGlmaWVyc0ZpZWxkcyddW251bWJlcl0+LFxyXG4gIFRNaXhpbkJhc2UgZXh0ZW5kcyBNaXhpbkN0b3I8R3JhcGhRTFJlcG9zaXRvcnk8TUJhc2U+PixcclxuPihcclxuICBNaXhpbkJhc2U6IE1peGluQ3RvcjxHcmFwaFFMUmVwb3NpdG9yeTxNQmFzZT4+ICYgVE1peGluQmFzZSxcclxuKTogTWl4aW5DdG9yPFxyXG4gIEdyYXBoUUxSZXBvc2l0b3J5PE1CYXNlPiAmIEluc3RhbmNlVHlwZTxUTWl4aW5CYXNlPiAmIENyZWF0ZVJlcG9zaXRvcnk8TUJhc2U+LFxyXG4gIE1lcmdlQ29uc3RydWN0b3JQYXJhbXM8W0NyZWF0ZUNvbnN0cnVjdG9yUGFyYW1zLCAuLi5hbnlbXV0sIENvbnN0cnVjdG9yUGFyYW1ldGVyczxUTWl4aW5CYXNlPj5cclxuPiA9PiB7XHJcbiAgcmV0dXJuIGNsYXNzIENyZWF0ZUhhc3VyYUdyYXBoUUxNaXhpbiBleHRlbmRzIE1peGluQmFzZSBpbXBsZW1lbnRzIENyZWF0ZVJlcG9zaXRvcnk8TUJhc2U+IHtcclxuICAgIGluc2VydEdyYXBoUUxPcGVyYXRpb246IHN0cmluZ1xyXG4gICAgaW5zZXJ0R3JhcGhRTE9iamVjdFR5cGU6IHN0cmluZ1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKC4uLnBhcmFtczogYW55W10pIHtcclxuICAgICAgY29uc3Qgb3B0aW9uczogQ3JlYXRlQ29uc3RydWN0b3JQYXJhbXMgPSBwYXJhbXM/LlswXVxyXG5cclxuICAgICAgc3VwZXIoLi4ucGFyYW1zKVxyXG5cclxuICAgICAgdGhpcy5pbnNlcnRHcmFwaFFMT3BlcmF0aW9uID0gb3B0aW9ucz8uaW5zZXJ0R3JhcGhRTE9wZXJhdGlvbiB8fCBgaW5zZXJ0XyR7dGhpcy50YWJsZU5hbWV9X29uZWBcclxuICAgICAgdGhpcy5pbnNlcnRHcmFwaFFMT2JqZWN0VHlwZSA9IG9wdGlvbnM/Lmluc2VydEdyYXBoUUxPYmplY3RUeXBlIHx8IGAke3RoaXMudGFibGVOYW1lfV9pbnNlcnRfaW5wdXRgXHJcbiAgICB9XHJcblxyXG4gICAgYXN5bmMgY3JlYXRlKGRhdGE6IENyZWF0ZVJlcG9zaXRvcnlQYXJhbXM8TUJhc2U+KTogUHJvbWlzZTxNQmFzZT4ge1xyXG4gICAgICB0aGlzLmxvZ2dlciA9IERlYnVnSGVscGVyLmZyb20odGhpcywgJ2NyZWF0ZScpXHJcblxyXG4gICAgICBjb25zdCBuZXdEYXRhID0gYXdhaXQgdGhpcy5zYXZlKHRoaXMubW9kZWwudG9JbnN0YW5jZShkYXRhKSlcclxuXHJcbiAgICAgIHJldHVybiB0aGlzLm1vZGVsLnRvSW5zdGFuY2UobmV3RGF0YSlcclxuICAgIH1cclxuXHJcbiAgICBhc3luYyBzYXZlKGRhdGE6IE1CYXNlKTogUHJvbWlzZTxQYXJ0aWFsPE1CYXNlPj4ge1xyXG4gICAgICBjb25zdCBwcmltYXJ5S2V5Q29sdW1ucyA9IHRoaXMubW9kZWwuaWRlbnRpZmllcnNGaWVsZHMubWFwKFxyXG4gICAgICAgIChmaWVsZCkgPT4gQXR0cmlidXRlT3B0aW9uSGVscGVyLkZpbmRCeUF0dHJpYnV0ZShmaWVsZCwgdGhpcy5maWVsZHMpLmNvbHVtbk5hbWUsXHJcbiAgICAgICkgYXMgSGFzdXJhR3JhcGhRTEZpZWxkczxNQmFzZT5cclxuICAgICAgY29uc3QgZm9yZWlnbktleUNvbHVtbnMgPSB0aGlzLmZpZWxkc1xyXG4gICAgICAgIC5tYXAoKGZpZWxkKSA9PiB7XHJcbiAgICAgICAgICBjb25zdCBjb2x1bW5PcHRpb25zID0gT2JqZWN0LnZhbHVlcyhmaWVsZCkuc2hpZnQoKVxyXG5cclxuICAgICAgICAgIHJldHVybiAoXHJcbiAgICAgICAgICAgIEF0dHJpYnV0ZU9wdGlvbkhlbHBlci5DaGVja0lzQ29sdW1uT3B0aW9uKGNvbHVtbk9wdGlvbnMpICYmXHJcbiAgICAgICAgICAgIGNvbHVtbk9wdGlvbnMuZm9yZWlnbktleUNvbHVtbiAmJiBbXHJcbiAgICAgICAgICAgICAgLi4uT2JqZWN0LnZhbHVlcyhjb2x1bW5PcHRpb25zLmZvcmVpZ25LZXlDb2x1bW4pLm1hcChcclxuICAgICAgICAgICAgICAgIChmb3JlaWduS2V5TmFtZSkgPT5cclxuICAgICAgICAgICAgICAgICAgQXR0cmlidXRlT3B0aW9uSGVscGVyLkZpbmRCeUF0dHJpYnV0ZShmb3JlaWduS2V5TmFtZSBhcyBhbnksIHRoaXMuZmllbGRzKT8uY29sdW1uTmFtZSxcclxuICAgICAgICAgICAgICApLFxyXG4gICAgICAgICAgICAgIHtcclxuICAgICAgICAgICAgICAgIFtjb2x1bW5PcHRpb25zLmNvbHVtbk5hbWVdOiBPYmplY3Qua2V5cyhjb2x1bW5PcHRpb25zLmZvcmVpZ25LZXlDb2x1bW4pLm1hcChcclxuICAgICAgICAgICAgICAgICAgKGZvcmVpZ25LZXlGaWVsZCkgPT5cclxuICAgICAgICAgICAgICAgICAgICBBdHRyaWJ1dGVPcHRpb25IZWxwZXIuRmluZEJ5QXR0cmlidXRlKGZvcmVpZ25LZXlGaWVsZCBhcyBhbnksIGNvbHVtbk9wdGlvbnM/LmZpZWxkcyBhcyBhbnkpXHJcbiAgICAgICAgICAgICAgICAgICAgICA/LmNvbHVtbk5hbWUgfHwgZm9yZWlnbktleUZpZWxkLFxyXG4gICAgICAgICAgICAgICAgKSxcclxuICAgICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICBdXHJcbiAgICAgICAgICApXHJcbiAgICAgICAgfSlcclxuICAgICAgICAuZmlsdGVyKEJvb2xlYW4pXHJcbiAgICAgICAgLnJlZHVjZSgoa2V5cywgY3VycmVudCkgPT4gWy4uLmtleXMsIC4uLmN1cnJlbnRdLCBbXSlcclxuXHJcbiAgICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHRoaXMubXV0YXRpb248UmVjb3JkPHN0cmluZywgUmVjb3JkPHN0cmluZywgYW55Pj4+KFxyXG4gICAgICAgIHRoaXMuaW5zZXJ0R3JhcGhRTE9wZXJhdGlvbixcclxuICAgICAgICBbLi4ucHJpbWFyeUtleUNvbHVtbnMsIC4uLmZvcmVpZ25LZXlDb2x1bW5zXSBhcyBIYXN1cmFHcmFwaFFMRmllbGRzPE1CYXNlPixcclxuICAgICAgICB7XHJcbiAgICAgICAgICBvYmplY3Q6IHsgdHlwZTogdGhpcy5pbnNlcnRHcmFwaFFMT2JqZWN0VHlwZSwgcmVxdWlyZWQ6IHRydWUsIHZhbHVlOiB0aGlzLmNvbnZlcnREYXRhVG9IYXN1cmEoZGF0YSkgfSxcclxuICAgICAgICB9LFxyXG4gICAgICApXHJcblxyXG4gICAgICByZXR1cm4geyAuLi5kYXRhLnRvUGxhaW4oKSwgLi4udGhpcy5jb252ZXJ0RGF0YUZyb21IYXN1cmEocmVzdWx0W3RoaXMuaW5zZXJ0R3JhcGhRTE9wZXJhdGlvbl0pLnRvUGxhaW4oKSB9XHJcbiAgICB9XHJcbiAgfSBhcyBhbnlcclxufVxyXG4iXX0=
|
|
@@ -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=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1jcnVkLWhhc3VyYS1ncmFwaHFsLm1peGluLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29ubmVjdC9zcmMvaW5mcmEvaGFzdXJhLWdyYXBocWwvbWl4aW5zL3dpdGgtY3J1ZC1oYXN1cmEtZ3JhcGhxbC5taXhpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxPQUFPLEVBQTJCLHVCQUF1QixFQUFFLE1BQU0sb0NBQW9DLENBQUE7QUFDckcsT0FBTyxFQUEyQix1QkFBdUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFBO0FBQ3JHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFBO0FBQ3hFLE9BQU8sRUFBd0Isb0JBQW9CLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQTtBQUU1RixPQUFPLEVBR0wsdUJBQXVCLEdBQ3hCLE1BQU0sb0NBQW9DLENBQUE7QUFFM0MsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsQ0FLbkMsU0FBMkQsRUFjM0QsRUFBRTtJQUNGLE9BQU8sTUFBTSxzQkFDWCxTQUFRLHVCQUF1QixDQUM3QixvQkFBb0IsQ0FDbEIscUJBQXFCLENBQ25CLHVCQUF1QixDQUFDLHVCQUF1QixDQUFDLFNBQWdELENBQUMsQ0FBQyxDQUNuRyxDQUNGLENBQ0Y7S0FDeUMsQ0FBQTtBQUM5QyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDcnVkUmVwb3NpdG9yeSwgTW9kZWxCYXNlU3RydWN0dXJlIH0gZnJvbSAnLi4vLi4vLi4vZG9tYWluJ1xyXG5pbXBvcnQgeyBNZXJnZUNvbnN0cnVjdG9yUGFyYW1zLCBNaXhpbkN0b3IgfSBmcm9tICcuLi8uLi8uLi91dGlscydcclxuaW1wb3J0IHsgR3JhcGhRTFJlcG9zaXRvcnkgfSBmcm9tICcuLi90eXBlcydcclxuXHJcbmltcG9ydCB7IENyZWF0ZUNvbnN0cnVjdG9yUGFyYW1zLCB3aXRoQ3JlYXRlSGFzdXJhR3JhcGhRTCB9IGZyb20gJy4vd2l0aC1jcmVhdGUtaGFzdXJhLWdyYXBocWwubWl4aW4nXHJcbmltcG9ydCB7IERlbGV0ZUNvbnN0cnVjdG9yUGFyYW1zLCB3aXRoRGVsZXRlSGFzdXJhR3JhcGhRTCB9IGZyb20gJy4vd2l0aC1kZWxldGUtaGFzdXJhLWdyYXBocWwubWl4aW4nXHJcbmltcG9ydCB7IHdpdGhGaW5kSGFzdXJhR3JhcGhRTCB9IGZyb20gJy4vd2l0aC1maW5kLWhhc3VyYS1ncmFwaHFsLm1peGluJ1xyXG5pbXBvcnQgeyBHZXRDb25zdHJ1Y3RvclBhcmFtcywgd2l0aEdldEhhc3VyYUdyYXBoUUwgfSBmcm9tICcuL3dpdGgtZ2V0LWhhc3VyYS1ncmFwaHFsLm1peGluJ1xyXG5pbXBvcnQgeyBIYXN1cmFDb25zdHJ1Y3RvclBhcmFtcyB9IGZyb20gJy4vd2l0aC1oYXN1cmEtZ3JhcGhxbC5taXhpbidcclxuaW1wb3J0IHtcclxuICBVcGRhdGVDb25zdHJ1Y3RvclBhcmFtcyxcclxuICBVcGRhdGVIYXN1cmFHcmFwaFFMUmVwb3NpdG9yeVR5cGUsXHJcbiAgd2l0aFVwZGF0ZUhhc3VyYUdyYXBoUUwsXHJcbn0gZnJvbSAnLi93aXRoLXVwZGF0ZS1oYXN1cmEtZ3JhcGhxbC5taXhpbidcclxuXHJcbmV4cG9ydCBjb25zdCB3aXRoQ3J1ZEhhc3VyYUdyYXBoUUwgPSA8XHJcbiAgVEJhc2UgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU8VEJhc2UsIFRCYXNlWydpZGVudGlmaWVyc0ZpZWxkcyddW251bWJlcl0+LFxyXG4gIFJlcG9zaXRvcnkgPSBDcnVkUmVwb3NpdG9yeTxUQmFzZT4sXHJcbiAgVE1peGluQmFzZSBleHRlbmRzIE1peGluQ3RvciA9IE1peGluQ3RvcixcclxuPihcclxuICBNaXhpbkJhc2U6IE1peGluQ3RvcjxHcmFwaFFMUmVwb3NpdG9yeTxUQmFzZT4+ICYgVE1peGluQmFzZSxcclxuKTogTWl4aW5DdG9yPFxyXG4gIEdyYXBoUUxSZXBvc2l0b3J5PFRCYXNlPiAmIFJlcG9zaXRvcnkgJiBVcGRhdGVIYXN1cmFHcmFwaFFMUmVwb3NpdG9yeVR5cGU8VEJhc2U+LFxyXG4gIE1lcmdlQ29uc3RydWN0b3JQYXJhbXM8XHJcbiAgICBbXHJcbiAgICAgIEhhc3VyYUNvbnN0cnVjdG9yUGFyYW1zPFRCYXNlPiAmXHJcbiAgICAgICAgQ3JlYXRlQ29uc3RydWN0b3JQYXJhbXMgJlxyXG4gICAgICAgIERlbGV0ZUNvbnN0cnVjdG9yUGFyYW1zICZcclxuICAgICAgICBHZXRDb25zdHJ1Y3RvclBhcmFtcyAmXHJcbiAgICAgICAgVXBkYXRlQ29uc3RydWN0b3JQYXJhbXMsXHJcbiAgICAgIC4uLmFueVtdLFxyXG4gICAgXSxcclxuICAgIENvbnN0cnVjdG9yUGFyYW1ldGVyczxUTWl4aW5CYXNlPlxyXG4gID5cclxuPiA9PiB7XHJcbiAgcmV0dXJuIGNsYXNzIENydWRIYXN1cmFHcmFwaFFMTWl4aW5cclxuICAgIGV4dGVuZHMgd2l0aFVwZGF0ZUhhc3VyYUdyYXBoUUwoXHJcbiAgICAgIHdpdGhHZXRIYXN1cmFHcmFwaFFMKFxyXG4gICAgICAgIHdpdGhGaW5kSGFzdXJhR3JhcGhRTChcclxuICAgICAgICAgIHdpdGhEZWxldGVIYXN1cmFHcmFwaFFMKHdpdGhDcmVhdGVIYXN1cmFHcmFwaFFMKE1peGluQmFzZSBhcyBNaXhpbkN0b3I8R3JhcGhRTFJlcG9zaXRvcnk8VEJhc2U+PikpLFxyXG4gICAgICAgICksXHJcbiAgICAgICksXHJcbiAgICApXHJcbiAgICBpbXBsZW1lbnRzIENydWRSZXBvc2l0b3J5PFRCYXNlPiB7fSBhcyBhbnlcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,31 @@
|
|
|
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?.[0];
|
|
7
|
+
super(...params);
|
|
8
|
+
this.deleteGraphQLOperation = 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 {
|
|
20
|
+
...ids,
|
|
21
|
+
[columnOption.columnName]: {
|
|
22
|
+
type: this.getAttributeGraphQLTypeOf(columnOption.type || value),
|
|
23
|
+
value,
|
|
24
|
+
required: true,
|
|
25
|
+
},
|
|
26
|
+
};
|
|
27
|
+
}, {}));
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1kZWxldGUtaGFzdXJhLWdyYXBocWwubWl4aW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9taXhpbnMvd2l0aC1kZWxldGUtaGFzdXJhLWdyYXBocWwubWl4aW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQXFDLE1BQU0sZ0JBQWdCLENBQUE7QUFHdEYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sV0FBVyxDQUFBO0FBTWpELE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLENBSXJDLFNBQTJELEVBSTNELEVBQUU7SUFDRixPQUFPLE1BQU0sd0JBQXlCLFNBQVEsU0FBUztRQUdyRCxZQUFZLEdBQUcsTUFBYTtZQUMxQixNQUFNLE9BQU8sR0FBNEIsTUFBTSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUE7WUFFcEQsS0FBSyxDQUFDLEdBQUcsTUFBTSxDQUFDLENBQUE7WUFFaEIsSUFBSSxDQUFDLHNCQUFzQixHQUFHLE9BQU8sRUFBRSxzQkFBc0IsSUFBSSxVQUFVLElBQUksQ0FBQyxTQUFTLFFBQVEsQ0FBQTtRQUNuRyxDQUFDO1FBRUQsS0FBSyxDQUFDLE1BQU0sQ0FBQyxXQUEwQztZQUNyRCxJQUFJLENBQUMsTUFBTSxHQUFHLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFBO1lBRTlDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFBO1lBRW5ELE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FDakIsSUFBSSxDQUFDLHNCQUFzQixFQUMzQixJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsQ0FDOUIsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLHFCQUFxQixDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFVBQVUsQ0FDbEQsRUFDL0IsSUFBSSxDQUFDLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsVUFBVSxFQUFFLEVBQUU7Z0JBQ3RELE1BQU0sZ0JBQWdCLEdBR2xCLFVBQVUsQ0FBQTtnQkFFZCxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLENBQUM7b0JBQUUsT0FBTyxHQUFHLENBQUE7Z0JBRTVELE1BQU0sWUFBWSxHQUFHLHFCQUFxQixDQUFDLGVBQWUsQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFBO2dCQUNuRixNQUFNLEtBQUssR0FBRyxZQUFZLENBQUMsRUFBRSxDQUFDLFdBQVcsQ0FBQyxVQUFpRCxDQUFDLEVBQUUsUUFBUSxDQUFDLENBQUE7Z0JBRXZHLE9BQU87b0JBQ0wsR0FBRyxHQUFHO29CQUNOLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxFQUFFO3dCQUN6QixJQUFJLEVBQUUsSUFBSSxDQUFDLHlCQUF5QixDQUFDLFlBQVksQ0FBQyxJQUFJLElBQUksS0FBSyxDQUFDO3dCQUNoRSxLQUFLO3dCQUNMLFFBQVEsRUFBRSxJQUFJO3FCQUNmO2lCQUNGLENBQUE7WUFDSCxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQ1AsQ0FBQTtRQUNILENBQUM7S0FDSyxDQUFBO0FBQ1YsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBEZWxldGVSZXBvc2l0b3J5LFxyXG4gIERlbGV0ZVJlcG9zaXRvcnlQYXJhbXMsXHJcbiAgTW9kZWxCYXNlU3RydWN0dXJlLFxyXG4gIE5vbkZ1bmN0aW9uQW5kSWRlbnRpZmllclByb3BlcnR5TmFtZXMsXHJcbn0gZnJvbSAnLi4vLi4vLi4vZG9tYWluJ1xyXG5pbXBvcnQgeyBEZWJ1Z0hlbHBlciwgaXNOaWwsIE1lcmdlQ29uc3RydWN0b3JQYXJhbXMsIE1peGluQ3RvciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzJ1xyXG5pbXBvcnQgeyBHcmFwaFFMUmVwb3NpdG9yeSwgSGFzdXJhR3JhcGhRTEZpZWxkcyB9IGZyb20gJy4uL3R5cGVzJ1xyXG5cclxuaW1wb3J0IHsgQXR0cmlidXRlT3B0aW9uSGVscGVyIH0gZnJvbSAnLi9oZWxwZXJzJ1xyXG5cclxuZXhwb3J0IHR5cGUgRGVsZXRlQ29uc3RydWN0b3JQYXJhbXMgPSB7XHJcbiAgZGVsZXRlR3JhcGhRTE9wZXJhdGlvbj86IHN0cmluZ1xyXG59XHJcblxyXG5leHBvcnQgY29uc3Qgd2l0aERlbGV0ZUhhc3VyYUdyYXBoUUwgPSA8XHJcbiAgTUJhc2UgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU8TUJhc2UsIE1CYXNlWydpZGVudGlmaWVyc0ZpZWxkcyddW251bWJlcl0+LFxyXG4gIFRNaXhpbkJhc2UgZXh0ZW5kcyBNaXhpbkN0b3I8R3JhcGhRTFJlcG9zaXRvcnk8TUJhc2U+PixcclxuPihcclxuICBNaXhpbkJhc2U6IE1peGluQ3RvcjxHcmFwaFFMUmVwb3NpdG9yeTxNQmFzZT4+ICYgVE1peGluQmFzZSxcclxuKTogTWl4aW5DdG9yPFxyXG4gIEdyYXBoUUxSZXBvc2l0b3J5PE1CYXNlPiAmIERlbGV0ZVJlcG9zaXRvcnk8TUJhc2U+ICYgSW5zdGFuY2VUeXBlPFRNaXhpbkJhc2U+LFxyXG4gIE1lcmdlQ29uc3RydWN0b3JQYXJhbXM8W0RlbGV0ZUNvbnN0cnVjdG9yUGFyYW1zLCAuLi5hbnlbXV0sIENvbnN0cnVjdG9yUGFyYW1ldGVyczxUTWl4aW5CYXNlPj5cclxuPiA9PiB7XHJcbiAgcmV0dXJuIGNsYXNzIERlbGV0ZUhhc3VyYUdyYXBoUUxNaXhpbiBleHRlbmRzIE1peGluQmFzZSBpbXBsZW1lbnRzIERlbGV0ZVJlcG9zaXRvcnk8TUJhc2U+IHtcclxuICAgIGRlbGV0ZUdyYXBoUUxPcGVyYXRpb246IHN0cmluZ1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKC4uLnBhcmFtczogYW55W10pIHtcclxuICAgICAgY29uc3Qgb3B0aW9uczogRGVsZXRlQ29uc3RydWN0b3JQYXJhbXMgPSBwYXJhbXM/LlswXVxyXG5cclxuICAgICAgc3VwZXIoLi4ucGFyYW1zKVxyXG5cclxuICAgICAgdGhpcy5kZWxldGVHcmFwaFFMT3BlcmF0aW9uID0gb3B0aW9ucz8uZGVsZXRlR3JhcGhRTE9wZXJhdGlvbiB8fCBgZGVsZXRlXyR7dGhpcy50YWJsZU5hbWV9X2J5X3BrYFxyXG4gICAgfVxyXG5cclxuICAgIGFzeW5jIGRlbGV0ZShpZGVudGlmaWVyczogRGVsZXRlUmVwb3NpdG9yeVBhcmFtczxNQmFzZT4pOiBQcm9taXNlPHZvaWQ+IHtcclxuICAgICAgdGhpcy5sb2dnZXIgPSBEZWJ1Z0hlbHBlci5mcm9tKHRoaXMsICdkZWxldGUnKVxyXG5cclxuICAgICAgY29uc3QgaW5zdGFuY2UgPSB0aGlzLm1vZGVsLnRvSW5zdGFuY2UoaWRlbnRpZmllcnMpXHJcblxyXG4gICAgICBhd2FpdCB0aGlzLm11dGF0aW9uKFxyXG4gICAgICAgIHRoaXMuZGVsZXRlR3JhcGhRTE9wZXJhdGlvbixcclxuICAgICAgICB0aGlzLm1vZGVsLmlkZW50aWZpZXJzRmllbGRzLm1hcChcclxuICAgICAgICAgIChmaWVsZCkgPT4gQXR0cmlidXRlT3B0aW9uSGVscGVyLkZpbmRCeUF0dHJpYnV0ZShmaWVsZCwgdGhpcy5maWVsZHMpLmNvbHVtbk5hbWUsXHJcbiAgICAgICAgKSBhcyBIYXN1cmFHcmFwaFFMRmllbGRzPE1CYXNlPixcclxuICAgICAgICB0aGlzLm1vZGVsLmlkZW50aWZpZXJzRmllbGRzLnJlZHVjZSgoaWRzLCBpZGVudGlmaWVyKSA9PiB7XHJcbiAgICAgICAgICBjb25zdCBpZGVudGlmaWVyQmluZGVkOiBFeHRyYWN0PFxyXG4gICAgICAgICAgICBOb25GdW5jdGlvbkFuZElkZW50aWZpZXJQcm9wZXJ0eU5hbWVzPE1CYXNlPixcclxuICAgICAgICAgICAgTUJhc2VbJ2lkZW50aWZpZXJzRmllbGRzJ11bbnVtYmVyXVxyXG4gICAgICAgICAgPiA9IGlkZW50aWZpZXJcclxuXHJcbiAgICAgICAgICBpZiAoaXNOaWwoaW5zdGFuY2UuaWRlbnRpZmllcltpZGVudGlmaWVyQmluZGVkXSkpIHJldHVybiBpZHNcclxuXHJcbiAgICAgICAgICBjb25zdCBjb2x1bW5PcHRpb24gPSBBdHRyaWJ1dGVPcHRpb25IZWxwZXIuRmluZEJ5QXR0cmlidXRlKGlkZW50aWZpZXIsIHRoaXMuZmllbGRzKVxyXG4gICAgICAgICAgY29uc3QgdmFsdWUgPSBjb2x1bW5PcHRpb24udG8oaWRlbnRpZmllcnNbaWRlbnRpZmllciBhcyBrZXlvZiBEZWxldGVSZXBvc2l0b3J5UGFyYW1zPE1CYXNlPl0sIGluc3RhbmNlKVxyXG5cclxuICAgICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgIC4uLmlkcyxcclxuICAgICAgICAgICAgW2NvbHVtbk9wdGlvbi5jb2x1bW5OYW1lXToge1xyXG4gICAgICAgICAgICAgIHR5cGU6IHRoaXMuZ2V0QXR0cmlidXRlR3JhcGhRTFR5cGVPZihjb2x1bW5PcHRpb24udHlwZSB8fCB2YWx1ZSksXHJcbiAgICAgICAgICAgICAgdmFsdWUsXHJcbiAgICAgICAgICAgICAgcmVxdWlyZWQ6IHRydWUsXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSwge30pLFxyXG4gICAgICApXHJcbiAgICB9XHJcbiAgfSBhcyBhbnlcclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,152 @@
|
|
|
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
|
+
...(aggregates?.minimal?.length
|
|
18
|
+
? [
|
|
19
|
+
{
|
|
20
|
+
min: this.bindAttributesToColumns(aggregates?.minimal, fields),
|
|
21
|
+
},
|
|
22
|
+
]
|
|
23
|
+
: []),
|
|
24
|
+
...(aggregates?.maximum?.length
|
|
25
|
+
? [
|
|
26
|
+
{
|
|
27
|
+
max: this.bindAttributesToColumns(aggregates?.maximum, fields),
|
|
28
|
+
},
|
|
29
|
+
]
|
|
30
|
+
: []),
|
|
31
|
+
];
|
|
32
|
+
this.bindDistinctAttributes = (distinct, fields) => this.bindAttributesToColumns(distinct, fields);
|
|
33
|
+
this.bindAttributesToColumns = (attributes, fields) => attributes.map((attr) => AttributeOptionHelper.FindByAttribute(attr.toString().split('.').pop(), fields)?.columnName || attr);
|
|
34
|
+
}
|
|
35
|
+
async find(params) {
|
|
36
|
+
this.logger = DebugHelper.from(this, 'find');
|
|
37
|
+
const { filters, limits, orderBy, options } = params || {};
|
|
38
|
+
const enableCount = options?.enableCount ?? true;
|
|
39
|
+
const variablesFilters = isNil(filters)
|
|
40
|
+
? {}
|
|
41
|
+
: {
|
|
42
|
+
where: {
|
|
43
|
+
value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),
|
|
44
|
+
type: `${this.tableName}_bool_exp`,
|
|
45
|
+
required: true,
|
|
46
|
+
},
|
|
47
|
+
};
|
|
48
|
+
const variablesCount = {
|
|
49
|
+
...(isNil(orderBy)
|
|
50
|
+
? {}
|
|
51
|
+
: {
|
|
52
|
+
order_by: {
|
|
53
|
+
type: `${this.tableName}_order_by!`,
|
|
54
|
+
list: true,
|
|
55
|
+
value: this.bindOrderByAttributes(orderBy, this.fields),
|
|
56
|
+
},
|
|
57
|
+
}),
|
|
58
|
+
...variablesFilters,
|
|
59
|
+
};
|
|
60
|
+
const variables = {
|
|
61
|
+
...(isNil(limits) ? {} : limits),
|
|
62
|
+
...variablesCount,
|
|
63
|
+
};
|
|
64
|
+
const aggregateFields = [
|
|
65
|
+
...(enableCount ? ['count'] : []),
|
|
66
|
+
...this.bindAggretageAttributes(params.options, this.fields),
|
|
67
|
+
];
|
|
68
|
+
const result = await this.query([
|
|
69
|
+
{
|
|
70
|
+
operation: this.tableName,
|
|
71
|
+
fields: params.fields
|
|
72
|
+
? params.fields
|
|
73
|
+
.map((fieldName) => this.fields.find((fieldOption) => fieldOption === fieldName) ??
|
|
74
|
+
this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName))
|
|
75
|
+
.filter(Boolean)
|
|
76
|
+
: this.fields,
|
|
77
|
+
variables,
|
|
78
|
+
},
|
|
79
|
+
...(aggregateFields.length > 0
|
|
80
|
+
? [
|
|
81
|
+
{
|
|
82
|
+
operation: `${this.tableName}_aggregate`,
|
|
83
|
+
fields: [
|
|
84
|
+
{
|
|
85
|
+
aggregate: aggregateFields,
|
|
86
|
+
},
|
|
87
|
+
],
|
|
88
|
+
variables: variablesCount,
|
|
89
|
+
},
|
|
90
|
+
]
|
|
91
|
+
: []),
|
|
92
|
+
...((!params.limits?.offset &&
|
|
93
|
+
params.options?.distinct?.map((distinct) => {
|
|
94
|
+
const distinctOption = this.fields.find((fieldOption) => fieldOption === distinct) ??
|
|
95
|
+
this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct);
|
|
96
|
+
const fieldName = Object.values(distinctOption).shift()?.columnName || distinct;
|
|
97
|
+
return {
|
|
98
|
+
operation: {
|
|
99
|
+
name: `${this.tableName}`,
|
|
100
|
+
alias: `${this.tableName}_${distinct.toString()}_distinct`,
|
|
101
|
+
},
|
|
102
|
+
fields: [distinctOption],
|
|
103
|
+
variables: {
|
|
104
|
+
...variablesFilters,
|
|
105
|
+
[`${this.tableName}_${fieldName}_distinct`]: {
|
|
106
|
+
type: `${this.tableName}_select_column!`,
|
|
107
|
+
list: true,
|
|
108
|
+
value: fieldName,
|
|
109
|
+
name: 'distinct_on',
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
};
|
|
113
|
+
})) ||
|
|
114
|
+
[]),
|
|
115
|
+
]);
|
|
116
|
+
const data = result[this.tableName].map((row) => this.convertDataFromHasura(row));
|
|
117
|
+
return {
|
|
118
|
+
data,
|
|
119
|
+
count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity,
|
|
120
|
+
...(options?.minimal?.length
|
|
121
|
+
? {
|
|
122
|
+
minimal: options.minimal.reduce((minimals, current) => ({
|
|
123
|
+
...minimals,
|
|
124
|
+
...set(minimals, current, result[`${this.tableName}_aggregate`].aggregate.min[AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)?.columnName || current]),
|
|
125
|
+
}), {}),
|
|
126
|
+
}
|
|
127
|
+
: {}),
|
|
128
|
+
...(options?.maximum?.length
|
|
129
|
+
? {
|
|
130
|
+
maximum: options.maximum.reduce((maximums, current) => ({
|
|
131
|
+
...maximums,
|
|
132
|
+
...set(maximums, current, result[`${this.tableName}_aggregate`].aggregate.max[AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)?.columnName || current]),
|
|
133
|
+
}), {}),
|
|
134
|
+
}
|
|
135
|
+
: {}),
|
|
136
|
+
...(!params.limits?.offset &&
|
|
137
|
+
options?.distinct?.length && {
|
|
138
|
+
distinct: options?.distinct.reduce((distinct, current) => {
|
|
139
|
+
const distinctOption = this.fields.find((fieldOption) => fieldOption === current) ??
|
|
140
|
+
this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current);
|
|
141
|
+
const fieldName = Object.values(distinctOption).shift()?.columnName || current;
|
|
142
|
+
return {
|
|
143
|
+
...distinct,
|
|
144
|
+
[current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map((obj) => obj[fieldName]),
|
|
145
|
+
};
|
|
146
|
+
}, {}),
|
|
147
|
+
}),
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
};
|
|
151
|
+
};
|
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-find-hasura-graphql.mixin.js","sourceRoot":"","sources":["../../../../../../projects/connect/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  FindRepository,\r\n  FindRepositoryParams,\r\n  ModelBaseStructure,\r\n  NonFunctionAndIdentifierPropertyNames,\r\n  RepositoryFindResult,\r\n  RepositoryOrderBy,\r\n} from '../../../domain'\r\nimport { DebugHelper, isNil, MixinCtor, set } from '../../../utils'\r\nimport { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types'\r\nimport { AttributeOptionHelper, BindFilterQueryHelper } from './helpers'\r\n\r\nexport const withFindHasuraGraphQL = <\r\n  MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\r\n  TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\r\n>(\r\n  MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\r\n) => {\r\n  return class FindHasuraGraphQLMixin extends MixinBase implements FindRepository<MBase> {\r\n    async find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>> {\r\n      this.logger = DebugHelper.from(this, 'find')\r\n\r\n      const { filters, limits, orderBy, options } = params || {}\r\n      const enableCount = options?.enableCount ?? true\r\n      const variablesFilters = isNil(filters)\r\n        ? {}\r\n        : {\r\n            where: {\r\n              value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),\r\n              type: `${this.tableName}_bool_exp`,\r\n              required: true,\r\n            },\r\n          }\r\n      const variablesCount = {\r\n        ...(isNil(orderBy)\r\n          ? {}\r\n          : {\r\n              order_by: {\r\n                type: `${this.tableName}_order_by!`,\r\n                list: true,\r\n                value: this.bindOrderByAttributes(orderBy, this.fields),\r\n              },\r\n            }),\r\n        ...variablesFilters,\r\n      }\r\n      const variables = {\r\n        ...(isNil(limits) ? {} : limits),\r\n        ...variablesCount,\r\n      }\r\n      const aggregateFields = [\r\n        ...(enableCount ? ['count'] : []),\r\n        ...this.bindAggretageAttributes(params.options, this.fields),\r\n      ]\r\n      const result = await this.query([\r\n        {\r\n          operation: this.tableName,\r\n          fields: params.fields\r\n            ? params.fields\r\n                .map(\r\n                  (fieldName) =>\r\n                    this.fields.find((fieldOption) => fieldOption === fieldName) ??\r\n                    this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName),\r\n                )\r\n                .filter(Boolean)\r\n            : this.fields,\r\n          variables,\r\n        },\r\n        ...(aggregateFields.length > 0\r\n          ? [\r\n              {\r\n                operation: `${this.tableName}_aggregate`,\r\n                fields: [\r\n                  {\r\n                    aggregate: aggregateFields,\r\n                  },\r\n                ],\r\n                variables: variablesCount,\r\n              } as GraphQLParams<MBase>,\r\n            ]\r\n          : []),\r\n        ...((!params.limits?.offset &&\r\n          params.options?.distinct?.map((distinct) => {\r\n            const distinctOption =\r\n              this.fields.find((fieldOption) => fieldOption === distinct) ??\r\n              this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct)\r\n            const fieldName = Object.values(distinctOption).shift()?.columnName || distinct\r\n\r\n            return {\r\n              operation: {\r\n                name: `${this.tableName}`,\r\n                alias: `${this.tableName}_${distinct.toString()}_distinct`,\r\n              },\r\n              fields: [distinctOption],\r\n              variables: {\r\n                ...variablesFilters,\r\n                [`${this.tableName}_${fieldName}_distinct`]: {\r\n                  type: `${this.tableName}_select_column!`,\r\n                  list: true,\r\n                  value: fieldName,\r\n                  name: 'distinct_on',\r\n                },\r\n              },\r\n            } as GraphQLParams<MBase>\r\n          })) ||\r\n          []),\r\n      ])\r\n      const data: MBase[] = result[this.tableName].map((row: Record<string, string | number>) =>\r\n        this.convertDataFromHasura(row),\r\n      )\r\n\r\n      return {\r\n        data,\r\n        count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity,\r\n        ...(options?.minimal?.length\r\n          ? {\r\n              minimal: options.minimal.reduce(\r\n                (minimals, current) => ({\r\n                  ...(minimals as any),\r\n                  ...set(\r\n                    minimals as any,\r\n                    current as any,\r\n                    result[`${this.tableName}_aggregate`].aggregate.min[\r\n                      AttributeOptionHelper.FindByAttribute(\r\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n                        this.fields,\r\n                      )?.columnName || (current as any)\r\n                    ],\r\n                  ),\r\n                }),\r\n                {},\r\n              ) as RepositoryFindResult<MBase>['minimal'],\r\n            }\r\n          : {}),\r\n        ...(options?.maximum?.length\r\n          ? {\r\n              maximum: options.maximum.reduce(\r\n                (maximums, current) => ({\r\n                  ...(maximums as any),\r\n                  ...set(\r\n                    maximums as any,\r\n                    current as any,\r\n                    result[`${this.tableName}_aggregate`].aggregate.max[\r\n                      AttributeOptionHelper.FindByAttribute(\r\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n                        this.fields,\r\n                      )?.columnName || (current as any)\r\n                    ],\r\n                  ),\r\n                }),\r\n                {},\r\n              ) as RepositoryFindResult<MBase>['maximum'],\r\n            }\r\n          : {}),\r\n        ...(!params.limits?.offset &&\r\n          options?.distinct?.length && {\r\n            distinct: options?.distinct.reduce((distinct, current) => {\r\n              const distinctOption =\r\n                this.fields.find((fieldOption) => fieldOption === current) ??\r\n                this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current)\r\n              const fieldName = Object.values(distinctOption).shift()?.columnName || current\r\n\r\n              return {\r\n                ...distinct,\r\n                [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map(\r\n                  (obj: Record<string, string | number>) => obj[fieldName],\r\n                ),\r\n              }\r\n            }, {} as any),\r\n          }),\r\n      }\r\n    }\r\n\r\n    bindOrderByAttributes = (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) =>\r\n      Object.keys(orderBy).reduce(\r\n        (acc, current) => [\r\n          ...acc,\r\n          {\r\n            [AttributeOptionHelper.FindByAttribute(current as NonFunctionAndIdentifierPropertyNames<MBase>, fields)\r\n              .columnName]:\r\n              orderBy[current as NonFunctionAndIdentifierPropertyNames<MBase>] === 'asc'\r\n                ? 'asc_nulls_last'\r\n                : 'desc_nulls_last',\r\n          },\r\n        ],\r\n        [],\r\n      )\r\n\r\n    bindAggretageAttributes = (\r\n      aggregates: {\r\n        minimal?: FindRepositoryParams<MBase>['options']['minimal']\r\n        maximum?: FindRepositoryParams<MBase>['options']['maximum']\r\n      },\r\n      fields: HasuraGraphQLFields<MBase>,\r\n    ) => [\r\n      ...(aggregates?.minimal?.length\r\n        ? [\r\n            {\r\n              min: this.bindAttributesToColumns(aggregates?.minimal, fields),\r\n            },\r\n          ]\r\n        : []),\r\n      ...(aggregates?.maximum?.length\r\n        ? [\r\n            {\r\n              max: this.bindAttributesToColumns(aggregates?.maximum, fields),\r\n            },\r\n          ]\r\n        : []),\r\n    ]\r\n\r\n    bindDistinctAttributes = (\r\n      distinct: FindRepositoryParams<MBase>['options']['distinct'],\r\n      fields: HasuraGraphQLFields<MBase>,\r\n    ) => this.bindAttributesToColumns(distinct, fields)\r\n\r\n    bindAttributesToColumns = (\r\n      attributes: Array<NonFunctionAndIdentifierPropertyNames<MBase> | {}>,\r\n      fields: HasuraGraphQLFields<MBase>,\r\n    ) =>\r\n      attributes.map(\r\n        (attr) =>\r\n          AttributeOptionHelper.FindByAttribute(\r\n            attr.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\r\n            fields,\r\n          )?.columnName || attr,\r\n      )\r\n  }\r\n}\r\n"]}
|