@infrab4a/connect 3.14.0-beta.5 → 3.14.2
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/bundles/infrab4a-connect.umd.js +263 -145
- package/bundles/infrab4a-connect.umd.js.map +1 -1
- package/domain/catalog/models/category-filter.d.ts +2 -0
- package/domain/catalog/repositories/product.repository.d.ts +3 -1
- package/domain/generic/repository/find.repository.d.ts +3 -1
- package/domain/generic/repository/types/repository-find-result.type.d.ts +8 -1
- package/domain/shopping/models/order.d.ts +1 -0
- package/domain/shopping/models/shipping-method.d.ts +1 -0
- package/esm2015/domain/catalog/models/category-filter.js +9 -2
- package/esm2015/domain/catalog/repositories/product.repository.js +1 -1
- package/esm2015/domain/generic/repository/find.repository.js +1 -1
- package/esm2015/domain/generic/repository/types/repository-find-result.type.js +1 -1
- package/esm2015/domain/shopping/models/order.js +1 -1
- package/esm2015/domain/shopping/models/shipping-method.js +1 -1
- package/esm2015/infra/firebase/firestore/mixins/with-firestore.mixin.js +17 -2
- package/esm2015/infra/firebase/firestore/repositories/catalog/product-firestore.repository.js +5 -2
- package/esm2015/infra/hasura-graphql/mixins/helpers/attribute-option.helper.js +2 -2
- package/esm2015/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +51 -6
- package/esm2015/infra/hasura-graphql/mixins/with-hasura-graphql.mixin.js +1 -1
- package/esm2015/infra/hasura-graphql/models/product-hasura-graphql.js +1 -1
- package/esm2015/infra/hasura-graphql/models/variant-hasura-graphql.js +1 -1
- package/esm2015/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +33 -2
- package/esm2015/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +2 -2
- package/esm2015/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +18 -6
- package/esm2015/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js +2 -1
- package/esm2015/utils/index.js +3 -3
- package/fesm2015/infrab4a-connect.js +127 -17
- package/fesm2015/infrab4a-connect.js.map +1 -1
- package/infra/firebase/firestore/repositories/catalog/product-firestore.repository.d.ts +2 -1
- package/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +12 -1
- package/infra/hasura-graphql/models/product-hasura-graphql.d.ts +2 -0
- package/infra/hasura-graphql/models/variant-hasura-graphql.d.ts +1 -0
- package/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.d.ts +2 -1
- package/package.json +1 -1
- package/utils/index.d.ts +2 -2
package/esm2015/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.js
CHANGED
|
@@ -51,6 +51,7 @@ export class VariantHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHa
|
|
|
51
51
|
to: (value) => (isNil(value === null || value === void 0 ? void 0 : value.quantity) ? value : value === null || value === void 0 ? void 0 : value.quantity),
|
|
52
52
|
},
|
|
53
53
|
},
|
|
54
|
+
{ hasStock: { columnName: 'has_stock' } },
|
|
54
55
|
'weight',
|
|
55
56
|
{ name: { to: () => '', from: () => undefined } },
|
|
56
57
|
{ hasVariants: { columnName: 'has_variants', to: () => false, from: () => undefined } },
|
|
@@ -113,4 +114,4 @@ export class VariantHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHa
|
|
|
113
114
|
});
|
|
114
115
|
}
|
|
115
116
|
}
|
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"variant-hasura-graphql.repository.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  FindRepositoryParams,\r\n  GetRepositoryParams,\r\n  RepositoryFindResult,\r\n  ShopPrice,\r\n  UpdateRepositoryParams,\r\n  VariantRepository,\r\n  Where,\r\n} from '../../../../domain'\r\nimport { NotFoundError } from '../../../../errors'\r\nimport { Base, isNil } from '../../../../utils'\r\nimport { HasuraGraphQLColumnType } from '../../enums'\r\nimport { withCrudHasuraGraphQL, withHasuraGraphQL } from '../../mixins'\r\nimport { VariantHasuraGraphQL } from '../../models'\r\nimport { HasuraGraphQLAuthOptions } from '../../types'\r\n\r\nexport class VariantHasuraGraphQLRepository\r\n  extends withCrudHasuraGraphQL(withHasuraGraphQL<VariantHasuraGraphQL>(Base))\r\n  implements VariantRepository\r\n{\r\n  constructor(endpoint: string, authOptions: HasuraGraphQLAuthOptions) {\r\n    super({\r\n      tableName: 'product',\r\n      model: VariantHasuraGraphQL,\r\n      endpoint,\r\n      authOptions,\r\n      fields: [\r\n        { id: { columnName: 'id', to: (value) => +value, from: (value) => value.toString() } },\r\n        { firestoreId: { columnName: 'firestore_id' } },\r\n        { productId: { columnName: 'main_product_id', to: (value) => +value, from: (value) => value?.toString() } },\r\n        { EAN: { columnName: 'ean' } },\r\n        { costPrice: { columnName: 'cost_price' } },\r\n        {\r\n          price: {\r\n            columnName: 'price',\r\n            from: (price, data): ShopPrice => ({\r\n              price,\r\n              fullPrice: data.full_price,\r\n              subscriberDiscountPercentage: data.subscriber_discount_percentage,\r\n              subscriberPrice: data.subscriber_price,\r\n            }),\r\n            bindFindFilter: (sentence) => {\r\n              const filters = Object.values(sentence).shift()\r\n\r\n              return {\r\n                ...((filters?.price || filters?.price === 0) && { price: filters.price }),\r\n                ...((filters.fullPrice || filters.fullPrice === 0) && { full_price: filters.fullPrice }),\r\n                ...((filters.subscriberDiscountPercentage || filters.subscriberDiscountPercentage === 0) && {\r\n                  subscriber_discount_percentage: filters.subscriberDiscountPercentage,\r\n                }),\r\n                ...((filters.subscriberPrice || filters.subscriberPrice === 0) && {\r\n                  subscriber_price: filters.subscriberPrice,\r\n                }),\r\n              }\r\n            },\r\n            bindPersistData: (priceData) => ({\r\n              ...(priceData?.price >= 0 && { price: priceData.price }),\r\n              ...(priceData.fullPrice >= 0 && { full_price: priceData.fullPrice }),\r\n              ...(priceData.subscriberDiscountPercentage >= 0 && {\r\n                subscriber_discount_percentage: priceData.subscriberDiscountPercentage,\r\n              }),\r\n              ...(priceData.subscriberPrice >= 0 && { subscriber_price: priceData.subscriberPrice }),\r\n            }),\r\n          },\r\n        },\r\n        { fullPrice: { columnName: 'full_price' } },\r\n        { subscriberDiscountPercentage: { columnName: 'subscriber_discount_percentage' } },\r\n        { subscriberPrice: { columnName: 'subscriber_price' } },\r\n        'sku',\r\n        {\r\n          stock: {\r\n            columnName: 'stock',\r\n            from: (quantity: number) => ({ quantity }),\r\n            to: (value) => (isNil(value?.quantity) ? value : value?.quantity),\r\n          },\r\n        },\r\n        'weight',\r\n        { name: { to: () => '', from: () => undefined } },\r\n        { hasVariants: { columnName: 'has_variants', to: () => false, from: () => undefined } },\r\n        { createdAt: { columnName: 'created_at' } },\r\n        { updatedAt: { columnName: 'updated_at' } },\r\n        {\r\n          grade: {\r\n            columnName: 'grade',\r\n            type: HasuraGraphQLColumnType.Jsonb,\r\n          },\r\n        },\r\n      ],\r\n    })\r\n  }\r\n\r\n  async get(identifiers: GetRepositoryParams<VariantHasuraGraphQL>): Promise<VariantHasuraGraphQL> {\r\n    const variant = Number.isNaN(+identifiers.id)\r\n      ? (await this.find({ filters: { firestoreId: identifiers.id } })).data?.[0]\r\n      : await super.get(identifiers)\r\n\r\n    if (!variant.productId) throw new NotFoundError(`Variant not found, it is a product`)\r\n\r\n    return variant\r\n  }\r\n\r\n  async find(params?: FindRepositoryParams<VariantHasuraGraphQL>): Promise<RepositoryFindResult<VariantHasuraGraphQL>> {\r\n    const { filters, ...options } = params || {}\r\n\r\n    return super.find({ ...options, filters: { productId: { operator: Where.ISNOTNULL }, ...filters } })\r\n  }\r\n\r\n  async update(params: UpdateRepositoryParams<VariantHasuraGraphQL>): Promise<VariantHasuraGraphQL> {\r\n    const { productId, id: checkId, ...data } = params\r\n    const dataWithProductId = this.paramsToPlain({ id: checkId, productId })\r\n    const id = await this.getId(dataWithProductId.id)\r\n    const product = await super.update({ id, ...data })\r\n\r\n    product.productId = dataWithProductId.productId\r\n\r\n    return product\r\n  }\r\n\r\n  private async getId(id: string): Promise<string> {\r\n    if (!Number.isNaN(+id)) return id\r\n\r\n    const { data } = await this.find({ filters: { firestoreId: id }, options: { enableCount: false } })\r\n\r\n    if (data?.[0]?.id) return data?.[0]?.id\r\n\r\n    throw new NotFoundError(`Product with id ${id} not found`)\r\n  }\r\n}\r\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"variant-hasura-graphql.repository.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/repositories/catalog/variant-hasura-graphql.repository.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  FindRepositoryParams,\r\n  GetRepositoryParams,\r\n  RepositoryFindResult,\r\n  ShopPrice,\r\n  UpdateRepositoryParams,\r\n  VariantRepository,\r\n  Where,\r\n} from '../../../../domain'\r\nimport { NotFoundError } from '../../../../errors'\r\nimport { Base, isNil } from '../../../../utils'\r\nimport { HasuraGraphQLColumnType } from '../../enums'\r\nimport { withCrudHasuraGraphQL, withHasuraGraphQL } from '../../mixins'\r\nimport { VariantHasuraGraphQL } from '../../models'\r\nimport { HasuraGraphQLAuthOptions } from '../../types'\r\n\r\nexport class VariantHasuraGraphQLRepository\r\n  extends withCrudHasuraGraphQL(withHasuraGraphQL<VariantHasuraGraphQL>(Base))\r\n  implements VariantRepository\r\n{\r\n  constructor(endpoint: string, authOptions: HasuraGraphQLAuthOptions) {\r\n    super({\r\n      tableName: 'product',\r\n      model: VariantHasuraGraphQL,\r\n      endpoint,\r\n      authOptions,\r\n      fields: [\r\n        { id: { columnName: 'id', to: (value) => +value, from: (value) => value.toString() } },\r\n        { firestoreId: { columnName: 'firestore_id' } },\r\n        { productId: { columnName: 'main_product_id', to: (value) => +value, from: (value) => value?.toString() } },\r\n        { EAN: { columnName: 'ean' } },\r\n        { costPrice: { columnName: 'cost_price' } },\r\n        {\r\n          price: {\r\n            columnName: 'price',\r\n            from: (price, data): ShopPrice => ({\r\n              price,\r\n              fullPrice: data.full_price,\r\n              subscriberDiscountPercentage: data.subscriber_discount_percentage,\r\n              subscriberPrice: data.subscriber_price,\r\n            }),\r\n            bindFindFilter: (sentence) => {\r\n              const filters = Object.values(sentence).shift()\r\n\r\n              return {\r\n                ...((filters?.price || filters?.price === 0) && { price: filters.price }),\r\n                ...((filters.fullPrice || filters.fullPrice === 0) && { full_price: filters.fullPrice }),\r\n                ...((filters.subscriberDiscountPercentage || filters.subscriberDiscountPercentage === 0) && {\r\n                  subscriber_discount_percentage: filters.subscriberDiscountPercentage,\r\n                }),\r\n                ...((filters.subscriberPrice || filters.subscriberPrice === 0) && {\r\n                  subscriber_price: filters.subscriberPrice,\r\n                }),\r\n              }\r\n            },\r\n            bindPersistData: (priceData) => ({\r\n              ...(priceData?.price >= 0 && { price: priceData.price }),\r\n              ...(priceData.fullPrice >= 0 && { full_price: priceData.fullPrice }),\r\n              ...(priceData.subscriberDiscountPercentage >= 0 && {\r\n                subscriber_discount_percentage: priceData.subscriberDiscountPercentage,\r\n              }),\r\n              ...(priceData.subscriberPrice >= 0 && { subscriber_price: priceData.subscriberPrice }),\r\n            }),\r\n          },\r\n        },\r\n        { fullPrice: { columnName: 'full_price' } },\r\n        { subscriberDiscountPercentage: { columnName: 'subscriber_discount_percentage' } },\r\n        { subscriberPrice: { columnName: 'subscriber_price' } },\r\n        'sku',\r\n        {\r\n          stock: {\r\n            columnName: 'stock',\r\n            from: (quantity: number) => ({ quantity }),\r\n            to: (value) => (isNil(value?.quantity) ? value : value?.quantity),\r\n          },\r\n        },\r\n        { hasStock: { columnName: 'has_stock' } },\r\n        'weight',\r\n        { name: { to: () => '', from: () => undefined } },\r\n        { hasVariants: { columnName: 'has_variants', to: () => false, from: () => undefined } },\r\n        { createdAt: { columnName: 'created_at' } },\r\n        { updatedAt: { columnName: 'updated_at' } },\r\n        {\r\n          grade: {\r\n            columnName: 'grade',\r\n            type: HasuraGraphQLColumnType.Jsonb,\r\n          },\r\n        },\r\n      ],\r\n    })\r\n  }\r\n\r\n  async get(identifiers: GetRepositoryParams<VariantHasuraGraphQL>): Promise<VariantHasuraGraphQL> {\r\n    const variant = Number.isNaN(+identifiers.id)\r\n      ? (await this.find({ filters: { firestoreId: identifiers.id } })).data?.[0]\r\n      : await super.get(identifiers)\r\n\r\n    if (!variant.productId) throw new NotFoundError(`Variant not found, it is a product`)\r\n\r\n    return variant\r\n  }\r\n\r\n  async find(params?: FindRepositoryParams<VariantHasuraGraphQL>): Promise<RepositoryFindResult<VariantHasuraGraphQL>> {\r\n    const { filters, ...options } = params || {}\r\n\r\n    return super.find({ ...options, filters: { productId: { operator: Where.ISNOTNULL }, ...filters } })\r\n  }\r\n\r\n  async update(params: UpdateRepositoryParams<VariantHasuraGraphQL>): Promise<VariantHasuraGraphQL> {\r\n    const { productId, id: checkId, ...data } = params\r\n    const dataWithProductId = this.paramsToPlain({ id: checkId, productId })\r\n    const id = await this.getId(dataWithProductId.id)\r\n    const product = await super.update({ id, ...data })\r\n\r\n    product.productId = dataWithProductId.productId\r\n\r\n    return product\r\n  }\r\n\r\n  private async getId(id: string): Promise<string> {\r\n    if (!Number.isNaN(+id)) return id\r\n\r\n    const { data } = await this.find({ filters: { firestoreId: id }, options: { enableCount: false } })\r\n\r\n    if (data?.[0]?.id) return data?.[0]?.id\r\n\r\n    throw new NotFoundError(`Product with id ${id} not found`)\r\n  }\r\n}\r\n"]}
|
package/esm2015/utils/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { add, addBusinessDays, addDays, addMonths, addYears, endOfDay, format, formatISO9075, parseISO, startOfDay, sub, } from 'date-fns';
|
|
2
|
-
import { chunk, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, } from 'lodash';
|
|
2
|
+
import { chunk, each, get, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, unset, } from 'lodash';
|
|
3
3
|
export * from './decorators';
|
|
4
4
|
export * from './helpers';
|
|
5
5
|
export * from './is-uuid';
|
|
@@ -7,5 +7,5 @@ export * from './log.utils';
|
|
|
7
7
|
export * from './mixins';
|
|
8
8
|
export * from './parse-datetime';
|
|
9
9
|
export * from './types';
|
|
10
|
-
export { add, addDays, addBusinessDays, addMonths, addYears, chunk, endOfDay, format, formatISO9075, isBoolean, isDate, isEmpty, isInteger, isNil, isNaN, isNumber, isObject, isString, parseISO, now, omit, pick, set, startOfDay, sub, };
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
export { add, addDays, addBusinessDays, addMonths, addYears, chunk, each, endOfDay, format, formatISO9075, get, isBoolean, isDate, isEmpty, isInteger, isNil, isNaN, isNumber, isObject, isString, parseISO, now, omit, pick, set, startOfDay, sub, unset, };
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsR0FBRyxFQUNILGVBQWUsRUFDZixPQUFPLEVBQ1AsU0FBUyxFQUNULFFBQVEsRUFDUixRQUFRLEVBQ1IsTUFBTSxFQUNOLGFBQWEsRUFDYixRQUFRLEVBQ1IsVUFBVSxFQUNWLEdBQUcsR0FDSixNQUFNLFVBQVUsQ0FBQTtBQUNqQixPQUFPLEVBQ0wsS0FBSyxFQUNMLElBQUksRUFDSixHQUFHLEVBQ0gsU0FBUyxFQUNULE1BQU0sRUFDTixPQUFPLEVBQ1AsU0FBUyxFQUNULEtBQUssRUFDTCxLQUFLLEVBQ0wsUUFBUSxFQUNSLFFBQVEsRUFDUixRQUFRLEVBQ1IsR0FBRyxFQUNILElBQUksRUFDSixJQUFJLEVBQ0osR0FBRyxFQUNILEtBQUssR0FDTixNQUFNLFFBQVEsQ0FBQTtBQUVmLGNBQWMsY0FBYyxDQUFBO0FBQzVCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsVUFBVSxDQUFBO0FBQ3hCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxTQUFTLENBQUE7QUFDdkIsT0FBTyxFQUNMLEdBQUcsRUFDSCxPQUFPLEVBQ1AsZUFBZSxFQUNmLFNBQVMsRUFDVCxRQUFRLEVBQ1IsS0FBSyxFQUNMLElBQUksRUFDSixRQUFRLEVBQ1IsTUFBTSxFQUNOLGFBQWEsRUFDYixHQUFHLEVBQ0gsU0FBUyxFQUNULE1BQU0sRUFDTixPQUFPLEVBQ1AsU0FBUyxFQUNULEtBQUssRUFDTCxLQUFLLEVBQ0wsUUFBUSxFQUNSLFFBQVEsRUFDUixRQUFRLEVBQ1IsUUFBUSxFQUNSLEdBQUcsRUFDSCxJQUFJLEVBQ0osSUFBSSxFQUNKLEdBQUcsRUFDSCxVQUFVLEVBQ1YsR0FBRyxFQUNILEtBQUssR0FDTixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBhZGQsXHJcbiAgYWRkQnVzaW5lc3NEYXlzLFxyXG4gIGFkZERheXMsXHJcbiAgYWRkTW9udGhzLFxyXG4gIGFkZFllYXJzLFxyXG4gIGVuZE9mRGF5LFxyXG4gIGZvcm1hdCxcclxuICBmb3JtYXRJU085MDc1LFxyXG4gIHBhcnNlSVNPLFxyXG4gIHN0YXJ0T2ZEYXksXHJcbiAgc3ViLFxyXG59IGZyb20gJ2RhdGUtZm5zJ1xyXG5pbXBvcnQge1xyXG4gIGNodW5rLFxyXG4gIGVhY2gsXHJcbiAgZ2V0LFxyXG4gIGlzQm9vbGVhbixcclxuICBpc0RhdGUsXHJcbiAgaXNFbXB0eSxcclxuICBpc0ludGVnZXIsXHJcbiAgaXNOYU4sXHJcbiAgaXNOaWwsXHJcbiAgaXNOdW1iZXIsXHJcbiAgaXNPYmplY3QsXHJcbiAgaXNTdHJpbmcsXHJcbiAgbm93LFxyXG4gIG9taXQsXHJcbiAgcGljayxcclxuICBzZXQsXHJcbiAgdW5zZXQsXHJcbn0gZnJvbSAnbG9kYXNoJ1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9kZWNvcmF0b3JzJ1xyXG5leHBvcnQgKiBmcm9tICcuL2hlbHBlcnMnXHJcbmV4cG9ydCAqIGZyb20gJy4vaXMtdXVpZCdcclxuZXhwb3J0ICogZnJvbSAnLi9sb2cudXRpbHMnXHJcbmV4cG9ydCAqIGZyb20gJy4vbWl4aW5zJ1xyXG5leHBvcnQgKiBmcm9tICcuL3BhcnNlLWRhdGV0aW1lJ1xyXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJ1xyXG5leHBvcnQge1xyXG4gIGFkZCxcclxuICBhZGREYXlzLFxyXG4gIGFkZEJ1c2luZXNzRGF5cyxcclxuICBhZGRNb250aHMsXHJcbiAgYWRkWWVhcnMsXHJcbiAgY2h1bmssXHJcbiAgZWFjaCxcclxuICBlbmRPZkRheSxcclxuICBmb3JtYXQsXHJcbiAgZm9ybWF0SVNPOTA3NSxcclxuICBnZXQsXHJcbiAgaXNCb29sZWFuLFxyXG4gIGlzRGF0ZSxcclxuICBpc0VtcHR5LFxyXG4gIGlzSW50ZWdlcixcclxuICBpc05pbCxcclxuICBpc05hTixcclxuICBpc051bWJlcixcclxuICBpc09iamVjdCxcclxuICBpc1N0cmluZyxcclxuICBwYXJzZUlTTyxcclxuICBub3csXHJcbiAgb21pdCxcclxuICBwaWNrLFxyXG4gIHNldCxcclxuICBzdGFydE9mRGF5LFxyXG4gIHN1YixcclxuICB1bnNldCxcclxufVxyXG4iXX0=
|
|
@@ -3,8 +3,8 @@ import { plainToInstance, instanceToPlain, Expose, Type } from 'class-transforme
|
|
|
3
3
|
import { __decorate, __metadata, __awaiter, __rest } from 'tslib';
|
|
4
4
|
import { parseISO } from 'date-fns';
|
|
5
5
|
export { add, addBusinessDays, addDays, addMonths, addYears, endOfDay, format, formatISO9075, parseISO, startOfDay, sub } from 'date-fns';
|
|
6
|
-
import { isNil, isArray, first, last, flatten, compact, get, isString, isNumber, isDate, set,
|
|
7
|
-
export { chunk, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set } from 'lodash';
|
|
6
|
+
import { isNil, isArray, first, last, flatten, compact, get, isString, each, unset, isObject, isNumber, isDate, set, isEmpty, chunk, isBoolean, isInteger, isNaN as isNaN$1, omit } from 'lodash';
|
|
7
|
+
export { chunk, each, get, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, unset } from 'lodash';
|
|
8
8
|
import { Subject } from 'rxjs';
|
|
9
9
|
import { debug } from 'debug';
|
|
10
10
|
import { CustomError } from 'ts-custom-error';
|
|
@@ -1219,9 +1219,13 @@ __decorate([
|
|
|
1219
1219
|
|
|
1220
1220
|
class CategoryFilter extends BaseModel {
|
|
1221
1221
|
static get identifiersFields() {
|
|
1222
|
-
return ['id'
|
|
1222
|
+
return ['id'];
|
|
1223
1223
|
}
|
|
1224
|
-
}
|
|
1224
|
+
}
|
|
1225
|
+
__decorate([
|
|
1226
|
+
Type(() => Filter),
|
|
1227
|
+
__metadata("design:type", Filter)
|
|
1228
|
+
], CategoryFilter.prototype, "filter", void 0);
|
|
1225
1229
|
|
|
1226
1230
|
var GenderDestination;
|
|
1227
1231
|
(function (GenderDestination) {
|
|
@@ -1753,13 +1757,27 @@ const withFirestore = (MixinBase) => {
|
|
|
1753
1757
|
? data[key].map((element) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))
|
|
1754
1758
|
: bindDate(data[key], key) })), {});
|
|
1755
1759
|
};
|
|
1760
|
+
const omitByRecursivelyInPlace = (value, iteratee) => {
|
|
1761
|
+
each(value, (v, k) => {
|
|
1762
|
+
if (iteratee(v, k)) {
|
|
1763
|
+
unset(value, k);
|
|
1764
|
+
}
|
|
1765
|
+
else if (isObject(v)) {
|
|
1766
|
+
omitByRecursivelyInPlace(v, iteratee);
|
|
1767
|
+
}
|
|
1768
|
+
});
|
|
1769
|
+
return value;
|
|
1770
|
+
};
|
|
1756
1771
|
return class extends MixinBase {
|
|
1757
1772
|
collection(path) {
|
|
1758
1773
|
return this.firestore.collection(path || this.collectionName).withConverter(this.buildModelInstance());
|
|
1759
1774
|
}
|
|
1760
1775
|
buildModelInstance() {
|
|
1761
1776
|
return {
|
|
1762
|
-
toFirestore: (data) =>
|
|
1777
|
+
toFirestore: (data) => {
|
|
1778
|
+
const plain = (data === null || data === void 0 ? void 0 : data.toPlain) ? data.toPlain() : data;
|
|
1779
|
+
return omitByRecursivelyInPlace(plain, (value) => value === undefined);
|
|
1780
|
+
},
|
|
1763
1781
|
fromFirestore: (snap) => {
|
|
1764
1782
|
const data = snap.data();
|
|
1765
1783
|
let bindedData;
|
|
@@ -2287,6 +2305,9 @@ class ProductFirestoreRepository extends withCrudFirestore(withHelpers(withFires
|
|
|
2287
2305
|
cleanShoppingCountFromIds(ids) {
|
|
2288
2306
|
return;
|
|
2289
2307
|
}
|
|
2308
|
+
findCatalog(params) {
|
|
2309
|
+
return this.find(params);
|
|
2310
|
+
}
|
|
2290
2311
|
}
|
|
2291
2312
|
|
|
2292
2313
|
class ProductVariantFirestoreRepository extends withSubCollection(withCrudFirestore(withHelpers(withFirestore(Base))), Product) {
|
|
@@ -2599,7 +2620,7 @@ AttributeOptionHelper.FindByAttribute = (attributeName, fields) => {
|
|
|
2599
2620
|
return { columnName: attributeName.toString(), attributeName, fields: fieldOption };
|
|
2600
2621
|
return Object.assign({ attributeName, columnName: attributeName.toString() }, fieldOption);
|
|
2601
2622
|
};
|
|
2602
|
-
AttributeOptionHelper.CheckIsColumnOption = (fieldValue) => !!fieldValue.columnName;
|
|
2623
|
+
AttributeOptionHelper.CheckIsColumnOption = (fieldValue) => !!(fieldValue === null || fieldValue === void 0 ? void 0 : fieldValue.columnName);
|
|
2603
2624
|
AttributeOptionHelper.FindColumnOptionFromList = (columnName, fields) => {
|
|
2604
2625
|
if (fields.includes(columnName))
|
|
2605
2626
|
return { columnName, attributeName: columnName };
|
|
@@ -3079,9 +3100,32 @@ const withFindHasuraGraphQL = (MixinBase) => {
|
|
|
3079
3100
|
super(...arguments);
|
|
3080
3101
|
this.bindOrderByAttributes = (orderBy, fields) => Object.keys(orderBy).reduce((acc, current) => (Object.assign(Object.assign({}, acc), { [AttributeOptionHelper.FindByAttribute(current, fields)
|
|
3081
3102
|
.columnName]: orderBy[current] })), {});
|
|
3103
|
+
this.bindAggretageAttributes = (aggregates, fields) => {
|
|
3104
|
+
var _a, _b;
|
|
3105
|
+
return [
|
|
3106
|
+
...(((_a = aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal) === null || _a === void 0 ? void 0 : _a.length)
|
|
3107
|
+
? [
|
|
3108
|
+
{
|
|
3109
|
+
min: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.minimal, fields),
|
|
3110
|
+
},
|
|
3111
|
+
]
|
|
3112
|
+
: []),
|
|
3113
|
+
...(((_b = aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum) === null || _b === void 0 ? void 0 : _b.length)
|
|
3114
|
+
? [
|
|
3115
|
+
{
|
|
3116
|
+
max: this.bindAttributesToColumns(aggregates === null || aggregates === void 0 ? void 0 : aggregates.maximum, fields),
|
|
3117
|
+
},
|
|
3118
|
+
]
|
|
3119
|
+
: []),
|
|
3120
|
+
];
|
|
3121
|
+
};
|
|
3122
|
+
this.bindAttributesToColumns = (attributes, fields) => attributes.map((attr) => {
|
|
3123
|
+
var _a;
|
|
3124
|
+
return ((_a = AttributeOptionHelper.FindByAttribute(attr.toString().split('.').pop(), fields)) === null || _a === void 0 ? void 0 : _a.columnName) || attr;
|
|
3125
|
+
});
|
|
3082
3126
|
}
|
|
3083
3127
|
find(params) {
|
|
3084
|
-
var _a;
|
|
3128
|
+
var _a, _b, _c;
|
|
3085
3129
|
return __awaiter(this, void 0, void 0, function* () {
|
|
3086
3130
|
this.logger = DebugHelper.from(this, 'find');
|
|
3087
3131
|
const { filters, limits, orderBy, options } = params || {};
|
|
@@ -3104,6 +3148,10 @@ const withFindHasuraGraphQL = (MixinBase) => {
|
|
|
3104
3148
|
},
|
|
3105
3149
|
}));
|
|
3106
3150
|
const variables = Object.assign(Object.assign({}, (isNil(limits) ? {} : limits)), variablesCount);
|
|
3151
|
+
const aggregateFields = [
|
|
3152
|
+
...(enableCount ? ['count'] : []),
|
|
3153
|
+
...this.bindAggretageAttributes(params.options, this.fields),
|
|
3154
|
+
];
|
|
3107
3155
|
const result = yield this.query([
|
|
3108
3156
|
{
|
|
3109
3157
|
operation: this.tableName,
|
|
@@ -3117,18 +3165,36 @@ const withFindHasuraGraphQL = (MixinBase) => {
|
|
|
3117
3165
|
: this.fields,
|
|
3118
3166
|
variables,
|
|
3119
3167
|
},
|
|
3120
|
-
...(
|
|
3168
|
+
...(aggregateFields.length > 0
|
|
3121
3169
|
? [
|
|
3122
3170
|
{
|
|
3123
3171
|
operation: `${this.tableName}_aggregate`,
|
|
3124
|
-
fields: [
|
|
3172
|
+
fields: [
|
|
3173
|
+
{
|
|
3174
|
+
aggregate: aggregateFields,
|
|
3175
|
+
},
|
|
3176
|
+
],
|
|
3125
3177
|
variables: variablesCount,
|
|
3126
3178
|
},
|
|
3127
3179
|
]
|
|
3128
3180
|
: []),
|
|
3129
3181
|
]);
|
|
3130
3182
|
const data = result[this.tableName].map((row) => this.convertDataFromHasura(row));
|
|
3131
|
-
return { data, count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity }
|
|
3183
|
+
return Object.assign(Object.assign({ data, count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity }, (((_b = options === null || options === void 0 ? void 0 : options.minimal) === null || _b === void 0 ? void 0 : _b.length)
|
|
3184
|
+
? {
|
|
3185
|
+
minimal: options.minimal.reduce((minimals, current) => {
|
|
3186
|
+
var _a;
|
|
3187
|
+
return (Object.assign(Object.assign({}, minimals), set(minimals, current, result[`${this.tableName}_aggregate`].aggregate.min[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
|
|
3188
|
+
}, {}),
|
|
3189
|
+
}
|
|
3190
|
+
: {})), (((_c = options === null || options === void 0 ? void 0 : options.maximum) === null || _c === void 0 ? void 0 : _c.length)
|
|
3191
|
+
? {
|
|
3192
|
+
maximum: options.maximum.reduce((maximums, current) => {
|
|
3193
|
+
var _a;
|
|
3194
|
+
return (Object.assign(Object.assign({}, maximums), set(maximums, current, result[`${this.tableName}_aggregate`].aggregate.max[((_a = AttributeOptionHelper.FindByAttribute(current.toString().split('.').pop(), this.fields)) === null || _a === void 0 ? void 0 : _a.columnName) || current])));
|
|
3195
|
+
}, {}),
|
|
3196
|
+
}
|
|
3197
|
+
: {}));
|
|
3132
3198
|
});
|
|
3133
3199
|
}
|
|
3134
3200
|
};
|
|
@@ -3210,7 +3276,38 @@ class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHa
|
|
|
3210
3276
|
model: CategoryFilter,
|
|
3211
3277
|
endpoint,
|
|
3212
3278
|
authOptions,
|
|
3213
|
-
fields: [
|
|
3279
|
+
fields: [
|
|
3280
|
+
'id',
|
|
3281
|
+
{ filterId: { columnName: 'filter_id' } },
|
|
3282
|
+
{ categoryId: { columnName: 'category_id' } },
|
|
3283
|
+
{
|
|
3284
|
+
filter: {
|
|
3285
|
+
columnName: 'filter',
|
|
3286
|
+
foreignKeyColumn: { id: 'filterId' },
|
|
3287
|
+
fields: [
|
|
3288
|
+
'id',
|
|
3289
|
+
'description',
|
|
3290
|
+
'slug',
|
|
3291
|
+
'enabled',
|
|
3292
|
+
{ createdAt: { columnName: 'created_at' } },
|
|
3293
|
+
{ updatedAt: { columnName: 'updated_at' } },
|
|
3294
|
+
{
|
|
3295
|
+
options: {
|
|
3296
|
+
columnName: 'options',
|
|
3297
|
+
foreignKeyColumn: { filterId: 'id' },
|
|
3298
|
+
fields: [
|
|
3299
|
+
'id',
|
|
3300
|
+
{ filterId: { columnName: 'filter_id' } },
|
|
3301
|
+
'description',
|
|
3302
|
+
{ createdAt: { columnName: 'created_at' } },
|
|
3303
|
+
{ updatedAt: { columnName: 'updated_at' } },
|
|
3304
|
+
],
|
|
3305
|
+
},
|
|
3306
|
+
},
|
|
3307
|
+
],
|
|
3308
|
+
},
|
|
3309
|
+
},
|
|
3310
|
+
],
|
|
3214
3311
|
});
|
|
3215
3312
|
}
|
|
3216
3313
|
deleteByCategoryAndFilter(categoryId, filterId) {
|
|
@@ -3584,7 +3681,7 @@ class CategoryHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGr
|
|
|
3584
3681
|
required: true,
|
|
3585
3682
|
},
|
|
3586
3683
|
});
|
|
3587
|
-
return category_tree.map((
|
|
3684
|
+
return category_tree.map((category) => Category.toInstance(category));
|
|
3588
3685
|
});
|
|
3589
3686
|
}
|
|
3590
3687
|
isChild(id, parentId) {
|
|
@@ -3763,8 +3860,7 @@ class ProductHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
3763
3860
|
brand: data.brand_description,
|
|
3764
3861
|
ingredients: data.ingredients,
|
|
3765
3862
|
}),
|
|
3766
|
-
bindFindFilter: (
|
|
3767
|
-
const filters = Object.values(sentence).shift();
|
|
3863
|
+
bindFindFilter: (filters) => {
|
|
3768
3864
|
return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({}, ((filters === null || filters === void 0 ? void 0 : filters.description) && { description: filters.description })), (filters.differentials && { differentials: filters.differentials })), (filters.whoMustUse && {
|
|
3769
3865
|
who_must_use: filters.whoMustUse,
|
|
3770
3866
|
})), (filters.howToUse && {
|
|
@@ -3808,8 +3904,7 @@ class ProductHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
3808
3904
|
subscriberDiscountPercentage: data.subscriber_discount_percentage,
|
|
3809
3905
|
subscriberPrice: data.subscriber_price,
|
|
3810
3906
|
}),
|
|
3811
|
-
bindFindFilter: (
|
|
3812
|
-
const filters = Object.values(sentence).shift();
|
|
3907
|
+
bindFindFilter: (filters) => {
|
|
3813
3908
|
return Object.assign(Object.assign(Object.assign(Object.assign({}, (((filters === null || filters === void 0 ? void 0 : filters.price) || (filters === null || filters === void 0 ? void 0 : filters.price) === 0) && { price: filters.price })), ((filters.fullPrice || filters.fullPrice === 0) && { full_price: filters.fullPrice })), ((filters.subscriberDiscountPercentage || filters.subscriberDiscountPercentage === 0) && {
|
|
3814
3909
|
subscriber_discount_percentage: filters.subscriberDiscountPercentage,
|
|
3815
3910
|
})), ((filters.subscriberPrice || filters.subscriberPrice === 0) && {
|
|
@@ -3833,11 +3928,13 @@ class ProductHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
3833
3928
|
to: (value) => (isNil(value === null || value === void 0 ? void 0 : value.quantity) ? value : value === null || value === void 0 ? void 0 : value.quantity),
|
|
3834
3929
|
},
|
|
3835
3930
|
},
|
|
3931
|
+
{ hasStock: { columnName: 'has_stock' } },
|
|
3836
3932
|
'slug',
|
|
3837
3933
|
'type',
|
|
3838
3934
|
'video',
|
|
3839
3935
|
'weight',
|
|
3840
3936
|
'gender',
|
|
3937
|
+
{ intGender: { columnName: 'int_gender' } },
|
|
3841
3938
|
{ tags: { columnName: 'tags', type: HasuraGraphQLColumnType.Jsonb } },
|
|
3842
3939
|
{ filters: { columnName: 'filters', type: HasuraGraphQLColumnType.Jsonb } },
|
|
3843
3940
|
{ isKit: { columnName: 'is_kit' } },
|
|
@@ -3952,12 +4049,19 @@ class ProductHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
3952
4049
|
const _super = Object.create(null, {
|
|
3953
4050
|
find: { get: () => super.find }
|
|
3954
4051
|
});
|
|
4052
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
3955
4053
|
return __awaiter(this, void 0, void 0, function* () {
|
|
3956
|
-
const
|
|
4054
|
+
const _o = params || {}, { filters, fields } = _o, options = __rest(_o, ["filters", "fields"]);
|
|
3957
4055
|
const bindFields = fields ||
|
|
3958
4056
|
this.fields
|
|
3959
4057
|
.map((field) => (typeof field === 'string' ? field : Object.keys(field).shift()))
|
|
3960
4058
|
.filter((field) => field !== 'reviews');
|
|
4059
|
+
if ((_b = (_a = options.options) === null || _a === void 0 ? void 0 : _a.minimal) === null || _b === void 0 ? void 0 : _b.includes('price'))
|
|
4060
|
+
(_c = options.options) === null || _c === void 0 ? void 0 : _c.minimal.push('price.price', 'price.fullPrice', 'price.subscriberPrice');
|
|
4061
|
+
if ((_e = (_d = options.options) === null || _d === void 0 ? void 0 : _d.maximum) === null || _e === void 0 ? void 0 : _e.includes('price'))
|
|
4062
|
+
(_f = options.options) === null || _f === void 0 ? void 0 : _f.maximum.push('price.price', 'price.fullPrice', 'price.subscriberPrice');
|
|
4063
|
+
(_h = (_g = options.options) === null || _g === void 0 ? void 0 : _g.minimal) === null || _h === void 0 ? void 0 : _h.splice((_j = options.options) === null || _j === void 0 ? void 0 : _j.minimal.indexOf('price'), 1);
|
|
4064
|
+
(_l = (_k = options.options) === null || _k === void 0 ? void 0 : _k.maximum) === null || _l === void 0 ? void 0 : _l.splice((_m = options.options) === null || _m === void 0 ? void 0 : _m.maximum.indexOf('price'), 1);
|
|
3961
4065
|
return _super.find.call(this, Object.assign(Object.assign({}, options), { filters: Object.assign(Object.assign({}, filters), { productId: { operator: Where.ISNULL } }), fields: [
|
|
3962
4066
|
...bindFields,
|
|
3963
4067
|
...(bindFields.includes('price')
|
|
@@ -4023,6 +4127,11 @@ class ProductHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
4023
4127
|
], []);
|
|
4024
4128
|
});
|
|
4025
4129
|
}
|
|
4130
|
+
findCatalog(params, mainGender) {
|
|
4131
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
4132
|
+
return this.find(Object.assign(Object.assign({}, params), { filters: Object.assign(Object.assign({}, params.filters), { published: true }), orderBy: Object.assign({ hasStock: 'desc', intGender: mainGender === 'female' ? 'desc' : 'asc' }, omit(params.orderBy, ['hasStock', 'intGender'])) }));
|
|
4133
|
+
});
|
|
4134
|
+
}
|
|
4026
4135
|
updateCategories(productId, { categories }) {
|
|
4027
4136
|
return __awaiter(this, void 0, void 0, function* () {
|
|
4028
4137
|
if ('action' in categories && categories.action === 'remove') {
|
|
@@ -4265,6 +4374,7 @@ class VariantHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHasuraGra
|
|
|
4265
4374
|
to: (value) => (isNil(value === null || value === void 0 ? void 0 : value.quantity) ? value : value === null || value === void 0 ? void 0 : value.quantity),
|
|
4266
4375
|
},
|
|
4267
4376
|
},
|
|
4377
|
+
{ hasStock: { columnName: 'has_stock' } },
|
|
4268
4378
|
'weight',
|
|
4269
4379
|
{ name: { to: () => '', from: () => undefined } },
|
|
4270
4380
|
{ hasVariants: { columnName: 'has_variants', to: () => false, from: () => undefined } },
|