monkey-front-components 0.0.420 → 0.0.421

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.
@@ -29,7 +29,7 @@ export class MECXFilterComponent {
29
29
  this.closeMenu = () => {
30
30
  this._showMenu = false;
31
31
  };
32
- this.closOrder = () => {
32
+ this.closeOrder = () => {
33
33
  this._showOrder = false;
34
34
  };
35
35
  // not to do
@@ -139,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
139
139
  }], onFilter: [{
140
140
  type: Output
141
141
  }] } });
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  closOrder = () => {\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\">\n  <div class=\"d-flex flex-column flex-md-row justify-content-between\">\n    <div class=\"d-flex full-width\">\n      <ng-container *ngIf=\"enableSearch\">\n        <monkey-input-filter [placeholder]=\"searchPlaceholder | translate\"\n          (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" iconPosition=\"left\"\n          [(value)]=\"_search\">\n        </monkey-input-filter>\n      </ng-container>\n      <ng-container *ngIf=\"!_hasFilterByMenu\">\n        <div *ngIf=\"enableAddFilter\" class=\"d-flex actions\" id=\"mecx-filters-add-filter\">\n          <monkey-button type=\"filter\" color=\"border\" (click)=\"onHandleShowMenu()\" icon=\"more-16\"\n            iconPosition=\"right\">\n            {{ 'BUTTONS.ADD-FILTER' | translate }}\n          </monkey-button>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"order hidden-sm hidden-xs\" *ngIf=\"enableOrder\">\n      <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\n    </div>\n  </div>\n  <ng-container *ngIf=\"_hasFilterByMenu\">\n    <div class=\"separator\"></div>\n    <div class=\"d-flex full-width\">\n      <mecx-filter-selected (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\"\n        [model]=\"menus\"></mecx-filter-selected>\n      <div class=\"more-filters\">\n        <monkey-button type=\"filter\" color=\"border\" icon=\"more-16\" id=\"mecx-filters-add-filter\"\n          (click)=\"onHandleShowMenu()\">\n        </monkey-button>\n      </div>\n    </div>\n  </ng-container>\n  <div class=\"order hidden-md hidden-lg\" *ngIf=\"enableOrder\">\n    <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\n  </div>\n</div>\n\n<mecx-filter-menu\n  *monkeyecxPopover=\"_showMenu; target: $any(_actionElement); closed: closeMenu; dir: 'ltr'\"\n  (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\" [model]=\"menus\">\n</mecx-filter-menu>\n\n<ng-template #orderBy>\n  <ng-container *ngIf=\"!_ordersList?.length > 0; else orderByList\">\n    <monkey-select-filter (onChange)=\"onHandleOrder($event)\"\n      [placeholder]=\"orderPlaceholder | translate\" type=\"none\" [(value)]=\"_order\">\n      <monkey-option *ngFor=\"let ordBy of orders\" [label]=\"ordBy?.label | translate\"\n        [value]=\"ordBy?.value\">x\n      </monkey-option>\n    </monkey-select-filter>\n  </ng-container>\n</ng-template>\n\n<ng-template #orderByList>\n  <div class=\"d-flex full-width justify-content-end\">\n    <div #ordersFilterMenu (click)=\"onHandleShowOrders(ordersFilterMenu)\">\n      <monkey-button type=\"filter\" color=\"border\" icon=\"arrow-down-16\" iconPosition=\"right\">\n        {{ 'BUTTONS.ORDINATION' | translate }}\n      </monkey-button>\n    </div>\n  </div>\n  <div class=\"ml-1\"\n    *monkeyecxPopover=\"_showOrder; target: $any(_actionElementOrder); closed: closeOrder; dir: 'rtl'\">\n    <div class=\"drop-down-orders-filter pt-4\">\n      <ng-container *ngFor=\"let item of _ordersList\">\n        <div class=\"px-4\">\n          <span>{{ item.label | translate }}</span>\n          <monkey-radiobutton [value]=\"item.value\" (onChange)=\"onHandleOrder($event, item.field)\">\n            <monkey-option *ngFor=\"let ordBy of item.values\" [label]=\"ordBy?.label | translate\"\n              [value]=\"ordBy?.value\">\n            </monkey-option>\n          </monkey-radiobutton>\n        </div>\n      </ng-container>\n    </div>\n  </div>\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\">\n  <div class=\"d-flex flex-column flex-md-row justify-content-between\">\n    <div class=\"d-flex full-width\">\n      <ng-container *ngIf=\"enableSearch\">\n        <monkey-input-filter [placeholder]=\"searchPlaceholder | translate\"\n          (onChange)=\"onSearchFilter($event)\" icon=\"search-16\" iconPosition=\"left\"\n          [(value)]=\"_search\">\n        </monkey-input-filter>\n      </ng-container>\n      <ng-container *ngIf=\"!_hasFilterByMenu\">\n        <div *ngIf=\"enableAddFilter\" class=\"d-flex actions\" id=\"mecx-filters-add-filter\">\n          <monkey-button type=\"filter\" color=\"border\" (click)=\"onHandleShowMenu()\" icon=\"more-16\"\n            iconPosition=\"right\">\n            {{ 'BUTTONS.ADD-FILTER' | translate }}\n          </monkey-button>\n        </div>\n      </ng-container>\n    </div>\n    <div class=\"order hidden-sm hidden-xs\" *ngIf=\"enableOrder\">\n      <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\n    </div>\n  </div>\n  <ng-container *ngIf=\"_hasFilterByMenu\">\n    <div class=\"separator\"></div>\n    <div class=\"d-flex full-width\">\n      <mecx-filter-selected (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\"\n        [model]=\"menus\"></mecx-filter-selected>\n      <div class=\"more-filters\">\n        <monkey-button type=\"filter\" color=\"border\" icon=\"more-16\" id=\"mecx-filters-add-filter\"\n          (click)=\"onHandleShowMenu()\">\n        </monkey-button>\n      </div>\n    </div>\n  </ng-container>\n  <div class=\"order hidden-md hidden-lg\" *ngIf=\"enableOrder\">\n    <ng-container *ngTemplateOutlet=\"orderBy\"></ng-container>\n  </div>\n</div>\n\n<mecx-filter-menu\n  *monkeyecxPopover=\"_showMenu; target: $any(_actionElement); closed: closeMenu; dir: 'ltr'\"\n  (onSubmit)=\"onHandleSubmit($event)\" (onClose)=\"onHandleClose()\" [model]=\"menus\">\n</mecx-filter-menu>\n\n<ng-template #orderBy>\n  <ng-container *ngIf=\"!_ordersList?.length > 0; else orderByList\">\n    <monkey-select-filter (onChange)=\"onHandleOrder($event)\"\n      [placeholder]=\"orderPlaceholder | translate\" type=\"none\" [(value)]=\"_order\">\n      <monkey-option *ngFor=\"let ordBy of orders\" [label]=\"ordBy?.label | translate\"\n        [value]=\"ordBy?.value\">x\n      </monkey-option>\n    </monkey-select-filter>\n  </ng-container>\n</ng-template>\n\n<ng-template #orderByList>\n  <div class=\"d-flex full-width justify-content-end\">\n    <div #ordersFilterMenu (click)=\"onHandleShowOrders(ordersFilterMenu)\">\n      <monkey-button type=\"filter\" color=\"border\" icon=\"arrow-down-16\" iconPosition=\"right\">\n        {{ 'BUTTONS.ORDINATION' | translate }}\n      </monkey-button>\n    </div>\n  </div>\n  <div class=\"ml-1\"\n    *monkeyecxPopover=\"_showOrder; target: $any(_actionElementOrder); closed: closeOrder; dir: 'rtl'\">\n    <div class=\"drop-down-orders-filter pt-4\">\n      <ng-container *ngFor=\"let item of _ordersList\">\n        <div class=\"px-4\">\n          <span>{{ item.label | translate }}</span>\n          <monkey-radiobutton [value]=\"item.value\" (onChange)=\"onHandleOrder($event, item.field)\">\n            <monkey-option *ngFor=\"let ordBy of item.values\" [label]=\"ordBy?.label | translate\"\n              [value]=\"ordBy?.value\">\n            </monkey-option>\n          </monkey-radiobutton>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</ng-template>"]}
@@ -2149,7 +2149,7 @@ class MECXFilterComponent {
2149
2149
  this.closeMenu = () => {
2150
2150
  this._showMenu = false;
2151
2151
  };
2152
- this.closOrder = () => {
2152
+ this.closeOrder = () => {
2153
2153
  this._showOrder = false;
2154
2154
  };
2155
2155
  // not to do