monkey-front-components 0.0.439 → 0.0.441
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/filter/filter.component.mjs +1 -4
- package/esm2020/lib/components/shared/filter/menu/menu.component.mjs +19 -36
- package/esm2020/lib/components/shared/filter/options/children/children.component.mjs +7 -14
- package/esm2020/lib/components/shared/filter/options/options.component.mjs +14 -32
- package/esm2020/lib/components/shared/filter/options/status/status.component.mjs +7 -14
- package/esm2020/lib/components/shared/filter/selected/item/currency/currency.component.mjs +5 -12
- package/esm2020/lib/components/shared/filter/selected/item/date-range/date-range.component.mjs +5 -12
- package/esm2020/lib/components/shared/filter/selected/item/date-with-action/date-with-action.component.mjs +5 -12
- package/esm2020/lib/components/shared/filter/selected/item/input/input.component.mjs +5 -11
- package/esm2020/lib/components/shared/filter/selected/item/item.component.mjs +13 -19
- package/esm2020/lib/components/shared/filter/selected/item/status/status.component.mjs +5 -12
- package/esm2020/lib/components/shared/filter/selected/selected.component.mjs +5 -15
- package/fesm2015/monkey-front-components.mjs +76 -180
- package/fesm2015/monkey-front-components.mjs.map +1 -1
- package/fesm2020/monkey-front-components.mjs +79 -181
- package/fesm2020/monkey-front-components.mjs.map +1 -1
- package/monkey-front-components-0.0.441.tgz +0 -0
- package/package.json +3 -3
- package/monkey-front-components-0.0.439.tgz +0 -0
|
@@ -55,9 +55,6 @@ export class MECXFilterComponent {
|
|
|
55
55
|
}
|
|
56
56
|
catch (e) {
|
|
57
57
|
// not to do
|
|
58
|
-
console.log('=====6');
|
|
59
|
-
console.log(e);
|
|
60
|
-
console.log(value);
|
|
61
58
|
}
|
|
62
59
|
return false;
|
|
63
60
|
}
|
|
@@ -142,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
142
139
|
}], onFilter: [{
|
|
143
140
|
type: Output
|
|
144
141
|
}] } });
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/filter.component.ts","../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterOrder, MonkeyEcxFilterOrdersList, MonkeyEcxUtils } from 'monkey-front-core';\n\n@Component({\n  selector: 'mecx-filter',\n  templateUrl: './filter.component.html',\n  styleUrls: ['./filter.component.scss']\n})\nexport class MECXFilterComponent implements OnChanges {\n  @Input() searchPlaceholder = '';\n\n  @Input() orderPlaceholder = '';\n\n  @Input() menus: MonkeyEcxFilterMenu[] = [];\n\n  @Input() orders: MonkeyEcxFilterOrder[] = [];\n\n  @Input() enableSearch = true;\n\n  @Input() enableAddFilter = true;\n\n  @Input() enableOrder = true;\n\n  @Input()\n  set search(value: string) {\n    this._search = value;\n  }\n\n  @Input()\n  set order(value: any) {\n    this._order = value;\n  }\n\n  @Input()\n  set ordersList(value: any[]) {\n    this._ordersList = value;\n  }\n\n  @Input() isLoading = false;\n\n  @Output() onFilter = new EventEmitter<any>();\n\n  _order: MonkeyEcxFilterOrder = null;\n\n  _search = '';\n\n  _ordersList: MonkeyEcxFilterOrdersList | any = null;\n\n  _showMenu = false;\n\n  _showOrder = false;\n\n  _hasFilterByMenu = false;\n\n  _actionElement: HTMLElement = null;\n\n  _actionElementOrder: HTMLElement = null;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  closeOrder = () => {\n    this._showOrder = false;\n  };\n\n  constructor() {\n    // not to do\n  }\n\n  private validateValue({ field, value, getValue }: any) {\n    try {\n      value = value || getValue()?.[field];\n      if (!value) return false;\n      if (typeof value === 'object') {\n        return value && JSON.stringify(value) !== '{}';\n      }\n      return MonkeyEcxUtils.persistNullEmptyUndefined(value);\n    } catch (e) {\n      // not to do\n      console.log('=====6');\n      console.log(e);\n      console.log(value);\n    }\n    return false;\n  }\n\n  private handleFilters() {\n    const { menus } = this;\n    let found = menus.find((_: any) => {\n      return this.validateValue(_);\n    });\n    if (!found) {\n      found = menus.find(({ children }) => {\n        return (children || [])?.find((_: any) => {\n          return this.validateValue(_);\n        });\n      });\n    }\n    this._hasFilterByMenu = !!found;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.menus) {\n      const { currentValue } = changes.menus;\n      if (currentValue && JSON.stringify(currentValue) !== '{}') {\n        this.handleFilters();\n      }\n    }\n  }\n\n  onSearchFilter(event: string) {\n    this.onFilter.next({ search: event });\n  }\n\n  onClearFilter() {\n    this._search = '';\n    this.onFilter.next({ search: null });\n  }\n\n  onHandleSubmit(event: any) {\n    this.onFilter.next(event);\n  }\n\n  onHandleShowMenu() {\n    this._actionElement = document.getElementById('mecx-filters-add-filter');\n    setTimeout(() => {\n      this._showMenu = true;\n    }, 0);\n  }\n\n  onHandleClose() {\n    this._showMenu = false;\n  }\n\n  onHandleShowOrders(el: HTMLElement) {\n    this._actionElementOrder = el;\n    setTimeout(() => {\n      this._showOrder = true;\n    }, 10);\n  }\n\n  onHandleOrder(event: any, field: string = 'sort') {\n    this.onFilter.next({ [field]: event });\n  }\n}\n","<div class=\"d-flex flex-column full-width\">\r\n  <div class=\"d-flex flex-column flex-md-row justify-content-between\">\r\n    <div class=\"d-flex full-width\">\r\n      <ng-container *ngIf=\"enableSearch\">\r\n        <monkey-input-filter [placeholder]=\"searchPlaceholder | translate\"\r\n          (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" iconPosition=\"left\"\r\n          [(value)]=\"_search\">\r\n        </monkey-input-filter>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"!_hasFilterByMenu\">\r\n        <div *ngIf=\"enableAddFilter\" class=\"d-flex actions\" id=\"mecx-filters-add-filter\">\r\n          <monkey-button type=\"filter\" color=\"border\" (click)=\"onHandleShowMenu()\" icon=\"more-16\"\r\n            iconPosition=\"right\">\r\n            {{ 'BUTTONS.ADD-FILTER' | translate }}\r\n          </monkey-button>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <div class=\"order hidden-sm hidden-xs\" *ngIf=\"enableOrder\">\r\n      <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\r\n    </div>\r\n  </div>\r\n  <ng-container *ngIf=\"_hasFilterByMenu\">\r\n    <div class=\"separator\"></div>\r\n    <div class=\"d-flex full-width\">\r\n      <mecx-filter-selected (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\"\r\n        [model]=\"menus\"></mecx-filter-selected>\r\n      <div class=\"more-filters\">\r\n        <monkey-button type=\"filter\" color=\"border\" icon=\"more-16\" id=\"mecx-filters-add-filter\"\r\n          (click)=\"onHandleShowMenu()\">\r\n        </monkey-button>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n  <div class=\"order hidden-md hidden-lg\" *ngIf=\"enableOrder\">\r\n    <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n<mecx-filter-menu\r\n  *monkeyecxPopover=\"_showMenu; target: $any(_actionElement); closed: closeMenu; dir: 'ltr'\"\r\n  (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\" [model]=\"menus\">\r\n</mecx-filter-menu>\r\n\r\n<ng-template #orderBy>\r\n  <ng-container *ngIf=\"!_ordersList?.length > 0; else orderByList\">\r\n    <monkey-select-filter (onChange)=\"onHandleOrder($event)\"\r\n      [placeholder]=\"orderPlaceholder | translate\" type=\"none\" [(value)]=\"_order\">\r\n      <monkey-option *ngFor=\"let ordBy of orders\" [label]=\"ordBy?.label | translate\"\r\n        [value]=\"ordBy?.value\">x\r\n      </monkey-option>\r\n    </monkey-select-filter>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #orderByList>\r\n  <div class=\"d-flex full-width justify-content-end\">\r\n    <div #ordersFilterMenu (click)=\"onHandleShowOrders(ordersFilterMenu)\">\r\n      <monkey-button type=\"filter\" color=\"border\" icon=\"arrow-down-16\" iconPosition=\"right\">\r\n        {{ 'BUTTONS.ORDINATION' | translate }}\r\n      </monkey-button>\r\n    </div>\r\n  </div>\r\n  <div class=\"ml-1\"\r\n    *monkeyecxPopover=\"_showOrder; target: $any(_actionElementOrder); closed: closeOrder; dir: 'rtl'\">\r\n    <div class=\"drop-down-orders-filter pt-4\">\r\n      <ng-container *ngFor=\"let item of _ordersList\">\r\n        <div class=\"px-4\">\r\n          <span>{{ item.label | translate }}</span>\r\n          <monkey-radiobutton [value]=\"item.value\" (onChange)=\"onHandleOrder($event, item.field)\">\r\n            <monkey-option *ngFor=\"let ordBy of item.values\" [label]=\"ordBy?.label | translate\"\r\n              [value]=\"ordBy?.value\">\r\n            </monkey-option>\r\n          </monkey-radiobutton>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.component.js","sourceRoot":"","sources":["../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/filter.component.ts","../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterOrder, MonkeyEcxFilterOrdersList, MonkeyEcxUtils } from 'monkey-front-core';\n\n@Component({\n  selector: 'mecx-filter',\n  templateUrl: './filter.component.html',\n  styleUrls: ['./filter.component.scss']\n})\nexport class MECXFilterComponent implements OnChanges {\n  @Input() searchPlaceholder = '';\n\n  @Input() orderPlaceholder = '';\n\n  @Input() menus: MonkeyEcxFilterMenu[] = [];\n\n  @Input() orders: MonkeyEcxFilterOrder[] = [];\n\n  @Input() enableSearch = true;\n\n  @Input() enableAddFilter = true;\n\n  @Input() enableOrder = true;\n\n  @Input()\n  set search(value: string) {\n    this._search = value;\n  }\n\n  @Input()\n  set order(value: any) {\n    this._order = value;\n  }\n\n  @Input()\n  set ordersList(value: any[]) {\n    this._ordersList = value;\n  }\n\n  @Input() isLoading = false;\n\n  @Output() onFilter = new EventEmitter<any>();\n\n  _order: MonkeyEcxFilterOrder = null;\n\n  _search = '';\n\n  _ordersList: MonkeyEcxFilterOrdersList | any = null;\n\n  _showMenu = false;\n\n  _showOrder = false;\n\n  _hasFilterByMenu = false;\n\n  _actionElement: HTMLElement = null;\n\n  _actionElementOrder: HTMLElement = null;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  closeOrder = () => {\n    this._showOrder = false;\n  };\n\n  constructor() {\n    // not to do\n  }\n\n  private validateValue({ field, value, getValue }: any) {\n    try {\n      value = value || getValue()?.[field];\n      if (!value) return false;\n      if (typeof value === 'object') {\n        return value && JSON.stringify(value) !== '{}';\n      }\n      return MonkeyEcxUtils.persistNullEmptyUndefined(value);\n    } catch (e) {\n      // not to do\n    }\n    return false;\n  }\n\n  private handleFilters() {\n    const { menus } = this;\n    let found = menus.find((_: any) => {\n      return this.validateValue(_);\n    });\n    if (!found) {\n      found = menus.find(({ children }) => {\n        return (children || [])?.find((_: any) => {\n          return this.validateValue(_);\n        });\n      });\n    }\n    this._hasFilterByMenu = !!found;\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.menus) {\n      const { currentValue } = changes.menus;\n      if (currentValue && JSON.stringify(currentValue) !== '{}') {\n        this.handleFilters();\n      }\n    }\n  }\n\n  onSearchFilter(event: string) {\n    this.onFilter.next({ search: event });\n  }\n\n  onClearFilter() {\n    this._search = '';\n    this.onFilter.next({ search: null });\n  }\n\n  onHandleSubmit(event: any) {\n    this.onFilter.next(event);\n  }\n\n  onHandleShowMenu() {\n    this._actionElement = document.getElementById('mecx-filters-add-filter');\n    setTimeout(() => {\n      this._showMenu = true;\n    }, 0);\n  }\n\n  onHandleClose() {\n    this._showMenu = false;\n  }\n\n  onHandleShowOrders(el: HTMLElement) {\n    this._actionElementOrder = el;\n    setTimeout(() => {\n      this._showOrder = true;\n    }, 10);\n  }\n\n  onHandleOrder(event: any, field: string = 'sort') {\n    this.onFilter.next({ [field]: event });\n  }\n}\n","<div class=\"d-flex flex-column full-width\">\r\n  <div class=\"d-flex flex-column flex-md-row justify-content-between\">\r\n    <div class=\"d-flex full-width\">\r\n      <ng-container *ngIf=\"enableSearch\">\r\n        <monkey-input-filter [placeholder]=\"searchPlaceholder | translate\"\r\n          (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" iconPosition=\"left\"\r\n          [(value)]=\"_search\">\r\n        </monkey-input-filter>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"!_hasFilterByMenu\">\r\n        <div *ngIf=\"enableAddFilter\" class=\"d-flex actions\" id=\"mecx-filters-add-filter\">\r\n          <monkey-button type=\"filter\" color=\"border\" (click)=\"onHandleShowMenu()\" icon=\"more-16\"\r\n            iconPosition=\"right\">\r\n            {{ 'BUTTONS.ADD-FILTER' | translate }}\r\n          </monkey-button>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n    <div class=\"order hidden-sm hidden-xs\" *ngIf=\"enableOrder\">\r\n      <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\r\n    </div>\r\n  </div>\r\n  <ng-container *ngIf=\"_hasFilterByMenu\">\r\n    <div class=\"separator\"></div>\r\n    <div class=\"d-flex full-width\">\r\n      <mecx-filter-selected (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\"\r\n        [model]=\"menus\"></mecx-filter-selected>\r\n      <div class=\"more-filters\">\r\n        <monkey-button type=\"filter\" color=\"border\" icon=\"more-16\" id=\"mecx-filters-add-filter\"\r\n          (click)=\"onHandleShowMenu()\">\r\n        </monkey-button>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n  <div class=\"order hidden-md hidden-lg\" *ngIf=\"enableOrder\">\r\n    <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\r\n  </div>\r\n</div>\r\n\r\n<mecx-filter-menu\r\n  *monkeyecxPopover=\"_showMenu; target: $any(_actionElement); closed: closeMenu; dir: 'ltr'\"\r\n  (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\" [model]=\"menus\">\r\n</mecx-filter-menu>\r\n\r\n<ng-template #orderBy>\r\n  <ng-container *ngIf=\"!_ordersList?.length > 0; else orderByList\">\r\n    <monkey-select-filter (onChange)=\"onHandleOrder($event)\"\r\n      [placeholder]=\"orderPlaceholder | translate\" type=\"none\" [(value)]=\"_order\">\r\n      <monkey-option *ngFor=\"let ordBy of orders\" [label]=\"ordBy?.label | translate\"\r\n        [value]=\"ordBy?.value\">x\r\n      </monkey-option>\r\n    </monkey-select-filter>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #orderByList>\r\n  <div class=\"d-flex full-width justify-content-end\">\r\n    <div #ordersFilterMenu (click)=\"onHandleShowOrders(ordersFilterMenu)\">\r\n      <monkey-button type=\"filter\" color=\"border\" icon=\"arrow-down-16\" iconPosition=\"right\">\r\n        {{ 'BUTTONS.ORDINATION' | translate }}\r\n      </monkey-button>\r\n    </div>\r\n  </div>\r\n  <div class=\"ml-1\"\r\n    *monkeyecxPopover=\"_showOrder; target: $any(_actionElementOrder); closed: closeOrder; dir: 'rtl'\">\r\n    <div class=\"drop-down-orders-filter pt-4\">\r\n      <ng-container *ngFor=\"let item of _ordersList\">\r\n        <div class=\"px-4\">\r\n          <span>{{ item.label | translate }}</span>\r\n          <monkey-radiobutton [value]=\"item.value\" (onChange)=\"onHandleOrder($event, item.field)\">\r\n            <monkey-option *ngFor=\"let ordBy of item.values\" [label]=\"ordBy?.label | translate\"\r\n              [value]=\"ordBy?.value\">\r\n            </monkey-option>\r\n          </monkey-radiobutton>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>"]}
|
|
@@ -31,9 +31,6 @@ export class MECXFilterMenuComponent {
|
|
|
31
31
|
}
|
|
32
32
|
catch (e) {
|
|
33
33
|
// not to do
|
|
34
|
-
console.log('=====3');
|
|
35
|
-
console.log(e);
|
|
36
|
-
console.log(value);
|
|
37
34
|
}
|
|
38
35
|
return false;
|
|
39
36
|
}
|
|
@@ -70,44 +67,30 @@ export class MECXFilterMenuComponent {
|
|
|
70
67
|
});
|
|
71
68
|
}
|
|
72
69
|
ngOnChanges(changes) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
this.onHandleMenus(currentValue);
|
|
78
|
-
}
|
|
70
|
+
if (changes.model) {
|
|
71
|
+
const { currentValue } = changes.model;
|
|
72
|
+
if (currentValue && JSON.stringify(currentValue) !== '{}') {
|
|
73
|
+
this.onHandleMenus(currentValue);
|
|
79
74
|
}
|
|
80
75
|
}
|
|
81
|
-
catch (e) {
|
|
82
|
-
console.log('=====4');
|
|
83
|
-
console.log(e);
|
|
84
|
-
console.log(changes?.model?.currentValue);
|
|
85
|
-
}
|
|
86
76
|
}
|
|
87
77
|
onHandleChildrenAction(option, child) {
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
78
|
+
const { field, type, action } = child;
|
|
79
|
+
if (type === 'with-action') {
|
|
80
|
+
this.onHandleSubmitValue({
|
|
81
|
+
[option.field]: JSON.stringify({
|
|
82
|
+
[field]: action()
|
|
83
|
+
})
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
this._showMenu = true;
|
|
88
|
+
this._menuOption = child;
|
|
89
|
+
this.onHandleSubmit = (event) => {
|
|
91
90
|
this.onHandleSubmitValue({
|
|
92
|
-
[option.field]: JSON.stringify(
|
|
93
|
-
[field]: action()
|
|
94
|
-
})
|
|
91
|
+
[option.field]: JSON.stringify(event)
|
|
95
92
|
});
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
this._showMenu = true;
|
|
99
|
-
this._menuOption = child;
|
|
100
|
-
this.onHandleSubmit = (event) => {
|
|
101
|
-
this.onHandleSubmitValue({
|
|
102
|
-
[option.field]: JSON.stringify(event)
|
|
103
|
-
});
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
catch (e) {
|
|
108
|
-
console.log('=====5');
|
|
109
|
-
console.log(e);
|
|
110
|
-
console.log(child);
|
|
93
|
+
};
|
|
111
94
|
}
|
|
112
95
|
}
|
|
113
96
|
onHandleShowMenu(option) {
|
|
@@ -134,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
134
117
|
}], onSubmit: [{
|
|
135
118
|
type: Output
|
|
136
119
|
}] } });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/menu/menu.component.ts","../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterMenuChildren, MonkeyEcxUtils } from 'monkey-front-core';\n\n@Component({\n  selector: 'mecx-filter-menu',\n  templateUrl: './menu.component.html',\n  styleUrls: ['./menu.component.scss']\n})\nexport class MECXFilterMenuComponent implements OnChanges {\n  @Input() model: MonkeyEcxFilterMenu[] = [];\n\n  @Output() onClose = new EventEmitter<any>();\n\n  @Output() onSubmit = new EventEmitter<any>();\n\n  _onHandleSubmit: Function = null;\n\n  _model: MonkeyEcxFilterMenu[] = [];\n\n  _showMenu = false;\n\n  _menuOption: MonkeyEcxFilterMenu | MonkeyEcxFilterMenuChildren = null;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  constructor() {\n    // not to do\n  }\n\n  private validateValue({ field, value, getValue }: any) {\n    try {\n      value = value || getValue()?.[field];\n      if (!value) return false;\n      if (typeof value === 'object') {\n        return value && JSON.stringify(value) !== '{}';\n      }\n      return MonkeyEcxUtils.persistNullEmptyUndefined(value);\n    } catch (e) {\n      // not to do\n      console.log('=====3');\n      console.log(e);\n      console.log(value);\n    }\n    return false;\n  }\n\n  private onHandleSubmitValue(value: any) {\n    this.onSubmit.next(value);\n    this.onHandleClose();\n  }\n\n  private onHandleMenus(value: any[]) {\n    this._model = value?.map((_: any) => {\n      const { children } = _;\n      let obj = null;\n      if (children) {\n        obj = {\n          ..._,\n          children: children?.filter((_: any) => {\n            return !this.validateValue(_);\n          })\n        };\n      } else if (!this.validateValue(_)) {\n        obj = {\n          ..._,\n          ...obj || {}\n        };\n      }\n\n      return obj;\n    })?.filter((_) => {\n      return _;\n    });\n\n    this._model = this._model?.sort((a, b) => {\n      const groupA = `${a?.group}`.toLowerCase();\n      const groupB = `${b?.group}`.toLowerCase();\n      return groupA !== groupB ? 1 : -1;\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    try {\n      if (changes.model) {\n        const { currentValue } = changes.model;\n        if (currentValue && JSON.stringify(currentValue) !== '{}') {\n          this.onHandleMenus(currentValue);\n        }\n      }\n    } catch (e) {\n      console.log('=====4');\n      console.log(e);\n      console.log(changes?.model?.currentValue);\n    }\n  }\n\n  onHandleChildrenAction(option: MonkeyEcxFilterMenu, child: MonkeyEcxFilterMenuChildren) {\n    try {\n      const { field, type, action } = child;\n      if (type === 'with-action') {\n        this.onHandleSubmitValue({\n          [option.field]: JSON.stringify({\n            [field]: action()\n          })\n        });\n      } else {\n        this._showMenu = true;\n        this._menuOption = child;\n        this.onHandleSubmit = (event: any) => {\n          this.onHandleSubmitValue({\n            [option.field]: JSON.stringify(event)\n          });\n        };\n      }\n    } catch (e) {\n      console.log('=====5');\n      console.log(e);\n      console.log(child);\n    }\n  }\n\n  onHandleShowMenu(option: MonkeyEcxFilterMenu) {\n    this._showMenu = true;\n    this._menuOption = option;\n  }\n\n  onHandleClose() {\n    this._showMenu = false;\n    this.onClose.next();\n  }\n\n  onHandleSubmit(event: any) {\n    this.onHandleSubmitValue(event);\n  }\n}\n","<div class=\"d-flex flex-column\" #actionElement>\r\n  <ng-container *ngFor=\"let menu of _model; let index = index\">\r\n    <ng-container *ngIf=\"menu?.children; else withoutChildren\">\r\n      <div class=\"item no-action\">\r\n        {{ menu.label | translate }}\r\n      </div>\r\n      <div class=\"separator\"></div>\r\n      <ng-container *ngFor=\"let child of menu?.children\">\r\n        <div class=\"item children\" (click)=\"onHandleChildrenAction(menu, child)\">\r\n          {{ child.label | translate }}\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n    <ng-template #withoutChildren>\r\n      <div class=\"item\" (click)=\"onHandleShowMenu(menu)\">\r\n        {{ menu.label | translate }}\r\n      </div>\r\n    </ng-template>\r\n    <ng-container *ngIf=\"_model[index+1]?.group as next; _model[index]?.group as current\">\r\n      <div class=\"separator\" *ngIf=\"next !== current\"></div>\r\n    </ng-container>\r\n  </ng-container>\r\n</div>\r\n<ng-container\r\n  *monkeyecxPopover=\"_showMenu; target: $any(actionElement); closed: closeMenu; dir: 'rt'\">\r\n  <mecx-filter-options [option]=\"_menuOption\" (onClose)=\"onHandleClose()\"\r\n    (onSubmit)=\"onHandleSubmit($event)\" [closeDirectly]=\"true\"></mecx-filter-options>\r\n</ng-container>"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/menu/menu.component.ts","../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterMenuChildren, MonkeyEcxUtils } from 'monkey-front-core';\n\n@Component({\n  selector: 'mecx-filter-menu',\n  templateUrl: './menu.component.html',\n  styleUrls: ['./menu.component.scss']\n})\nexport class MECXFilterMenuComponent implements OnChanges {\n  @Input() model: MonkeyEcxFilterMenu[] = [];\n\n  @Output() onClose = new EventEmitter<any>();\n\n  @Output() onSubmit = new EventEmitter<any>();\n\n  _onHandleSubmit: Function = null;\n\n  _model: MonkeyEcxFilterMenu[] = [];\n\n  _showMenu = false;\n\n  _menuOption: MonkeyEcxFilterMenu | MonkeyEcxFilterMenuChildren = null;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  constructor() {\n    // not to do\n  }\n\n  private validateValue({ field, value, getValue }: any) {\n    try {\n      value = value || getValue()?.[field];\n      if (!value) return false;\n      if (typeof value === 'object') {\n        return value && JSON.stringify(value) !== '{}';\n      }\n      return MonkeyEcxUtils.persistNullEmptyUndefined(value);\n    } catch (e) {\n      // not to do\n    }\n    return false;\n  }\n\n  private onHandleSubmitValue(value: any) {\n    this.onSubmit.next(value);\n    this.onHandleClose();\n  }\n\n  private onHandleMenus(value: any[]) {\n    this._model = value?.map((_: any) => {\n      const { children } = _;\n      let obj = null;\n      if (children) {\n        obj = {\n          ..._,\n          children: children?.filter((_: any) => {\n            return !this.validateValue(_);\n          })\n        };\n      } else if (!this.validateValue(_)) {\n        obj = {\n          ..._,\n          ...obj || {}\n        };\n      }\n\n      return obj;\n    })?.filter((_) => {\n      return _;\n    });\n\n    this._model = this._model?.sort((a, b) => {\n      const groupA = `${a?.group}`.toLowerCase();\n      const groupB = `${b?.group}`.toLowerCase();\n      return groupA !== groupB ? 1 : -1;\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.model) {\n      const { currentValue } = changes.model;\n      if (currentValue && JSON.stringify(currentValue) !== '{}') {\n        this.onHandleMenus(currentValue);\n      }\n    }\n  }\n\n  onHandleChildrenAction(option: MonkeyEcxFilterMenu, child: MonkeyEcxFilterMenuChildren) {\n    const { field, type, action } = child;\n    if (type === 'with-action') {\n      this.onHandleSubmitValue({\n        [option.field]: JSON.stringify({\n          [field]: action()\n        })\n      });\n    } else {\n      this._showMenu = true;\n      this._menuOption = child;\n      this.onHandleSubmit = (event: any) => {\n        this.onHandleSubmitValue({\n          [option.field]: JSON.stringify(event)\n        });\n      };\n    }\n  }\n\n  onHandleShowMenu(option: MonkeyEcxFilterMenu) {\n    this._showMenu = true;\n    this._menuOption = option;\n  }\n\n  onHandleClose() {\n    this._showMenu = false;\n    this.onClose.next();\n  }\n\n  onHandleSubmit(event: any) {\n    this.onHandleSubmitValue(event);\n  }\n}\n","<div class=\"d-flex flex-column\" #actionElement>\r\n  <ng-container *ngFor=\"let menu of _model; let index = index\">\r\n    <ng-container *ngIf=\"menu?.children; else withoutChildren\">\r\n      <div class=\"item no-action\">\r\n        {{ menu.label | translate }}\r\n      </div>\r\n      <div class=\"separator\"></div>\r\n      <ng-container *ngFor=\"let child of menu?.children\">\r\n        <div class=\"item children\" (click)=\"onHandleChildrenAction(menu, child)\">\r\n          {{ child.label | translate }}\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n    <ng-template #withoutChildren>\r\n      <div class=\"item\" (click)=\"onHandleShowMenu(menu)\">\r\n        {{ menu.label | translate }}\r\n      </div>\r\n    </ng-template>\r\n    <ng-container *ngIf=\"_model[index+1]?.group as next; _model[index]?.group as current\">\r\n      <div class=\"separator\" *ngIf=\"next !== current\"></div>\r\n    </ng-container>\r\n  </ng-container>\r\n</div>\r\n<ng-container\r\n  *monkeyecxPopover=\"_showMenu; target: $any(actionElement); closed: closeMenu; dir: 'rt'\">\r\n  <mecx-filter-options [option]=\"_menuOption\" (onClose)=\"onHandleClose()\"\r\n    (onSubmit)=\"onHandleSubmit($event)\" [closeDirectly]=\"true\"></mecx-filter-options>\r\n</ng-container>"]}
|
|
@@ -22,20 +22,13 @@ export class MECXFilterOptionsChildrenComponent {
|
|
|
22
22
|
}
|
|
23
23
|
onHandleChildrenAction(child) {
|
|
24
24
|
const { field, type, action } = child;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
}));
|
|
30
|
-
}
|
|
31
|
-
else {
|
|
32
|
-
this.onShow.next(child);
|
|
33
|
-
}
|
|
25
|
+
if (type === 'with-action') {
|
|
26
|
+
this.eventHandle.next(JSON.stringify({
|
|
27
|
+
[field]: action()
|
|
28
|
+
}));
|
|
34
29
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
console.log(e);
|
|
38
|
-
console.log(action);
|
|
30
|
+
else {
|
|
31
|
+
this.onShow.next(child);
|
|
39
32
|
}
|
|
40
33
|
}
|
|
41
34
|
onHandleValidateSelected({ field, getValue }) {
|
|
@@ -54,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
54
47
|
}], onShow: [{
|
|
55
48
|
type: Output
|
|
56
49
|
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpbGRyZW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC9maWx0ZXIvb3B0aW9ucy9jaGlsZHJlbi9jaGlsZHJlbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9vcHRpb25zL2NoaWxkcmVuL2NoaWxkcmVuLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzFGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7OztBQU85QyxNQUFNLE9BQU8sa0NBQWtDO0lBVzdDO1FBVlMsV0FBTSxHQUF3QixJQUFJLENBQUM7UUFFbEMsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbkMsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFFbkMsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBSzVDLFlBQVk7SUFDZCxDQUFDO0lBRUQsUUFBUTtRQUNOLE1BQU0sRUFDSixXQUFXLEVBQ1gsUUFBUSxFQUNSLE1BQU0sRUFBRSxFQUFFLEtBQUssRUFBRSxFQUNsQixHQUFHLElBQUksQ0FBQztRQUVULElBQUksQ0FBQyxpQkFBaUIsR0FBRyxXQUFXLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQVUsRUFBRSxFQUFFO1lBQ3BGLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QyxDQUFDO0lBRUQsc0JBQXNCLENBQUMsS0FBVTtRQUMvQixNQUFNLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsR0FBRyxLQUFLLENBQUM7UUFFdEMsSUFBSSxJQUFJLEtBQUssYUFBYSxFQUFFO1lBQzFCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUNuQixJQUFJLENBQUMsU0FBUyxDQUFDO2dCQUNiLENBQUMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFO2FBQ2xCLENBQUMsQ0FDSCxDQUFDO1NBQ0g7YUFBTTtZQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQztJQUVELHdCQUF3QixDQUFDLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBTztRQUMvQyxPQUFPLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7OytIQS9DVSxrQ0FBa0M7bUhBQWxDLGtDQUFrQyx1SkNWL0MsNlBBS2U7MkZES0Ysa0NBQWtDO2tCQUw5QyxTQUFTOytCQUNFLDhCQUE4QjswRUFLL0IsTUFBTTtzQkFBZCxLQUFLO2dCQUVJLFFBQVE7c0JBQWpCLE1BQU07Z0JBRUcsTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb25rZXlFY3hGaWx0ZXJNZW51IH0gZnJvbSAnbW9ua2V5LWZyb250LWNvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkZWJvdW5jZVRpbWUgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21lY3gtZmlsdGVyLW9wdGlvbnMtY2hpbGRyZW4nLFxuICB0ZW1wbGF0ZVVybDogJy4vY2hpbGRyZW4uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaGlsZHJlbi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1FQ1hGaWx0ZXJPcHRpb25zQ2hpbGRyZW5Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIG9wdGlvbjogTW9ua2V5RWN4RmlsdGVyTWVudSA9IG51bGw7XG5cbiAgQE91dHB1dCgpIG9uU3VibWl0ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgQE91dHB1dCgpIG9uU2hvdyA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIHByaXZhdGUgZXZlbnRIYW5kbGUgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBwcml2YXRlIGV2ZW50U3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gbm90IHRvIGRvXG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICBjb25zdCB7XG4gICAgICBldmVudEhhbmRsZSxcbiAgICAgIG9uU3VibWl0LFxuICAgICAgb3B0aW9uOiB7IGZpZWxkIH1cbiAgICB9ID0gdGhpcztcblxuICAgIHRoaXMuZXZlbnRTdWJzY3JpcHRpb24gPSBldmVudEhhbmRsZS5waXBlKGRlYm91bmNlVGltZSgxMDApKS5zdWJzY3JpYmUoKHZhbHVlOiBhbnkpID0+IHtcbiAgICAgIG9uU3VibWl0Lm5leHQoeyBbZmllbGRdOiB2YWx1ZSB9KTtcbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuZXZlbnRTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgfVxuXG4gIG9uSGFuZGxlQ2hpbGRyZW5BY3Rpb24oY2hpbGQ6IGFueSkge1xuICAgIGNvbnN0IHsgZmllbGQsIHR5cGUsIGFjdGlvbiB9ID0gY2hpbGQ7XG5cbiAgICBpZiAodHlwZSA9PT0gJ3dpdGgtYWN0aW9uJykge1xuICAgICAgdGhpcy5ldmVudEhhbmRsZS5uZXh0KFxuICAgICAgICBKU09OLnN0cmluZ2lmeSh7XG4gICAgICAgICAgW2ZpZWxkXTogYWN0aW9uKClcbiAgICAgICAgfSlcbiAgICAgICk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMub25TaG93Lm5leHQoY2hpbGQpO1xuICAgIH1cbiAgfVxuXG4gIG9uSGFuZGxlVmFsaWRhdGVTZWxlY3RlZCh7IGZpZWxkLCBnZXRWYWx1ZSB9OiBhbnkpIHtcbiAgICByZXR1cm4gISFnZXRWYWx1ZSgpPy5bZmllbGRdO1xuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjaGlsZCBvZiBvcHRpb24/LmNoaWxkcmVuXCI+XHJcbiAgPGRpdiBjbGFzcz1cIml0ZW1cIiAoY2xpY2spPVwib25IYW5kbGVDaGlsZHJlbkFjdGlvbihjaGlsZClcIlxyXG4gICAgW2NsYXNzLnNlbGVjdGVkXT1cIm9uSGFuZGxlVmFsaWRhdGVTZWxlY3RlZChjaGlsZClcIj5cclxuICAgIHt7IGNoaWxkLmxhYmVsIHwgdHJhbnNsYXRlIH19XHJcbiAgPC9kaXY+XHJcbjwvbmctY29udGFpbmVyPiJdfQ==
|
|
@@ -26,47 +26,29 @@ export class MECXFilterOptionsComponent extends BaseComponent {
|
|
|
26
26
|
this.closeMenu = () => {
|
|
27
27
|
this._showMenu = false;
|
|
28
28
|
};
|
|
29
|
-
console.log('veio no options do filtro do batman');
|
|
30
29
|
}
|
|
31
30
|
onHandleLoading(loading = false) {
|
|
32
31
|
this._isLoading = loading;
|
|
33
32
|
}
|
|
34
33
|
onHandleLoadValues(first = false) {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
if (!values?.length && first) {
|
|
38
|
-
this.option?.loadValues?.();
|
|
39
|
-
}
|
|
40
|
-
else if (!first) {
|
|
41
|
-
this.option?.loadMoreValues?.();
|
|
42
|
-
}
|
|
34
|
+
if (first) {
|
|
35
|
+
this.option?.loadValues?.();
|
|
43
36
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
console.log(e);
|
|
37
|
+
else {
|
|
38
|
+
this.option?.loadMoreValues?.();
|
|
47
39
|
}
|
|
48
40
|
}
|
|
49
41
|
ngOnInit() {
|
|
50
42
|
const { option } = this;
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
this._hasMoreValues = !!(data?.next);
|
|
61
|
-
});
|
|
62
|
-
option?.control$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
|
|
63
|
-
this.onHandleLoading(data?.isLoading);
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
catch (e) {
|
|
67
|
-
console.log('=====1');
|
|
68
|
-
console.log(e);
|
|
69
|
-
}
|
|
43
|
+
option?.values$()?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
|
|
44
|
+
this.option.values = data;
|
|
45
|
+
});
|
|
46
|
+
option?.pagination$()?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
|
|
47
|
+
this._hasMoreValues = !!(data?.next);
|
|
48
|
+
});
|
|
49
|
+
option?.control$()?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
|
|
50
|
+
this.onHandleLoading(data?.isLoading);
|
|
51
|
+
});
|
|
70
52
|
}
|
|
71
53
|
ngAfterViewInit() {
|
|
72
54
|
this.onHandleLoadValues(true);
|
|
@@ -116,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
116
98
|
}], onShowFromChildren: [{
|
|
117
99
|
type: Output
|
|
118
100
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.component.js","sourceRoot":"","sources":["../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/options/options.component.ts","../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/options/options.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit, AfterViewInit } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterMenuChildren } from 'monkey-front-core';\nimport { takeUntil } from 'rxjs/operators';\nimport { BaseComponent } from '../../../base';\n\n@Component({\n  selector: 'mecx-filter-options',\n  templateUrl: './options.component.html',\n  styleUrls: ['./options.component.scss']\n})\nexport class MECXFilterOptionsComponent extends BaseComponent implements OnInit, AfterViewInit {\n  @Input() option: MonkeyEcxFilterMenu = null;\n\n  @Input() closeDirectly = false;\n\n  @Output() onClose = new EventEmitter<any>();\n\n  @Output() onRemove = new EventEmitter<any>();\n\n  @Output() onSubmit = new EventEmitter<any>();\n\n  @Output() onShowFromChildren = new EventEmitter<any>();\n\n  _showMenu = false;\n\n  _isLoading = false;\n\n  _hasMoreValues = false;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  constructor() {\n    super();\n    console.log('veio no options do filtro do batman');\n  }\n\n  private onHandleLoading(loading = false) {\n    this._isLoading = loading;\n  }\n\n  private onHandleLoadValues(first = false) {\n    const { values } = this.option;\n    try {\n      if (!values?.length && first) {\n        this.option?.loadValues?.();\n      } else if (!first) {\n        this.option?.loadMoreValues?.();\n      }\n    } catch (e) {\n      console.log('====asdaosdioaisdoa');\n      console.log(e);\n    }\n  }\n\n  ngOnInit() {\n    const { option } = this;\n\n    try {\n      console.log('option?.values$');\n      console.log(option?.values$);\n      (option?.values$ as any)()?.pipe(\n        takeUntil(this.__unsubscribeAll)\n      ).subscribe((data: any) => {\n        console.log('!@@@@@@@@@@@@@@@@@@@@');\n        console.log(data);\n        this.option.values = data;\n      });\n\n      option?.pagination$?.pipe(\n        takeUntil(this.__unsubscribeAll)\n      ).subscribe((data: any) => {\n        this._hasMoreValues = !!(data?.next);\n      });\n\n      option?.control$?.pipe(\n        takeUntil(this.__unsubscribeAll)\n      ).subscribe((data: any) => {\n        this.onHandleLoading(data?.isLoading);\n      });\n    } catch (e) {\n      console.log('=====1');\n      console.log(e);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.onHandleLoadValues(true);\n  }\n\n  onHandleChildrenAction(child: MonkeyEcxFilterMenuChildren) {\n    const { option } = this;\n    const { field, action } = child;\n    this.onSubmit.next({\n      [option.field]: {\n        [field]: action()\n      }\n    });\n  }\n\n  onHandleSubmitChildren(event: any) {\n    this.onSubmit.next(event);\n  }\n\n  onHandleSubmit(event: any) {\n    this.onSubmit.next(event);\n  }\n\n  onHandleShowMenu() {\n    const { closeDirectly } = this;\n    if (closeDirectly) {\n      this.onClose.next();\n      return;\n    }\n    this._showMenu = true;\n  }\n\n  onHandleLoadMoreValues() {\n    this.onHandleLoadValues();\n  }\n}\n","<div class=\"d-flex justify-content-between header\">\r\n  <span class=\"title\">\r\n    {{ option?.label | translate }}\r\n  </span>\r\n  <div class=\"close\" #actionElement (click)=\"onHandleShowMenu()\">\r\n    <monkey-icon icon=\"close-12\" color=\"#474747\"></monkey-icon>\r\n  </div>\r\n</div>\r\n<ng-container *ngIf=\"option?.type as type\">\r\n  <ng-container *ngIf=\"option?.children; else withoutChildren\">\r\n    <mecx-filter-options-children [option]=\"option\" (onSubmit)=\"onHandleSubmitChildren($event)\"\r\n      (onShow)=\"onShowFromChildren.next($event)\">\r\n    </mecx-filter-options-children>\r\n  </ng-container>\r\n  <ng-template #withoutChildren>\r\n    <ng-container [ngSwitch]=\"type\">\r\n      <mecx-filter-options-status *ngSwitchCase=\"'status'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-status>\r\n      <mecx-filter-options-date-range *ngSwitchCase=\"'date-range'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-date-range>\r\n      <mecx-filter-options-currency *ngSwitchCase=\"'currency'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-currency>\r\n      <mecx-filter-options-input *ngSwitchCase=\"'input'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-input>\r\n    </ng-container>\r\n  </ng-template>\r\n</ng-container>\r\n\r\n<div class=\"box-loading\" *ngIf=\"_isLoading\">\r\n  <div class=\"loading\"></div>\r\n  <div class=\"loading\"></div>\r\n  <div class=\"loading\"></div>\r\n</div>\r\n\r\n<div class=\"footer\" *ngIf=\"_hasMoreValues && !_isLoading\">\r\n  <monkey-button type=\"tertiary\" color=\"theme\" [label]=\"'BUTTONS.LOAD-MORE' | translate\"\r\n    (click)=\"onHandleLoadMoreValues()\">\r\n  </monkey-button>\r\n</div>\r\n\r\n<ng-container\r\n  *monkeyecxPopover=\"_showMenu; target: $any(actionElement); closed: closeMenu; dir: 'ltr'\">\r\n  <div class=\"close-menu\">\r\n    <monkey-button type=\"tertiary\" color=\"error\" (click)=\"onRemove.next()\" size=\"sm\">\r\n      {{ 'BUTTONS.REMOVE' | translate }}\r\n    </monkey-button>\r\n    <monkey-button type=\"tertiary\" color=\"theme\" (click)=\"onClose.next()\" size=\"sm\">\r\n      {{ 'BUTTONS.CLOSE' | translate }}\r\n    </monkey-button>\r\n  </div>\r\n</ng-container>"]}
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"options.component.js","sourceRoot":"","sources":["../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/options/options.component.ts","../../../../../../../../projects/monkey-front-components/src/lib/components/shared/filter/options/options.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAyB,MAAM,eAAe,CAAC;AAE9F,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AAO9C,MAAM,OAAO,0BAA2B,SAAQ,aAAa;IAuB3D;QACE,KAAK,EAAE,CAAC;QAvBD,WAAM,GAAwB,IAAI,CAAC;QAEnC,kBAAa,GAAG,KAAK,CAAC;QAErB,YAAO,GAAG,IAAI,YAAY,EAAO,CAAC;QAElC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,uBAAkB,GAAG,IAAI,YAAY,EAAO,CAAC;QAEvD,cAAS,GAAG,KAAK,CAAC;QAElB,eAAU,GAAG,KAAK,CAAC;QAEnB,mBAAc,GAAG,KAAK,CAAC;QAEvB,cAAS,GAAG,GAAG,EAAE;YACf,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC;IAIF,CAAC;IAEO,eAAe,CAAC,OAAO,GAAG,KAAK;QACrC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;IAC5B,CAAC;IAEO,kBAAkB,CAAC,KAAK,GAAG,KAAK;QACtC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,MAAM,EAAE,cAAc,EAAE,EAAE,CAAC;SACjC;IACH,CAAC;IAED,QAAQ;QACN,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QAExB,MAAM,EAAE,OAAO,EAAE,EAAE,IAAI,CACrB,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CACjC,CAAC,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACxB,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,WAAW,EAAE,EAAE,IAAI,CACzB,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CACjC,CAAC,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACxB,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,MAAM,EAAE,QAAQ,EAAE,EAAE,IAAI,CACtB,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CACjC,CAAC,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE;YACxB,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,sBAAsB,CAAC,KAAkC;QACvD,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;QACxB,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;YACjB,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;gBACd,CAAC,KAAK,CAAC,EAAE,MAAM,EAAE;aAClB;SACF,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,KAAU;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,gBAAgB;QACd,MAAM,EAAE,aAAa,EAAE,GAAG,IAAI,CAAC;QAC/B,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACpB,OAAO;SACR;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;IAED,sBAAsB;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;;uHA9FU,0BAA0B;2GAA1B,0BAA0B,uQCVvC,02EAsDe;2FD5CF,0BAA0B;kBALtC,SAAS;+BACE,qBAAqB;0EAKtB,MAAM;sBAAd,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEI,OAAO;sBAAhB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAEG,kBAAkB;sBAA3B,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit, AfterViewInit } from '@angular/core';\nimport { MonkeyEcxFilterMenu, MonkeyEcxFilterMenuChildren } from 'monkey-front-core';\nimport { takeUntil } from 'rxjs/operators';\nimport { BaseComponent } from '../../../base';\n\n@Component({\n  selector: 'mecx-filter-options',\n  templateUrl: './options.component.html',\n  styleUrls: ['./options.component.scss']\n})\nexport class MECXFilterOptionsComponent extends BaseComponent implements OnInit, AfterViewInit {\n  @Input() option: MonkeyEcxFilterMenu = null;\n\n  @Input() closeDirectly = false;\n\n  @Output() onClose = new EventEmitter<any>();\n\n  @Output() onRemove = new EventEmitter<any>();\n\n  @Output() onSubmit = new EventEmitter<any>();\n\n  @Output() onShowFromChildren = new EventEmitter<any>();\n\n  _showMenu = false;\n\n  _isLoading = false;\n\n  _hasMoreValues = false;\n\n  closeMenu = () => {\n    this._showMenu = false;\n  };\n\n  constructor() {\n    super();\n  }\n\n  private onHandleLoading(loading = false) {\n    this._isLoading = loading;\n  }\n\n  private onHandleLoadValues(first = false) {\n    if (first) {\n      this.option?.loadValues?.();\n    } else {\n      this.option?.loadMoreValues?.();\n    }\n  }\n\n  ngOnInit() {\n    const { option } = this;\n\n    option?.values$()?.pipe(\n      takeUntil(this.__unsubscribeAll)\n    ).subscribe((data: any) => {\n      this.option.values = data;\n    });\n\n    option?.pagination$()?.pipe(\n      takeUntil(this.__unsubscribeAll)\n    ).subscribe((data: any) => {\n      this._hasMoreValues = !!(data?.next);\n    });\n\n    option?.control$()?.pipe(\n      takeUntil(this.__unsubscribeAll)\n    ).subscribe((data: any) => {\n      this.onHandleLoading(data?.isLoading);\n    });\n  }\n\n  ngAfterViewInit() {\n    this.onHandleLoadValues(true);\n  }\n\n  onHandleChildrenAction(child: MonkeyEcxFilterMenuChildren) {\n    const { option } = this;\n    const { field, action } = child;\n    this.onSubmit.next({\n      [option.field]: {\n        [field]: action()\n      }\n    });\n  }\n\n  onHandleSubmitChildren(event: any) {\n    this.onSubmit.next(event);\n  }\n\n  onHandleSubmit(event: any) {\n    this.onSubmit.next(event);\n  }\n\n  onHandleShowMenu() {\n    const { closeDirectly } = this;\n    if (closeDirectly) {\n      this.onClose.next();\n      return;\n    }\n    this._showMenu = true;\n  }\n\n  onHandleLoadMoreValues() {\n    this.onHandleLoadValues();\n  }\n}\n","<div class=\"d-flex justify-content-between header\">\r\n  <span class=\"title\">\r\n    {{ option?.label | translate }}\r\n  </span>\r\n  <div class=\"close\" #actionElement (click)=\"onHandleShowMenu()\">\r\n    <monkey-icon icon=\"close-12\" color=\"#474747\"></monkey-icon>\r\n  </div>\r\n</div>\r\n<ng-container *ngIf=\"option?.type as type\">\r\n  <ng-container *ngIf=\"option?.children; else withoutChildren\">\r\n    <mecx-filter-options-children [option]=\"option\" (onSubmit)=\"onHandleSubmitChildren($event)\"\r\n      (onShow)=\"onShowFromChildren.next($event)\">\r\n    </mecx-filter-options-children>\r\n  </ng-container>\r\n  <ng-template #withoutChildren>\r\n    <ng-container [ngSwitch]=\"type\">\r\n      <mecx-filter-options-status *ngSwitchCase=\"'status'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-status>\r\n      <mecx-filter-options-date-range *ngSwitchCase=\"'date-range'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-date-range>\r\n      <mecx-filter-options-currency *ngSwitchCase=\"'currency'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-currency>\r\n      <mecx-filter-options-input *ngSwitchCase=\"'input'\" [option]=\"option\"\r\n        (onSubmit)=\"onHandleSubmit($event)\">\r\n      </mecx-filter-options-input>\r\n    </ng-container>\r\n  </ng-template>\r\n</ng-container>\r\n\r\n<div class=\"box-loading\" *ngIf=\"_isLoading\">\r\n  <div class=\"loading\"></div>\r\n  <div class=\"loading\"></div>\r\n  <div class=\"loading\"></div>\r\n</div>\r\n\r\n<div class=\"footer\" *ngIf=\"_hasMoreValues && !_isLoading\">\r\n  <monkey-button type=\"tertiary\" color=\"theme\" [label]=\"'BUTTONS.LOAD-MORE' | translate\"\r\n    (click)=\"onHandleLoadMoreValues()\">\r\n  </monkey-button>\r\n</div>\r\n\r\n<ng-container\r\n  *monkeyecxPopover=\"_showMenu; target: $any(actionElement); closed: closeMenu; dir: 'ltr'\">\r\n  <div class=\"close-menu\">\r\n    <monkey-button type=\"tertiary\" color=\"error\" (click)=\"onRemove.next()\" size=\"sm\">\r\n      {{ 'BUTTONS.REMOVE' | translate }}\r\n    </monkey-button>\r\n    <monkey-button type=\"tertiary\" color=\"theme\" (click)=\"onClose.next()\" size=\"sm\">\r\n      {{ 'BUTTONS.CLOSE' | translate }}\r\n    </monkey-button>\r\n  </div>\r\n</ng-container>"]}
|
|
@@ -27,19 +27,12 @@ export class MECXFilterOptionsStatusComponent {
|
|
|
27
27
|
this.eventSubscription.unsubscribe();
|
|
28
28
|
}
|
|
29
29
|
ngOnChanges(changes) {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
this._value = currentValue?.value;
|
|
35
|
-
}
|
|
30
|
+
if (changes.option) {
|
|
31
|
+
const { currentValue } = changes.option;
|
|
32
|
+
if (currentValue && JSON.stringify(currentValue) !== '{}') {
|
|
33
|
+
this._value = currentValue?.value;
|
|
36
34
|
}
|
|
37
35
|
}
|
|
38
|
-
catch (e) {
|
|
39
|
-
console.log('=====2');
|
|
40
|
-
console.log(e);
|
|
41
|
-
console.log(changes?.option?.currentValue);
|
|
42
|
-
}
|
|
43
36
|
}
|
|
44
37
|
onHandleChecked(cmp) {
|
|
45
38
|
const { _value } = this;
|
|
@@ -61,13 +54,13 @@ export class MECXFilterOptionsStatusComponent {
|
|
|
61
54
|
}
|
|
62
55
|
}
|
|
63
56
|
MECXFilterOptionsStatusComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXFilterOptionsStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
64
|
-
MECXFilterOptionsStatusComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXFilterOptionsStatusComponent, selector: "mecx-filter-options-status", inputs: { option: "option" }, outputs: { onSubmit: "onSubmit" }, usesOnChanges: true, ngImport: i0, template: "<
|
|
57
|
+
MECXFilterOptionsStatusComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: MECXFilterOptionsStatusComponent, selector: "mecx-filter-options-status", inputs: { option: "option" }, outputs: { onSubmit: "onSubmit" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngFor=\"let op of option?.values\">\r\n <div class=\"content-status d-flex flex-column\">\r\n <div class=\"d-flex justify-content-center align-items-center\">\r\n <monkey-checkbox type=\"multiple\"\r\n [description]=\"op?.description | translate\" [value]=\"onHandleChecked(op?.value)\"\r\n (click)=\"onChangeFilter($event, op?.value)\">\r\n </monkey-checkbox>\r\n <span class=\"helper\">{{ op?.helper }}</span>\r\n </div>\r\n </div>\r\n</ng-container>", styles: [":host{display:flex;flex-direction:column;max-width:232px;min-width:180px;max-height:500px;padding:12px 12px 8px;color:#72717e;overflow:auto}:host .content-status{margin:6px 0}:host .content-status .helper{margin-bottom:4px;font-size:16px;margin-left:12}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox{padding:0!important}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox .mecx-check-container{height:unset!important}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox .mecx-check-container .mecx-check-mark{top:50%;transform:translateY(-50%)}:host ::ng-deep monkey-checkbox{margin:6px 0!important}\n"], components: [{ type: i1.MonkeyCheckboxComponent, selector: "monkey-checkbox", inputs: ["label", "type", "helperMessage", "infoMessage", "errorMessage", "description", "value"], outputs: ["onChange"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": i3.TranslatePipe } });
|
|
65
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXFilterOptionsStatusComponent, decorators: [{
|
|
66
59
|
type: Component,
|
|
67
|
-
args: [{ selector: 'mecx-filter-options-status', template: "<
|
|
60
|
+
args: [{ selector: 'mecx-filter-options-status', template: "<ng-container *ngFor=\"let op of option?.values\">\r\n <div class=\"content-status d-flex flex-column\">\r\n <div class=\"d-flex justify-content-center align-items-center\">\r\n <monkey-checkbox type=\"multiple\"\r\n [description]=\"op?.description | translate\" [value]=\"onHandleChecked(op?.value)\"\r\n (click)=\"onChangeFilter($event, op?.value)\">\r\n </monkey-checkbox>\r\n <span class=\"helper\">{{ op?.helper }}</span>\r\n </div>\r\n </div>\r\n</ng-container>", styles: [":host{display:flex;flex-direction:column;max-width:232px;min-width:180px;max-height:500px;padding:12px 12px 8px;color:#72717e;overflow:auto}:host .content-status{margin:6px 0}:host .content-status .helper{margin-bottom:4px;font-size:16px;margin-left:12}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox{padding:0!important}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox .mecx-check-container{height:unset!important}:host ::ng-deep mecx-form-field mecx-form-field-body.checkbox .mecx-check-container .mecx-check-mark{top:50%;transform:translateY(-50%)}:host ::ng-deep monkey-checkbox{margin:6px 0!important}\n"] }]
|
|
68
61
|
}], ctorParameters: function () { return []; }, propDecorators: { option: [{
|
|
69
62
|
type: Input
|
|
70
63
|
}], onSubmit: [{
|
|
71
64
|
type: Output
|
|
72
65
|
}] } });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1mcm9udC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaGFyZWQvZmlsdGVyL29wdGlvbnMvc3RhdHVzL3N0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9vcHRpb25zL3N0YXR1cy9zdGF0dXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFnQyxNQUFNLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBR3BILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7QUFPOUMsTUFBTSxPQUFPLGdDQUFnQztJQVczQztRQVZTLFdBQU0sR0FBd0IsSUFBSSxDQUFDO1FBRWxDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBRTdDLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFFSixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFLNUMsWUFBWTtJQUNkLENBQUM7SUFFTyxjQUFjLENBQUMsS0FBYTtRQUNsQyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxRQUFRO1FBQ04sTUFBTSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFFMUQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLFdBQVc7YUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN2QixTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtZQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUU7WUFDbEIsTUFBTSxFQUFFLFlBQVksRUFBRSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDeEMsSUFBSSxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3pELElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxFQUFFLEtBQUssQ0FBQzthQUNuQztTQUNGO0lBQ0gsQ0FBQztJQUVELGVBQWUsQ0FBQyxHQUFXO1FBQ3pCLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDeEIsT0FBTyxHQUFHLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxjQUFjLENBQUMsS0FBVSxFQUFFLEtBQWE7UUFDdEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixNQUFNLFFBQVEsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0MsTUFBTSxPQUFPLEdBQWEsSUFBSSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3hELElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixPQUFPLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDM0M7YUFBTTtZQUNMLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDckI7UUFFRCxJQUFJLENBQUMsTUFBTSxHQUFHLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUN6RCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDckMsQ0FBQzs7NkhBN0RVLGdDQUFnQztpSEFBaEMsZ0NBQWdDLHdKQ1Y3QywwZkFVZTsyRkRBRixnQ0FBZ0M7a0JBTDVDLFNBQVM7K0JBQ0UsNEJBQTRCOzBFQUs3QixNQUFNO3NCQUFkLEtBQUs7Z0JBRUksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3ksIE9uSW5pdCwgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb25rZXlFY3hGaWx0ZXJNZW51IH0gZnJvbSAnbW9ua2V5LWZyb250LWNvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkZWJvdW5jZVRpbWUgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21lY3gtZmlsdGVyLW9wdGlvbnMtc3RhdHVzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N0YXR1cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3N0YXR1cy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1FQ1hGaWx0ZXJPcHRpb25zU3RhdHVzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIG9wdGlvbjogTW9ua2V5RWN4RmlsdGVyTWVudSA9IG51bGw7XG5cbiAgQE91dHB1dCgpIG9uU3VibWl0ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgX3ZhbHVlID0gJyc7XG5cbiAgcHJpdmF0ZSBldmVudEhhbmRsZSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIHByaXZhdGUgZXZlbnRTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICAvLyBub3QgdG8gZG9cbiAgfVxuXG4gIHByaXZhdGUgdmVyaWZ5U2VsZWN0ZWQodmFsdWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl92YWx1ZT8uaW5jbHVkZXModmFsdWUpO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgeyBldmVudEhhbmRsZSwgb25TdWJtaXQsIG9wdGlvbjogeyBmaWVsZCB9IH0gPSB0aGlzO1xuXG4gICAgdGhpcy5ldmVudFN1YnNjcmlwdGlvbiA9IGV2ZW50SGFuZGxlXG4gICAgICAucGlwZShkZWJvdW5jZVRpbWUoODAwKSlcbiAgICAgIC5zdWJzY3JpYmUoKHZhbHVlOiBzdHJpbmcpID0+IHtcbiAgICAgICAgb25TdWJtaXQubmV4dCh7IFtmaWVsZF06IHZhbHVlIH0pO1xuICAgICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmV2ZW50U3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKGNoYW5nZXMub3B0aW9uKSB7XG4gICAgICBjb25zdCB7IGN1cnJlbnRWYWx1ZSB9ID0gY2hhbmdlcy5vcHRpb247XG4gICAgICBpZiAoY3VycmVudFZhbHVlICYmIEpTT04uc3RyaW5naWZ5KGN1cnJlbnRWYWx1ZSkgIT09ICd7fScpIHtcbiAgICAgICAgdGhpcy5fdmFsdWUgPSBjdXJyZW50VmFsdWU/LnZhbHVlO1xuICAgICAgfVxuICAgIH1cbiAgfVxuXG4gIG9uSGFuZGxlQ2hlY2tlZChjbXA6IHN0cmluZykge1xuICAgIGNvbnN0IHsgX3ZhbHVlIH0gPSB0aGlzO1xuICAgIHJldHVybiBgJHtfdmFsdWV9YC5zcGxpdCgnLCcpPy5pbmRleE9mKGNtcCkgPj0gMDtcbiAgfVxuXG4gIG9uQ2hhbmdlRmlsdGVyKGV2ZW50OiBhbnksIHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgY29uc3Qgc2VsZWN0ZWQgPSAhdGhpcy52ZXJpZnlTZWxlY3RlZCh2YWx1ZSk7XG4gICAgY29uc3QgZmlsdGVyczogc3RyaW5nW10gPSB0aGlzLl92YWx1ZT8uc3BsaXQoJywnKSB8fCBbXTtcbiAgICBpZiAoIXNlbGVjdGVkKSB7XG4gICAgICBmaWx0ZXJzLnNwbGljZShmaWx0ZXJzLmluZGV4T2YodmFsdWUpLCAxKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZmlsdGVycy5wdXNoKHZhbHVlKTtcbiAgICB9XG5cbiAgICB0aGlzLl92YWx1ZSA9IGZpbHRlcnM/Lmxlbmd0aCA/IGZpbHRlcnMuam9pbignLCcpIDogbnVsbDtcbiAgICB0aGlzLmV2ZW50SGFuZGxlLm5leHQodGhpcy5fdmFsdWUpO1xuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBvcCBvZiBvcHRpb24/LnZhbHVlc1wiPlxyXG4gIDxkaXYgY2xhc3M9XCJjb250ZW50LXN0YXR1cyBkLWZsZXggZmxleC1jb2x1bW5cIj5cclxuICAgIDxkaXYgY2xhc3M9XCJkLWZsZXgganVzdGlmeS1jb250ZW50LWNlbnRlciBhbGlnbi1pdGVtcy1jZW50ZXJcIj5cclxuICAgICAgPG1vbmtleS1jaGVja2JveCB0eXBlPVwibXVsdGlwbGVcIlxyXG4gICAgICAgIFtkZXNjcmlwdGlvbl09XCJvcD8uZGVzY3JpcHRpb24gfCB0cmFuc2xhdGVcIiBbdmFsdWVdPVwib25IYW5kbGVDaGVja2VkKG9wPy52YWx1ZSlcIlxyXG4gICAgICAgIChjbGljayk9XCJvbkNoYW5nZUZpbHRlcigkZXZlbnQsIG9wPy52YWx1ZSlcIj5cclxuICAgICAgPC9tb25rZXktY2hlY2tib3g+XHJcbiAgICAgIDxzcGFuIGNsYXNzPVwiaGVscGVyXCI+e3sgb3A/LmhlbHBlciB9fTwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L25nLWNvbnRhaW5lcj4iXX0=
|
|
@@ -10,19 +10,12 @@ export class MECXFilterSelectedItemCurrencyComponent {
|
|
|
10
10
|
this._value = value;
|
|
11
11
|
}
|
|
12
12
|
ngOnChanges(changes) {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
this.onHandleSelectedValue(currentValue);
|
|
18
|
-
}
|
|
13
|
+
if (changes.option) {
|
|
14
|
+
const { currentValue } = changes.option;
|
|
15
|
+
if (currentValue && JSON.stringify(currentValue) !== '{}') {
|
|
16
|
+
this.onHandleSelectedValue(currentValue);
|
|
19
17
|
}
|
|
20
18
|
}
|
|
21
|
-
catch (e) {
|
|
22
|
-
console.log('=======13');
|
|
23
|
-
console.log(e);
|
|
24
|
-
console.log(changes);
|
|
25
|
-
}
|
|
26
19
|
}
|
|
27
20
|
}
|
|
28
21
|
MECXFilterSelectedItemCurrencyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXFilterSelectedItemCurrencyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -33,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
33
26
|
}], propDecorators: { option: [{
|
|
34
27
|
type: Input
|
|
35
28
|
}] } });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3kuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbW9ua2V5LWZyb250LWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC9maWx0ZXIvc2VsZWN0ZWQvaXRlbS9jdXJyZW5jeS9jdXJyZW5jeS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9zZWxlY3RlZC9pdGVtL2N1cnJlbmN5L2N1cnJlbmN5LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUE0QixNQUFNLGVBQWUsQ0FBQzs7O0FBUTNFLE1BQU0sT0FBTyx1Q0FBdUM7SUFMcEQ7UUFNVyxXQUFNLEdBQXdCLElBQUksQ0FBQztRQUU1QyxXQUFNLEdBQVEsSUFBSSxDQUFDO0tBY3BCO0lBWlMscUJBQXFCLENBQUMsRUFBRSxLQUFLLEVBQU87UUFDMUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUU7WUFDbEIsTUFBTSxFQUFFLFlBQVksRUFBRSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDeEMsSUFBSSxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3pELElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUMxQztTQUNGO0lBQ0gsQ0FBQzs7b0lBaEJVLHVDQUF1Qzt3SEFBdkMsdUNBQXVDLDZIQ1JwRCx3Q0FBc0M7MkZEUXpCLHVDQUF1QztrQkFMbkQsU0FBUzsrQkFDRSxvQ0FBb0M7OEJBS3JDLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTW9ua2V5RWN4RmlsdGVyTWVudSB9IGZyb20gJ21vbmtleS1mcm9udC1jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbWVjeC1maWx0ZXItc2VsZWN0ZWQtaXRlbS1jdXJyZW5jeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jdXJyZW5jeS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2N1cnJlbmN5LmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgTUVDWEZpbHRlclNlbGVjdGVkSXRlbUN1cnJlbmN5Q29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgb3B0aW9uOiBNb25rZXlFY3hGaWx0ZXJNZW51ID0gbnVsbDtcblxuICBfdmFsdWU6IGFueSA9IG51bGw7XG5cbiAgcHJpdmF0ZSBvbkhhbmRsZVNlbGVjdGVkVmFsdWUoeyB2YWx1ZSB9OiBhbnkpIHtcbiAgICB0aGlzLl92YWx1ZSA9IHZhbHVlO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzLm9wdGlvbikge1xuICAgICAgY29uc3QgeyBjdXJyZW50VmFsdWUgfSA9IGNoYW5nZXMub3B0aW9uO1xuICAgICAgaWYgKGN1cnJlbnRWYWx1ZSAmJiBKU09OLnN0cmluZ2lmeShjdXJyZW50VmFsdWUpICE9PSAne30nKSB7XG4gICAgICAgIHRoaXMub25IYW5kbGVTZWxlY3RlZFZhbHVlKGN1cnJlbnRWYWx1ZSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCJ7eyBfdmFsdWUgfCBtb25rZXllY3hGb3JtYXRDdXJyZW5jeSB9fSJdfQ==
|
package/esm2020/lib/components/shared/filter/selected/item/date-range/date-range.component.mjs
CHANGED
|
@@ -23,19 +23,12 @@ export class MECXFilterSelectedItemDateRangeComponent {
|
|
|
23
23
|
}
|
|
24
24
|
}
|
|
25
25
|
ngOnChanges(changes) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
this.onHandleSelectedValue(currentValue);
|
|
31
|
-
}
|
|
26
|
+
if (changes.option) {
|
|
27
|
+
const { currentValue } = changes.option;
|
|
28
|
+
if (currentValue && JSON.stringify(currentValue) !== '{}') {
|
|
29
|
+
this.onHandleSelectedValue(currentValue);
|
|
32
30
|
}
|
|
33
31
|
}
|
|
34
|
-
catch (e) {
|
|
35
|
-
console.log('=======12');
|
|
36
|
-
console.log(e);
|
|
37
|
-
console.log(changes);
|
|
38
|
-
}
|
|
39
32
|
}
|
|
40
33
|
}
|
|
41
34
|
MECXFilterSelectedItemDateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXFilterSelectedItemDateRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -46,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
46
39
|
}], propDecorators: { option: [{
|
|
47
40
|
type: Input
|
|
48
41
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9zZWxlY3RlZC9pdGVtL2RhdGUtcmFuZ2UvZGF0ZS1yYW5nZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9zZWxlY3RlZC9pdGVtL2RhdGUtcmFuZ2UvZGF0ZS1yYW5nZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7OztBQVEzRSxNQUFNLE9BQU8sd0NBQXdDO0lBTHJEO1FBTVcsV0FBTSxHQUFzRCxJQUFJLENBQUM7UUFFMUUsZUFBVSxHQUFHLEVBQUUsQ0FBQztRQUVoQixhQUFRLEdBQUcsRUFBRSxDQUFDO0tBeUJmO0lBdkJTLHFCQUFxQixDQUFDLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQU87UUFDM0QsSUFBSTtZQUNGLEtBQUssR0FBRyxLQUFLLElBQUksUUFBUSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNyQyxJQUFJLEtBQUssSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLElBQUksRUFBRTtnQkFDM0MsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDbkMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLEVBQUUsU0FBUyxDQUFDO2dCQUN0QyxJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsRUFBRSxPQUFPLENBQUM7YUFDbkM7U0FDRjtRQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ1YsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDMUMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLEVBQUUsU0FBUyxDQUFDO1lBQ3RDLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxFQUFFLE9BQU8sQ0FBQztTQUNuQztJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFO1lBQ2xCLE1BQU0sRUFBRSxZQUFZLEVBQUUsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDO1lBQ3hDLElBQUksWUFBWSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLEtBQUssSUFBSSxFQUFFO2dCQUN6RCxJQUFJLENBQUMscUJBQXFCLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDMUM7U0FDRjtJQUNILENBQUM7O3FJQTdCVSx3Q0FBd0M7eUhBQXhDLHdDQUF3QywrSENSckQsa0hBQ29EOzJGRE92Qyx3Q0FBd0M7a0JBTHBELFNBQVM7K0JBQ0Usc0NBQXNDOzhCQUt2QyxNQUFNO3NCQUFkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1vbmtleUVjeEZpbHRlck1lbnUsIE1vbmtleUVjeEZpbHRlck1lbnVDaGlsZHJlbiB9IGZyb20gJ21vbmtleS1mcm9udC1jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbWVjeC1maWx0ZXItc2VsZWN0ZWQtaXRlbS1kYXRlLXJhbmdlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtcmFuZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kYXRlLXJhbmdlLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgTUVDWEZpbHRlclNlbGVjdGVkSXRlbURhdGVSYW5nZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIG9wdGlvbjogTW9ua2V5RWN4RmlsdGVyTWVudSB8IE1vbmtleUVjeEZpbHRlck1lbnVDaGlsZHJlbiA9IG51bGw7XG5cbiAgX3N0YXJ0RGF0ZSA9ICcnO1xuXG4gIF9lbmREYXRlID0gJyc7XG5cbiAgcHJpdmF0ZSBvbkhhbmRsZVNlbGVjdGVkVmFsdWUoeyBmaWVsZCwgdmFsdWUsIGdldFZhbHVlIH06IGFueSkge1xuICAgIHRyeSB7XG4gICAgICB2YWx1ZSA9IHZhbHVlIHx8IGdldFZhbHVlKCk/LltmaWVsZF07XG4gICAgICBpZiAodmFsdWUgJiYgSlNPTi5zdHJpbmdpZnkodmFsdWUpICE9PSAne30nKSB7XG4gICAgICAgIGNvbnN0IG9iakRhdGVzID0gSlNPTi5wYXJzZSh2YWx1ZSk7XG4gICAgICAgIHRoaXMuX3N0YXJ0RGF0ZSA9IG9iakRhdGVzPy5zdGFydERhdGU7XG4gICAgICAgIHRoaXMuX2VuZERhdGUgPSBvYmpEYXRlcz8uZW5kRGF0ZTtcbiAgICAgIH1cbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBjb25zdCBvYmpEYXRlcyA9IEpTT04ucGFyc2UodmFsdWU/LmRhdGVzKTtcbiAgICAgIHRoaXMuX3N0YXJ0RGF0ZSA9IG9iakRhdGVzPy5zdGFydERhdGU7XG4gICAgICB0aGlzLl9lbmREYXRlID0gb2JqRGF0ZXM/LmVuZERhdGU7XG4gICAgfVxuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzLm9wdGlvbikge1xuICAgICAgY29uc3QgeyBjdXJyZW50VmFsdWUgfSA9IGNoYW5nZXMub3B0aW9uO1xuICAgICAgaWYgKGN1cnJlbnRWYWx1ZSAmJiBKU09OLnN0cmluZ2lmeShjdXJyZW50VmFsdWUpICE9PSAne30nKSB7XG4gICAgICAgIHRoaXMub25IYW5kbGVTZWxlY3RlZFZhbHVlKGN1cnJlbnRWYWx1ZSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCJ7eyBfc3RhcnREYXRlIHwgbW9ua2V5ZWN4Rm9ybWF0RGF0ZVRpbWVsYXBzZTogZmFsc2UgfX0gLVxyXG57eyBfZW5kRGF0ZSB8IG1vbmtleWVjeEZvcm1hdERhdGVUaW1lbGFwc2U6IGZhbHNlIH19Il19
|
|
@@ -14,19 +14,12 @@ export class MECXFilterSelectedItemDateWithActionComponent {
|
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
16
|
ngOnChanges(changes) {
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
this.onHandleSelectedValue(currentValue);
|
|
22
|
-
}
|
|
17
|
+
if (changes.option) {
|
|
18
|
+
const { currentValue } = changes.option;
|
|
19
|
+
if (currentValue && JSON.stringify(currentValue) !== '{}') {
|
|
20
|
+
this.onHandleSelectedValue(currentValue);
|
|
23
21
|
}
|
|
24
22
|
}
|
|
25
|
-
catch (e) {
|
|
26
|
-
console.log('=======12');
|
|
27
|
-
console.log(e);
|
|
28
|
-
console.log(changes);
|
|
29
|
-
}
|
|
30
23
|
}
|
|
31
24
|
}
|
|
32
25
|
MECXFilterSelectedItemDateWithActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: MECXFilterSelectedItemDateWithActionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -37,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
37
30
|
}], propDecorators: { option: [{
|
|
38
31
|
type: Input
|
|
39
32
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS13aXRoLWFjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9zZWxlY3RlZC9pdGVtL2RhdGUtd2l0aC1hY3Rpb24vZGF0ZS13aXRoLWFjdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9zZWxlY3RlZC9pdGVtL2RhdGUtd2l0aC1hY3Rpb24vZGF0ZS13aXRoLWFjdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUErQixjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7O0FBT2hGLE1BQU0sT0FBTyw2Q0FBNkM7SUFMMUQ7UUFNVyxXQUFNLEdBQWdDLElBQUksQ0FBQztRQUVwRCxVQUFLLEdBQUcsRUFBRSxDQUFDO0tBaUJaO0lBZlMscUJBQXFCLENBQUMsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFPO1FBQ3BELE1BQU0sS0FBSyxHQUFHLFFBQVEsRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsSUFBSSxjQUFjLENBQUMseUJBQXlCLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDbkQsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7U0FDcEI7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLE1BQU0sRUFBRTtZQUNsQixNQUFNLEVBQUUsWUFBWSxFQUFFLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztZQUN4QyxJQUFJLFlBQVksSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxLQUFLLElBQUksRUFBRTtnQkFDekQsSUFBSSxDQUFDLHFCQUFxQixDQUFDLFlBQVksQ0FBQyxDQUFDO2FBQzFDO1NBQ0Y7SUFDSCxDQUFDOzswSUFuQlUsNkNBQTZDOzhIQUE3Qyw2Q0FBNkMscUlDUjFELG1EQUFpRDsyRkRRcEMsNkNBQTZDO2tCQUx6RCxTQUFTOytCQUNFLDRDQUE0Qzs4QkFLN0MsTUFBTTtzQkFBZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb25rZXlFY3hGaWx0ZXJNZW51Q2hpbGRyZW4sIE1vbmtleUVjeFV0aWxzIH0gZnJvbSAnbW9ua2V5LWZyb250LWNvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtZWN4LWZpbHRlci1zZWxlY3RlZC1pdGVtLWRhdGUtd2l0aC1hY3Rpb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS13aXRoLWFjdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2RhdGUtd2l0aC1hY3Rpb24uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNRUNYRmlsdGVyU2VsZWN0ZWRJdGVtRGF0ZVdpdGhBY3Rpb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBvcHRpb246IE1vbmtleUVjeEZpbHRlck1lbnVDaGlsZHJlbiA9IG51bGw7XG5cbiAgX2RhdGUgPSAnJztcblxuICBwcml2YXRlIG9uSGFuZGxlU2VsZWN0ZWRWYWx1ZSh7IGZpZWxkLCBnZXRWYWx1ZSB9OiBhbnkpIHtcbiAgICBjb25zdCB2YWx1ZSA9IGdldFZhbHVlKCk/LltmaWVsZF07XG4gICAgaWYgKE1vbmtleUVjeFV0aWxzLnBlcnNpc3ROdWxsRW1wdHlVbmRlZmluZWQodmFsdWUpKSB7XG4gICAgICB0aGlzLl9kYXRlID0gdmFsdWU7XG4gICAgfVxuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzLm9wdGlvbikge1xuICAgICAgY29uc3QgeyBjdXJyZW50VmFsdWUgfSA9IGNoYW5nZXMub3B0aW9uO1xuICAgICAgaWYgKGN1cnJlbnRWYWx1ZSAmJiBKU09OLnN0cmluZ2lmeShjdXJyZW50VmFsdWUpICE9PSAne30nKSB7XG4gICAgICAgIHRoaXMub25IYW5kbGVTZWxlY3RlZFZhbHVlKGN1cnJlbnRWYWx1ZSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCJ7eyBfZGF0ZSB8IG1vbmtleWVjeEZvcm1hdERhdGVUaW1lbGFwc2U6IGZhbHNlIH19Il19
|