@infrab4a/connect-angular 5.5.0-beta.2 → 5.5.0-beta.20

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.
@@ -31,7 +31,7 @@ export class ProfileSearchStrategy {
31
31
  distinct: ['brand'],
32
32
  },
33
33
  };
34
- return productCatalog.productCatalogRepository.findCatalog(repoParams, mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'), optionsCache);
34
+ return productCatalog.productRepository.findCatalog(repoParams, mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'), optionsCache);
35
35
  }
36
36
  }
37
37
  ProfileSearchStrategy.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProfileSearchStrategy, deps: [{ token: i1.CatalogRepositoryService }, { token: i1.CatalogHelpersService }], target: i0.ɵɵFactoryTarget.Injectable });
@@ -39,4 +39,4 @@ ProfileSearchStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0"
39
39
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProfileSearchStrategy, decorators: [{
40
40
  type: Injectable
41
41
  }], ctorParameters: function () { return [{ type: i1.CatalogRepositoryService }, { type: i1.CatalogHelpersService }]; } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS1zZWFyY2guc3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0LWFuZ3VsYXIvc3JjL3NlcnZpY2VzL2NhdGFsb2cvc3RyYXRlZ2llcy9wcm9maWxlLXNlYXJjaC5zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQzFDLE9BQU8sRUFBeUQsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBR3ZHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGFBQWEsQ0FBQTs7O0FBRzdFLE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFDbUIsaUJBQTJDLEVBQzNDLGNBQXFDO1FBRHJDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBMEI7UUFDM0MsbUJBQWMsR0FBZCxjQUFjLENBQXVCO0lBQ3JELENBQUM7SUFFSixLQUFLLENBQUMsTUFBTSxDQUNWLE1BQTJCLEVBQzNCLElBQVcsRUFDWCxZQUFpRDtRQUVqRCxNQUFNLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxHQUFHLE1BQU0sQ0FBQTtRQUU3RCxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQywrQ0FBK0MsQ0FBQyxDQUFBO1NBQ2pFO1FBRUQsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGlCQUFpQixFQUFFLENBQUE7UUFDakUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEVBQUUsQ0FBQTtRQUMxRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFBO1FBQ3RELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsZUFBZSxFQUFFLENBQUE7UUFFMUQsTUFBTSxVQUFVLEdBQUc7WUFDakIsTUFBTSxFQUFFLFlBQVksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QyxPQUFPLEVBQUU7Z0JBQ1AsV0FBVyxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRTtnQkFDckQsR0FBRyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQzthQUNoRDtZQUNELEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBTyxFQUFFLFVBQVUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQzdELE1BQU07WUFDTixPQUFPLEVBQUU7Z0JBQ1AsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO2dCQUNsQixPQUFPLEVBQUUsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xCLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQzthQUNwQjtTQUNGLENBQUE7UUFFRCxPQUFPLGNBQWMsQ0FBQyx3QkFBd0IsQ0FBQyxXQUFXLENBQ3hELFVBQVUsRUFDVixVQUFVLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFDN0QsWUFBWSxDQUNiLENBQUE7SUFDSCxDQUFDOztrSEExQ1UscUJBQXFCO3NIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBQcm9kdWN0LCBSZXBvc2l0b3J5Q2FjaGVPcHRpb25zLCBSZXBvc2l0b3J5RmluZFJlc3VsdCwgU2hvcHMsIFdoZXJlIH0gZnJvbSAnQGluZnJhYjRhL2Nvbm5lY3QnXHJcblxyXG5pbXBvcnQgeyBDYXRhbG9nU2VhcmNoUGFyYW1zLCBDYXRhbG9nU2VhcmNoU3RyYXRlZ3kgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJ1xyXG5pbXBvcnQgeyBDYXRhbG9nSGVscGVyc1NlcnZpY2UsIENhdGFsb2dSZXBvc2l0b3J5U2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJ1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgUHJvZmlsZVNlYXJjaFN0cmF0ZWd5IGltcGxlbWVudHMgQ2F0YWxvZ1NlYXJjaFN0cmF0ZWd5IHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgcmVwb3NpdG9yeVNlcnZpY2U6IENhdGFsb2dSZXBvc2l0b3J5U2VydmljZSxcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgaGVscGVyc1NlcnZpY2U6IENhdGFsb2dIZWxwZXJzU2VydmljZSxcclxuICApIHt9XHJcblxyXG4gIGFzeW5jIHNlYXJjaChcclxuICAgIHBhcmFtczogQ2F0YWxvZ1NlYXJjaFBhcmFtcyxcclxuICAgIHNob3A6IFNob3BzLFxyXG4gICAgb3B0aW9uc0NhY2hlPzogeyBjYWNoZT86IFJlcG9zaXRvcnlDYWNoZU9wdGlvbnMgfSxcclxuICApOiBQcm9taXNlPFJlcG9zaXRvcnlGaW5kUmVzdWx0PFByb2R1Y3Q+PiB7XHJcbiAgICBjb25zdCB7IHByb2ZpbGUsIGZpbHRlcnMsIGxpbWl0cywgc29ydCwgbWFpbkdlbmRlciB9ID0gcGFyYW1zXHJcblxyXG4gICAgaWYgKCFwcm9maWxlKSB7XHJcbiAgICAgIHRocm93IG5ldyBFcnJvcignUHJvZmlsZSBpcyByZXF1aXJlZCBmb3IgUHJvZmlsZVNlYXJjaFN0cmF0ZWd5JylcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBwcm9kdWN0Q2F0YWxvZyA9IHRoaXMucmVwb3NpdG9yeVNlcnZpY2UuZ2V0UHJvZHVjdENhdGFsb2coKVxyXG4gICAgY29uc3QgZmlsdGVySGVscGVyID0gdGhpcy5oZWxwZXJzU2VydmljZS5nZXRGaWx0ZXJIZWxwZXIoKVxyXG4gICAgY29uc3Qgc29ydEhlbHBlciA9IHRoaXMuaGVscGVyc1NlcnZpY2UuZ2V0U29ydEhlbHBlcigpXHJcbiAgICBjb25zdCBmaWVsZHNIZWxwZXIgPSB0aGlzLmhlbHBlcnNTZXJ2aWNlLmdldEZpZWxkc0hlbHBlcigpXHJcblxyXG4gICAgY29uc3QgcmVwb1BhcmFtcyA9IHtcclxuICAgICAgZmllbGRzOiBmaWVsZHNIZWxwZXIuZ2V0U3RhbmRhcmRGaWVsZHMoKSxcclxuICAgICAgZmlsdGVyczoge1xyXG4gICAgICAgIHRhZ3NQcm9maWxlOiB7IG9wZXJhdG9yOiBXaGVyZS5MSUtFLCB2YWx1ZTogcHJvZmlsZSB9LFxyXG4gICAgICAgIC4uLmZpbHRlckhlbHBlci5idWlsZEZpbHRlclF1ZXJ5KGZpbHRlcnMgfHwge30pLFxyXG4gICAgICB9LFxyXG4gICAgICAuLi4oc29ydCA/IHsgb3JkZXJCeTogc29ydEhlbHBlci5idWlsZFNvcnRRdWVyeShzb3J0KSB9IDoge30pLFxyXG4gICAgICBsaW1pdHMsXHJcbiAgICAgIG9wdGlvbnM6IHtcclxuICAgICAgICBtaW5pbWFsOiBbJ3ByaWNlJ10sXHJcbiAgICAgICAgbWF4aW11bTogWydwcmljZSddLFxyXG4gICAgICAgIGRpc3RpbmN0OiBbJ2JyYW5kJ10sXHJcbiAgICAgIH0sXHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHByb2R1Y3RDYXRhbG9nLnByb2R1Y3RDYXRhbG9nUmVwb3NpdG9yeS5maW5kQ2F0YWxvZyhcclxuICAgICAgcmVwb1BhcmFtcyxcclxuICAgICAgbWFpbkdlbmRlciB8fCAoc2hvcCA9PT0gU2hvcHMuTUVOU01BUktFVCA/ICdtYWxlJyA6ICdmZW1hbGUnKSxcclxuICAgICAgb3B0aW9uc0NhY2hlLFxyXG4gICAgKVxyXG4gIH1cclxufVxyXG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS1zZWFyY2guc3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0LWFuZ3VsYXIvc3JjL3NlcnZpY2VzL2NhdGFsb2cvc3RyYXRlZ2llcy9wcm9maWxlLXNlYXJjaC5zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQzFDLE9BQU8sRUFBeUQsS0FBSyxFQUFFLEtBQUssRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBR3ZHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSx3QkFBd0IsRUFBRSxNQUFNLGFBQWEsQ0FBQTs7O0FBRzdFLE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFDbUIsaUJBQTJDLEVBQzNDLGNBQXFDO1FBRHJDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBMEI7UUFDM0MsbUJBQWMsR0FBZCxjQUFjLENBQXVCO0lBQ3JELENBQUM7SUFFSixLQUFLLENBQUMsTUFBTSxDQUNWLE1BQTJCLEVBQzNCLElBQVcsRUFDWCxZQUFpRDtRQUVqRCxNQUFNLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxHQUFHLE1BQU0sQ0FBQTtRQUU3RCxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ1osTUFBTSxJQUFJLEtBQUssQ0FBQywrQ0FBK0MsQ0FBQyxDQUFBO1NBQ2pFO1FBRUQsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGlCQUFpQixFQUFFLENBQUE7UUFDakUsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxlQUFlLEVBQUUsQ0FBQTtRQUMxRCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFBO1FBQ3RELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsZUFBZSxFQUFFLENBQUE7UUFFMUQsTUFBTSxVQUFVLEdBQUc7WUFDakIsTUFBTSxFQUFFLFlBQVksQ0FBQyxpQkFBaUIsRUFBRTtZQUN4QyxPQUFPLEVBQUU7Z0JBQ1AsV0FBVyxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRTtnQkFDckQsR0FBRyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQzthQUNoRDtZQUNELEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBTyxFQUFFLFVBQVUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBQzdELE1BQU07WUFDTixPQUFPLEVBQUU7Z0JBQ1AsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO2dCQUNsQixPQUFPLEVBQUUsQ0FBQyxPQUFPLENBQUM7Z0JBQ2xCLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQzthQUNwQjtTQUNGLENBQUE7UUFFRCxPQUFPLGNBQWMsQ0FBQyxpQkFBaUIsQ0FBQyxXQUFXLENBQ2pELFVBQVUsRUFDVixVQUFVLElBQUksQ0FBQyxJQUFJLEtBQUssS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFDN0QsWUFBWSxDQUNiLENBQUE7SUFDSCxDQUFDOztrSEExQ1UscUJBQXFCO3NIQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFEakMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xyXG5pbXBvcnQgeyBQcm9kdWN0LCBSZXBvc2l0b3J5Q2FjaGVPcHRpb25zLCBSZXBvc2l0b3J5RmluZFJlc3VsdCwgU2hvcHMsIFdoZXJlIH0gZnJvbSAnQGluZnJhYjRhL2Nvbm5lY3QnXHJcblxyXG5pbXBvcnQgeyBDYXRhbG9nU2VhcmNoUGFyYW1zLCBDYXRhbG9nU2VhcmNoU3RyYXRlZ3kgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJ1xyXG5pbXBvcnQgeyBDYXRhbG9nSGVscGVyc1NlcnZpY2UsIENhdGFsb2dSZXBvc2l0b3J5U2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzJ1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgUHJvZmlsZVNlYXJjaFN0cmF0ZWd5IGltcGxlbWVudHMgQ2F0YWxvZ1NlYXJjaFN0cmF0ZWd5IHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgcmVwb3NpdG9yeVNlcnZpY2U6IENhdGFsb2dSZXBvc2l0b3J5U2VydmljZSxcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgaGVscGVyc1NlcnZpY2U6IENhdGFsb2dIZWxwZXJzU2VydmljZSxcclxuICApIHt9XHJcblxyXG4gIGFzeW5jIHNlYXJjaChcclxuICAgIHBhcmFtczogQ2F0YWxvZ1NlYXJjaFBhcmFtcyxcclxuICAgIHNob3A6IFNob3BzLFxyXG4gICAgb3B0aW9uc0NhY2hlPzogeyBjYWNoZT86IFJlcG9zaXRvcnlDYWNoZU9wdGlvbnMgfSxcclxuICApOiBQcm9taXNlPFJlcG9zaXRvcnlGaW5kUmVzdWx0PFByb2R1Y3Q+PiB7XHJcbiAgICBjb25zdCB7IHByb2ZpbGUsIGZpbHRlcnMsIGxpbWl0cywgc29ydCwgbWFpbkdlbmRlciB9ID0gcGFyYW1zXHJcblxyXG4gICAgaWYgKCFwcm9maWxlKSB7XHJcbiAgICAgIHRocm93IG5ldyBFcnJvcignUHJvZmlsZSBpcyByZXF1aXJlZCBmb3IgUHJvZmlsZVNlYXJjaFN0cmF0ZWd5JylcclxuICAgIH1cclxuXHJcbiAgICBjb25zdCBwcm9kdWN0Q2F0YWxvZyA9IHRoaXMucmVwb3NpdG9yeVNlcnZpY2UuZ2V0UHJvZHVjdENhdGFsb2coKVxyXG4gICAgY29uc3QgZmlsdGVySGVscGVyID0gdGhpcy5oZWxwZXJzU2VydmljZS5nZXRGaWx0ZXJIZWxwZXIoKVxyXG4gICAgY29uc3Qgc29ydEhlbHBlciA9IHRoaXMuaGVscGVyc1NlcnZpY2UuZ2V0U29ydEhlbHBlcigpXHJcbiAgICBjb25zdCBmaWVsZHNIZWxwZXIgPSB0aGlzLmhlbHBlcnNTZXJ2aWNlLmdldEZpZWxkc0hlbHBlcigpXHJcblxyXG4gICAgY29uc3QgcmVwb1BhcmFtcyA9IHtcclxuICAgICAgZmllbGRzOiBmaWVsZHNIZWxwZXIuZ2V0U3RhbmRhcmRGaWVsZHMoKSxcclxuICAgICAgZmlsdGVyczoge1xyXG4gICAgICAgIHRhZ3NQcm9maWxlOiB7IG9wZXJhdG9yOiBXaGVyZS5MSUtFLCB2YWx1ZTogcHJvZmlsZSB9LFxyXG4gICAgICAgIC4uLmZpbHRlckhlbHBlci5idWlsZEZpbHRlclF1ZXJ5KGZpbHRlcnMgfHwge30pLFxyXG4gICAgICB9LFxyXG4gICAgICAuLi4oc29ydCA/IHsgb3JkZXJCeTogc29ydEhlbHBlci5idWlsZFNvcnRRdWVyeShzb3J0KSB9IDoge30pLFxyXG4gICAgICBsaW1pdHMsXHJcbiAgICAgIG9wdGlvbnM6IHtcclxuICAgICAgICBtaW5pbWFsOiBbJ3ByaWNlJ10sXHJcbiAgICAgICAgbWF4aW11bTogWydwcmljZSddLFxyXG4gICAgICAgIGRpc3RpbmN0OiBbJ2JyYW5kJ10sXHJcbiAgICAgIH0sXHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHByb2R1Y3RDYXRhbG9nLnByb2R1Y3RSZXBvc2l0b3J5LmZpbmRDYXRhbG9nKFxyXG4gICAgICByZXBvUGFyYW1zLFxyXG4gICAgICBtYWluR2VuZGVyIHx8IChzaG9wID09PSBTaG9wcy5NRU5TTUFSS0VUID8gJ21hbGUnIDogJ2ZlbWFsZScpLFxyXG4gICAgICBvcHRpb25zQ2FjaGUsXHJcbiAgICApXHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -37,7 +37,7 @@ export class TermSearchStrategy {
37
37
  const { productIds, filters, shop, mainGender } = params;
38
38
  const productCatalog = this.repositoryService.getProductCatalog();
39
39
  const filterHelper = this.helpersService.getFilterHelper();
40
- const totalResult = await productCatalog.productCatalogRepository.findCatalog({
40
+ const totalResult = await productCatalog.productRepository.findCatalog({
41
41
  fields: ['id', 'stock', 'gender'],
42
42
  filters: {
43
43
  id: { operator: Where.IN, value: productIds },
@@ -62,7 +62,7 @@ export class TermSearchStrategy {
62
62
  const { productIds, filters, limits, shop, mainGender, fields } = params;
63
63
  const productCatalog = this.repositoryService.getProductCatalog();
64
64
  const filterHelper = this.helpersService.getFilterHelper();
65
- return productCatalog.productCatalogRepository.findCatalog({
65
+ return productCatalog.productRepository.findCatalog({
66
66
  fields,
67
67
  filters: {
68
68
  id: { operator: Where.IN, value: productIds },
@@ -92,7 +92,7 @@ export class TermSearchStrategy {
92
92
  async getDetailedProducts(orderedId, totalResult, fieldsHelper) {
93
93
  const productCatalog = this.repositoryService.getProductCatalog();
94
94
  const fields = fieldsHelper.getStandardFields();
95
- const productResult = await productCatalog.productCatalogRepository.findCatalog({
95
+ const productResult = await productCatalog.productRepository.findCatalog({
96
96
  filters: {
97
97
  id: { operator: Where.IN, value: orderedId },
98
98
  },
@@ -120,4 +120,4 @@ TermSearchStrategy.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", v
120
120
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: TermSearchStrategy, decorators: [{
121
121
  type: Injectable
122
122
  }], ctorParameters: function () { return [{ type: i1.CatalogRepositoryService }, { type: i1.CatalogHelpersService }]; } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"term-search.strategy.js","sourceRoot":"","sources":["../../../../../../projects/connect-angular/src/services/catalog/strategies/term-search.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\r\nimport {\r\n  isEmpty,\r\n  Product,\r\n  ProductSearch,\r\n  RepositoryCacheOptions,\r\n  RepositoryFindResult,\r\n  Shops,\r\n  Where,\r\n} from '@infrab4a/connect'\r\n\r\nimport { CatalogSearchParams, CatalogSearchStrategy } from '../../../interfaces'\r\nimport { CatalogHelpersService, CatalogRepositoryService } from '../services'\r\n\r\nimport {\r\n  SortByTermRelevanceParams,\r\n  TermSearchDefaultParams,\r\n  TermSearchMostRelevantParams,\r\n} from './types/strategy-params.type'\r\n\r\n@Injectable()\r\nexport class TermSearchStrategy implements CatalogSearchStrategy {\r\n  private productsByTerm: Record<string, string[]> = {}\r\n\r\n  constructor(\r\n    private readonly repositoryService: CatalogRepositoryService,\r\n    private readonly helpersService: CatalogHelpersService,\r\n  ) {}\r\n\r\n  async search(\r\n    params: CatalogSearchParams,\r\n    shop: Shops,\r\n    _optionsCache?: { cache?: RepositoryCacheOptions },\r\n  ): Promise<RepositoryFindResult<Product>> {\r\n    const { term, filters, limits, sort, mainGender } = params\r\n\r\n    if (!term) {\r\n      throw new Error('Term is required for TermSearchStrategy')\r\n    }\r\n\r\n    const productIds = await this.findCatalogIdsBySearch(term, shop)\r\n\r\n    if (sort === 'most-relevant') {\r\n      return this.searchWithMostRelevant({\r\n        productIds,\r\n        filters,\r\n        limits,\r\n        shop,\r\n        mainGender,\r\n      })\r\n    }\r\n\r\n    return this.searchDefault({\r\n      productIds,\r\n      filters,\r\n      limits,\r\n      shop,\r\n      mainGender,\r\n      fields: this.helpersService.getFieldsHelper().getStandardFields(),\r\n    })\r\n  }\r\n\r\n  private async searchWithMostRelevant(params: TermSearchMostRelevantParams): Promise<RepositoryFindResult<Product>> {\r\n    const { productIds, filters, shop, mainGender } = params\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const filterHelper = this.helpersService.getFilterHelper()\r\n\r\n    const totalResult = await productCatalog.productCatalogRepository.findCatalog(\r\n      {\r\n        fields: ['id', 'stock', 'gender'],\r\n        filters: {\r\n          id: { operator: Where.IN, value: productIds },\r\n          published: { operator: Where.EQUALS, value: true },\r\n          ...filterHelper.buildFilterQuery(filters || {}),\r\n        },\r\n        options: {\r\n          minimal: ['price'],\r\n          maximum: ['price'],\r\n          ...(isEmpty(filters?.brands) ? { distinct: ['brand'] } : {}),\r\n        },\r\n      },\r\n      // mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'),\r\n    )\r\n\r\n    return this.sortByTermRelevance({\r\n      productIds,\r\n      totalResult,\r\n      limits: params.limits,\r\n      filters,\r\n      fieldsHelper: this.helpersService.getFieldsHelper(),\r\n    })\r\n  }\r\n\r\n  private async searchDefault(params: TermSearchDefaultParams): Promise<RepositoryFindResult<Product>> {\r\n    const { productIds, filters, limits, shop, mainGender, fields } = params\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const filterHelper = this.helpersService.getFilterHelper()\r\n\r\n    return productCatalog.productCatalogRepository.findCatalog(\r\n      {\r\n        fields,\r\n        filters: {\r\n          id: { operator: Where.IN, value: productIds },\r\n          published: { operator: Where.EQUALS, value: true },\r\n          ...filterHelper.buildFilterQuery(filters || {}),\r\n        },\r\n        limits,\r\n        options: {\r\n          minimal: ['price'],\r\n          maximum: ['price'],\r\n          distinct: ['brand'],\r\n        },\r\n      },\r\n      // mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'),\r\n    )\r\n  }\r\n\r\n  private sortByTermRelevance(params: SortByTermRelevanceParams) {\r\n    const { productIds, totalResult, limits, filters, fieldsHelper } = params\r\n    // const defaultGender = filters?.gender?.at(0) || 'male'\r\n    const stockData = totalResult.data.filter((product: any) => product.stock.quantity > 0)\r\n    const stockOut = totalResult.data.filter((product: any) => product.stock.quantity <= 0)\r\n    const productIdsStock = productIds.filter((product) => stockData.some((result: any) => result.id === product))\r\n    const productIdsStockOut = productIds.filter((product) => stockOut.some((result: any) => result.id === product))\r\n    const limitedProductId = productIdsStock\r\n      .concat(productIdsStockOut)\r\n      .slice(limits.offset, limits.offset + limits.limit)\r\n\r\n    return this.getDetailedProducts(limitedProductId, totalResult, fieldsHelper)\r\n  }\r\n\r\n  private async getDetailedProducts(orderedId: string[], totalResult: any, fieldsHelper: any) {\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const fields = fieldsHelper.getStandardFields()\r\n    const productResult = await productCatalog.productCatalogRepository.findCatalog({\r\n      filters: {\r\n        id: { operator: Where.IN, value: orderedId },\r\n      },\r\n      fields,\r\n    })\r\n\r\n    return {\r\n      data: orderedId.map((id) => productResult.data.find((product) => product.id === id)).filter(Boolean),\r\n      count: totalResult.count,\r\n      maximum: totalResult.maximum,\r\n      minimal: totalResult.minimal,\r\n      distinct: totalResult.distinct,\r\n    }\r\n  }\r\n\r\n  private async findCatalogIdsBySearch(term: string, shop: Shops): Promise<string[]> {\r\n    if (this.productsByTerm[term]) return this.productsByTerm[term]\r\n\r\n    const productServices = this.repositoryService.getProductServices()\r\n\r\n    return (this.productsByTerm[term] = await productServices.productSearch\r\n      .search<ProductSearch>(term, 999, shop === Shops.GLAMSHOP ? 'female' : 'male')\r\n      .then((products) => [...new Set(products.map((product) => product.id))]))\r\n  }\r\n}\r\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"term-search.strategy.js","sourceRoot":"","sources":["../../../../../../projects/connect-angular/src/services/catalog/strategies/term-search.strategy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\r\nimport {\r\n  isEmpty,\r\n  Product,\r\n  ProductSearch,\r\n  RepositoryCacheOptions,\r\n  RepositoryFindResult,\r\n  Shops,\r\n  Where,\r\n} from '@infrab4a/connect'\r\n\r\nimport { CatalogSearchParams, CatalogSearchStrategy } from '../../../interfaces'\r\nimport { CatalogHelpersService, CatalogRepositoryService } from '../services'\r\n\r\nimport {\r\n  SortByTermRelevanceParams,\r\n  TermSearchDefaultParams,\r\n  TermSearchMostRelevantParams,\r\n} from './types/strategy-params.type'\r\n\r\n@Injectable()\r\nexport class TermSearchStrategy implements CatalogSearchStrategy {\r\n  private productsByTerm: Record<string, string[]> = {}\r\n\r\n  constructor(\r\n    private readonly repositoryService: CatalogRepositoryService,\r\n    private readonly helpersService: CatalogHelpersService,\r\n  ) {}\r\n\r\n  async search(\r\n    params: CatalogSearchParams,\r\n    shop: Shops,\r\n    _optionsCache?: { cache?: RepositoryCacheOptions },\r\n  ): Promise<RepositoryFindResult<Product>> {\r\n    const { term, filters, limits, sort, mainGender } = params\r\n\r\n    if (!term) {\r\n      throw new Error('Term is required for TermSearchStrategy')\r\n    }\r\n\r\n    const productIds = await this.findCatalogIdsBySearch(term, shop)\r\n\r\n    if (sort === 'most-relevant') {\r\n      return this.searchWithMostRelevant({\r\n        productIds,\r\n        filters,\r\n        limits,\r\n        shop,\r\n        mainGender,\r\n      })\r\n    }\r\n\r\n    return this.searchDefault({\r\n      productIds,\r\n      filters,\r\n      limits,\r\n      shop,\r\n      mainGender,\r\n      fields: this.helpersService.getFieldsHelper().getStandardFields(),\r\n    })\r\n  }\r\n\r\n  private async searchWithMostRelevant(params: TermSearchMostRelevantParams): Promise<RepositoryFindResult<Product>> {\r\n    const { productIds, filters, shop, mainGender } = params\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const filterHelper = this.helpersService.getFilterHelper()\r\n\r\n    const totalResult = await productCatalog.productRepository.findCatalog(\r\n      {\r\n        fields: ['id', 'stock', 'gender'],\r\n        filters: {\r\n          id: { operator: Where.IN, value: productIds },\r\n          published: { operator: Where.EQUALS, value: true },\r\n          ...filterHelper.buildFilterQuery(filters || {}),\r\n        },\r\n        options: {\r\n          minimal: ['price'],\r\n          maximum: ['price'],\r\n          ...(isEmpty(filters?.brands) ? { distinct: ['brand'] } : {}),\r\n        },\r\n      },\r\n      // mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'),\r\n    )\r\n\r\n    return this.sortByTermRelevance({\r\n      productIds,\r\n      totalResult,\r\n      limits: params.limits,\r\n      filters,\r\n      fieldsHelper: this.helpersService.getFieldsHelper(),\r\n    })\r\n  }\r\n\r\n  private async searchDefault(params: TermSearchDefaultParams): Promise<RepositoryFindResult<Product>> {\r\n    const { productIds, filters, limits, shop, mainGender, fields } = params\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const filterHelper = this.helpersService.getFilterHelper()\r\n\r\n    return productCatalog.productRepository.findCatalog(\r\n      {\r\n        fields,\r\n        filters: {\r\n          id: { operator: Where.IN, value: productIds },\r\n          published: { operator: Where.EQUALS, value: true },\r\n          ...filterHelper.buildFilterQuery(filters || {}),\r\n        },\r\n        limits,\r\n        options: {\r\n          minimal: ['price'],\r\n          maximum: ['price'],\r\n          distinct: ['brand'],\r\n        },\r\n      },\r\n      // mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'),\r\n    )\r\n  }\r\n\r\n  private sortByTermRelevance(params: SortByTermRelevanceParams) {\r\n    const { productIds, totalResult, limits, filters, fieldsHelper } = params\r\n    // const defaultGender = filters?.gender?.at(0) || 'male'\r\n    const stockData = totalResult.data.filter((product: any) => product.stock.quantity > 0)\r\n    const stockOut = totalResult.data.filter((product: any) => product.stock.quantity <= 0)\r\n    const productIdsStock = productIds.filter((product) => stockData.some((result: any) => result.id === product))\r\n    const productIdsStockOut = productIds.filter((product) => stockOut.some((result: any) => result.id === product))\r\n    const limitedProductId = productIdsStock\r\n      .concat(productIdsStockOut)\r\n      .slice(limits.offset, limits.offset + limits.limit)\r\n\r\n    return this.getDetailedProducts(limitedProductId, totalResult, fieldsHelper)\r\n  }\r\n\r\n  private async getDetailedProducts(orderedId: string[], totalResult: any, fieldsHelper: any) {\r\n    const productCatalog = this.repositoryService.getProductCatalog()\r\n    const fields = fieldsHelper.getStandardFields()\r\n    const productResult = await productCatalog.productRepository.findCatalog({\r\n      filters: {\r\n        id: { operator: Where.IN, value: orderedId },\r\n      },\r\n      fields,\r\n    })\r\n\r\n    return {\r\n      data: orderedId.map((id) => productResult.data.find((product) => product.id === id)).filter(Boolean),\r\n      count: totalResult.count,\r\n      maximum: totalResult.maximum,\r\n      minimal: totalResult.minimal,\r\n      distinct: totalResult.distinct,\r\n    }\r\n  }\r\n\r\n  private async findCatalogIdsBySearch(term: string, shop: Shops): Promise<string[]> {\r\n    if (this.productsByTerm[term]) return this.productsByTerm[term]\r\n\r\n    const productServices = this.repositoryService.getProductServices()\r\n\r\n    return (this.productsByTerm[term] = await productServices.productSearch\r\n      .search<ProductSearch>(term, 999, shop === Shops.GLAMSHOP ? 'female' : 'male')\r\n      .then((products) => [...new Set(products.map((product) => product.id))]))\r\n  }\r\n}\r\n"]}
@@ -7,7 +7,7 @@ import { provideAppCheck, initializeAppCheck } from '@angular/fire/app-check';
7
7
  import * as i3$1 from '@angular/fire/storage';
8
8
  import { Storage, provideStorage, getStorage } from '@angular/fire/storage';
9
9
  import * as i3 from '@infrab4a/connect';
10
- import { ProductsIndex, AxiosAdapter, Authentication, AuthenticationFirebaseAuthService, Register, RegisterFirebaseAuthService, SignOut, RecoveryPassword, ConnectFirestoreService, UserBeautyProfileFirestoreRepository, Buy2WinFirestoreRepository, CategoryFirestoreRepository, CheckoutFirestoreRepository, CheckoutSubscriptionFirestoreRepository, CouponFirestoreRepository, CampaignHashtagFirestoreRepository, CampaignDashboardFirestoreRepository, SubscriptionEditionFirestoreRepository, GroupFirestoreRepository, HomeFirestoreRepository, LeadFirestoreRepository, LegacyOrderFirestoreRepository, ShopMenuFirestoreRepository, OrderFirestoreRepository, PaymentFirestoreRepository, ProductFirestoreRepository, ShopSettingsFirestoreRepository, SubscriptionPaymentFirestoreRepository, SubscriptionPlanFirestoreRepository, SubscriptionProductFirestoreRepository, SubscriptionFirestoreRepository, UserFirestoreRepository, UserAddressFirestoreRepository, UserPaymentMethodFirestoreRepository, SubscriptionMaterializationFirestoreRepository, SubscriptionSummaryFirestoreRepository, ProductVariantFirestoreRepository, OrderBlockedFirestoreRepository, LogFirestoreRepository, SequenceFirestoreRepository, CategoryHasuraGraphQLRepository, ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository, ProductReviewHasuraGraphQLRepository, VariantHasuraGraphQLRepository, ProductStockNotificationHasuraGraphQLRepository, FilterOptionHasuraGraphQLRepository, FilterHasuraGraphQLRepository, CategoryCollectionChildrenHasuraGraphQLRepository, CategoryProductHasuraGraphQLRepository, WishlistHasuraGraphQLRepository, ProductErrorsHasuraGraphQLRepository, ProductCatalogHasuraGraphQLRepository, ProductsVertexSearch, VertexAxiosAdapter, isNil, NotFoundError, Checkout, pick, LineItem, Where, isEmpty, Shops, set, InvalidArgumentError, RoundProductPricesHelper, Category, WishlistLogType, PersonTypes, Wishlist, CheckoutTypes, CouponTypes, Exclusivities, OrderStatus, CheckoutSubscription, Product, RequiredArgumentError, add, ProductReview, Order, UpdateUserImage, FirebaseFileUploaderService } from '@infrab4a/connect';
10
+ import { ProductsIndex, AxiosAdapter, Authentication, AuthenticationFirebaseAuthService, Register, RegisterFirebaseAuthService, SignOut, RecoveryPassword, ConnectFirestoreService, UserBeautyProfileFirestoreRepository, Buy2WinFirestoreRepository, CategoryFirestoreRepository, CheckoutFirestoreRepository, CheckoutSubscriptionFirestoreRepository, CouponFirestoreRepository, CampaignHashtagFirestoreRepository, CampaignDashboardFirestoreRepository, SubscriptionEditionFirestoreRepository, GroupFirestoreRepository, HomeFirestoreRepository, LeadFirestoreRepository, LegacyOrderFirestoreRepository, ShopMenuFirestoreRepository, OrderFirestoreRepository, PaymentFirestoreRepository, ProductFirestoreRepository, ShopSettingsFirestoreRepository, SubscriptionPaymentFirestoreRepository, SubscriptionPlanFirestoreRepository, SubscriptionProductFirestoreRepository, SubscriptionFirestoreRepository, UserFirestoreRepository, UserAddressFirestoreRepository, UserPaymentMethodFirestoreRepository, SubscriptionMaterializationFirestoreRepository, SubscriptionSummaryFirestoreRepository, ProductVariantFirestoreRepository, OrderBlockedFirestoreRepository, LogFirestoreRepository, SequenceFirestoreRepository, BrandCategoryFirestoreRepository, CategoryHasuraGraphQLRepository, ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository, ProductReviewHasuraGraphQLRepository, VariantHasuraGraphQLRepository, ProductStockNotificationHasuraGraphQLRepository, FilterOptionHasuraGraphQLRepository, FilterHasuraGraphQLRepository, CategoryCollectionChildrenHasuraGraphQLRepository, CategoryProductHasuraGraphQLRepository, WishlistHasuraGraphQLRepository, ProductErrorsHasuraGraphQLRepository, ProductsVertexSearch, VertexAxiosAdapter, isNil, NotFoundError, Checkout, pick, LineItem, Where, isEmpty, Shops, set, InvalidArgumentError, RoundProductPricesHelper, Category, WishlistLogType, PersonTypes, Wishlist, CheckoutTypes, CouponTypes, Exclusivities, OrderStatus, CheckoutSubscription, Product, RequiredArgumentError, add, ProductReview, Order, UpdateUserImage, FirebaseFileUploaderService } from '@infrab4a/connect';
11
11
  import * as i1 from '@angular/fire/auth';
12
12
  import { Auth, provideAuth, initializeAuth, indexedDBLocalPersistence, browserLocalPersistence, browserSessionPersistence, getAuth, getIdToken, authState } from '@angular/fire/auth';
13
13
  import { isPlatformBrowser, isPlatformServer } from '@angular/common';
@@ -464,6 +464,13 @@ AngularFirestoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0",
464
464
  },
465
465
  deps: ['FirestoreOptions'],
466
466
  },
467
+ {
468
+ provide: 'BrandCategoryRepository',
469
+ useFactory: (options) => {
470
+ return new BrandCategoryFirestoreRepository(options);
471
+ },
472
+ deps: ['FirestoreOptions'],
473
+ },
467
474
  ], imports: [AngularElasticSeachModule,
468
475
  provideFirestore((injector) => {
469
476
  const platformId = injector.get(PLATFORM_ID);
@@ -737,6 +744,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
737
744
  },
738
745
  deps: ['FirestoreOptions'],
739
746
  },
747
+ {
748
+ provide: 'BrandCategoryRepository',
749
+ useFactory: (options) => {
750
+ return new BrandCategoryFirestoreRepository(options);
751
+ },
752
+ deps: ['FirestoreOptions'],
753
+ },
740
754
  ],
741
755
  }]
742
756
  }] });
@@ -906,17 +920,6 @@ AngularHasuraGraphQLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.
906
920
  provide: 'ProductErrorsRepository',
907
921
  useExisting: ProductErrorsHasuraGraphQLRepository,
908
922
  },
909
- {
910
- provide: ProductCatalogHasuraGraphQLRepository,
911
- useFactory: (options) => {
912
- return new ProductCatalogHasuraGraphQLRepository(options);
913
- },
914
- deps: ['HasuraConfig'],
915
- },
916
- {
917
- provide: 'ProductCatalogRepository',
918
- useExisting: ProductCatalogHasuraGraphQLRepository,
919
- },
920
923
  ] });
921
924
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, decorators: [{
922
925
  type: NgModule,
@@ -1076,17 +1079,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
1076
1079
  provide: 'ProductErrorsRepository',
1077
1080
  useExisting: ProductErrorsHasuraGraphQLRepository,
1078
1081
  },
1079
- {
1080
- provide: ProductCatalogHasuraGraphQLRepository,
1081
- useFactory: (options) => {
1082
- return new ProductCatalogHasuraGraphQLRepository(options);
1083
- },
1084
- deps: ['HasuraConfig'],
1085
- },
1086
- {
1087
- provide: 'ProductCatalogRepository',
1088
- useExisting: ProductCatalogHasuraGraphQLRepository,
1089
- },
1090
1082
  ],
1091
1083
  }]
1092
1084
  }] });
@@ -1585,14 +1577,14 @@ class CategorySearchStrategy {
1585
1577
  maximum: ['price'],
1586
1578
  distinct: ['brand'],
1587
1579
  } });
1588
- return productCatalog.productCatalogRepository.findCatalog(repoParams, null, optionsCache);
1580
+ return productCatalog.productRepository.findCatalog(repoParams, null, optionsCache);
1589
1581
  });
1590
1582
  }
1591
1583
  getProductIds(category, filters, optionsCache) {
1592
1584
  return __awaiter(this, void 0, void 0, function* () {
1593
1585
  const productCatalog = this.repositoryService.getProductCatalog();
1594
1586
  const filterHelper = this.helpersService.getFilterHelper();
1595
- return productCatalog.productCatalogRepository
1587
+ return productCatalog.productRepository
1596
1588
  .findCatalog({
1597
1589
  fields: ['id'],
1598
1590
  filters: Object.assign(Object.assign({}, (yield productCatalog.categoryStructureAdapter.buildProductFilterByCategory(category))), filterHelper.buildFilterQuery(filters || {})),
@@ -1607,7 +1599,7 @@ class CategorySearchStrategy {
1607
1599
  const filterHelper = this.helpersService.getFilterHelper();
1608
1600
  const sortHelper = this.helpersService.getSortHelper();
1609
1601
  const mostRelevantProductsIds = [...new Set(mostRelevants.concat(productIds))];
1610
- const totalResult = yield productCatalog.productCatalogRepository.findCatalog({
1602
+ const totalResult = yield productCatalog.productRepository.findCatalog({
1611
1603
  fields,
1612
1604
  filters: Object.assign({ id: { operator: Where.IN, value: mostRelevantProductsIds } }, filterHelper.buildFilterQuery(filters || {})),
1613
1605
  orderBy: sortHelper.buildSortQuery('best-sellers'),
@@ -1661,7 +1653,7 @@ class ProfileSearchStrategy {
1661
1653
  maximum: ['price'],
1662
1654
  distinct: ['brand'],
1663
1655
  } });
1664
- return productCatalog.productCatalogRepository.findCatalog(repoParams, mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'), optionsCache);
1656
+ return productCatalog.productRepository.findCatalog(repoParams, mainGender || (shop === Shops.MENSMARKET ? 'male' : 'female'), optionsCache);
1665
1657
  });
1666
1658
  }
1667
1659
  }
@@ -1708,7 +1700,7 @@ class TermSearchStrategy {
1708
1700
  const { productIds, filters, shop, mainGender } = params;
1709
1701
  const productCatalog = this.repositoryService.getProductCatalog();
1710
1702
  const filterHelper = this.helpersService.getFilterHelper();
1711
- const totalResult = yield productCatalog.productCatalogRepository.findCatalog({
1703
+ const totalResult = yield productCatalog.productRepository.findCatalog({
1712
1704
  fields: ['id', 'stock', 'gender'],
1713
1705
  filters: Object.assign({ id: { operator: Where.IN, value: productIds }, published: { operator: Where.EQUALS, value: true } }, filterHelper.buildFilterQuery(filters || {})),
1714
1706
  options: Object.assign({ minimal: ['price'], maximum: ['price'] }, (isEmpty(filters === null || filters === void 0 ? void 0 : filters.brands) ? { distinct: ['brand'] } : {})),
@@ -1727,7 +1719,7 @@ class TermSearchStrategy {
1727
1719
  const { productIds, filters, limits, shop, mainGender, fields } = params;
1728
1720
  const productCatalog = this.repositoryService.getProductCatalog();
1729
1721
  const filterHelper = this.helpersService.getFilterHelper();
1730
- return productCatalog.productCatalogRepository.findCatalog({
1722
+ return productCatalog.productRepository.findCatalog({
1731
1723
  fields,
1732
1724
  filters: Object.assign({ id: { operator: Where.IN, value: productIds }, published: { operator: Where.EQUALS, value: true } }, filterHelper.buildFilterQuery(filters || {})),
1733
1725
  limits,
@@ -1755,7 +1747,7 @@ class TermSearchStrategy {
1755
1747
  return __awaiter(this, void 0, void 0, function* () {
1756
1748
  const productCatalog = this.repositoryService.getProductCatalog();
1757
1749
  const fields = fieldsHelper.getStandardFields();
1758
- const productResult = yield productCatalog.productCatalogRepository.findCatalog({
1750
+ const productResult = yield productCatalog.productRepository.findCatalog({
1759
1751
  filters: {
1760
1752
  id: { operator: Where.IN, value: orderedId },
1761
1753
  },
@@ -1851,7 +1843,7 @@ class CategoryService {
1851
1843
  }
1852
1844
  fetchBrands(category, options, optionsCache) {
1853
1845
  return __awaiter(this, void 0, void 0, function* () {
1854
- const brands = yield this.productCatalog.productCatalogRepository
1846
+ const brands = yield this.productCatalog.productRepository
1855
1847
  .findCatalog({
1856
1848
  filters: yield this.productCatalog.categoryStructureAdapter.buildProductFilterByCategory(category),
1857
1849
  fields: ['brand'],
@@ -1887,19 +1879,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
1887
1879
  } });
1888
1880
 
1889
1881
  class ProductCatalogFacade {
1890
- constructor(productCatalogRepository, categoryStructureAdapter) {
1891
- this.productCatalogRepository = productCatalogRepository;
1882
+ constructor(productRepository, categoryStructureAdapter) {
1883
+ this.productRepository = productRepository;
1892
1884
  this.categoryStructureAdapter = categoryStructureAdapter;
1893
1885
  }
1894
1886
  }
1895
- ProductCatalogFacade.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProductCatalogFacade, deps: [{ token: 'ProductCatalogRepository' }, { token: CATEGORY_STRUCTURE }], target: i0.ɵɵFactoryTarget.Injectable });
1887
+ ProductCatalogFacade.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProductCatalogFacade, deps: [{ token: 'ProductRepository' }, { token: CATEGORY_STRUCTURE }], target: i0.ɵɵFactoryTarget.Injectable });
1896
1888
  ProductCatalogFacade.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProductCatalogFacade });
1897
1889
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ProductCatalogFacade, decorators: [{
1898
1890
  type: Injectable
1899
1891
  }], ctorParameters: function () {
1900
1892
  return [{ type: undefined, decorators: [{
1901
1893
  type: Inject,
1902
- args: ['ProductCatalogRepository']
1894
+ args: ['ProductRepository']
1903
1895
  }] }, { type: undefined, decorators: [{
1904
1896
  type: Inject,
1905
1897
  args: [CATEGORY_STRUCTURE]
@@ -1962,12 +1954,14 @@ class BrandManagerHelper {
1962
1954
  }
1963
1955
  fetchBrandsOnly(options) {
1964
1956
  return __awaiter(this, void 0, void 0, function* () {
1965
- return this.productCatalog.productCatalogRepository
1957
+ let filters = {};
1958
+ if (options.category) {
1959
+ filters = yield this.productCatalog.categoryStructureAdapter.buildProductFilterByCategory(options.category);
1960
+ }
1961
+ return this.productCatalog.productRepository
1966
1962
  .findCatalog({
1967
1963
  fields: ['id'],
1968
- filters: {
1969
- published: { operator: Where.EQUALS, value: true },
1970
- },
1964
+ filters: Object.assign(Object.assign({}, filters), { published: { operator: Where.EQUALS, value: true } }),
1971
1965
  options: {
1972
1966
  distinct: ['brand'],
1973
1967
  },