verben-ng-ui 0.2.8 → 0.2.9

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.
@@ -64,6 +64,7 @@ export class DataViewComponent {
64
64
  }
65
65
  onClearSearch() {
66
66
  this.searchValue = "";
67
+ this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });
67
68
  }
68
69
  toggleChildView(viewType) {
69
70
  switch (viewType) {
@@ -210,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
210
211
  }], onSearchChange: [{
211
212
  type: Output
212
213
  }] } });
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\ninterface ViewState {\n  isSearch?: boolean;\n  isColumn?: boolean;\n  isFilter?: boolean;\n  isSort?: boolean;\n  isExport?: boolean;\n  isSelect?: boolean;\n  isCreate?:boolean\n  isToggle?:boolean\n}\n\n@Component({\n  selector: 'verben-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataViewComponent implements OnInit {\n  @Input() buttonClass?: string;\n  @Input() iconClass?: string;\n  @Input() activeIconClass?: string=\"\"\n  @Input() columnCustomClass?:string=''\n  @Input() filterCustomClass?:string=''\n  @Input() sortCustomClass?:string=''\n  @Input() exportCustomClass?:string=''\n  @Input() selectCustomClass?:string=''\n  @Input() zIndex?:number=5\n  @Input() createCustomClass:string=''\n  @Input() tableIcon: string = 'grid-3';\n  @Input() cardIcon: string = 'list-view';\n  @Input() cardClass: string = '';\n  @Input() tableClass: string = '';\n  @Input() searchKey:string='search';\n  @Input() searchValue:string='';\n  @Input() viewState: ViewState = {\n    isSearch: true,\n    isColumn: true,\n    isFilter: true,\n    isSort: true,\n    isExport: true,\n    isSelect: true,\n    isCreate:true,\n    isToggle:true\n  };\n\n  @Input() searchTemplate?: Node;\n  @Input() columnTemplate?: Node;\n  @Input() filterTemplate?: Node;\n  @Input() sortTemplate?: Node;\n  @Input() children?: Node;\n  @Input() exportTemplate?: Node;\n  @Input() createTemplate?: Node;\n  @Input() selectedColumnCount?: number = 0;\n  @Input() selectedSortCount: number = 0;\n  @Input() selectedFilterTableCount: number = 0;\n  @Input() inputWidth: string=\"100%\";\n  @Input()showColumnChild: boolean = false;\n  @Input() showSortChild: boolean = false;\n  @Input() showFilterChild: boolean = false;\n  @Input() showExportChild: boolean = false;\n  @Input() create: boolean = false;\n  @Input() showSelected: boolean = false;\n  \n  @Input() isTableView: boolean = false;\n  @Output() viewChange = new EventEmitter<boolean>();\n  @Output() stateChange = new EventEmitter<{ key: string; value: boolean }>();\n  @Output() onSearchChange=new EventEmitter<{ key: string; value: string }>()\n  ngOnInit(): void {}\n\n  toggleView(): void {\n    this.isTableView = !this.isTableView;\n    this.viewChange.emit(this.isTableView);\n  }\n\n  onSearch(event:any): void {\n    this.searchValue=event.target.value\n    this.onSearchChange.emit({key:this.searchKey, value:this.searchValue});\n  }\n  \nonClearSearch(){\n this.searchValue=\"\"\n}\n  toggleChildView(viewType: string): void {\n    switch (viewType) {\n      case 'column':\n        this.showColumnChild = !this.showColumnChild;\n        this.resetChildViewsExcept('column');\n        break;\n      case 'filter':\n        this.showFilterChild = !this.showFilterChild;\n        this.resetChildViewsExcept('filter');\n        break;\n      case 'sort':\n        this.showSortChild = !this.showSortChild;\n        this.resetChildViewsExcept('sort');\n        break;\n      case 'select':\n        this.showSelected = !this.showSelected;\n        this.resetChildViewsExcept('select');\n        break;\n      case 'export':\n        this.showExportChild = !this.showExportChild;\n        this.resetChildViewsExcept('export');\n        break;\n        case 'create':\n          this.create = !this.create;\n          this.resetChildViewsExcept('create');\n          break;\n    }\n    this.stateChange.emit({ key: viewType, value: this.getChildViewState(viewType) });\n    \n  }\n  resetChildViewsExcept(viewType: string): void {\n    if (viewType !== 'column') this.showColumnChild = false;\n    if (viewType !== 'filter') this.showFilterChild = false;\n    if (viewType !== 'sort') this.showSortChild = false;\n    if (viewType !== 'select') this.showSelected = false;\n    if (viewType !== 'export') this.showExportChild = false;\n    if (viewType !== 'create') this.create = false;\n  }\n\n  // Helper method to get the state of a specific child view\n  getChildViewState(viewType: string): boolean {\n    switch (viewType) {\n      case 'column':\n        return this.showColumnChild;\n      case 'filter':\n        return this.showFilterChild;\n      case 'sort':\n        return this.showSortChild;\n      case 'select':\n        return this.showSelected;\n      case 'export':\n        return this.showExportChild;\n        case 'create':\n        return this.create;\n      default:\n        return false;\n    }\n  }\n}\n","<div class=\"toolbar flex gap justify-between items-center \">\n  <div class=\"flex items-center gap flex-1 justify-end\">\n    <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n      <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n        <verben-svg\n          [icon]=\"tableIcon\"\n          [class.active]=\"!isTableView\"\n          [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n        ></verben-svg>\n        <verben-svg\n          [icon]=\"cardIcon\"\n          [class.active]=\"isTableView\"\n          [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n          [width]=\"25\"\n          [height]=\"25\"\n        ></verben-svg>\n      </button>\n    </div>\n    <!-- Search Input -->\n    <div\n      [style.width]=\"inputWidth\"\n      class=\"search-input\"\n      *ngIf=\"viewState.isSearch\"\n    >\n      <verbena-input\n        [type]=\"'text'\"\n        [placeHolder]=\"'Search...'\"\n        (input)=\"onSearch($event)\"\n        [bgColor]=\"'transparent'\"\n        [border]=\"'0'\"\n        [value]=\"searchValue\"\n      />\n      <verben-svg\n        *ngIf=\"searchValue.length > 0\"\n        [icon]=\"'close'\"\n        [width]=\"15\"\n        (click)=\"onClearSearch()\"\n        class=\"close-icon-class\"\n        [height]=\"15\"\n      ></verben-svg>\n    </div>\n  </div>\n\n  <div class=\"flex items-center relative gap flex-1 justify-end \">\n    <!-- Column Section -->\n    <ng-container\n      [appOutSideClick]=\"showColumnChild\"\n      (outSideClick)=\"resetChildViewsExcept('column')\"\n      *ngIf=\"viewState.isColumn && isTableView\"\n    >\n      <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n      <ng-template #defaultColumn>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            columnCustomClass ? columnCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('column')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n          <span\n            >Columns <sup>({{ selectedColumnCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n          </ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Filter Section -->\n    <ng-container\n      [appOutSideClick]=\"showFilterChild\"\n      (outSideClick)=\"resetChildViewsExcept('filter')\"\n      *ngIf=\"viewState.isFilter\"\n    >\n      <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n      <ng-template #defaultFilter>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            filterCustomClass ? filterCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('filter')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n          <span\n            >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showFilterChild\"\n            select=\"[filter-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Sort Section -->\n    <ng-container\n      [appOutSideClick]=\"showSortChild\"\n      (outSideClick)=\"resetChildViewsExcept('sort')\"\n      *ngIf=\"viewState.isSort\"\n    >\n      <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n      <ng-template #defaultSort>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            sortCustomClass ? sortCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('sort')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n          <span\n            >Sort <sup>({{ selectedSortCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showSortChild\"\n            select=\"[sort-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Export Section -->\n    <ng-container\n      [appOutSideClick]=\"showExportChild\"\n      (outSideClick)=\"resetChildViewsExcept('export')\"\n      *ngIf=\"viewState.isExport\"\n    >\n      <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n      <ng-template #defaultExport>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            exportCustomClass ? exportCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('export')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n          Export\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showExportChild\"\n            select=\"[export-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Select Section -->\n    <div *ngIf=\"viewState.isSelect\">\n      <span\n        [ngClass]=\"[\n          'flex gap text-xs items-center pd rounded cursor-pointer',\n          selectCustomClass ? selectCustomClass : ''\n        ]\"\n        [style.background-color]=\"'#D9D9D940'\"\n        (click)=\"toggleChildView('select')\"\n      >\n        <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n        <span>Select</span>\n        <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n      </span>\n    </div>\n\n    <!-- Create Button -->\n\n    <div\n      [appOutSideClick]=\"create\"\n      (outSideClick)=\"resetChildViewsExcept('create')\"\n      *ngIf=\"viewState.isCreate\"\n    >\n      <verbena-button\n        class=\"text-sm font-semibold\"\n        [bgColor]=\"'#FFE681'\"\n        [buttonClass]=\"createCustomClass\"\n        [pd]=\"'6px'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#000'\"\n        [svg]=\"'add'\"\n        [svgPosition]=\"'right'\"\n        [text]=\"'Create New'\"\n        (click)=\"toggleChildView('create')\"\n      >\n      </verbena-button>\n      <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n      <ng-template #defaultCreate>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n    <div>\n      <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n      <ng-template #defaultChildren>\n        <div>\n          <ng-content select=\"[children]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n  \n  <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n    <ng-content select=\"[table-content]\"></ng-content>\n  </div>\n</div>\n<ng-template #listViewTemplate>\n  <div [class]=\"cardClass\">\n    <ng-content select=\"[card-content]\"></ng-content>\n  </div>\n</ng-template>\n"]}
214
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-view.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/data-view/data-view.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,GACP,MAAM,eAAe,CAAC;;;;;;;AAmBvB,MAAM,OAAO,iBAAiB;IACnB,WAAW,CAAU;IACrB,SAAS,CAAU;IACnB,eAAe,GAAU,EAAE,CAAA;IAC3B,iBAAiB,GAAS,EAAE,CAAA;IAC5B,iBAAiB,GAAS,EAAE,CAAA;IAC5B,eAAe,GAAS,EAAE,CAAA;IAC1B,iBAAiB,GAAS,EAAE,CAAA;IAC5B,iBAAiB,GAAS,EAAE,CAAA;IAC5B,MAAM,GAAS,CAAC,CAAA;IAChB,iBAAiB,GAAQ,EAAE,CAAA;IAC3B,SAAS,GAAW,QAAQ,CAAC;IAC7B,QAAQ,GAAW,WAAW,CAAC;IAC/B,SAAS,GAAW,EAAE,CAAC;IACvB,UAAU,GAAW,EAAE,CAAC;IACxB,SAAS,GAAQ,QAAQ,CAAC;IAC1B,WAAW,GAAQ,EAAE,CAAC;IACtB,SAAS,GAAc;QAC9B,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,IAAI;QACZ,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAE,IAAI;QACd,QAAQ,EAAC,IAAI;QACb,QAAQ,EAAC,IAAI;KACd,CAAC;IAEO,cAAc,CAAQ;IACtB,cAAc,CAAQ;IACtB,cAAc,CAAQ;IACtB,YAAY,CAAQ;IACpB,QAAQ,CAAQ;IAChB,cAAc,CAAQ;IACtB,cAAc,CAAQ;IACtB,mBAAmB,GAAY,CAAC,CAAC;IACjC,iBAAiB,GAAW,CAAC,CAAC;IAC9B,wBAAwB,GAAW,CAAC,CAAC;IACrC,UAAU,GAAS,MAAM,CAAC;IAC3B,eAAe,GAAY,KAAK,CAAC;IAChC,aAAa,GAAY,KAAK,CAAC;IAC/B,eAAe,GAAY,KAAK,CAAC;IACjC,eAAe,GAAY,KAAK,CAAC;IACjC,MAAM,GAAY,KAAK,CAAC;IACxB,YAAY,GAAY,KAAK,CAAC;IAE9B,WAAW,GAAY,KAAK,CAAC;IAC5B,UAAU,GAAG,IAAI,YAAY,EAAW,CAAC;IACzC,WAAW,GAAG,IAAI,YAAY,EAAmC,CAAC;IAClE,cAAc,GAAC,IAAI,YAAY,EAAkC,CAAA;IAC3E,QAAQ,KAAU,CAAC;IAEnB,UAAU;QACR,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC;IAED,QAAQ,CAAC,KAAS;QAChB,IAAI,CAAC,WAAW,GAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAA;QACnC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAC,GAAG,EAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAC,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;IACzE,CAAC;IAEH,aAAa;QACZ,IAAI,CAAC,WAAW,GAAC,EAAE,CAAA;QACnB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAE5E,CAAC;IACC,eAAe,CAAC,QAAgB;QAC9B,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,QAAQ;gBACX,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;gBAC7C,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;gBACrC,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;gBAC7C,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;gBACrC,MAAM;YACR,KAAK,MAAM;gBACT,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC;gBACzC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;gBACnC,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;gBACvC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;gBACrC,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;gBAC7C,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;gBACrC,MAAM;YACN,KAAK,QAAQ;gBACX,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;gBAC3B,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,CAAC;gBACrC,MAAM;QACZ,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IAEpF,CAAC;IACD,qBAAqB,CAAC,QAAgB;QACpC,IAAI,QAAQ,KAAK,QAAQ;YAAE,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QACxD,IAAI,QAAQ,KAAK,QAAQ;YAAE,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QACxD,IAAI,QAAQ,KAAK,MAAM;YAAE,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QACpD,IAAI,QAAQ,KAAK,QAAQ;YAAE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QACrD,IAAI,QAAQ,KAAK,QAAQ;YAAE,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QACxD,IAAI,QAAQ,KAAK,QAAQ;YAAE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACjD,CAAC;IAED,0DAA0D;IAC1D,iBAAiB,CAAC,QAAgB;QAChC,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,eAAe,CAAC;YAC9B,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,eAAe,CAAC;YAC9B,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC,aAAa,CAAC;YAC5B,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,YAAY,CAAC;YAC3B,KAAK,QAAQ;gBACX,OAAO,IAAI,CAAC,eAAe,CAAC;YAC5B,KAAK,QAAQ;gBACb,OAAO,IAAI,CAAC,MAAM,CAAC;YACrB;gBACE,OAAO,KAAK,CAAC;QACjB,CAAC;IACH,CAAC;uGA5HU,iBAAiB;2FAAjB,iBAAiB,qwCC1B9B,w9OAkOA;;2FDxMa,iBAAiB;kBAN7B,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM;8BAGtC,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAWG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACE,eAAe;sBAAtB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,cAAc;sBAAvB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\ninterface ViewState {\n  isSearch?: boolean;\n  isColumn?: boolean;\n  isFilter?: boolean;\n  isSort?: boolean;\n  isExport?: boolean;\n  isSelect?: boolean;\n  isCreate?:boolean\n  isToggle?:boolean\n}\n\n@Component({\n  selector: 'verben-data-view',\n  templateUrl: './data-view.component.html',\n  styleUrls: ['./data-view.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DataViewComponent implements OnInit {\n  @Input() buttonClass?: string;\n  @Input() iconClass?: string;\n  @Input() activeIconClass?: string=\"\"\n  @Input() columnCustomClass?:string=''\n  @Input() filterCustomClass?:string=''\n  @Input() sortCustomClass?:string=''\n  @Input() exportCustomClass?:string=''\n  @Input() selectCustomClass?:string=''\n  @Input() zIndex?:number=5\n  @Input() createCustomClass:string=''\n  @Input() tableIcon: string = 'grid-3';\n  @Input() cardIcon: string = 'list-view';\n  @Input() cardClass: string = '';\n  @Input() tableClass: string = '';\n  @Input() searchKey:string='search';\n  @Input() searchValue:string='';\n  @Input() viewState: ViewState = {\n    isSearch: true,\n    isColumn: true,\n    isFilter: true,\n    isSort: true,\n    isExport: true,\n    isSelect: true,\n    isCreate:true,\n    isToggle:true\n  };\n\n  @Input() searchTemplate?: Node;\n  @Input() columnTemplate?: Node;\n  @Input() filterTemplate?: Node;\n  @Input() sortTemplate?: Node;\n  @Input() children?: Node;\n  @Input() exportTemplate?: Node;\n  @Input() createTemplate?: Node;\n  @Input() selectedColumnCount?: number = 0;\n  @Input() selectedSortCount: number = 0;\n  @Input() selectedFilterTableCount: number = 0;\n  @Input() inputWidth: string=\"100%\";\n  @Input()showColumnChild: boolean = false;\n  @Input() showSortChild: boolean = false;\n  @Input() showFilterChild: boolean = false;\n  @Input() showExportChild: boolean = false;\n  @Input() create: boolean = false;\n  @Input() showSelected: boolean = false;\n  \n  @Input() isTableView: boolean = false;\n  @Output() viewChange = new EventEmitter<boolean>();\n  @Output() stateChange = new EventEmitter<{ key: string; value: boolean }>();\n  @Output() onSearchChange=new EventEmitter<{ key: string; value: string }>()\n  ngOnInit(): void {}\n\n  toggleView(): void {\n    this.isTableView = !this.isTableView;\n    this.viewChange.emit(this.isTableView);\n  }\n\n  onSearch(event:any): void {\n    this.searchValue=event.target.value\n    this.onSearchChange.emit({key:this.searchKey, value:this.searchValue});\n  }\n  \nonClearSearch(){\n this.searchValue=\"\"\n this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });\n\n}\n  toggleChildView(viewType: string): void {\n    switch (viewType) {\n      case 'column':\n        this.showColumnChild = !this.showColumnChild;\n        this.resetChildViewsExcept('column');\n        break;\n      case 'filter':\n        this.showFilterChild = !this.showFilterChild;\n        this.resetChildViewsExcept('filter');\n        break;\n      case 'sort':\n        this.showSortChild = !this.showSortChild;\n        this.resetChildViewsExcept('sort');\n        break;\n      case 'select':\n        this.showSelected = !this.showSelected;\n        this.resetChildViewsExcept('select');\n        break;\n      case 'export':\n        this.showExportChild = !this.showExportChild;\n        this.resetChildViewsExcept('export');\n        break;\n        case 'create':\n          this.create = !this.create;\n          this.resetChildViewsExcept('create');\n          break;\n    }\n    this.stateChange.emit({ key: viewType, value: this.getChildViewState(viewType) });\n    \n  }\n  resetChildViewsExcept(viewType: string): void {\n    if (viewType !== 'column') this.showColumnChild = false;\n    if (viewType !== 'filter') this.showFilterChild = false;\n    if (viewType !== 'sort') this.showSortChild = false;\n    if (viewType !== 'select') this.showSelected = false;\n    if (viewType !== 'export') this.showExportChild = false;\n    if (viewType !== 'create') this.create = false;\n  }\n\n  // Helper method to get the state of a specific child view\n  getChildViewState(viewType: string): boolean {\n    switch (viewType) {\n      case 'column':\n        return this.showColumnChild;\n      case 'filter':\n        return this.showFilterChild;\n      case 'sort':\n        return this.showSortChild;\n      case 'select':\n        return this.showSelected;\n      case 'export':\n        return this.showExportChild;\n        case 'create':\n        return this.create;\n      default:\n        return false;\n    }\n  }\n}\n","<div class=\"toolbar flex gap justify-between items-center \">\n  <div class=\"flex items-center gap flex-1 justify-end\">\n    <div *ngIf=\"viewState.isToggle\" class=\"toggle-button-container\">\n      <button type=\"button\" (click)=\"toggleView()\" [ngClass]=\"buttonClass\">\n        <verben-svg\n          [icon]=\"tableIcon\"\n          [class.active]=\"!isTableView\"\n          [ngClass]=\"!isTableView ? activeIconClass : iconClass\"\n        ></verben-svg>\n        <verben-svg\n          [icon]=\"cardIcon\"\n          [class.active]=\"isTableView\"\n          [ngClass]=\"isTableView ? activeIconClass : iconClass\"\n          [width]=\"25\"\n          [height]=\"25\"\n        ></verben-svg>\n      </button>\n    </div>\n    <!-- Search Input -->\n    <div\n      [style.width]=\"inputWidth\"\n      class=\"search-input\"\n      *ngIf=\"viewState.isSearch\"\n    >\n      <verbena-input\n        [type]=\"'text'\"\n        [placeHolder]=\"'Search...'\"\n        (input)=\"onSearch($event)\"\n        [bgColor]=\"'transparent'\"\n        [border]=\"'0'\"\n        [value]=\"searchValue\"\n      />\n      <verben-svg\n        *ngIf=\"searchValue.length > 0\"\n        [icon]=\"'close'\"\n        [width]=\"15\"\n        (click)=\"onClearSearch()\"\n        class=\"close-icon-class\"\n        [height]=\"15\"\n      ></verben-svg>\n    </div>\n  </div>\n\n  <div class=\"flex items-center relative gap flex-1 justify-end \">\n    <!-- Column Section -->\n    <ng-container\n      [appOutSideClick]=\"showColumnChild\"\n      (outSideClick)=\"resetChildViewsExcept('column')\"\n      *ngIf=\"viewState.isColumn && isTableView\"\n    >\n      <ng-container *ngIf=\"columnTemplate; else defaultColumn\"></ng-container>\n      <ng-template #defaultColumn>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            columnCustomClass ? columnCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('column')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'column'\"></verben-svg>\n          <span\n            >Columns <sup>({{ selectedColumnCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"showColumnChild\" select=\"[column-content]\">\n          </ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Filter Section -->\n    <ng-container\n      [appOutSideClick]=\"showFilterChild\"\n      (outSideClick)=\"resetChildViewsExcept('filter')\"\n      *ngIf=\"viewState.isFilter\"\n    >\n      <ng-container *ngIf=\"filterTemplate; else defaultFilter\"></ng-container>\n      <ng-template #defaultFilter>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            filterCustomClass ? filterCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('filter')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'filter'\"></verben-svg>\n          <span\n            >Filter <sup>({{ selectedFilterTableCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showFilterChild\"\n            select=\"[filter-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Sort Section -->\n    <ng-container\n      [appOutSideClick]=\"showSortChild\"\n      (outSideClick)=\"resetChildViewsExcept('sort')\"\n      *ngIf=\"viewState.isSort\"\n    >\n      <ng-container *ngIf=\"sortTemplate; else defaultSort\"></ng-container>\n      <ng-template #defaultSort>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            sortCustomClass ? sortCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('sort')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'sort'\"></verben-svg>\n          <span\n            >Sort <sup>({{ selectedSortCount }})</sup></span\n          >\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showSortChild\"\n            select=\"[sort-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Export Section -->\n    <ng-container\n      [appOutSideClick]=\"showExportChild\"\n      (outSideClick)=\"resetChildViewsExcept('export')\"\n      *ngIf=\"viewState.isExport\"\n    >\n      <ng-container *ngIf=\"exportTemplate; else defaultExport\"></ng-container>\n      <ng-template #defaultExport>\n        <span\n          [ngClass]=\"[\n            'flex gap text-xs items-center pd rounded cursor-pointer',\n            exportCustomClass ? exportCustomClass : ''\n          ]\"\n          [style.background-color]=\"'#D9D9D940'\"\n          (click)=\"toggleChildView('export')\"\n        >\n          <verben-svg [width]=\"15\" [icon]=\"'export'\"></verben-svg>\n          Export\n        </span>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content\n            *ngIf=\"showExportChild\"\n            select=\"[export-content]\"\n          ></ng-content>\n        </div>\n      </ng-template>\n    </ng-container>\n\n    <!-- Select Section -->\n    <div *ngIf=\"viewState.isSelect\">\n      <span\n        [ngClass]=\"[\n          'flex gap text-xs items-center pd rounded cursor-pointer',\n          selectCustomClass ? selectCustomClass : ''\n        ]\"\n        [style.background-color]=\"'#D9D9D940'\"\n        (click)=\"toggleChildView('select')\"\n      >\n        <verben-svg [width]=\"15\" [icon]=\"'select'\"></verben-svg>\n        <span>Select</span>\n        <verben-svg [width]=\"6\" [icon]=\"'chevron-down'\"></verben-svg>\n      </span>\n    </div>\n\n    <!-- Create Button -->\n\n    <div\n      [appOutSideClick]=\"create\"\n      (outSideClick)=\"resetChildViewsExcept('create')\"\n      *ngIf=\"viewState.isCreate\"\n    >\n      <verbena-button\n        class=\"text-sm font-semibold\"\n        [bgColor]=\"'#FFE681'\"\n        [buttonClass]=\"createCustomClass\"\n        [pd]=\"'6px'\"\n        [borderRadius]=\"'4px'\"\n        [textColor]=\"'#000'\"\n        [svg]=\"'add'\"\n        [svgPosition]=\"'right'\"\n        [text]=\"'Create New'\"\n        (click)=\"toggleChildView('create')\"\n      >\n      </verbena-button>\n      <ng-container *ngIf=\"createTemplate; else defaultCreate\"></ng-container>\n      <ng-template #defaultCreate>\n        <div [style.z-index]=\"zIndex\" class=\"data-view-element\">\n          <ng-content *ngIf=\"create\" select=\"[create-content]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n    <div>\n      <ng-container *ngIf=\"children; else defaultChildren\"></ng-container>\n      <ng-template #defaultChildren>\n        <div>\n          <ng-content select=\"[children]\"></ng-content>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n</div>\n\n<!-- Grid and List View Handling -->\n<div *ngIf=\"isTableView; else listViewTemplate\">\n  \n  <div [style.overflow]=\"'auto'\" [class]=\"tableClass\">\n    <ng-content select=\"[table-content]\"></ng-content>\n  </div>\n</div>\n<ng-template #listViewTemplate>\n  <div [class]=\"cardClass\">\n    <ng-content select=\"[card-content]\"></ng-content>\n  </div>\n</ng-template>\n"]}
@@ -3,6 +3,7 @@ import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
4
  export class VerbenPopUpComponent {
5
5
  elementRef;
6
+ renderer;
6
7
  dropdownOpen = false;
7
8
  dropdownOpenChange = new EventEmitter();
8
9
  dropdownWidth = '';
@@ -13,12 +14,16 @@ export class VerbenPopUpComponent {
13
14
  borderRadius = '';
14
15
  enableMouseLeave = true;
15
16
  close = new EventEmitter();
16
- constructor(elementRef) {
17
+ constructor(elementRef, renderer) {
17
18
  this.elementRef = elementRef;
19
+ this.renderer = renderer;
18
20
  }
19
21
  toggleDropdown() {
20
22
  this.dropdownOpen = !this.dropdownOpen;
21
23
  this.dropdownOpenChange.emit(this.dropdownOpen);
24
+ if (this.dropdownOpen) {
25
+ this.setDropdownPosition();
26
+ }
22
27
  }
23
28
  onMouseOut() {
24
29
  if (this.enableMouseLeave) {
@@ -49,13 +54,97 @@ export class VerbenPopUpComponent {
49
54
  this.dropdownOpenChange.emit(this.dropdownOpen);
50
55
  }
51
56
  }
52
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
53
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: VerbenPopUpComponent, selector: "verben-pop-Up", inputs: { dropdownOpen: "dropdownOpen", dropdownWidth: "dropdownWidth", color: "color", customStyles: "customStyles", popUpClass: "popUpClass", border: "border", borderRadius: "borderRadius", enableMouseLeave: "enableMouseLeave" }, outputs: { dropdownOpenChange: "dropdownOpenChange", close: "close" }, host: { listeners: { "document:click": "onClickOutside($event.target)" } }, ngImport: i0, template: "<div class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n appDropdownPosition\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute top-2 left-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</div>\n", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
57
+ // private setDropdownPosition(): void {
58
+ // const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-menu');
59
+ // const dropdownRect = dropdown.getBoundingClientRect();
60
+ // const parentRect = this.elementRef.nativeElement.getBoundingClientRect();
61
+ // const viewportHeight = window.innerHeight;
62
+ // const viewportWidth = window.innerWidth;
63
+ // console.log('Dropdown Rect:', dropdownRect);
64
+ // console.log('Parent Rect:', parentRect);
65
+ // console.log('Viewport:', { width: viewportWidth, height: viewportHeight });
66
+ // // Check vertical space
67
+ // if (viewportHeight - parentRect.bottom < dropdownRect.height) {
68
+ // // Position above
69
+ // this.renderer.setStyle(dropdown, 'top', 'auto');
70
+ // this.renderer.setStyle(dropdown, 'bottom', `${parentRect.height}px`);
71
+ // } else {
72
+ // // Position below
73
+ // this.renderer.setStyle(dropdown, 'top', `${parentRect.height}px`);
74
+ // this.renderer.setStyle(dropdown, 'bottom', 'auto');
75
+ // }
76
+ // // Check horizontal space
77
+ // if (parentRect.left + dropdownRect.width > viewportWidth) {
78
+ // // Position to the left
79
+ // this.renderer.setStyle(dropdown, 'left', 'auto');
80
+ // this.renderer.setStyle(dropdown, 'right', '0');
81
+ // } else if (parentRect.right - dropdownRect.width < 0) {
82
+ // // Position to the right
83
+ // this.renderer.setStyle(dropdown, 'left', '0');
84
+ // this.renderer.setStyle(dropdown, 'right', 'auto');
85
+ // } else {
86
+ // // Default alignment
87
+ // this.renderer.setStyle(dropdown, 'left', '0');
88
+ // this.renderer.setStyle(dropdown, 'right', 'auto');
89
+ // }
90
+ // }
91
+ ngAfterViewChecked() {
92
+ if (this.dropdownOpen) {
93
+ this.setDropdownPosition();
94
+ }
95
+ }
96
+ setDropdownPosition() {
97
+ const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-container > div');
98
+ // const triggerElement = this.elementRef.nativeElement.querySelector('dropdown-menu')
99
+ if (!dropdown) {
100
+ console.warn('Dropdown element not found.');
101
+ return;
102
+ }
103
+ const dropdownRect = dropdown.getBoundingClientRect();
104
+ const parentRect = this.elementRef.nativeElement.getBoundingClientRect();
105
+ const viewportHeight = window.innerHeight;
106
+ const viewportWidth = window.innerWidth;
107
+ console.log('Dropdown Rect:', dropdownRect);
108
+ console.log('Parent Rect:', parentRect);
109
+ console.log('Viewport:', { width: viewportWidth, height: viewportHeight });
110
+ // Vertical Positioning
111
+ if (viewportHeight - parentRect.bottom < dropdownRect.height) {
112
+ // Not enough space below, position above
113
+ console.log('not enough space below');
114
+ const topPosition = parentRect.top - dropdownRect.height;
115
+ console.log('top pos:', topPosition);
116
+ this.renderer.setStyle(dropdown, 'top', `auto`);
117
+ this.renderer.setStyle(dropdown, 'bottom', '15px');
118
+ }
119
+ else {
120
+ // Enough space below, position below
121
+ console.log('Enough space below');
122
+ const topPosition = parentRect.bottom;
123
+ this.renderer.setStyle(dropdown, 'top', `20px`);
124
+ this.renderer.setStyle(dropdown, 'bottom', 'auto');
125
+ }
126
+ // Horizontal Positioning
127
+ if (parentRect.left + dropdownRect.width > viewportWidth) {
128
+ console.log('not Enough space right');
129
+ const leftPosition = viewportWidth - dropdownRect.width - 10;
130
+ this.renderer.setStyle(dropdown, 'left', `auto`);
131
+ // this.renderer.setStyle(dropdown, 'left', `${Math.max(leftPosition, 0)}px`);
132
+ this.renderer.setStyle(dropdown, 'right', '10px');
133
+ }
134
+ else {
135
+ console.log('Enough space right');
136
+ const leftPosition = parentRect.left;
137
+ this.renderer.setStyle(dropdown, 'left', `${10}px`);
138
+ this.renderer.setStyle(dropdown, 'right', 'auto');
139
+ }
140
+ }
141
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
142
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: VerbenPopUpComponent, selector: "verben-pop-Up", inputs: { dropdownOpen: "dropdownOpen", dropdownWidth: "dropdownWidth", color: "color", customStyles: "customStyles", popUpClass: "popUpClass", border: "border", borderRadius: "borderRadius", enableMouseLeave: "enableMouseLeave" }, outputs: { dropdownOpenChange: "dropdownOpenChange", close: "close" }, host: { listeners: { "document:click": "onClickOutside($event.target)" } }, ngImport: i0, template: "<span class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\" class=\"dropdown-menu\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute bottom-2 right-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</span>", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
54
143
  }
55
144
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, decorators: [{
56
145
  type: Component,
57
- args: [{ selector: 'verben-pop-Up', template: "<div class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n appDropdownPosition\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute top-2 left-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</div>\n", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"] }]
58
- }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { dropdownOpen: [{
146
+ args: [{ selector: 'verben-pop-Up', template: "<span class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\" class=\"dropdown-menu\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute bottom-2 right-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</span>", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"] }]
147
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { dropdownOpen: [{
59
148
  type: Input
60
149
  }], dropdownOpenChange: [{
61
150
  type: Output
@@ -79,4 +168,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
79
168
  type: HostListener,
80
169
  args: ['document:click', ['$event.target']]
81
170
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wLXVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZlcmJlbi1uZy11aS9zcmMvbGliL2NvbXBvbmVudHMvcG9wLXVwL3BvcC11cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92ZXJiZW4tbmctdWkvc3JjL2xpYi9jb21wb25lbnRzL3BvcC11cC9wb3AtdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQWMsTUFBTSxlQUFlLENBQUM7OztBQU9qRyxNQUFNLE9BQU8sb0JBQW9CO0lBWVg7SUFYWCxZQUFZLEdBQVksS0FBSyxDQUFDO0lBQzdCLGtCQUFrQixHQUEwQixJQUFJLFlBQVksRUFBVyxDQUFDO0lBQ3pFLGFBQWEsR0FBVyxFQUFFLENBQUM7SUFDM0IsS0FBSyxHQUFXLE9BQU8sQ0FBQztJQUN4QixZQUFZLEdBQThCLEVBQUUsQ0FBQztJQUM3QyxVQUFVLEdBQVUsRUFBRSxDQUFDO0lBQ3ZCLE1BQU0sR0FBVyxFQUFFLENBQUM7SUFDcEIsWUFBWSxHQUFXLEVBQUUsQ0FBQztJQUMxQixnQkFBZ0IsR0FBWSxJQUFJLENBQUM7SUFDaEMsS0FBSyxHQUF3QixJQUFJLFlBQVksRUFBRSxDQUFDO0lBRTFELFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBRyxDQUFDO0lBRTlDLGNBQWM7UUFDWixJQUFJLENBQUMsWUFBWSxHQUFHLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQztRQUN2QyxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNsQixJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztZQUMxQixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNsRCxDQUFDO0lBQ0gsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxJQUFJLGNBQWM7UUFDaEIsT0FBTztZQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsYUFBYTtZQUN6QixNQUFNLEVBQUUsSUFBSSxDQUFDLE1BQU07WUFDbkIsWUFBWSxFQUFFLElBQUksQ0FBQyxZQUFZO1NBQ2hDLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1osT0FBTztZQUNMLEdBQUcsSUFBSSxDQUFDLFlBQVk7U0FDckIsQ0FBQztJQUNKLENBQUM7SUFHRCxjQUFjLENBQUMsYUFBMEI7UUFDdkMsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQzVFLElBQUksQ0FBQyxhQUFhLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hDLElBQUksQ0FBQyxZQUFZLEdBQUcsS0FBSyxDQUFDO1lBQzFCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBQ2xELENBQUM7SUFDSCxDQUFDO3VHQXBEVSxvQkFBb0I7MkZBQXBCLG9CQUFvQixnYkNQakMsbWhCQWlCQTs7MkZEVmEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGVBQWU7K0VBS2hCLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0ksa0JBQWtCO3NCQUEzQixNQUFNO2dCQUNFLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0ksS0FBSztzQkFBZCxNQUFNO2dCQW9DUCxjQUFjO3NCQURiLFlBQVk7dUJBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgSG9zdExpc3RlbmVyLCBFbGVtZW50UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZlcmJlbi1wb3AtVXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vcG9wLXVwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcG9wLXVwLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBWZXJiZW5Qb3BVcENvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGRyb3Bkb3duT3BlbjogYm9vbGVhbiA9IGZhbHNlO1xuICBAT3V0cHV0KCkgZHJvcGRvd25PcGVuQ2hhbmdlOiBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG4gIEBJbnB1dCgpIGRyb3Bkb3duV2lkdGg6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBjb2xvcjogc3RyaW5nID0gJ2JsYWNrJztcbiAgQElucHV0KCkgY3VzdG9tU3R5bGVzOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9ID0ge307IFxuICBASW5wdXQoKSBwb3BVcENsYXNzOnN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBib3JkZXI6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBib3JkZXJSYWRpdXM6IHN0cmluZyA9ICcnO1xuICBASW5wdXQoKSBlbmFibGVNb3VzZUxlYXZlOiBib29sZWFuID0gdHJ1ZTsgXG4gIEBPdXRwdXQoKSBjbG9zZTogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgdG9nZ2xlRHJvcGRvd24oKSB7XG4gICAgdGhpcy5kcm9wZG93bk9wZW4gPSAhdGhpcy5kcm9wZG93bk9wZW47XG4gICAgdGhpcy5kcm9wZG93bk9wZW5DaGFuZ2UuZW1pdCh0aGlzLmRyb3Bkb3duT3Blbik7XG4gIH1cblxuICBvbk1vdXNlT3V0KCkge1xuICAgIGlmICh0aGlzLmVuYWJsZU1vdXNlTGVhdmUpIHtcbiAgICAgIHRoaXMuY2xvc2UuZW1pdCgpO1xuICAgICAgdGhpcy5kcm9wZG93bk9wZW4gPSBmYWxzZTtcbiAgICAgIHRoaXMuZHJvcGRvd25PcGVuQ2hhbmdlLmVtaXQodGhpcy5kcm9wZG93bk9wZW4pO1xuICAgIH1cbiAgfVxuXG4gIG9uQ2xvc2UoKSB7XG4gICAgdGhpcy5jbG9zZS5lbWl0KCk7XG4gIH1cblxuICBnZXQgZHJvcGRvd25TdHlsZXMoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHdpZHRoOiB0aGlzLmRyb3Bkb3duV2lkdGgsXG4gICAgICBib3JkZXI6IHRoaXMuYm9yZGVyLFxuICAgICAgYm9yZGVyUmFkaXVzOiB0aGlzLmJvcmRlclJhZGl1cyxcbiAgICB9O1xuICB9XG5cbiAgZ2V0IHlvdXJTdHlsZXMoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnRoaXMuY3VzdG9tU3R5bGVzLFxuICAgIH07XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50LnRhcmdldCddKVxuICBvbkNsaWNrT3V0c2lkZSh0YXJnZXRFbGVtZW50OiBIVE1MRWxlbWVudCkge1xuICAgIGNvbnN0IGNsaWNrZWRJbnNpZGUgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5jb250YWlucyh0YXJnZXRFbGVtZW50KTtcbiAgICBpZiAoIWNsaWNrZWRJbnNpZGUgJiYgdGhpcy5kcm9wZG93bk9wZW4pIHtcbiAgICAgIHRoaXMuZHJvcGRvd25PcGVuID0gZmFsc2U7XG4gICAgICB0aGlzLmRyb3Bkb3duT3BlbkNoYW5nZS5lbWl0KHRoaXMuZHJvcGRvd25PcGVuKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJyZWxhdGl2ZSBkcm9wZG93bi1jb250YWluZXJcIiBbbmdTdHlsZV09XCJkcm9wZG93blN0eWxlc1wiPlxuICA8c3BhbiAoY2xpY2spPVwidG9nZ2xlRHJvcGRvd24oKVwiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltkcm9wZG93bi10cmlnZ2VyXVwiPjwvbmctY29udGVudD5cbiAgPC9zcGFuPlxuXG4gIDxkaXZcbiAgICBhcHBEcm9wZG93blBvc2l0aW9uXG4gICAgW25nQ2xhc3NdPVwieyd6LVs5OTk5XSc6IHRydWV9XCJcbiAgICAqbmdJZj1cImRyb3Bkb3duT3BlblwiXG4gICAgKG1vdXNlbGVhdmUpPVwib25Nb3VzZU91dCgpXCJcbiAgICBbYXR0ci5hcmlhLWhpZGRlbl09XCIhZHJvcGRvd25PcGVuXCJcbiAgICBjbGFzcz1cImFic29sdXRlIHRvcC0yIGxlZnQtMCB7e3BvcFVwQ2xhc3N9fVwiXG4gICAgW25nU3R5bGVdPVwieW91clN0eWxlc1wiXG4gID5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbZHJvcGRvd24tY29udGVudF1cIj48L25nLWNvbnRlbnQ+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
171
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pop-up.component.js","sourceRoot":"","sources":["../../../../../../projects/verben-ng-ui/src/lib/components/pop-up/pop-up.component.ts","../../../../../../projects/verben-ng-ui/src/lib/components/pop-up/pop-up.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, HostListener, ElementRef,Renderer2, AfterViewChecked } from '@angular/core';\n\n@Component({\n  selector: 'verben-pop-Up',\n  templateUrl: './pop-up.component.html',\n  styleUrls: ['./pop-up.component.css']\n})\nexport class VerbenPopUpComponent implements AfterViewChecked {\n  @Input() dropdownOpen: boolean = false;\n  @Output() dropdownOpenChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n  @Input() dropdownWidth: string = '';\n  @Input() color: string = 'black';\n  @Input() customStyles: { [key: string]: string } = {}; \n  @Input() popUpClass:string = '';\n  @Input() border: string = '';\n  @Input() borderRadius: string = '';\n  @Input() enableMouseLeave: boolean = true; \n  @Output() close: EventEmitter<Event> = new EventEmitter();\n\n  constructor(private elementRef: ElementRef,private renderer: Renderer2) {}\n\n  toggleDropdown() {\n    this.dropdownOpen = !this.dropdownOpen;\n    this.dropdownOpenChange.emit(this.dropdownOpen);\n\n    \n    if (this.dropdownOpen) {\n      this.setDropdownPosition();\n    }\n  }\n\n  onMouseOut() {\n    if (this.enableMouseLeave) {\n      this.close.emit();\n      this.dropdownOpen = false;\n      this.dropdownOpenChange.emit(this.dropdownOpen);\n    }\n  }\n\n  onClose() {\n    this.close.emit();\n  }\n\n  get dropdownStyles() {\n    return {\n      width: this.dropdownWidth,\n      border: this.border,\n      borderRadius: this.borderRadius,\n    };\n  }\n\n  get yourStyles() {\n    return {\n      ...this.customStyles,\n    };\n  }\n\n  @HostListener('document:click', ['$event.target'])\n  onClickOutside(targetElement: HTMLElement) {\n    const clickedInside = this.elementRef.nativeElement.contains(targetElement);\n    if (!clickedInside && this.dropdownOpen) {\n      this.dropdownOpen = false;\n      this.dropdownOpenChange.emit(this.dropdownOpen);\n    }\n  }\n\n  // private setDropdownPosition(): void {\n  //   const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-menu');\n  //   const dropdownRect = dropdown.getBoundingClientRect();\n  //   const parentRect = this.elementRef.nativeElement.getBoundingClientRect();\n  //   const viewportHeight = window.innerHeight;\n  //   const viewportWidth = window.innerWidth;\n\n    \n  //   console.log('Dropdown Rect:', dropdownRect);\n  //   console.log('Parent Rect:', parentRect);\n  //   console.log('Viewport:', { width: viewportWidth, height: viewportHeight });\n  \n\n  //   // Check vertical space\n  //   if (viewportHeight - parentRect.bottom < dropdownRect.height) {\n  //     // Position above\n  //     this.renderer.setStyle(dropdown, 'top', 'auto');\n  //     this.renderer.setStyle(dropdown, 'bottom', `${parentRect.height}px`);\n  //   } else {\n  //     // Position below\n  //     this.renderer.setStyle(dropdown, 'top', `${parentRect.height}px`);\n  //     this.renderer.setStyle(dropdown, 'bottom', 'auto');\n  //   }\n\n  //   // Check horizontal space\n  //   if (parentRect.left + dropdownRect.width > viewportWidth) {\n  //     // Position to the left\n  //     this.renderer.setStyle(dropdown, 'left', 'auto');\n  //     this.renderer.setStyle(dropdown, 'right', '0');\n  //   } else if (parentRect.right - dropdownRect.width < 0) {\n  //     // Position to the right\n  //     this.renderer.setStyle(dropdown, 'left', '0');\n  //     this.renderer.setStyle(dropdown, 'right', 'auto');\n  //   } else {\n  //     // Default alignment\n  //     this.renderer.setStyle(dropdown, 'left', '0');\n  //     this.renderer.setStyle(dropdown, 'right', 'auto');\n  //   }\n  // }\n\n  ngAfterViewChecked() {\n    if (this.dropdownOpen) {\n      this.setDropdownPosition();\n    }\n  }\n\n  private setDropdownPosition(): void {\n    const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-container > div');\n    // const triggerElement = this.elementRef.nativeElement.querySelector('dropdown-menu')\n  \n    if (!dropdown) {\n      console.warn('Dropdown element not found.');\n      return;\n    }\n  \n    const dropdownRect = dropdown.getBoundingClientRect();\n    const parentRect = this.elementRef.nativeElement.getBoundingClientRect();\n    const viewportHeight = window.innerHeight;\n    const viewportWidth = window.innerWidth;\n\n    \n    console.log('Dropdown Rect:', dropdownRect);\n    console.log('Parent Rect:', parentRect);\n    console.log('Viewport:', { width: viewportWidth, height: viewportHeight });\n  \n    // Vertical Positioning\n    if (viewportHeight - parentRect.bottom < dropdownRect.height) {\n      // Not enough space below, position above\n      console.log('not enough space below')\n      const topPosition = parentRect.top - dropdownRect.height;\n      console.log('top pos:', topPosition);\n      this.renderer.setStyle(dropdown, 'top', `auto`);\n      this.renderer.setStyle(dropdown, 'bottom', '15px');\n    } else {\n      // Enough space below, position below\n      console.log('Enough space below')\n      const topPosition = parentRect.bottom;\n      this.renderer.setStyle(dropdown, 'top', `20px`);\n      this.renderer.setStyle(dropdown, 'bottom', 'auto');\n    }\n  \n    // Horizontal Positioning\n    if (parentRect.left + dropdownRect.width > viewportWidth) {\n      console.log('not Enough space right')\n      const leftPosition = viewportWidth - dropdownRect.width - 10;\n      this.renderer.setStyle(dropdown, 'left', `auto`);\n      // this.renderer.setStyle(dropdown, 'left', `${Math.max(leftPosition, 0)}px`);\n      this.renderer.setStyle(dropdown, 'right', '10px');\n    } else {\n      console.log('Enough space right')\n      const leftPosition = parentRect.left;\n      this.renderer.setStyle(dropdown, 'left', `${10}px`);\n      this.renderer.setStyle(dropdown, 'right', 'auto');\n    }\n  }\n  \n}","<span class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n  <span (click)=\"toggleDropdown()\" class=\"dropdown-menu\">\n    <ng-content select=\"[dropdown-trigger]\"></ng-content>\n  </span>\n\n  <div\n    [ngClass]=\"{'z-[9999]': true}\"\n    *ngIf=\"dropdownOpen\"\n    (mouseleave)=\"onMouseOut()\"\n    [attr.aria-hidden]=\"!dropdownOpen\"\n    class=\"absolute bottom-2 right-0 {{popUpClass}}\"\n    [ngStyle]=\"yourStyles\"\n  >\n    <ng-content select=\"[dropdown-content]\"></ng-content>\n  </div>\n</span>"]}
@@ -3,19 +3,19 @@ export class Config {
3
3
  typeOptions = [
4
4
  {
5
5
  type: DataFilterType.String,
6
- options: [ConditionalOptions.Equal, ConditionalOptions.NotEqual]
6
+ options: [ConditionalOptions.On, ConditionalOptions.NotEqual]
7
7
  },
8
8
  {
9
9
  type: DataFilterType.Integer,
10
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
10
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
11
11
  },
12
12
  {
13
13
  type: DataFilterType.Decimal,
14
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
14
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
15
15
  },
16
16
  {
17
17
  type: DataFilterType.Credit,
18
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
18
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
19
19
  },
20
20
  {
21
21
  type: DataFilterType.Date,
@@ -31,4 +31,4 @@ export class Config {
31
31
  return typeOption ? typeOption.options : null;
32
32
  }
33
33
  }
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQWUsTUFBTSx1QkFBdUIsQ0FBQztBQUV4RixNQUFNLE9BQU8sTUFBTTtJQUNmLFdBQVcsR0FBa0I7UUFDekI7WUFDRSxJQUFJLEVBQUUsY0FBYyxDQUFDLE1BQU07WUFDM0IsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUMsS0FBSyxFQUFDLGtCQUFrQixDQUFDLFFBQVEsQ0FBQztTQUNoRTtRQUNEO1lBQ0UsSUFBSSxFQUFFLGNBQWMsQ0FBQyxPQUFPO1lBQzVCLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDLEtBQUssRUFBRSxrQkFBa0IsQ0FBQyxRQUFRLEVBQUUsa0JBQWtCLENBQUMsV0FBVyxDQUFDO1NBQ2pHO1FBQ0Q7WUFDRSxJQUFJLEVBQUUsY0FBYyxDQUFDLE9BQU87WUFDNUIsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUMsS0FBSyxFQUFFLGtCQUFrQixDQUFDLFFBQVEsRUFBRSxrQkFBa0IsQ0FBQyxXQUFXLENBQUM7U0FDakc7UUFDRDtZQUNFLElBQUksRUFBRSxjQUFjLENBQUMsTUFBTTtZQUMzQixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLEVBQUUsa0JBQWtCLENBQUMsUUFBUSxFQUFFLGtCQUFrQixDQUFDLFdBQVcsQ0FBQztTQUNqRztRQUNEO1lBQ0UsSUFBSSxFQUFFLGNBQWMsQ0FBQyxJQUFJO1lBQ3pCLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDLEVBQUUsRUFBQyxrQkFBa0IsQ0FBQyxNQUFNLEVBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDO1NBQ3BGO1FBQ0Q7WUFDRSxJQUFJLEVBQUUsY0FBYyxDQUFDLElBQUk7WUFDekIsT0FBTyxFQUFFLENBQUMsa0JBQWtCLENBQUMsR0FBRyxFQUFDLGtCQUFrQixDQUFDLEVBQUUsQ0FBQztTQUN4RDtLQUNGLENBQUM7SUFFRixtQkFBbUIsQ0FBQyxVQUEwQjtRQUM1QyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssVUFBVSxDQUFDLENBQUM7UUFDL0UsT0FBTyxVQUFVLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUNsRCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25kaXRpb25hbE9wdGlvbnMsIERhdGFGaWx0ZXJUeXBlLCBJVHlwZU9wdGlvbiB9IGZyb20gXCIuL21vZGVscy90YWJsZS1maWx0ZXJcIjtcblxuZXhwb3J0IGNsYXNzIENvbmZpZyB7XG4gICAgdHlwZU9wdGlvbnM6IElUeXBlT3B0aW9uW10gPSBbXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5TdHJpbmcsXG4gICAgICAgICAgb3B0aW9uczogW0NvbmRpdGlvbmFsT3B0aW9ucy5FcXVhbCxDb25kaXRpb25hbE9wdGlvbnMuTm90RXF1YWxdXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5JbnRlZ2VyLFxuICAgICAgICAgIG9wdGlvbnM6IFtDb25kaXRpb25hbE9wdGlvbnMuRXF1YWwsIENvbmRpdGlvbmFsT3B0aW9ucy5MZXNzVGhhbiwgQ29uZGl0aW9uYWxPcHRpb25zLkdyZWF0ZXJUaGFuXSBcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgIHR5cGU6IERhdGFGaWx0ZXJUeXBlLkRlY2ltYWwsXG4gICAgICAgICAgb3B0aW9uczogW0NvbmRpdGlvbmFsT3B0aW9ucy5FcXVhbCwgQ29uZGl0aW9uYWxPcHRpb25zLkxlc3NUaGFuLCBDb25kaXRpb25hbE9wdGlvbnMuR3JlYXRlclRoYW5dXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5DcmVkaXQsXG4gICAgICAgICAgb3B0aW9uczogW0NvbmRpdGlvbmFsT3B0aW9ucy5FcXVhbCwgQ29uZGl0aW9uYWxPcHRpb25zLkxlc3NUaGFuLCBDb25kaXRpb25hbE9wdGlvbnMuR3JlYXRlclRoYW5dXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5EYXRlLFxuICAgICAgICAgIG9wdGlvbnM6IFtDb25kaXRpb25hbE9wdGlvbnMuT24sQ29uZGl0aW9uYWxPcHRpb25zLkJlZm9yZSxDb25kaXRpb25hbE9wdGlvbnMuQWZ0ZXJdIFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgdHlwZTogRGF0YUZpbHRlclR5cGUuQm9vbCxcbiAgICAgICAgICBvcHRpb25zOiBbQ29uZGl0aW9uYWxPcHRpb25zLlllcyxDb25kaXRpb25hbE9wdGlvbnMuTm9dXG4gICAgICAgIH1cbiAgICAgIF07XG5cbiAgICAgIGdldENvbmRpdGlvbk9wdGlvbnMoZmlsdGVyVHlwZTogRGF0YUZpbHRlclR5cGUpOiBzdHJpbmdbXSB8IG51bGwge1xuICAgICAgICBjb25zdCB0eXBlT3B0aW9uID0gdGhpcy50eXBlT3B0aW9ucy5maW5kKG9wdGlvbiA9PiBvcHRpb24udHlwZSA9PT0gZmlsdGVyVHlwZSk7XG4gICAgICAgIHJldHVybiB0eXBlT3B0aW9uID8gdHlwZU9wdGlvbi5vcHRpb25zIDogbnVsbDtcbiAgICB9IFxufVxuXG5cbiJdfQ==
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQWUsTUFBTSx1QkFBdUIsQ0FBQztBQUV4RixNQUFNLE9BQU8sTUFBTTtJQUNqQixXQUFXLEdBQWtCO1FBQzNCO1lBQ0UsSUFBSSxFQUFFLGNBQWMsQ0FBQyxNQUFNO1lBQzNCLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDLEVBQUUsRUFBQyxrQkFBa0IsQ0FBQyxRQUFRLENBQUM7U0FDN0Q7UUFDRDtZQUNFLElBQUksRUFBRSxjQUFjLENBQUMsT0FBTztZQUM1QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUUsa0JBQWtCLENBQUMsTUFBTSxFQUFDLGtCQUFrQixDQUFDLGdCQUFnQixFQUFFLGtCQUFrQixDQUFDLEtBQUssRUFBQyxrQkFBa0IsQ0FBQyxtQkFBbUIsQ0FBQztTQUNqSztRQUNEO1lBQ0UsSUFBSSxFQUFFLGNBQWMsQ0FBQyxPQUFPO1lBQzVCLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDLEVBQUUsRUFBRSxrQkFBa0IsQ0FBQyxNQUFNLEVBQUMsa0JBQWtCLENBQUMsZ0JBQWdCLEVBQUUsa0JBQWtCLENBQUMsS0FBSyxFQUFDLGtCQUFrQixDQUFDLG1CQUFtQixDQUFDO1NBQ2pLO1FBQ0Q7WUFDRSxJQUFJLEVBQUUsY0FBYyxDQUFDLE1BQU07WUFDM0IsT0FBTyxFQUFDLENBQUMsa0JBQWtCLENBQUMsRUFBRSxFQUFFLGtCQUFrQixDQUFDLE1BQU0sRUFBQyxrQkFBa0IsQ0FBQyxnQkFBZ0IsRUFBRSxrQkFBa0IsQ0FBQyxLQUFLLEVBQUMsa0JBQWtCLENBQUMsbUJBQW1CLENBQUM7U0FDaEs7UUFDRDtZQUNFLElBQUksRUFBRSxjQUFjLENBQUMsSUFBSTtZQUN6QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQyxFQUFFLEVBQUMsa0JBQWtCLENBQUMsTUFBTSxFQUFDLGtCQUFrQixDQUFDLEtBQUssQ0FBQztTQUNwRjtRQUNEO1lBQ0UsSUFBSSxFQUFFLGNBQWMsQ0FBQyxJQUFJO1lBQ3pCLE9BQU8sRUFBRSxDQUFDLGtCQUFrQixDQUFDLEdBQUcsRUFBQyxrQkFBa0IsQ0FBQyxFQUFFLENBQUM7U0FDeEQ7S0FDRixDQUFDO0lBRUUsbUJBQW1CLENBQUMsVUFBMEI7UUFDNUMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxNQUFNLENBQUMsSUFBSSxLQUFLLFVBQVUsQ0FBQyxDQUFDO1FBQy9FLE9BQU8sVUFBVSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDbEQsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uZGl0aW9uYWxPcHRpb25zLCBEYXRhRmlsdGVyVHlwZSwgSVR5cGVPcHRpb24gfSBmcm9tIFwiLi9tb2RlbHMvdGFibGUtZmlsdGVyXCI7XG5cbmV4cG9ydCBjbGFzcyBDb25maWcge1xuICB0eXBlT3B0aW9uczogSVR5cGVPcHRpb25bXSA9IFtcbiAgICB7XG4gICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5TdHJpbmcsXG4gICAgICBvcHRpb25zOiBbQ29uZGl0aW9uYWxPcHRpb25zLk9uLENvbmRpdGlvbmFsT3B0aW9ucy5Ob3RFcXVhbF1cbiAgICB9LFxuICAgIHtcbiAgICAgIHR5cGU6IERhdGFGaWx0ZXJUeXBlLkludGVnZXIsXG4gICAgICBvcHRpb25zOiBbQ29uZGl0aW9uYWxPcHRpb25zLk9uLCBDb25kaXRpb25hbE9wdGlvbnMuQmVmb3JlLENvbmRpdGlvbmFsT3B0aW9ucy5MZXNzVGhhbkFuZEVxdWFsLCBDb25kaXRpb25hbE9wdGlvbnMuQWZ0ZXIsQ29uZGl0aW9uYWxPcHRpb25zLkdyZWF0ZXJUaGFuQW5kRXF1YWxdXG4gICAgfSxcbiAgICB7XG4gICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5EZWNpbWFsLFxuICAgICAgb3B0aW9uczogW0NvbmRpdGlvbmFsT3B0aW9ucy5PbiwgQ29uZGl0aW9uYWxPcHRpb25zLkJlZm9yZSxDb25kaXRpb25hbE9wdGlvbnMuTGVzc1RoYW5BbmRFcXVhbCwgQ29uZGl0aW9uYWxPcHRpb25zLkFmdGVyLENvbmRpdGlvbmFsT3B0aW9ucy5HcmVhdGVyVGhhbkFuZEVxdWFsXVxuICAgIH0sXG4gICAge1xuICAgICAgdHlwZTogRGF0YUZpbHRlclR5cGUuQ3JlZGl0LFxuICAgICAgb3B0aW9uczpbQ29uZGl0aW9uYWxPcHRpb25zLk9uLCBDb25kaXRpb25hbE9wdGlvbnMuQmVmb3JlLENvbmRpdGlvbmFsT3B0aW9ucy5MZXNzVGhhbkFuZEVxdWFsLCBDb25kaXRpb25hbE9wdGlvbnMuQWZ0ZXIsQ29uZGl0aW9uYWxPcHRpb25zLkdyZWF0ZXJUaGFuQW5kRXF1YWxdXG4gICAgfSxcbiAgICB7XG4gICAgICB0eXBlOiBEYXRhRmlsdGVyVHlwZS5EYXRlLFxuICAgICAgb3B0aW9uczogW0NvbmRpdGlvbmFsT3B0aW9ucy5PbixDb25kaXRpb25hbE9wdGlvbnMuQmVmb3JlLENvbmRpdGlvbmFsT3B0aW9ucy5BZnRlcl1cbiAgICB9LFxuICAgIHtcbiAgICAgIHR5cGU6IERhdGFGaWx0ZXJUeXBlLkJvb2wsXG4gICAgICBvcHRpb25zOiBbQ29uZGl0aW9uYWxPcHRpb25zLlllcyxDb25kaXRpb25hbE9wdGlvbnMuTm9dXG4gICAgfVxuICBdO1xuXG4gICAgICBnZXRDb25kaXRpb25PcHRpb25zKGZpbHRlclR5cGU6IERhdGFGaWx0ZXJUeXBlKTogc3RyaW5nW10gfCBudWxsIHtcbiAgICAgICAgY29uc3QgdHlwZU9wdGlvbiA9IHRoaXMudHlwZU9wdGlvbnMuZmluZChvcHRpb24gPT4gb3B0aW9uLnR5cGUgPT09IGZpbHRlclR5cGUpO1xuICAgICAgICByZXR1cm4gdHlwZU9wdGlvbiA/IHR5cGVPcHRpb24ub3B0aW9ucyA6IG51bGw7XG4gICAgfSBcbn1cblxuXG4iXX0=
@@ -10,14 +10,13 @@ export var DataFilterType;
10
10
  })(DataFilterType || (DataFilterType = {}));
11
11
  export var ConditionalOptions;
12
12
  (function (ConditionalOptions) {
13
- ConditionalOptions["LessThan"] = "Less than";
14
- ConditionalOptions["GreaterThan"] = "Greater than";
15
- ConditionalOptions["Equal"] = "Equal";
16
- ConditionalOptions["NotEqual"] = "Not equal";
13
+ ConditionalOptions["GreaterThanAndEqual"] = "GTE";
14
+ ConditionalOptions["LessThanAndEqual"] = "LTE";
15
+ ConditionalOptions["NotEqual"] = "NEQ";
17
16
  ConditionalOptions["On"] = "On";
18
17
  ConditionalOptions["Before"] = "Before";
19
18
  ConditionalOptions["After"] = "After";
20
19
  ConditionalOptions["Yes"] = "Yes";
21
20
  ConditionalOptions["No"] = "No";
22
21
  })(ConditionalOptions || (ConditionalOptions = {}));
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvbW9kZWxzL3RhYmxlLWZpbHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQVFYO0FBUkQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHFDQUFtQixDQUFBO0lBQ25CLHFDQUFtQixDQUFBO0lBQ25CLG1DQUFnQixDQUFBO0lBQ2hCLCtCQUFhLENBQUE7SUFDYiwrQkFBYSxDQUFBO0lBQ2IsbUNBQWUsQ0FBQTtBQUNqQixDQUFDLEVBUlcsY0FBYyxLQUFkLGNBQWMsUUFRekI7QUFVRCxNQUFNLENBQU4sSUFBWSxrQkFVVjtBQVZGLFdBQVksa0JBQWtCO0lBQzVCLDRDQUFzQixDQUFBO0lBQ3RCLGtEQUE0QixDQUFBO0lBQzVCLHFDQUFlLENBQUE7SUFDZiw0Q0FBc0IsQ0FBQTtJQUN0QiwrQkFBUyxDQUFBO0lBQ1QsdUNBQWlCLENBQUE7SUFDakIscUNBQWUsQ0FBQTtJQUNmLGlDQUFXLENBQUE7SUFDWCwrQkFBUyxDQUFBO0FBQ1YsQ0FBQyxFQVZVLGtCQUFrQixLQUFsQixrQkFBa0IsUUFVNUIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBEYXRhRmlsdGVyVHlwZSB7XG4gIFN0cmluZyA9ICdTdHJpbmcnLFxuICBJbnRlZ2VyID0gJ0ludGVnZXInLFxuICBEZWNpbWFsID0gJ0RlY2ltYWwnLFxuICBDcmVkaXQ9ICdDcmVkaXQnLFxuICBEYXRlID0gJ0RhdGUnLFxuICBCb29sID0gXCJCb29sXCIsXG4gIE51bWJlcj1cIk51bWJlclwiXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGFGaWx0ZXIge1xuICBuYW1lOnN0cmluZyxcbiAgdHlwZTogRGF0YUZpbHRlclR5cGU7XG4gIHZhbHVlPzphbnk7IFxuICBjaGVja2VkOiBib29sZWFuO1xuICBjb25kaXRpb24/OnN0cmluZztcbn1cblxuZXhwb3J0IGVudW0gQ29uZGl0aW9uYWxPcHRpb25zIHtcbiAgTGVzc1RoYW4gPSAnTGVzcyB0aGFuJyxcbiAgR3JlYXRlclRoYW4gPSAnR3JlYXRlciB0aGFuJyxcbiAgRXF1YWwgPSAnRXF1YWwnLFxuICBOb3RFcXVhbCA9ICdOb3QgZXF1YWwnLFxuICBPbiA9ICdPbicsXG4gIEJlZm9yZSA9ICdCZWZvcmUnLFxuICBBZnRlciA9ICdBZnRlcicsXG4gIFllcyA9ICdZZXMnLFxuICBObyA9ICdObydcbiB9XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVR5cGVPcHRpb24ge1xuICB0eXBlOiBEYXRhRmlsdGVyVHlwZTtcbiAgb3B0aW9uczogc3RyaW5nW107XG59XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmVyYmVuLW5nLXVpL3NyYy9saWIvbW9kZWxzL3RhYmxlLWZpbHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxjQVFYO0FBUkQsV0FBWSxjQUFjO0lBQ3hCLG1DQUFpQixDQUFBO0lBQ2pCLHFDQUFtQixDQUFBO0lBQ25CLHFDQUFtQixDQUFBO0lBQ25CLG1DQUFnQixDQUFBO0lBQ2hCLCtCQUFhLENBQUE7SUFDYiwrQkFBYSxDQUFBO0lBQ2IsbUNBQWUsQ0FBQTtBQUNqQixDQUFDLEVBUlcsY0FBYyxLQUFkLGNBQWMsUUFRekI7QUFVRCxNQUFNLENBQU4sSUFBWSxrQkFTVjtBQVRGLFdBQVksa0JBQWtCO0lBQzVCLGlEQUEyQixDQUFBO0lBQzNCLDhDQUF3QixDQUFBO0lBQ3hCLHNDQUFnQixDQUFBO0lBQ2hCLCtCQUFTLENBQUE7SUFDVCx1Q0FBaUIsQ0FBQTtJQUNqQixxQ0FBZSxDQUFBO0lBQ2YsaUNBQVcsQ0FBQTtJQUNYLCtCQUFTLENBQUE7QUFDVixDQUFDLEVBVFUsa0JBQWtCLEtBQWxCLGtCQUFrQixRQVM1QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIERhdGFGaWx0ZXJUeXBlIHtcbiAgU3RyaW5nID0gJ1N0cmluZycsXG4gIEludGVnZXIgPSAnSW50ZWdlcicsXG4gIERlY2ltYWwgPSAnRGVjaW1hbCcsXG4gIENyZWRpdD0gJ0NyZWRpdCcsXG4gIERhdGUgPSAnRGF0ZScsXG4gIEJvb2wgPSBcIkJvb2xcIixcbiAgTnVtYmVyPVwiTnVtYmVyXCJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRGF0YUZpbHRlciB7XG4gIG5hbWU6c3RyaW5nLFxuICB0eXBlOiBEYXRhRmlsdGVyVHlwZTtcbiAgdmFsdWU/OmFueTsgXG4gIGNoZWNrZWQ6IGJvb2xlYW47XG4gIGNvbmRpdGlvbj86c3RyaW5nO1xufVxuXG5leHBvcnQgZW51bSBDb25kaXRpb25hbE9wdGlvbnMge1xuICBHcmVhdGVyVGhhbkFuZEVxdWFsID0gJ0dURScsXG4gIExlc3NUaGFuQW5kRXF1YWwgPSAnTFRFJyxcbiAgTm90RXF1YWwgPSAnTkVRJyxcbiAgT24gPSAnT24nLFxuICBCZWZvcmUgPSAnQmVmb3JlJyxcbiAgQWZ0ZXIgPSAnQWZ0ZXInLFxuICBZZXMgPSAnWWVzJyxcbiAgTm8gPSAnTm8nLFxuIH1cblxuZXhwb3J0IGludGVyZmFjZSBJVHlwZU9wdGlvbiB7XG4gIHR5cGU6IERhdGFGaWx0ZXJUeXBlO1xuICBvcHRpb25zOiBzdHJpbmdbXTtcbn1cbiJdfQ==
@@ -2071,10 +2071,9 @@ var DataFilterType;
2071
2071
  })(DataFilterType || (DataFilterType = {}));
2072
2072
  var ConditionalOptions;
2073
2073
  (function (ConditionalOptions) {
2074
- ConditionalOptions["LessThan"] = "Less than";
2075
- ConditionalOptions["GreaterThan"] = "Greater than";
2076
- ConditionalOptions["Equal"] = "Equal";
2077
- ConditionalOptions["NotEqual"] = "Not equal";
2074
+ ConditionalOptions["GreaterThanAndEqual"] = "GTE";
2075
+ ConditionalOptions["LessThanAndEqual"] = "LTE";
2076
+ ConditionalOptions["NotEqual"] = "NEQ";
2078
2077
  ConditionalOptions["On"] = "On";
2079
2078
  ConditionalOptions["Before"] = "Before";
2080
2079
  ConditionalOptions["After"] = "After";
@@ -2086,19 +2085,19 @@ class Config {
2086
2085
  typeOptions = [
2087
2086
  {
2088
2087
  type: DataFilterType.String,
2089
- options: [ConditionalOptions.Equal, ConditionalOptions.NotEqual]
2088
+ options: [ConditionalOptions.On, ConditionalOptions.NotEqual]
2090
2089
  },
2091
2090
  {
2092
2091
  type: DataFilterType.Integer,
2093
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
2092
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
2094
2093
  },
2095
2094
  {
2096
2095
  type: DataFilterType.Decimal,
2097
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
2096
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
2098
2097
  },
2099
2098
  {
2100
2099
  type: DataFilterType.Credit,
2101
- options: [ConditionalOptions.Equal, ConditionalOptions.LessThan, ConditionalOptions.GreaterThan]
2100
+ options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
2102
2101
  },
2103
2102
  {
2104
2103
  type: DataFilterType.Date,
@@ -3636,6 +3635,7 @@ class DataViewComponent {
3636
3635
  }
3637
3636
  onClearSearch() {
3638
3637
  this.searchValue = "";
3638
+ this.onSearchChange.emit({ key: this.searchKey, value: this.searchValue });
3639
3639
  }
3640
3640
  toggleChildView(viewType) {
3641
3641
  switch (viewType) {
@@ -5692,6 +5692,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImpor
5692
5692
 
5693
5693
  class VerbenPopUpComponent {
5694
5694
  elementRef;
5695
+ renderer;
5695
5696
  dropdownOpen = false;
5696
5697
  dropdownOpenChange = new EventEmitter();
5697
5698
  dropdownWidth = '';
@@ -5702,12 +5703,16 @@ class VerbenPopUpComponent {
5702
5703
  borderRadius = '';
5703
5704
  enableMouseLeave = true;
5704
5705
  close = new EventEmitter();
5705
- constructor(elementRef) {
5706
+ constructor(elementRef, renderer) {
5706
5707
  this.elementRef = elementRef;
5708
+ this.renderer = renderer;
5707
5709
  }
5708
5710
  toggleDropdown() {
5709
5711
  this.dropdownOpen = !this.dropdownOpen;
5710
5712
  this.dropdownOpenChange.emit(this.dropdownOpen);
5713
+ if (this.dropdownOpen) {
5714
+ this.setDropdownPosition();
5715
+ }
5711
5716
  }
5712
5717
  onMouseOut() {
5713
5718
  if (this.enableMouseLeave) {
@@ -5738,13 +5743,97 @@ class VerbenPopUpComponent {
5738
5743
  this.dropdownOpenChange.emit(this.dropdownOpen);
5739
5744
  }
5740
5745
  }
5741
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
5742
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: VerbenPopUpComponent, selector: "verben-pop-Up", inputs: { dropdownOpen: "dropdownOpen", dropdownWidth: "dropdownWidth", color: "color", customStyles: "customStyles", popUpClass: "popUpClass", border: "border", borderRadius: "borderRadius", enableMouseLeave: "enableMouseLeave" }, outputs: { dropdownOpenChange: "dropdownOpenChange", close: "close" }, host: { listeners: { "document:click": "onClickOutside($event.target)" } }, ngImport: i0, template: "<div class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n appDropdownPosition\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute top-2 left-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</div>\n", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
5746
+ // private setDropdownPosition(): void {
5747
+ // const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-menu');
5748
+ // const dropdownRect = dropdown.getBoundingClientRect();
5749
+ // const parentRect = this.elementRef.nativeElement.getBoundingClientRect();
5750
+ // const viewportHeight = window.innerHeight;
5751
+ // const viewportWidth = window.innerWidth;
5752
+ // console.log('Dropdown Rect:', dropdownRect);
5753
+ // console.log('Parent Rect:', parentRect);
5754
+ // console.log('Viewport:', { width: viewportWidth, height: viewportHeight });
5755
+ // // Check vertical space
5756
+ // if (viewportHeight - parentRect.bottom < dropdownRect.height) {
5757
+ // // Position above
5758
+ // this.renderer.setStyle(dropdown, 'top', 'auto');
5759
+ // this.renderer.setStyle(dropdown, 'bottom', `${parentRect.height}px`);
5760
+ // } else {
5761
+ // // Position below
5762
+ // this.renderer.setStyle(dropdown, 'top', `${parentRect.height}px`);
5763
+ // this.renderer.setStyle(dropdown, 'bottom', 'auto');
5764
+ // }
5765
+ // // Check horizontal space
5766
+ // if (parentRect.left + dropdownRect.width > viewportWidth) {
5767
+ // // Position to the left
5768
+ // this.renderer.setStyle(dropdown, 'left', 'auto');
5769
+ // this.renderer.setStyle(dropdown, 'right', '0');
5770
+ // } else if (parentRect.right - dropdownRect.width < 0) {
5771
+ // // Position to the right
5772
+ // this.renderer.setStyle(dropdown, 'left', '0');
5773
+ // this.renderer.setStyle(dropdown, 'right', 'auto');
5774
+ // } else {
5775
+ // // Default alignment
5776
+ // this.renderer.setStyle(dropdown, 'left', '0');
5777
+ // this.renderer.setStyle(dropdown, 'right', 'auto');
5778
+ // }
5779
+ // }
5780
+ ngAfterViewChecked() {
5781
+ if (this.dropdownOpen) {
5782
+ this.setDropdownPosition();
5783
+ }
5784
+ }
5785
+ setDropdownPosition() {
5786
+ const dropdown = this.elementRef.nativeElement.querySelector('.dropdown-container > div');
5787
+ // const triggerElement = this.elementRef.nativeElement.querySelector('dropdown-menu')
5788
+ if (!dropdown) {
5789
+ console.warn('Dropdown element not found.');
5790
+ return;
5791
+ }
5792
+ const dropdownRect = dropdown.getBoundingClientRect();
5793
+ const parentRect = this.elementRef.nativeElement.getBoundingClientRect();
5794
+ const viewportHeight = window.innerHeight;
5795
+ const viewportWidth = window.innerWidth;
5796
+ console.log('Dropdown Rect:', dropdownRect);
5797
+ console.log('Parent Rect:', parentRect);
5798
+ console.log('Viewport:', { width: viewportWidth, height: viewportHeight });
5799
+ // Vertical Positioning
5800
+ if (viewportHeight - parentRect.bottom < dropdownRect.height) {
5801
+ // Not enough space below, position above
5802
+ console.log('not enough space below');
5803
+ const topPosition = parentRect.top - dropdownRect.height;
5804
+ console.log('top pos:', topPosition);
5805
+ this.renderer.setStyle(dropdown, 'top', `auto`);
5806
+ this.renderer.setStyle(dropdown, 'bottom', '15px');
5807
+ }
5808
+ else {
5809
+ // Enough space below, position below
5810
+ console.log('Enough space below');
5811
+ const topPosition = parentRect.bottom;
5812
+ this.renderer.setStyle(dropdown, 'top', `20px`);
5813
+ this.renderer.setStyle(dropdown, 'bottom', 'auto');
5814
+ }
5815
+ // Horizontal Positioning
5816
+ if (parentRect.left + dropdownRect.width > viewportWidth) {
5817
+ console.log('not Enough space right');
5818
+ const leftPosition = viewportWidth - dropdownRect.width - 10;
5819
+ this.renderer.setStyle(dropdown, 'left', `auto`);
5820
+ // this.renderer.setStyle(dropdown, 'left', `${Math.max(leftPosition, 0)}px`);
5821
+ this.renderer.setStyle(dropdown, 'right', '10px');
5822
+ }
5823
+ else {
5824
+ console.log('Enough space right');
5825
+ const leftPosition = parentRect.left;
5826
+ this.renderer.setStyle(dropdown, 'left', `${10}px`);
5827
+ this.renderer.setStyle(dropdown, 'right', 'auto');
5828
+ }
5829
+ }
5830
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
5831
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.5", type: VerbenPopUpComponent, selector: "verben-pop-Up", inputs: { dropdownOpen: "dropdownOpen", dropdownWidth: "dropdownWidth", color: "color", customStyles: "customStyles", popUpClass: "popUpClass", border: "border", borderRadius: "borderRadius", enableMouseLeave: "enableMouseLeave" }, outputs: { dropdownOpenChange: "dropdownOpenChange", close: "close" }, host: { listeners: { "document:click": "onClickOutside($event.target)" } }, ngImport: i0, template: "<span class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\" class=\"dropdown-menu\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute bottom-2 right-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</span>", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
5743
5832
  }
5744
5833
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: VerbenPopUpComponent, decorators: [{
5745
5834
  type: Component,
5746
- args: [{ selector: 'verben-pop-Up', template: "<div class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n appDropdownPosition\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute top-2 left-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</div>\n", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"] }]
5747
- }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { dropdownOpen: [{
5835
+ args: [{ selector: 'verben-pop-Up', template: "<span class=\"relative dropdown-container\" [ngStyle]=\"dropdownStyles\">\n <span (click)=\"toggleDropdown()\" class=\"dropdown-menu\">\n <ng-content select=\"[dropdown-trigger]\"></ng-content>\n </span>\n\n <div\n [ngClass]=\"{'z-[9999]': true}\"\n *ngIf=\"dropdownOpen\"\n (mouseleave)=\"onMouseOut()\"\n [attr.aria-hidden]=\"!dropdownOpen\"\n class=\"absolute bottom-2 right-0 {{popUpClass}}\"\n [ngStyle]=\"yourStyles\"\n >\n <ng-content select=\"[dropdown-content]\"></ng-content>\n </div>\n</span>", styles: [".boxShadow{box-shadow:4px 4px 4px #00000040}.dropdown-content{transition:transform .2s ease-in-out,opacity .2s ease-in-out;transform:scale(.95);opacity:0}.dropdown-content.open{transform:scale(1);opacity:1}\n"] }]
5836
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { dropdownOpen: [{
5748
5837
  type: Input
5749
5838
  }], dropdownOpenChange: [{
5750
5839
  type: Output