@infrab4a/connect 4.9.7-beta.35 → 4.9.7-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (83) hide show
  1. package/index.cjs.js +597 -1036
  2. package/index.esm.js +598 -1029
  3. package/package.json +1 -1
  4. package/src/domain/catalog/models/category-base.d.ts +3 -5
  5. package/src/domain/catalog/models/enums/index.d.ts +0 -2
  6. package/src/domain/catalog/models/filter.d.ts +0 -1
  7. package/src/domain/catalog/models/index.d.ts +0 -1
  8. package/src/domain/catalog/models/product-base.d.ts +1 -4
  9. package/src/domain/catalog/models/types/index.d.ts +1 -3
  10. package/src/domain/catalog/models/variant.d.ts +0 -4
  11. package/src/domain/catalog/models/wishlist.d.ts +0 -3
  12. package/src/domain/catalog/repositories/category.repository.d.ts +3 -3
  13. package/src/domain/catalog/repositories/index.d.ts +0 -1
  14. package/src/domain/catalog/repositories/product-reviews.repository.d.ts +0 -1
  15. package/src/domain/catalog/repositories/product-stock-notification.repository.d.ts +1 -9
  16. package/src/domain/catalog/repositories/product.repository.d.ts +1 -2
  17. package/src/domain/catalog/repositories/wishlist.repository.d.ts +1 -6
  18. package/src/domain/general/index.d.ts +0 -3
  19. package/src/domain/shopping/index.d.ts +0 -1
  20. package/src/domain/shopping/models/buy-2-win.d.ts +0 -2
  21. package/src/domain/shopping/models/coupons/coupon.d.ts +4 -8
  22. package/src/domain/shopping/models/coupons/enums/coupon-types.enum.d.ts +1 -2
  23. package/src/domain/shopping/models/coupons/enums/index.d.ts +1 -3
  24. package/src/domain/shopping/models/index.d.ts +0 -1
  25. package/src/domain/shopping/models/order.d.ts +0 -4
  26. package/src/domain/shopping/repositories/index.d.ts +0 -1
  27. package/src/domain/users/models/enums/index.d.ts +0 -1
  28. package/src/domain/users/models/index.d.ts +2 -3
  29. package/src/infra/elasticsearch/indexes/products-index.d.ts +1 -39
  30. package/src/infra/firebase/firestore/mixins/with-helpers.mixin.d.ts +1 -1
  31. package/src/infra/firebase/firestore/repositories/catalog/category-firestore.repository.d.ts +2 -2
  32. package/src/infra/firebase/firestore/repositories/catalog/product-firestore.repository.d.ts +1 -2
  33. package/src/infra/firebase/firestore/repositories/index.d.ts +2 -3
  34. package/src/infra/firebase/firestore/repositories/shopping/index.d.ts +0 -1
  35. package/src/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +0 -1
  36. package/src/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.d.ts +2 -2
  37. package/src/infra/hasura-graphql/repositories/catalog/index.d.ts +0 -1
  38. package/src/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.d.ts +2 -2
  39. package/src/infra/hasura-graphql/repositories/catalog/product-review-hasura-graphql.repository.d.ts +0 -1
  40. package/src/infra/hasura-graphql/repositories/catalog/product-stock-notification-hasura-graphql.repository.d.ts +1 -8
  41. package/src/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.d.ts +15 -18
  42. package/src/infra/index.d.ts +0 -1
  43. package/src/domain/catalog/models/category-product.d.ts +0 -8
  44. package/src/domain/catalog/models/enums/product-label.enum.d.ts +0 -6
  45. package/src/domain/catalog/models/enums/wishlist-log.enum.d.ts +0 -7
  46. package/src/domain/catalog/models/types/product-label.type.d.ts +0 -2
  47. package/src/domain/catalog/models/types/product-variant-report.type.d.ts +0 -46
  48. package/src/domain/catalog/models/types/report-stock-notification.type.d.ts +0 -21
  49. package/src/domain/catalog/repositories/category-product.repository.d.ts +0 -6
  50. package/src/domain/general/models/index.d.ts +0 -1
  51. package/src/domain/general/models/log-document.d.ts +0 -15
  52. package/src/domain/general/repositories/index.d.ts +0 -1
  53. package/src/domain/general/repositories/log.repository.d.ts +0 -4
  54. package/src/domain/general/search/index.d.ts +0 -1
  55. package/src/domain/general/search/product-search-index.d.ts +0 -3
  56. package/src/domain/shopping/models/coupons/enums/coupon-category.enum.d.ts +0 -41
  57. package/src/domain/shopping/models/coupons/enums/coupon-channels.enum.d.ts +0 -10
  58. package/src/domain/shopping/models/coupons/types/coupon-category.type.d.ts +0 -2
  59. package/src/domain/shopping/models/coupons/types/coupon-channel.type.d.ts +0 -2
  60. package/src/domain/shopping/models/coupons/types/index.d.ts +0 -2
  61. package/src/domain/shopping/models/order-blocked.d.ts +0 -26
  62. package/src/domain/shopping/repositories/order-blocked.repository.d.ts +0 -6
  63. package/src/domain/shopping/types/index.d.ts +0 -2
  64. package/src/domain/shopping/types/order-tracking-events.type.d.ts +0 -14
  65. package/src/domain/shopping/types/payment-card-info.type.d.ts +0 -4
  66. package/src/domain/users/models/enums/person-types.enum.d.ts +0 -5
  67. package/src/domain/users/models/types/index.d.ts +0 -1
  68. package/src/domain/users/models/types/person.type.d.ts +0 -2
  69. package/src/infra/firebase/firestore/repositories/general/index.d.ts +0 -1
  70. package/src/infra/firebase/firestore/repositories/general/log-firestore.repository.d.ts +0 -7
  71. package/src/infra/firebase/firestore/repositories/shopping/order-blocked-firestore.repository.ts.d.ts +0 -9
  72. package/src/infra/hasura-graphql/models/wishlist-hasura-graphql.d.ts +0 -4
  73. package/src/infra/hasura-graphql/repositories/catalog/category-product-hasura-graphql.repository.d.ts +0 -11
  74. package/src/infra/vertex-ai/adapters/index.d.ts +0 -2
  75. package/src/infra/vertex-ai/adapters/vertex-ai-search.adapter.d.ts +0 -10
  76. package/src/infra/vertex-ai/adapters/vertex-axios.adapter.d.ts +0 -15
  77. package/src/infra/vertex-ai/index.d.ts +0 -3
  78. package/src/infra/vertex-ai/indexes/index.d.ts +0 -1
  79. package/src/infra/vertex-ai/indexes/products-vertex-search.d.ts +0 -13
  80. package/src/infra/vertex-ai/types/axios-vertex-search-config.d.ts +0 -4
  81. package/src/infra/vertex-ai/types/index.d.ts +0 -3
  82. package/src/infra/vertex-ai/types/product-bulk.d.ts +0 -4
  83. package/src/infra/vertex-ai/types/product-search.d.ts +0 -21
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@infrab4a/connect",
3
- "version": "4.9.7-beta.35",
3
+ "version": "4.9.7-beta.4",
4
4
  "publishConfig": {
5
5
  "registry": "https://registry.npmjs.org"
6
6
  },
@@ -20,16 +20,14 @@ export declare class CategoryBase<ChildCategory extends ModelBaseStructure<Child
20
20
  shop?: Shops;
21
21
  shops?: string[];
22
22
  published: boolean;
23
- metadata: CategoryMetadata;
24
- metadatas: CategoryMetadata[];
23
+ metadata: CategoryMetadata[];
25
24
  isCollection?: boolean;
26
25
  isWishlist?: boolean;
27
26
  reference?: string;
28
27
  parentId?: number;
29
28
  theme?: string;
30
29
  bannerUrl?: string;
31
- mostRelevant?: string[];
32
- mostRelevants?: CategoryMostRelevant;
30
+ mostRelevant?: CategoryMostRelevant;
33
31
  parent?: CategoryBase;
34
32
  filters?: Filter[];
35
33
  static get identifiersFields(): GenericIdentifier[];
@@ -45,5 +43,5 @@ export declare class CategoryBase<ChildCategory extends ModelBaseStructure<Child
45
43
  };
46
44
  get glamMetadata(): CategoryMetadata;
47
45
  get mensMetadata(): CategoryMetadata;
48
- getMostRelevantByShop(shop: Shops): string[];
46
+ glamMostRelevantByShop(shop: Shops): string[];
49
47
  }
@@ -1,4 +1,2 @@
1
1
  export * from './product-genders.enum';
2
- export * from './product-label.enum';
3
2
  export * from './shops.enum';
4
- export * from './wishlist-log.enum';
@@ -4,7 +4,6 @@ import { FilterOption } from './filter-option';
4
4
  export declare class Filter extends BaseModel<Filter> {
5
5
  id: number;
6
6
  description: string;
7
- title?: string;
8
7
  slug: string;
9
8
  enabled: boolean;
10
9
  options?: FilterOption[];
@@ -1,7 +1,6 @@
1
1
  export * from './category';
2
2
  export * from './category-collection-children';
3
3
  export * from './category-filter';
4
- export * from './category-product';
5
4
  export * from './enums';
6
5
  export * from './filter';
7
6
  export * from './filter-option';
@@ -1,5 +1,5 @@
1
1
  import { BaseModel, GenericIdentifier, ModelBaseStructure } from '../../generic/model';
2
- import { ProductEvaluation, ProductGender, ProductLabel, ProductMetadata, ProductReview, ShopDescription, ShopPrice, Stock } from './types';
2
+ import { ProductEvaluation, ProductGender, ProductMetadata, ProductReview, ShopDescription, ShopPrice, Stock } from './types';
3
3
  import { Variant } from './variant';
4
4
  export declare class ProductBase<ChildProduct extends ModelBaseStructure<ChildProduct, Identifiers>, Identifiers = ChildProduct['identifiersFields']> extends BaseModel<ChildProduct, Identifiers> {
5
5
  id: string;
@@ -34,9 +34,6 @@ export declare class ProductBase<ChildProduct extends ModelBaseStructure<ChildPr
34
34
  shoppingCount?: number;
35
35
  metadata: ProductMetadata;
36
36
  outlet?: boolean;
37
- label?: ProductLabel;
38
- group?: number;
39
- validity: boolean;
40
37
  private reviewsTotal?;
41
38
  get evaluation(): ProductEvaluation;
42
39
  set evaluation(evaluation: ProductEvaluation);
@@ -2,13 +2,11 @@ export * from './category-condition.type';
2
2
  export * from './category-images.type';
3
3
  export * from './category-metadata.type';
4
4
  export * from './category-most-relevant.type';
5
+ export * from './category-product';
5
6
  export * from './product-evaluation.type';
6
7
  export * from './product-gender.type';
7
- export * from './product-label.type';
8
8
  export * from './product-metadata.type';
9
9
  export * from './product-review.type';
10
- export * from './product-variant-report.type';
11
- export * from './report-stock-notification.type';
12
10
  export * from './shop-description.type';
13
11
  export * from './shop-price.type';
14
12
  export * from './stock.type';
@@ -13,9 +13,5 @@ export declare class Variant extends BaseModel<Variant, ProductVariantIdentifier
13
13
  weight: number;
14
14
  createdAt?: Date;
15
15
  updatedAt?: Date;
16
- group?: number;
17
- validity: boolean;
18
- tags: string[];
19
- published: boolean;
20
16
  static get identifiersFields(): ProductVariantIdentifiers[];
21
17
  }
@@ -1,11 +1,8 @@
1
1
  import { GenericIdentifier } from '../../generic/model';
2
- import { PersonType } from '../../users';
3
2
  import { Category } from './category';
4
3
  export declare class Wishlist extends Category {
5
4
  personId?: string;
6
5
  personName?: string;
7
6
  personPhoto?: string;
8
- personType?: PersonType;
9
- personIsSubscriber?: boolean;
10
7
  static get identifiersFields(): GenericIdentifier[];
11
8
  }
@@ -2,14 +2,14 @@ import { CrudRepository } from '../../generic/repository/crud.repository';
2
2
  import { Product } from '../models';
3
3
  import { Category } from '../models/category';
4
4
  import { Shops } from '../models/enums/shops.enum';
5
- export interface CategoryRepository<T extends Category = Category> extends CrudRepository<T> {
5
+ export interface CategoryRepository extends CrudRepository<Category> {
6
6
  getCategoryBySlug(slug: string, shop: Shops): Promise<Category>;
7
7
  getCategoryByShop(shop: string): Promise<Category[]>;
8
- getCategoriesForHome(categoryIds: string[], shop: Shops, limit?: number): Promise<{
8
+ getCategoriesForHome(categoryIds: string[], limit?: number, gender?: string): Promise<{
9
9
  category: Category;
10
10
  products: Product[];
11
11
  }[]>;
12
- mountCategory(category: Category, shop: Shops, options?: {
12
+ mountCategory(category: Category, options?: {
13
13
  limit?: number;
14
14
  hasStock?: boolean;
15
15
  }): Promise<Product[]>;
@@ -1,6 +1,5 @@
1
1
  export * from './category-collection-children.repository';
2
2
  export * from './category-filter.repository';
3
- export * from './category-product.repository';
4
3
  export * from './category.repository';
5
4
  export * from './filter-option.repository';
6
5
  export * from './filter.repository';
@@ -3,5 +3,4 @@ import { ProductReviews } from '../models';
3
3
  export interface ProductReviewsRepository extends CrudRepository<ProductReviews> {
4
4
  aproveReview(id: number): Promise<ProductReviews>;
5
5
  disaproveReview(id: number): Promise<ProductReviews>;
6
- updateManyStatus(reviews: Pick<ProductReviews, 'id' | 'status'>[]): Promise<void>;
7
6
  }
@@ -1,13 +1,5 @@
1
- import { RepositoryFindResult } from '../../generic';
2
1
  import { CrudRepository } from '../../generic/repository/crud.repository';
3
- import { ProductStockNotification, ReportStockNotification, ReportStockNotificationInput, Shops } from '../models';
2
+ import { ProductStockNotification, Shops } from '../models';
4
3
  export interface ProductStockNotificationRepository extends CrudRepository<ProductStockNotification> {
5
4
  addCustomerEmail(shop: Shops, productId: string, name: string, email: string): Promise<void>;
6
- getNotificationsReport(params: ReportStockNotificationInput, orderBy: {
7
- field: string;
8
- direction: string;
9
- }, pagination?: {
10
- offset: number;
11
- limit: number;
12
- }): Promise<RepositoryFindResult<ReportStockNotification>>;
13
5
  }
@@ -1,6 +1,6 @@
1
1
  import { FindRepositoryParams, RepositoryFindResult } from '../../generic';
2
2
  import { CrudRepository } from '../../generic/repository/crud.repository';
3
- import { Product, ProductGender, ProductReview, ProductVariantReport } from '../models';
3
+ import { Product, ProductGender, ProductReview } from '../models';
4
4
  export type ReviewStatusParams = 'pending' | 'approved' | 'rejected';
5
5
  export type ReviewWithProductData = ProductReview & {
6
6
  productId: string;
@@ -25,5 +25,4 @@ export interface ProductRepository extends CrudRepository<Product> {
25
25
  fetchProductReviews(filters: PaginatedReviewFilters): Promise<ReviewWithProductData[]>;
26
26
  cleanShoppingCountFromIds(ids: string[]): Promise<any>;
27
27
  findCatalog(params: FindRepositoryParams<Product>, mainGender?: Extract<ProductGender, 'female' | 'male' | 'unisex'>): Promise<RepositoryFindResult<Product>>;
28
- productVariantFullReport(): Promise<ProductVariantReport[]>;
29
28
  }
@@ -1,11 +1,6 @@
1
1
  import { CategoryRepository } from '.';
2
- import { FindRepositoryParams, RepositoryFindResult } from '../../generic';
3
- import { Shops } from '../models';
4
2
  import { Wishlist } from '../models/wishlist';
5
- export interface WishlistRepository extends CategoryRepository<Wishlist> {
3
+ export interface WishlistRepository extends CategoryRepository {
6
4
  getWishlistBySlug(slug: string): Promise<Wishlist>;
7
5
  getWishlistByPerson(personId: string): Promise<Wishlist[]>;
8
- findBfluOrGlamgirlWishlists(params: FindRepositoryParams<Wishlist>, shops: Shops[]): Promise<RepositoryFindResult<Wishlist>>;
9
- addProduct(wishlistId: string, productId: string): Promise<void>;
10
- removeProduct(wishlistId: string, productId: string): Promise<void>;
11
6
  }
@@ -1,4 +1 @@
1
- export * from './models';
2
- export * from './repositories';
3
- export * from './search';
4
1
  export * from './storage';
@@ -1,3 +1,2 @@
1
1
  export * from './models';
2
2
  export * from './repositories';
3
- export * from './types';
@@ -11,8 +11,6 @@ export declare class Buy2Win extends BaseModel<Buy2Win> {
11
11
  shop: Shops;
12
12
  activeCategory?: boolean;
13
13
  cartValueMin?: number;
14
- cartItensQuantityMin?: number;
15
- type: 'items' | 'value';
16
14
  startDate: Date;
17
15
  updatedAt?: Date;
18
16
  categories: Category[];
@@ -1,15 +1,11 @@
1
1
  import { Shops } from '../../../catalog/models/enums/shops.enum';
2
2
  import { BaseModel, GenericIdentifier } from '../../../generic/model/base.model';
3
3
  import { CheckoutTypes } from '../enums/checkout-types.enum';
4
- import { CouponCategory as CouponOldCategory, CouponTypes, Exclusivities } from './enums';
4
+ import { CouponTypes, Exclusivities } from './enums';
5
5
  import { ClubeDaMensPlan } from './enums/coupon-club-mens.enum';
6
- import { CouponCategory, CouponChannel } from './types';
7
6
  export declare class Coupon extends BaseModel<Coupon> {
8
7
  id: string;
9
- category?: CouponOldCategory;
10
- oldCategory?: CouponOldCategory;
11
- newCategory?: CouponCategory;
12
- channel?: CouponChannel;
8
+ category?: string;
13
9
  discount: {
14
10
  subscriber: {
15
11
  type: CouponTypes;
@@ -52,7 +48,6 @@ export declare class Coupon extends BaseModel<Coupon> {
52
48
  expiresIn?: Date;
53
49
  shopAvailability: Shops;
54
50
  personId?: number;
55
- personEmail?: string;
56
51
  influencerEmail?: string;
57
52
  plan?: ClubeDaMensPlan;
58
53
  productsCategories: string[];
@@ -61,7 +56,8 @@ export declare class Coupon extends BaseModel<Coupon> {
61
56
  createdAt: Date;
62
57
  updatedAt?: Date;
63
58
  checkoutType: CheckoutTypes;
64
- exclusivityType?: Exclusivities[];
59
+ exclusivityType?: [Exclusivities];
65
60
  get isInfluencer(): boolean;
66
61
  static get identifiersFields(): GenericIdentifier[];
62
+ static createCoupon(userId: string): Coupon;
67
63
  }
@@ -1,5 +1,4 @@
1
1
  export declare enum CouponTypes {
2
2
  ABSOLUTE = 1,
3
- PERCENTAGE = 2,
4
- SHIPPING = 3
3
+ PERCENTAGE = 2
5
4
  }
@@ -1,5 +1,3 @@
1
- export * from './coupon-category.enum';
2
- export * from './coupon-channels.enum';
3
- export * from './coupon-subtypes.enum';
4
1
  export * from './coupon-types.enum';
2
+ export * from './coupon-subtypes.enum';
5
3
  export * from './exclusivities.enum';
@@ -6,7 +6,6 @@ export * from './coupons';
6
6
  export * from './enums';
7
7
  export * from './line-item';
8
8
  export * from './order';
9
- export * from './order-blocked';
10
9
  export * from './payment';
11
10
  export * from './shipping-method';
12
11
  export * from './subscription';
@@ -1,4 +1,3 @@
1
- import { OrderTrackingEvent } from '../types';
2
1
  import { Checkout } from './checkout';
3
2
  import { OrderStatus } from './enums/order-status.enum';
4
3
  import { Payment } from './payment';
@@ -7,8 +6,5 @@ export declare class Order extends Checkout {
7
6
  orderNumber?: string;
8
7
  trackingCode?: string;
9
8
  trackingUrl?: string;
10
- sentAt?: string;
11
- deliveredAt?: string;
12
- trackingEvents?: OrderTrackingEvent[];
13
9
  payment: Payment;
14
10
  }
@@ -4,7 +4,6 @@ export * from './campaign-hashtag.repository';
4
4
  export * from './checkout.repository';
5
5
  export * from './coupon.repository';
6
6
  export * from './legacy-order.repository';
7
- export * from './order-blocked.repository';
8
7
  export * from './order.repository';
9
8
  export * from './payment.repository';
10
9
  export * from './subscription';
@@ -16,6 +16,5 @@ export * from './hair-problems.enum';
16
16
  export * from './hair-strands.enum';
17
17
  export * from './hair-types.enum';
18
18
  export * from './office-position.enum';
19
- export * from './person-types.enum';
20
19
  export * from './product-spents.enum';
21
20
  export * from './user-type.enum';
@@ -1,8 +1,7 @@
1
- export * from './beauty-profile';
2
1
  export * from './enums';
3
- export * from './lead';
4
2
  export * from './subscription';
5
- export * from './types';
6
3
  export * from './user';
4
+ export * from './beauty-profile';
7
5
  export * from './user-address';
8
6
  export * from './user-payment-method';
7
+ export * from './lead';
@@ -6,45 +6,7 @@ export declare class ProductsIndex {
6
6
  private index;
7
7
  constructor(adapter: ElasticSearchAdapter<Product>);
8
8
  getById(id: string): Promise<Product>;
9
- search(searchTerm: string, total: number, shop?: string): Promise<{
10
- stock: number;
11
- category: import("../../../domain/catalog/models/category-for-product").CategoryForProduct;
12
- kitProducts?: import("../../../domain").KitProduct[];
13
- id: string;
14
- name: string;
15
- slug: string;
16
- description: import("../../../domain").ShopDescription;
17
- sku: string;
18
- price: import("../../../domain").ShopPrice;
19
- hasVariants: boolean;
20
- NCM: string;
21
- EAN: string;
22
- CEST: string;
23
- weight: number;
24
- costPrice: number;
25
- images?: string[];
26
- miniatures?: string[];
27
- published: boolean;
28
- createdAt?: Date;
29
- updatedAt?: Date;
30
- brand: string;
31
- tags?: string[];
32
- filters?: string[];
33
- type?: string;
34
- categories?: string[];
35
- reviews?: import("../../../domain").ProductReview[];
36
- variants?: import("../../../domain").Variant[];
37
- video?: string;
38
- isKit?: boolean;
39
- rate?: number;
40
- gender?: import("../../../domain").ProductGender;
41
- shoppingCount?: number;
42
- metadata: import("../../../domain").ProductMetadata;
43
- outlet?: boolean;
44
- label?: "outlet" | "on-sale" | "last-units" | "glamstar";
45
- group?: number;
46
- validity: boolean;
47
- }[]>;
9
+ search(searchTerm: string, total: number, shop: string): Promise<import("..").ElasticSearchResult<Product>>;
48
10
  save(product: ProductHasuraGraphQL): Promise<void>;
49
11
  update(product: ProductHasuraGraphQL): Promise<void>;
50
12
  delete(id: string): Promise<void>;
@@ -5,7 +5,7 @@ import { FirestoreRepository, FirestoreSubRepository } from '../types';
5
5
  export declare const withHelpers: <TMixinBase extends MixinCtor = MixinCtor>(MixinBase: MixinCtor & TMixinBase) => {
6
6
  new (...args: any[]): {
7
7
  [x: string]: any;
8
- toArray<T extends ModelBaseStructure<T>>(snapShot: QuerySnapshot<T, import("firebase/firestore").DocumentData> | QueryDocumentSnapshot<T, import("firebase/firestore").DocumentData>[]): T[];
8
+ toArray<T extends ModelBaseStructure<T>>(snapShot: QuerySnapshot<T, import("@firebase/firestore").DocumentData> | QueryDocumentSnapshot<T, import("@firebase/firestore").DocumentData>[]): T[];
9
9
  isSubCollection<T_1 extends ModelBaseStructure<T_1>, E extends ModelBaseStructure<E>>(repository: FirestoreRepository<T_1> | FirestoreSubRepository<T_1, E>): repository is FirestoreSubRepository<T_1, E>;
10
10
  };
11
11
  } & TMixinBase;
@@ -4,11 +4,11 @@ declare const CategoryFirestoreRepository_base: import("../../../../../utils").M
4
4
  export declare class CategoryFirestoreRepository extends CategoryFirestoreRepository_base implements CategoryRepository {
5
5
  constructor({ firestore, interceptors }: Pick<FirestoreConstructorParams<Category>, 'firestore' | 'interceptors'>);
6
6
  getCategoryBySlug(slug: string, shop: Shops): Promise<Category>;
7
- getCategoriesForHome(categoryIds: string[], shop: Shops, limit?: number): Promise<{
7
+ getCategoriesForHome(categoryIds: string[], limit?: number, gender?: string): Promise<{
8
8
  category: Category;
9
9
  products: Product[];
10
10
  }[]>;
11
- mountCategory(category: Category, shop: Shops, options?: {
11
+ mountCategory(category: Category, options?: {
12
12
  limit?: number;
13
13
  hasStock?: boolean;
14
14
  gender?: string;
@@ -1,4 +1,4 @@
1
- import { FindRepositoryParams, PaginatedReviewFilters, Product, ProductRepository, ProductVariantReport, RepositoryFindResult, ReviewStatusParams, ReviewWithProductData } from '../../../../../domain';
1
+ import { FindRepositoryParams, PaginatedReviewFilters, Product, ProductRepository, RepositoryFindResult, ReviewStatusParams, ReviewWithProductData } from '../../../../../domain';
2
2
  import { FirestoreConstructorParams } from '../../mixins';
3
3
  declare const ProductFirestoreRepository_base: import("../../../../../utils").MixinCtor<import("../..").FirestoreRepository<Product> & import("../../../../../domain").CrudRepository<Product, import("../../../../../domain").CrudParams<Product>> & import("../..").FirestoreHelpers, [FirestoreConstructorParams<Product>, ...any[]]>;
4
4
  export declare class ProductFirestoreRepository extends ProductFirestoreRepository_base implements ProductRepository {
@@ -10,6 +10,5 @@ export declare class ProductFirestoreRepository extends ProductFirestoreReposito
10
10
  cleanShoppingCountFromIds(): Promise<void>;
11
11
  findCatalog(params: FindRepositoryParams<Product>): Promise<RepositoryFindResult<Product>>;
12
12
  fetchPaginatedReviews(): Promise<ReviewWithProductData[]>;
13
- productVariantFullReport(): Promise<ProductVariantReport[]>;
14
13
  }
15
14
  export {};
@@ -1,5 +1,4 @@
1
+ export * from './users';
1
2
  export * from './catalog';
2
- export * from './general';
3
- export * from './shop-settings';
4
3
  export * from './shopping';
5
- export * from './users';
4
+ export * from './shop-settings';
@@ -5,7 +5,6 @@ export * from './checkout-firestore.repository';
5
5
  export * from './checkout-subscription-firestore.repository';
6
6
  export * from './coupon-firestore.repository';
7
7
  export * from './legacy-order-firestore.repository';
8
- export * from './order-blocked-firestore.repository.ts';
9
8
  export * from './order-firestore.repository';
10
9
  export * from './payment-firestore.repository';
11
10
  export * from './subscription-plan-firestore.repository';
@@ -3,7 +3,6 @@ import { DebugHelper, MixinCtor } from '../../../utils';
3
3
  import { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types';
4
4
  export declare const withFindHasuraGraphQL: <MBase extends ModelBaseStructure<MBase, MBase["identifiersFields"][number]>, TMixinBase extends MixinCtor<GraphQLRepository<MBase>>>(MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase) => {
5
5
  new (...args: any[]): {
6
- lastDistinct: Record<string, any>;
7
6
  find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>>;
8
7
  bindOrderByAttributes: (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) => any[];
9
8
  bindAggretageAttributes: (aggregates: {
@@ -15,11 +15,11 @@ export declare class CategoryHasuraGraphQLRepository extends CategoryHasuraGraph
15
15
  update(params: UpdateRepositoryParams<CategoryHasuraGraphQL>): Promise<CategoryHasuraGraphQL>;
16
16
  getCategoryBySlug(slug: string, shop: Shops): Promise<Category>;
17
17
  getCategoryByShop(shop: string): Promise<Category[]>;
18
- getCategoriesForHome(categoryIds: string[], shop: Shops, limit?: number): Promise<{
18
+ getCategoriesForHome(categoryIds: string[], limit?: number, gender?: string): Promise<{
19
19
  category: Category;
20
20
  products: Product[];
21
21
  }[]>;
22
- mountCategory(category: Category, shop: Shops, options?: {
22
+ mountCategory(category: Category, options?: {
23
23
  limit?: number;
24
24
  hasStock?: boolean;
25
25
  gender?: string;
@@ -1,7 +1,6 @@
1
1
  export * from './category-collection-children-hasura-graphql.repository';
2
2
  export * from './category-filter-hasura-graphql.repository';
3
3
  export * from './category-hasura-graphql.repository';
4
- export * from './category-product-hasura-graphql.repository';
5
4
  export * from './filter-hasura-graphql.repository';
6
5
  export * from './filter-option-hasura-graphql.repository';
7
6
  export * from './product-hasura-graphql.repository';
@@ -1,4 +1,4 @@
1
- import { CreateRepositoryParams, FindRepositoryParams, GetRepositoryParams, ProductGender, ProductRepository, ProductVariantReport, RepositoryFindResult, ReviewStatusParams, ReviewWithProductData, UpdateRepositoryParams } from '../../../../domain';
1
+ import { CreateRepositoryParams, FindRepositoryParams, GetRepositoryParams, ProductGender, ProductRepository, RepositoryFindResult, ReviewStatusParams, ReviewWithProductData, UpdateRepositoryParams } from '../../../../domain';
2
2
  import { HasuraConstructorParams } from '../../mixins';
3
3
  import { ProductHasuraGraphQL } from '../../models';
4
4
  declare const ProductHasuraGraphQLRepository_base: import("../../../../utils").MixinCtor<import("../../types").GraphQLRepository<ProductHasuraGraphQL> & import("../../../../domain").CrudRepository<ProductHasuraGraphQL, import("../../../../domain").CrudParams<ProductHasuraGraphQL>> & import("../../../../domain").UpdateRepository<ProductHasuraGraphQL, import("../../../../domain").RepositoryUpdateParams<ProductHasuraGraphQL>> & {
@@ -17,6 +17,7 @@ export declare class ProductHasuraGraphQLRepository extends ProductHasuraGraphQL
17
17
  findCatalog(params: FindRepositoryParams<ProductHasuraGraphQL>, mainGender?: Extract<ProductGender, 'female' | 'male'>): Promise<RepositoryFindResult<ProductHasuraGraphQL>>;
18
18
  cleanShoppingCountFromIds(ids: string[]): Promise<void>;
19
19
  private getReviewStatus;
20
+ private updateCategories;
20
21
  private updateKitProducts;
21
22
  private updateReviews;
22
23
  private updateMetadata;
@@ -27,6 +28,5 @@ export declare class ProductHasuraGraphQLRepository extends ProductHasuraGraphQL
27
28
  private getReviewByAuthorAndEmail;
28
29
  private bindReviewToModel;
29
30
  private bindReviewToHasura;
30
- productVariantFullReport(): Promise<ProductVariantReport[]>;
31
31
  }
32
32
  export {};
@@ -6,7 +6,6 @@ declare const ProductReviewsHasuraGraphQLRepository_base: import("../../../../ut
6
6
  }, [HasuraConstructorParams<ProductReviews> & import("../../mixins").CreateConstructorParams & import("../../mixins").DeleteConstructorParams & import("../../mixins").GetConstructorParams & import("../../mixins").UpdateConstructorParams, ...any[]]>;
7
7
  export declare class ProductReviewsHasuraGraphQLRepository extends ProductReviewsHasuraGraphQLRepository_base implements ProductReviewsRepository {
8
8
  constructor({ endpoint, authOptions, interceptors, }: Pick<HasuraConstructorParams<ProductReviews>, 'endpoint' | 'authOptions' | 'interceptors'>);
9
- updateManyStatus(reviews: Pick<ProductReviews, 'id' | 'status'>[]): Promise<void>;
10
9
  aproveReview(id: number): Promise<ProductReviews>;
11
10
  disaproveReview(id: number): Promise<ProductReviews>;
12
11
  }
@@ -1,4 +1,4 @@
1
- import { Filter, ProductStockNotification, ReportStockNotification, ReportStockNotificationInput, RepositoryFindResult, Shops } from '../../../../domain';
1
+ import { Filter, ProductStockNotification, Shops } from '../../../../domain';
2
2
  import { ProductStockNotificationRepository } from '../../../../domain/catalog/repositories';
3
3
  import { HasuraConstructorParams } from '../../mixins';
4
4
  declare const ProductStockNotificationHasuraGraphQLRepository_base: import("../../../../utils").MixinCtor<import("../..").GraphQLRepository<ProductStockNotification> & import("../../../../domain").CrudRepository<ProductStockNotification, import("../../../../domain").CrudParams<ProductStockNotification>> & import("../../../../domain").UpdateRepository<ProductStockNotification, import("../../../../domain").RepositoryUpdateParams<ProductStockNotification>> & {
@@ -7,12 +7,5 @@ declare const ProductStockNotificationHasuraGraphQLRepository_base: import("../.
7
7
  export declare class ProductStockNotificationHasuraGraphQLRepository extends ProductStockNotificationHasuraGraphQLRepository_base implements ProductStockNotificationRepository {
8
8
  constructor({ endpoint, authOptions, interceptors, }: Pick<HasuraConstructorParams<Filter>, 'endpoint' | 'authOptions' | 'interceptors'>);
9
9
  addCustomerEmail(shop: Shops, productId: string, name: string, email: string): Promise<void>;
10
- getNotificationsReport(params: ReportStockNotificationInput, orderBy: {
11
- field: string;
12
- direction: string;
13
- }, pagination?: {
14
- offset: number;
15
- limit: number;
16
- }): Promise<RepositoryFindResult<ReportStockNotification>>;
17
10
  }
18
11
  export {};
@@ -1,31 +1,28 @@
1
1
  import { Category, CreateRepositoryParams, FindRepositoryParams, GetRepositoryParams, Product, RepositoryFindResult, Shops, UpdateRepositoryParams, Wishlist, WishlistRepository } from '../../../../domain';
2
2
  import { HasuraConstructorParams } from '../../mixins';
3
- import { WishlistHasuraGraphQL } from '../../models/wishlist-hasura-graphql';
4
- import { CategoryProductHasuraGraphQLRepository } from './category-product-hasura-graphql.repository';
5
- declare const WishlistHasuraGraphQLRepository_base: import("../../../../utils").MixinCtor<import("../..").GraphQLRepository<WishlistHasuraGraphQL> & import("../../../../domain").CrudRepository<WishlistHasuraGraphQL, import("../../../../domain").CrudParams<WishlistHasuraGraphQL>> & import("../../../../domain").UpdateRepository<WishlistHasuraGraphQL, import("../../../../domain").RepositoryUpdateParams<WishlistHasuraGraphQL>> & {
6
- paramsToPlain(params: import("../../../../domain").RepositoryUpdateParams<WishlistHasuraGraphQL>): Partial<WishlistHasuraGraphQL>;
7
- }, [HasuraConstructorParams<WishlistHasuraGraphQL> & import("../../mixins").CreateConstructorParams & import("../../mixins").DeleteConstructorParams & import("../../mixins").GetConstructorParams & import("../../mixins").UpdateConstructorParams, ...any[]]>;
3
+ import { CategoryFilterHasuraGraphQLRepository } from './category-filter-hasura-graphql.repository';
4
+ declare const WishlistHasuraGraphQLRepository_base: import("../../../../utils").MixinCtor<import("../..").GraphQLRepository<Wishlist> & import("../../../../domain").CrudRepository<Wishlist, import("../../../../domain").CrudParams<Wishlist>> & import("../../../../domain").UpdateRepository<Wishlist, import("../../../../domain").RepositoryUpdateParams<Wishlist>> & {
5
+ paramsToPlain(params: import("../../../../domain").RepositoryUpdateParams<Wishlist>): Partial<Wishlist>;
6
+ }, [HasuraConstructorParams<Wishlist> & import("../../mixins").CreateConstructorParams & import("../../mixins").DeleteConstructorParams & import("../../mixins").GetConstructorParams & import("../../mixins").UpdateConstructorParams, ...any[]]>;
8
7
  export declare class WishlistHasuraGraphQLRepository extends WishlistHasuraGraphQLRepository_base implements WishlistRepository {
9
- private readonly categoryProductRepository;
10
- constructor({ endpoint, authOptions, interceptors, }: Pick<HasuraConstructorParams<Wishlist>, 'endpoint' | 'authOptions' | 'interceptors'>, categoryProductRepository: CategoryProductHasuraGraphQLRepository);
11
- create(params: CreateRepositoryParams<WishlistHasuraGraphQL>): Promise<WishlistHasuraGraphQL>;
12
- get(identifiers: GetRepositoryParams<WishlistHasuraGraphQL>): Promise<WishlistHasuraGraphQL>;
13
- find(params?: FindRepositoryParams<WishlistHasuraGraphQL>): Promise<RepositoryFindResult<WishlistHasuraGraphQL>>;
14
- update(params: UpdateRepositoryParams<WishlistHasuraGraphQL>): Promise<WishlistHasuraGraphQL>;
15
- getWishlistBySlug(slug: string): Promise<WishlistHasuraGraphQL>;
16
- getWishlistByPerson(personId: string): Promise<WishlistHasuraGraphQL[]>;
8
+ private readonly categoryFilterRepository;
9
+ constructor({ endpoint, authOptions, interceptors, }: Pick<HasuraConstructorParams<Wishlist>, 'endpoint' | 'authOptions' | 'interceptors'>, categoryFilterRepository: CategoryFilterHasuraGraphQLRepository);
10
+ create(params: CreateRepositoryParams<Wishlist>): Promise<Wishlist>;
11
+ get(identifiers: GetRepositoryParams<Wishlist>): Promise<Wishlist>;
12
+ find(params?: FindRepositoryParams<Wishlist>): Promise<RepositoryFindResult<Wishlist>>;
13
+ update(params: UpdateRepositoryParams<Wishlist>): Promise<Wishlist>;
14
+ getWishlistBySlug(slug: string): Promise<Wishlist>;
15
+ getWishlistByPerson(personId: string): Promise<Wishlist[]>;
17
16
  getCategoryBySlug(slug: string, _shop: Shops): Promise<Wishlist>;
18
17
  getCategoryByShop(shop: string): Promise<any>;
19
- findBfluOrGlamgirlWishlists(params: FindRepositoryParams<WishlistHasuraGraphQL>, shops: Shops[]): Promise<RepositoryFindResult<WishlistHasuraGraphQL>>;
20
- getCategoriesForHome(categoryIds: string[], gender?: string, limit?: number): any;
21
- mountCategory(category: Category, shop: Shops, options?: {
18
+ getCategoriesForHome(categoryIds: string[], limit?: number, gender?: string): any;
19
+ mountCategory(category: Category, options?: {
22
20
  limit?: number;
23
21
  hasStock?: boolean;
24
22
  }): Promise<Product[]>;
25
23
  getChildren(parentId: number): Promise<Category[]>;
26
24
  isChild(id: number, parentId: number): Promise<boolean>;
25
+ private updateProducts;
27
26
  private updateMetadata;
28
- addProduct(wishlistId: string, productId: string): Promise<void>;
29
- removeProduct(wishlistId: string, productId: string): Promise<void>;
30
27
  }
31
28
  export {};
@@ -1,4 +1,3 @@
1
1
  export * from './elasticsearch';
2
2
  export * from './firebase';
3
3
  export * from './hasura-graphql';
4
- export * from './vertex-ai';
@@ -1,8 +0,0 @@
1
- import { BaseModel } from '../../generic/model';
2
- export type CategoryProductIdentifiers = 'productId' | 'categoryId';
3
- export declare class CategoryProduct extends BaseModel<CategoryProduct, CategoryProductIdentifiers> {
4
- categoryId: number;
5
- productId: number;
6
- order: number;
7
- static get identifiersFields(): CategoryProductIdentifiers[];
8
- }
@@ -1,6 +0,0 @@
1
- export declare enum ProductLabelEnum {
2
- ON_SALE = "on-sale",
3
- OUTLET = "outlet",
4
- LAST_UNITS = "last-units",
5
- GLAMSTAR = "glamstar"
6
- }
@@ -1,7 +0,0 @@
1
- export declare enum WishlistLogType {
2
- CREATE = "create",
3
- UPDATE = "update",
4
- DELETE = "delete",
5
- ADD_PRODUCT = "add_product",
6
- REMOVE_PRODUCT = "remove_product"
7
- }
@@ -1,2 +0,0 @@
1
- import { ProductLabelEnum } from '../enums';
2
- export type ProductLabel = `${ProductLabelEnum}`;