monkey-front-components 0.0.431 → 0.0.433

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -31,6 +31,9 @@ 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);
34
37
  }
35
38
  return false;
36
39
  }
@@ -67,30 +70,44 @@ export class MECXFilterMenuComponent {
67
70
  });
68
71
  }
69
72
  ngOnChanges(changes) {
70
- if (changes.model) {
71
- const { currentValue } = changes.model;
72
- if (currentValue && JSON.stringify(currentValue) !== '{}') {
73
- this.onHandleMenus(currentValue);
73
+ try {
74
+ if (changes.model) {
75
+ const { currentValue } = changes.model;
76
+ if (currentValue && JSON.stringify(currentValue) !== '{}') {
77
+ this.onHandleMenus(currentValue);
78
+ }
74
79
  }
75
80
  }
81
+ catch (e) {
82
+ console.log('=====4');
83
+ console.log(e);
84
+ console.log(changes?.model?.currentValue);
85
+ }
76
86
  }
77
87
  onHandleChildrenAction(option, child) {
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) => {
88
+ try {
89
+ const { field, type, action } = child;
90
+ if (type === 'with-action') {
90
91
  this.onHandleSubmitValue({
91
- [option.field]: JSON.stringify(event)
92
+ [option.field]: JSON.stringify({
93
+ [field]: action()
94
+ })
92
95
  });
93
- };
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);
94
111
  }
95
112
  }
96
113
  onHandleShowMenu(option) {
@@ -117,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
117
134
  }], onSubmit: [{
118
135
  type: Output
119
136
  }] } });
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>"]}
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>"]}
@@ -41,17 +41,23 @@ export class MECXFilterOptionsComponent extends BaseComponent {
41
41
  }
42
42
  ngOnInit() {
43
43
  const { option } = this;
44
- option?.values$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
45
- console.log('!@@@@@@@@@@@@@@@@@@@@');
46
- console.log(data);
47
- this.option.values = data;
48
- });
49
- option?.pagination$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
50
- this._hasMoreValues = !!(data?.next);
51
- });
52
- option?.control$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
53
- this.onHandleLoading(data?.isLoading);
54
- });
44
+ try {
45
+ option?.values$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
46
+ console.log('!@@@@@@@@@@@@@@@@@@@@');
47
+ console.log(data);
48
+ this.option.values = data;
49
+ });
50
+ option?.pagination$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
51
+ this._hasMoreValues = !!(data?.next);
52
+ });
53
+ option?.control$?.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
54
+ this.onHandleLoading(data?.isLoading);
55
+ });
56
+ }
57
+ catch (e) {
58
+ console.log('=====1');
59
+ console.log(e);
60
+ }
55
61
  }
56
62
  ngAfterViewInit() {
57
63
  this.onHandleLoadValues(true);
@@ -101,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
101
107
  }], onShowFromChildren: [{
102
108
  type: Output
103
109
  }] } });
104
- //# 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  }\n\n  private onHandleLoading(loading = false) {\n    this._isLoading = loading;\n  }\n\n  private onHandleLoadValues(first = false) {\n    const { values } = this.option;\n\n    if (!values?.length && first) {\n      this.option?.loadValues?.();\n    } else if (!first) {\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      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  }\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>"]}
110
+ //# 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  }\n\n  private onHandleLoading(loading = false) {\n    this._isLoading = loading;\n  }\n\n  private onHandleLoadValues(first = false) {\n    const { values } = this.option;\n\n    if (!values?.length && first) {\n      this.option?.loadValues?.();\n    } else if (!first) {\n      this.option?.loadMoreValues?.();\n    }\n  }\n\n  ngOnInit() {\n    const { option } = this;\n\n    try {\n      option?.values$?.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>"]}
@@ -27,12 +27,19 @@ export class MECXFilterOptionsStatusComponent {
27
27
  this.eventSubscription.unsubscribe();
28
28
  }
29
29
  ngOnChanges(changes) {
30
- if (changes.option) {
31
- const { currentValue } = changes.option;
32
- if (currentValue && JSON.stringify(currentValue) !== '{}') {
33
- this._value = currentValue?.value;
30
+ try {
31
+ if (changes.option) {
32
+ const { currentValue } = changes.option;
33
+ if (currentValue && JSON.stringify(currentValue) !== '{}') {
34
+ this._value = currentValue?.value;
35
+ }
34
36
  }
35
37
  }
38
+ catch (e) {
39
+ console.log('=====2');
40
+ console.log(e);
41
+ console.log(changes?.option?.currentValue);
42
+ }
36
43
  }
37
44
  onHandleChecked(cmp) {
38
45
  const { _value } = this;
@@ -63,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
63
70
  }], onSubmit: [{
64
71
  type: Output
65
72
  }] } });
66
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1mcm9udC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaGFyZWQvZmlsdGVyL29wdGlvbnMvc3RhdHVzL3N0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9vcHRpb25zL3N0YXR1cy9zdGF0dXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFnQyxNQUFNLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBR3BILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7QUFPOUMsTUFBTSxPQUFPLGdDQUFnQztJQVczQztRQVZTLFdBQU0sR0FBd0IsSUFBSSxDQUFDO1FBRWxDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBRTdDLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFFSixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFLNUMsWUFBWTtJQUNkLENBQUM7SUFFTyxjQUFjLENBQUMsS0FBYTtRQUNsQyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxRQUFRO1FBQ04sTUFBTSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFFMUQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLFdBQVc7YUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN2QixTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtZQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEVBQUU7WUFDbEIsTUFBTSxFQUFFLFlBQVksRUFBRSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDeEMsSUFBSSxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsS0FBSyxJQUFJLEVBQUU7Z0JBQ3pELElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxFQUFFLEtBQUssQ0FBQzthQUNuQztTQUNGO0lBQ0gsQ0FBQztJQUVELGVBQWUsQ0FBQyxHQUFXO1FBQ3pCLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDeEIsT0FBTyxHQUFHLE1BQU0sRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxjQUFjLENBQUMsS0FBVSxFQUFFLEtBQWE7UUFDdEMsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUV4QixNQUFNLFFBQVEsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0MsTUFBTSxPQUFPLEdBQWEsSUFBSSxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3hELElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDYixPQUFPLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7U0FDM0M7YUFBTTtZQUNMLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDckI7UUFFRCxJQUFJLENBQUMsTUFBTSxHQUFHLE9BQU8sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztRQUN6RCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDckMsQ0FBQzs7NkhBN0RVLGdDQUFnQztpSEFBaEMsZ0NBQWdDLHdKQ1Y3Qyw0T0FHa0I7MkZET0wsZ0NBQWdDO2tCQUw1QyxTQUFTOytCQUNFLDRCQUE0QjswRUFLN0IsTUFBTTtzQkFBZCxLQUFLO2dCQUVJLFFBQVE7c0JBQWpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uQ2hhbmdlcywgT25EZXN0cm95LCBPbkluaXQsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTW9ua2V5RWN4RmlsdGVyTWVudSB9IGZyb20gJ21vbmtleS1mcm9udC1jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZGVib3VuY2VUaW1lIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdtZWN4LWZpbHRlci1vcHRpb25zLXN0YXR1cycsXG4gIHRlbXBsYXRlVXJsOiAnLi9zdGF0dXMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zdGF0dXMuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBNRUNYRmlsdGVyT3B0aW9uc1N0YXR1c0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICBASW5wdXQoKSBvcHRpb246IE1vbmtleUVjeEZpbHRlck1lbnUgPSBudWxsO1xuXG4gIEBPdXRwdXQoKSBvblN1Ym1pdCA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIF92YWx1ZSA9ICcnO1xuXG4gIHByaXZhdGUgZXZlbnRIYW5kbGUgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBwcml2YXRlIGV2ZW50U3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgLy8gbm90IHRvIGRvXG4gIH1cblxuICBwcml2YXRlIHZlcmlmeVNlbGVjdGVkKHZhbHVlOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU/LmluY2x1ZGVzKHZhbHVlKTtcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIGNvbnN0IHsgZXZlbnRIYW5kbGUsIG9uU3VibWl0LCBvcHRpb246IHsgZmllbGQgfSB9ID0gdGhpcztcblxuICAgIHRoaXMuZXZlbnRTdWJzY3JpcHRpb24gPSBldmVudEhhbmRsZVxuICAgICAgLnBpcGUoZGVib3VuY2VUaW1lKDgwMCkpXG4gICAgICAuc3Vic2NyaWJlKCh2YWx1ZTogc3RyaW5nKSA9PiB7XG4gICAgICAgIG9uU3VibWl0Lm5leHQoeyBbZmllbGRdOiB2YWx1ZSB9KTtcbiAgICAgIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5ldmVudFN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzLm9wdGlvbikge1xuICAgICAgY29uc3QgeyBjdXJyZW50VmFsdWUgfSA9IGNoYW5nZXMub3B0aW9uO1xuICAgICAgaWYgKGN1cnJlbnRWYWx1ZSAmJiBKU09OLnN0cmluZ2lmeShjdXJyZW50VmFsdWUpICE9PSAne30nKSB7XG4gICAgICAgIHRoaXMuX3ZhbHVlID0gY3VycmVudFZhbHVlPy52YWx1ZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvbkhhbmRsZUNoZWNrZWQoY21wOiBzdHJpbmcpIHtcbiAgICBjb25zdCB7IF92YWx1ZSB9ID0gdGhpcztcbiAgICByZXR1cm4gYCR7X3ZhbHVlfWAuc3BsaXQoJywnKT8uaW5kZXhPZihjbXApID49IDA7XG4gIH1cblxuICBvbkNoYW5nZUZpbHRlcihldmVudDogYW55LCB2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcblxuICAgIGNvbnN0IHNlbGVjdGVkID0gIXRoaXMudmVyaWZ5U2VsZWN0ZWQodmFsdWUpO1xuICAgIGNvbnN0IGZpbHRlcnM6IHN0cmluZ1tdID0gdGhpcy5fdmFsdWU/LnNwbGl0KCcsJykgfHwgW107XG4gICAgaWYgKCFzZWxlY3RlZCkge1xuICAgICAgZmlsdGVycy5zcGxpY2UoZmlsdGVycy5pbmRleE9mKHZhbHVlKSwgMSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGZpbHRlcnMucHVzaCh2YWx1ZSk7XG4gICAgfVxuXG4gICAgdGhpcy5fdmFsdWUgPSBmaWx0ZXJzPy5sZW5ndGggPyBmaWx0ZXJzLmpvaW4oJywnKSA6IG51bGw7XG4gICAgdGhpcy5ldmVudEhhbmRsZS5uZXh0KHRoaXMuX3ZhbHVlKTtcbiAgfVxufVxuIiwiPG1vbmtleS1jaGVja2JveCB0eXBlPVwibXVsdGlwbGVcIiAqbmdGb3I9XCJsZXQgb3Agb2Ygb3B0aW9uPy52YWx1ZXNcIlxyXG4gIFtkZXNjcmlwdGlvbl09XCJvcD8uZGVzY3JpcHRpb24gfCB0cmFuc2xhdGVcIiBbdmFsdWVdPVwib25IYW5kbGVDaGVja2VkKG9wPy52YWx1ZSlcIlxyXG4gIChjbGljayk9XCJvbkNoYW5nZUZpbHRlcigkZXZlbnQsIG9wPy52YWx1ZSlcIj5cclxuPC9tb25rZXktY2hlY2tib3g+Il19
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21vbmtleS1mcm9udC1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaGFyZWQvZmlsdGVyL29wdGlvbnMvc3RhdHVzL3N0YXR1cy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tb25rZXktZnJvbnQtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2hhcmVkL2ZpbHRlci9vcHRpb25zL3N0YXR1cy9zdGF0dXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFnQyxNQUFNLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBR3BILE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7QUFPOUMsTUFBTSxPQUFPLGdDQUFnQztJQVczQztRQVZTLFdBQU0sR0FBd0IsSUFBSSxDQUFDO1FBRWxDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBRTdDLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFFSixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFLNUMsWUFBWTtJQUNkLENBQUM7SUFFTyxjQUFjLENBQUMsS0FBYTtRQUNsQyxPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxRQUFRO1FBQ04sTUFBTSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLEVBQUUsS0FBSyxFQUFFLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFFMUQsSUFBSSxDQUFDLGlCQUFpQixHQUFHLFdBQVc7YUFDakMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN2QixTQUFTLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRTtZQUMzQixRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQ3BDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsaUJBQWlCLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDdkMsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJO1lBQ0YsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFO2dCQUNsQixNQUFNLEVBQUUsWUFBWSxFQUFFLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQztnQkFDeEMsSUFBSSxZQUFZLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsS0FBSyxJQUFJLEVBQUU7b0JBQ3pELElBQUksQ0FBQyxNQUFNLEdBQUcsWUFBWSxFQUFFLEtBQUssQ0FBQztpQkFDbkM7YUFDRjtTQUNGO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixPQUFPLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3RCLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDZixPQUFPLENBQUMsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUM7U0FDNUM7SUFDSCxDQUFDO0lBRUQsZUFBZSxDQUFDLEdBQVc7UUFDekIsTUFBTSxFQUFFLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQztRQUN4QixPQUFPLEdBQUcsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVELGNBQWMsQ0FBQyxLQUFVLEVBQUUsS0FBYTtRQUN0QyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBRXhCLE1BQU0sUUFBUSxHQUFHLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM3QyxNQUFNLE9BQU8sR0FBYSxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDeEQsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNiLE9BQU8sQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUMzQzthQUFNO1lBQ0wsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNyQjtRQUVELElBQUksQ0FBQyxNQUFNLEdBQUcsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQ3pELElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDOzs2SEFuRVUsZ0NBQWdDO2lIQUFoQyxnQ0FBZ0Msd0pDVjdDLDRPQUdrQjsyRkRPTCxnQ0FBZ0M7a0JBTDVDLFNBQVM7K0JBQ0UsNEJBQTRCOzBFQUs3QixNQUFNO3NCQUFkLEtBQUs7Z0JBRUksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3ksIE9uSW5pdCwgT3V0cHV0LCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNb25rZXlFY3hGaWx0ZXJNZW51IH0gZnJvbSAnbW9ua2V5LWZyb250LWNvcmUnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBkZWJvdW5jZVRpbWUgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ21lY3gtZmlsdGVyLW9wdGlvbnMtc3RhdHVzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3N0YXR1cy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3N0YXR1cy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE1FQ1hGaWx0ZXJPcHRpb25zU3RhdHVzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIG9wdGlvbjogTW9ua2V5RWN4RmlsdGVyTWVudSA9IG51bGw7XG5cbiAgQE91dHB1dCgpIG9uU3VibWl0ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgX3ZhbHVlID0gJyc7XG5cbiAgcHJpdmF0ZSBldmVudEhhbmRsZSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIHByaXZhdGUgZXZlbnRTdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICAvLyBub3QgdG8gZG9cbiAgfVxuXG4gIHByaXZhdGUgdmVyaWZ5U2VsZWN0ZWQodmFsdWU6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLl92YWx1ZT8uaW5jbHVkZXModmFsdWUpO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc3QgeyBldmVudEhhbmRsZSwgb25TdWJtaXQsIG9wdGlvbjogeyBmaWVsZCB9IH0gPSB0aGlzO1xuXG4gICAgdGhpcy5ldmVudFN1YnNjcmlwdGlvbiA9IGV2ZW50SGFuZGxlXG4gICAgICAucGlwZShkZWJvdW5jZVRpbWUoODAwKSlcbiAgICAgIC5zdWJzY3JpYmUoKHZhbHVlOiBzdHJpbmcpID0+IHtcbiAgICAgICAgb25TdWJtaXQubmV4dCh7IFtmaWVsZF06IHZhbHVlIH0pO1xuICAgICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmV2ZW50U3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgdHJ5IHtcbiAgICAgIGlmIChjaGFuZ2VzLm9wdGlvbikge1xuICAgICAgICBjb25zdCB7IGN1cnJlbnRWYWx1ZSB9ID0gY2hhbmdlcy5vcHRpb247XG4gICAgICAgIGlmIChjdXJyZW50VmFsdWUgJiYgSlNPTi5zdHJpbmdpZnkoY3VycmVudFZhbHVlKSAhPT0gJ3t9Jykge1xuICAgICAgICAgIHRoaXMuX3ZhbHVlID0gY3VycmVudFZhbHVlPy52YWx1ZTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIGNvbnNvbGUubG9nKCc9PT09PTInKTtcbiAgICAgIGNvbnNvbGUubG9nKGUpO1xuICAgICAgY29uc29sZS5sb2coY2hhbmdlcz8ub3B0aW9uPy5jdXJyZW50VmFsdWUpO1xuICAgIH1cbiAgfVxuXG4gIG9uSGFuZGxlQ2hlY2tlZChjbXA6IHN0cmluZykge1xuICAgIGNvbnN0IHsgX3ZhbHVlIH0gPSB0aGlzO1xuICAgIHJldHVybiBgJHtfdmFsdWV9YC5zcGxpdCgnLCcpPy5pbmRleE9mKGNtcCkgPj0gMDtcbiAgfVxuXG4gIG9uQ2hhbmdlRmlsdGVyKGV2ZW50OiBhbnksIHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXG4gICAgY29uc3Qgc2VsZWN0ZWQgPSAhdGhpcy52ZXJpZnlTZWxlY3RlZCh2YWx1ZSk7XG4gICAgY29uc3QgZmlsdGVyczogc3RyaW5nW10gPSB0aGlzLl92YWx1ZT8uc3BsaXQoJywnKSB8fCBbXTtcbiAgICBpZiAoIXNlbGVjdGVkKSB7XG4gICAgICBmaWx0ZXJzLnNwbGljZShmaWx0ZXJzLmluZGV4T2YodmFsdWUpLCAxKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZmlsdGVycy5wdXNoKHZhbHVlKTtcbiAgICB9XG5cbiAgICB0aGlzLl92YWx1ZSA9IGZpbHRlcnM/Lmxlbmd0aCA/IGZpbHRlcnMuam9pbignLCcpIDogbnVsbDtcbiAgICB0aGlzLmV2ZW50SGFuZGxlLm5leHQodGhpcy5fdmFsdWUpO1xuICB9XG59XG4iLCI8bW9ua2V5LWNoZWNrYm94IHR5cGU9XCJtdWx0aXBsZVwiICpuZ0Zvcj1cImxldCBvcCBvZiBvcHRpb24/LnZhbHVlc1wiXHJcbiAgW2Rlc2NyaXB0aW9uXT1cIm9wPy5kZXNjcmlwdGlvbiB8IHRyYW5zbGF0ZVwiIFt2YWx1ZV09XCJvbkhhbmRsZUNoZWNrZWQob3A/LnZhbHVlKVwiXHJcbiAgKGNsaWNrKT1cIm9uQ2hhbmdlRmlsdGVyKCRldmVudCwgb3A/LnZhbHVlKVwiPlxyXG48L21vbmtleS1jaGVja2JveD4iXX0=
@@ -1648,12 +1648,20 @@ class MECXFilterOptionsStatusComponent {
1648
1648
  this.eventSubscription.unsubscribe();
1649
1649
  }
1650
1650
  ngOnChanges(changes) {
1651
- if (changes.option) {
1652
- const { currentValue } = changes.option;
1653
- if (currentValue && JSON.stringify(currentValue) !== '{}') {
1654
- this._value = currentValue === null || currentValue === void 0 ? void 0 : currentValue.value;
1651
+ var _a;
1652
+ try {
1653
+ if (changes.option) {
1654
+ const { currentValue } = changes.option;
1655
+ if (currentValue && JSON.stringify(currentValue) !== '{}') {
1656
+ this._value = currentValue === null || currentValue === void 0 ? void 0 : currentValue.value;
1657
+ }
1655
1658
  }
1656
1659
  }
1660
+ catch (e) {
1661
+ console.log('=====2');
1662
+ console.log(e);
1663
+ console.log((_a = changes === null || changes === void 0 ? void 0 : changes.option) === null || _a === void 0 ? void 0 : _a.currentValue);
1664
+ }
1657
1665
  }
1658
1666
  onHandleChecked(cmp) {
1659
1667
  var _a;
@@ -1863,17 +1871,23 @@ class MECXFilterOptionsComponent extends BaseComponent {
1863
1871
  ngOnInit() {
1864
1872
  var _a, _b, _c;
1865
1873
  const { option } = this;
1866
- (_a = option === null || option === void 0 ? void 0 : option.values$) === null || _a === void 0 ? void 0 : _a.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1867
- console.log('!@@@@@@@@@@@@@@@@@@@@');
1868
- console.log(data);
1869
- this.option.values = data;
1870
- });
1871
- (_b = option === null || option === void 0 ? void 0 : option.pagination$) === null || _b === void 0 ? void 0 : _b.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1872
- this._hasMoreValues = !!(data === null || data === void 0 ? void 0 : data.next);
1873
- });
1874
- (_c = option === null || option === void 0 ? void 0 : option.control$) === null || _c === void 0 ? void 0 : _c.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1875
- this.onHandleLoading(data === null || data === void 0 ? void 0 : data.isLoading);
1876
- });
1874
+ try {
1875
+ (_a = option === null || option === void 0 ? void 0 : option.values$) === null || _a === void 0 ? void 0 : _a.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1876
+ console.log('!@@@@@@@@@@@@@@@@@@@@');
1877
+ console.log(data);
1878
+ this.option.values = data;
1879
+ });
1880
+ (_b = option === null || option === void 0 ? void 0 : option.pagination$) === null || _b === void 0 ? void 0 : _b.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1881
+ this._hasMoreValues = !!(data === null || data === void 0 ? void 0 : data.next);
1882
+ });
1883
+ (_c = option === null || option === void 0 ? void 0 : option.control$) === null || _c === void 0 ? void 0 : _c.pipe(takeUntil(this.__unsubscribeAll)).subscribe((data) => {
1884
+ this.onHandleLoading(data === null || data === void 0 ? void 0 : data.isLoading);
1885
+ });
1886
+ }
1887
+ catch (e) {
1888
+ console.log('=====1');
1889
+ console.log(e);
1890
+ }
1877
1891
  }
1878
1892
  ngAfterViewInit() {
1879
1893
  this.onHandleLoadValues(true);
@@ -2081,6 +2095,9 @@ class MECXFilterMenuComponent {
2081
2095
  }
2082
2096
  catch (e) {
2083
2097
  // not to do
2098
+ console.log('=====3');
2099
+ console.log(e);
2100
+ console.log(value);
2084
2101
  }
2085
2102
  return false;
2086
2103
  }
@@ -2112,30 +2129,45 @@ class MECXFilterMenuComponent {
2112
2129
  });
2113
2130
  }
2114
2131
  ngOnChanges(changes) {
2115
- if (changes.model) {
2116
- const { currentValue } = changes.model;
2117
- if (currentValue && JSON.stringify(currentValue) !== '{}') {
2118
- this.onHandleMenus(currentValue);
2132
+ var _a;
2133
+ try {
2134
+ if (changes.model) {
2135
+ const { currentValue } = changes.model;
2136
+ if (currentValue && JSON.stringify(currentValue) !== '{}') {
2137
+ this.onHandleMenus(currentValue);
2138
+ }
2119
2139
  }
2120
2140
  }
2141
+ catch (e) {
2142
+ console.log('=====4');
2143
+ console.log(e);
2144
+ console.log((_a = changes === null || changes === void 0 ? void 0 : changes.model) === null || _a === void 0 ? void 0 : _a.currentValue);
2145
+ }
2121
2146
  }
2122
2147
  onHandleChildrenAction(option, child) {
2123
- const { field, type, action } = child;
2124
- if (type === 'with-action') {
2125
- this.onHandleSubmitValue({
2126
- [option.field]: JSON.stringify({
2127
- [field]: action()
2128
- })
2129
- });
2130
- }
2131
- else {
2132
- this._showMenu = true;
2133
- this._menuOption = child;
2134
- this.onHandleSubmit = (event) => {
2148
+ try {
2149
+ const { field, type, action } = child;
2150
+ if (type === 'with-action') {
2135
2151
  this.onHandleSubmitValue({
2136
- [option.field]: JSON.stringify(event)
2152
+ [option.field]: JSON.stringify({
2153
+ [field]: action()
2154
+ })
2137
2155
  });
2138
- };
2156
+ }
2157
+ else {
2158
+ this._showMenu = true;
2159
+ this._menuOption = child;
2160
+ this.onHandleSubmit = (event) => {
2161
+ this.onHandleSubmitValue({
2162
+ [option.field]: JSON.stringify(event)
2163
+ });
2164
+ };
2165
+ }
2166
+ }
2167
+ catch (e) {
2168
+ console.log('=====5');
2169
+ console.log(e);
2170
+ console.log(child);
2139
2171
  }
2140
2172
  }
2141
2173
  onHandleShowMenu(option) {