@acorex/components 4.2.28 → 4.2.31

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.
@@ -59,7 +59,7 @@ export class AXPropertyDecorator {
59
59
  // @dynamic
60
60
  export class AXPropertyDecorators {
61
61
  static register(cls, property, options) {
62
- const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);
62
+ const item = AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);
63
63
  if (item) {
64
64
  item.options = options;
65
65
  }
@@ -68,14 +68,14 @@ export class AXPropertyDecorators {
68
68
  }
69
69
  }
70
70
  static has(cls, property) {
71
- return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);
71
+ return AXPropertyDecorators.REGISTRY.some((c) => c.cls === cls && c.property === property);
72
72
  }
73
73
  static get(cls, property) {
74
- return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);
74
+ return AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);
75
75
  }
76
76
  static isValid(property) {
77
77
  if (property) {
78
- return AXPropertyDecorators.REGISTRY.some(c => c.property === property);
78
+ return AXPropertyDecorators.REGISTRY.some((c) => c.property === property);
79
79
  }
80
80
  return false;
81
81
  }
@@ -87,7 +87,7 @@ export class AXPropertyDecorators {
87
87
  p.push(superClass.constructor);
88
88
  superClass = Object.getPrototypeOf(superClass);
89
89
  }
90
- list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));
90
+ list.push(...AXPropertyDecorators.REGISTRY.filter((c) => p.includes(c.cls.constructor)));
91
91
  return list;
92
92
  }
93
93
  }
@@ -98,4 +98,4 @@ export function propertyEditor(options) {
98
98
  AXPropertyDecorators.register(target, key, options);
99
99
  };
100
100
  }
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;AAuD/B,MAAM,OAAgB,wBAAwB;IA+C1C,YAAsB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QA5C5C,aAAQ,GAAY,KAAK,CAAC;QAGlB,eAAU,GAAY,KAAK,CAAC;QAC5B,gBAAW,GAAY,KAAK,CAAC;QAOrC,mCAA8B,GAAoC,IAAI,OAAO,EAA0B,CAAC;QASxG,gBAAW,GAAoB,IAAI,YAAY,EAAK,CAAC;QAIrD,sBAAiB,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAqB7D,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,GAAG,EAAE;YAClC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IA1CD,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC;IAC/C,CAAC;IAMD,yBAAyB,CAAC,SAAkC;QACxD,IAAI,CAAC,8BAA8B,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAWD,IACW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAW,KAAK,CAAC,CAAI;QACjB,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,EAAE;YACnB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;YACzB,4BAA4B;YAC5B,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YAC5B,CAAC,EAAE,GAAG,CAAC,CAAC;SACX;IACL,CAAC;IAUD,iBAAiB,CAAC,CAAI;QAClB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACnB,CAAC;;sHAzDiB,wBAAwB;0GAAxB,wBAAwB;4FAAxB,wBAAwB;kBAD7C,SAAS;wGAwBN,WAAW;sBADV,MAAM;gBAKP,iBAAiB;sBADhB,MAAM;gBAKI,KAAK;sBADf,KAAK;;AAgCV,MAAM,OAAO,mBAAmB;IAK5B,YACI,GAAQ,EACR,QAAgB,EAChB,OAAY;QACZ,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;QACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;CACJ;AAGD,WAAW;AACX,MAAM,OAAO,oBAAoB;IAG7B,MAAM,CAAC,QAAQ,CAAC,GAAW,EAAE,QAAgB,EAAE,OAAa;QACxD,MAAM,IAAI,GAAG,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;QAC/F,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;SAC1B;aACI;YACD,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,mBAAmB,CAAC,GAAG,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;SACvF;IACL,CAAC;IAID,MAAM,CAAC,GAAG,CAAC,GAAW,EAAE,QAAgB;QACpC,OAAO,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;IAC7F,CAAC;IAED,MAAM,CAAC,GAAG,CAAC,GAAW,EAAE,QAAgB;QACpC,OAAO,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,GAAG,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;IAC7F,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,QAAgB;QAC3B,IAAI,QAAQ,EAAE;YACV,OAAO,oBAAoB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC;SAC3E;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,aAAa,CAAC,MAAW;QAC5B,MAAM,IAAI,GAA0B,EAAE,CAAC;QACvC,MAAM,CAAC,GAAU,KAAK,EAAO,CAAC;QAC9B,IAAI,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAC/C,OAAO,UAAU,CAAC,WAAW,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC7C,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;YAC/B,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QACvF,OAAO,IAAI,CAAC;IAChB,CAAC;;AAvCc,6BAAQ,GAAG,IAAI,KAAK,EAAuB,CAAC;AA4C/D,MAAM,UAAU,cAAc,CAAC,OAA4B;IACvD,OAAO,CAAC,MAAW,EAAE,GAAW,EAAE,EAAE;QAC/B,OAAe,CAAC,IAAI,GAAG,GAAG,CAAC;QAC5B,oBAAoB,CAAC,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;IACxD,CAAC,CAAC;AACN,CAAC","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, Directive } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\n\r\n\r\nexport interface AXPropertyDef {\r\n    name: string;\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n    row?: number;\r\n    col?: number | AXPropertyColDef;\r\n}\r\n\r\nexport interface AXPropertyColDef {\r\n    lg?: number;\r\n    md?: number;\r\n    sm?: number;\r\n    xs?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n    title: string;\r\n    hint?: string;\r\n    defaultValue?: any;\r\n    editorClass: any;\r\n    editorOptions?: any;\r\n    visible?: boolean | (() => boolean);\r\n    order?: number;\r\n}\r\n\r\n\r\n\r\n\r\nexport interface AXPropertyConfig {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n    property: AXPropertyDef;\r\n    value: any;\r\n}\r\n\r\n\r\n\r\n@Directive()\r\nexport abstract class AXProperyEditorComponent<T>{\r\n\r\n\r\n    readonly: boolean = false;\r\n\r\n\r\n    private _initiated: boolean = false;\r\n    private _valueBound: boolean = false;\r\n\r\n    public get initiated(): boolean {\r\n        return this._initiated && this._valueBound;\r\n    }\r\n\r\n\r\n    validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n\r\n    registerForValidationForm(component?: AXValidatableComponent) {\r\n        this.validatableComponentRegistered.next(component);\r\n    }\r\n\r\n\r\n    @Output()\r\n    valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n\r\n    @Output()\r\n    onRenderCompleted: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n    private _value: T;\r\n    @Input()\r\n    public get value(): T {\r\n        return this._value;\r\n    }\r\n\r\n    public set value(v: T) {\r\n        if (v !== this._value) {\r\n            this._value = v;\r\n            this.valueChange.emit(v);\r\n            this.cdr.detectChanges();\r\n            //TODO: find better solution\r\n            setTimeout(() => {\r\n                this._valueBound = true;\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    constructor(protected cdr: ChangeDetectorRef) {\r\n        this.onRenderCompleted.subscribe(() => {\r\n            this._initiated = true;\r\n        });\r\n    }\r\n\r\n    uid: string;\r\n\r\n    handleValueChange(v: T) {\r\n        this.value = v;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport class AXPropertyDecorator {\r\n    cls: any;\r\n    property: string;\r\n    options: any;\r\n\r\n    constructor(\r\n        cls: any,\r\n        property: string,\r\n        options: any) {\r\n        this.cls = cls;\r\n        this.property = property;\r\n        this.options = options;\r\n    }\r\n}\r\n\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n    private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n    static register(cls: string, property: string, options?: any) {\r\n        const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n        if (item) {\r\n            item.options = options;\r\n        }\r\n        else {\r\n            AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n        }\r\n    }\r\n\r\n\r\n\r\n    static has(cls: string, property: string): boolean {\r\n        return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static get(cls: string, property: string): AXPropertyDecorator {\r\n        return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);\r\n    }\r\n\r\n    static isValid(property: string): boolean {\r\n        if (property) {\r\n            return AXPropertyDecorators.REGISTRY.some(c => c.property === property);\r\n        }\r\n        return false;\r\n    }\r\n\r\n    static getProperties(target: any): AXPropertyDecorator[] {\r\n        const list: AXPropertyDecorator[] = [];\r\n        const p: any[] = Array<any>();\r\n        let superClass = Object.getPrototypeOf(target);\r\n        while (superClass.constructor.name !== 'Object') {\r\n            p.push(superClass.constructor);\r\n            superClass = Object.getPrototypeOf(superClass);\r\n        }\r\n        list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));\r\n        return list;\r\n    }\r\n}\r\n\r\n\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n    return (target: any, key: string) => {\r\n        (options as any).name = key;\r\n        AXPropertyDecorators.register(target, key, options);\r\n    };\r\n}\r\n\r\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"property-editor.class.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/property-editor/property-editor.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, Directive } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { AXValidatableComponent } from '../base/element.class';\r\n\r\nexport type AXDataType = 'string' | 'number' | 'date' | 'boolean' | 'object';\r\nexport type AXControlType = 'textbox' | 'numberbox' | 'datePicker' | 'switch' | 'custom';\r\n\r\nexport interface AXPropertyDef {\r\n  name: string;\r\n  title: string;\r\n  hint?: string;\r\n  defaultValue?: any;\r\n  editorClass: any;\r\n  editorOptions?: any;\r\n  visible?: boolean | (() => boolean);\r\n  order?: number;\r\n  row?: number;\r\n  col?: number | AXPropertyColDef;\r\n  filterOptions?: FilterModel;\r\n}\r\n\r\nexport interface FilterModel {\r\n  operator?: any;\r\n  filters?: FilterModel[];\r\n  truncateDate?: boolean;\r\n  joinType?: string;\r\n  ignoreCase?: boolean;\r\n  logic?: 'and' | 'or';\r\n}\r\nexport interface AXPropertyColDef {\r\n  lg?: number;\r\n  md?: number;\r\n  sm?: number;\r\n  xs?: number;\r\n}\r\n\r\nexport interface AXPropertyEditorDef {\r\n  title: string;\r\n  hint?: string;\r\n  defaultValue?: any;\r\n  editorClass: any;\r\n  editorOptions?: any;\r\n  visible?: boolean | (() => boolean);\r\n  order?: number;\r\n}\r\n\r\nexport interface AXPropertyConfig {\r\n  property: AXPropertyDef;\r\n  value: any;\r\n}\r\n\r\nexport interface AXProperyEditorValueChangeEvent {\r\n  property: AXPropertyDef;\r\n  value: any;\r\n}\r\n\r\n@Directive()\r\nexport abstract class AXProperyEditorComponent<T> {\r\n  readonly: boolean = false;\r\n\r\n  private _initiated: boolean = false;\r\n  private _valueBound: boolean = false;\r\n\r\n  public get initiated(): boolean {\r\n    return this._initiated && this._valueBound;\r\n  }\r\n\r\n  validatableComponentRegistered: Subject<AXValidatableComponent> = new Subject<AXValidatableComponent>();\r\n\r\n  registerForValidationForm(component?: AXValidatableComponent) {\r\n    this.validatableComponentRegistered.next(component);\r\n  }\r\n\r\n  @Output()\r\n  valueChange: EventEmitter<T> = new EventEmitter<T>();\r\n\r\n  @Output()\r\n  onRenderCompleted: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  private _value: T;\r\n  @Input()\r\n  public get value(): T {\r\n    return this._value;\r\n  }\r\n\r\n  public set value(v: T) {\r\n    if (v !== this._value) {\r\n      this._value = v;\r\n      this.valueChange.emit(v);\r\n      this.cdr.detectChanges();\r\n      //TODO: find better solution\r\n      setTimeout(() => {\r\n        this._valueBound = true;\r\n      }, 100);\r\n    }\r\n  }\r\n\r\n  constructor(protected cdr: ChangeDetectorRef) {\r\n    this.onRenderCompleted.subscribe(() => {\r\n      this._initiated = true;\r\n    });\r\n  }\r\n\r\n  uid: string;\r\n\r\n  handleValueChange(v: T) {\r\n    this.value = v;\r\n  }\r\n}\r\n\r\nexport class AXPropertyDecorator {\r\n  cls: any;\r\n  property: string;\r\n  options: any;\r\n\r\n  constructor(cls: any, property: string, options: any) {\r\n    this.cls = cls;\r\n    this.property = property;\r\n    this.options = options;\r\n  }\r\n}\r\n\r\n// @dynamic\r\nexport class AXPropertyDecorators {\r\n  private static REGISTRY = new Array<AXPropertyDecorator>();\r\n\r\n  static register(cls: string, property: string, options?: any) {\r\n    const item = AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);\r\n    if (item) {\r\n      item.options = options;\r\n    } else {\r\n      AXPropertyDecorators.REGISTRY.push(new AXPropertyDecorator(cls, property, options));\r\n    }\r\n  }\r\n\r\n  static has(cls: string, property: string): boolean {\r\n    return AXPropertyDecorators.REGISTRY.some((c) => c.cls === cls && c.property === property);\r\n  }\r\n\r\n  static get(cls: string, property: string): AXPropertyDecorator {\r\n    return AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);\r\n  }\r\n\r\n  static isValid(property: string): boolean {\r\n    if (property) {\r\n      return AXPropertyDecorators.REGISTRY.some((c) => c.property === property);\r\n    }\r\n    return false;\r\n  }\r\n\r\n  static getProperties(target: any): AXPropertyDecorator[] {\r\n    const list: AXPropertyDecorator[] = [];\r\n    const p: any[] = Array<any>();\r\n    let superClass = Object.getPrototypeOf(target);\r\n    while (superClass.constructor.name !== 'Object') {\r\n      p.push(superClass.constructor);\r\n      superClass = Object.getPrototypeOf(superClass);\r\n    }\r\n    list.push(...AXPropertyDecorators.REGISTRY.filter((c) => p.includes(c.cls.constructor)));\r\n    return list;\r\n  }\r\n}\r\n\r\nexport function propertyEditor(options: AXPropertyEditorDef) {\r\n  return (target: any, key: string) => {\r\n    (options as any).name = key;\r\n    AXPropertyDecorators.register(target, key, options);\r\n  };\r\n}\r\n"]}
@@ -24,7 +24,6 @@ export class AXSearchBarComponent {
24
24
  this._context = {};
25
25
  }
26
26
  set items(v) {
27
- debugger;
28
27
  v.forEach((el) => {
29
28
  if (el.value != null) {
30
29
  this._filterItems.push({
@@ -34,10 +33,13 @@ export class AXSearchBarComponent {
34
33
  });
35
34
  }
36
35
  });
37
- this._items = _.chain(v).groupBy(x => x.property.row).map((value, key) => ({ row: key, items: value })).value();
36
+ this._items = _.chain(v)
37
+ .groupBy((x) => x.property.row)
38
+ .map((value, key) => ({ row: key, items: value }))
39
+ .value();
38
40
  }
39
41
  clearItem(name) {
40
- this._editors.find(e => e.property.property.name == name).clear();
42
+ this._editors.find((e) => e.property.property.name == name).clear();
41
43
  }
42
44
  handleButtonClick() {
43
45
  this.dropdown.toggle();
@@ -50,13 +52,21 @@ export class AXSearchBarComponent {
50
52
  this._filterItemsClone.push({
51
53
  name: e.property.name,
52
54
  title: e.property.title,
53
- value: e.value
55
+ value: e.value,
56
+ filterOptions: {
57
+ filters: e.property?.filterOptions?.filters ? e.property.filterOptions.filters : [],
58
+ logic: e.property?.filterOptions?.logic ? e.property.filterOptions.logic : 'and',
59
+ ignoreCase: e.property?.filterOptions?.ignoreCase ? e.property.filterOptions.ignoreCase : true,
60
+ joinType: e.property?.filterOptions?.joinType ? e.property.filterOptions.joinType : 'INNER',
61
+ operator: e.property?.filterOptions?.operator ? e.property.filterOptions.operator : null,
62
+ truncateDate: e.property?.filterOptions?.truncateDate ? e.property.filterOptions.truncateDate : true
63
+ }
54
64
  });
55
65
  }
56
66
  this.onValueChange.emit(e);
57
67
  }
58
68
  handleItemRemoveClick(item) {
59
- this._editors.forEach(e => {
69
+ this._editors.forEach((e) => {
60
70
  if (e.property.property.name == item.name) {
61
71
  e.clear();
62
72
  }
@@ -69,7 +79,7 @@ export class AXSearchBarComponent {
69
79
  this.onSearchValue.emit(this._filterItems);
70
80
  }
71
81
  clear() {
72
- this._editors.forEach(e => {
82
+ this._editors.forEach((e) => {
73
83
  e.clear();
74
84
  });
75
85
  this._filterItems = [];
@@ -102,8 +112,7 @@ export class AXSearchBarComponent {
102
112
  }
103
113
  return className.toString().replace(/,/, ' ');
104
114
  }
105
- ngOnInit() {
106
- }
115
+ ngOnInit() { }
107
116
  }
108
117
  AXSearchBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXSearchBarComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
109
118
  AXSearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXSearchBarComponent, selector: "ax-search-bar", inputs: { size: "size", disabled: "disabled", items: "items", rtl: "rtl" }, outputs: { onValueChange: "onValueChange", onSearchValue: "onSearchValue" }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "_editors", predicate: AXPropertyEditorRendererDirective, descendants: true }], ngImport: i0, template: "<ax-drop-down [fitParent]=\"true\" [size]=\"size\" [showDropDownButton]=\"false\" icon=\"far fa-sliders-h\" #dropdown\r\n maxHeight=\"unset\">\r\n <ng-container start>\r\n <ng-content select=\"[start]\">\r\n </ng-content>\r\n </ng-container>\r\n <ng-container header>\r\n <div class=\"ax chips-container\">\r\n <div class=\"chips\" *ngFor=\"let item of _filterItems\">\r\n <span class=\"chips-text\">\r\n <b>{{item.title}} :</b> {{item.value}}\r\n </span>\r\n <span class=\"close-icon\" (click)=\"handleItemRemoveClick(item)\">\r\n <i class=\"far fa-times close\"></i>\r\n </span>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container panel>\r\n <div class=\"panel-box\">\r\n <div *ngFor=\"let item of _items\" class=\"row\">\r\n <div *ngFor=\"let prop of item.items\" class=\"{{renderCol(prop.property.col)}}\">\r\n <!-- <ax-form-group> -->\r\n <div *ngIf=\"prop.property.visible != false\">\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [property]=\"prop\" [context]=\"_context\"\r\n (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n <!-- </ax-form-group> -->\r\n </div>\r\n </div>\r\n <div class=\"footer-button\">\r\n <ax-button (click)=\"search()\">{{'common.search' | trans}}</ax-button>\r\n <ax-button type=\"blank danger\" (click)=\"clear()\">{{'dataGrid.clearFilter' | trans}}</ax-button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container end>\r\n <ax-button end icon=\"far fa-sliders-h icon\" type=\"light blank\" [disabled]=\"disabled\" [size]=\"size\"\r\n [tabIndex]=\"-1\" (click)=\"handleButtonClick()\">{{'common.search' | trans}}</ax-button>\r\n </ng-container>\r\n\r\n</ax-drop-down>\r\n", styles: [".ax.chips-container{height:100%}.panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}\n"], components: [{ type: i1.AXDropdownComponent, selector: "ax-drop-down", inputs: ["rtl", "readonly", "loading"], outputs: ["dropdownToggle", "onButtonClick"] }, { type: i2.AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { type: i3.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }], directives: [{ type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.AXPropertyEditorRendererDirective, selector: "[ax-property-editor-renderer]", inputs: ["property", "validationForm", "context", "host", "groupId"], outputs: ["onValueChange"] }], pipes: { "trans": i6.AXTranslatorPipe } });
@@ -129,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
129
138
  }], onSearchValue: [{
130
139
  type: Output
131
140
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/search-bar/search-bar.component.ts","../../../../../../projects/acorex/components/src/lib/search-bar/search-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from '@acorex/core';\r\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';\r\nimport * as _ from 'lodash';\r\nimport { AXElementSize } from '../base/element.class';\r\nimport { AXDropdownComponent } from '../dropdown/dropdown.component';\r\nimport { AXPropertyEditorRendererDirective } from '../property-editor/property-editor-renderer.directive';\r\nimport { AXPropertyColDef, AXPropertyConfig, AXProperyEditorValueChangeEvent } from '../property-editor/property-editor.class';\r\nexport interface FilterTextItemsModel {\r\n    name: string;\r\n    title: string;\r\n    value: any;\r\n}\r\n@Component({\r\n    selector: 'ax-search-bar',\r\n    templateUrl: './search-bar.component.html',\r\n    styleUrls: ['./search-bar.component.scss']\r\n})\r\nexport class AXSearchBarComponent implements OnInit {\r\n    constructor(\r\n        private ref: ElementRef<HTMLDivElement>\r\n    ) { }\r\n    @ViewChild('dropdown', { static: true }) dropdown: AXDropdownComponent;\r\n    @ViewChildren(AXPropertyEditorRendererDirective) _editors: QueryList<AXPropertyEditorRendererDirective>;\r\n\r\n    @Input()\r\n    size: AXElementSize = 'md';\r\n\r\n    @Input()\r\n    disabled: boolean = false;\r\n\r\n    @Input()\r\n    public set items(v: AXPropertyConfig[]) {\r\n        debugger\r\n        v.forEach((el) => {\r\n            if (el.value != null) {\r\n                this._filterItems.push({\r\n                    name: el.property.name,\r\n                    title: el.property.title,\r\n                    value: el.value\r\n                });\r\n            }\r\n        });\r\n        this._items = _.chain(v).groupBy(x => x.property.row).map((value, key) => ({ row: key, items: value })).value();\r\n    }\r\n\r\n    @Input()\r\n    rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n    @Output()\r\n    onValueChange: EventEmitter<any> = new EventEmitter();\r\n\r\n    @Output()\r\n    onSearchValue: EventEmitter<FilterTextItemsModel[]> = new EventEmitter();\r\n\r\n    _items: any[] = [];\r\n    _filterItems: FilterTextItemsModel[] = [];\r\n    _filterItemsClone: FilterTextItemsModel[] = [];\r\n    _context: any = {};\r\n\r\n    public clearItem(name: string) {\r\n        this._editors.find(e => e.property.property.name == name).clear();\r\n    }\r\n\r\n    handleButtonClick() {\r\n        this.dropdown.toggle();\r\n    }\r\n\r\n    handleValueChange(e: AXProperyEditorValueChangeEvent) {\r\n        if (this._filterItemsClone.find((el) => el.name == e.property.name)) {\r\n            this._filterItemsClone.find((el) => el.name == e.property.name).value = e.value;\r\n        } else if (e.value != null) {\r\n            this._filterItemsClone.push({\r\n                name: e.property.name,\r\n                title: e.property.title,\r\n                value: e.value\r\n            });\r\n        }\r\n        this.onValueChange.emit(e);\r\n    }\r\n\r\n    handleItemRemoveClick(item: FilterTextItemsModel) {\r\n        this._editors.forEach(e => {\r\n            if (e.property.property.name == item.name) {\r\n                e.clear();\r\n            }\r\n        });\r\n        this._filterItems = this._filterItems.filter((el) => el.name != item.name);\r\n    }\r\n\r\n    search() {\r\n        this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n        this.handleButtonClick();\r\n        this.onSearchValue.emit(this._filterItems);\r\n    }\r\n\r\n    clear() {\r\n        this._editors.forEach(e => {\r\n            e.clear();\r\n        });\r\n        this._filterItems = [];\r\n        this._filterItemsClone = [];\r\n        this.handleButtonClick();\r\n        this.onSearchValue.emit(this._filterItems);\r\n    }\r\n\r\n    renderCol(e: number | AXPropertyColDef) {\r\n        let className: string[] = [];\r\n        if (typeof e == 'number') {\r\n            className.push(`col-${e}`);\r\n        } else {\r\n            for (const key in e) {\r\n                switch (key) {\r\n                    case 'lg':\r\n                        className.push(`col-lg-${e[key]}`);\r\n                        break;\r\n                    case 'md':\r\n                        className.push(`col-md-${e[key]}`);\r\n                        break;\r\n                    case 'sm':\r\n                        className.push(`col-sm-${e[key]}`);\r\n                        break;\r\n                    case 'xs':\r\n                        className.push(`col-xs-${e[key]}`);\r\n                        break;\r\n                }\r\n            }\r\n        }\r\n        return className.toString().replace(/,/, ' ');\r\n    }\r\n\r\n    ngOnInit(): void {\r\n\r\n    }\r\n}\r\n","<ax-drop-down [fitParent]=\"true\" [size]=\"size\" [showDropDownButton]=\"false\" icon=\"far fa-sliders-h\" #dropdown\r\n    maxHeight=\"unset\">\r\n    <ng-container start>\r\n        <ng-content select=\"[start]\">\r\n        </ng-content>\r\n    </ng-container>\r\n    <ng-container header>\r\n        <div class=\"ax chips-container\">\r\n            <div class=\"chips\" *ngFor=\"let item of _filterItems\">\r\n                <span class=\"chips-text\">\r\n                    <b>{{item.title}} :</b> {{item.value}}\r\n                </span>\r\n                <span class=\"close-icon\" (click)=\"handleItemRemoveClick(item)\">\r\n                    <i class=\"far fa-times close\"></i>\r\n                </span>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <ng-container panel>\r\n        <div class=\"panel-box\">\r\n            <div *ngFor=\"let item of _items\" class=\"row\">\r\n                <div *ngFor=\"let prop of item.items\" class=\"{{renderCol(prop.property.col)}}\">\r\n                    <!-- <ax-form-group> -->\r\n                        <div *ngIf=\"prop.property.visible != false\">\r\n                            <ax-label>{{prop.property.title}}</ax-label>\r\n                            <ng-container ax-property-editor-renderer [property]=\"prop\" [context]=\"_context\"\r\n                                (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n                        </div>\r\n                    <!-- </ax-form-group> -->\r\n                </div>\r\n            </div>\r\n            <div class=\"footer-button\">\r\n                <ax-button (click)=\"search()\">{{'common.search' | trans}}</ax-button>\r\n                <ax-button type=\"blank danger\" (click)=\"clear()\">{{'dataGrid.clearFilter' | trans}}</ax-button>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <ng-container end>\r\n        <ax-button end icon=\"far fa-sliders-h icon\" type=\"light blank\" [disabled]=\"disabled\" [size]=\"size\"\r\n            [tabIndex]=\"-1\" (click)=\"handleButtonClick()\">{{'common.search' | trans}}</ax-button>\r\n    </ng-container>\r\n\r\n</ax-drop-down>\r\n"]}
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/search-bar/search-bar.component.ts","../../../../../../projects/acorex/components/src/lib/search-bar/search-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from '@acorex/core';\r\nimport { Component, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';\r\nimport * as _ from 'lodash';\r\nimport { AXElementSize } from '../base/element.class';\r\nimport { AXDropdownComponent } from '../dropdown/dropdown.component';\r\nimport { AXPropertyEditorRendererDirective } from '../property-editor/property-editor-renderer.directive';\r\nimport { AXPropertyColDef, AXPropertyConfig, AXProperyEditorValueChangeEvent, FilterModel } from '../property-editor/property-editor.class';\r\nexport interface FilterTextItemsModel {\r\n  name: string;\r\n  title: string;\r\n  value: any;\r\n  filterOptions?: FilterModel;\r\n}\r\n\r\n@Component({\r\n  selector: 'ax-search-bar',\r\n  templateUrl: './search-bar.component.html',\r\n  styleUrls: ['./search-bar.component.scss']\r\n})\r\nexport class AXSearchBarComponent implements OnInit {\r\n  constructor(private ref: ElementRef<HTMLDivElement>) {}\r\n  @ViewChild('dropdown', { static: true }) dropdown: AXDropdownComponent;\r\n  @ViewChildren(AXPropertyEditorRendererDirective) _editors: QueryList<AXPropertyEditorRendererDirective>;\r\n\r\n  @Input()\r\n  size: AXElementSize = 'md';\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  public set items(v: AXPropertyConfig[]) {\r\n    v.forEach((el) => {\r\n      if (el.value != null) {\r\n        this._filterItems.push({\r\n          name: el.property.name,\r\n          title: el.property.title,\r\n          value: el.value\r\n        });\r\n      }\r\n    });\r\n    this._items = _.chain(v)\r\n      .groupBy((x) => x.property.row)\r\n      .map((value, key) => ({ row: key, items: value }))\r\n      .value();\r\n  }\r\n\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  @Output()\r\n  onValueChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output()\r\n  onSearchValue: EventEmitter<FilterTextItemsModel[]> = new EventEmitter();\r\n\r\n  _items: any[] = [];\r\n  _filterItems: FilterTextItemsModel[] = [];\r\n  _filterItemsClone: FilterTextItemsModel[] = [];\r\n  _context: any = {};\r\n\r\n  public clearItem(name: string) {\r\n    this._editors.find((e) => e.property.property.name == name).clear();\r\n  }\r\n\r\n  handleButtonClick() {\r\n    this.dropdown.toggle();\r\n  }\r\n\r\n  handleValueChange(e: AXProperyEditorValueChangeEvent) {\r\n    if (this._filterItemsClone.find((el) => el.name == e.property.name)) {\r\n      this._filterItemsClone.find((el) => el.name == e.property.name).value = e.value;\r\n    } else if (e.value != null) {\r\n      this._filterItemsClone.push({\r\n        name: e.property.name,\r\n        title: e.property.title,\r\n        value: e.value,\r\n        filterOptions: {\r\n          filters: e.property?.filterOptions?.filters ? e.property.filterOptions.filters : [],\r\n          logic: e.property?.filterOptions?.logic ? e.property.filterOptions.logic : 'and',\r\n          ignoreCase: e.property?.filterOptions?.ignoreCase ? e.property.filterOptions.ignoreCase : true,\r\n          joinType: e.property?.filterOptions?.joinType ? e.property.filterOptions.joinType : 'INNER',\r\n          operator: e.property?.filterOptions?.operator ? e.property.filterOptions.operator : null,\r\n          truncateDate: e.property?.filterOptions?.truncateDate ? e.property.filterOptions.truncateDate : true\r\n        }\r\n      });\r\n    }\r\n    this.onValueChange.emit(e);\r\n  }\r\n\r\n  handleItemRemoveClick(item: FilterTextItemsModel) {\r\n    this._editors.forEach((e) => {\r\n      if (e.property.property.name == item.name) {\r\n        e.clear();\r\n      }\r\n    });\r\n    this._filterItems = this._filterItems.filter((el) => el.name != item.name);\r\n  }\r\n\r\n  search() {\r\n    this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n    this.handleButtonClick();\r\n    this.onSearchValue.emit(this._filterItems);\r\n  }\r\n\r\n  clear() {\r\n    this._editors.forEach((e) => {\r\n      e.clear();\r\n    });\r\n    this._filterItems = [];\r\n    this._filterItemsClone = [];\r\n    this.handleButtonClick();\r\n    this.onSearchValue.emit(this._filterItems);\r\n  }\r\n\r\n  renderCol(e: number | AXPropertyColDef) {\r\n    let className: string[] = [];\r\n    if (typeof e == 'number') {\r\n      className.push(`col-${e}`);\r\n    } else {\r\n      for (const key in e) {\r\n        switch (key) {\r\n          case 'lg':\r\n            className.push(`col-lg-${e[key]}`);\r\n            break;\r\n          case 'md':\r\n            className.push(`col-md-${e[key]}`);\r\n            break;\r\n          case 'sm':\r\n            className.push(`col-sm-${e[key]}`);\r\n            break;\r\n          case 'xs':\r\n            className.push(`col-xs-${e[key]}`);\r\n            break;\r\n        }\r\n      }\r\n    }\r\n    return className.toString().replace(/,/, ' ');\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n}\r\n","<ax-drop-down [fitParent]=\"true\" [size]=\"size\" [showDropDownButton]=\"false\" icon=\"far fa-sliders-h\" #dropdown\r\n    maxHeight=\"unset\">\r\n    <ng-container start>\r\n        <ng-content select=\"[start]\">\r\n        </ng-content>\r\n    </ng-container>\r\n    <ng-container header>\r\n        <div class=\"ax chips-container\">\r\n            <div class=\"chips\" *ngFor=\"let item of _filterItems\">\r\n                <span class=\"chips-text\">\r\n                    <b>{{item.title}} :</b> {{item.value}}\r\n                </span>\r\n                <span class=\"close-icon\" (click)=\"handleItemRemoveClick(item)\">\r\n                    <i class=\"far fa-times close\"></i>\r\n                </span>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <ng-container panel>\r\n        <div class=\"panel-box\">\r\n            <div *ngFor=\"let item of _items\" class=\"row\">\r\n                <div *ngFor=\"let prop of item.items\" class=\"{{renderCol(prop.property.col)}}\">\r\n                    <!-- <ax-form-group> -->\r\n                        <div *ngIf=\"prop.property.visible != false\">\r\n                            <ax-label>{{prop.property.title}}</ax-label>\r\n                            <ng-container ax-property-editor-renderer [property]=\"prop\" [context]=\"_context\"\r\n                                (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n                        </div>\r\n                    <!-- </ax-form-group> -->\r\n                </div>\r\n            </div>\r\n            <div class=\"footer-button\">\r\n                <ax-button (click)=\"search()\">{{'common.search' | trans}}</ax-button>\r\n                <ax-button type=\"blank danger\" (click)=\"clear()\">{{'dataGrid.clearFilter' | trans}}</ax-button>\r\n            </div>\r\n        </div>\r\n    </ng-container>\r\n    <ng-container end>\r\n        <ax-button end icon=\"far fa-sliders-h icon\" type=\"light blank\" [disabled]=\"disabled\" [size]=\"size\"\r\n            [tabIndex]=\"-1\" (click)=\"handleButtonClick()\">{{'common.search' | trans}}</ax-button>\r\n    </ng-container>\r\n\r\n</ax-drop-down>\r\n"]}
@@ -22,7 +22,8 @@ export class AXTabPageHostComponent {
22
22
  active() {
23
23
  const func = this.componentRef?.instance?.onActivated;
24
24
  if (func) {
25
- func();
25
+ const f = func.bind(this.componentRef.instance);
26
+ f();
26
27
  }
27
28
  }
28
29
  async ngAfterViewInit() {
@@ -112,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
112
113
  type: ViewChild,
113
114
  args: ['container', { read: ViewContainerRef, static: true }]
114
115
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-page-host.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/tab-page/tab-page-host.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ViewContainerRef, ComponentFactoryResolver, ElementRef, ComponentRef, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';\r\nimport { AXTabPage, AXTabPageService } from './tab-page.service';\r\nimport { AXRenderService } from '@acorex/core';\r\nimport { AXBasePageComponent, AXPageCloseEvent, TAB_META_KEY } from '../base/base-page.class';\r\nimport { AXLoadingService } from '../loading/loading.service';\r\n\r\n@Component({\r\n    selector: 'ax-tab-page-host',\r\n    template: `\r\n        <div class='ax-loading-host'>\r\n            <div class='ax-tab-page-host' >\r\n                <div [hidden]=\"isLoading\" style=\"height:100%\" class='ax-tab-page-host-container'>\r\n                    <ng-template #container></ng-template>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    `\r\n})\r\n\r\nexport class AXTabPageHostComponent implements OnInit {\r\n\r\n    tab: AXTabPage;\r\n    private componentRef: ComponentRef<any>;\r\n    isLoading: boolean;\r\n    _loadingId: number;\r\n\r\n    @ViewChild('container', { read: ViewContainerRef, static: true })\r\n    private container: ViewContainerRef;\r\n\r\n    constructor(\r\n        private resolver: ComponentFactoryResolver,\r\n        private ref: ElementRef<HTMLDivElement>,\r\n        private rendererService: AXRenderService,\r\n        private tabService: AXTabPageService,\r\n        private loadingService: AXLoadingService,\r\n        private cdr: ChangeDetectorRef,\r\n    ) {\r\n    }\r\n\r\n\r\n    ngOnInit() {\r\n        this.isLoading = true;\r\n    }\r\n\r\n    active() {\r\n        const func = this.componentRef?.instance?.onActivated;\r\n        if (func) {\r\n            func();\r\n        }\r\n    }\r\n\r\n    async ngAfterViewInit() {\r\n        this._loadingId = this.loadingService.show(this.ref.nativeElement.querySelector('.ax-tab-page-host-container'));\r\n        //\r\n        let data: any = {};\r\n        //\r\n        let component: any;\r\n        if (typeof this.tab.content === 'string') {\r\n            const route = await this.rendererService.findLoadedComponentByRoute(this.tab.content, 20);\r\n            component = route?.component;\r\n            data = Object.assign(data, route.data);\r\n        }\r\n        else if (typeof this.tab.content === 'function') {\r\n            component = this.tab.content;\r\n        }\r\n        if (component == null) {\r\n            // TODO: 404 page component\r\n            this.isLoading = false;\r\n            console.error(`Invalid page Component! ${this.tab.content}`);\r\n            return;\r\n        }\r\n        //\r\n        data = Object.assign(data, this.tab.data);\r\n        //\r\n        try {\r\n            const factory = this.resolver.resolveComponentFactory(component);\r\n            this.componentRef = this.container.createComponent(factory);\r\n            if (!this.componentRef.instance.onClosed) {\r\n                throw Error('The Component must be inherited from AXBasePageComponent!');\r\n            }\r\n            this.componentRef.instance.onClosed.subscribe((e: AXPageCloseEvent) => {\r\n                this.tabService.close(this.tab);\r\n            });\r\n            //\r\n            const com = this.componentRef.instance as any;\r\n            //\r\n            Object.assign(com, data);\r\n            //\r\n            this.tab[TAB_META_KEY].component = com;\r\n            this.isLoading = false;\r\n            this.loadingService.hide(this._loadingId);\r\n            this.componentRef.changeDetectorRef.detectChanges();\r\n        } catch (error) {\r\n            // TODO: 404 page component\r\n            console.error(error);\r\n        } finally {\r\n            //this.isLoading = false;\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.componentRef) {\r\n            this.componentRef.hostView.destroy();\r\n            this.componentRef.destroy();\r\n            this.container.clear();\r\n        }\r\n        this.loadingService.hide(this._loadingId);\r\n    }\r\n}"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-page-host.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/tab-page/tab-page-host.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ViewContainerRef, ComponentFactoryResolver, ElementRef, ComponentRef, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';\r\nimport { AXTabPage, AXTabPageService } from './tab-page.service';\r\nimport { AXRenderService } from '@acorex/core';\r\nimport { AXBasePageComponent, AXPageCloseEvent, TAB_META_KEY } from '../base/base-page.class';\r\nimport { AXLoadingService } from '../loading/loading.service';\r\n\r\n@Component({\r\n    selector: 'ax-tab-page-host',\r\n    template: `\r\n        <div class='ax-loading-host'>\r\n            <div class='ax-tab-page-host' >\r\n                <div [hidden]=\"isLoading\" style=\"height:100%\" class='ax-tab-page-host-container'>\r\n                    <ng-template #container></ng-template>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    `\r\n})\r\n\r\nexport class AXTabPageHostComponent implements OnInit {\r\n\r\n    tab: AXTabPage;\r\n    private componentRef: ComponentRef<any>;\r\n    isLoading: boolean;\r\n    _loadingId: number;\r\n\r\n    @ViewChild('container', { read: ViewContainerRef, static: true })\r\n    private container: ViewContainerRef;\r\n\r\n    constructor(\r\n        private resolver: ComponentFactoryResolver,\r\n        private ref: ElementRef<HTMLDivElement>,\r\n        private rendererService: AXRenderService,\r\n        private tabService: AXTabPageService,\r\n        private loadingService: AXLoadingService,\r\n        private cdr: ChangeDetectorRef,\r\n    ) {\r\n    }\r\n\r\n\r\n    ngOnInit() {\r\n        this.isLoading = true;\r\n    }\r\n\r\n    active() {\r\n        const func = this.componentRef?.instance?.onActivated;\r\n        if (func) {\r\n            const f = (func as Function).bind(this.componentRef.instance);\r\n            f()\r\n        }\r\n    }\r\n\r\n    async ngAfterViewInit() {\r\n        this._loadingId = this.loadingService.show(this.ref.nativeElement.querySelector('.ax-tab-page-host-container'));\r\n        //\r\n        let data: any = {};\r\n        //\r\n        let component: any;\r\n        if (typeof this.tab.content === 'string') {\r\n            const route = await this.rendererService.findLoadedComponentByRoute(this.tab.content, 20);\r\n            component = route?.component;\r\n            data = Object.assign(data, route.data);\r\n        }\r\n        else if (typeof this.tab.content === 'function') {\r\n            component = this.tab.content;\r\n        }\r\n        if (component == null) {\r\n            // TODO: 404 page component\r\n            this.isLoading = false;\r\n            console.error(`Invalid page Component! ${this.tab.content}`);\r\n            return;\r\n        }\r\n        //\r\n        data = Object.assign(data, this.tab.data);\r\n        //\r\n        try {\r\n            const factory = this.resolver.resolveComponentFactory(component);\r\n            this.componentRef = this.container.createComponent(factory);\r\n            if (!this.componentRef.instance.onClosed) {\r\n                throw Error('The Component must be inherited from AXBasePageComponent!');\r\n            }\r\n            this.componentRef.instance.onClosed.subscribe((e: AXPageCloseEvent) => {\r\n                this.tabService.close(this.tab);\r\n            });\r\n            //\r\n            const com = this.componentRef.instance as any;\r\n            //\r\n            Object.assign(com, data);\r\n            //\r\n            this.tab[TAB_META_KEY].component = com;\r\n            this.isLoading = false;\r\n            this.loadingService.hide(this._loadingId);\r\n            this.componentRef.changeDetectorRef.detectChanges();\r\n        } catch (error) {\r\n            // TODO: 404 page component\r\n            console.error(error);\r\n        } finally {\r\n            //this.isLoading = false;\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.componentRef) {\r\n            this.componentRef.hostView.destroy();\r\n            this.componentRef.destroy();\r\n            this.container.clear();\r\n        }\r\n        this.loadingService.hide(this._loadingId);\r\n    }\r\n}"]}
@@ -10303,7 +10303,6 @@ class AXSearchBarComponent {
10303
10303
  this._context = {};
10304
10304
  }
10305
10305
  set items(v) {
10306
- debugger;
10307
10306
  v.forEach((el) => {
10308
10307
  if (el.value != null) {
10309
10308
  this._filterItems.push({
@@ -10313,15 +10312,19 @@ class AXSearchBarComponent {
10313
10312
  });
10314
10313
  }
10315
10314
  });
10316
- this._items = _.chain(v).groupBy(x => x.property.row).map((value, key) => ({ row: key, items: value })).value();
10315
+ this._items = _.chain(v)
10316
+ .groupBy((x) => x.property.row)
10317
+ .map((value, key) => ({ row: key, items: value }))
10318
+ .value();
10317
10319
  }
10318
10320
  clearItem(name) {
10319
- this._editors.find(e => e.property.property.name == name).clear();
10321
+ this._editors.find((e) => e.property.property.name == name).clear();
10320
10322
  }
10321
10323
  handleButtonClick() {
10322
10324
  this.dropdown.toggle();
10323
10325
  }
10324
10326
  handleValueChange(e) {
10327
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
10325
10328
  if (this._filterItemsClone.find((el) => el.name == e.property.name)) {
10326
10329
  this._filterItemsClone.find((el) => el.name == e.property.name).value = e.value;
10327
10330
  }
@@ -10329,13 +10332,21 @@ class AXSearchBarComponent {
10329
10332
  this._filterItemsClone.push({
10330
10333
  name: e.property.name,
10331
10334
  title: e.property.title,
10332
- value: e.value
10335
+ value: e.value,
10336
+ filterOptions: {
10337
+ filters: ((_b = (_a = e.property) === null || _a === void 0 ? void 0 : _a.filterOptions) === null || _b === void 0 ? void 0 : _b.filters) ? e.property.filterOptions.filters : [],
10338
+ logic: ((_d = (_c = e.property) === null || _c === void 0 ? void 0 : _c.filterOptions) === null || _d === void 0 ? void 0 : _d.logic) ? e.property.filterOptions.logic : 'and',
10339
+ ignoreCase: ((_f = (_e = e.property) === null || _e === void 0 ? void 0 : _e.filterOptions) === null || _f === void 0 ? void 0 : _f.ignoreCase) ? e.property.filterOptions.ignoreCase : true,
10340
+ joinType: ((_h = (_g = e.property) === null || _g === void 0 ? void 0 : _g.filterOptions) === null || _h === void 0 ? void 0 : _h.joinType) ? e.property.filterOptions.joinType : 'INNER',
10341
+ operator: ((_k = (_j = e.property) === null || _j === void 0 ? void 0 : _j.filterOptions) === null || _k === void 0 ? void 0 : _k.operator) ? e.property.filterOptions.operator : null,
10342
+ truncateDate: ((_m = (_l = e.property) === null || _l === void 0 ? void 0 : _l.filterOptions) === null || _m === void 0 ? void 0 : _m.truncateDate) ? e.property.filterOptions.truncateDate : true
10343
+ }
10333
10344
  });
10334
10345
  }
10335
10346
  this.onValueChange.emit(e);
10336
10347
  }
10337
10348
  handleItemRemoveClick(item) {
10338
- this._editors.forEach(e => {
10349
+ this._editors.forEach((e) => {
10339
10350
  if (e.property.property.name == item.name) {
10340
10351
  e.clear();
10341
10352
  }
@@ -10348,7 +10359,7 @@ class AXSearchBarComponent {
10348
10359
  this.onSearchValue.emit(this._filterItems);
10349
10360
  }
10350
10361
  clear() {
10351
- this._editors.forEach(e => {
10362
+ this._editors.forEach((e) => {
10352
10363
  e.clear();
10353
10364
  });
10354
10365
  this._filterItems = [];
@@ -10381,8 +10392,7 @@ class AXSearchBarComponent {
10381
10392
  }
10382
10393
  return className.toString().replace(/,/, ' ');
10383
10394
  }
10384
- ngOnInit() {
10385
- }
10395
+ ngOnInit() { }
10386
10396
  }
10387
10397
  AXSearchBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXSearchBarComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
10388
10398
  AXSearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXSearchBarComponent, selector: "ax-search-bar", inputs: { size: "size", disabled: "disabled", items: "items", rtl: "rtl" }, outputs: { onValueChange: "onValueChange", onSearchValue: "onSearchValue" }, viewQueries: [{ propertyName: "dropdown", first: true, predicate: ["dropdown"], descendants: true, static: true }, { propertyName: "_editors", predicate: AXPropertyEditorRendererDirective, descendants: true }], ngImport: i0, template: "<ax-drop-down [fitParent]=\"true\" [size]=\"size\" [showDropDownButton]=\"false\" icon=\"far fa-sliders-h\" #dropdown\r\n maxHeight=\"unset\">\r\n <ng-container start>\r\n <ng-content select=\"[start]\">\r\n </ng-content>\r\n </ng-container>\r\n <ng-container header>\r\n <div class=\"ax chips-container\">\r\n <div class=\"chips\" *ngFor=\"let item of _filterItems\">\r\n <span class=\"chips-text\">\r\n <b>{{item.title}} :</b> {{item.value}}\r\n </span>\r\n <span class=\"close-icon\" (click)=\"handleItemRemoveClick(item)\">\r\n <i class=\"far fa-times close\"></i>\r\n </span>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container panel>\r\n <div class=\"panel-box\">\r\n <div *ngFor=\"let item of _items\" class=\"row\">\r\n <div *ngFor=\"let prop of item.items\" class=\"{{renderCol(prop.property.col)}}\">\r\n <!-- <ax-form-group> -->\r\n <div *ngIf=\"prop.property.visible != false\">\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [property]=\"prop\" [context]=\"_context\"\r\n (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n <!-- </ax-form-group> -->\r\n </div>\r\n </div>\r\n <div class=\"footer-button\">\r\n <ax-button (click)=\"search()\">{{'common.search' | trans}}</ax-button>\r\n <ax-button type=\"blank danger\" (click)=\"clear()\">{{'dataGrid.clearFilter' | trans}}</ax-button>\r\n </div>\r\n </div>\r\n </ng-container>\r\n <ng-container end>\r\n <ax-button end icon=\"far fa-sliders-h icon\" type=\"light blank\" [disabled]=\"disabled\" [size]=\"size\"\r\n [tabIndex]=\"-1\" (click)=\"handleButtonClick()\">{{'common.search' | trans}}</ax-button>\r\n </ng-container>\r\n\r\n</ax-drop-down>\r\n", styles: [".ax.chips-container{height:100%}.panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}\n"], components: [{ type: AXDropdownComponent, selector: "ax-drop-down", inputs: ["rtl", "readonly", "loading"], outputs: ["dropdownToggle", "onButtonClick"] }, { type: AXLabelComponent, selector: "ax-label", inputs: ["size"] }, { type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }], directives: [{ type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: AXPropertyEditorRendererDirective, selector: "[ax-property-editor-renderer]", inputs: ["property", "validationForm", "context", "host", "groupId"], outputs: ["onValueChange"] }], pipes: { "trans": i1$2.AXTranslatorPipe } });
@@ -10467,7 +10477,7 @@ class AXPropertyDecorator {
10467
10477
  // @dynamic
10468
10478
  class AXPropertyDecorators {
10469
10479
  static register(cls, property, options) {
10470
- const item = AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);
10480
+ const item = AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);
10471
10481
  if (item) {
10472
10482
  item.options = options;
10473
10483
  }
@@ -10476,14 +10486,14 @@ class AXPropertyDecorators {
10476
10486
  }
10477
10487
  }
10478
10488
  static has(cls, property) {
10479
- return AXPropertyDecorators.REGISTRY.some(c => c.cls === cls && c.property === property);
10489
+ return AXPropertyDecorators.REGISTRY.some((c) => c.cls === cls && c.property === property);
10480
10490
  }
10481
10491
  static get(cls, property) {
10482
- return AXPropertyDecorators.REGISTRY.find(c => c.cls === cls && c.property === property);
10492
+ return AXPropertyDecorators.REGISTRY.find((c) => c.cls === cls && c.property === property);
10483
10493
  }
10484
10494
  static isValid(property) {
10485
10495
  if (property) {
10486
- return AXPropertyDecorators.REGISTRY.some(c => c.property === property);
10496
+ return AXPropertyDecorators.REGISTRY.some((c) => c.property === property);
10487
10497
  }
10488
10498
  return false;
10489
10499
  }
@@ -10495,7 +10505,7 @@ class AXPropertyDecorators {
10495
10505
  p.push(superClass.constructor);
10496
10506
  superClass = Object.getPrototypeOf(superClass);
10497
10507
  }
10498
- list.push(...AXPropertyDecorators.REGISTRY.filter(c => p.includes(c.cls.constructor)));
10508
+ list.push(...AXPropertyDecorators.REGISTRY.filter((c) => p.includes(c.cls.constructor)));
10499
10509
  return list;
10500
10510
  }
10501
10511
  }
@@ -13536,7 +13546,8 @@ class AXTabPageHostComponent {
13536
13546
  var _a, _b;
13537
13547
  const func = (_b = (_a = this.componentRef) === null || _a === void 0 ? void 0 : _a.instance) === null || _b === void 0 ? void 0 : _b.onActivated;
13538
13548
  if (func) {
13539
- func();
13549
+ const f = func.bind(this.componentRef.instance);
13550
+ f();
13540
13551
  }
13541
13552
  }
13542
13553
  ngAfterViewInit() {