@acorex/components 5.1.7 → 5.1.10

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.
@@ -102,7 +102,7 @@ AXToolbarSchedulerNavigatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVers
102
102
  <ax-popover target="#nav" placement="bottom-end" alignment="top-end" #pop>
103
103
  <ax-calendar-box (onValueChanged)="onDateChange($event)" [depth]="viewDepth" #cal></ax-calendar-box>
104
104
  </ax-popover>
105
- </div>`, isInline: true, components: [{ type: i1.AXToolbarMenuComponent, selector: "ax-toolbar-menu", inputs: ["menuTemplate", "selection", "items"], outputs: ["onItemClick"] }, { type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openMode", "closeMode", "visible"] }, { type: i3.AXCalendarBoxComponent, selector: "ax-calendar-box", inputs: ["size", "type", "locale", "dir", "min", "max", "selectableHoliday", "dayStyle", "dayMinMaxResoan", "showTodayButton", "view", "depth", "value"], outputs: ["onValueChanged", "onClick", "valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
105
+ </div>`, isInline: true, components: [{ type: i1.AXToolbarMenuComponent, selector: "ax-toolbar-menu", inputs: ["menuTemplate", "selection", "items"], outputs: ["onItemClick"] }, { type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openMode", "closeMode", "rtl", "visible"] }, { type: i3.AXCalendarBoxComponent, selector: "ax-calendar-box", inputs: ["size", "type", "locale", "dir", "min", "max", "selectableHoliday", "dayStyle", "dayMinMaxResoan", "showTodayButton", "view", "depth", "value"], outputs: ["onValueChanged", "onClick", "valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
106
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXToolbarSchedulerNavigatorComponent, decorators: [{
107
107
  type: Component,
108
108
  args: [{
@@ -34,7 +34,8 @@ export class AXOverlayService {
34
34
  }
35
35
  let positionStrategy;
36
36
  if (configs.position && configs.targetElement) {
37
- positionStrategy = this.overlayService.position()
37
+ positionStrategy = this.overlayService
38
+ .position()
38
39
  .flexibleConnectedTo(configs.targetElement)
39
40
  .withPositions(Array.isArray(configs.position) ? configs.position : [configs.position])
40
41
  .withPush(true);
@@ -51,7 +52,7 @@ export class AXOverlayService {
51
52
  scrollStrategy,
52
53
  hasBackdrop: configs.hasBackdrop,
53
54
  disposeOnNavigation: true,
54
- backdropClass: configs.backdropClass ? configs.backdropClass : (configs.transparentBackdrop ? 'cdk-overlay-transparent-backdrop' : undefined),
55
+ backdropClass: configs.backdropClass ? configs.backdropClass : configs.transparentBackdrop ? 'cdk-overlay-transparent-backdrop' : undefined,
55
56
  panelClass: configs.panelClass ? configs.panelClass : ['animate__animated', 'animate__fadeIn']
56
57
  };
57
58
  // joon nanat dorost sho
@@ -63,6 +64,8 @@ export class AXOverlayService {
63
64
  host.changeDetectorRef.detectChanges();
64
65
  }, 0);
65
66
  }
67
+ if (configs.direction)
68
+ overlayRef.setDirection(configs.direction);
66
69
  if (configs.closeOnClickOutside) {
67
70
  merge(overlayRef.backdropClick(), overlayRef.detachments()).subscribe(() => {
68
71
  overlayRef.dispose();
@@ -84,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
84
87
  type: Injectable,
85
88
  args: [{ providedIn: 'root' }]
86
89
  }], ctorParameters: function () { return [{ type: i1.DynamicOverlay }, { type: i2.Overlay }, { type: i0.ApplicationRef }]; } });
87
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ApplicationRef, ViewContainerRef, TemplateRef, EventEmitter } from '@angular/core';\r\nimport { Overlay, PositionStrategy, ScrollStrategy } from '@angular/cdk/overlay';\r\nimport { TemplatePortal, Portal, ComponentPortal } from '@angular/cdk/portal';\r\nimport { AXConnectedPosition } from '@acorex/core';\r\nimport { merge } from 'rxjs';\r\nimport { DynamicOverlay } from './custom-cdk-overlay.service';\r\n\r\nexport interface AXOverlayViewRef {\r\n    instance: any;\r\n    dispose: () => void;\r\n}\r\n\r\nexport interface AXOverlayConfigs {\r\n    position?: AXConnectedPosition | AXConnectedPosition[];\r\n    hasBackdrop?: boolean;\r\n    transparentBackdrop?: boolean;\r\n    closeOnClickOutside?: boolean;\r\n    targetElement?: HTMLElement;\r\n    containerElement?: HTMLElement;\r\n    onBackdropClick?: () => void;\r\n    panelClass?: string[] | string;\r\n    backdropClass?: string[] | string;\r\n    scroll?: 'auto' | 'block';\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXOverlayService {\r\n    constructor(\r\n        private overlayService: DynamicOverlay,\r\n        private overlayService2: Overlay,\r\n        private appRef: ApplicationRef) {\r\n\r\n    }\r\n\r\n    show(content: any, context?: any, configs?: AXOverlayConfigs): AXOverlayViewRef {\r\n        configs = Object.assign({\r\n            hasBackdrop: true,\r\n            transparentBackdrop: true,\r\n            closeOnClickOutside: true\r\n        }, configs || {});\r\n        // get root viewref\r\n        const viewRef: ViewContainerRef = this.appRef.components[0].instance.viewRef;\r\n\r\n        let portal: Portal<any>;\r\n        // get component by route\r\n        if (typeof content === 'string') {\r\n            // TODO\r\n        }\r\n        // create portal from component\r\n        else if (content instanceof TemplateRef) {\r\n            portal = new TemplatePortal(content, viewRef, context);\r\n        }\r\n        else if (typeof content === 'function') {\r\n            portal = new ComponentPortal(content, viewRef);\r\n        }\r\n        let positionStrategy: PositionStrategy;\r\n        if (configs.position && configs.targetElement) {\r\n            positionStrategy = this.overlayService.position()\r\n                .flexibleConnectedTo(configs.targetElement)\r\n                .withPositions(\r\n                    Array.isArray(configs.position) ? configs.position : [configs.position]\r\n                )\r\n                .withPush(true);\r\n        }\r\n        else {\r\n            positionStrategy = this.overlayService.position().global().centerHorizontally().centerVertically();\r\n        }\r\n        let scrollStrategy: ScrollStrategy = this.overlayService.scrollStrategies.reposition({ autoClose: true });\r\n        if (configs.scroll === 'block') {\r\n            scrollStrategy = this.overlayService.scrollStrategies.block();\r\n        }\r\n\r\n        const config = {\r\n            positionStrategy,\r\n            scrollStrategy,\r\n            hasBackdrop: configs.hasBackdrop,\r\n            disposeOnNavigation: true,\r\n            backdropClass: configs.backdropClass ? configs.backdropClass : (configs.transparentBackdrop ? 'cdk-overlay-transparent-backdrop' : undefined),\r\n            panelClass: configs.panelClass ? configs.panelClass : ['animate__animated', 'animate__fadeIn']\r\n        };\r\n        // joon nanat dorost sho\r\n        let overlayRef = configs.containerElement ? this.overlayService.createOn(configs.containerElement, config) : this.overlayService2.create(config);\r\n\r\n        const host = overlayRef.attach(portal);\r\n        if (host.instance) {\r\n            Object.assign(host.instance, context);\r\n            setTimeout(() => {\r\n                host.changeDetectorRef.detectChanges();\r\n            }, 0);\r\n        }\r\n        if (configs.closeOnClickOutside) {\r\n            merge(\r\n                overlayRef.backdropClick() as any,\r\n                overlayRef.detachments() as any,\r\n            ).subscribe(() => {\r\n                overlayRef.dispose();\r\n                overlayRef = undefined;\r\n                if (configs.onBackdropClick) {\r\n                    configs.onBackdropClick();\r\n                }\r\n            });\r\n\r\n        }\r\n        return {\r\n            instance: host.instance,\r\n            dispose: overlayRef.dispose.bind(overlayRef)\r\n        };\r\n    }\r\n\r\n}"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ApplicationRef, ViewContainerRef, TemplateRef, EventEmitter } from '@angular/core';\r\nimport { Overlay, PositionStrategy, ScrollStrategy } from '@angular/cdk/overlay';\r\nimport { TemplatePortal, Portal, ComponentPortal } from '@angular/cdk/portal';\r\nimport { AXConnectedPosition } from '@acorex/core';\r\nimport { merge } from 'rxjs';\r\nimport { DynamicOverlay } from './custom-cdk-overlay.service';\r\n\r\nexport interface AXOverlayViewRef {\r\n  instance: any;\r\n  dispose: () => void;\r\n}\r\n\r\nexport interface AXOverlayConfigs {\r\n  position?: AXConnectedPosition | AXConnectedPosition[];\r\n  hasBackdrop?: boolean;\r\n  transparentBackdrop?: boolean;\r\n  closeOnClickOutside?: boolean;\r\n  targetElement?: HTMLElement;\r\n  containerElement?: HTMLElement;\r\n  onBackdropClick?: () => void;\r\n  panelClass?: string[] | string;\r\n  backdropClass?: string[] | string;\r\n  scroll?: 'auto' | 'block';\r\n  direction?: 'rtl' | 'ltr';\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class AXOverlayService {\r\n  constructor(private overlayService: DynamicOverlay, private overlayService2: Overlay, private appRef: ApplicationRef) {}\r\n\r\n  show(content: any, context?: any, configs?: AXOverlayConfigs): AXOverlayViewRef {\r\n    configs = Object.assign(\r\n      {\r\n        hasBackdrop: true,\r\n        transparentBackdrop: true,\r\n        closeOnClickOutside: true\r\n      },\r\n      configs || {}\r\n    );\r\n    // get root viewref\r\n    const viewRef: ViewContainerRef = this.appRef.components[0].instance.viewRef;\r\n\r\n    let portal: Portal<any>;\r\n    // get component by route\r\n    if (typeof content === 'string') {\r\n      // TODO\r\n    }\r\n    // create portal from component\r\n    else if (content instanceof TemplateRef) {\r\n      portal = new TemplatePortal(content, viewRef, context);\r\n    } else if (typeof content === 'function') {\r\n      portal = new ComponentPortal(content, viewRef);\r\n    }\r\n    let positionStrategy: PositionStrategy;\r\n    if (configs.position && configs.targetElement) {\r\n      positionStrategy = this.overlayService\r\n        .position()\r\n        .flexibleConnectedTo(configs.targetElement)\r\n        .withPositions(Array.isArray(configs.position) ? configs.position : [configs.position])\r\n        .withPush(true);\r\n    } else {\r\n      positionStrategy = this.overlayService.position().global().centerHorizontally().centerVertically();\r\n    }\r\n    let scrollStrategy: ScrollStrategy = this.overlayService.scrollStrategies.reposition({ autoClose: true });\r\n    if (configs.scroll === 'block') {\r\n      scrollStrategy = this.overlayService.scrollStrategies.block();\r\n    }\r\n\r\n    const config = {\r\n      positionStrategy,\r\n      scrollStrategy,\r\n      hasBackdrop: configs.hasBackdrop,\r\n      disposeOnNavigation: true,\r\n      backdropClass: configs.backdropClass ? configs.backdropClass : configs.transparentBackdrop ? 'cdk-overlay-transparent-backdrop' : undefined,\r\n      panelClass: configs.panelClass ? configs.panelClass : ['animate__animated', 'animate__fadeIn']\r\n    };\r\n    // joon nanat dorost sho\r\n    let overlayRef = configs.containerElement ? this.overlayService.createOn(configs.containerElement, config) : this.overlayService2.create(config);\r\n\r\n    const host = overlayRef.attach(portal);\r\n    if (host.instance) {\r\n      Object.assign(host.instance, context);\r\n      setTimeout(() => {\r\n        host.changeDetectorRef.detectChanges();\r\n      }, 0);\r\n    }\r\n    if (configs.direction) overlayRef.setDirection(configs.direction);\r\n    if (configs.closeOnClickOutside) {\r\n      merge(overlayRef.backdropClick() as any, overlayRef.detachments() as any).subscribe(() => {\r\n        overlayRef.dispose();\r\n        overlayRef = undefined;\r\n        if (configs.onBackdropClick) {\r\n          configs.onBackdropClick();\r\n        }\r\n      });\r\n    }\r\n    return {\r\n      instance: host.instance,\r\n      dispose: overlayRef.dispose.bind(overlayRef)\r\n    };\r\n  }\r\n}\r\n"]}
@@ -1,17 +1,21 @@
1
1
  import { Component, Input, NgZone, ChangeDetectorRef, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, TemplateRef } from '@angular/core';
2
+ import { ElementRef } from '@angular/core';
2
3
  import { AXOverlayService } from './overlay.service';
4
+ import { AXConfig } from '@acorex/core';
3
5
  import * as i0 from "@angular/core";
4
6
  import * as i1 from "./overlay.service";
5
7
  export class AXPopoverComponent {
6
- constructor(overlayService, zone, cdr) {
8
+ constructor(overlayService, zone, ref, cdr) {
7
9
  this.overlayService = overlayService;
8
10
  this.zone = zone;
11
+ this.ref = ref;
9
12
  this.cdr = cdr;
10
13
  //
11
14
  this.openMode = 'manual';
12
15
  //
13
16
  this.closeMode = 'clickout';
14
17
  //
18
+ this.rtl = AXConfig.get('layout.rtl');
15
19
  this._visible = false;
16
20
  }
17
21
  get visible() {
@@ -52,6 +56,7 @@ export class AXPopoverComponent {
52
56
  targetElement: this.targetEl,
53
57
  hasBackdrop: this.closeMode === 'clickout',
54
58
  position: this.position,
59
+ direction: this.rtl ? 'rtl' : 'ltr',
55
60
  onBackdropClick: () => {
56
61
  this._visible = false;
57
62
  }
@@ -62,6 +67,11 @@ export class AXPopoverComponent {
62
67
  this.overlay.dispose();
63
68
  }
64
69
  }
70
+ ngOnInit() {
71
+ if (this.rtl == null) {
72
+ this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';
73
+ }
74
+ }
65
75
  ngAfterViewInit() {
66
76
  setTimeout(() => {
67
77
  this.targetEl = typeof this.target === 'string' ? document.querySelector(this.target) : this.target;
@@ -89,12 +99,12 @@ export class AXPopoverComponent {
89
99
  return this.visible;
90
100
  }
91
101
  }
92
- AXPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXPopoverComponent, deps: [{ token: i1.AXOverlayService }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
93
- AXPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXPopoverComponent, selector: "ax-popover", inputs: { target: "target", position: "position", openMode: "openMode", closeMode: "closeMode", visible: "visible" }, viewQueries: [{ propertyName: "template", first: true, predicate: ["tpl"], descendants: true }], ngImport: i0, template: "<ng-template #tpl>\r\n <div class=\"ax-popover-container animate__animated animate__fadeIn\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".ax-popover-container .ax-popover-container-bordered{background:var(--ax-white-color);border:1px solid;border-color:var(--ax-border-color);border-radius:var(--ax-border-radius-size);box-shadow:0 5px 10px #0000004d}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
102
+ AXPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXPopoverComponent, deps: [{ token: i1.AXOverlayService }, { token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
103
+ AXPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXPopoverComponent, selector: "ax-popover", inputs: { target: "target", position: "position", openMode: "openMode", closeMode: "closeMode", rtl: "rtl", visible: "visible" }, viewQueries: [{ propertyName: "template", first: true, predicate: ["tpl"], descendants: true }], ngImport: i0, template: "<ng-template #tpl>\r\n <div class=\"ax-popover-container animate__animated animate__fadeIn\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".ax-popover-container .ax-popover-container-bordered{background:var(--ax-white-color);border:1px solid;border-color:var(--ax-border-color);border-radius:var(--ax-border-radius-size);box-shadow:0 5px 10px #0000004d}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
94
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXPopoverComponent, decorators: [{
95
105
  type: Component,
96
106
  args: [{ selector: 'ax-popover', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template #tpl>\r\n <div class=\"ax-popover-container animate__animated animate__fadeIn\">\r\n <ng-content></ng-content>\r\n </div>\r\n</ng-template>", styles: [".ax-popover-container .ax-popover-container-bordered{background:var(--ax-white-color);border:1px solid;border-color:var(--ax-border-color);border-radius:var(--ax-border-radius-size);box-shadow:0 5px 10px #0000004d}\n"] }]
97
- }], ctorParameters: function () { return [{ type: i1.AXOverlayService }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { template: [{
107
+ }], ctorParameters: function () { return [{ type: i1.AXOverlayService }, { type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { template: [{
98
108
  type: ViewChild,
99
109
  args: ['tpl']
100
110
  }], target: [{
@@ -109,7 +119,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
109
119
  }], closeMode: [{
110
120
  type: Input,
111
121
  args: ['closeMode']
122
+ }], rtl: [{
123
+ type: Input
112
124
  }], visible: [{
113
125
  type: Input
114
126
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/popover.component.ts","../../../../../../projects/acorex/components/src/lib/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgZone, ChangeDetectorRef, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, TemplateRef } from '@angular/core';\r\nimport { ElementRef } from '@angular/core';\r\nimport { AXOverlayService, AXOverlayViewRef } from './overlay.service';\r\nimport { AXConnectedPosition } from '@acorex/core';\r\n\r\n\r\n@Component({\r\n  selector: 'ax-popover',\r\n  templateUrl: './popover.component.html',\r\n  styleUrls: ['./popover.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXPopoverComponent {\r\n  constructor(\r\n    private overlayService: AXOverlayService,\r\n    private zone: NgZone,\r\n    private cdr: ChangeDetectorRef) {\r\n\r\n  }\r\n  //\r\n  private targetEl: HTMLElement;\r\n  private overlay: AXOverlayViewRef;\r\n  @ViewChild('tpl')\r\n  private template: TemplateRef<any>;\r\n  //\r\n  @Input('target') target: string | HTMLElement;\r\n  //\r\n  @Input('position') position: AXConnectedPosition;\r\n  //\r\n  @Input('openMode') openMode: 'manual' | 'click' | 'hover' = 'manual';\r\n  //\r\n  @Input('closeMode') closeMode: 'manual' | 'clickout' | 'mouseout' = 'clickout';\r\n  //\r\n  private _visible: boolean = false;\r\n  @Input()\r\n  public get visible(): boolean {\r\n    return this._visible;\r\n  }\r\n  public set visible(v: boolean) {\r\n    if (v !== this._visible) {\r\n      if (v) {\r\n        this.internalShow();\r\n      } else {\r\n        this.internalHide();\r\n      }\r\n      this._visible = v;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n  //\r\n  toggle() {\r\n    this.visible = !this.visible;\r\n  }\r\n\r\n  close() {\r\n    this.zone.run(() => {\r\n      this.visible = false;\r\n    });\r\n  }\r\n\r\n  open() {\r\n    this.zone.run(() => {\r\n      this.visible = true;\r\n    });\r\n  }\r\n\r\n  private internalShow() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this.overlay = this.overlayService.show(this.template, {}, {\r\n      closeOnClickOutside: this.closeMode === 'clickout',\r\n      targetElement: this.targetEl,\r\n      hasBackdrop: this.closeMode === 'clickout',\r\n      position: this.position,\r\n      onBackdropClick: () => {\r\n        this._visible = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  private internalHide() {\r\n    if (this.overlay) {\r\n      this.overlay.dispose();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.targetEl = typeof this.target === 'string' ? document.querySelector<HTMLElement>(this.target) : this.target;\r\n      //\r\n      if (this.closeMode === 'mouseout') {\r\n        this.targetEl.addEventListener('mouseout', this.close.bind(this));\r\n      }\r\n      if (this.openMode === 'hover' && this.targetEl) {\r\n        this.targetEl.addEventListener('mouseover', this.open.bind(this));\r\n      }\r\n      //\r\n      if (this.openMode === 'click' && this.targetEl) {\r\n        this.targetEl.addEventListener('click', this.open.bind(this));\r\n      }\r\n    }, 100);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.openMode === 'click' && this.targetEl) {\r\n      this.targetEl.removeEventListener('mouseover', this.open.bind(this));\r\n      this.targetEl.removeEventListener('click', this.open.bind(this));\r\n      this.targetEl.removeEventListener('mouseout', this.open.bind(this));\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this.visible;\r\n  }\r\n}\r\n","<ng-template #tpl>\r\n  <div class=\"ax-popover-container animate__animated animate__fadeIn\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n</ng-template>"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/popover/popover.component.ts","../../../../../../projects/acorex/components/src/lib/popover/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgZone, ChangeDetectorRef, ChangeDetectionStrategy, ViewEncapsulation, ViewChild, TemplateRef } from '@angular/core';\r\nimport { ElementRef } from '@angular/core';\r\nimport { AXOverlayService, AXOverlayViewRef } from './overlay.service';\r\nimport { AXConfig, AXConnectedPosition } from '@acorex/core';\r\n\r\n@Component({\r\n  selector: 'ax-popover',\r\n  templateUrl: './popover.component.html',\r\n  styleUrls: ['./popover.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class AXPopoverComponent {\r\n  constructor(\r\n    private overlayService: AXOverlayService,\r\n    private zone: NgZone,\r\n    private ref: ElementRef<HTMLDivElement>,\r\n    private cdr: ChangeDetectorRef\r\n  ) {}\r\n  //\r\n  private targetEl: HTMLElement;\r\n  private overlay: AXOverlayViewRef;\r\n  @ViewChild('tpl')\r\n  private template: TemplateRef<any>;\r\n  //\r\n  @Input('target') target: string | HTMLElement;\r\n  //\r\n  @Input('position') position: AXConnectedPosition;\r\n  //\r\n  @Input('openMode') openMode: 'manual' | 'click' | 'hover' = 'manual';\r\n  //\r\n  @Input('closeMode') closeMode: 'manual' | 'clickout' | 'mouseout' = 'clickout';\r\n  //\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  private _visible: boolean = false;\r\n  @Input()\r\n  public get visible(): boolean {\r\n    return this._visible;\r\n  }\r\n  public set visible(v: boolean) {\r\n    if (v !== this._visible) {\r\n      if (v) {\r\n        this.internalShow();\r\n      } else {\r\n        this.internalHide();\r\n      }\r\n      this._visible = v;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n  //\r\n  toggle() {\r\n    this.visible = !this.visible;\r\n  }\r\n\r\n  close() {\r\n    this.zone.run(() => {\r\n      this.visible = false;\r\n    });\r\n  }\r\n\r\n  open() {\r\n    this.zone.run(() => {\r\n      this.visible = true;\r\n    });\r\n  }\r\n\r\n  private internalShow() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this.overlay = this.overlayService.show(\r\n      this.template,\r\n      {},\r\n      {\r\n        closeOnClickOutside: this.closeMode === 'clickout',\r\n        targetElement: this.targetEl,\r\n        hasBackdrop: this.closeMode === 'clickout',\r\n        position: this.position,\r\n        direction: this.rtl ? 'rtl' : 'ltr',\r\n        onBackdropClick: () => {\r\n          this._visible = false;\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  private internalHide() {\r\n    if (this.overlay) {\r\n      this.overlay.dispose();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.rtl == null) {\r\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.targetEl = typeof this.target === 'string' ? document.querySelector<HTMLElement>(this.target) : this.target;\r\n      //\r\n      if (this.closeMode === 'mouseout') {\r\n        this.targetEl.addEventListener('mouseout', this.close.bind(this));\r\n      }\r\n      if (this.openMode === 'hover' && this.targetEl) {\r\n        this.targetEl.addEventListener('mouseover', this.open.bind(this));\r\n      }\r\n      //\r\n      if (this.openMode === 'click' && this.targetEl) {\r\n        this.targetEl.addEventListener('click', this.open.bind(this));\r\n      }\r\n    }, 100);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.openMode === 'click' && this.targetEl) {\r\n      this.targetEl.removeEventListener('mouseover', this.open.bind(this));\r\n      this.targetEl.removeEventListener('click', this.open.bind(this));\r\n      this.targetEl.removeEventListener('mouseout', this.open.bind(this));\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this.visible;\r\n  }\r\n}\r\n","<ng-template #tpl>\r\n  <div class=\"ax-popover-container animate__animated animate__fadeIn\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n</ng-template>"]}
@@ -1,5 +1,5 @@
1
1
  import { AXConfig, AXDateTime } from '@acorex/core';
2
- import { ChangeDetectorRef, Component, EventEmitter, Input, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
2
+ import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
3
3
  import * as _ from 'lodash';
4
4
  import { AXPopoverComponent } from '../popover/popover.component';
5
5
  import { AXPropertyEditorRendererDirective } from '../property-editor/property-editor-renderer.directive';
@@ -13,12 +13,14 @@ import * as i5 from "@angular/common";
13
13
  import * as i6 from "../property-editor/property-editor-renderer.directive";
14
14
  import * as i7 from "@acorex/core";
15
15
  export class AXSearchBarComponent {
16
- constructor(cdr) {
16
+ constructor(cdr, ref) {
17
17
  this.cdr = cdr;
18
- this.size = 'md';
18
+ this.ref = ref;
19
+ this.sizeButton = 'md';
20
+ this.size = 'sm';
19
21
  this.disabled = false;
20
22
  this.fitParent = false;
21
- this.popoverWidth = '60%';
23
+ this.popoverWidth = '65vw';
22
24
  this.rtl = AXConfig.get('layout.rtl');
23
25
  this.loadOnInit = false;
24
26
  this.onValueChange = new EventEmitter();
@@ -52,6 +54,11 @@ export class AXSearchBarComponent {
52
54
  clearItem(name) {
53
55
  this._editors.find((x) => x.property.property.name === name).clear();
54
56
  }
57
+ ngOnInit() {
58
+ if (this.rtl == null) {
59
+ this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';
60
+ }
61
+ }
55
62
  refresh() {
56
63
  this.loadOnInit = true;
57
64
  this._defultValueCount = [];
@@ -214,12 +221,12 @@ export class AXSearchBarComponent {
214
221
  }
215
222
  }
216
223
  }
217
- AXSearchBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXSearchBarComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
218
- AXSearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXSearchBarComponent, selector: "ax-search-bar", inputs: { size: "size", disabled: "disabled", fitParent: "fitParent", popoverWidth: "popoverWidth", rtl: "rtl", loadOnInit: "loadOnInit", items: "items" }, outputs: { onValueChange: "onValueChange", onSearchValue: "onSearchValue" }, viewQueries: [{ propertyName: "searchPopover", first: true, predicate: ["searchPop"], descendants: true }, { propertyName: "form", first: true, predicate: AXValidationFormComponent, descendants: true }, { propertyName: "_editors", predicate: AXPropertyEditorRendererDirective, descendants: true }], ngImport: i0, template: "<div class=\"d-flex align-items-center\">\r\n <ax-button #searchBtnTarget end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"size\" [tabIndex]=\"-1\"\r\n (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n</div>\r\n\r\n<ax-popover #searchPop [target]=\"searchBtnTarget\"\r\n [position]=\"{originX:'center',originY:'bottom',overlayX:'center',overlayY:'top',offsetY:50,offsetX:10}\">\r\n <div class=\"panel-box ax-dropdown-container-bordered\" [ngStyle]=\"{'width' : popoverWidth }\">\r\n <ax-validation-form #form>\r\n <ng-container *ngFor=\"let item of _items\">\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let prop of item.items\">\r\n <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n <div>\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\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 </ax-validation-form>\r\n </div>\r\n</ax-popover>", styles: [".panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}.search-count{background:rgba(255,255,255,.2);border-radius:50%;color:var(--ax-white-color);padding:.125rem;width:1.75rem;height:1.75rem;font-size:.875rem;display:inline-flex;align-items:center;justify-content:center;-webkit-margin-start:.5rem;margin-inline-start:.5rem}\n"], components: [{ type: i1.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openMode", "closeMode", "visible"] }, { type: i3.AXValidationFormComponent, selector: "ax-validation-form", inputs: ["validateOn"], outputs: ["onInit"] }, { type: i4.AXLabelComponent, selector: "ax-label", inputs: ["size"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.AXPropertyEditorRendererDirective, selector: "[ax-property-editor-renderer]", inputs: ["property", "validationForm", "context", "host", "groupId"], outputs: ["onValueChange"] }], pipes: { "trans": i7.AXTranslatorPipe } });
224
+ AXSearchBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXSearchBarComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
225
+ AXSearchBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXSearchBarComponent, selector: "ax-search-bar", inputs: { sizeButton: "sizeButton", size: "size", disabled: "disabled", fitParent: "fitParent", popoverWidth: "popoverWidth", rtl: "rtl", loadOnInit: "loadOnInit", items: "items" }, outputs: { onValueChange: "onValueChange", onSearchValue: "onSearchValue" }, viewQueries: [{ propertyName: "searchPopover", first: true, predicate: ["searchPop"], descendants: true }, { propertyName: "form", first: true, predicate: AXValidationFormComponent, descendants: true }, { propertyName: "_editors", predicate: AXPropertyEditorRendererDirective, descendants: true }], ngImport: i0, template: "<ax-button end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"sizeButton\"\r\n [tabIndex]=\"-1\" (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n\r\n\r\n<ax-popover #searchPop [target]=\"ref\" [rtl]=\"rtl\"\r\n [position]=\"{originX:'start',originY:'bottom',overlayX:'start',overlayY:'top',offsetY:10}\">\r\n <div class=\"panel-box ax-dropdown-container-bordered {{size}}\">\r\n <ax-validation-form #form>\r\n <ng-container *ngFor=\"let item of _items\">\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let prop of item.items\">\r\n <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n <div>\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\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 </ax-validation-form>\r\n </div>\r\n</ax-popover>", styles: [".panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}.panel-box.sm{width:30vw}.panel-box.md{width:50vw}.panel-box.lg{width:70vw}.panel-box.full{width:90vw}@media all and (min-width: 1280px){.panel-box.sm{width:420px!important}.panel-box.md{width:680px!important}.panel-box.lg{width:1024px!important}}@media all and (min-width: 1024px) and (max-width: 1279px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md{width:500px!important}.panel-box.lg{width:900px!important}}@media all and (min-width: 768px) and (max-width: 1023px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md{width:500px!important}.panel-box.lg{width:700px!important}}@media all and (min-width: 425px) and (max-width: 767px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md,.panel-box.lg{width:460px!important}}@media all and (min-width: 0px) and (max-width: 424px){.panel-box.sm,.panel-box.md,.panel-box.lg{width:100vw;max-height:100vh}}.search-count{background:rgba(255,255,255,.2);border-radius:50%;color:var(--ax-white-color);padding:.125rem;width:1.75rem;height:1.75rem;font-size:.875rem;display:inline-flex;align-items:center;justify-content:center;-webkit-margin-start:.5rem;margin-inline-start:.5rem}\n"], components: [{ type: i1.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openMode", "closeMode", "rtl", "visible"] }, { type: i3.AXValidationFormComponent, selector: "ax-validation-form", inputs: ["validateOn"], outputs: ["onInit"] }, { type: i4.AXLabelComponent, selector: "ax-label", inputs: ["size"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.AXPropertyEditorRendererDirective, selector: "[ax-property-editor-renderer]", inputs: ["property", "validationForm", "context", "host", "groupId"], outputs: ["onValueChange"] }], pipes: { "trans": i7.AXTranslatorPipe } });
219
226
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXSearchBarComponent, decorators: [{
220
227
  type: Component,
221
- args: [{ selector: 'ax-search-bar', template: "<div class=\"d-flex align-items-center\">\r\n <ax-button #searchBtnTarget end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"size\" [tabIndex]=\"-1\"\r\n (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n</div>\r\n\r\n<ax-popover #searchPop [target]=\"searchBtnTarget\"\r\n [position]=\"{originX:'center',originY:'bottom',overlayX:'center',overlayY:'top',offsetY:50,offsetX:10}\">\r\n <div class=\"panel-box ax-dropdown-container-bordered\" [ngStyle]=\"{'width' : popoverWidth }\">\r\n <ax-validation-form #form>\r\n <ng-container *ngFor=\"let item of _items\">\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let prop of item.items\">\r\n <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n <div>\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\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 </ax-validation-form>\r\n </div>\r\n</ax-popover>", styles: [".panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}.search-count{background:rgba(255,255,255,.2);border-radius:50%;color:var(--ax-white-color);padding:.125rem;width:1.75rem;height:1.75rem;font-size:.875rem;display:inline-flex;align-items:center;justify-content:center;-webkit-margin-start:.5rem;margin-inline-start:.5rem}\n"] }]
222
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { searchPopover: [{
228
+ args: [{ selector: 'ax-search-bar', template: "<ax-button end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"sizeButton\"\r\n [tabIndex]=\"-1\" (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n\r\n\r\n<ax-popover #searchPop [target]=\"ref\" [rtl]=\"rtl\"\r\n [position]=\"{originX:'start',originY:'bottom',overlayX:'start',overlayY:'top',offsetY:10}\">\r\n <div class=\"panel-box ax-dropdown-container-bordered {{size}}\">\r\n <ax-validation-form #form>\r\n <ng-container *ngFor=\"let item of _items\">\r\n <div class=\"row\">\r\n <ng-container *ngFor=\"let prop of item.items\">\r\n <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n <div>\r\n <ax-label>{{prop.property.title}}</ax-label>\r\n <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n </div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </ng-container>\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 </ax-validation-form>\r\n </div>\r\n</ax-popover>", styles: [".panel-box{padding:1rem}.panel-box .footer-button{margin-top:1rem;display:flex;align-items:center;gap:.5rem}.panel-box.sm{width:30vw}.panel-box.md{width:50vw}.panel-box.lg{width:70vw}.panel-box.full{width:90vw}@media all and (min-width: 1280px){.panel-box.sm{width:420px!important}.panel-box.md{width:680px!important}.panel-box.lg{width:1024px!important}}@media all and (min-width: 1024px) and (max-width: 1279px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md{width:500px!important}.panel-box.lg{width:900px!important}}@media all and (min-width: 768px) and (max-width: 1023px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md{width:500px!important}.panel-box.lg{width:700px!important}}@media all and (min-width: 425px) and (max-width: 767px){.panel-box.sm{width:100vw;max-height:100vh}.panel-box.md,.panel-box.lg{width:460px!important}}@media all and (min-width: 0px) and (max-width: 424px){.panel-box.sm,.panel-box.md,.panel-box.lg{width:100vw;max-height:100vh}}.search-count{background:rgba(255,255,255,.2);border-radius:50%;color:var(--ax-white-color);padding:.125rem;width:1.75rem;height:1.75rem;font-size:.875rem;display:inline-flex;align-items:center;justify-content:center;-webkit-margin-start:.5rem;margin-inline-start:.5rem}\n"] }]
229
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { searchPopover: [{
223
230
  type: ViewChild,
224
231
  args: ['searchPop']
225
232
  }], _editors: [{
@@ -228,6 +235,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
228
235
  }], form: [{
229
236
  type: ViewChild,
230
237
  args: [AXValidationFormComponent]
238
+ }], sizeButton: [{
239
+ type: Input
231
240
  }], size: [{
232
241
  type: Input
233
242
  }], disabled: [{
@@ -247,4 +256,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
247
256
  }], onSearchValue: [{
248
257
  type: Output
249
258
  }] } });
250
- //# 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, AXDateTime } from '@acorex/core';\r\nimport { ChangeDetectorRef, Component, EventEmitter, Input, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';\r\nimport * as _ from 'lodash';\r\nimport { AXElementSize } from '../base/element.class';\r\nimport { AXPopoverComponent } from '../popover/popover.component';\r\nimport { AXPropertyEditorRendererDirective } from '../property-editor/property-editor-renderer.directive';\r\nimport { AXPropertyColDef, AXPropertyConfig, AXProperyEditorValueChangeEvent, FilterModel } from '../property-editor/property-editor.class';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\n\r\nexport interface FilterTextItemsModel {\r\n  name: string;\r\n  title: string;\r\n  value: any;\r\n  textValue: string;\r\n  filterOptions?: FilterModel;\r\n  component: AXPropertyConfig;\r\n  uniqueNumber?: number;\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 {\r\n  constructor(private cdr: ChangeDetectorRef) {}\r\n\r\n  @ViewChild('searchPop') searchPopover: AXPopoverComponent;\r\n  @ViewChildren(AXPropertyEditorRendererDirective) _editors: QueryList<AXPropertyEditorRendererDirective>;\r\n  @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\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  fitParent: boolean = false;\r\n\r\n  @Input()\r\n  popoverWidth: string = '60%';\r\n\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  @Input()\r\n  loadOnInit: boolean = false;\r\n\r\n  @Input()\r\n  public set items(v: AXPropertyConfig[]) {\r\n    this._defultValueCount = v.filter((x) => x.value);\r\n    v.forEach((el) => {\r\n      el.property.uniqueNumber = Math.random();\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          textValue: this._handleTextValue(el),\r\n          value: el.value ? this._handleDefultVlaue(el) : null,\r\n          component: el\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  @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  _defultValueCount: any = [];\r\n  _context: any = {};\r\n  _isEmitted: boolean = false;\r\n  public clearItem(name: string) {\r\n    this._editors.find((x) => x.property.property.name === name).clear();\r\n  }\r\n\r\n  public refresh() {\r\n    this.loadOnInit = true;\r\n    this._defultValueCount = [];\r\n    this._filterItems = [];\r\n    this._filterItemsClone = [];\r\n    this.items = this._items[0].items;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  handleButtonClick() {\r\n    this.searchPopover.open();\r\n  }\r\n\r\n  async handleValueChange(e: AXProperyEditorValueChangeEvent) {\r\n    await this._handleInitVlaue(e);\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  public search() {\r\n    this.form.validate().then((c) => {\r\n      if (c.result) {\r\n        this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n        this.searchPopover.close();\r\n        this.onSearchValue.emit(this._filterItems);\r\n      }\r\n    });\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.searchPopover.close();\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(/,/g, ' ');\r\n  }\r\n\r\n  _handleShowTitleSelected(item) {\r\n    if (item.title) {\r\n      return item.title + ':';\r\n    }\r\n  }\r\n\r\n  _handleShowValueSelected(item) {\r\n    if (item.component.property.editorClass === 'ax/editors/check') {\r\n      return item.component.property.editorOptions.label;\r\n    } else {\r\n      return item.textValue;\r\n    }\r\n  }\r\n\r\n  private _handleTextValue(dataItem: any) {\r\n    let text = '';\r\n    if (Array.isArray(dataItem.value)) {\r\n      if (dataItem.value.length) {\r\n        dataItem.value.forEach((element, index) => {\r\n          text +=\r\n            index === dataItem.value.length - 1\r\n              ? element[dataItem.property.editorOptions.textField]\r\n              : element[dataItem.property.editorOptions.textField] + ',';\r\n        });\r\n      }\r\n      return text;\r\n    } else if (dataItem.property.editorClass === 'ax/editors/date') {\r\n      if (dataItem.value) {\r\n        return new AXDateTime(dataItem.value, 'jalali').format('yyyy/MM/DD');\r\n      } else {\r\n        return;\r\n      }\r\n    } else {\r\n      return;\r\n    }\r\n  }\r\n\r\n  private async _handleDefultVlaue(dataItem: any) {\r\n    await this._handleInitVlaue(dataItem);\r\n    this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n    if (this._filterItems.length === this._defultValueCount.length && this.loadOnInit && !this._isEmitted) {\r\n      this._isEmitted = true;\r\n      this.onSearchValue.emit(this._filterItems);\r\n    }\r\n  }\r\n\r\n  private async _handleInitVlaue(e) {\r\n    let value = [];\r\n    let text: any = [];\r\n    if (e.property.editorOptions?.valueField && e.value != null) {\r\n      if (e.property.editorOptions.returnAllData) {\r\n        value = e.value;\r\n        text = await this._handleTextValue(e);\r\n      } else if (e.property.editorOptions?.mode == 'multiple') {\r\n        e.value.forEach((element) => {\r\n          value.push(element[e.property.editorOptions.valueField]);\r\n          text.push(element[e.property.editorOptions.textField]);\r\n        });\r\n      } else {\r\n        if (e.value.length) {\r\n          value = e.value[0][e.property.editorOptions.valueField];\r\n          text = e.value[0][e.property.editorOptions.textField];\r\n        }\r\n      }\r\n    } else {\r\n      value = e.value;\r\n      text = e.value;\r\n    }\r\n    const findEl = this._filterItemsClone.find((el) => el.uniqueNumber == e.property.uniqueNumber);\r\n    if (findEl) {\r\n      findEl.value = value;\r\n      findEl.textValue = e.property.editorClass === 'ax/editors/date' ? new AXDateTime(text, 'jalali').format('yyyy/MM/DD') : text;\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        uniqueNumber: e.property.uniqueNumber,\r\n        value,\r\n        textValue: e.property.editorClass === 'ax/editors/date' ? new AXDateTime(text, 'jalali').format('yyyy/MM/DD') : text,\r\n        component: e,\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  }\r\n}\r\n","<div class=\"d-flex align-items-center\">\r\n    <ax-button #searchBtnTarget end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n        [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"size\" [tabIndex]=\"-1\"\r\n        (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n            class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n</div>\r\n\r\n<ax-popover #searchPop [target]=\"searchBtnTarget\"\r\n    [position]=\"{originX:'center',originY:'bottom',overlayX:'center',overlayY:'top',offsetY:50,offsetX:10}\">\r\n    <div class=\"panel-box ax-dropdown-container-bordered\" [ngStyle]=\"{'width' : popoverWidth }\">\r\n        <ax-validation-form #form>\r\n            <ng-container *ngFor=\"let item of _items\">\r\n                <div class=\"row\">\r\n                    <ng-container *ngFor=\"let prop of item.items\">\r\n                        <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n                            <div>\r\n                                <ax-label>{{prop.property.title}}</ax-label>\r\n                                <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n                                    [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\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        </ax-validation-form>\r\n    </div>\r\n</ax-popover>"]}
259
+ //# 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, AXDateTime } from '@acorex/core';\r\nimport { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';\r\nimport * as _ from 'lodash';\r\nimport { AXElementSize } from '../base/element.class';\r\nimport { AXPopoverComponent } from '../popover/popover.component';\r\nimport { AXPropertyEditorRendererDirective } from '../property-editor/property-editor-renderer.directive';\r\nimport { AXPropertyColDef, AXPropertyConfig, AXProperyEditorValueChangeEvent, FilterModel } from '../property-editor/property-editor.class';\r\nimport { AXValidationFormComponent } from '../validation/validation-form.component';\r\n\r\nexport interface FilterTextItemsModel {\r\n  name: string;\r\n  title: string;\r\n  value: any;\r\n  textValue: string;\r\n  filterOptions?: FilterModel;\r\n  component: AXPropertyConfig;\r\n  uniqueNumber?: number;\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 {\r\n  constructor(private cdr: ChangeDetectorRef, public ref: ElementRef<HTMLDivElement>) {}\r\n\r\n  @ViewChild('searchPop') searchPopover: AXPopoverComponent;\r\n  @ViewChildren(AXPropertyEditorRendererDirective) _editors: QueryList<AXPropertyEditorRendererDirective>;\r\n  @ViewChild(AXValidationFormComponent) form: AXValidationFormComponent;\r\n\r\n  @Input()\r\n  sizeButton: AXElementSize = 'md';\r\n\r\n  @Input()\r\n  size: 'sm' | 'md' | 'lg' | 'full' = 'sm';\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  fitParent: boolean = false;\r\n\r\n  @Input()\r\n  popoverWidth: string = '65vw';\r\n\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  @Input()\r\n  loadOnInit: boolean = false;\r\n\r\n  @Input()\r\n  public set items(v: AXPropertyConfig[]) {\r\n    this._defultValueCount = v.filter((x) => x.value);\r\n    v.forEach((el) => {\r\n      el.property.uniqueNumber = Math.random();\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          textValue: this._handleTextValue(el),\r\n          value: el.value ? this._handleDefultVlaue(el) : null,\r\n          component: el\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  @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  _defultValueCount: any = [];\r\n  _context: any = {};\r\n  _isEmitted: boolean = false;\r\n  public clearItem(name: string) {\r\n    this._editors.find((x) => x.property.property.name === name).clear();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.rtl == null) {\r\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\r\n    }\r\n  }\r\n\r\n  public refresh() {\r\n    this.loadOnInit = true;\r\n    this._defultValueCount = [];\r\n    this._filterItems = [];\r\n    this._filterItemsClone = [];\r\n    this.items = this._items[0].items;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  handleButtonClick() {\r\n    this.searchPopover.open();\r\n  }\r\n\r\n  async handleValueChange(e: AXProperyEditorValueChangeEvent) {\r\n    await this._handleInitVlaue(e);\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  public search() {\r\n    this.form.validate().then((c) => {\r\n      if (c.result) {\r\n        this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n        this.searchPopover.close();\r\n        this.onSearchValue.emit(this._filterItems);\r\n      }\r\n    });\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.searchPopover.close();\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(/,/g, ' ');\r\n  }\r\n\r\n  _handleShowTitleSelected(item) {\r\n    if (item.title) {\r\n      return item.title + ':';\r\n    }\r\n  }\r\n\r\n  _handleShowValueSelected(item) {\r\n    if (item.component.property.editorClass === 'ax/editors/check') {\r\n      return item.component.property.editorOptions.label;\r\n    } else {\r\n      return item.textValue;\r\n    }\r\n  }\r\n\r\n  private _handleTextValue(dataItem: any) {\r\n    let text = '';\r\n    if (Array.isArray(dataItem.value)) {\r\n      if (dataItem.value.length) {\r\n        dataItem.value.forEach((element, index) => {\r\n          text +=\r\n            index === dataItem.value.length - 1\r\n              ? element[dataItem.property.editorOptions.textField]\r\n              : element[dataItem.property.editorOptions.textField] + ',';\r\n        });\r\n      }\r\n      return text;\r\n    } else if (dataItem.property.editorClass === 'ax/editors/date') {\r\n      if (dataItem.value) {\r\n        return new AXDateTime(dataItem.value, 'jalali').format('yyyy/MM/DD');\r\n      } else {\r\n        return;\r\n      }\r\n    } else {\r\n      return;\r\n    }\r\n  }\r\n\r\n  private async _handleDefultVlaue(dataItem: any) {\r\n    await this._handleInitVlaue(dataItem);\r\n    this._filterItems = JSON.parse(JSON.stringify(this._filterItemsClone.filter((el) => el.value != null && el.value != '')));\r\n    if (this._filterItems.length === this._defultValueCount.length && this.loadOnInit && !this._isEmitted) {\r\n      this._isEmitted = true;\r\n      this.onSearchValue.emit(this._filterItems);\r\n    }\r\n  }\r\n\r\n  private async _handleInitVlaue(e) {\r\n    let value = [];\r\n    let text: any = [];\r\n    if (e.property.editorOptions?.valueField && e.value != null) {\r\n      if (e.property.editorOptions.returnAllData) {\r\n        value = e.value;\r\n        text = await this._handleTextValue(e);\r\n      } else if (e.property.editorOptions?.mode == 'multiple') {\r\n        e.value.forEach((element) => {\r\n          value.push(element[e.property.editorOptions.valueField]);\r\n          text.push(element[e.property.editorOptions.textField]);\r\n        });\r\n      } else {\r\n        if (e.value.length) {\r\n          value = e.value[0][e.property.editorOptions.valueField];\r\n          text = e.value[0][e.property.editorOptions.textField];\r\n        }\r\n      }\r\n    } else {\r\n      value = e.value;\r\n      text = e.value;\r\n    }\r\n    const findEl = this._filterItemsClone.find((el) => el.uniqueNumber == e.property.uniqueNumber);\r\n    if (findEl) {\r\n      findEl.value = value;\r\n      findEl.textValue = e.property.editorClass === 'ax/editors/date' ? new AXDateTime(text, 'jalali').format('yyyy/MM/DD') : text;\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        uniqueNumber: e.property.uniqueNumber,\r\n        value,\r\n        textValue: e.property.editorClass === 'ax/editors/date' ? new AXDateTime(text, 'jalali').format('yyyy/MM/DD') : text,\r\n        component: e,\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  }\r\n}\r\n","<ax-button end icon=\"far fa-sliders-h icon\" [selected]=\"_filterItems.length ? true:false\"\r\n    [type]=\" _filterItems.length ? 'primary':'primary outline'\" [disabled]=\"disabled\" [size]=\"sizeButton\"\r\n    [tabIndex]=\"-1\" (click)=\"handleButtonClick()\"> {{'common.search' | trans}} <span *ngIf=\"_filterItems.length\"\r\n        class=\"search-count\">{{_filterItems.length}}</span></ax-button>\r\n\r\n\r\n<ax-popover #searchPop [target]=\"ref\" [rtl]=\"rtl\"\r\n    [position]=\"{originX:'start',originY:'bottom',overlayX:'start',overlayY:'top',offsetY:10}\">\r\n    <div class=\"panel-box ax-dropdown-container-bordered {{size}}\">\r\n        <ax-validation-form #form>\r\n            <ng-container *ngFor=\"let item of _items\">\r\n                <div class=\"row\">\r\n                    <ng-container *ngFor=\"let prop of item.items\">\r\n                        <div *ngIf=\"prop.property.visible != false\" class=\"{{renderCol(prop.property.col)}}\">\r\n                            <div>\r\n                                <ax-label>{{prop.property.title}}</ax-label>\r\n                                <ng-container ax-property-editor-renderer [validationForm]=\"form\" [property]=\"prop\"\r\n                                    [context]=\"_context\" (onValueChange)=\"handleValueChange($event)\"></ng-container>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\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        </ax-validation-form>\r\n    </div>\r\n</ax-popover>"]}