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.
- package/esm2022/lib/components/data-view/data-view.component.mjs +2 -1
- package/esm2022/lib/components/pop-up/pop-up.component.mjs +95 -6
- package/esm2022/lib/config.mjs +5 -5
- package/esm2022/lib/models/table-filter.mjs +4 -5
- package/fesm2022/verben-ng-ui.mjs +102 -13
- package/fesm2022/verben-ng-ui.mjs.map +1 -1
- package/lib/components/pop-up/pop-up.component.d.ts +6 -3
- package/lib/models/table-filter.d.ts +3 -4
- package/package.json +1 -1
|
@@ -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":"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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 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
|
-
|
|
53
|
-
|
|
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: "<
|
|
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>"]}
|
package/esm2022/lib/config.mjs
CHANGED
|
@@ -3,19 +3,19 @@ export class Config {
|
|
|
3
3
|
typeOptions = [
|
|
4
4
|
{
|
|
5
5
|
type: DataFilterType.String,
|
|
6
|
-
options: [ConditionalOptions.
|
|
6
|
+
options: [ConditionalOptions.On, ConditionalOptions.NotEqual]
|
|
7
7
|
},
|
|
8
8
|
{
|
|
9
9
|
type: DataFilterType.Integer,
|
|
10
|
-
options: [ConditionalOptions.
|
|
10
|
+
options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
|
|
11
11
|
},
|
|
12
12
|
{
|
|
13
13
|
type: DataFilterType.Decimal,
|
|
14
|
-
options: [ConditionalOptions.
|
|
14
|
+
options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
|
|
15
15
|
},
|
|
16
16
|
{
|
|
17
17
|
type: DataFilterType.Credit,
|
|
18
|
-
options: [ConditionalOptions.
|
|
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,
|
|
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["
|
|
14
|
-
ConditionalOptions["
|
|
15
|
-
ConditionalOptions["
|
|
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,
|
|
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["
|
|
2075
|
-
ConditionalOptions["
|
|
2076
|
-
ConditionalOptions["
|
|
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.
|
|
2088
|
+
options: [ConditionalOptions.On, ConditionalOptions.NotEqual]
|
|
2090
2089
|
},
|
|
2091
2090
|
{
|
|
2092
2091
|
type: DataFilterType.Integer,
|
|
2093
|
-
options: [ConditionalOptions.
|
|
2092
|
+
options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
|
|
2094
2093
|
},
|
|
2095
2094
|
{
|
|
2096
2095
|
type: DataFilterType.Decimal,
|
|
2097
|
-
options: [ConditionalOptions.
|
|
2096
|
+
options: [ConditionalOptions.On, ConditionalOptions.Before, ConditionalOptions.LessThanAndEqual, ConditionalOptions.After, ConditionalOptions.GreaterThanAndEqual]
|
|
2098
2097
|
},
|
|
2099
2098
|
{
|
|
2100
2099
|
type: DataFilterType.Credit,
|
|
2101
|
-
options: [ConditionalOptions.
|
|
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
|
-
|
|
5742
|
-
|
|
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: "<
|
|
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
|