monkey-front-components 0.0.303 → 0.0.306
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/components/shared/index.mjs +2 -1
- package/esm2020/lib/components/shared/products/filter/filter.component.mjs +36 -0
- package/esm2020/lib/components/shared/products/index.mjs +3 -0
- package/esm2020/lib/components/shared/products/products.component.mjs +89 -0
- package/esm2020/lib/components/shared/products/products.module.mjs +22 -0
- package/esm2020/lib/components/shared/products/providers/index.mjs +2 -0
- package/esm2020/lib/components/shared/products/providers/products.model.mjs +33 -0
- package/fesm2015/monkey-front-components.mjs +162 -1
- package/fesm2015/monkey-front-components.mjs.map +1 -1
- package/fesm2020/monkey-front-components.mjs +160 -1
- package/fesm2020/monkey-front-components.mjs.map +1 -1
- package/lib/components/shared/index.d.ts +1 -0
- package/lib/components/shared/products/filter/filter.component.d.ts +12 -0
- package/lib/components/shared/products/index.d.ts +2 -0
- package/lib/components/shared/products/products.component.d.ts +19 -0
- package/lib/components/shared/products/products.module.d.ts +11 -0
- package/lib/components/shared/products/providers/index.d.ts +1 -0
- package/lib/components/shared/products/providers/products.model.d.ts +13 -0
- package/monkey-front-components-0.0.306.tgz +0 -0
- package/package.json +3 -3
- package/monkey-front-components-0.0.303.tgz +0 -0
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
export * from './filter';
|
|
2
2
|
export * from './password-strength';
|
|
3
3
|
export * from './progress-bar';
|
|
4
|
-
|
|
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
|