@infrab4a/connect 3.15.0-beta.1 → 3.16.0-beta.1

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 (54) hide show
  1. package/bundles/infrab4a-connect.umd.js +706 -148
  2. package/bundles/infrab4a-connect.umd.js.map +1 -1
  3. package/domain/catalog/models/category-base.d.ts +30 -0
  4. package/domain/catalog/models/category-filter.d.ts +2 -0
  5. package/domain/catalog/models/category-for-product.d.ts +5 -0
  6. package/domain/catalog/models/category.d.ts +5 -27
  7. package/domain/catalog/models/index.d.ts +1 -0
  8. package/domain/catalog/models/kit-product.d.ts +3 -3
  9. package/domain/catalog/models/product-base.d.ts +40 -0
  10. package/domain/catalog/models/product-for-category.d.ts +7 -0
  11. package/domain/catalog/models/product-for-kit.d.ts +7 -0
  12. package/domain/catalog/models/product.d.ts +5 -40
  13. package/domain/catalog/models/wishlist.d.ts +6 -0
  14. package/domain/catalog/repositories/category-filter.repository.d.ts +1 -0
  15. package/domain/catalog/repositories/index.d.ts +1 -0
  16. package/domain/catalog/repositories/product.repository.d.ts +1 -1
  17. package/domain/catalog/repositories/wishlist.repository.d.ts +6 -0
  18. package/domain/generic/repository/find.repository.d.ts +1 -0
  19. package/domain/generic/repository/types/repository-find-result.type.d.ts +3 -0
  20. package/esm2015/domain/catalog/models/category-base.js +18 -0
  21. package/esm2015/domain/catalog/models/category-filter.js +6 -1
  22. package/esm2015/domain/catalog/models/category-for-product.js +7 -0
  23. package/esm2015/domain/catalog/models/category.js +6 -10
  24. package/esm2015/domain/catalog/models/index.js +2 -1
  25. package/esm2015/domain/catalog/models/kit-product.js +6 -6
  26. package/esm2015/domain/catalog/models/product-base.js +25 -0
  27. package/esm2015/domain/catalog/models/product-for-category.js +14 -0
  28. package/esm2015/domain/catalog/models/product-for-kit.js +14 -0
  29. package/esm2015/domain/catalog/models/product.js +6 -24
  30. package/esm2015/domain/catalog/models/wishlist.js +7 -0
  31. package/esm2015/domain/catalog/repositories/category-filter.repository.js +1 -1
  32. package/esm2015/domain/catalog/repositories/index.js +2 -1
  33. package/esm2015/domain/catalog/repositories/product.repository.js +1 -1
  34. package/esm2015/domain/catalog/repositories/wishlist.repository.js +2 -0
  35. package/esm2015/domain/generic/repository/find.repository.js +1 -1
  36. package/esm2015/domain/generic/repository/types/repository-find-result.type.js +1 -1
  37. package/esm2015/infra/elasticsearch/indexes/products-index.js +2 -2
  38. package/esm2015/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.js +2 -2
  39. package/esm2015/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.js +44 -14
  40. package/esm2015/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.js +52 -1
  41. package/esm2015/infra/hasura-graphql/repositories/catalog/category-hasura-graphql.repository.js +36 -50
  42. package/esm2015/infra/hasura-graphql/repositories/catalog/index.js +2 -1
  43. package/esm2015/infra/hasura-graphql/repositories/catalog/product-hasura-graphql.repository.js +2 -2
  44. package/esm2015/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.js +252 -0
  45. package/esm2015/infra/hasura-graphql/types/graphql.repository.type.js +1 -1
  46. package/fesm2015/infrab4a-connect.js +469 -104
  47. package/fesm2015/infrab4a-connect.js.map +1 -1
  48. package/infra/hasura-graphql/mixins/with-find-hasura-graphql.mixin.d.ts +3 -2
  49. package/infra/hasura-graphql/mixins/with-get-hasura-graphql.mixin.d.ts +2 -2
  50. package/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.d.ts +1 -0
  51. package/infra/hasura-graphql/repositories/catalog/index.d.ts +1 -0
  52. package/infra/hasura-graphql/repositories/catalog/wishlist-hasura-graphql.repository.d.ts +27 -0
  53. package/infra/hasura-graphql/types/graphql.repository.type.d.ts +4 -3
  54. package/package.json +1 -1
@@ -13,7 +13,7 @@ export class ProductsIndex {
13
13
  }
14
14
  search(searchTerm, total, shop) {
15
15
  return __awaiter(this, void 0, void 0, function* () {
16
- const size = total >= 10 ? 500 : 9;
16
+ const size = total || 9;
17
17
  const fields = [
18
18
  'EAN',
19
19
  'brand',
@@ -112,4 +112,4 @@ export class ProductsIndex {
112
112
  });
113
113
  }
114
114
  }
115
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdHMtaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9lbGFzdGljc2VhcmNoL2luZGV4ZXMvcHJvZHVjdHMtaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsS0FBSyxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFJMUUsTUFBTSxPQUFPLGFBQWE7SUFFeEIsWUFBNkIsT0FBc0M7UUFBdEMsWUFBTyxHQUFQLE9BQU8sQ0FBK0I7UUFEM0QsVUFBSyxHQUFHLFVBQVUsQ0FBQTtJQUM0QyxDQUFDO0lBRWpFLE9BQU8sQ0FBQyxFQUFVOztZQUN0QixNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFDbkQsT0FBTyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ2pDLENBQUM7S0FBQTtJQUVLLE1BQU0sQ0FBQyxVQUFrQixFQUFFLEtBQWEsRUFBRSxJQUFZOztZQUMxRCxNQUFNLElBQUksR0FBVyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQTtZQUUxQyxNQUFNLE1BQU0sR0FBRztnQkFDYixLQUFLO2dCQUNMLE9BQU87Z0JBQ1AsSUFBSTtnQkFDSixRQUFRO2dCQUNSLFlBQVk7Z0JBQ1osTUFBTTtnQkFDTixPQUFPO2dCQUNQLEtBQUs7Z0JBQ0wsT0FBTztnQkFDUCxNQUFNO2dCQUNOLFNBQVM7Z0JBQ1QsYUFBYTtnQkFDYixNQUFNO2FBQ1AsQ0FBQTtZQUVELE1BQU0sTUFBTSxHQUFrRSxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQTtZ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QTthQUNyQjtRQUNILENBQUM7S0FBQTtDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvZHVjdCwgUm91bmRQcm9kdWN0UHJpY2VzSGVscGVyLCBTaG9wcyB9IGZyb20gJy4uLy4uLy4uL2RvbWFpbidcbmltcG9ydCB7IFByb2R1Y3RIYXN1cmFHcmFwaFFMIH0gZnJvbSAnLi4vLi4vaGFzdXJhLWdyYXBocWwnXG5pbXBvcnQgeyBFbGFzdGljU2VhcmNoQWRhcHRlciB9IGZyb20gJy4uL2FkYXB0ZXJzJ1xuXG5leHBvcnQgY2xhc3MgUHJvZHVjdHNJbmRleCB7XG4gIHByaXZhdGUgaW5kZXggPSBgcHJvZHVjdHNgXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgYWRhcHRlcjogRWxhc3RpY1NlYXJjaEFkYXB0ZXI8UHJvZHVjdD4pIHt9XG5cbiAgYXN5bmMgZ2V0QnlJZChpZDogc3RyaW5nKTogUHJvbWlzZTxQcm9kdWN0PiB7XG4gICAgY29uc3QgZGF0YSA9IGF3YWl0IHRoaXMuYWRhcHRlci5nZXQodGhpcy5pbmRleCwgaWQpXG4gICAgcmV0dXJuIFByb2R1Y3QudG9JbnN0YW5jZShkYXRhKVxuICB9XG5cbiAgYXN5bmMgc2VhcmNoKHNlYXJjaFRlcm06IHN0cmluZywgdG90YWw6IG51bWJlciwgc2hvcDogc3RyaW5nKSB7XG4gICAgY29uc3Qgc2l6ZTogbnVtYmVyID0gdG90YWwgPj0gMTAgPyA1MDAgOiA5XG5cbiAgICBjb25zdCBmaWVsZHMgPSBbXG4gICAgICAnRUFOJyxcbiAgICAgICdicmFuZCcsXG4gICAgICAnaWQnLFxuICAgICAgJ2ltYWdlcycsXG4gICAgICAnbWluaWF0dXJlcycsXG4gICAgICAnbmFtZScsXG4gICAgICAncHJpY2UnLFxuICAgICAgJ3NrdScsXG4gICAgICAnc3RvY2snLFxuICAgICAgJ3NsdWcnLFxuICAgICAgJ3Jldmlld3MnLFxuICAgICAgJ2hhc1ZhcmlhbnRzJyxcbiAgICAgICdyYXRlJyxcbiAgICBdXG5cbiAgICBjb25zdCBmaWx0ZXI6IEFycmF5PHsgdGVybTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCBib29sZWFuIHwgbnVtYmVyIH0gfT4gPSBbeyB0ZXJtOiB7IHB1Ymxpc2hlZDogdHJ1ZSB9IH1dXG5cbiAgICBpZiAoc2l6ZSA+IDkpIHtcbiAgICAgIGZpZWxkcy5wdXNoKC4uLlsncHJpY2VQYWlkJywgJ2lzR2lmdCcsICdzdG9jaycsICd3ZWlnaHQnLCAndGFncyddKVxuICAgIH0gZWxzZSB7XG4gICAgICBmaWx0ZXIucHVzaCh7IHRlcm06IHsgdGFnczogc2hvcCA9PSBTaG9wcy5HTEFNU0hPUCA/ICdmZW1pbmlubycgOiAnbWFzY3VsaW5vJyB9IH0pXG4gICAgfVxuXG4gICAgY29uc3Qgc2VhcmNoID0gYXdhaXQgdGhpcy5hZGFwdGVyLnF1ZXJ5KHRoaXMuaW5kZXgsIHtcbiAgICAgIHNpemUsXG4gICAgICBfc291cmNlOiBmaWVsZHMsXG4gICAgICBxdWVyeToge1xuICAgICAgICBib29sOiB7XG4gICAgICAgICAgbXVzdDoge1xuICAgICAgICAgICAgbXVsdGlfbWF0Y2g6IHtcbiAgICAgICAgICAgICAgcXVlcnk6IGAke3NlYXJjaFRlcm19YCxcbiAgICAgICAgICAgICAgdHlwZTogJ2Jvb2xfcHJlZml4JyxcbiAgICAgICAgICAgICAgZmllbGRzOiBbXG4gICAgICAgICAgICAgICAgJ25hbWUnLFxuICAgICAgICAgICAgICAgICduYW1lLmZvbGRlZCcsXG4gICAgICAgICAgICAgICAgJ25hbWUuc2VhcmNoJyxcbiAgICAgICAgICAgICAgICAnZGVzY3JpcHRpb24nLFxuICAgICAgICAgICAgICAgICdkZXNjcmlwdGlvbi5zZWFyY2gnLFxuICAgICAgICAgICAgICAgICdkZXNjcmlwdGlvbi5mb2xkZWQnLFxuICAgICAgICAgICAgICAgICdicmFuZCcsXG4gICAgICAgICAgICAgICAgJ2JyYW5kLnNlYXJjaCcsXG4gICAgICAgICAgICAgICAgJ2JyYW5kLmZvbGRlZCcsXG4gICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgIGZ1enppbmVzczogMixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgICBzaG91bGQ6IHtcbiAgICAgICAgICAgIG1hdGNoX3BocmFzZV9wcmVmaXg6IHtcbiAgICAgICAgICAgICAgJ25hbWUuc2VhcmNoJzoge1xuICAgICAgICAgICAgICAgIHF1ZXJ5OiBgJHtzZWFyY2hUZXJtfWAsXG4gICAgICAgICAgICAgICAgc2xvcDogMTAsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgICAgZmlsdGVyLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgc2VhcmNoLmhpdHMgPSBzZWFyY2guaGl0c1xuICAgICAgLmZpbHRlcigoZTogYW55KSA9PiBlLl9zb3VyY2UubmFtZSAhPT0gJycpXG4gICAgICAubWFwKChoaXQpID0+IHtcbiAgICAgICAgUm91bmRQcm9kdWN0UHJpY2VzSGVscGVyLnJvdW5kUHJvZHVjdFByaWNlcyhoaXQuX3NvdXJjZSlcbiAgICAgICAgcmV0dXJuIGhpdFxuICAgICAgfSlcblxuICAgIHJldHVybiBzZWFyY2hcbiAgfVxuXG4gIGFzeW5jIHNhdmUocHJvZHVjdDogUHJvZHVjdEhhc3VyYUdyYXBoUUwpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgeyBjcmVhdGVkQXQsIHVwZGF0ZWRBdCwga2l0UHJvZHVjdHMsIC4uLmRhdGEgfSA9IHByb2R1Y3RcblxuICAgICAgdGhpcy5hZGFwdGVyLnNhdmUodGhpcy5pbmRleCwgZGF0YSlcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICB9XG4gIH1cblxuICBhc3luYyB1cGRhdGUocHJvZHVjdDogUHJvZHVjdEhhc3VyYUdyYXBoUUwpIHtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgdGhpcy5hZGFwdGVyLnVwZGF0ZSh0aGlzLmluZGV4LCBwcm9kdWN0LmlkLCBwcm9kdWN0KVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycm9yKVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGRlbGV0ZShpZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IHRoaXMuYWRhcHRlci5kZWxldGUodGhpcy5pbmRleCwgaWQpXG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpXG4gICAgfVxuICB9XG59XG4iXX0=
115
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdHMtaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9lbGFzdGljc2VhcmNoL2luZGV4ZXMvcHJvZHVjdHMtaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsS0FBSyxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFJMUUsTUFBTSxPQUFPLGFBQWE7SUFFeEIsWUFBNkIsT0FBc0M7UUFBdEMsWUFBTyxHQUFQLE9BQU8sQ0FBK0I7UUFEM0QsVUFBSyxHQUFHLFVBQVUsQ0FBQTtJQUM0QyxDQUFDO0lBRWpFLE9BQU8sQ0FBQyxFQUFVOztZQUN0QixNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7WUFDbkQsT0FBTyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFBO1FBQ2pDLENBQUM7S0FBQTtJQUVLLE1BQU0sQ0FBQyxVQUFrQixFQUFFLEtBQWEsRUFBRSxJQUFZOztZQUMxRCxNQUFNLElBQUksR0FBVyxLQUFLLElBQUksQ0FBQyxDQUFBO1lBRS9CLE1BQU0sTUFBTSxHQUFHO2dCQUNiLEtBQUs7Z0JBQ0wsT0FBTztnQkFDUCxJQUFJO2dCQUNKLFFBQVE7Z0JBQ1IsWUFBWTtnQkFDWixNQUFNO2dCQUNOLE9BQU87Z0JBQ1AsS0FBSztnQkFDTCxPQUFPO2dCQUNQLE1BQU07Z0JBQ04sU0FBUztnQkFDVCxhQUFhO2dCQUNiLE1BQU07YUFDUCxDQUFBO1lBRUQsTUFBTSxNQUFNLEdBQWtFLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxTQUFTLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFBO1lBRTdHLElBQUksSUFBSSxHQUFHLENBQUMsRUFBRTtnQkFDWixNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTthQUNuRTtpQkFBTTtnQkFDTCxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsQ0FBQTthQUNuRjtZQUVELE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRTtnQkFDbEQsSUFBSTtnQkFDSixPQUFPLEVBQUUsTUFBTTtnQkFDZixLQUFLLEVBQUU7b0JBQ0wsSUFBSSxFQUFFO3dCQUNKLElBQUksRUFBRTs0QkFDSixXQUFXLEVBQUU7Z0NBQ1gsS0FBSyxFQUFFLEdBQUcsVUFBVSxFQUFFO2dDQUN0QixJQUFJLEVBQUUsYUFBYTtnQ0FDbkIsTUFBTSxFQUFFO29DQUNOLE1BQU07b0NBQ04sYUFBYTtvQ0FDYixhQUFhO29DQUNiLGFBQWE7b0NBQ2Isb0JBQW9CO29DQUNwQixvQkFBb0I7b0NBQ3BCLE9BQU87b0NBQ1AsY0FBYztvQ0FDZCxjQUFjO2lDQUNmO2dDQUNELFNBQVMsRUFBRSxDQUFDOzZCQUNiO3lCQUNGO3dCQUNELE1BQU0sRUFBRTs0QkFDTixtQkFBbUIsRUFBRTtnQ0FDbkIsYUFBYSxFQUFFO29DQUNiLEtBQUssRUFBRSxHQUFHLFVBQVUsRUFBRTtvQ0FDdEIsSUFBSSxFQUFFLEVBQUU7aUNBQ1Q7NkJBQ0Y7eUJBQ0Y7d0JBQ0QsTUFBTTtxQkFDUDtpQkFDRjthQUNGLENBQUMsQ0FBQTtZQUVGLE1BQU0sQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUk7aUJBQ3RCLE1BQU0sQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEtBQUssRUFBRSxDQUFDO2lCQUN6QyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDWCx3QkFBd0IsQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUE7Z0JBQ3hELE9BQU8sR0FBRyxDQUFBO1lBQ1osQ0FBQyxDQUFDLENBQUE7WUFFSixPQUFPLE1BQU0sQ0FBQTtRQUNmLENBQUM7S0FBQTtJQUVLLElBQUksQ0FBQyxPQUE2Qjs7WUFDdEMsSUFBSTtnQkFDRixNQUFNLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxXQUFXLEtBQWMsT0FBTyxFQUFoQixJQUFJLFVBQUssT0FBTyxFQUF4RCx5Q0FBOEMsQ0FBVSxDQUFBO2dCQUU5RCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFBO2FBQ3BDO1lBQUMsT0FBTyxLQUFLLEVBQUU7Z0JBQ2QsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQTthQUNyQjtRQUNILENBQUM7S0FBQTtJQUVLLE1BQU0sQ0FBQyxPQUE2Qjs7WUFDeEMsSUFBSTtnQkFDRixNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQTthQUMzRDtZQUFDLE9BQU8sS0FBSyxFQUFFO2dCQUNkLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUE7YUFDckI7UUFDSCxDQUFDO0tBQUE7SUFFSyxNQUFNLENBQUMsRUFBVTs7WUFDckIsSUFBSTtnQkFDRixNQUFNLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUE7YUFDMUM7WUFBQyxPQUFPLEtBQUssRUFBRTtnQkFDZCxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFBO2FBQ3JCO1FBQ0gsQ0FBQztLQUFBO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9kdWN0LCBSb3VuZFByb2R1Y3RQcmljZXNIZWxwZXIsIFNob3BzIH0gZnJvbSAnLi4vLi4vLi4vZG9tYWluJ1xuaW1wb3J0IHsgUHJvZHVjdEhhc3VyYUdyYXBoUUwgfSBmcm9tICcuLi8uLi9oYXN1cmEtZ3JhcGhxbCdcbmltcG9ydCB7IEVsYXN0aWNTZWFyY2hBZGFwdGVyIH0gZnJvbSAnLi4vYWRhcHRlcnMnXG5cbmV4cG9ydCBjbGFzcyBQcm9kdWN0c0luZGV4IHtcbiAgcHJpdmF0ZSBpbmRleCA9IGBwcm9kdWN0c2BcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBhZGFwdGVyOiBFbGFzdGljU2VhcmNoQWRhcHRlcjxQcm9kdWN0Pikge31cblxuICBhc3luYyBnZXRCeUlkKGlkOiBzdHJpbmcpOiBQcm9taXNlPFByb2R1Y3Q+IHtcbiAgICBjb25zdCBkYXRhID0gYXdhaXQgdGhpcy5hZGFwdGVyLmdldCh0aGlzLmluZGV4LCBpZClcbiAgICByZXR1cm4gUHJvZHVjdC50b0luc3RhbmNlKGRhdGEpXG4gIH1cblxuICBhc3luYyBzZWFyY2goc2VhcmNoVGVybTogc3RyaW5nLCB0b3RhbDogbnVtYmVyLCBzaG9wOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzaXplOiBudW1iZXIgPSB0b3RhbCB8fCA5XG5cbiAgICBjb25zdCBmaWVsZHMgPSBbXG4gICAgICAnRUFOJyxcbiAgICAgICdicmFuZCcsXG4gICAgICAnaWQnLFxuICAgICAgJ2ltYWdlcycsXG4gICAgICAnbWluaWF0dXJlcycsXG4gICAgICAnbmFtZScsXG4gICAgICAncHJpY2UnLFxuICAgICAgJ3NrdScsXG4gICAgICAnc3RvY2snLFxuICAgICAgJ3NsdWcnLFxuICAgICAgJ3Jldmlld3MnLFxuICAgICAgJ2hhc1ZhcmlhbnRzJyxcbiAgICAgICdyYXRlJyxcbiAgICBdXG5cbiAgICBjb25zdCBmaWx0ZXI6IEFycmF5PHsgdGVybTogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfCBib29sZWFuIHwgbnVtYmVyIH0gfT4gPSBbeyB0ZXJtOiB7IHB1Ymxpc2hlZDogdHJ1ZSB9IH1dXG5cbiAgICBpZiAoc2l6ZSA+IDkpIHtcbiAgICAgIGZpZWxkcy5wdXNoKC4uLlsncHJpY2VQYWlkJywgJ2lzR2lmdCcsICdzdG9jaycsICd3ZWlnaHQnLCAndGFncyddKVxuICAgIH0gZWxzZSB7XG4gICAgICBmaWx0ZXIucHVzaCh7IHRlcm06IHsgdGFnczogc2hvcCA9PSBTaG9wcy5HTEFNU0hPUCA/ICdmZW1pbmlubycgOiAnbWFzY3VsaW5vJyB9IH0pXG4gICAgfVxuXG4gICAgY29uc3Qgc2VhcmNoID0gYXdhaXQgdGhpcy5hZGFwdGVyLnF1ZXJ5KHRoaXMuaW5kZXgsIHtcbiAgICAgIHNpemUsXG4gICAgICBfc291cmNlOiBmaWVsZHMsXG4gICAgICBxdWVyeToge1xuICAgICAgICBib29sOiB7XG4gICAgICAgICAgbXVzdDoge1xuICAgICAgICAgICAgbXVsdGlfbWF0Y2g6IHtcbiAgICAgICAgICAgICAgcXVlcnk6IGAke3NlYXJjaFRlcm19YCxcbiAgICAgICAgICAgICAgdHlwZTogJ2Jvb2xfcHJlZml4JyxcbiAgICAgICAgICAgICAgZmllbGRzOiBbXG4gICAgICAgICAgICAgICAgJ25hbWUnLFxuICAgICAgICAgICAgICAgICduYW1lLmZvbGRlZCcsXG4gICAgICAgICAgICAgICAgJ25hbWUuc2VhcmNoJyxcbiAgICAgICAgICAgICAgICAnZGVzY3JpcHRpb24nLFxuICAgICAgICAgICAgICAgICdkZXNjcmlwdGlvbi5zZWFyY2gnLFxuICAgICAgICAgICAgICAgICdkZXNjcmlwdGlvbi5mb2xkZWQnLFxuICAgICAgICAgICAgICAgICdicmFuZCcsXG4gICAgICAgICAgICAgICAgJ2JyYW5kLnNlYXJjaCcsXG4gICAgICAgICAgICAgICAgJ2JyYW5kLmZvbGRlZCcsXG4gICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgIGZ1enppbmVzczogMixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgICBzaG91bGQ6IHtcbiAgICAgICAgICAgIG1hdGNoX3BocmFzZV9wcmVmaXg6IHtcbiAgICAgICAgICAgICAgJ25hbWUuc2VhcmNoJzoge1xuICAgICAgICAgICAgICAgIHF1ZXJ5OiBgJHtzZWFyY2hUZXJtfWAsXG4gICAgICAgICAgICAgICAgc2xvcDogMTAsXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICB9LFxuICAgICAgICAgIH0sXG4gICAgICAgICAgZmlsdGVyLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KVxuXG4gICAgc2VhcmNoLmhpdHMgPSBzZWFyY2guaGl0c1xuICAgICAgLmZpbHRlcigoZTogYW55KSA9PiBlLl9zb3VyY2UubmFtZSAhPT0gJycpXG4gICAgICAubWFwKChoaXQpID0+IHtcbiAgICAgICAgUm91bmRQcm9kdWN0UHJpY2VzSGVscGVyLnJvdW5kUHJvZHVjdFByaWNlcyhoaXQuX3NvdXJjZSlcbiAgICAgICAgcmV0dXJuIGhpdFxuICAgICAgfSlcblxuICAgIHJldHVybiBzZWFyY2hcbiAgfVxuXG4gIGFzeW5jIHNhdmUocHJvZHVjdDogUHJvZHVjdEhhc3VyYUdyYXBoUUwpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgeyBjcmVhdGVkQXQsIHVwZGF0ZWRBdCwga2l0UHJvZHVjdHMsIC4uLmRhdGEgfSA9IHByb2R1Y3RcblxuICAgICAgdGhpcy5hZGFwdGVyLnNhdmUodGhpcy5pbmRleCwgZGF0YSlcbiAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgY29uc29sZS5lcnJvcihlcnJvcilcbiAgICB9XG4gIH1cblxuICBhc3luYyB1cGRhdGUocHJvZHVjdDogUHJvZHVjdEhhc3VyYUdyYXBoUUwpIHtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgdGhpcy5hZGFwdGVyLnVwZGF0ZSh0aGlzLmluZGV4LCBwcm9kdWN0LmlkLCBwcm9kdWN0KVxuICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycm9yKVxuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGRlbGV0ZShpZDogc3RyaW5nKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdHJ5IHtcbiAgICAgIGF3YWl0IHRoaXMuYWRhcHRlci5kZWxldGUodGhpcy5pbmRleCwgaWQpXG4gICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoZXJyb3IpXG4gICAgfVxuICB9XG59XG4iXX0=
@@ -26,7 +26,7 @@ BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
26
26
  const fieldOptions = AttributeOptionHelper.FindByAttribute(key, (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || fields);
27
27
  const columnName = fieldOptions.columnName;
28
28
  const columnFields = fieldOptions.fields;
29
- return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, options[key], columnFields || []) });
29
+ return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, options[key], (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || columnFields || fields) });
30
30
  }, {});
31
31
  if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
32
32
  return {
@@ -55,4 +55,4 @@ BindFilterQueryHelper.GetHasuraJsonbOperator = (options) => {
55
55
  return '_has_keys_any';
56
56
  return HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator === Object.keys(Where).find((operator) => Where[operator] === (options === null || options === void 0 ? void 0 : options.operator)))];
57
57
  };
58
- //# 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 {\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  Where,\n} from '../../../../domain'\nimport { isNil, isObject } from '../../../../utils'\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\n\nimport { AttributeOptionHelper } from './attribute-option.helper'\nimport { FilterOptionHelper } from './filter-option.helper'\n\nexport class BindFilterQueryHelper {\n  static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\n    filter: RepositoryFindFielters<MBase>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions =>\n    Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\n      const columnOption = AttributeOptionHelper.FindByAttribute(\n        fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n        fields,\n      )\n\n      if (!columnOption.bindFindFilter)\n        return {\n          ...variables,\n          ...{\n            [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              filter[fieldName],\n              fields,\n            ),\n          },\n        }\n\n      const builtFilter: RepositoryFindFieltersOptions<\n        MBase,\n        NonFunctionPropertyNames<MBase>\n      > = columnOption.bindFindFilter(filter[fieldName])\n\n      return {\n        ...variables,\n        ...Object.keys(builtFilter).reduce(\n          (variablesList: VariableOptions, columnName: string) => ({\n            ...variablesList,\n            [columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              builtFilter[columnName],\n              fields,\n            ),\n          }),\n          {},\n        ),\n      }\n    }, {})\n\n  static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\n    field: NonFunctionAndIdentifierPropertyNames<MBase>,\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions => {\n    const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\n    const isNestedField =\n      !Array.isArray(options) &&\n      isObject(options) &&\n      isNil(options?.operator) &&\n      isNil(options?.value) &&\n      isNil(fieldSentenceOptions?.to)\n\n    if (isNestedField)\n      return Object.keys(options).reduce((variables, key) => {\n        const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\n          key as NonFunctionAndIdentifierPropertyNames<MBase>,\n          fieldSentenceOptions?.fields || (fields as any),\n        )\n        const columnName = fieldOptions.columnName\n        const columnFields = fieldOptions.fields\n\n        return {\n          ...variables,\n          [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\n            key as NonFunctionAndIdentifierPropertyNames<MBase>,\n            options[key],\n            columnFields || ([] as any),\n          ),\n        }\n      }, {})\n\n    if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\n      return {\n        [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\n          BindFilterQueryHelper.BuildOperatorSentence(\n            options,\n            fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n          ),\n      }\n\n    if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\n      options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\n\n    return Array.isArray(options)\n      ? options.reduce(\n          (whereSentence, option) => ({\n            ...whereSentence,\n            ...BindFilterQueryHelper.BuildOperatorSentence(\n              option,\n              fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n            ),\n          }),\n          {},\n        )\n      : BindFilterQueryHelper.BuildOperatorSentence(\n          options,\n          fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n        )\n  }\n\n  static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, any>,\n    fieldOption: ColumnOptions<any, any>,\n  ): VariableOptions => ({\n    [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\n      options,\n      fieldOption,\n    ),\n  })\n\n  static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fieldOption: ColumnOptions<any, any>,\n  ): HasuraGraphQLWhere => {\n    if (!FilterOptionHelper.CheckIfIsFilterOption(options)) return HasuraGraphQLWhere.EQUALS\n    if (fieldOption.type === HasuraGraphQLColumnType.Jsonb) return BindFilterQueryHelper.GetHasuraJsonbOperator(options)\n\n    return HasuraGraphQLWhere[\n      Object.keys(HasuraGraphQLWhere).find(\n        (graphQLOperator) =>\n          graphQLOperator === Object.keys(Where).find((operator) => Where[operator] === options?.operator),\n      )\n    ]\n  }\n\n  static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n  ): HasuraGraphQLWhere => {\n    if (options.operator === Where.IN) return '_contains' as HasuraGraphQLWhere\n    if (options.operator === Where.LIKE) return '_has_keys_any' as HasuraGraphQLWhere\n\n    return HasuraGraphQLWhere[\n      Object.keys(HasuraGraphQLWhere).find(\n        (graphQLOperator) =>\n          graphQLOperator === Object.keys(Where).find((operator) => Where[operator] === options?.operator),\n      )\n    ]\n  }\n}\n"]}
58
+ //# 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 {\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  Where,\n} from '../../../../domain'\nimport { isNil, isObject } from '../../../../utils'\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\n\nimport { AttributeOptionHelper } from './attribute-option.helper'\nimport { FilterOptionHelper } from './filter-option.helper'\n\nexport class BindFilterQueryHelper {\n  static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\n    filter: RepositoryFindFielters<MBase>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions =>\n    Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\n      const columnOption = AttributeOptionHelper.FindByAttribute(\n        fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n        fields,\n      )\n\n      if (!columnOption.bindFindFilter)\n        return {\n          ...variables,\n          ...{\n            [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              filter[fieldName],\n              fields,\n            ),\n          },\n        }\n\n      const builtFilter: RepositoryFindFieltersOptions<\n        MBase,\n        NonFunctionPropertyNames<MBase>\n      > = columnOption.bindFindFilter(filter[fieldName])\n\n      return {\n        ...variables,\n        ...Object.keys(builtFilter).reduce(\n          (variablesList: VariableOptions, columnName: string) => ({\n            ...variablesList,\n            [columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              builtFilter[columnName],\n              fields,\n            ),\n          }),\n          {},\n        ),\n      }\n    }, {})\n\n  static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\n    field: NonFunctionAndIdentifierPropertyNames<MBase>,\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions => {\n    const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\n    const isNestedField =\n      !Array.isArray(options) &&\n      isObject(options) &&\n      isNil(options?.operator) &&\n      isNil(options?.value) &&\n      isNil(fieldSentenceOptions?.to)\n\n    if (isNestedField)\n      return Object.keys(options).reduce((variables, key) => {\n        const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\n          key as NonFunctionAndIdentifierPropertyNames<MBase>,\n          fieldSentenceOptions?.fields || (fields as any),\n        )\n        const columnName = fieldOptions.columnName\n        const columnFields = fieldOptions.fields\n\n        return {\n          ...variables,\n          [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\n            key as NonFunctionAndIdentifierPropertyNames<MBase>,\n            options[key],\n            fieldSentenceOptions?.fields || columnFields || (fields as any),\n          ),\n        }\n      }, {})\n\n    if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\n      return {\n        [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\n          BindFilterQueryHelper.BuildOperatorSentence(\n            options,\n            fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n          ),\n      }\n\n    if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\n      options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\n\n    return Array.isArray(options)\n      ? options.reduce(\n          (whereSentence, option) => ({\n            ...whereSentence,\n            ...BindFilterQueryHelper.BuildOperatorSentence(\n              option,\n              fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n            ),\n          }),\n          {},\n        )\n      : BindFilterQueryHelper.BuildOperatorSentence(\n          options,\n          fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n        )\n  }\n\n  static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, any>,\n    fieldOption: ColumnOptions<any, any>,\n  ): VariableOptions => ({\n    [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\n      options,\n      fieldOption,\n    ),\n  })\n\n  static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fieldOption: ColumnOptions<any, any>,\n  ): HasuraGraphQLWhere => {\n    if (!FilterOptionHelper.CheckIfIsFilterOption(options)) return HasuraGraphQLWhere.EQUALS\n    if (fieldOption.type === HasuraGraphQLColumnType.Jsonb) return BindFilterQueryHelper.GetHasuraJsonbOperator(options)\n\n    return HasuraGraphQLWhere[\n      Object.keys(HasuraGraphQLWhere).find(\n        (graphQLOperator) =>\n          graphQLOperator === Object.keys(Where).find((operator) => Where[operator] === options?.operator),\n      )\n    ]\n  }\n\n  static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n  ): HasuraGraphQLWhere => {\n    if (options.operator === Where.IN) return '_contains' as HasuraGraphQLWhere\n    if (options.operator === Where.LIKE) return '_has_keys_any' as HasuraGraphQLWhere\n\n    return HasuraGraphQLWhere[\n      Object.keys(HasuraGraphQLWhere).find(\n        (graphQLOperator) =>\n          graphQLOperator === Object.keys(Where).find((operator) => Where[operator] === options?.operator),\n      )\n    ]\n  }\n}\n"]}
@@ -26,17 +26,27 @@ export const withFindHasuraGraphQL = (MixinBase) => {
26
26
  : []),
27
27
  ];
28
28
  };
29
+ this.bindDistinctAttributes = (distinct, fields) => this.bindAttributesToColumns(distinct, fields);
29
30
  this.bindAttributesToColumns = (attributes, fields) => attributes.map((attr) => {
30
31
  var _a;
31
32
  return ((_a = AttributeOptionHelper.FindByAttribute(attr.toString().split('.').pop(), fields)) === null || _a === void 0 ? void 0 : _a.columnName) || attr;
32
33
  });
33
34
  }
34
35
  find(params) {
35
- var _a, _b, _c;
36
+ var _a, _b, _c, _d, _e, _f, _g, _h;
36
37
  return __awaiter(this, void 0, void 0, function* () {
37
38
  this.logger = DebugHelper.from(this, 'find');
38
39
  const { filters, limits, orderBy, options } = params || {};
39
40
  const enableCount = (_a = options === null || options === void 0 ? void 0 : options.enableCount) !== null && _a !== void 0 ? _a : true;
41
+ const variablesFilters = isNil(filters)
42
+ ? {}
43
+ : {
44
+ where: {
45
+ value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),
46
+ type: `${this.tableName}_bool_exp`,
47
+ required: true,
48
+ },
49
+ };
40
50
  const variablesCount = Object.assign(Object.assign({}, (isNil(orderBy)
41
51
  ? {}
42
52
  : {
@@ -45,15 +55,7 @@ export const withFindHasuraGraphQL = (MixinBase) => {
45
55
  list: true,
46
56
  value: this.bindOrderByAttributes(orderBy, this.fields),
47
57
  },
48
- })), (isNil(filters)
49
- ? {}
50
- : {
51
- where: {
52
- value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),
53
- type: `${this.tableName}_bool_exp`,
54
- required: true,
55
- },
56
- }));
58
+ })), variablesFilters);
57
59
  const variables = Object.assign(Object.assign({}, (isNil(limits) ? {} : limits)), variablesCount);
58
60
  const aggregateFields = [
59
61
  ...(enableCount ? ['count'] : []),
@@ -85,25 +87,53 @@ export const withFindHasuraGraphQL = (MixinBase) => {
85
87
  },
86
88
  ]
87
89
  : []),
90
+ ...((!((_b = params.limits) === null || _b === void 0 ? void 0 : _b.offset) &&
91
+ ((_d = (_c = params.options) === null || _c === void 0 ? void 0 : _c.distinct) === null || _d === void 0 ? void 0 : _d.map((distinct) => {
92
+ var _a, _b;
93
+ const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === distinct)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct);
94
+ const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || distinct;
95
+ return {
96
+ operation: {
97
+ name: `${this.tableName}`,
98
+ alias: `${this.tableName}_${distinct}_distinct`,
99
+ },
100
+ fields: [distinctOption],
101
+ variables: Object.assign(Object.assign({}, variablesFilters), { [`${this.tableName}_${fieldName}_distinct`]: {
102
+ type: `${this.tableName}_select_column!`,
103
+ list: true,
104
+ value: fieldName,
105
+ name: 'distinct_on',
106
+ } }),
107
+ };
108
+ }))) ||
109
+ []),
88
110
  ]);
89
111
  const data = result[this.tableName].map((row) => this.convertDataFromHasura(row));
90
- 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)
112
+ return Object.assign(Object.assign(Object.assign({ data, count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity }, (((_e = options === null || options === void 0 ? void 0 : options.minimal) === null || _e === void 0 ? void 0 : _e.length)
91
113
  ? {
92
114
  minimal: options.minimal.reduce((minimals, current) => {
93
115
  var _a;
94
116
  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])));
95
117
  }, {}),
96
118
  }
97
- : {})), (((_c = options === null || options === void 0 ? void 0 : options.maximum) === null || _c === void 0 ? void 0 : _c.length)
119
+ : {})), (((_f = options === null || options === void 0 ? void 0 : options.maximum) === null || _f === void 0 ? void 0 : _f.length)
98
120
  ? {
99
121
  maximum: options.maximum.reduce((maximums, current) => {
100
122
  var _a;
101
123
  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])));
102
124
  }, {}),
103
125
  }
104
- : {}));
126
+ : {})), (!((_g = params.limits) === null || _g === void 0 ? void 0 : _g.offset) &&
127
+ ((_h = options === null || options === void 0 ? void 0 : options.distinct) === null || _h === void 0 ? void 0 : _h.length) && {
128
+ distinct: options === null || options === void 0 ? void 0 : options.distinct.reduce((distinct, current) => {
129
+ var _a, _b;
130
+ const distinctOption = (_a = this.fields.find((fieldOption) => fieldOption === current)) !== null && _a !== void 0 ? _a : this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current);
131
+ const fieldName = ((_b = Object.values(distinctOption).shift()) === null || _b === void 0 ? void 0 : _b.columnName) || current;
132
+ return Object.assign(Object.assign({}, distinct), { [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map((obj) => obj[fieldName]) });
133
+ }, {}),
134
+ }));
105
135
  });
106
136
  }
107
137
  };
108
138
  };
109
- //# 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 {\n  FindRepository,\n  FindRepositoryParams,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  RepositoryFindResult,\n  RepositoryOrderBy,\n} from '../../../domain'\nimport { DebugHelper, isNil, MixinCtor, set } from '../../../utils'\nimport { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types'\nimport { AttributeOptionHelper, BindFilterQueryHelper } from './helpers'\n\nexport const withFindHasuraGraphQL = <\n  MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\n  TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\n>(\n  MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\n) => {\n  return class FindHasuraGraphQLMixin extends MixinBase implements FindRepository<MBase> {\n    async find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>> {\n      this.logger = DebugHelper.from(this, 'find')\n\n      const { filters, limits, orderBy, options } = params || {}\n      const enableCount = options?.enableCount ?? true\n      const variablesCount = {\n        ...(isNil(orderBy)\n          ? {}\n          : {\n              order_by: {\n                type: `${this.tableName}_order_by!`,\n                list: true,\n                value: this.bindOrderByAttributes(orderBy, this.fields),\n              },\n            }),\n        ...(isNil(filters)\n          ? {}\n          : {\n              where: {\n                value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),\n                type: `${this.tableName}_bool_exp`,\n                required: true,\n              },\n            }),\n      }\n      const variables = {\n        ...(isNil(limits) ? {} : limits),\n        ...variablesCount,\n      }\n      const aggregateFields = [\n        ...(enableCount ? ['count'] : []),\n        ...this.bindAggretageAttributes(params.options, this.fields),\n      ]\n      const result = await this.query([\n        {\n          operation: this.tableName,\n          fields: params.fields\n            ? params.fields\n                .map(\n                  (fieldName) =>\n                    this.fields.find((fieldOption) => fieldOption === fieldName) ??\n                    this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName),\n                )\n                .filter(Boolean)\n            : this.fields,\n          variables,\n        },\n        ...(aggregateFields.length > 0\n          ? [\n              {\n                operation: `${this.tableName}_aggregate`,\n                fields: [\n                  {\n                    aggregate: aggregateFields,\n                  },\n                ],\n                variables: variablesCount,\n              } as GraphQLParams<MBase>,\n            ]\n          : []),\n      ])\n      const data: MBase[] = result[this.tableName].map((row) => this.convertDataFromHasura(row))\n\n      return {\n        data,\n        count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity,\n        ...(options?.minimal?.length\n          ? {\n              minimal: options.minimal.reduce(\n                (minimals, current) => ({\n                  ...(minimals as any),\n                  ...set(\n                    minimals,\n                    current,\n                    result[`${this.tableName}_aggregate`].aggregate.min[\n                      AttributeOptionHelper.FindByAttribute(\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n                        this.fields,\n                      )?.columnName || (current as any)\n                    ],\n                  ),\n                }),\n                {},\n              ),\n            }\n          : {}),\n        ...(options?.maximum?.length\n          ? {\n              maximum: options.maximum.reduce(\n                (maximums, current) => ({\n                  ...(maximums as any),\n                  ...set(\n                    maximums,\n                    current,\n                    result[`${this.tableName}_aggregate`].aggregate.max[\n                      AttributeOptionHelper.FindByAttribute(\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n                        this.fields,\n                      )?.columnName || (current as any)\n                    ],\n                  ),\n                }),\n                {},\n              ),\n            }\n          : {}),\n      }\n    }\n\n    bindOrderByAttributes = (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) =>\n      Object.keys(orderBy).reduce(\n        (acc, current) => ({\n          ...acc,\n          [AttributeOptionHelper.FindByAttribute(current as NonFunctionAndIdentifierPropertyNames<MBase>, fields)\n            .columnName]: orderBy[current as NonFunctionAndIdentifierPropertyNames<MBase>],\n        }),\n        {},\n      )\n\n    bindAggretageAttributes = (\n      aggregates: {\n        minimal?: FindRepositoryParams<MBase>['options']['minimal']\n        maximum?: FindRepositoryParams<MBase>['options']['maximum']\n      },\n      fields: HasuraGraphQLFields<MBase>,\n    ) => [\n      ...(aggregates?.minimal?.length\n        ? [\n            {\n              min: this.bindAttributesToColumns(aggregates?.minimal, fields),\n            },\n          ]\n        : []),\n      ...(aggregates?.maximum?.length\n        ? [\n            {\n              max: this.bindAttributesToColumns(aggregates?.maximum, fields),\n            },\n          ]\n        : []),\n    ]\n\n    bindAttributesToColumns = (\n      attributes: Array<NonFunctionAndIdentifierPropertyNames<MBase> | {}>,\n      fields: HasuraGraphQLFields<MBase>,\n    ) =>\n      attributes.map(\n        (attr) =>\n          AttributeOptionHelper.FindByAttribute(\n            attr.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n            fields,\n          )?.columnName || attr,\n      )\n  }\n}\n"]}
139
+ //# 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 {\n  FindRepository,\n  FindRepositoryParams,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  RepositoryFindResult,\n  RepositoryOrderBy,\n} from '../../../domain'\nimport { DebugHelper, isNil, MixinCtor, set } from '../../../utils'\nimport { GraphQLParams, GraphQLRepository, HasuraGraphQLFields } from '../types'\nimport { AttributeOptionHelper, BindFilterQueryHelper } from './helpers'\n\nexport const withFindHasuraGraphQL = <\n  MBase extends ModelBaseStructure<MBase, MBase['identifiersFields'][number]>,\n  TMixinBase extends MixinCtor<GraphQLRepository<MBase>>,\n>(\n  MixinBase: MixinCtor<GraphQLRepository<MBase>> & TMixinBase,\n) => {\n  return class FindHasuraGraphQLMixin extends MixinBase implements FindRepository<MBase> {\n    async find(params?: FindRepositoryParams<MBase>): Promise<RepositoryFindResult<MBase>> {\n      this.logger = DebugHelper.from(this, 'find')\n\n      const { filters, limits, orderBy, options } = params || {}\n      const enableCount = options?.enableCount ?? true\n      const variablesFilters = isNil(filters)\n        ? {}\n        : {\n            where: {\n              value: BindFilterQueryHelper.MakeGraphQLWhere(filters, this.fields),\n              type: `${this.tableName}_bool_exp`,\n              required: true,\n            },\n          }\n      const variablesCount = {\n        ...(isNil(orderBy)\n          ? {}\n          : {\n              order_by: {\n                type: `${this.tableName}_order_by!`,\n                list: true,\n                value: this.bindOrderByAttributes(orderBy, this.fields),\n              },\n            }),\n        ...variablesFilters,\n      }\n      const variables = {\n        ...(isNil(limits) ? {} : limits),\n        ...variablesCount,\n      }\n      const aggregateFields = [\n        ...(enableCount ? ['count'] : []),\n        ...this.bindAggretageAttributes(params.options, this.fields),\n      ]\n      const result = await this.query([\n        {\n          operation: this.tableName,\n          fields: params.fields\n            ? params.fields\n                .map(\n                  (fieldName) =>\n                    this.fields.find((fieldOption) => fieldOption === fieldName) ??\n                    this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === fieldName),\n                )\n                .filter(Boolean)\n            : this.fields,\n          variables,\n        },\n        ...(aggregateFields.length > 0\n          ? [\n              {\n                operation: `${this.tableName}_aggregate`,\n                fields: [\n                  {\n                    aggregate: aggregateFields,\n                  },\n                ],\n                variables: variablesCount,\n              } as GraphQLParams<MBase>,\n            ]\n          : []),\n        ...((!params.limits?.offset &&\n          params.options?.distinct?.map((distinct) => {\n            const distinctOption =\n              this.fields.find((fieldOption) => fieldOption === distinct) ??\n              this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === distinct)\n            const fieldName = Object.values(distinctOption).shift()?.columnName || distinct\n\n            return {\n              operation: {\n                name: `${this.tableName}`,\n                alias: `${this.tableName}_${distinct}_distinct`,\n              },\n              fields: [distinctOption],\n              variables: {\n                ...variablesFilters,\n                [`${this.tableName}_${fieldName}_distinct`]: {\n                  type: `${this.tableName}_select_column!`,\n                  list: true,\n                  value: fieldName,\n                  name: 'distinct_on',\n                },\n              },\n            } as GraphQLParams<MBase>\n          })) ||\n          []),\n      ])\n      const data: MBase[] = result[this.tableName].map((row) => this.convertDataFromHasura(row))\n\n      return {\n        data,\n        count: enableCount ? result[`${this.tableName}_aggregate`].aggregate.count : Infinity,\n        ...(options?.minimal?.length\n          ? {\n              minimal: options.minimal.reduce(\n                (minimals, current) => ({\n                  ...(minimals as any),\n                  ...set(\n                    minimals,\n                    current,\n                    result[`${this.tableName}_aggregate`].aggregate.min[\n                      AttributeOptionHelper.FindByAttribute(\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n                        this.fields,\n                      )?.columnName || (current as any)\n                    ],\n                  ),\n                }),\n                {},\n              ),\n            }\n          : {}),\n        ...(options?.maximum?.length\n          ? {\n              maximum: options.maximum.reduce(\n                (maximums, current) => ({\n                  ...(maximums as any),\n                  ...set(\n                    maximums,\n                    current,\n                    result[`${this.tableName}_aggregate`].aggregate.max[\n                      AttributeOptionHelper.FindByAttribute(\n                        current.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n                        this.fields,\n                      )?.columnName || (current as any)\n                    ],\n                  ),\n                }),\n                {},\n              ),\n            }\n          : {}),\n        ...(!params.limits?.offset &&\n          options?.distinct?.length && {\n            distinct: options?.distinct.reduce((distinct, current) => {\n              const distinctOption =\n                this.fields.find((fieldOption) => fieldOption === current) ??\n                this.fields.find((fieldOption) => Object.keys(fieldOption).shift() === current)\n              const fieldName = Object.values(distinctOption).shift()?.columnName || current\n\n              return {\n                ...distinct,\n                [current.toString()]: result[`${this.tableName}_${current.toString()}_distinct`].map(\n                  (obj) => obj[fieldName],\n                ),\n              }\n            }, {} as any),\n          }),\n      }\n    }\n\n    bindOrderByAttributes = (orderBy: RepositoryOrderBy<MBase>, fields: HasuraGraphQLFields<MBase>) =>\n      Object.keys(orderBy).reduce(\n        (acc, current) => ({\n          ...acc,\n          [AttributeOptionHelper.FindByAttribute(current as NonFunctionAndIdentifierPropertyNames<MBase>, fields)\n            .columnName]: orderBy[current as NonFunctionAndIdentifierPropertyNames<MBase>],\n        }),\n        {},\n      )\n\n    bindAggretageAttributes = (\n      aggregates: {\n        minimal?: FindRepositoryParams<MBase>['options']['minimal']\n        maximum?: FindRepositoryParams<MBase>['options']['maximum']\n      },\n      fields: HasuraGraphQLFields<MBase>,\n    ) => [\n      ...(aggregates?.minimal?.length\n        ? [\n            {\n              min: this.bindAttributesToColumns(aggregates?.minimal, fields),\n            },\n          ]\n        : []),\n      ...(aggregates?.maximum?.length\n        ? [\n            {\n              max: this.bindAttributesToColumns(aggregates?.maximum, fields),\n            },\n          ]\n        : []),\n    ]\n\n    bindDistinctAttributes = (\n      distinct: FindRepositoryParams<MBase>['options']['distinct'],\n      fields: HasuraGraphQLFields<MBase>,\n    ) => this.bindAttributesToColumns(distinct, fields)\n\n    bindAttributesToColumns = (\n      attributes: Array<NonFunctionAndIdentifierPropertyNames<MBase> | {}>,\n      fields: HasuraGraphQLFields<MBase>,\n    ) =>\n      attributes.map(\n        (attr) =>\n          AttributeOptionHelper.FindByAttribute(\n            attr.toString().split('.').pop() as NonFunctionAndIdentifierPropertyNames<MBase>,\n            fields,\n          )?.columnName || attr,\n      )\n  }\n}\n"]}
@@ -39,9 +39,60 @@ export class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL
39
39
  ],
40
40
  },
41
41
  },
42
+ {
43
+ category: {
44
+ columnName: 'category',
45
+ foreignKeyColumn: { id: 'categoryId' },
46
+ fields: [
47
+ 'id',
48
+ 'description',
49
+ {
50
+ products: {
51
+ columnName: 'products',
52
+ fields: ['product_id'],
53
+ from: (value) => value.map((product) => product.product_id.toString()),
54
+ to: (productIds) => productIds.map((productId) => ({
55
+ product_id: +productId,
56
+ })),
57
+ },
58
+ },
59
+ {
60
+ childrenProducts: {
61
+ columnName: 'children_products',
62
+ foreignKeyColumn: { category_id: 'id' },
63
+ fields: [
64
+ 'id',
65
+ 'name',
66
+ 'slug',
67
+ {
68
+ categories: {
69
+ columnName: 'categories',
70
+ fields: ['category_id'],
71
+ bindPersistData: (value) => ({
72
+ categories: { data: value.map((category) => ({ category_id: +category })) },
73
+ }),
74
+ to: (categories) => categories.map((categoryId) => +categoryId),
75
+ from: (categories) => (categories === null || categories === void 0 ? void 0 : categories.map((category) => { var _a; return (_a = category === null || category === void 0 ? void 0 : category.category_id) === null || _a === void 0 ? void 0 : _a.toString(); })) || [],
76
+ },
77
+ },
78
+ ],
79
+ },
80
+ },
81
+ ],
82
+ },
83
+ },
42
84
  ],
43
85
  });
44
86
  }
87
+ deleteByCategory(categoryId) {
88
+ return this.mutation('delete_category_filter', ['affected_rows'], {
89
+ where: {
90
+ type: 'category_filter_bool_exp',
91
+ required: true,
92
+ value: { category_id: { _eq: categoryId } },
93
+ },
94
+ });
95
+ }
45
96
  deleteByCategoryAndFilter(categoryId, filterId) {
46
97
  return this.mutation('delete_category_filter', ['affected_rows'], {
47
98
  where: {
@@ -52,4 +103,4 @@ export class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL
52
103
  });
53
104
  }
54
105
  }
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZmlsdGVyLWhhc3VyYS1ncmFwaHFsLnJlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9yZXBvc2l0b3JpZXMvY2F0YWxvZy9jYXRlZ29yeS1maWx0ZXItaGFzdXJhLWdyYXBocWwucmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUE7QUFFbkQsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUd2RSxNQUFNLE9BQU8scUNBQ1gsU0FBUSxxQkFBcUIsQ0FBQyxpQkFBaUIsQ0FBaUIsSUFBSSxDQUFDLENBQUM7SUFHdEUsWUFBWSxRQUFnQixFQUFFLFdBQXFDO1FBQ2pFLEtBQUssQ0FBQztZQUNKLFNBQVMsRUFBRSxpQkFBaUI7WUFDNUIsS0FBSyxFQUFFLGNBQWM7WUFDckIsUUFBUTtZQUNSLFdBQVc7WUFDWCxNQUFNLEVBQUU7Z0JBQ04sSUFBSTtnQkFDSixFQUFFLFFBQVEsRUFBRSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsRUFBRTtnQkFDekMsRUFBRSxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLEVBQUU7Z0JBQzdDO29CQUNFLE1BQU0sRUFBRTt3QkFDTixVQUFVLEVBQUUsUUFBUTt3QkFDcEIsZ0JBQWdCLEVBQUUsRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFO3dCQUNwQyxNQUFNLEVBQUU7NEJBQ04sSUFBSTs0QkFDSixhQUFhOzRCQUNiLE1BQU07NEJBQ04sU0FBUzs0QkFDVCxFQUFFLFNBQVMsRUFBRSxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsRUFBRTs0QkFDM0MsRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEVBQUU7NEJBQzNDO2dDQUNFLE9BQU8sRUFBRTtvQ0FDUCxVQUFVLEVBQUUsU0FBUztvQ0FDckIsZ0JBQWdCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO29DQUNwQyxNQUFNLEVBQUU7d0NBQ04sSUFBSTt3Q0FDSixFQUFFLFFBQVEsRUFBRSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsRUFBRTt3Q0FDekMsYUFBYTt3Q0FDYixFQUFFLFNBQVMsRUFBRSxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsRUFBRTt3Q0FDM0MsRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEVBQUU7cUNBQzVDO2lDQUNGOzZCQUNGO3lCQUNGO3FCQUNGO2lCQUNGO2FBQ0Y7U0FDRixDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQseUJBQXlCLENBQUMsVUFBa0IsRUFBRSxRQUFnQjtRQUM1RCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsd0JBQXdCLEVBQUUsQ0FBQyxlQUFlLENBQUMsRUFBRTtZQUNoRSxLQUFLLEVBQUU7Z0JBQ0wsSUFBSSxFQUFFLDBCQUEwQjtnQkFDaEMsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsS0FBSyxFQUFFLEVBQUUsV0FBVyxFQUFFLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxFQUFFLFNBQVMsRUFBRSxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsRUFBRTthQUMxRTtTQUNGLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhdGVnb3J5RmlsdGVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vZG9tYWluJ1xuaW1wb3J0IHsgQ2F0ZWdvcnlGaWx0ZXJSZXBvc2l0b3J5IH0gZnJvbSAnLi4vLi4vLi4vLi4vZG9tYWluL2NhdGFsb2cvcmVwb3NpdG9yaWVzJ1xuaW1wb3J0IHsgQmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uL3V0aWxzJ1xuaW1wb3J0IHsgd2l0aENydWRIYXN1cmFHcmFwaFFMLCB3aXRoSGFzdXJhR3JhcGhRTCB9IGZyb20gJy4uLy4uL21peGlucydcbmltcG9ydCB7IEhhc3VyYUdyYXBoUUxBdXRoT3B0aW9ucyB9IGZyb20gJy4uLy4uL3R5cGVzJ1xuXG5leHBvcnQgY2xhc3MgQ2F0ZWdvcnlGaWx0ZXJIYXN1cmFHcmFwaFFMUmVwb3NpdG9yeVxuICBleHRlbmRzIHdpdGhDcnVkSGFzdXJhR3JhcGhRTCh3aXRoSGFzdXJhR3JhcGhRTDxDYXRlZ29yeUZpbHRlcj4oQmFzZSkpXG4gIGltcGxlbWVudHMgQ2F0ZWdvcnlGaWx0ZXJSZXBvc2l0b3J5XG57XG4gIGNvbnN0cnVjdG9yKGVuZHBvaW50OiBzdHJpbmcsIGF1dGhPcHRpb25zOiBIYXN1cmFHcmFwaFFMQXV0aE9wdGlvbnMpIHtcbiAgICBzdXBlcih7XG4gICAgICB0YWJsZU5hbWU6ICdjYXRlZ29yeV9maWx0ZXInLFxuICAgICAgbW9kZWw6IENhdGVnb3J5RmlsdGVyLFxuICAgICAgZW5kcG9pbnQsXG4gICAgICBhdXRoT3B0aW9ucyxcbiAgICAgIGZpZWxkczogW1xuICAgICAgICAnaWQnLFxuICAgICAgICB7IGZpbHRlcklkOiB7IGNvbHVtbk5hbWU6ICdmaWx0ZXJfaWQnIH0gfSxcbiAgICAgICAgeyBjYXRlZ29yeUlkOiB7IGNvbHVtbk5hbWU6ICdjYXRlZ29yeV9pZCcgfSB9LFxuICAgICAgICB7XG4gICAgICAgICAgZmlsdGVyOiB7XG4gICAgICAgICAgICBjb2x1bW5OYW1lOiAnZmlsdGVyJyxcbiAgICAgICAgICAgIGZvcmVpZ25LZXlDb2x1bW46IHsgaWQ6ICdmaWx0ZXJJZCcgfSxcbiAgICAgICAgICAgIGZpZWxkczogW1xuICAgICAgICAgICAgICAnaWQnLFxuICAgICAgICAgICAgICAnZGVzY3JpcHRpb24nLFxuICAgICAgICAgICAgICAnc2x1ZycsXG4gICAgICAgICAgICAgICdlbmFibGVkJyxcbiAgICAgICAgICAgICAgeyBjcmVhdGVkQXQ6IHsgY29sdW1uTmFtZTogJ2NyZWF0ZWRfYXQnIH0gfSxcbiAgICAgICAgICAgICAgeyB1cGRhdGVkQXQ6IHsgY29sdW1uTmFtZTogJ3VwZGF0ZWRfYXQnIH0gfSxcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICAgICAgICAgIGNvbHVtbk5hbWU6ICdvcHRpb25zJyxcbiAgICAgICAgICAgICAgICAgIGZvcmVpZ25LZXlDb2x1bW46IHsgZmlsdGVySWQ6ICdpZCcgfSxcbiAgICAgICAgICAgICAgICAgIGZpZWxkczogW1xuICAgICAgICAgICAgICAgICAgICAnaWQnLFxuICAgICAgICAgICAgICAgICAgICB7IGZpbHRlcklkOiB7IGNvbHVtbk5hbWU6ICdmaWx0ZXJfaWQnIH0gfSxcbiAgICAgICAgICAgICAgICAgICAgJ2Rlc2NyaXB0aW9uJyxcbiAgICAgICAgICAgICAgICAgICAgeyBjcmVhdGVkQXQ6IHsgY29sdW1uTmFtZTogJ2NyZWF0ZWRfYXQnIH0gfSxcbiAgICAgICAgICAgICAgICAgICAgeyB1cGRhdGVkQXQ6IHsgY29sdW1uTmFtZTogJ3VwZGF0ZWRfYXQnIH0gfSxcbiAgICAgICAgICAgICAgICAgIF0sXG4gICAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIF0sXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgIF0sXG4gICAgfSlcbiAgfVxuXG4gIGRlbGV0ZUJ5Q2F0ZWdvcnlBbmRGaWx0ZXIoY2F0ZWdvcnlJZDogbnVtYmVyLCBmaWx0ZXJJZDogbnVtYmVyKTogUHJvbWlzZTxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy5tdXRhdGlvbignZGVsZXRlX2NhdGVnb3J5X2ZpbHRlcicsIFsnYWZmZWN0ZWRfcm93cyddLCB7XG4gICAgICB3aGVyZToge1xuICAgICAgICB0eXBlOiAnY2F0ZWdvcnlfZmlsdGVyX2Jvb2xfZXhwJyxcbiAgICAgICAgcmVxdWlyZWQ6IHRydWUsXG4gICAgICAgIHZhbHVlOiB7IGNhdGVnb3J5X2lkOiB7IF9lcTogY2F0ZWdvcnlJZCB9LCBmaWx0ZXJfaWQ6IHsgX2VxOiBmaWx0ZXJJZCB9IH0sXG4gICAgICB9LFxuICAgIH0pXG4gIH1cbn1cbiJdfQ==
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-filter-hasura-graphql.repository.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.ts"],"names":[],"mappings":"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","sourcesContent":["import { CategoryFilter } from '../../../../domain'\nimport { CategoryFilterRepository } from '../../../../domain/catalog/repositories'\nimport { Base } from '../../../../utils'\nimport { withCrudHasuraGraphQL, withHasuraGraphQL } from '../../mixins'\nimport { HasuraGraphQLAuthOptions } from '../../types'\n\nexport class CategoryFilterHasuraGraphQLRepository\n  extends withCrudHasuraGraphQL(withHasuraGraphQL<CategoryFilter>(Base))\n  implements CategoryFilterRepository\n{\n  constructor(endpoint: string, authOptions: HasuraGraphQLAuthOptions) {\n    super({\n      tableName: 'category_filter',\n      model: CategoryFilter,\n      endpoint,\n      authOptions,\n      fields: [\n        'id',\n        { filterId: { columnName: 'filter_id' } },\n        { categoryId: { columnName: 'category_id' } },\n        {\n          filter: {\n            columnName: 'filter',\n            foreignKeyColumn: { id: 'filterId' },\n            fields: [\n              'id',\n              'description',\n              'slug',\n              'enabled',\n              { createdAt: { columnName: 'created_at' } },\n              { updatedAt: { columnName: 'updated_at' } },\n              {\n                options: {\n                  columnName: 'options',\n                  foreignKeyColumn: { filterId: 'id' },\n                  fields: [\n                    'id',\n                    { filterId: { columnName: 'filter_id' } },\n                    'description',\n                    { createdAt: { columnName: 'created_at' } },\n                    { updatedAt: { columnName: 'updated_at' } },\n                  ],\n                },\n              },\n            ],\n          },\n        },\n        {\n          category: {\n            columnName: 'category',\n            foreignKeyColumn: { id: 'categoryId' },\n            fields: [\n              'id',\n              'description',\n              {\n                products: {\n                  columnName: 'products',\n                  fields: ['product_id'],\n                  from: (value: { product_id: number }[]) => value.map((product) => product.product_id.toString()),\n                  to: (productIds) =>\n                    productIds.map((productId) => ({\n                      product_id: +productId,\n                    })),\n                },\n              },\n              {\n                childrenProducts: {\n                  columnName: 'children_products',\n                  foreignKeyColumn: { category_id: 'id' },\n                  fields: [\n                    'id',\n                    'name',\n                    'slug',\n                    {\n                      categories: {\n                        columnName: 'categories',\n                        fields: ['category_id'],\n                        bindPersistData: (value) => ({\n                          categories: { data: value.map((category) => ({ category_id: +category })) },\n                        }),\n                        to: (categories) => categories.map((categoryId) => +categoryId),\n                        from: (categories: { category_id: number }[]) =>\n                          categories?.map((category) => category?.category_id?.toString()) || [],\n                      },\n                    },\n                  ],\n                },\n              },\n            ],\n          },\n        },\n      ],\n    })\n  }\n\n  deleteByCategory(categoryId: number): Promise<any> {\n    return this.mutation('delete_category_filter', ['affected_rows'], {\n      where: {\n        type: 'category_filter_bool_exp',\n        required: true,\n        value: { category_id: { _eq: categoryId } },\n      },\n    })\n  }\n\n  deleteByCategoryAndFilter(categoryId: number, filterId: number): Promise<any> {\n    return this.mutation('delete_category_filter', ['affected_rows'], {\n      where: {\n        type: 'category_filter_bool_exp',\n        required: true,\n        value: { category_id: { _eq: categoryId }, filter_id: { _eq: filterId } },\n      },\n    })\n  }\n}\n"]}