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.
- package/esm2020/lib/components/shared/filter/menu/menu.component.mjs +36 -19
- package/esm2020/lib/components/shared/filter/options/options.component.mjs +18 -12
- package/esm2020/lib/components/shared/filter/options/status/status.component.mjs +12 -5
- package/fesm2015/monkey-front-components.mjs +65 -33
- package/fesm2015/monkey-front-components.mjs.map +1 -1
- package/fesm2020/monkey-front-components.mjs +63 -33
- package/fesm2020/monkey-front-components.mjs.map +1 -1
- package/monkey-front-components-0.0.433.tgz +0 -0
- package/package.json +1 -1
- package/monkey-front-components-0.0.431.tgz +0 -0
|
@@ -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
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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
|
-
|
|
79
|
-
|
|
80
|
-
|
|
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(
|
|
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
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
this.
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
this.
|
|
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
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
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,
|
|
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
|
-
|
|
1652
|
-
|
|
1653
|
-
if (
|
|
1654
|
-
|
|
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
|
-
|
|
1867
|
-
|
|
1868
|
-
|
|
1869
|
-
|
|
1870
|
-
|
|
1871
|
-
|
|
1872
|
-
|
|
1873
|
-
|
|
1874
|
-
|
|
1875
|
-
|
|
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
|
-
|
|
2116
|
-
|
|
2117
|
-
if (
|
|
2118
|
-
|
|
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
|
-
|
|
2124
|
-
|
|
2125
|
-
|
|
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(
|
|
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) {
|