@sd-angular/core 1.1.88 → 1.1.89

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.
@@ -177,7 +177,7 @@ _setting = new WeakMap(), _initDefault = new WeakMap();
177
177
  SdGridConfig.decorators = [
178
178
  { type: Component, args: [{
179
179
  selector: 'sd-grid-config',
180
- template: "<sd-modal [title]=\"'Configuration' | sdTranslate\" #modal>\r\n <sd-modal-body *ngIf=\"storage\">\r\n <div class=\"row\">\r\n <div class=\"col-md-3 col-6\">\r\n <sd-input-number [label]=\"'Page size' | sdTranslate\" [(model)]=\"storage.pageSize\" step=\"1\">\r\n </sd-input-number>\r\n </div>\r\n </div>\r\n <div class=\"sd-box sd-box-primary\">\r\n <div class=\"sd-box-body p-0\">\r\n <div class=\"table-responsive\">\r\n <table class=\"table table-striped table-sm table-hover table-bordered c-table\">\r\n <thead class=\"thead-light\">\r\n <tr>\r\n <th class=\"text-center\" style=\"width: 50px\">#</th>\r\n <th *sdDesktop class=\"text-center\" style=\"width: 80px\"></th>\r\n <!-- <th class=\"text-uppercase\" style=\"width: 120px\">Field </th> -->\r\n <th class=\"text-uppercase\">{{'Title' | sdTranslate}}</th>\r\n <th *sdDesktop class=\"text-uppercase\" style=\"width: 80px\">{{'Width' | sdTranslate}}</th>\r\n <th class=\"text-uppercase\" style=\"width: 80px\">{{'Hidden' | sdTranslate}}</th>\r\n <th *sdDesktop class=\"text-uppercase\" style=\"width: 80px\">{{'Freeze' | sdTranslate}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let column of storage.columnConfigs; let idx = index\">\r\n <td class=\"align-middle text-center\">\r\n {{idx+1}}\r\n </td>\r\n <td *sdDesktop class=\"align-middle text-center\">\r\n <button type=\"button\" [disabled]=\"idx==0\" type=\"button\" class=\"c-btn-icon\" placement=\"top\"\r\n matTooltip=\"Up\" (click)=\"moveColumnUp(idx)\">\r\n <i class=\"fa fa-arrow-up text-primary\" aria-hidden=\"true\"></i>\r\n </button>\r\n <button type=\"button\" [disabled]=\"idx==storage.columnConfigs.length-1\" type=\"button\"\r\n class=\"c-btn-icon\" placement=\"top\" matTooltip=\"Down\" (click)=\"moveColumnDown(idx)\">\r\n <i class=\"fa fa-arrow-down text-primary\" aria-hidden=\"true\"></i>\r\n </button>\r\n </td>\r\n <!-- <td class=\"align-middle\">{{column.originColumn.field}}</td> -->\r\n <td class=\"align-middle\">\r\n <input type=\"text\" placeholder=\"{{column.originColumn.title}}\" [(ngModel)]=\"column.title\"\r\n class=\"form-control form-control-sm\">\r\n </td>\r\n <td *sdDesktop class=\"align-middle\">\r\n <input type=\"text\" placeholder=\"{{column.originColumn.width}}\" [(ngModel)]=\"column.width\"\r\n class=\"form-control form-control-sm\">\r\n </td>\r\n <td class=\"align-middle text-center\">\r\n <mat-slide-toggle [(ngModel)]=\"column.hidden\" color=\"primary\"></mat-slide-toggle>\r\n </td>\r\n <td *sdDesktop class=\"align-middle text-center\">\r\n <mat-slide-toggle [(ngModel)]=\"column.fixed\" color=\"primary\"></mat-slide-toggle>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n </div>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"reset()\" icon=\"refresh\" [title]=\"'Reset' | sdTranslate\" size=\"sm\"></sd-button>\r\n <sd-button (action)=\"save()\" icon=\"save\" [title]=\"'Save' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"reset()\" icon=\"refresh\" [title]=\"'Reset' | sdTranslate\"\r\n width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"save()\" icon=\"save\" [title]=\"'Save' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>",
180
+ template: "<sd-modal [title]=\"'Configuration' | sdTranslate\" #modal>\r\n <sd-modal-body *ngIf=\"storage\">\r\n <div class=\"row\">\r\n <div class=\"col-md-3 col-6\">\r\n <sd-input-currency [label]=\"'Page size' | sdTranslate\" [(model)]=\"storage.pageSize\" step=\"1\">\r\n </sd-input-currency>\r\n </div>\r\n </div>\r\n <div class=\"sd-box sd-box-primary\">\r\n <div class=\"sd-box-body p-0\">\r\n <div class=\"table-responsive\">\r\n <table class=\"table table-striped table-sm table-hover table-bordered c-table\">\r\n <thead class=\"thead-light\">\r\n <tr>\r\n <th class=\"text-center\" style=\"width: 50px\">#</th>\r\n <th *sdDesktop class=\"text-center\" style=\"width: 80px\"></th>\r\n <!-- <th class=\"text-uppercase\" style=\"width: 120px\">Field </th> -->\r\n <th class=\"text-uppercase\">{{'Title' | sdTranslate}}</th>\r\n <th *sdDesktop class=\"text-uppercase\" style=\"width: 80px\">{{'Width' | sdTranslate}}</th>\r\n <th class=\"text-uppercase\" style=\"width: 80px\">{{'Hidden' | sdTranslate}}</th>\r\n <th *sdDesktop class=\"text-uppercase\" style=\"width: 80px\">{{'Freeze' | sdTranslate}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let column of storage.columnConfigs; let idx = index\">\r\n <td class=\"align-middle text-center\">\r\n {{idx+1}}\r\n </td>\r\n <td *sdDesktop class=\"align-middle text-center\">\r\n <button type=\"button\" [disabled]=\"idx==0\" type=\"button\" class=\"c-btn-icon\" placement=\"top\"\r\n matTooltip=\"Up\" (click)=\"moveColumnUp(idx)\">\r\n <i class=\"fa fa-arrow-up text-primary\" aria-hidden=\"true\"></i>\r\n </button>\r\n <button type=\"button\" [disabled]=\"idx==storage.columnConfigs.length-1\" type=\"button\"\r\n class=\"c-btn-icon\" placement=\"top\" matTooltip=\"Down\" (click)=\"moveColumnDown(idx)\">\r\n <i class=\"fa fa-arrow-down text-primary\" aria-hidden=\"true\"></i>\r\n </button>\r\n </td>\r\n <!-- <td class=\"align-middle\">{{column.originColumn.field}}</td> -->\r\n <td class=\"align-middle\">\r\n <input type=\"text\" placeholder=\"{{column.originColumn.title}}\" [(ngModel)]=\"column.title\"\r\n class=\"form-control form-control-sm\">\r\n </td>\r\n <td *sdDesktop class=\"align-middle\">\r\n <input type=\"text\" placeholder=\"{{column.originColumn.width}}\" [(ngModel)]=\"column.width\"\r\n class=\"form-control form-control-sm\">\r\n </td>\r\n <td class=\"align-middle text-center\">\r\n <mat-slide-toggle [(ngModel)]=\"column.hidden\" color=\"primary\"></mat-slide-toggle>\r\n </td>\r\n <td *sdDesktop class=\"align-middle text-center\">\r\n <mat-slide-toggle [(ngModel)]=\"column.fixed\" color=\"primary\"></mat-slide-toggle>\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n </div>\r\n </div>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"reset()\" icon=\"refresh\" [title]=\"'Reset' | sdTranslate\" size=\"sm\"></sd-button>\r\n <sd-button (action)=\"save()\" icon=\"save\" [title]=\"'Save' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"reset()\" icon=\"refresh\" [title]=\"'Reset' | sdTranslate\"\r\n width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"save()\" icon=\"save\" [title]=\"'Save' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>",
181
181
  styles: [".c-btn-icon{background:none!important;border:none;opacity:.8}.c-btn-icon:hover{cursor:pointer;opacity:1}.c-btn-icon:disabled{background:none!important;border:none;cursor:not-allowed;opacity:.3}.table td,.table th{padding:.2rem!important}.c-table.table{margin-bottom:5px}"]
182
182
  },] }
183
183
  ];
@@ -191,4 +191,4 @@ SdGridConfig.propDecorators = {
191
191
  modal: [{ type: ViewChild, args: ['modal',] }],
192
192
  sdChange: [{ type: Output }]
193
193
  };
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-config.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-config/grid-config.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';\r\nimport { ConfigOption, ConfigResult, ConfigStorage } from './grid-config.model';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\n\r\nimport {\r\n  SdSetting,\r\n  SdSettingService\r\n} from '@sd-angular/core/setting';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\n\r\n@Component({\r\n  selector: 'sd-grid-config',\r\n  templateUrl: './grid-config.component.html',\r\n  styleUrls: ['./grid-config.component.scss']\r\n})\r\nexport class SdGridConfig implements OnInit {\r\n  @ViewChild('modal') modal: SdModal;\r\n  @Output() sdChange = new EventEmitter<ConfigResult>();\r\n\r\n  option: ConfigOption;\r\n  storage: ConfigStorage;\r\n  #setting: SdSetting<ConfigStorage>;\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private settingService: SdSettingService,\r\n    private translateService: SdTranslateService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n  async setOption(option: ConfigOption) {\r\n    this.ref.detectChanges();\r\n    this.option = option;\r\n    if (this.option.key) {\r\n      this.#setting = this.settingService.create<ConfigStorage>(this.option.key);\r\n    } else {\r\n      this.#setting = null;\r\n    }\r\n    await this.init();\r\n    this.emitOnChange();\r\n  }\r\n\r\n  private async init() {\r\n    if (this.#setting) {\r\n      const storage: ConfigStorage = await this.#setting.get();\r\n      try {\r\n        if (!storage) {\r\n          await this.#setting.remove();\r\n          this.#initDefault();\r\n          return;\r\n        }\r\n        this.storage = storage;\r\n\r\n        // Loại bỏ những column đã bị xóa khỏi originColumns\r\n        this.storage.columnConfigs = this.storage.columnConfigs\r\n          .filter(column => this.option.columns.some(e => e.field === column.originColumn.field));\r\n\r\n        // Thêm những column mới vào storage nếu có\r\n        this.option.columns.forEach(column => {\r\n          if (!this.storage.columnConfigs.some(e => e.originColumn.field === column.field)) {\r\n            this.storage.columnConfigs.push({\r\n              originColumn: {\r\n                field: column.field,\r\n                title: column.title,\r\n                width: column.width,\r\n                fixed: column.fixed\r\n              },\r\n              hidden: false,\r\n              fixed: column.fixed\r\n            });\r\n          }\r\n        });\r\n\r\n        // Cập nhật originColumn\r\n        this.storage.columnConfigs.forEach(column => {\r\n          const originColumn = this.option.columns.find(e => e.field === column.originColumn.field);\r\n          if (originColumn) {\r\n            Object.assign(column.originColumn, {\r\n              title: originColumn.title,\r\n              width: originColumn.width,\r\n              fixed: originColumn.fixed\r\n            });\r\n          }\r\n        });\r\n      } catch (ex) {\r\n        this.#setting.remove();\r\n        this.#initDefault();\r\n      }\r\n    } else {\r\n      this.#initDefault();\r\n    }\r\n  }\r\n\r\n  #initDefault = () => {\r\n    this.storage = {};\r\n    this.storage.pageSize = this.option.pageSize;\r\n    this.storage.columnConfigs = [];\r\n    this.option.columns.forEach(column => {\r\n      this.storage.columnConfigs.push({\r\n        originColumn: {\r\n          field: column.field,\r\n          title: column.title,\r\n          width: column.width,\r\n          fixed: column.fixed\r\n        },\r\n        hidden: false,\r\n        fixed: column.fixed\r\n      });\r\n    });\r\n  }\r\n\r\n  open() {\r\n    this.modal.open();\r\n  }\r\n\r\n  save() {\r\n    if (!Number.isSafeInteger(+this.storage.pageSize)) {\r\n      this.notifyService.notify.warning(this.translateService.translate('Page size must be an integer'));\r\n      return;\r\n    }\r\n    if (this.storage.pageSize > 200) {\r\n      this.notifyService.notify.warning(this.translateService.translate('Page size is too large'));\r\n      return;\r\n    }\r\n    this.#setting?.set?.(this.storage);\r\n    this.emitOnChange();\r\n    this.modal.close();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  reset() {\r\n    this.#setting?.remove?.();\r\n    this.#initDefault();\r\n    this.emitOnChange();\r\n    this.modal.close();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  moveColumnUp(index: number) {\r\n    const temp = this.storage.columnConfigs[index];\r\n    this.storage.columnConfigs[index] = this.storage.columnConfigs[index - 1];\r\n    this.storage.columnConfigs[index - 1] = temp;\r\n  }\r\n\r\n  moveColumnDown(index: number) {\r\n    const temp = this.storage.columnConfigs[index];\r\n    this.storage.columnConfigs[index] = this.storage.columnConfigs[index + 1];\r\n    this.storage.columnConfigs[index + 1] = temp;\r\n  }\r\n\r\n  emitOnChange() {\r\n    const pageSize = +this.storage.pageSize || this.option.pageSize;\r\n    const columns = this.option.columns.filter(column => {\r\n      // Hidden column theo config\r\n      // Lấy các thuộc tính Title, Width, Fixed từ config\r\n      const columnConfig = this.storage.columnConfigs.find(e => e.originColumn.field === column.field);\r\n      if (columnConfig) {\r\n        column.title = columnConfig.title || column.title;\r\n        column.width = columnConfig.width || column.width;\r\n        column.fixed = columnConfig.fixed;\r\n        return !columnConfig.hidden;\r\n      }\r\n      return true;\r\n    }).sort((current, next) => {\r\n      // Sắp xếp theo config\r\n      const currentIndex = this.storage.columnConfigs.findIndex(e => e.originColumn.field === current.field);\r\n      const nextIndex = this.storage.columnConfigs.findIndex(e => e.originColumn.field === next.field);\r\n      return currentIndex - nextIndex;\r\n    }).filter(column => {\r\n      // Hidden column theo option truyền vào\r\n      if (column.hidden === undefined) {\r\n        return true;\r\n      }\r\n      if (typeof (column.hidden) === 'boolean') {\r\n        return !column.hidden;\r\n      }\r\n      if (typeof (column.hidden) === 'function') {\r\n        return !column.hidden();\r\n      }\r\n      return false;\r\n    });\r\n    const result: ConfigResult = {\r\n      pageSize,\r\n      columns,\r\n      fixedColumns: columns.filter(e => e.fixed),\r\n      normalColumns: columns.filter(e => !e.fixed)\r\n    };\r\n    this.sdChange.emit(result);\r\n  }\r\n}\r\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-config.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-config/grid-config.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';\r\nimport { ConfigOption, ConfigResult, ConfigStorage } from './grid-config.model';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\n\r\nimport {\r\n  SdSetting,\r\n  SdSettingService\r\n} from '@sd-angular/core/setting';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\n\r\n@Component({\r\n  selector: 'sd-grid-config',\r\n  templateUrl: './grid-config.component.html',\r\n  styleUrls: ['./grid-config.component.scss']\r\n})\r\nexport class SdGridConfig implements OnInit {\r\n  @ViewChild('modal') modal: SdModal;\r\n  @Output() sdChange = new EventEmitter<ConfigResult>();\r\n\r\n  option: ConfigOption;\r\n  storage: ConfigStorage;\r\n  #setting: SdSetting<ConfigStorage>;\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private settingService: SdSettingService,\r\n    private translateService: SdTranslateService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n  async setOption(option: ConfigOption) {\r\n    this.ref.detectChanges();\r\n    this.option = option;\r\n    if (this.option.key) {\r\n      this.#setting = this.settingService.create<ConfigStorage>(this.option.key);\r\n    } else {\r\n      this.#setting = null;\r\n    }\r\n    await this.init();\r\n    this.emitOnChange();\r\n  }\r\n\r\n  private async init() {\r\n    if (this.#setting) {\r\n      const storage: ConfigStorage = await this.#setting.get();\r\n      try {\r\n        if (!storage) {\r\n          await this.#setting.remove();\r\n          this.#initDefault();\r\n          return;\r\n        }\r\n        this.storage = storage;\r\n\r\n        // Loại bỏ những column đã bị xóa khỏi originColumns\r\n        this.storage.columnConfigs = this.storage.columnConfigs\r\n          .filter(column => this.option.columns.some(e => e.field === column.originColumn.field));\r\n\r\n        // Thêm những column mới vào storage nếu có\r\n        this.option.columns.forEach(column => {\r\n          if (!this.storage.columnConfigs.some(e => e.originColumn.field === column.field)) {\r\n            this.storage.columnConfigs.push({\r\n              originColumn: {\r\n                field: column.field,\r\n                title: column.title,\r\n                width: column.width,\r\n                fixed: column.fixed\r\n              },\r\n              hidden: false,\r\n              fixed: column.fixed\r\n            });\r\n          }\r\n        });\r\n\r\n        // Cập nhật originColumn\r\n        this.storage.columnConfigs.forEach(column => {\r\n          const originColumn = this.option.columns.find(e => e.field === column.originColumn.field);\r\n          if (originColumn) {\r\n            Object.assign(column.originColumn, {\r\n              title: originColumn.title,\r\n              width: originColumn.width,\r\n              fixed: originColumn.fixed\r\n            });\r\n          }\r\n        });\r\n      } catch (ex) {\r\n        this.#setting.remove();\r\n        this.#initDefault();\r\n      }\r\n    } else {\r\n      this.#initDefault();\r\n    }\r\n  }\r\n\r\n  #initDefault = () => {\r\n    this.storage = {};\r\n    this.storage.pageSize = this.option.pageSize;\r\n    this.storage.columnConfigs = [];\r\n    this.option.columns.forEach(column => {\r\n      this.storage.columnConfigs.push({\r\n        originColumn: {\r\n          field: column.field,\r\n          title: column.title,\r\n          width: column.width,\r\n          fixed: column.fixed\r\n        },\r\n        hidden: false,\r\n        fixed: column.fixed\r\n      });\r\n    });\r\n  }\r\n\r\n  open() {\r\n    this.modal.open();\r\n  }\r\n\r\n  save() {\r\n    if (!Number.isSafeInteger(+this.storage.pageSize)) {\r\n      this.notifyService.notify.warning(this.translateService.translate('Page size must be an integer'));\r\n      return;\r\n    }\r\n    if (this.storage.pageSize > 200) {\r\n      this.notifyService.notify.warning(this.translateService.translate('Page size is too large'));\r\n      return;\r\n    }\r\n    this.#setting?.set?.(this.storage);\r\n    this.emitOnChange();\r\n    this.modal.close();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  reset() {\r\n    this.#setting?.remove?.();\r\n    this.#initDefault();\r\n    this.emitOnChange();\r\n    this.modal.close();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  moveColumnUp(index: number) {\r\n    const temp = this.storage.columnConfigs[index];\r\n    this.storage.columnConfigs[index] = this.storage.columnConfigs[index - 1];\r\n    this.storage.columnConfigs[index - 1] = temp;\r\n  }\r\n\r\n  moveColumnDown(index: number) {\r\n    const temp = this.storage.columnConfigs[index];\r\n    this.storage.columnConfigs[index] = this.storage.columnConfigs[index + 1];\r\n    this.storage.columnConfigs[index + 1] = temp;\r\n  }\r\n\r\n  emitOnChange() {\r\n    const pageSize = +this.storage.pageSize || this.option.pageSize;\r\n    const columns = this.option.columns.filter(column => {\r\n      // Hidden column theo config\r\n      // Lấy các thuộc tính Title, Width, Fixed từ config\r\n      const columnConfig = this.storage.columnConfigs.find(e => e.originColumn.field === column.field);\r\n      if (columnConfig) {\r\n        column.title = columnConfig.title || column.title;\r\n        column.width = columnConfig.width || column.width;\r\n        column.fixed = columnConfig.fixed;\r\n        return !columnConfig.hidden;\r\n      }\r\n      return true;\r\n    }).sort((current, next) => {\r\n      // Sắp xếp theo config\r\n      const currentIndex = this.storage.columnConfigs.findIndex(e => e.originColumn.field === current.field);\r\n      const nextIndex = this.storage.columnConfigs.findIndex(e => e.originColumn.field === next.field);\r\n      return currentIndex - nextIndex;\r\n    }).filter(column => {\r\n      // Hidden column theo option truyền vào\r\n      if (column.hidden === undefined) {\r\n        return true;\r\n      }\r\n      if (typeof (column.hidden) === 'boolean') {\r\n        return !column.hidden;\r\n      }\r\n      if (typeof (column.hidden) === 'function') {\r\n        return !column.hidden();\r\n      }\r\n      return false;\r\n    });\r\n    const result: ConfigResult = {\r\n      pageSize,\r\n      columns,\r\n      fixedColumns: columns.filter(e => e.fixed),\r\n      normalColumns: columns.filter(e => !e.fixed)\r\n    };\r\n    this.sdChange.emit(result);\r\n  }\r\n}\r\n"]}
@@ -49,7 +49,7 @@ export class SdGridDesktopColumnEdit {
49
49
  SdGridDesktopColumnEdit.decorators = [
50
50
  { type: Component, args: [{
51
51
  selector: 'sd-grid-desktop-column-edit',
52
- template: "<ng-container *ngIf=\"column && item\">\r\n <div *ngIf=\"column.type === 'string'\">\r\n <div *ngIf=\"column.editor?.item;else elseUseInput\">\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </div>\r\n <ng-template #elseUseInput>\r\n <sd-input size=\"sm\" *ngIf=\"column.editor?.click\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\" (sdClick)=\"column.editor.click(item)\"></sd-input>\r\n <sd-input size=\"sm\" *ngIf=\"!column.editor?.click\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\"></sd-input>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'color'\">\r\n <sd-input size=\"sm\" type=\"color\" [(model)]=\"item[column.field]\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\">\r\n </sd-input>\r\n </div>\r\n <div *ngIf=\"column.type === 'number'\">\r\n <sd-input-number size=\"sm\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\"></sd-input-number>\r\n </div>\r\n <div *ngIf=\"column.type === 'date'\">\r\n <sd-date-time size=\"sm\" [(model)]=\"item[column.field]\" type=\"date\"></sd-date-time>\r\n </div>\r\n <div class=\"text-center\" *ngIf=\"column.type === 'datetime'\">\r\n <sd-date-time size=\"sm\" [(model)]=\"item[column.field]\" type=\"datetime\"></sd-date-time>\r\n </div>\r\n <div class=\"text-center\" *ngIf=\"column.type === 'time'\">\r\n <sd-time [(model)]=\"item[column.field]\"></sd-time>\r\n <!-- <sd-grid-date-picker-control [(model)]=\"item[column.field]\" type=\"time\"></sd-grid-date-picker-control> -->\r\n </div>\r\n <div class=\"align-middle text-center\" *ngIf=\"column.type === 'bool'\">\r\n <sd-switch [(model)]=\"item[column.field]\" (sdChange)=\"onEditorChange(column,item,item[column.field])\">\r\n </sd-switch>\r\n </div>\r\n <div *ngIf=\"column.type === 'values'\">\r\n <div *ngIf=\"column.editor?.item;else elseUseValues\">\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </div>\r\n <ng-template #elseUseValues>\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\" [items]=\"column.values\" valueField=\"value\" displayField=\"text\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\" [items]=\"column.values\" valueField=\"value\" displayField=\"text\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'radio'\">\r\n <section class=\"mt-5 ml-5\">\r\n <mat-radio-group class=\"d-flex\" [(ngModel)]=\"item[column.field]\"\r\n (change)=\"column.editor?.change && column.editor?.change(item)\">\r\n <mat-radio-button *ngIf=\"!column.editor?.required\" color=\"warn\" class=\"mr-5\" value=\"\">\r\n {{'Please select' | sdTranslate}}\r\n </mat-radio-button>\r\n <mat-radio-button color=\"primary\" class=\"mr-5\" *ngFor=\"let data of column.values\"\r\n [value]=\"data[column.valueField]\">\r\n {{data[column.displayField]}}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n </section>\r\n </div>\r\n <div class=\"align-middle text-center\" *ngIf=\"column.type === 'image'\">\r\n <img [src]=\"item[column.field]\" [width]=\"column.display?.width\" [height]=\"column.display?.height\"\r\n style=\"margin: 5px 0\" (click)=\"column.click && column.click(item[column.field], item)\">\r\n </div>\r\n</ng-container>",
52
+ template: "<ng-container *ngIf=\"column && item\">\r\n <div *ngIf=\"column.type === 'string'\">\r\n <div *ngIf=\"column.editor?.item;else elseUseInput\">\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </div>\r\n <ng-template #elseUseInput>\r\n <sd-input size=\"sm\" *ngIf=\"column.editor?.click\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\" (sdClick)=\"column.editor.click(item)\"></sd-input>\r\n <sd-input size=\"sm\" *ngIf=\"!column.editor?.click\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\"></sd-input>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'color'\">\r\n <sd-input size=\"sm\" type=\"color\" [(model)]=\"item[column.field]\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\">\r\n </sd-input>\r\n </div>\r\n <div *ngIf=\"column.type === 'number'\">\r\n <sd-input-currency size=\"sm\" [(model)]=\"item[column.field]\"\r\n (keyupEnter)=\"column.editor?.keyupEnter && column.editor?.keyupEnter(item)\"\r\n (sdChange)=\"onEditorChange(column,item,item[column.field])\"></sd-input-currency>\r\n </div>\r\n <div *ngIf=\"column.type === 'date'\">\r\n <sd-date-time size=\"sm\" [(model)]=\"item[column.field]\" type=\"date\"></sd-date-time>\r\n </div>\r\n <div class=\"text-center\" *ngIf=\"column.type === 'datetime'\">\r\n <sd-date-time size=\"sm\" [(model)]=\"item[column.field]\" type=\"datetime\"></sd-date-time>\r\n </div>\r\n <div class=\"text-center\" *ngIf=\"column.type === 'time'\">\r\n <sd-time [(model)]=\"item[column.field]\"></sd-time>\r\n <!-- <sd-grid-date-picker-control [(model)]=\"item[column.field]\" type=\"time\"></sd-grid-date-picker-control> -->\r\n </div>\r\n <div class=\"align-middle text-center\" *ngIf=\"column.type === 'bool'\">\r\n <sd-switch [(model)]=\"item[column.field]\" (sdChange)=\"onEditorChange(column,item,item[column.field])\">\r\n </sd-switch>\r\n </div>\r\n <div *ngIf=\"column.type === 'values'\">\r\n <div *ngIf=\"column.editor?.item;else elseUseValues\">\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\"\r\n [items]=\"item[column.editor?.item?.dependOnField] | sdDynamicItems:dynamicItems\"\r\n [valueField]=\"column.editor.item.value\" [displayField]=\"column.editor.item.display\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </div>\r\n <ng-template #elseUseValues>\r\n <sd-select *ngIf=\"!column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\" [items]=\"column.values\" valueField=\"value\" displayField=\"text\"\r\n (sdSelection)=\"onSelectionChange($event)\" [placeholder]=\"column.title\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.editor?.autocomplete\" size=\"sm\" [(model)]=\"item[column.field]\" [items]=\"column.values\" valueField=\"value\" displayField=\"text\"\r\n (sdChange)=\"onAutocompleteChange($event)\" [placeholder]=\"column.title\">\r\n </sd-autocomplete>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"column.type === 'radio'\">\r\n <section class=\"mt-5 ml-5\">\r\n <mat-radio-group class=\"d-flex\" [(ngModel)]=\"item[column.field]\"\r\n (change)=\"column.editor?.change && column.editor?.change(item)\">\r\n <mat-radio-button *ngIf=\"!column.editor?.required\" color=\"warn\" class=\"mr-5\" value=\"\">\r\n {{'Please select' | sdTranslate}}\r\n </mat-radio-button>\r\n <mat-radio-button color=\"primary\" class=\"mr-5\" *ngFor=\"let data of column.values\"\r\n [value]=\"data[column.valueField]\">\r\n {{data[column.displayField]}}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n </section>\r\n </div>\r\n <div class=\"align-middle text-center\" *ngIf=\"column.type === 'image'\">\r\n <img [src]=\"item[column.field]\" [width]=\"column.display?.width\" [height]=\"column.display?.height\"\r\n style=\"margin: 5px 0\" (click)=\"column.click && column.click(item[column.field], item)\">\r\n </div>\r\n</ng-container>",
53
53
  changeDetection: ChangeDetectionStrategy.OnPush,
54
54
  styles: [".c-input-xs{font-size:13px!important;height:28px!important;line-height:1.5!important;padding:3px!important}"]
55
55
  },] }
@@ -62,4 +62,4 @@ SdGridDesktopColumnEdit.propDecorators = {
62
62
  item: [{ type: Input }],
63
63
  sdChange: [{ type: Output }]
64
64
  };
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy9ncmlkLWRlc2t0b3AtY29sdW1uLWVkaXQvZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLHVCQUF1QixFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVNuSCxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLFlBQ1UsR0FBc0I7UUFBdEIsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFGdEIsYUFBUSxHQUFHLElBQUksWUFBWSxFQUF3RCxDQUFDO1FBSzlGLG1CQUFjLEdBQUcsQ0FBQyxNQUFvQixFQUFFLElBQWMsRUFBRSxLQUFVLEVBQUUsRUFBRTs7WUFDcEUsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLFVBQVUsRUFBRTtnQkFDOUIsWUFBQSxNQUFNLENBQUMsTUFBTSwwQ0FBRSxNQUFNLG1EQUFHLElBQUksRUFBRSxLQUFLLEVBQUU7Z0JBQ3JDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7YUFDdEI7UUFDSCxDQUFDLENBQUE7UUFFRCx5QkFBb0IsR0FBRyxDQUFDLElBQVMsRUFBRSxFQUFFOztZQUNuQyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxRQUFRLEVBQUU7Z0JBQ2xFLFlBQUEsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLDBDQUFFLE1BQU0sbURBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsSUFBSSxFQUFFO2dCQUM1RSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO2FBQ3RCO1FBQ0gsQ0FBQyxDQUFBO1FBRUQsc0JBQWlCLEdBQUcsQ0FBQyxNQUErQyxFQUFFLEVBQUU7O1lBQ3RFLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssUUFBUSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBRTtnQkFDbEUsWUFBQSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sMENBQUUsTUFBTSxtREFBRyxJQUFJLENBQUMsSUFBSSxFQUFFLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRSxLQUFLLEVBQUUsQ0FBQSxNQUFNLGFBQU4sTUFBTSx1QkFBTixNQUFNLENBQUUsSUFBSSxNQUFJLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRSxLQUFLLENBQUEsRUFBRTtnQkFDdEYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztnQkFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUN0QjtRQUNILENBQUMsQ0FBQTtRQUVELGlCQUFZLEdBQUcsQ0FBTyxLQUFVLEVBQUUsRUFBRTtZQUNsQyxJQUFJLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxJQUFJLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRTtnQkFDM0QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7Z0JBQ2xELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDeEIsT0FBTyxLQUFLLENBQUM7aUJBQ2Q7Z0JBQ0QsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQ3hDLElBQUksT0FBTyxZQUFZLE9BQU8sRUFBRTtvQkFDOUIsT0FBTyxNQUFNLE9BQU8sQ0FBQztpQkFDdEI7Z0JBQ0QsT0FBTyxPQUFPLENBQUM7YUFDaEI7aUJBQU07Z0JBQ0wsT0FBTyxFQUFFLENBQUM7YUFDWDtRQUNILENBQUMsQ0FBQSxDQUFBO0lBeENHLENBQUM7OztZQVpOLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2dCQUN2QyxzK0tBQXdEO2dCQUV4RCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQ7OztZQVIwQixpQkFBaUI7OztxQkFVekMsS0FBSzttQkFDTCxLQUFLO3VCQUNMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBDaGFuZ2VEZXRlY3RvclJlZiwgRXZlbnRFbWl0dGVyLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkR3JpZENvbHVtbiwgR3JpZEl0ZW0gfSBmcm9tICcuLi8uLi9ncmlkLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9ncmlkLWRlc2t0b3AtY29sdW1uLWVkaXQuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RHcmlkRGVza3RvcENvbHVtbkVkaXQge1xyXG4gIEBJbnB1dCgpIGNvbHVtbjogU2RHcmlkQ29sdW1uO1xyXG4gIEBJbnB1dCgpIGl0ZW06IEdyaWRJdGVtO1xyXG4gIEBPdXRwdXQoKSBzZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8eyBjb2x1bW46IFNkR3JpZENvbHVtbiwgaXRlbTogR3JpZEl0ZW0sIHZhbHVlOiBhbnkgfT4oKTtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVmOiBDaGFuZ2VEZXRlY3RvclJlZixcclxuICApIHsgfVxyXG5cclxuICBvbkVkaXRvckNoYW5nZSA9IChjb2x1bW46IFNkR3JpZENvbHVtbiwgaXRlbTogR3JpZEl0ZW0sIHZhbHVlOiBhbnkpID0+IHtcclxuICAgIGlmIChjb2x1bW4udHlwZSAhPT0gJ2NoaWxkcmVuJykge1xyXG4gICAgICBjb2x1bW4uZWRpdG9yPy5jaGFuZ2U/LihpdGVtLCB2YWx1ZSk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvbkF1dG9jb21wbGV0ZUNoYW5nZSA9IChpdGVtOiBhbnkpID0+IHtcclxuICAgIGlmICh0aGlzLmNvbHVtbi50eXBlID09PSAnc3RyaW5nJyB8fCB0aGlzLmNvbHVtbi50eXBlID09PSAndmFsdWVzJykge1xyXG4gICAgICB0aGlzLmNvbHVtbi5lZGl0b3I/LmNoYW5nZT8uKHRoaXMuaXRlbSwgdGhpcy5pdGVtW3RoaXMuY29sdW1uLmZpZWxkXSwgaXRlbSk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvblNlbGVjdGlvbkNoYW5nZSA9IChwYXJhbXM6IHsgdmFsdWU6IGFueSwgaXRlbTogYW55LCBpdGVtczogYW55W10gfSkgPT4ge1xyXG4gICAgaWYgKHRoaXMuY29sdW1uLnR5cGUgPT09ICdzdHJpbmcnIHx8IHRoaXMuY29sdW1uLnR5cGUgPT09ICd2YWx1ZXMnKSB7XHJcbiAgICAgIHRoaXMuY29sdW1uLmVkaXRvcj8uY2hhbmdlPy4odGhpcy5pdGVtLCBwYXJhbXM/LnZhbHVlLCBwYXJhbXM/Lml0ZW0gfHwgcGFyYW1zPy5pdGVtcyk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBkeW5hbWljSXRlbXMgPSBhc3luYyAodmFsdWU6IGFueSkgPT4ge1xyXG4gICAgaWYgKCdlZGl0b3InIGluIHRoaXMuY29sdW1uICYmICdpdGVtJyBpbiB0aGlzLmNvbHVtbi5lZGl0b3IpIHtcclxuICAgICAgY29uc3QgaXRlbXMgPSB0aGlzLmNvbHVtbi5lZGl0b3IuaXRlbS5pdGVtcyB8fCBbXTtcclxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoaXRlbXMpKSB7XHJcbiAgICAgICAgcmV0dXJuIGl0ZW1zO1xyXG4gICAgICB9XHJcbiAgICAgIGNvbnN0IHJlc3VsdHMgPSBpdGVtcyh0aGlzLml0ZW0sIHZhbHVlKTtcclxuICAgICAgaWYgKHJlc3VsdHMgaW5zdGFuY2VvZiBQcm9taXNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGF3YWl0IHJlc3VsdHM7XHJcbiAgICAgIH1cclxuICAgICAgcmV0dXJuIHJlc3VsdHM7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gW107XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy9ncmlkLWRlc2t0b3AtY29sdW1uLWVkaXQvZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsWUFBWSxFQUFFLHVCQUF1QixFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVNuSCxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLFlBQ1UsR0FBc0I7UUFBdEIsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFGdEIsYUFBUSxHQUFHLElBQUksWUFBWSxFQUF3RCxDQUFDO1FBSzlGLG1CQUFjLEdBQUcsQ0FBQyxNQUFvQixFQUFFLElBQWMsRUFBRSxLQUFVLEVBQUUsRUFBRTs7WUFDcEUsSUFBSSxNQUFNLENBQUMsSUFBSSxLQUFLLFVBQVUsRUFBRTtnQkFDOUIsWUFBQSxNQUFNLENBQUMsTUFBTSwwQ0FBRSxNQUFNLG1EQUFHLElBQUksRUFBRSxLQUFLLEVBQUU7Z0JBQ3JDLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7YUFDdEI7UUFDSCxDQUFDLENBQUE7UUFFRCx5QkFBb0IsR0FBRyxDQUFDLElBQVMsRUFBRSxFQUFFOztZQUNuQyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksS0FBSyxRQUFRLEVBQUU7Z0JBQ2xFLFlBQUEsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLDBDQUFFLE1BQU0sbURBQUcsSUFBSSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsSUFBSSxFQUFFO2dCQUM1RSxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO2dCQUN6QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO2FBQ3RCO1FBQ0gsQ0FBQyxDQUFBO1FBRUQsc0JBQWlCLEdBQUcsQ0FBQyxNQUErQyxFQUFFLEVBQUU7O1lBQ3RFLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssUUFBUSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBRTtnQkFDbEUsWUFBQSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sMENBQUUsTUFBTSxtREFBRyxJQUFJLENBQUMsSUFBSSxFQUFFLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRSxLQUFLLEVBQUUsQ0FBQSxNQUFNLGFBQU4sTUFBTSx1QkFBTixNQUFNLENBQUUsSUFBSSxNQUFJLE1BQU0sYUFBTixNQUFNLHVCQUFOLE1BQU0sQ0FBRSxLQUFLLENBQUEsRUFBRTtnQkFDdEYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztnQkFDekIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQzthQUN0QjtRQUNILENBQUMsQ0FBQTtRQUVELGlCQUFZLEdBQUcsQ0FBTyxLQUFVLEVBQUUsRUFBRTtZQUNsQyxJQUFJLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxJQUFJLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRTtnQkFDM0QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUM7Z0JBQ2xELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDeEIsT0FBTyxLQUFLLENBQUM7aUJBQ2Q7Z0JBQ0QsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7Z0JBQ3hDLElBQUksT0FBTyxZQUFZLE9BQU8sRUFBRTtvQkFDOUIsT0FBTyxNQUFNLE9BQU8sQ0FBQztpQkFDdEI7Z0JBQ0QsT0FBTyxPQUFPLENBQUM7YUFDaEI7aUJBQU07Z0JBQ0wsT0FBTyxFQUFFLENBQUM7YUFDWDtRQUNILENBQUMsQ0FBQSxDQUFBO0lBeENHLENBQUM7OztZQVpOLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2dCQUN2QywwK0tBQXdEO2dCQUV4RCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQ7OztZQVIwQixpQkFBaUI7OztxQkFVekMsS0FBSzttQkFDTCxLQUFLO3VCQUNMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBDaGFuZ2VEZXRlY3RvclJlZiwgRXZlbnRFbWl0dGVyLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkR3JpZENvbHVtbiwgR3JpZEl0ZW0gfSBmcm9tICcuLi8uLi9ncmlkLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZ3JpZC1kZXNrdG9wLWNvbHVtbi1lZGl0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9ncmlkLWRlc2t0b3AtY29sdW1uLWVkaXQuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RHcmlkRGVza3RvcENvbHVtbkVkaXQge1xyXG4gIEBJbnB1dCgpIGNvbHVtbjogU2RHcmlkQ29sdW1uO1xyXG4gIEBJbnB1dCgpIGl0ZW06IEdyaWRJdGVtO1xyXG4gIEBPdXRwdXQoKSBzZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8eyBjb2x1bW46IFNkR3JpZENvbHVtbiwgaXRlbTogR3JpZEl0ZW0sIHZhbHVlOiBhbnkgfT4oKTtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVmOiBDaGFuZ2VEZXRlY3RvclJlZixcclxuICApIHsgfVxyXG5cclxuICBvbkVkaXRvckNoYW5nZSA9IChjb2x1bW46IFNkR3JpZENvbHVtbiwgaXRlbTogR3JpZEl0ZW0sIHZhbHVlOiBhbnkpID0+IHtcclxuICAgIGlmIChjb2x1bW4udHlwZSAhPT0gJ2NoaWxkcmVuJykge1xyXG4gICAgICBjb2x1bW4uZWRpdG9yPy5jaGFuZ2U/LihpdGVtLCB2YWx1ZSk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvbkF1dG9jb21wbGV0ZUNoYW5nZSA9IChpdGVtOiBhbnkpID0+IHtcclxuICAgIGlmICh0aGlzLmNvbHVtbi50eXBlID09PSAnc3RyaW5nJyB8fCB0aGlzLmNvbHVtbi50eXBlID09PSAndmFsdWVzJykge1xyXG4gICAgICB0aGlzLmNvbHVtbi5lZGl0b3I/LmNoYW5nZT8uKHRoaXMuaXRlbSwgdGhpcy5pdGVtW3RoaXMuY29sdW1uLmZpZWxkXSwgaXRlbSk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvblNlbGVjdGlvbkNoYW5nZSA9IChwYXJhbXM6IHsgdmFsdWU6IGFueSwgaXRlbTogYW55LCBpdGVtczogYW55W10gfSkgPT4ge1xyXG4gICAgaWYgKHRoaXMuY29sdW1uLnR5cGUgPT09ICdzdHJpbmcnIHx8IHRoaXMuY29sdW1uLnR5cGUgPT09ICd2YWx1ZXMnKSB7XHJcbiAgICAgIHRoaXMuY29sdW1uLmVkaXRvcj8uY2hhbmdlPy4odGhpcy5pdGVtLCBwYXJhbXM/LnZhbHVlLCBwYXJhbXM/Lml0ZW0gfHwgcGFyYW1zPy5pdGVtcyk7XHJcbiAgICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgdGhpcy5zZENoYW5nZS5lbWl0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBkeW5hbWljSXRlbXMgPSBhc3luYyAodmFsdWU6IGFueSkgPT4ge1xyXG4gICAgaWYgKCdlZGl0b3InIGluIHRoaXMuY29sdW1uICYmICdpdGVtJyBpbiB0aGlzLmNvbHVtbi5lZGl0b3IpIHtcclxuICAgICAgY29uc3QgaXRlbXMgPSB0aGlzLmNvbHVtbi5lZGl0b3IuaXRlbS5pdGVtcyB8fCBbXTtcclxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoaXRlbXMpKSB7XHJcbiAgICAgICAgcmV0dXJuIGl0ZW1zO1xyXG4gICAgICB9XHJcbiAgICAgIGNvbnN0IHJlc3VsdHMgPSBpdGVtcyh0aGlzLml0ZW0sIHZhbHVlKTtcclxuICAgICAgaWYgKHJlc3VsdHMgaW5zdGFuY2VvZiBQcm9taXNlKSB7XHJcbiAgICAgICAgcmV0dXJuIGF3YWl0IHJlc3VsdHM7XHJcbiAgICAgIH1cclxuICAgICAgcmV0dXJuIHJlc3VsdHM7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gW107XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -16,7 +16,7 @@ export class SdGridDesktopInlineFilter {
16
16
  SdGridDesktopInlineFilter.decorators = [
17
17
  { type: Component, args: [{
18
18
  selector: 'sd-grid-desktop-inline-filter',
19
- template: "<ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <ng-container *ngIf=\"columns?.length && filterOption?.columnInline === 'outside'\">\r\n <ng-container *ngFor=\"let item of columns\">\r\n <ng-container\r\n *ngIf=\"item.type !== 'children' && item.type !== 'image' && !item?.filter?.disabled && item.priority !== 'low'\">\r\n <ng-container *ngIf=\"inlineColumn[item.field] || inlineColumn[item.field] === undefined\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"filter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-number [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"filter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-number>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"filter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"filter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select *ngIf=\"item.type === 'values' && !item?.editor?.autocomplete\" [label]=\"item.title\"\r\n [items]=\"item.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.type === 'values' && item?.editor?.autocomplete\" [items]=\"item.values\"\r\n valueField=\"value\" displayField=\"text\" [(model)]=\"filter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"item.type === 'date' || item.type === 'datetime' || item.type === 'time'\"\r\n [label]=\"item.title\" [(model)]=\"filter[item.field]\" type=\"date\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"item.type === 'children' && item.children?.length && !item?.filter?.disabled && item.priority !== 'low'\">\r\n <ng-container *ngFor=\"let childColumn of item.children\">\r\n <ng-container\r\n *ngIf=\"inlineColumn[childColumn.field] && !childColumn?.filter?.disabled && childColumn.priority !== 'low' && childColumn.type !== 'image'\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'string'\" type=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-number [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'number'\"\r\n [(model)]=\"filter[childColumn.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-number>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'bool'\" [items]=\"[{value:'1',display:childColumn.trueValue || 'True' },\r\n {value:'0',display:childColumn.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'radio'\" [items]=\"childColumn.values\"\r\n [valueField]=\"childColumn.valueField\" [displayField]=\"childColumn.displayField\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select *ngIf=\"childColumn.type === 'values' && !item?.editor?.autocomplete\"\r\n [label]=\"childColumn.title\" [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"childColumn.type === 'values' && item?.editor?.autocomplete\"\r\n [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-date-time\r\n *ngIf=\"childColumn.type === 'date' || childColumn.type === 'datetime' || childColumn.type === 'time'\"\r\n [label]=\"childColumn.title\" [(model)]=\"filter[childColumn.field]\" type=\"date\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterOption?.externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of filterOption.externalFilters\">\r\n <ng-container\r\n *ngIf=\"(inlineExternal[item.field] || inlineExternal[item.field] === undefined) && item.priority !== 'low'\">\r\n <div *ngIf=\"item.type !=='daterange' && item.type !=='numberrange';else elseFilterRange\"\r\n class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\"\r\n [(model)]=\"externalFilter[item.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-number [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-number>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'custom'\"\r\n [(model)]=\"externalFilter[displayKey + item.field]\"\r\n (sdFocusForceBlur)=\"item?.onClick(externalFilter, item.field, displayKey + item.field)\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <ng-container *ngIf=\"item.type === 'values'\">\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\" multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\" filtered=\"true\" multiple=\"true\">\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.selection\" [label]=\"item.title\" [items]=\"item.values\" [valueField]=\"item.valueField\"\r\n [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date'\" [(model)]=\"externalFilter[item.field]\"\r\n type=\"date\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterangefull'\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-range>\r\n </div>\r\n <ng-template #elseFilterRange>\r\n <ng-container *ngIf=\"item.type ==='daterange' && externalFilter[item.field]\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-date-time [label]=\"item.fromTitle\" [(model)]=\"externalFilter[item.field].from\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\" [minDate]=\"item.minDate\"\r\n [maxDate]=\"externalFilter[item.field].to || item.maxDate\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-date-time [label]=\"item.toTitle\" [(model)]=\"externalFilter[item.field].to\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\"\r\n [minDate]=\"item.minDate || externalFilter[item.field].from\" [maxDate]=\"item.maxDate\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.type ==='numberrange' && externalFilter[item.field]\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.fromTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].from\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n </div>\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.toTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].to\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n </div>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>",
19
+ template: "<ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <ng-container *ngIf=\"columns?.length && filterOption?.columnInline === 'outside'\">\r\n <ng-container *ngFor=\"let item of columns\">\r\n <ng-container\r\n *ngIf=\"item.type !== 'children' && item.type !== 'image' && !item?.filter?.disabled && item.priority !== 'low'\">\r\n <ng-container *ngIf=\"inlineColumn[item.field] || inlineColumn[item.field] === undefined\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"filter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-currency [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"filter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-currency>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"filter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"filter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select *ngIf=\"item.type === 'values' && !item?.editor?.autocomplete\" [label]=\"item.title\"\r\n [items]=\"item.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.type === 'values' && item?.editor?.autocomplete\" [items]=\"item.values\"\r\n valueField=\"value\" displayField=\"text\" [(model)]=\"filter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"item.type === 'date' || item.type === 'datetime' || item.type === 'time'\"\r\n [label]=\"item.title\" [(model)]=\"filter[item.field]\" type=\"date\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"item.type === 'children' && item.children?.length && !item?.filter?.disabled && item.priority !== 'low'\">\r\n <ng-container *ngFor=\"let childColumn of item.children\">\r\n <ng-container\r\n *ngIf=\"inlineColumn[childColumn.field] && !childColumn?.filter?.disabled && childColumn.priority !== 'low' && childColumn.type !== 'image'\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'string'\" type=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-currency [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'number'\"\r\n [(model)]=\"filter[childColumn.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-currency>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'bool'\" [items]=\"[{value:'1',display:childColumn.trueValue || 'True' },\r\n {value:'0',display:childColumn.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'radio'\" [items]=\"childColumn.values\"\r\n [valueField]=\"childColumn.valueField\" [displayField]=\"childColumn.displayField\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select *ngIf=\"childColumn.type === 'values' && !item?.editor?.autocomplete\"\r\n [label]=\"childColumn.title\" [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"childColumn.type === 'values' && item?.editor?.autocomplete\"\r\n [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-date-time\r\n *ngIf=\"childColumn.type === 'date' || childColumn.type === 'datetime' || childColumn.type === 'time'\"\r\n [label]=\"childColumn.title\" [(model)]=\"filter[childColumn.field]\" type=\"date\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"filterOption?.externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of filterOption.externalFilters\">\r\n <ng-container\r\n *ngIf=\"(inlineExternal[item.field] || inlineExternal[item.field] === undefined) && item.priority !== 'low'\">\r\n <div *ngIf=\"item.type !=='daterange' && item.type !=='numberrange';else elseFilterRange\"\r\n class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\"\r\n [(model)]=\"externalFilter[item.field]\" (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <sd-input-currency [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onUpdateFilter()\">\r\n </sd-input-currency>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'custom'\"\r\n [(model)]=\"externalFilter[displayKey + item.field]\"\r\n (sdFocusForceBlur)=\"item?.onClick(externalFilter, item.field, displayKey + item.field)\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n <ng-container *ngIf=\"item.type === 'values'\">\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\" multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n (sdChange)=\"onUpdateFilter()\" filtered=\"true\" multiple=\"true\">\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.selection\" [label]=\"item.title\" [items]=\"item.values\" [valueField]=\"item.valueField\"\r\n [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date'\" [(model)]=\"externalFilter[item.field]\"\r\n type=\"date\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterangefull'\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-range>\r\n </div>\r\n <ng-template #elseFilterRange>\r\n <ng-container *ngIf=\"item.type ==='daterange' && externalFilter[item.field]\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-date-time [label]=\"item.fromTitle\" [(model)]=\"externalFilter[item.field].from\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\" [minDate]=\"item.minDate\"\r\n [maxDate]=\"externalFilter[item.field].to || item.maxDate\" (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-date-time [label]=\"item.toTitle\" [(model)]=\"externalFilter[item.field].to\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\"\r\n [minDate]=\"item.minDate || externalFilter[item.field].from\" [maxDate]=\"item.maxDate\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-date-time>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"item.type ==='numberrange' && externalFilter[item.field]\">\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.fromTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].from\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n </div>\r\n <div class=\"col-lg-2 col-md-3 col-sm-6 px-4\">\r\n <sd-input [label]=\"item.toTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].to\"\r\n (sdChange)=\"onUpdateFilter()\">\r\n </sd-input>\r\n </div>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>",
20
20
  styles: [""]
21
21
  },] }
22
22
  ];
@@ -30,4 +30,4 @@ SdGridDesktopInlineFilter.propDecorators = {
30
30
  inlineColumn: [{ type: Input }],
31
31
  sdChange: [{ type: Output }]
32
32
  };
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2dyaWQtZGVza3RvcC1pbmxpbmUtZmlsdGVyL2dyaWQtZGVza3RvcC1pbmxpbmUtZmlsdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBU3ZFLE1BQU0sT0FBTyx5QkFBeUI7SUFjcEM7UUFiUyxZQUFPLEdBQW1CLEVBQUUsQ0FBQztRQUM3QixtQkFBYyxHQUFRLEVBQUUsQ0FBQztRQUN6QixXQUFNLEdBQVEsRUFBRSxDQUFDO1FBRWpCLG1CQUFjLEdBRW5CLEVBQUUsQ0FBQztRQUNFLGlCQUFZLEdBRWpCLEVBQUUsQ0FBQztRQUNHLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRXhDLGVBQVUsR0FBRyxVQUFVLENBQUM7UUFHeEIsbUJBQWMsR0FBRyxHQUFHLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDLENBQUE7SUFKZSxDQUFDOzs7WUFuQmxCLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsK0JBQStCO2dCQUN6QyxpeFZBQTBEOzthQUUzRDs7OztzQkFFRSxLQUFLOzZCQUNMLEtBQUs7cUJBQ0wsS0FBSzsyQkFDTCxLQUFLOzZCQUNMLEtBQUs7MkJBR0wsS0FBSzt1QkFHTCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IFNkR3JpZENvbHVtbiwgR3JpZEJhc2VPcHRpb25GaWx0ZXIgfSBmcm9tICcuLi8uLi9ncmlkLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9ncmlkLWRlc2t0b3AtaW5saW5lLWZpbHRlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RHcmlkRGVza3RvcElubGluZUZpbHRlciB7XHJcbiAgQElucHV0KCkgY29sdW1uczogU2RHcmlkQ29sdW1uW10gPSBbXTtcclxuICBASW5wdXQoKSBleHRlcm5hbEZpbHRlcjogYW55ID0ge307XHJcbiAgQElucHV0KCkgZmlsdGVyOiBhbnkgPSB7fTtcclxuICBASW5wdXQoKSBmaWx0ZXJPcHRpb246IEdyaWRCYXNlT3B0aW9uRmlsdGVyO1xyXG4gIEBJbnB1dCgpIGlubGluZUV4dGVybmFsOiB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBib29sZWFuO1xyXG4gIH0gPSB7fTtcclxuICBASW5wdXQoKSBpbmxpbmVDb2x1bW46IHtcclxuICAgIFtrZXk6IHN0cmluZ106IGJvb2xlYW47XHJcbiAgfSA9IHt9O1xyXG4gIEBPdXRwdXQoKSBzZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBpc0Rlc2t0b3A6IGJvb2xlYW47XHJcbiAgZGlzcGxheUtleSA9ICdTRENVU1RPTSc7XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgb25VcGRhdGVGaWx0ZXIgPSAoKSA9PiB7XHJcbiAgICB0aGlzLnNkQ2hhbmdlLmVtaXQoKTtcclxuICB9XHJcbn1cclxuIl19
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2dyaWQtZGVza3RvcC1pbmxpbmUtZmlsdGVyL2dyaWQtZGVza3RvcC1pbmxpbmUtZmlsdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBU3ZFLE1BQU0sT0FBTyx5QkFBeUI7SUFjcEM7UUFiUyxZQUFPLEdBQW1CLEVBQUUsQ0FBQztRQUM3QixtQkFBYyxHQUFRLEVBQUUsQ0FBQztRQUN6QixXQUFNLEdBQVEsRUFBRSxDQUFDO1FBRWpCLG1CQUFjLEdBRW5CLEVBQUUsQ0FBQztRQUNFLGlCQUFZLEdBRWpCLEVBQUUsQ0FBQztRQUNHLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRXhDLGVBQVUsR0FBRyxVQUFVLENBQUM7UUFHeEIsbUJBQWMsR0FBRyxHQUFHLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDLENBQUE7SUFKZSxDQUFDOzs7WUFuQmxCLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsK0JBQStCO2dCQUN6Qyw2eFZBQTBEOzthQUUzRDs7OztzQkFFRSxLQUFLOzZCQUNMLEtBQUs7cUJBQ0wsS0FBSzsyQkFDTCxLQUFLOzZCQUNMLEtBQUs7MkJBR0wsS0FBSzt1QkFHTCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IFNkR3JpZENvbHVtbiwgR3JpZEJhc2VPcHRpb25GaWx0ZXIgfSBmcm9tICcuLi8uLi9ncmlkLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9ncmlkLWRlc2t0b3AtaW5saW5lLWZpbHRlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZ3JpZC1kZXNrdG9wLWlubGluZS1maWx0ZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RHcmlkRGVza3RvcElubGluZUZpbHRlciB7XHJcbiAgQElucHV0KCkgY29sdW1uczogU2RHcmlkQ29sdW1uW10gPSBbXTtcclxuICBASW5wdXQoKSBleHRlcm5hbEZpbHRlcjogYW55ID0ge307XHJcbiAgQElucHV0KCkgZmlsdGVyOiBhbnkgPSB7fTtcclxuICBASW5wdXQoKSBmaWx0ZXJPcHRpb246IEdyaWRCYXNlT3B0aW9uRmlsdGVyO1xyXG4gIEBJbnB1dCgpIGlubGluZUV4dGVybmFsOiB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBib29sZWFuO1xyXG4gIH0gPSB7fTtcclxuICBASW5wdXQoKSBpbmxpbmVDb2x1bW46IHtcclxuICAgIFtrZXk6IHN0cmluZ106IGJvb2xlYW47XHJcbiAgfSA9IHt9O1xyXG4gIEBPdXRwdXQoKSBzZENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBpc0Rlc2t0b3A6IGJvb2xlYW47XHJcbiAgZGlzcGxheUtleSA9ICdTRENVU1RPTSc7XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgb25VcGRhdGVGaWx0ZXIgPSAoKSA9PiB7XHJcbiAgICB0aGlzLnNkQ2hhbmdlLmVtaXQoKTtcclxuICB9XHJcbn1cclxuIl19
@@ -35,7 +35,7 @@ export class SdGridPopupEditor {
35
35
  SdGridPopupEditor.decorators = [
36
36
  { type: Component, args: [{
37
37
  selector: 'sd-grid-popup-editor',
38
- template: "<sd-modal [title]=\"(isModified ? 'Edit' : 'Create')\" width=\"sm\" #modal>\r\n <sd-modal-body *ngIf=\"item && columns?.length\">\r\n <form #formEditor=\"ngForm\">\r\n <ng-container *ngFor=\"let column of columns\">\r\n <div *ngIf=\"column | editorPopupVisible:item\" class=\"row\">\r\n <div class=\"col-12\">\r\n <sd-input *ngIf=\"column.type === 'string'\" [(model)]=\"item[column.field]\"></sd-input>\r\n <sd-input-number *ngIf=\"column.type === 'number'\" [(model)]=\"item[column.field]\">\r\n </sd-input-number>\r\n <sd-select *ngIf=\"column.type === 'values'\" [(model)]=\"item[column.field]\" [items]=\"column.values\">\r\n </sd-select>\r\n <sd-switch *ngIf=\"column.type === 'boolean'\" [(model)]=\"item[column.field]\">\r\n </sd-switch>\r\n <sd-select *ngIf=\"column.type === 'radio'\" [(model)]=\"item[column.field]\" [items]=\"column.values\">\r\n </sd-select>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </form>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"onCancel()\" icon=\"close\" [title]=\"'Cancel' | sdTranslate\" size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"onSave()\" icon=\"save\" [title]=\"'Save' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"onCancel()\" icon=\"close\" [title]=\"'Cancel' | sdTranslate\"\r\n width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"onSave()\" icon=\"save\" [title]=\"'Save' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>"
38
+ template: "<sd-modal [title]=\"(isModified ? 'Edit' : 'Create')\" width=\"sm\" #modal>\r\n <sd-modal-body *ngIf=\"item && columns?.length\">\r\n <form #formEditor=\"ngForm\">\r\n <ng-container *ngFor=\"let column of columns\">\r\n <div *ngIf=\"column | editorPopupVisible:item\" class=\"row\">\r\n <div class=\"col-12\">\r\n <sd-input *ngIf=\"column.type === 'string'\" [(model)]=\"item[column.field]\"></sd-input>\r\n <sd-input-currency *ngIf=\"column.type === 'number'\" [(model)]=\"item[column.field]\">\r\n </sd-input-currency>\r\n <sd-select *ngIf=\"column.type === 'values'\" [(model)]=\"item[column.field]\" [items]=\"column.values\">\r\n </sd-select>\r\n <sd-switch *ngIf=\"column.type === 'boolean'\" [(model)]=\"item[column.field]\">\r\n </sd-switch>\r\n <sd-select *ngIf=\"column.type === 'radio'\" [(model)]=\"item[column.field]\" [items]=\"column.values\">\r\n </sd-select>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </form>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"onCancel()\" icon=\"close\" [title]=\"'Cancel' | sdTranslate\" size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"onSave()\" icon=\"save\" [title]=\"'Save' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"onCancel()\" icon=\"close\" [title]=\"'Cancel' | sdTranslate\"\r\n width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"onSave()\" icon=\"save\" [title]=\"'Save' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>"
39
39
  },] }
40
40
  ];
41
41
  SdGridPopupEditor.ctorParameters = () => [];
@@ -43,4 +43,4 @@ SdGridPopupEditor.propDecorators = {
43
43
  modal: [{ type: ViewChild, args: ['modal',] }],
44
44
  save: [{ type: Output }]
45
45
  };
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1wb3B1cC1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2dyaWQtcG9wdXAtZWRpdG9yL2dyaWQtcG9wdXAtZWRpdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFNBQVMsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUW5GLE1BQU0sT0FBTyxpQkFBaUI7SUFRNUI7UUFMVSxTQUFJLEdBQUcsSUFBSSxZQUFZLEVBQVksQ0FBQztRQUM5QyxZQUFPLEdBQW1CLEVBQUUsQ0FBQztRQVM3QixTQUFJLEdBQUcsQ0FBQyxJQUFjLEVBQUUsT0FBdUIsRUFBRSxVQUFvQixFQUFFLEVBQUU7WUFDdkUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7WUFDakIsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLGFBQVYsVUFBVSxjQUFWLFVBQVUsR0FBSSxLQUFLLENBQUM7WUFDdEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7WUFDbEIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRTs7Z0JBQ3ZCLElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxPQUFPLElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxVQUFVLEVBQUU7b0JBQ3pELElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2lCQUMzQjtnQkFDRCxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssVUFBVSxFQUFFO29CQUM5QixNQUFBLE1BQU0sQ0FBQyxRQUFRLDBDQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRTt3QkFDckMsSUFBSSxXQUFXLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTs0QkFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7eUJBQ2hDO29CQUNILENBQUMsRUFBRTtpQkFDSjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFBO1FBRUQsYUFBUSxHQUFHLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFBO1FBRUQsV0FBTSxHQUFHLEdBQUcsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQTtJQTlCZSxDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDOzs7WUFmRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtnQkFDaEMsZzJEQUFpRDthQUNsRDs7OztvQkFHRSxTQUFTLFNBQUMsT0FBTzttQkFDakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBWaWV3Q2hpbGQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkTW9kYWwgfSBmcm9tICdAc2QtYW5ndWxhci9jb3JlL21vZGFsJztcclxuaW1wb3J0IHsgU2RHcmlkT3B0aW9uLCBTZEdyaWRDb2x1bW4sIEdyaWRJdGVtIH0gZnJvbSAnLi4vLi4vZ3JpZC5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NkLWdyaWQtcG9wdXAtZWRpdG9yJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZ3JpZC1wb3B1cC1lZGl0b3IuY29tcG9uZW50Lmh0bWwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZEdyaWRQb3B1cEVkaXRvciBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ21vZGFsJykgbW9kYWw6IFNkTW9kYWw7XHJcbiAgQE91dHB1dCgpIHNhdmUgPSBuZXcgRXZlbnRFbWl0dGVyPEdyaWRJdGVtPigpO1xyXG4gIGNvbHVtbnM6IFNkR3JpZENvbHVtbltdID0gW107XHJcbiAgZ3JpZE9wdGlvbjogU2RHcmlkT3B0aW9uO1xyXG4gIGl0ZW06IEdyaWRJdGVtO1xyXG4gIGlzTW9kaWZpZWQ6IGJvb2xlYW47XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG5cclxuICBvcGVuID0gKGl0ZW06IEdyaWRJdGVtLCBjb2x1bW5zOiBTZEdyaWRDb2x1bW5bXSwgaXNNb2RpZmllZD86IGJvb2xlYW4pID0+IHtcclxuICAgIHRoaXMuaXRlbSA9IGl0ZW07XHJcbiAgICB0aGlzLmlzTW9kaWZpZWQgPSBpc01vZGlmaWVkID8/IGZhbHNlO1xyXG4gICAgdGhpcy5jb2x1bW5zID0gW107XHJcbiAgICBjb2x1bW5zLmZvckVhY2goY29sdW1uID0+IHtcclxuICAgICAgaWYgKGNvbHVtbi50eXBlICE9PSAnaW1hZ2UnICYmIGNvbHVtbi50eXBlICE9PSAnY2hpbGRyZW4nKSB7XHJcbiAgICAgICAgdGhpcy5jb2x1bW5zLnB1c2goY29sdW1uKTtcclxuICAgICAgfVxyXG4gICAgICBpZiAoY29sdW1uLnR5cGUgPT09ICdjaGlsZHJlbicpIHtcclxuICAgICAgICBjb2x1bW4uY2hpbGRyZW4/LmZvckVhY2goY2hpbGRDb2x1bW4gPT4ge1xyXG4gICAgICAgICAgaWYgKGNoaWxkQ29sdW1uLnR5cGUgIT09ICdpbWFnZScpIHtcclxuICAgICAgICAgICAgdGhpcy5jb2x1bW5zLnB1c2goY2hpbGRDb2x1bW4pO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIG9uQ2FuY2VsID0gKCkgPT4ge1xyXG4gICAgdGhpcy5tb2RhbC5jbG9zZSgpO1xyXG4gIH1cclxuXHJcbiAgb25TYXZlID0gKCkgPT4ge1xyXG4gICAgdGhpcy5tb2RhbC5jbG9zZSgpO1xyXG4gICAgdGhpcy5zYXZlLmVtaXQodGhpcy5pdGVtKTtcclxuICB9XHJcbn1cclxuIl19
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1wb3B1cC1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2dyaWQtcG9wdXAtZWRpdG9yL2dyaWQtcG9wdXAtZWRpdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFNBQVMsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBUW5GLE1BQU0sT0FBTyxpQkFBaUI7SUFRNUI7UUFMVSxTQUFJLEdBQUcsSUFBSSxZQUFZLEVBQVksQ0FBQztRQUM5QyxZQUFPLEdBQW1CLEVBQUUsQ0FBQztRQVM3QixTQUFJLEdBQUcsQ0FBQyxJQUFjLEVBQUUsT0FBdUIsRUFBRSxVQUFvQixFQUFFLEVBQUU7WUFDdkUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7WUFDakIsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLGFBQVYsVUFBVSxjQUFWLFVBQVUsR0FBSSxLQUFLLENBQUM7WUFDdEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7WUFDbEIsT0FBTyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBRTs7Z0JBQ3ZCLElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxPQUFPLElBQUksTUFBTSxDQUFDLElBQUksS0FBSyxVQUFVLEVBQUU7b0JBQ3pELElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2lCQUMzQjtnQkFDRCxJQUFJLE1BQU0sQ0FBQyxJQUFJLEtBQUssVUFBVSxFQUFFO29CQUM5QixNQUFBLE1BQU0sQ0FBQyxRQUFRLDBDQUFFLE9BQU8sQ0FBQyxXQUFXLENBQUMsRUFBRTt3QkFDckMsSUFBSSxXQUFXLENBQUMsSUFBSSxLQUFLLE9BQU8sRUFBRTs0QkFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7eUJBQ2hDO29CQUNILENBQUMsRUFBRTtpQkFDSjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFBO1FBRUQsYUFBUSxHQUFHLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDckIsQ0FBQyxDQUFBO1FBRUQsV0FBTSxHQUFHLEdBQUcsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQTtJQTlCZSxDQUFDO0lBRWpCLFFBQVE7SUFDUixDQUFDOzs7WUFmRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHNCQUFzQjtnQkFDaEMsbzJEQUFpRDthQUNsRDs7OztvQkFHRSxTQUFTLFNBQUMsT0FBTzttQkFDakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBWaWV3Q2hpbGQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFNkTW9kYWwgfSBmcm9tICdAc2QtYW5ndWxhci9jb3JlL21vZGFsJztcclxuaW1wb3J0IHsgU2RHcmlkT3B0aW9uLCBTZEdyaWRDb2x1bW4sIEdyaWRJdGVtIH0gZnJvbSAnLi4vLi4vZ3JpZC5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NkLWdyaWQtcG9wdXAtZWRpdG9yJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZ3JpZC1wb3B1cC1lZGl0b3IuY29tcG9uZW50Lmh0bWwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZEdyaWRQb3B1cEVkaXRvciBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ21vZGFsJykgbW9kYWw6IFNkTW9kYWw7XHJcbiAgQE91dHB1dCgpIHNhdmUgPSBuZXcgRXZlbnRFbWl0dGVyPEdyaWRJdGVtPigpO1xyXG4gIGNvbHVtbnM6IFNkR3JpZENvbHVtbltdID0gW107XHJcbiAgZ3JpZE9wdGlvbjogU2RHcmlkT3B0aW9uO1xyXG4gIGl0ZW06IEdyaWRJdGVtO1xyXG4gIGlzTW9kaWZpZWQ6IGJvb2xlYW47XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgfVxyXG5cclxuICBvcGVuID0gKGl0ZW06IEdyaWRJdGVtLCBjb2x1bW5zOiBTZEdyaWRDb2x1bW5bXSwgaXNNb2RpZmllZD86IGJvb2xlYW4pID0+IHtcclxuICAgIHRoaXMuaXRlbSA9IGl0ZW07XHJcbiAgICB0aGlzLmlzTW9kaWZpZWQgPSBpc01vZGlmaWVkID8/IGZhbHNlO1xyXG4gICAgdGhpcy5jb2x1bW5zID0gW107XHJcbiAgICBjb2x1bW5zLmZvckVhY2goY29sdW1uID0+IHtcclxuICAgICAgaWYgKGNvbHVtbi50eXBlICE9PSAnaW1hZ2UnICYmIGNvbHVtbi50eXBlICE9PSAnY2hpbGRyZW4nKSB7XHJcbiAgICAgICAgdGhpcy5jb2x1bW5zLnB1c2goY29sdW1uKTtcclxuICAgICAgfVxyXG4gICAgICBpZiAoY29sdW1uLnR5cGUgPT09ICdjaGlsZHJlbicpIHtcclxuICAgICAgICBjb2x1bW4uY2hpbGRyZW4/LmZvckVhY2goY2hpbGRDb2x1bW4gPT4ge1xyXG4gICAgICAgICAgaWYgKGNoaWxkQ29sdW1uLnR5cGUgIT09ICdpbWFnZScpIHtcclxuICAgICAgICAgICAgdGhpcy5jb2x1bW5zLnB1c2goY2hpbGRDb2x1bW4pO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIG9uQ2FuY2VsID0gKCkgPT4ge1xyXG4gICAgdGhpcy5tb2RhbC5jbG9zZSgpO1xyXG4gIH1cclxuXHJcbiAgb25TYXZlID0gKCkgPT4ge1xyXG4gICAgdGhpcy5tb2RhbC5jbG9zZSgpO1xyXG4gICAgdGhpcy5zYXZlLmVtaXQodGhpcy5pdGVtKTtcclxuICB9XHJcbn1cclxuIl19
@@ -290,7 +290,7 @@ _loadConfiguration = new WeakMap();
290
290
  SdGridPopupFilter.decorators = [
291
291
  { type: Component, args: [{
292
292
  selector: 'sd-grid-popup-filter',
293
- template: "<sd-modal width=\"sm\" [title]=\"'Filter' | sdTranslate\" #modal>\r\n <sd-modal-body>\r\n <div\r\n *ngIf=\"key && filterOption?.multiple !== false && (!filterOption?.quickFilterVisibility || filterOption?.quickFilterVisibility === 'popup')\">\r\n <mat-form-field class=\"sd-md\" appearance=\"outline\">\r\n <mat-label>{{'Quick filters' | sdTranslate}}</mat-label>\r\n <mat-select [(ngModel)]=\"selectedCode\" (selectionChange)=\"onSelectionChange($event)\" #matSelect>\r\n <mat-option value=\"\">{{'Please select' | sdTranslate}}</mat-option>\r\n <mat-option *ngFor=\"let quickFilter of quickFilters\" [value]=\"quickFilter.code\">\r\n <div style=\"display:flex; justify-content: space-between\">\r\n <span>{{quickFilter.code}}</span>\r\n <div>\r\n <mat-icon class=\"mr-1 c-fa-icon\" (click)=\"onEditQuickFilter($event, quickFilter)\" fontSet=\"fa\"\r\n fontIcon=\"fa-pencil\"></mat-icon>\r\n <mat-icon class=\"mr-0 c-fa-icon\" (click)=\"onDeleteQuickFilter($event, quickFilter)\" fontSet=\"fa\"\r\n fontIcon=\"fa-trash-o\"></mat-icon>\r\n </div>\r\n </div>\r\n </mat-option>\r\n <mat-option [value]=\"newQuickFilter\">\r\n <div (click)=\"onCreateQuickFilter($event)\">\r\n <mat-icon class=\"mr-1\" fontSet=\"material-icons-outlined\">add</mat-icon>\r\n <span>{{'Create quick filter' | sdTranslate}}</span>\r\n </div>\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <ng-container *ngIf=\"filterOption?.multiple === false\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{'Select field' | sdTranslate}}</mat-label>\r\n <mat-select [(ngModel)]=\"selectedField\">\r\n <mat-option value=\"\">{{'Please select' | sdTranslate}}</mat-option>\r\n <mat-option *ngFor=\"let item of externalFilters\" [value]=\"'external' + item.field\">\r\n {{item.title}}\r\n </mat-option>\r\n <ng-container *ngFor=\"let item of columns\">\r\n <mat-option *ngIf=\"item.type !== 'children'\" [value]=\"'column' + item.field\">\r\n {{item.title}}\r\n </mat-option>\r\n <ng-container *ngIf=\"item.type === 'children' && item.children?.length\">\r\n <ng-container *ngFor=\"let childColumn of item.children\">\r\n <mat-option [value]=\"'column' + childColumn.field\">\r\n {{childColumn.title}}\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of externalFilters\">\r\n <div *ngIf=\"filterOption?.multiple !== false || selectedField === 'external' + item.field\"\r\n class=\"d-flex align-items-baseline\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineExternal[item.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\"\r\n [(model)]=\"externalFilter[item.field]\">\r\n </sd-input>\r\n <sd-input-number [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-input-number>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\" [{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n <ng-container *ngIf=\"item.type === 'values'\">\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n filtered=\"true\" multiple=\"true\">\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.selection\" [label]=\"item.title\" [items]=\"item.values\" [valueField]=\"item.valueField\"\r\n [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-input *ngIf=\"item.type === 'custom'\" [label]=\"item.title\"\r\n [(model)]=\"externalFilter[displayKey + item.field]\"\r\n (sdFocusForceBlur)=\"item?.onClick(externalFilter, item.field, displayKey + item.field)\">\r\n </sd-input>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date'\" [(model)]=\"externalFilter[item.field]\"\r\n type=\"date\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterangefull'\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\">\r\n </sd-date-range>\r\n <ng-container *ngIf=\"item.type ==='daterange'\">\r\n <div class=\"row\">\r\n <div class=\"col-6\">\r\n <sd-date-time [label]=\"item.fromTitle\" [(model)]=\"externalFilter[item.field].from\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\" [minDate]=\"item.minDate\"\r\n [maxDate]=\"externalFilter[item.field].to || item.maxDate\">\r\n </sd-date-time>\r\n </div>\r\n <div class=\"col-6\">\r\n <sd-date-time [label]=\"item.toTitle\" [(model)]=\"externalFilter[item.field].to\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\"\r\n [minDate]=\"item.minDate || externalFilter[item.field].from\" [maxDate]=\"item.maxDate\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"row\" *ngIf=\"item.type ==='numberrange'\">\r\n <div class=\"col-6\">\r\n <sd-input [label]=\"item.fromTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].from\">\r\n </sd-input>\r\n </div>\r\n <div class=\"col-6\">\r\n <sd-input [label]=\"item.toTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].to\">\r\n </sd-input>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of columns\">\r\n <div class=\"d-flex align-items-baseline\"\r\n *ngIf=\"column.type !== 'children' && (filterOption?.multiple !== false || selectedField === 'column' + column.field)\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineColumn[column.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input *ngIf=\"column.type === 'string'\" [label]=\"column.title\" type=\"text\"\r\n [(model)]=\"filter[column.field]\">\r\n </sd-input>\r\n <sd-input *ngIf=\"column.type === 'number'\" [label]=\"column.title\" type=\" number\"\r\n [(model)]=\"filter[column.field]\">\r\n </sd-input>\r\n <sd-select *ngIf=\"column.type === 'bool'\" [label]=\"column.title\" [items]=\"[{value:'1',display:column.trueValue || 'True' },\r\n {value:'0',display:column.falseValue || 'False' }]\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-select *ngIf=\"column.type === 'radio'\" [label]=\"column.title\" [items]=\"column.values\"\r\n [valueField]=\"column.valueField\" [displayField]=\"column.displayField\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-select *ngIf=\"column.type === 'values' && !column?.editor?.autocomplete\" [label]=\"column.title\"\r\n [items]=\"column.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.type === 'values' && column?.editor?.autocomplete\" [label]=\"column.title\"\r\n [items]=\"column.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[column.field]\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"column.type ==='date' || column.type==='datetime' ||\r\n column.type==='time'\" [label]=\"column.title\" [(model)]=\" filter[column.field]\" type=\"date\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"column.type === 'children' && column.children?.length\">\r\n <ng-container *ngFor=\"let childColumn of column.children\">\r\n <div class=\"d-flex align-items-baseline\"\r\n *ngIf=\"filterOption?.multiple !== false || selectedField === 'column' + childColumn.field\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineColumn[childColumn.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'string'\" type=\"text\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-input>\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'number'\" type=\" number\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-input>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'bool'\" [items]=\"[{value:'1',display:column.trueValue || 'True' },\r\n {value:'0',display:childColumn.falseValue || 'False' }]\" [(model)]=\"filter[childColumn.field]\">\r\n </sd-select>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'radio'\" [items]=\"childColumn.values\"\r\n [valueField]=\"childColumn.valueField\" [displayField]=\"childColumn.displayField\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-select>\r\n <sd-autocomplete [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'values'\"\r\n [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-autocomplete>\r\n <sd-date-time [label]=\"childColumn.title\" *ngIf=\"childColumn.type ==='date' || childColumn.type==='datetime' ||\r\n childColumn.type==='time'\" [(model)]=\" filter[childColumn.field]\" type=\"date\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"onClear()\" icon=\"clear\" [title]=\"'Clear filter' | sdTranslate\" size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"onAccept()\" icon=\"done\" [title]=\"'Accept' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"onClear()\" icon=\"clear\"\r\n [title]=\"'Clear filter' | sdTranslate\" width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"onAccept()\" icon=\"done\" [title]=\"'Accept' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>\r\n<sd-grid-popup-quick-filter-detail #popupQuickFilterDetail (accept)=\"onAcceptQuickFilter($event)\">\r\n</sd-grid-popup-quick-filter-detail>",
293
+ template: "<sd-modal width=\"sm\" [title]=\"'Filter' | sdTranslate\" #modal>\r\n <sd-modal-body>\r\n <div\r\n *ngIf=\"key && filterOption?.multiple !== false && (!filterOption?.quickFilterVisibility || filterOption?.quickFilterVisibility === 'popup')\">\r\n <mat-form-field class=\"sd-md\" appearance=\"outline\">\r\n <mat-label>{{'Quick filters' | sdTranslate}}</mat-label>\r\n <mat-select [(ngModel)]=\"selectedCode\" (selectionChange)=\"onSelectionChange($event)\" #matSelect>\r\n <mat-option value=\"\">{{'Please select' | sdTranslate}}</mat-option>\r\n <mat-option *ngFor=\"let quickFilter of quickFilters\" [value]=\"quickFilter.code\">\r\n <div style=\"display:flex; justify-content: space-between\">\r\n <span>{{quickFilter.code}}</span>\r\n <div>\r\n <mat-icon class=\"mr-1 c-fa-icon\" (click)=\"onEditQuickFilter($event, quickFilter)\" fontSet=\"fa\"\r\n fontIcon=\"fa-pencil\"></mat-icon>\r\n <mat-icon class=\"mr-0 c-fa-icon\" (click)=\"onDeleteQuickFilter($event, quickFilter)\" fontSet=\"fa\"\r\n fontIcon=\"fa-trash-o\"></mat-icon>\r\n </div>\r\n </div>\r\n </mat-option>\r\n <mat-option [value]=\"newQuickFilter\">\r\n <div (click)=\"onCreateQuickFilter($event)\">\r\n <mat-icon class=\"mr-1\" fontSet=\"material-icons-outlined\">add</mat-icon>\r\n <span>{{'Create quick filter' | sdTranslate}}</span>\r\n </div>\r\n </mat-option>\r\n </mat-select>\r\n </mat-form-field>\r\n </div>\r\n <ng-container *ngIf=\"filterOption?.multiple === false\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-label>{{'Select field' | sdTranslate}}</mat-label>\r\n <mat-select [(ngModel)]=\"selectedField\">\r\n <mat-option value=\"\">{{'Please select' | sdTranslate}}</mat-option>\r\n <mat-option *ngFor=\"let item of externalFilters\" [value]=\"'external' + item.field\">\r\n {{item.title}}\r\n </mat-option>\r\n <ng-container *ngFor=\"let item of columns\">\r\n <mat-option *ngIf=\"item.type !== 'children'\" [value]=\"'column' + item.field\">\r\n {{item.title}}\r\n </mat-option>\r\n <ng-container *ngIf=\"item.type === 'children' && item.children?.length\">\r\n <ng-container *ngFor=\"let childColumn of item.children\">\r\n <mat-option [value]=\"'column' + childColumn.field\">\r\n {{childColumn.title}}\r\n </mat-option>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </mat-select>\r\n </mat-form-field>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of externalFilters\">\r\n <div *ngIf=\"filterOption?.multiple !== false || selectedField === 'external' + item.field\"\r\n class=\"d-flex align-items-baseline\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineExternal[item.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\"\r\n [(model)]=\"externalFilter[item.field]\">\r\n </sd-input>\r\n <sd-input-currency [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-input-currency>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\" [{value:'1',display:item.trueValue || 'True' },\r\n {value:'0',display:item.falseValue || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'radio'\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n <ng-container *ngIf=\"item.type === 'values'\">\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n multiple=\"true\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\" [items]=\"item.values\"\r\n [valueField]=\"item.valueField\" [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\"\r\n filtered=\"true\" multiple=\"true\">\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.selection\" [label]=\"item.title\" [items]=\"item.values\" [valueField]=\"item.valueField\"\r\n [displayField]=\"item.displayField\" [(model)]=\"externalFilter[item.field]\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-input *ngIf=\"item.type === 'custom'\" [label]=\"item.title\"\r\n [(model)]=\"externalFilter[displayKey + item.field]\"\r\n (sdFocusForceBlur)=\"item?.onClick(externalFilter, item.field, displayKey + item.field)\">\r\n </sd-input>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date'\" [(model)]=\"externalFilter[item.field]\"\r\n type=\"date\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterangefull'\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\">\r\n </sd-date-range>\r\n <ng-container *ngIf=\"item.type ==='daterange'\">\r\n <div class=\"row\">\r\n <div class=\"col-6\">\r\n <sd-date-time [label]=\"item.fromTitle\" [(model)]=\"externalFilter[item.field].from\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\" [minDate]=\"item.minDate\"\r\n [maxDate]=\"externalFilter[item.field].to || item.maxDate\">\r\n </sd-date-time>\r\n </div>\r\n <div class=\"col-6\">\r\n <sd-date-time [label]=\"item.toTitle\" [(model)]=\"externalFilter[item.field].to\"\r\n [type]=\"item.enableTime ? 'datetime' : 'date'\"\r\n [minDate]=\"item.minDate || externalFilter[item.field].from\" [maxDate]=\"item.maxDate\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <div class=\"row\" *ngIf=\"item.type ==='numberrange'\">\r\n <div class=\"col-6\">\r\n <sd-input [label]=\"item.fromTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].from\">\r\n </sd-input>\r\n </div>\r\n <div class=\"col-6\">\r\n <sd-input [label]=\"item.toTitle\" type=\" number\" [(model)]=\"externalFilter[item.field].to\">\r\n </sd-input>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngFor=\"let column of columns\">\r\n <div class=\"d-flex align-items-baseline\"\r\n *ngIf=\"column.type !== 'children' && (filterOption?.multiple !== false || selectedField === 'column' + column.field)\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineColumn[column.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input *ngIf=\"column.type === 'string'\" [label]=\"column.title\" type=\"text\"\r\n [(model)]=\"filter[column.field]\">\r\n </sd-input>\r\n <sd-input *ngIf=\"column.type === 'number'\" [label]=\"column.title\" type=\" number\"\r\n [(model)]=\"filter[column.field]\">\r\n </sd-input>\r\n <sd-select *ngIf=\"column.type === 'bool'\" [label]=\"column.title\" [items]=\"[{value:'1',display:column.trueValue || 'True' },\r\n {value:'0',display:column.falseValue || 'False' }]\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-select *ngIf=\"column.type === 'radio'\" [label]=\"column.title\" [items]=\"column.values\"\r\n [valueField]=\"column.valueField\" [displayField]=\"column.displayField\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-select *ngIf=\"column.type === 'values' && !column?.editor?.autocomplete\" [label]=\"column.title\"\r\n [items]=\"column.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[column.field]\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"column.type === 'values' && column?.editor?.autocomplete\" [label]=\"column.title\"\r\n [items]=\"column.values\" valueField=\"value\" displayField=\"text\" [(model)]=\"filter[column.field]\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"column.type ==='date' || column.type==='datetime' ||\r\n column.type==='time'\" [label]=\"column.title\" [(model)]=\" filter[column.field]\" type=\"date\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n <ng-container *ngIf=\"column.type === 'children' && column.children?.length\">\r\n <ng-container *ngFor=\"let childColumn of column.children\">\r\n <div class=\"d-flex align-items-baseline\"\r\n *ngIf=\"filterOption?.multiple !== false || selectedField === 'column' + childColumn.field\">\r\n <ng-container *ngIf=\"filterOption?.multiple !== false\">\r\n <div *sdDesktop class=\"c-checkable\">\r\n <sd-switch [(model)]=\"inlineColumn[childColumn.field]\" (sdChange)=\"onInlineChange()\">\r\n </sd-switch>\r\n </div>\r\n </ng-container>\r\n <div class=\"c-filterable\">\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'string'\" type=\"text\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-input>\r\n <sd-input [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'number'\" type=\" number\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-input>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'bool'\" [items]=\"[{value:'1',display:column.trueValue || 'True' },\r\n {value:'0',display:childColumn.falseValue || 'False' }]\" [(model)]=\"filter[childColumn.field]\">\r\n </sd-select>\r\n <sd-select [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'radio'\" [items]=\"childColumn.values\"\r\n [valueField]=\"childColumn.valueField\" [displayField]=\"childColumn.displayField\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-select>\r\n <sd-autocomplete [label]=\"childColumn.title\" *ngIf=\"childColumn.type === 'values'\"\r\n [items]=\"childColumn.values\" valueField=\"value\" displayField=\"text\"\r\n [(model)]=\"filter[childColumn.field]\">\r\n </sd-autocomplete>\r\n <sd-date-time [label]=\"childColumn.title\" *ngIf=\"childColumn.type ==='date' || childColumn.type==='datetime' ||\r\n childColumn.type==='time'\" [(model)]=\" filter[childColumn.field]\" type=\"date\">\r\n </sd-date-time>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </sd-modal-body>\r\n <sd-modal-footer *sdDesktop>\r\n <sd-button class=\"mr-auto\" (action)=\"onClear()\" icon=\"clear\" [title]=\"'Clear filter' | sdTranslate\" size=\"sm\">\r\n </sd-button>\r\n <sd-button (action)=\"onAccept()\" icon=\"done\" [title]=\"'Accept' | sdTranslate\" color=\"primary\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n <sd-modal-footer *sdMobileTablet>\r\n <sd-button style=\"flex: 1; padding-right: 5px;\" (action)=\"onClear()\" icon=\"clear\"\r\n [title]=\"'Clear filter' | sdTranslate\" width=\"100%\" size=\"sm\"></sd-button>\r\n <sd-button style=\"flex: 1; padding-left: 5px;\" (action)=\"onAccept()\" icon=\"done\" [title]=\"'Accept' | sdTranslate\"\r\n color=\"primary\" width=\"100%\" size=\"sm\"></sd-button>\r\n </sd-modal-footer>\r\n</sd-modal>\r\n<sd-grid-popup-quick-filter-detail #popupQuickFilterDetail (accept)=\"onAcceptQuickFilter($event)\">\r\n</sd-grid-popup-quick-filter-detail>",
294
294
  encapsulation: ViewEncapsulation.None,
295
295
  styles: [".c-fa-icon{color:grey;font-size:20px}.c-checkable{width:50px}.c-filterable{flex:1}"]
296
296
  },] }
@@ -314,4 +314,4 @@ SdGridPopupFilter.propDecorators = {
314
314
  inlineExternal: [{ type: Input }],
315
315
  inlineColumn: [{ type: Input }]
316
316
  };
317
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-popup-filter.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-popup-filter/grid-popup-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable-next-line:max-line-length\r\nimport { Component, OnInit, AfterViewInit, ViewChild, Output, EventEmitter, Input, ChangeDetectorRef, ViewEncapsulation } from '@angular/core';\r\nimport { SdGridColumn, SdGridExternalFilter, GridBaseOptionFilter } from '../../grid.model';\r\nimport { QuickFilter, FilterConfiguration } from './grid-popup-filter.model';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdSettingService\r\n} from '@sd-angular/core/setting';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdGridPopupQuickFilterDetail } from '../grid-popup-quick-filter-detail/grid-popup-quick-filter-detail.component';\r\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\n\r\n@Component({\r\n  selector: 'sd-grid-popup-filter',\r\n  templateUrl: './grid-popup-filter.component.html',\r\n  styleUrls: ['./grid-popup-filter.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SdGridPopupFilter implements OnInit, AfterViewInit {\r\n  private keyPrefix = 'PopupFilter';\r\n  displayKey = 'SDCUSTOM';\r\n  isMobileOrTablet = false;\r\n  @ViewChild('modal') modal: SdModal;\r\n  @ViewChild('popupQuickFilterDetail') popupQuickFilterDetail: SdGridPopupQuickFilterDetail;\r\n  @ViewChild('matSelect') matSelect: MatSelect;\r\n  @Input() key = '';\r\n  @Input() filterOption: GridBaseOptionFilter;\r\n  @Output() accept = new EventEmitter<{ filter: any, externalFilter: any }>();\r\n  @Output() clear = new EventEmitter<void>();\r\n  @Output() loadInlineFilter = new EventEmitter<FilterConfiguration>();\r\n  selectedField: string;\r\n  newQuickFilter = 'e1ef1d43-d689-424f-959e-e6cd154cfee7';\r\n  filter: any = {};\r\n  externalFilter: any = {};\r\n  columns: SdGridColumn[] = [];\r\n  externalFilters: SdGridExternalFilter[] = [];\r\n  quickFilters: QuickFilter[] = [];\r\n  selectedCode: string;\r\n  maxQuickFilters = 5;\r\n  @Input() inlineExternal: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  @Input() inlineColumn: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    deviceService: DeviceDetectorService,\r\n    private settingService: SdSettingService,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService\r\n  ) {\r\n    this.isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#loadConfiguration().then(() => {\r\n      this.loadInlineFilter.emit({\r\n        quickFilters: this.quickFilters || [],\r\n        selectedQuickFilter: this.selectedCode || '',\r\n        inlineExternal: this.inlineExternal,\r\n        inlineColumn: this.inlineColumn\r\n      });\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n  }\r\n\r\n  open = (\r\n    fixedColums: SdGridColumn[],\r\n    normalColumns: SdGridColumn[],\r\n    filter: any,\r\n    externalFilter: any,\r\n    externalFilters?: SdGridExternalFilter[]) => {\r\n    this.init(fixedColums, normalColumns, filter, externalFilter, externalFilters);\r\n    this.modal.open();\r\n  }\r\n\r\n  init = (\r\n    fixedColums: SdGridColumn[],\r\n    normalColumns: SdGridColumn[],\r\n    filter: any,\r\n    externalFilter: any,\r\n    externalFilters?: SdGridExternalFilter[]) => {\r\n    this.columns = [...fixedColums, ...normalColumns].filter(e => !e.filter?.disabled && e.type !== 'image');\r\n    this.columns.forEach(column => {\r\n      if (column.type === 'children') {\r\n        column.children = column.children.filter(e => !e.filter?.disabled && e.type !== 'image');\r\n      }\r\n    });\r\n    if (externalFilters) {\r\n      this.externalFilters = externalFilters.filter(e => !e.disabled);\r\n    } else {\r\n      this.externalFilters = [];\r\n    }\r\n    this.filter = filter;\r\n    this.externalFilter = this.initExternalFilter(externalFilters, externalFilter);\r\n    for (const eFilter of this.externalFilters) {\r\n      if (this.inlineExternal[eFilter.field] === undefined) {\r\n        this.inlineExternal[eFilter.field] = true;\r\n      }\r\n    }\r\n    for (const column of this.columns) {\r\n      if (this.inlineColumn[column.field] === undefined) {\r\n        this.inlineColumn[column.field] = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  close = () => {\r\n    this.modal.close();\r\n  }\r\n\r\n  onAccept() {\r\n    if (this.filterOption?.multiple === false) {\r\n      if (this.selectedField) {\r\n        if (this.selectedField.startsWith('column')) {\r\n          const field = this.selectedField.replace('column', '');\r\n          this.accept.emit({\r\n            filter: {\r\n              [field]: this.filter[field]\r\n            },\r\n            externalFilter: {}\r\n          });\r\n        } else if (this.selectedField.startsWith('external')) {\r\n          const field = this.selectedField.replace('external', '');\r\n          this.accept.emit({\r\n            filter: {},\r\n            externalFilter: this.initExternalFilter(this.externalFilters, {\r\n              [field]: this.externalFilter[field]\r\n            })\r\n          });\r\n        }\r\n      }\r\n    } else {\r\n      this.accept.emit({\r\n        filter: this.filter,\r\n        externalFilter: this.externalFilter\r\n      });\r\n    }\r\n    this.modal.close();\r\n  }\r\n\r\n  onClear() {\r\n    delete this.selectedCode;\r\n    this.clear.emit();\r\n  }\r\n\r\n  #loadConfiguration = async () => {\r\n    this.quickFilters = [];\r\n    if (!this.key) {\r\n      return;\r\n    }\r\n    const { get, has } = this.settingService.create<FilterConfiguration>({\r\n      prefix: this.keyPrefix,\r\n      key: this.key\r\n    });\r\n    if (!await has()) {\r\n      return;\r\n    }\r\n    const configuration = await get();\r\n    if (Array.isArray(configuration?.quickFilters)) {\r\n      this.quickFilters = configuration.quickFilters;\r\n    }\r\n    this.selectedCode = configuration?.selectedQuickFilter || '';\r\n    this.inlineExternal = configuration?.inlineExternal || {};\r\n    this.inlineColumn = configuration?.inlineColumn || {};\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (this.inlineExternal[externalFilter.field] === undefined) {\r\n        this.inlineExternal[externalFilter.field] = true;\r\n      }\r\n    }\r\n    for (const column of this.columns) {\r\n      if (this.inlineColumn[column.field] === undefined) {\r\n        this.inlineColumn[column.field] = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  async updateConfiguration(selectedQuickFilterCode?: string) {\r\n    if (!this.key) {\r\n      return;\r\n    }\r\n    if (selectedQuickFilterCode !== undefined) {\r\n      this.selectedCode = selectedQuickFilterCode;\r\n    }\r\n    const { set } = this.settingService.create<FilterConfiguration>({\r\n      prefix: this.keyPrefix,\r\n      key: this.key\r\n    });\r\n    await set({\r\n      quickFilters: this.quickFilters,\r\n      selectedQuickFilter: this.selectedCode,\r\n      inlineExternal: this.inlineExternal,\r\n      inlineColumn: this.inlineColumn\r\n    });\r\n    this.loadInlineFilter.emit({\r\n      quickFilters: this.quickFilters || [],\r\n      selectedQuickFilter: this.selectedCode || '',\r\n      inlineExternal: this.inlineExternal,\r\n      inlineColumn: this.inlineColumn\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onSelectionChange = (change: MatSelectChange) => {\r\n    const value = change?.value || '';\r\n    if (value === this.newQuickFilter) {\r\n      this.selectedCode = '';\r\n      this.onCreateQuickFilter();\r\n      this.ref.detectChanges();\r\n    } else {\r\n      const quickFilter = this.quickFilters.find(e => e.code === value);\r\n      if (quickFilter) {\r\n        this.onDetailQuickFilter(quickFilter);\r\n      }\r\n    }\r\n  }\r\n\r\n  onCreateQuickFilter = (ev?: Event) => {\r\n    ev?.stopPropagation();\r\n    ev?.preventDefault();\r\n    this.matSelect?.close();\r\n    this.popupQuickFilterDetail.open(this.columns, this.externalFilters);\r\n  }\r\n\r\n  onDetailQuickFilter = async (quickFilter?: QuickFilter) => {\r\n    if (quickFilter) {\r\n      this.selectedCode = quickFilter.code;\r\n      const f1 = JSON.stringify(quickFilter.filter);\r\n      const f2 = JSON.stringify(quickFilter.externalFilter);\r\n      this.filter = JSON.parse(f1);\r\n      this.externalFilter = this.initExternalFilter(this.externalFilters, JSON.parse(f2));\r\n      await this.updateConfiguration();\r\n    }\r\n  }\r\n\r\n  onEditQuickFilter = (ev: Event, quickFilter?: QuickFilter) => {\r\n    ev.stopPropagation();\r\n    ev.preventDefault();\r\n    this.matSelect?.close();\r\n    if (quickFilter) {\r\n      this.popupQuickFilterDetail.open(this.columns,\r\n        this.externalFilters,\r\n        quickFilter.filter,\r\n        quickFilter.externalFilter,\r\n        quickFilter.code);\r\n      this.ref.detectChanges();\r\n    }\r\n  }\r\n\r\n  onDeleteQuickFilter = (ev: Event, quickFilter?: QuickFilter) => {\r\n    ev.stopPropagation();\r\n    ev.preventDefault();\r\n    this.matSelect?.close();\r\n    if (quickFilter) {\r\n      this.notifyService.confirm(this.translateService.translate('Remove filter')).then(async () => {\r\n        if (quickFilter.code === this.selectedCode) {\r\n          this.selectedCode = '';\r\n        }\r\n        const idx = this.quickFilters.findIndex(e => e.code === quickFilter.code);\r\n        this.quickFilters.splice(idx, 1);\r\n        await this.updateConfiguration();\r\n        this.ref.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  onAcceptQuickFilter = async (args: { code: string, filter: any, externalFilter: any }) => {\r\n    const quickFilter = this.quickFilters.find(e => e.code === args.code);\r\n    if (!quickFilter) {\r\n      this.quickFilters.push({\r\n        code: args.code,\r\n        filter: args.filter,\r\n        externalFilter: this.initExternalFilter(this.externalFilters, args.externalFilter)\r\n      });\r\n    } else {\r\n      quickFilter.filter = args.filter;\r\n      quickFilter.externalFilter = this.initExternalFilter(this.externalFilters, args.externalFilter);\r\n    }\r\n    await this.updateConfiguration();\r\n  }\r\n\r\n  onInlineChange = () => {\r\n    this.updateConfiguration();\r\n  }\r\n\r\n  private initExternalFilter = (externalFilters: SdGridExternalFilter[], externalFilter: any) => {\r\n    externalFilter = externalFilter || {};\r\n    externalFilters = externalFilters || [];\r\n    externalFilters.forEach(e => {\r\n      if (e.type === 'string') {\r\n        externalFilter[e.field] = externalFilter[e.field] ?? e.default ?? '';\r\n        return;\r\n      }\r\n      if (e.type === 'number') {\r\n        externalFilter[e.field] = externalFilter[e.field] ?? e.default ?? undefined;\r\n        return;\r\n      }\r\n      if (e.type === 'daterange') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'numberrange') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'daterangefull') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'values') { // andn1\r\n        externalFilter[e.field] = (externalFilter[e.field] || e.default) ?? '';\r\n        return;\r\n      }\r\n    });\r\n    return externalFilter;\r\n  }\r\n}\r\n"]}
317
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-popup-filter.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid/","sources":["src/lib/components/grid-popup-filter/grid-popup-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable-next-line:max-line-length\r\nimport { Component, OnInit, AfterViewInit, ViewChild, Output, EventEmitter, Input, ChangeDetectorRef, ViewEncapsulation } from '@angular/core';\r\nimport { SdGridColumn, SdGridExternalFilter, GridBaseOptionFilter } from '../../grid.model';\r\nimport { QuickFilter, FilterConfiguration } from './grid-popup-filter.model';\r\n\r\nimport {\r\n  SdNotifyService\r\n} from '@sd-angular/core/notify';\r\n\r\nimport {\r\n  SdSettingService\r\n} from '@sd-angular/core/setting';\r\n\r\nimport {\r\n  SdTranslateService\r\n} from '@sd-angular/core/translate';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdGridPopupQuickFilterDetail } from '../grid-popup-quick-filter-detail/grid-popup-quick-filter-detail.component';\r\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { SdModal } from '@sd-angular/core/modal';\r\n\r\n@Component({\r\n  selector: 'sd-grid-popup-filter',\r\n  templateUrl: './grid-popup-filter.component.html',\r\n  styleUrls: ['./grid-popup-filter.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SdGridPopupFilter implements OnInit, AfterViewInit {\r\n  private keyPrefix = 'PopupFilter';\r\n  displayKey = 'SDCUSTOM';\r\n  isMobileOrTablet = false;\r\n  @ViewChild('modal') modal: SdModal;\r\n  @ViewChild('popupQuickFilterDetail') popupQuickFilterDetail: SdGridPopupQuickFilterDetail;\r\n  @ViewChild('matSelect') matSelect: MatSelect;\r\n  @Input() key = '';\r\n  @Input() filterOption: GridBaseOptionFilter;\r\n  @Output() accept = new EventEmitter<{ filter: any, externalFilter: any }>();\r\n  @Output() clear = new EventEmitter<void>();\r\n  @Output() loadInlineFilter = new EventEmitter<FilterConfiguration>();\r\n  selectedField: string;\r\n  newQuickFilter = 'e1ef1d43-d689-424f-959e-e6cd154cfee7';\r\n  filter: any = {};\r\n  externalFilter: any = {};\r\n  columns: SdGridColumn[] = [];\r\n  externalFilters: SdGridExternalFilter[] = [];\r\n  quickFilters: QuickFilter[] = [];\r\n  selectedCode: string;\r\n  maxQuickFilters = 5;\r\n  @Input() inlineExternal: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  @Input() inlineColumn: {\r\n    [key: string]: boolean\r\n  } = {};\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    deviceService: DeviceDetectorService,\r\n    private settingService: SdSettingService,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService\r\n  ) {\r\n    this.isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#loadConfiguration().then(() => {\r\n      this.loadInlineFilter.emit({\r\n        quickFilters: this.quickFilters || [],\r\n        selectedQuickFilter: this.selectedCode || '',\r\n        inlineExternal: this.inlineExternal,\r\n        inlineColumn: this.inlineColumn\r\n      });\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n\r\n  }\r\n\r\n  open = (\r\n    fixedColums: SdGridColumn[],\r\n    normalColumns: SdGridColumn[],\r\n    filter: any,\r\n    externalFilter: any,\r\n    externalFilters?: SdGridExternalFilter[]) => {\r\n    this.init(fixedColums, normalColumns, filter, externalFilter, externalFilters);\r\n    this.modal.open();\r\n  }\r\n\r\n  init = (\r\n    fixedColums: SdGridColumn[],\r\n    normalColumns: SdGridColumn[],\r\n    filter: any,\r\n    externalFilter: any,\r\n    externalFilters?: SdGridExternalFilter[]) => {\r\n    this.columns = [...fixedColums, ...normalColumns].filter(e => !e.filter?.disabled && e.type !== 'image');\r\n    this.columns.forEach(column => {\r\n      if (column.type === 'children') {\r\n        column.children = column.children.filter(e => !e.filter?.disabled && e.type !== 'image');\r\n      }\r\n    });\r\n    if (externalFilters) {\r\n      this.externalFilters = externalFilters.filter(e => !e.disabled);\r\n    } else {\r\n      this.externalFilters = [];\r\n    }\r\n    this.filter = filter;\r\n    this.externalFilter = this.initExternalFilter(externalFilters, externalFilter);\r\n    for (const eFilter of this.externalFilters) {\r\n      if (this.inlineExternal[eFilter.field] === undefined) {\r\n        this.inlineExternal[eFilter.field] = true;\r\n      }\r\n    }\r\n    for (const column of this.columns) {\r\n      if (this.inlineColumn[column.field] === undefined) {\r\n        this.inlineColumn[column.field] = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  close = () => {\r\n    this.modal.close();\r\n  }\r\n\r\n  onAccept() {\r\n    if (this.filterOption?.multiple === false) {\r\n      if (this.selectedField) {\r\n        if (this.selectedField.startsWith('column')) {\r\n          const field = this.selectedField.replace('column', '');\r\n          this.accept.emit({\r\n            filter: {\r\n              [field]: this.filter[field]\r\n            },\r\n            externalFilter: {}\r\n          });\r\n        } else if (this.selectedField.startsWith('external')) {\r\n          const field = this.selectedField.replace('external', '');\r\n          this.accept.emit({\r\n            filter: {},\r\n            externalFilter: this.initExternalFilter(this.externalFilters, {\r\n              [field]: this.externalFilter[field]\r\n            })\r\n          });\r\n        }\r\n      }\r\n    } else {\r\n      this.accept.emit({\r\n        filter: this.filter,\r\n        externalFilter: this.externalFilter\r\n      });\r\n    }\r\n    this.modal.close();\r\n  }\r\n\r\n  onClear() {\r\n    delete this.selectedCode;\r\n    this.clear.emit();\r\n  }\r\n\r\n  #loadConfiguration = async () => {\r\n    this.quickFilters = [];\r\n    if (!this.key) {\r\n      return;\r\n    }\r\n    const { get, has } = this.settingService.create<FilterConfiguration>({\r\n      prefix: this.keyPrefix,\r\n      key: this.key\r\n    });\r\n    if (!await has()) {\r\n      return;\r\n    }\r\n    const configuration = await get();\r\n    if (Array.isArray(configuration?.quickFilters)) {\r\n      this.quickFilters = configuration.quickFilters;\r\n    }\r\n    this.selectedCode = configuration?.selectedQuickFilter || '';\r\n    this.inlineExternal = configuration?.inlineExternal || {};\r\n    this.inlineColumn = configuration?.inlineColumn || {};\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (this.inlineExternal[externalFilter.field] === undefined) {\r\n        this.inlineExternal[externalFilter.field] = true;\r\n      }\r\n    }\r\n    for (const column of this.columns) {\r\n      if (this.inlineColumn[column.field] === undefined) {\r\n        this.inlineColumn[column.field] = true;\r\n      }\r\n    }\r\n  }\r\n\r\n  async updateConfiguration(selectedQuickFilterCode?: string) {\r\n    if (!this.key) {\r\n      return;\r\n    }\r\n    if (selectedQuickFilterCode !== undefined) {\r\n      this.selectedCode = selectedQuickFilterCode;\r\n    }\r\n    const { set } = this.settingService.create<FilterConfiguration>({\r\n      prefix: this.keyPrefix,\r\n      key: this.key\r\n    });\r\n    await set({\r\n      quickFilters: this.quickFilters,\r\n      selectedQuickFilter: this.selectedCode,\r\n      inlineExternal: this.inlineExternal,\r\n      inlineColumn: this.inlineColumn\r\n    });\r\n    this.loadInlineFilter.emit({\r\n      quickFilters: this.quickFilters || [],\r\n      selectedQuickFilter: this.selectedCode || '',\r\n      inlineExternal: this.inlineExternal,\r\n      inlineColumn: this.inlineColumn\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onSelectionChange = (change: MatSelectChange) => {\r\n    const value = change?.value || '';\r\n    if (value === this.newQuickFilter) {\r\n      this.selectedCode = '';\r\n      this.onCreateQuickFilter();\r\n      this.ref.detectChanges();\r\n    } else {\r\n      const quickFilter = this.quickFilters.find(e => e.code === value);\r\n      if (quickFilter) {\r\n        this.onDetailQuickFilter(quickFilter);\r\n      }\r\n    }\r\n  }\r\n\r\n  onCreateQuickFilter = (ev?: Event) => {\r\n    ev?.stopPropagation();\r\n    ev?.preventDefault();\r\n    this.matSelect?.close();\r\n    this.popupQuickFilterDetail.open(this.columns, this.externalFilters);\r\n  }\r\n\r\n  onDetailQuickFilter = async (quickFilter?: QuickFilter) => {\r\n    if (quickFilter) {\r\n      this.selectedCode = quickFilter.code;\r\n      const f1 = JSON.stringify(quickFilter.filter);\r\n      const f2 = JSON.stringify(quickFilter.externalFilter);\r\n      this.filter = JSON.parse(f1);\r\n      this.externalFilter = this.initExternalFilter(this.externalFilters, JSON.parse(f2));\r\n      await this.updateConfiguration();\r\n    }\r\n  }\r\n\r\n  onEditQuickFilter = (ev: Event, quickFilter?: QuickFilter) => {\r\n    ev.stopPropagation();\r\n    ev.preventDefault();\r\n    this.matSelect?.close();\r\n    if (quickFilter) {\r\n      this.popupQuickFilterDetail.open(this.columns,\r\n        this.externalFilters,\r\n        quickFilter.filter,\r\n        quickFilter.externalFilter,\r\n        quickFilter.code);\r\n      this.ref.detectChanges();\r\n    }\r\n  }\r\n\r\n  onDeleteQuickFilter = (ev: Event, quickFilter?: QuickFilter) => {\r\n    ev.stopPropagation();\r\n    ev.preventDefault();\r\n    this.matSelect?.close();\r\n    if (quickFilter) {\r\n      this.notifyService.confirm(this.translateService.translate('Remove filter')).then(async () => {\r\n        if (quickFilter.code === this.selectedCode) {\r\n          this.selectedCode = '';\r\n        }\r\n        const idx = this.quickFilters.findIndex(e => e.code === quickFilter.code);\r\n        this.quickFilters.splice(idx, 1);\r\n        await this.updateConfiguration();\r\n        this.ref.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  onAcceptQuickFilter = async (args: { code: string, filter: any, externalFilter: any }) => {\r\n    const quickFilter = this.quickFilters.find(e => e.code === args.code);\r\n    if (!quickFilter) {\r\n      this.quickFilters.push({\r\n        code: args.code,\r\n        filter: args.filter,\r\n        externalFilter: this.initExternalFilter(this.externalFilters, args.externalFilter)\r\n      });\r\n    } else {\r\n      quickFilter.filter = args.filter;\r\n      quickFilter.externalFilter = this.initExternalFilter(this.externalFilters, args.externalFilter);\r\n    }\r\n    await this.updateConfiguration();\r\n  }\r\n\r\n  onInlineChange = () => {\r\n    this.updateConfiguration();\r\n  }\r\n\r\n  private initExternalFilter = (externalFilters: SdGridExternalFilter[], externalFilter: any) => {\r\n    externalFilter = externalFilter || {};\r\n    externalFilters = externalFilters || [];\r\n    externalFilters.forEach(e => {\r\n      if (e.type === 'string') {\r\n        externalFilter[e.field] = externalFilter[e.field] ?? e.default ?? '';\r\n        return;\r\n      }\r\n      if (e.type === 'number') {\r\n        externalFilter[e.field] = externalFilter[e.field] ?? e.default ?? undefined;\r\n        return;\r\n      }\r\n      if (e.type === 'daterange') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'numberrange') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'daterangefull') {\r\n        externalFilter[e.field] = {\r\n          from: externalFilter[e.field]?.from ?? e.defaultFrom ?? undefined,\r\n          to: externalFilter[e.field]?.to ?? e.defaultTo ?? undefined\r\n        };\r\n        return;\r\n      }\r\n      if (e.type === 'values') { // andn1\r\n        externalFilter[e.field] = (externalFilter[e.field] || e.default) ?? '';\r\n        return;\r\n      }\r\n    });\r\n    return externalFilter;\r\n  }\r\n}\r\n"]}