monkey-front-components 0.0.302 → 0.0.305

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.
@@ -1,4 +1,5 @@
1
1
  export * from './filter';
2
2
  export * from './password-strength';
3
3
  export * from './progress-bar';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsdGVyJztcbmV4cG9ydCAqIGZyb20gJy4vcGFzc3dvcmQtc3RyZW5ndGgnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuIl19
4
+ export * from './products';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZmlsdGVyJztcbmV4cG9ydCAqIGZyb20gJy4vcGFzc3dvcmQtc3RyZW5ndGgnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcy1iYXInO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0cyc7XG4iXX0=
@@ -0,0 +1,36 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "monkey-style-guide";
4
+ import * as i2 from "@ngx-translate/core";
5
+ export class MECXProductsFilterComponent {
6
+ constructor() {
7
+ this.isLoading = false;
8
+ this.onChangeFilter = new EventEmitter();
9
+ this._search = '';
10
+ // not to do
11
+ }
12
+ onSearchFilter(event) {
13
+ this._search = event;
14
+ if (!event) {
15
+ this.onChangeFilter.next('');
16
+ return;
17
+ }
18
+ event = `${event}`.toLowerCase();
19
+ this.onChangeFilter.next(event);
20
+ }
21
+ onClearFilter() {
22
+ this._search = '';
23
+ this.onChangeFilter.next(this._search);
24
+ }
25
+ }
26
+ MECXProductsFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
27
+ MECXProductsFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXProductsFilterComponent, selector: "mecx-products-filter", inputs: { isLoading: "isLoading" }, outputs: { onChangeFilter: "onChangeFilter" }, ngImport: i0, template: "<monkey-input-filter [placeholder]=\"'SIDEBAR-ACTIONS.PROFILE.FILTER.SEARCH-INPUT' | translate\"\n (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" [(value)]=\"_search\">\n</monkey-input-filter>\n<monkey-button type=\"filter\" color=\"border\" (click)=\"onClearFilter()\">\n Limpar\n</monkey-button>", styles: [":host{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}:host ::ng-deep mecx-form-field-filter mecx-form-field-body{height:44px}:host ::ng-deep monkey-input-filter{width:100%}@media screen and (min-width: 960px){:host ::ng-deep monkey-input-filter{margin-right:8px}}\n"], components: [{ type: i1.MonkeyInputFilterComponent, selector: "monkey-input-filter", inputs: ["name", "label", "helperMessage", "placeholder", "icon", "type", "infoMessage", "errorMessage", "mask", "prefix", "onlyNumber", "onlyAlphaNumeric", "upperCase", "lowerCase", "capitalize", "currency", "iconPosition", "value"], outputs: ["onChange"] }, { type: i1.MonkeyButtonComponent, selector: "monkey-button", inputs: ["label", "icon", "iconPosition", "type", "color", "disabled", "size"] }], pipes: { "translate": i2.TranslatePipe } });
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsFilterComponent, decorators: [{
29
+ type: Component,
30
+ args: [{ selector: 'mecx-products-filter', template: "<monkey-input-filter [placeholder]=\"'SIDEBAR-ACTIONS.PROFILE.FILTER.SEARCH-INPUT' | translate\"\n (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" [(value)]=\"_search\">\n</monkey-input-filter>\n<monkey-button type=\"filter\" color=\"border\" (click)=\"onClearFilter()\">\n Limpar\n</monkey-button>", styles: [":host{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}:host ::ng-deep mecx-form-field-filter mecx-form-field-body{height:44px}:host ::ng-deep monkey-input-filter{width:100%}@media screen and (min-width: 960px){:host ::ng-deep monkey-input-filter{margin-right:8px}}\n"] }]
31
+ }], ctorParameters: function () { return []; }, propDecorators: { isLoading: [{
32
+ type: Input
33
+ }], onChangeFilter: [{
34
+ type: Output
35
+ }] } });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1mcm9udC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaGFyZWQvcHJvZHVjdHMvZmlsdGVyL2ZpbHRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL3Byb2R1Y3RzL2ZpbHRlci9maWx0ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQU92RSxNQUFNLE9BQU8sMkJBQTJCO0lBT3RDO1FBTlMsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUVqQixtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbkQsWUFBTyxHQUFHLEVBQUUsQ0FBQztRQUdYLFlBQVk7SUFDZCxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQWE7UUFDMUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7UUFDckIsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNWLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQzdCLE9BQU87U0FDUjtRQUNELEtBQUssR0FBRyxHQUFHLEtBQUssRUFBRSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRWpDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCxhQUFhO1FBQ1gsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7UUFDbEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3pDLENBQUM7O3dIQXpCVSwyQkFBMkI7NEdBQTNCLDJCQUEyQiwrSUNQeEMsdVRBS2dCOzJGREVILDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSxzQkFBc0I7MEVBS3ZCLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUksY0FBYztzQkFBdkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21lY3gtcHJvZHVjdHMtZmlsdGVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbHRlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ZpbHRlci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1FQ1hQcm9kdWN0c0ZpbHRlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGlzTG9hZGluZyA9IGZhbHNlO1xuXG4gIEBPdXRwdXQoKSBvbkNoYW5nZUZpbHRlciA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIF9zZWFyY2ggPSAnJztcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICAvLyBub3QgdG8gZG9cbiAgfVxuXG4gIG9uU2VhcmNoRmlsdGVyKGV2ZW50OiBzdHJpbmcpIHtcbiAgICB0aGlzLl9zZWFyY2ggPSBldmVudDtcbiAgICBpZiAoIWV2ZW50KSB7XG4gICAgICB0aGlzLm9uQ2hhbmdlRmlsdGVyLm5leHQoJycpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBldmVudCA9IGAke2V2ZW50fWAudG9Mb3dlckNhc2UoKTtcblxuICAgIHRoaXMub25DaGFuZ2VGaWx0ZXIubmV4dChldmVudCk7XG4gIH1cblxuICBvbkNsZWFyRmlsdGVyKCkge1xuICAgIHRoaXMuX3NlYXJjaCA9ICcnO1xuICAgIHRoaXMub25DaGFuZ2VGaWx0ZXIubmV4dCh0aGlzLl9zZWFyY2gpO1xuICB9XG59XG4iLCI8bW9ua2V5LWlucHV0LWZpbHRlciBbcGxhY2Vob2xkZXJdPVwiJ1NJREVCQVItQUNUSU9OUy5QUk9GSUxFLkZJTFRFUi5TRUFSQ0gtSU5QVVQnIHwgdHJhbnNsYXRlXCJcbiAgKG9uQ2hhbmdlKT1cIm9uU2VhcmNoRmlsdGVyKCRldmVudClcIiBpY29uPVwic2VhcmNoLTE2XCIgWyh2YWx1ZSldPVwiX3NlYXJjaFwiPlxuPC9tb25rZXktaW5wdXQtZmlsdGVyPlxuPG1vbmtleS1idXR0b24gdHlwZT1cImZpbHRlclwiIGNvbG9yPVwiYm9yZGVyXCIgKGNsaWNrKT1cIm9uQ2xlYXJGaWx0ZXIoKVwiPlxuICBMaW1wYXJcbjwvbW9ua2V5LWJ1dHRvbj4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from './products.component';
2
+ export * from './products.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL3Byb2R1Y3RzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZHVjdHMubW9kdWxlJztcbiJdfQ==
@@ -0,0 +1,89 @@
1
+ import { Component, EventEmitter, Output } from '@angular/core';
2
+ import { takeUntil } from 'rxjs/operators';
3
+ import { BaseComponent } from '../../base/base-component';
4
+ import { ProductsModel } from './providers';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "monkey-front-core";
7
+ import * as i2 from "./filter/filter.component";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "@ngx-translate/core";
10
+ export class MECXProductsComponent extends BaseComponent {
11
+ constructor(tokenStorage) {
12
+ super();
13
+ this.tokenStorage = tokenStorage;
14
+ this.onAccess = new EventEmitter();
15
+ this._filter = '';
16
+ }
17
+ onImgError(img) {
18
+ const index = Math.floor(Math.random() * (6 - 1 + 1)) + 1;
19
+ img.src = `https://assets.monkeyecx.com/icons/icon-${index}.svg`;
20
+ img.className = 'no-image';
21
+ }
22
+ onHandleProducts() {
23
+ const { _filter } = this;
24
+ this._filteredProducts = this._products.map(({ name, items }) => {
25
+ const found = items?.filter((_) => {
26
+ const cmpA = `${_.name}`.toLowerCase();
27
+ const cmpB = `${_filter}`.toLowerCase();
28
+ return cmpA.includes(cmpB);
29
+ });
30
+ if (found && found.length) {
31
+ return {
32
+ name,
33
+ items: found
34
+ };
35
+ }
36
+ return null;
37
+ }).filter((_) => { return _; });
38
+ }
39
+ onHandleMe() {
40
+ const programs = this.tokenStorage.getMe()?.programs?.map((_) => {
41
+ return new ProductsModel(_);
42
+ });
43
+ const onlyUnique = (value, index, self) => {
44
+ return self.indexOf(value) === index;
45
+ };
46
+ const products = programs.map(({ product }) => {
47
+ return product;
48
+ }).filter(onlyUnique);
49
+ this._products = Object.entries(products).map(([key, value]) => {
50
+ const found = programs.filter(({ product }) => {
51
+ return `${product}` === `${value}`;
52
+ })?.sort((a, b) => {
53
+ const groupA = `${a?.name}`.toLowerCase();
54
+ const groupB = `${b?.name}`.toLowerCase();
55
+ return groupA !== groupB ? 1 : -1;
56
+ });
57
+ return {
58
+ name: value,
59
+ items: found
60
+ };
61
+ })?.sort((a, b) => {
62
+ const groupA = `${a?.name}`.toLowerCase();
63
+ const groupB = `${b?.name}`.toLowerCase();
64
+ return groupA !== groupB ? -1 : 1;
65
+ });
66
+ this._filteredProducts = this._products;
67
+ }
68
+ ngOnInit() {
69
+ this.tokenStorage
70
+ .meHasChanged()
71
+ .pipe(takeUntil(this.__unsubscribeAll))
72
+ .subscribe(() => {
73
+ this.onHandleMe();
74
+ });
75
+ }
76
+ onHandleChangeFilter(event) {
77
+ this._filter = event;
78
+ this.onHandleProducts();
79
+ }
80
+ }
81
+ MECXProductsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsComponent, deps: [{ token: i1.MonkeyEcxTokenStorageService }], target: i0.ɵɵFactoryTarget.Component });
82
+ MECXProductsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXProductsComponent, selector: "mecx-products", outputs: { onAccess: "onAccess" }, usesInheritance: true, ngImport: i0, template: "<mecx-products-filter (onChangeFilter)=\"onHandleChangeFilter($event)\"></mecx-products-filter>\r\n<div class=\"products-list\">\r\n <div *ngFor=\"let product of _filteredProducts\" class=\"product\">\r\n <span class=\"title\">{{ 'PRODUCTS.'+product.name | translate }}</span>\r\n <div class=\"items\">\r\n <div *ngFor=\"let item of product.items\" class=\"item\"\r\n (click)=\"onAccess.next(item)\">\r\n <div class=\"icon\">\r\n <img [src]=\"item.logo\" #img (error)=\"onImgError(img)\">\r\n </div>\r\n <span class=\"name\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:flex;flex-direction:column;overflow:hidden}:host .products-list{display:flex;flex-direction:column;overflow:auto}:host .product{display:flex;flex-direction:column}:host .product .title{font-style:normal;font-weight:600;font-size:24px;line-height:32px;letter-spacing:.04em;color:#4b4a53;margin:32px 0}:host .product .items{display:grid;grid-template-columns:repeat(2,1fr);grid-column-gap:10px;grid-row-gap:10px}:host .product .items .item{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;padding:12px}:host .product .items .item .icon{margin:12px 0}:host .product .items .item .icon img{width:100%;max-width:140px}:host .product .items .item .icon .no-image{width:52px;height:52px}:host .product .items .item .name{font-style:normal;font-weight:400;font-size:18px;line-height:24px;color:#72717e;margin-top:8px}:host .product .items .item:hover{box-shadow:0 25px 52px 8px #eaeaeae0}\n"], components: [{ type: i2.MECXProductsFilterComponent, selector: "mecx-products-filter", inputs: ["isLoading"], outputs: ["onChangeFilter"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i4.TranslatePipe } });
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsComponent, decorators: [{
84
+ type: Component,
85
+ args: [{ selector: 'mecx-products', template: "<mecx-products-filter (onChangeFilter)=\"onHandleChangeFilter($event)\"></mecx-products-filter>\r\n<div class=\"products-list\">\r\n <div *ngFor=\"let product of _filteredProducts\" class=\"product\">\r\n <span class=\"title\">{{ 'PRODUCTS.'+product.name | translate }}</span>\r\n <div class=\"items\">\r\n <div *ngFor=\"let item of product.items\" class=\"item\"\r\n (click)=\"onAccess.next(item)\">\r\n <div class=\"icon\">\r\n <img [src]=\"item.logo\" #img (error)=\"onImgError(img)\">\r\n </div>\r\n <span class=\"name\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:flex;flex-direction:column;overflow:hidden}:host .products-list{display:flex;flex-direction:column;overflow:auto}:host .product{display:flex;flex-direction:column}:host .product .title{font-style:normal;font-weight:600;font-size:24px;line-height:32px;letter-spacing:.04em;color:#4b4a53;margin:32px 0}:host .product .items{display:grid;grid-template-columns:repeat(2,1fr);grid-column-gap:10px;grid-row-gap:10px}:host .product .items .item{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;padding:12px}:host .product .items .item .icon{margin:12px 0}:host .product .items .item .icon img{width:100%;max-width:140px}:host .product .items .item .icon .no-image{width:52px;height:52px}:host .product .items .item .name{font-style:normal;font-weight:400;font-size:18px;line-height:24px;color:#72717e;margin-top:8px}:host .product .items .item:hover{box-shadow:0 25px 52px 8px #eaeaeae0}\n"] }]
86
+ }], ctorParameters: function () { return [{ type: i1.MonkeyEcxTokenStorageService }]; }, propDecorators: { onAccess: [{
87
+ type: Output
88
+ }] } });
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"products.component.js","sourceRoot":"","sources":["../../../../../../../projects/monkey-front-components/src/lib/components/shared/products/products.component.ts","../../../../../../../projects/monkey-front-components/src/lib/components/shared/products/products.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, OnInit, Output } from '@angular/core';\nimport { MonkeyEcxTokenStorageService } from 'monkey-front-core';\nimport { takeUntil } from 'rxjs/operators';\nimport { BaseComponent } from '../../base/base-component';\nimport { ProductsModel } from './providers';\n\n@Component({\n  selector: 'mecx-products',\n  templateUrl: './products.component.html',\n  styleUrls: ['./products.component.scss']\n})\nexport class MECXProductsComponent extends BaseComponent implements OnInit {\n  @Output() onAccess = new EventEmitter<any>();\n\n  _products: any[];\n\n  _filteredProducts: any[];\n\n  _filter = '';\n\n  constructor(private tokenStorage: MonkeyEcxTokenStorageService) {\n    super();\n  }\n\n  onImgError(img: HTMLImageElement) {\n    const index = Math.floor(Math.random() * (6 - 1 + 1)) + 1;\n    img.src = `https://assets.monkeyecx.com/icons/icon-${index}.svg`;\n    img.className = 'no-image';\n  }\n\n  private onHandleProducts() {\n    const { _filter } = this;\n\n    this._filteredProducts = this._products.map(({ name, items }) => {\n      const found = items?.filter((_: any) => {\n        const cmpA = `${_.name}`.toLowerCase();\n        const cmpB = `${_filter}`.toLowerCase();\n        return cmpA.includes(cmpB);\n      });\n\n      if (found && found.length) {\n        return {\n          name,\n          items: found\n        };\n      }\n\n      return null;\n    }).filter((_: any) => { return _; });\n  }\n\n  private onHandleMe() {\n    const programs: ProductsModel[] = this.tokenStorage.getMe()?.programs?.map((_: any) => {\n      return new ProductsModel(_);\n    });\n\n    const onlyUnique = (value: any, index: any, self: any) => {\n      return self.indexOf(value) === index;\n    };\n\n    const products = programs.map(({ product }) => {\n      return product;\n    }).filter(onlyUnique);\n\n    this._products = Object.entries(products).map(([key, value]) => {\n      const found = programs.filter(({ product }) => {\n        return `${product}` === `${value}`;\n      })?.sort((a, b) => {\n        const groupA = `${a?.name}`.toLowerCase();\n        const groupB = `${b?.name}`.toLowerCase();\n        return groupA !== groupB ? 1 : -1;\n      });\n\n      return {\n        name: value,\n        items: found\n      };\n    })?.sort((a, b) => {\n      const groupA = `${a?.name}`.toLowerCase();\n      const groupB = `${b?.name}`.toLowerCase();\n      return groupA !== groupB ? -1 : 1;\n    });\n\n    this._filteredProducts = this._products;\n  }\n\n  ngOnInit() {\n    this.tokenStorage\n      .meHasChanged()\n      .pipe(takeUntil(this.__unsubscribeAll))\n      .subscribe(() => {\n        this.onHandleMe();\n      });\n  }\n\n  onHandleChangeFilter(event: string) {\n    this._filter = event;\n    this.onHandleProducts();\n  }\n}\n","<mecx-products-filter (onChangeFilter)=\"onHandleChangeFilter($event)\"></mecx-products-filter>\r\n<div class=\"products-list\">\r\n  <div *ngFor=\"let product of _filteredProducts\" class=\"product\">\r\n    <span class=\"title\">{{ 'PRODUCTS.'+product.name | translate }}</span>\r\n    <div class=\"items\">\r\n      <div *ngFor=\"let item of product.items\" class=\"item\"\r\n        (click)=\"onAccess.next(item)\">\r\n        <div class=\"icon\">\r\n          <img [src]=\"item.logo\" #img (error)=\"onImgError(img)\">\r\n        </div>\r\n        <span class=\"name\">{{ item.name }}</span>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>"]}
@@ -0,0 +1,22 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { TranslateModule } from '@ngx-translate/core';
4
+ import { MonkeyButtonModule, MonkeyInputModule } from 'monkey-style-guide';
5
+ import { MECXProductsFilterComponent } from './filter/filter.component';
6
+ import { MECXProductsComponent } from './products.component';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@ngx-translate/core";
9
+ export class MECXProductsModule {
10
+ }
11
+ MECXProductsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
+ MECXProductsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, declarations: [MECXProductsComponent, MECXProductsFilterComponent], imports: [CommonModule, i1.TranslateModule, MonkeyInputModule, MonkeyButtonModule], exports: [MECXProductsComponent] });
13
+ MECXProductsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, imports: [[CommonModule, TranslateModule.forChild(), MonkeyInputModule, MonkeyButtonModule]] });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, decorators: [{
15
+ type: NgModule,
16
+ args: [{
17
+ declarations: [MECXProductsComponent, MECXProductsFilterComponent],
18
+ imports: [CommonModule, TranslateModule.forChild(), MonkeyInputModule, MonkeyButtonModule],
19
+ exports: [MECXProductsComponent]
20
+ }]
21
+ }] });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC9wcm9kdWN0cy9wcm9kdWN0cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzNFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFPN0QsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQUpkLHFCQUFxQixFQUFFLDJCQUEyQixhQUN2RCxZQUFZLHNCQUE4QixpQkFBaUIsRUFBRSxrQkFBa0IsYUFDL0UscUJBQXFCO2dIQUVwQixrQkFBa0IsWUFIcEIsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFFBQVEsRUFBRSxFQUFFLGlCQUFpQixFQUFFLGtCQUFrQixDQUFDOzJGQUcvRSxrQkFBa0I7a0JBTDlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLEVBQUUsMkJBQTJCLENBQUM7b0JBQ2xFLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxlQUFlLENBQUMsUUFBUSxFQUFFLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLENBQUM7b0JBQzFGLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBNb25rZXlCdXR0b25Nb2R1bGUsIE1vbmtleUlucHV0TW9kdWxlIH0gZnJvbSAnbW9ua2V5LXN0eWxlLWd1aWRlJztcbmltcG9ydCB7IE1FQ1hQcm9kdWN0c0ZpbHRlckNvbXBvbmVudCB9IGZyb20gJy4vZmlsdGVyL2ZpbHRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgTUVDWFByb2R1Y3RzQ29tcG9uZW50IH0gZnJvbSAnLi9wcm9kdWN0cy5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtNRUNYUHJvZHVjdHNDb21wb25lbnQsIE1FQ1hQcm9kdWN0c0ZpbHRlckNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRyYW5zbGF0ZU1vZHVsZS5mb3JDaGlsZCgpLCBNb25rZXlJbnB1dE1vZHVsZSwgTW9ua2V5QnV0dG9uTW9kdWxlXSxcbiAgZXhwb3J0czogW01FQ1hQcm9kdWN0c0NvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgTUVDWFByb2R1Y3RzTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './products.model';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL3Byb2R1Y3RzL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wcm9kdWN0cy5tb2RlbCc7XG4iXX0=
@@ -0,0 +1,33 @@
1
+ export class ProductsModel {
2
+ constructor(data) {
3
+ this.url = data?.url;
4
+ this.token = data?.token;
5
+ this.username = data?.username;
6
+ this.ownerGovernmentId = data?.ownerGovernmentId;
7
+ this.ownerName = data?.ownerName;
8
+ this.product = data?.product;
9
+ this.name = data?.name;
10
+ this.type = data?.type;
11
+ this.handleLogo();
12
+ }
13
+ handleLogo() {
14
+ const { product, token, url } = this;
15
+ if (!url)
16
+ return;
17
+ const contries = {
18
+ '.monkey.exchange': 'br',
19
+ '.monkeyecx.com': 'br',
20
+ '.sales.finance': 'br',
21
+ '.monkeyexchange.cl': 'cl'
22
+ };
23
+ const domain = url.substring(url.indexOf('.', -1), url.length);
24
+ const country = contries[domain];
25
+ const sufix = {
26
+ SUPPLY_CHAIN: 'SCF',
27
+ SALES_FINANCE: 'SF'
28
+ }[product];
29
+ const handled = `https://assets.monkey.exchange/${sufix}/${country}/wl/${token}/login.svg`;
30
+ this.logo = handled.toLowerCase();
31
+ }
32
+ }
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdHMubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL3Byb2R1Y3RzL3Byb3ZpZGVycy9wcm9kdWN0cy5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sYUFBYTtJQW1CeEIsWUFBWSxJQUFVO1FBQ3BCLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxFQUFFLEdBQUcsQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksRUFBRSxLQUFLLENBQUM7UUFDekIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLEVBQUUsUUFBUSxDQUFDO1FBQy9CLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLEVBQUUsaUJBQWlCLENBQUM7UUFDakQsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLEVBQUUsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxFQUFFLE9BQU8sQ0FBQztRQUM3QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksRUFBRSxJQUFJLENBQUM7UUFDdkIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLEVBQUUsSUFBSSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRU8sVUFBVTtRQUNoQixNQUFNLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDckMsSUFBSSxDQUFDLEdBQUc7WUFBRSxPQUFPO1FBRWpCLE1BQU0sUUFBUSxHQUFRO1lBQ3BCLGtCQUFrQixFQUFFLElBQUk7WUFDeEIsZ0JBQWdCLEVBQUUsSUFBSTtZQUN0QixnQkFBZ0IsRUFBRSxJQUFJO1lBQ3RCLG9CQUFvQixFQUFFLElBQUk7U0FDM0IsQ0FBQztRQUNGLE1BQU0sTUFBTSxHQUFHLEdBQUcsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDL0QsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRWpDLE1BQU0sS0FBSyxHQUFHO1lBQ1osWUFBWSxFQUFFLEtBQUs7WUFDbkIsYUFBYSxFQUFFLElBQUk7U0FDcEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVYLE1BQU0sT0FBTyxHQUFHLGtDQUFrQyxLQUFLLElBQUksT0FBTyxPQUFPLEtBQUssWUFBWSxDQUFDO1FBRTNGLElBQUksQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3BDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBQcm9kdWN0c01vZGVsIHtcbiAgdXJsOiBzdHJpbmc7XG5cbiAgdG9rZW46IHN0cmluZztcblxuICB1c2VybmFtZTogc3RyaW5nO1xuXG4gIG93bmVyR292ZXJubWVudElkOiBzdHJpbmc7XG5cbiAgb3duZXJOYW1lOiBzdHJpbmc7XG5cbiAgcHJvZHVjdDogc3RyaW5nO1xuXG4gIG5hbWU6IHN0cmluZztcblxuICB0eXBlOiBzdHJpbmc7XG5cbiAgbG9nbzogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKGRhdGE/OiBhbnkpIHtcbiAgICB0aGlzLnVybCA9IGRhdGE/LnVybDtcbiAgICB0aGlzLnRva2VuID0gZGF0YT8udG9rZW47XG4gICAgdGhpcy51c2VybmFtZSA9IGRhdGE/LnVzZXJuYW1lO1xuICAgIHRoaXMub3duZXJHb3Zlcm5tZW50SWQgPSBkYXRhPy5vd25lckdvdmVybm1lbnRJZDtcbiAgICB0aGlzLm93bmVyTmFtZSA9IGRhdGE/Lm93bmVyTmFtZTtcbiAgICB0aGlzLnByb2R1Y3QgPSBkYXRhPy5wcm9kdWN0O1xuICAgIHRoaXMubmFtZSA9IGRhdGE/Lm5hbWU7XG4gICAgdGhpcy50eXBlID0gZGF0YT8udHlwZTtcbiAgICB0aGlzLmhhbmRsZUxvZ28oKTtcbiAgfVxuXG4gIHByaXZhdGUgaGFuZGxlTG9nbygpIHtcbiAgICBjb25zdCB7IHByb2R1Y3QsIHRva2VuLCB1cmwgfSA9IHRoaXM7XG4gICAgaWYgKCF1cmwpIHJldHVybjtcblxuICAgIGNvbnN0IGNvbnRyaWVzOiBhbnkgPSB7XG4gICAgICAnLm1vbmtleS5leGNoYW5nZSc6ICdicicsXG4gICAgICAnLm1vbmtleWVjeC5jb20nOiAnYnInLFxuICAgICAgJy5zYWxlcy5maW5hbmNlJzogJ2JyJyxcbiAgICAgICcubW9ua2V5ZXhjaGFuZ2UuY2wnOiAnY2wnXG4gICAgfTtcbiAgICBjb25zdCBkb21haW4gPSB1cmwuc3Vic3RyaW5nKHVybC5pbmRleE9mKCcuJywgLTEpLCB1cmwubGVuZ3RoKTtcbiAgICBjb25zdCBjb3VudHJ5ID0gY29udHJpZXNbZG9tYWluXTtcblxuICAgIGNvbnN0IHN1Zml4ID0ge1xuICAgICAgU1VQUExZX0NIQUlOOiAnU0NGJyxcbiAgICAgIFNBTEVTX0ZJTkFOQ0U6ICdTRidcbiAgICB9W3Byb2R1Y3RdO1xuXG4gICAgY29uc3QgaGFuZGxlZCA9IGBodHRwczovL2Fzc2V0cy5tb25rZXkuZXhjaGFuZ2UvJHtzdWZpeH0vJHtjb3VudHJ5fS93bC8ke3Rva2VufS9sb2dpbi5zdmdgO1xuXG4gICAgdGhpcy5sb2dvID0gaGFuZGxlZC50b0xvd2VyQ2FzZSgpO1xuICB9XG59XG4iXX0=
@@ -2619,6 +2619,167 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
2619
2619
  }]
2620
2620
  }] });
2621
2621
 
2622
+ class ProductsModel {
2623
+ constructor(data) {
2624
+ this.url = data === null || data === void 0 ? void 0 : data.url;
2625
+ this.token = data === null || data === void 0 ? void 0 : data.token;
2626
+ this.username = data === null || data === void 0 ? void 0 : data.username;
2627
+ this.ownerGovernmentId = data === null || data === void 0 ? void 0 : data.ownerGovernmentId;
2628
+ this.ownerName = data === null || data === void 0 ? void 0 : data.ownerName;
2629
+ this.product = data === null || data === void 0 ? void 0 : data.product;
2630
+ this.name = data === null || data === void 0 ? void 0 : data.name;
2631
+ this.type = data === null || data === void 0 ? void 0 : data.type;
2632
+ this.handleLogo();
2633
+ }
2634
+ handleLogo() {
2635
+ const { product, token, url } = this;
2636
+ if (!url)
2637
+ return;
2638
+ const contries = {
2639
+ '.monkey.exchange': 'br',
2640
+ '.monkeyecx.com': 'br',
2641
+ '.sales.finance': 'br',
2642
+ '.monkeyexchange.cl': 'cl'
2643
+ };
2644
+ const domain = url.substring(url.indexOf('.', -1), url.length);
2645
+ const country = contries[domain];
2646
+ const sufix = {
2647
+ SUPPLY_CHAIN: 'SCF',
2648
+ SALES_FINANCE: 'SF'
2649
+ }[product];
2650
+ const handled = `https://assets.monkey.exchange/${sufix}/${country}/wl/${token}/login.svg`;
2651
+ this.logo = handled.toLowerCase();
2652
+ }
2653
+ }
2654
+
2655
+ class MECXProductsFilterComponent {
2656
+ constructor() {
2657
+ this.isLoading = false;
2658
+ this.onChangeFilter = new EventEmitter();
2659
+ this._search = '';
2660
+ // not to do
2661
+ }
2662
+ onSearchFilter(event) {
2663
+ this._search = event;
2664
+ if (!event) {
2665
+ this.onChangeFilter.next('');
2666
+ return;
2667
+ }
2668
+ event = `${event}`.toLowerCase();
2669
+ this.onChangeFilter.next(event);
2670
+ }
2671
+ onClearFilter() {
2672
+ this._search = '';
2673
+ this.onChangeFilter.next(this._search);
2674
+ }
2675
+ }
2676
+ MECXProductsFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
2677
+ MECXProductsFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXProductsFilterComponent, selector: "mecx-products-filter", inputs: { isLoading: "isLoading" }, outputs: { onChangeFilter: "onChangeFilter" }, ngImport: i0, template: "<monkey-input-filter [placeholder]=\"'SIDEBAR-ACTIONS.PROFILE.FILTER.SEARCH-INPUT' | translate\"\n (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" [(value)]=\"_search\">\n</monkey-input-filter>\n<monkey-button type=\"filter\" color=\"border\" (click)=\"onClearFilter()\">\n Limpar\n</monkey-button>", styles: [":host{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}:host ::ng-deep mecx-form-field-filter mecx-form-field-body{height:44px}:host ::ng-deep monkey-input-filter{width:100%}@media screen and (min-width: 960px){:host ::ng-deep monkey-input-filter{margin-right:8px}}\n"], components: [{ type: i1$2.MonkeyInputFilterComponent, selector: "monkey-input-filter", inputs: ["name", "label", "helperMessage", "placeholder", "icon", "type", "infoMessage", "errorMessage", "mask", "prefix", "onlyNumber", "onlyAlphaNumeric", "upperCase", "lowerCase", "capitalize", "currency", "iconPosition", "value"], outputs: ["onChange"] }, { type: i1$2.MonkeyButtonComponent, selector: "monkey-button", inputs: ["label", "icon", "iconPosition", "type", "color", "disabled", "size"] }], pipes: { "translate": i1$3.TranslatePipe } });
2678
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsFilterComponent, decorators: [{
2679
+ type: Component,
2680
+ args: [{ selector: 'mecx-products-filter', template: "<monkey-input-filter [placeholder]=\"'SIDEBAR-ACTIONS.PROFILE.FILTER.SEARCH-INPUT' | translate\"\n (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" [(value)]=\"_search\">\n</monkey-input-filter>\n<monkey-button type=\"filter\" color=\"border\" (click)=\"onClearFilter()\">\n Limpar\n</monkey-button>", styles: [":host{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}:host ::ng-deep mecx-form-field-filter mecx-form-field-body{height:44px}:host ::ng-deep monkey-input-filter{width:100%}@media screen and (min-width: 960px){:host ::ng-deep monkey-input-filter{margin-right:8px}}\n"] }]
2681
+ }], ctorParameters: function () { return []; }, propDecorators: { isLoading: [{
2682
+ type: Input
2683
+ }], onChangeFilter: [{
2684
+ type: Output
2685
+ }] } });
2686
+
2687
+ class MECXProductsComponent extends BaseComponent {
2688
+ constructor(tokenStorage) {
2689
+ super();
2690
+ this.tokenStorage = tokenStorage;
2691
+ this.onAccess = new EventEmitter();
2692
+ this._filter = '';
2693
+ }
2694
+ onImgError(img) {
2695
+ const index = Math.floor(Math.random() * (6 - 1 + 1)) + 1;
2696
+ img.src = `https://assets.monkeyecx.com/icons/icon-${index}.svg`;
2697
+ img.className = 'no-image';
2698
+ }
2699
+ onHandleProducts() {
2700
+ const { _filter } = this;
2701
+ this._filteredProducts = this._products.map(({ name, items }) => {
2702
+ const found = items === null || items === void 0 ? void 0 : items.filter((_) => {
2703
+ const cmpA = `${_.name}`.toLowerCase();
2704
+ const cmpB = `${_filter}`.toLowerCase();
2705
+ return cmpA.includes(cmpB);
2706
+ });
2707
+ if (found && found.length) {
2708
+ return {
2709
+ name,
2710
+ items: found
2711
+ };
2712
+ }
2713
+ return null;
2714
+ }).filter((_) => { return _; });
2715
+ }
2716
+ onHandleMe() {
2717
+ var _a, _b, _c;
2718
+ const programs = (_b = (_a = this.tokenStorage.getMe()) === null || _a === void 0 ? void 0 : _a.programs) === null || _b === void 0 ? void 0 : _b.map((_) => {
2719
+ return new ProductsModel(_);
2720
+ });
2721
+ const onlyUnique = (value, index, self) => {
2722
+ return self.indexOf(value) === index;
2723
+ };
2724
+ const products = programs.map(({ product }) => {
2725
+ return product;
2726
+ }).filter(onlyUnique);
2727
+ this._products = (_c = Object.entries(products).map(([key, value]) => {
2728
+ var _a;
2729
+ const found = (_a = programs.filter(({ product }) => {
2730
+ return `${product}` === `${value}`;
2731
+ })) === null || _a === void 0 ? void 0 : _a.sort((a, b) => {
2732
+ const groupA = `${a === null || a === void 0 ? void 0 : a.name}`.toLowerCase();
2733
+ const groupB = `${b === null || b === void 0 ? void 0 : b.name}`.toLowerCase();
2734
+ return groupA !== groupB ? 1 : -1;
2735
+ });
2736
+ return {
2737
+ name: value,
2738
+ items: found
2739
+ };
2740
+ })) === null || _c === void 0 ? void 0 : _c.sort((a, b) => {
2741
+ const groupA = `${a === null || a === void 0 ? void 0 : a.name}`.toLowerCase();
2742
+ const groupB = `${b === null || b === void 0 ? void 0 : b.name}`.toLowerCase();
2743
+ return groupA !== groupB ? -1 : 1;
2744
+ });
2745
+ this._filteredProducts = this._products;
2746
+ }
2747
+ ngOnInit() {
2748
+ this.tokenStorage
2749
+ .meHasChanged()
2750
+ .pipe(takeUntil(this.__unsubscribeAll))
2751
+ .subscribe(() => {
2752
+ this.onHandleMe();
2753
+ });
2754
+ }
2755
+ onHandleChangeFilter(event) {
2756
+ this._filter = event;
2757
+ this.onHandleProducts();
2758
+ }
2759
+ }
2760
+ MECXProductsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsComponent, deps: [{ token: i1$4.MonkeyEcxTokenStorageService }], target: i0.ɵɵFactoryTarget.Component });
2761
+ MECXProductsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXProductsComponent, selector: "mecx-products", outputs: { onAccess: "onAccess" }, usesInheritance: true, ngImport: i0, template: "<mecx-products-filter (onChangeFilter)=\"onHandleChangeFilter($event)\"></mecx-products-filter>\r\n<div class=\"products-list\">\r\n <div *ngFor=\"let product of _filteredProducts\" class=\"product\">\r\n <span class=\"title\">{{ 'PRODUCTS.'+product.name | translate }}</span>\r\n <div class=\"items\">\r\n <div *ngFor=\"let item of product.items\" class=\"item\"\r\n (click)=\"onAccess.next(item)\">\r\n <div class=\"icon\">\r\n <img [src]=\"item.logo\" #img (error)=\"onImgError(img)\">\r\n </div>\r\n <span class=\"name\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:flex;flex-direction:column;overflow:hidden}:host .products-list{display:flex;flex-direction:column;overflow:auto}:host .product{display:flex;flex-direction:column}:host .product .title{font-style:normal;font-weight:600;font-size:24px;line-height:32px;letter-spacing:.04em;color:#4b4a53;margin:32px 0}:host .product .items{display:grid;grid-template-columns:repeat(2,1fr);grid-column-gap:10px;grid-row-gap:10px}:host .product .items .item{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;padding:12px}:host .product .items .item .icon{margin:12px 0}:host .product .items .item .icon img{width:100%;max-width:140px}:host .product .items .item .icon .no-image{width:52px;height:52px}:host .product .items .item .name{font-style:normal;font-weight:400;font-size:18px;line-height:24px;color:#72717e;margin-top:8px}:host .product .items .item:hover{box-shadow:0 25px 52px 8px #eaeaeae0}\n"], components: [{ type: MECXProductsFilterComponent, selector: "mecx-products-filter", inputs: ["isLoading"], outputs: ["onChangeFilter"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i1$3.TranslatePipe } });
2762
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsComponent, decorators: [{
2763
+ type: Component,
2764
+ args: [{ selector: 'mecx-products', template: "<mecx-products-filter (onChangeFilter)=\"onHandleChangeFilter($event)\"></mecx-products-filter>\r\n<div class=\"products-list\">\r\n <div *ngFor=\"let product of _filteredProducts\" class=\"product\">\r\n <span class=\"title\">{{ 'PRODUCTS.'+product.name | translate }}</span>\r\n <div class=\"items\">\r\n <div *ngFor=\"let item of product.items\" class=\"item\"\r\n (click)=\"onAccess.next(item)\">\r\n <div class=\"icon\">\r\n <img [src]=\"item.logo\" #img (error)=\"onImgError(img)\">\r\n </div>\r\n <span class=\"name\">{{ item.name }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [":host{display:flex;flex-direction:column;overflow:hidden}:host .products-list{display:flex;flex-direction:column;overflow:auto}:host .product{display:flex;flex-direction:column}:host .product .title{font-style:normal;font-weight:600;font-size:24px;line-height:32px;letter-spacing:.04em;color:#4b4a53;margin:32px 0}:host .product .items{display:grid;grid-template-columns:repeat(2,1fr);grid-column-gap:10px;grid-row-gap:10px}:host .product .items .item{cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100px;padding:12px}:host .product .items .item .icon{margin:12px 0}:host .product .items .item .icon img{width:100%;max-width:140px}:host .product .items .item .icon .no-image{width:52px;height:52px}:host .product .items .item .name{font-style:normal;font-weight:400;font-size:18px;line-height:24px;color:#72717e;margin-top:8px}:host .product .items .item:hover{box-shadow:0 25px 52px 8px #eaeaeae0}\n"] }]
2765
+ }], ctorParameters: function () { return [{ type: i1$4.MonkeyEcxTokenStorageService }]; }, propDecorators: { onAccess: [{
2766
+ type: Output
2767
+ }] } });
2768
+
2769
+ class MECXProductsModule {
2770
+ }
2771
+ MECXProductsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2772
+ MECXProductsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, declarations: [MECXProductsComponent, MECXProductsFilterComponent], imports: [CommonModule, i1$3.TranslateModule, MonkeyInputModule, MonkeyButtonModule], exports: [MECXProductsComponent] });
2773
+ MECXProductsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, imports: [[CommonModule, TranslateModule.forChild(), MonkeyInputModule, MonkeyButtonModule]] });
2774
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXProductsModule, decorators: [{
2775
+ type: NgModule,
2776
+ args: [{
2777
+ declarations: [MECXProductsComponent, MECXProductsFilterComponent],
2778
+ imports: [CommonModule, TranslateModule.forChild(), MonkeyInputModule, MonkeyButtonModule],
2779
+ exports: [MECXProductsComponent]
2780
+ }]
2781
+ }] });
2782
+
2622
2783
  /*
2623
2784
  * Public API Surface of monkey-front-components
2624
2785
  */
@@ -2627,5 +2788,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
2627
2788
  * Generated bundle index. Do not edit.
2628
2789
  */
2629
2790
 
2630
- export { BaseComponent, BaseDynamic, BaseDynamicArray, BaseScrollComponent, MECXDynamicDirective, MECXDynamicFileUploadComponent, MECXDynamicFormArrayComponent, MECXDynamicFormComponent, MECXDynamicInputComponent, MECXDynamicInputPhoneComponent, MECXDynamicModule, MECXDynamicRadioComponent, MECXDynamicSelectComponent, MECXFilterComponent, MECXFilterModule, MECXPasswordStrengthComponent, MECXPasswordStrengthModule, MECXProgressBarComponent, MECXProgressBarModule, MECXProgressBarService, validators };
2791
+ export { BaseComponent, BaseDynamic, BaseDynamicArray, BaseScrollComponent, MECXDynamicDirective, MECXDynamicFileUploadComponent, MECXDynamicFormArrayComponent, MECXDynamicFormComponent, MECXDynamicInputComponent, MECXDynamicInputPhoneComponent, MECXDynamicModule, MECXDynamicRadioComponent, MECXDynamicSelectComponent, MECXFilterComponent, MECXFilterModule, MECXPasswordStrengthComponent, MECXPasswordStrengthModule, MECXProductsComponent, MECXProductsModule, MECXProgressBarComponent, MECXProgressBarModule, MECXProgressBarService, validators };
2631
2792
  //# sourceMappingURL=monkey-front-components.mjs.map