ng-zenduit 2.0.12 → 2.0.13
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/esm2020/lib/groups/zendu-groups.component.mjs +5 -1
- package/esm2020/lib/pagination-bar/zendu-pagination-bar.component.mjs +1 -1
- package/esm2020/lib/select/zendu-select.component.mjs +9 -3
- package/esm2020/lib/top-nav/zen-top-nav.component.mjs +3 -3
- package/esm2020/lib/top-nav-item/zen-top-nav-item.component.mjs +2 -2
- package/fesm2015/ng-zenduit.mjs +17 -6
- package/fesm2015/ng-zenduit.mjs.map +1 -1
- package/fesm2020/ng-zenduit.mjs +16 -6
- package/fesm2020/ng-zenduit.mjs.map +1 -1
- package/lib/select/zendu-select.component.d.ts +5 -1
- package/lib/top-nav/zen-top-nav.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -37,6 +37,10 @@ export class ZenduGroupsComponent {
|
|
|
37
37
|
if (changes['dataSource']) {
|
|
38
38
|
this.buildTreeLevels();
|
|
39
39
|
}
|
|
40
|
+
if ((changes['filteredDataSource'] || changes['dataSource']) &&
|
|
41
|
+
this._treeMap.size > 0 && this.filteredDataSource?.length) {
|
|
42
|
+
this.filteredDataSource = this.sortTreeOrder(this.filteredDataSource);
|
|
43
|
+
}
|
|
40
44
|
}
|
|
41
45
|
onOutsideClick(event) {
|
|
42
46
|
if (this.inline || !this.isOpen)
|
|
@@ -344,4 +348,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
344
348
|
type: HostListener,
|
|
345
349
|
args: ['window:mousedown', ['$event']]
|
|
346
350
|
}] } });
|
|
347
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-groups.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/groups/zendu-groups.component.ts","../../../../../projects/ng-zenduit/src/lib/groups/zendu-groups.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { DataSource } from '../filter/filtersConfig';\n\n@Component({\n  selector: 'zen-groups',\n  templateUrl: './zendu-groups.component.html',\n  styleUrls: ['./zendu-groups.component.scss'],\n})\nexport class ZenduGroupsComponent implements OnChanges {\n  @Input() dataSource: DataSource[] = [];\n  @Input() filteredDataSource: DataSource[] = [];\n  @Input() hideSelectAll = false;\n  @Input() isSelectedAll = false;\n  @Input() inline = false;\n  @Input() width = '300px';\n  @Input() placeholder = 'Select group';\n  @Input() hideSearch = false;\n  @Input() idProp: string = 'id';\n  @Input() displayProp: string = 'name';\n\n  @Output() isSelectedAllChange = new EventEmitter<boolean>();\n  @Output() checkedChange = new EventEmitter<DataSource>();\n\n  public isOpen = false;\n  public openUpward = false;\n  public searchText = '';\n  private _searchFilteredDataSource: DataSource[] | null = null;\n\n  private _treeMap = new Map<string | number, DataSource>();\n  private _childCountCache = new Map<string | number, number>();\n\n  constructor(private _elementRef: ElementRef) {}\n\n  private getChildren(item: any): string[] | undefined {\n    return item.children || item.Children || item.Childrens;\n  }\n\n  public hasChildren(item: any): boolean {\n    const children = this.getChildren(item);\n    return !!children && children.length > 0;\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['dataSource']) {\n      this.buildTreeLevels();\n    }\n  }\n\n  @HostListener('window:mousedown', ['$event'])\n  onOutsideClick(event: MouseEvent) {\n    if (this.inline || !this.isOpen) return;\n    const target = event.target as HTMLElement;\n    if (!this._elementRef.nativeElement.contains(target)) {\n      this.isOpen = false;\n    }\n  }\n\n  public toggleDropdown(): void {\n    this.isOpen = !this.isOpen;\n    if (this.isOpen) {\n      this.openUpward = this.shouldOpenUpward(300);\n    } else {\n      this.searchText = '';\n      this._searchFilteredDataSource = null;\n    }\n  }\n\n  private shouldOpenUpward(dropdownHeight: number): boolean {\n    const rect = this._elementRef.nativeElement.getBoundingClientRect();\n    return (window.innerHeight - rect.bottom) < dropdownHeight;\n  }\n\n  public get displayDataSource(): DataSource[] {\n    if (this._searchFilteredDataSource !== null) {\n      return this._searchFilteredDataSource;\n    }\n    return this.filteredDataSource;\n  }\n\n  public onSearchChange(): void {\n    if (!this.searchText) {\n      this._searchFilteredDataSource = null;\n      return;\n    }\n\n    const lowerSearch = this.searchText.toLowerCase();\n    const matchingIds = new Set<string | number>();\n\n    for (const el of this.dataSource) {\n      const name = typeof el[this.displayProp] === 'number' ? el[this.displayProp].toString() : el[this.displayProp];\n      if (name.toLowerCase().includes(lowerSearch)) {\n        matchingIds.add(el[this.idProp]);\n        // Include all ancestors\n        let current = el;\n        while (current.parentId != null) {\n          matchingIds.add(current.parentId);\n          const parent = this._treeMap.get(current.parentId);\n          if (!parent) break;\n          current = parent;\n        }\n      }\n    }\n\n    let filtered = this.dataSource.filter(el => matchingIds.has(el[this.idProp]));\n\n    // Auto-expand parents when searching\n    for (const el of filtered) {\n      if (this.hasChildren(el)) {\n        el.isOpen = true;\n      }\n    }\n\n    this._searchFilteredDataSource = this.sortTreeOrder(filtered);\n  }\n\n  public get selectedCount(): number {\n    return this.dataSource?.filter(d => d.checked).length || 0;\n  }\n\n  public get selectedLabel(): string {\n    const count = this.selectedCount;\n    if (count === 0) return '';\n    if (count === 1) {\n      const item = this.dataSource.find(d => d.checked);\n      return item ? item[this.displayProp]?.toString() : '';\n    }\n    return `${count} selected`;\n  }\n\n  public get hasActiveItems(): boolean {\n    return this.dataSource?.some(d => d.checked) || false;\n  }\n\n  public onSelectAll(): void {\n    this.dataSource.forEach(d => (d.checked = this.isSelectedAll));\n    this.isSelectedAllChange.emit(this.isSelectedAll);\n  }\n\n  public onCheckChanged(dsItem: DataSource): void {\n    this.cascadeToChildren(dsItem);\n    this.updateParentCheckedState(dsItem);\n    this.checkedChange.emit(dsItem);\n  }\n\n  private buildTreeLevels(): void {\n    if (!this.dataSource?.length) return;\n    const hasChildren = this.dataSource.some(d => this.hasChildren(d));\n    if (!hasChildren) return;\n\n    const map = new Map<string | number, DataSource>();\n    for (const item of this.dataSource) {\n      map.set(item[this.idProp], item);\n    }\n    this._treeMap = map;\n\n    for (const item of this.dataSource) {\n      const children = this.getChildren(item);\n      if (children?.length) {\n        for (const childId of children) {\n          const child = map.get(childId);\n          if (child && child.parentId == null) {\n            child.parentId = item[this.idProp];\n          }\n        }\n      }\n    }\n\n    for (const item of this.dataSource) {\n      let level = 0;\n      let current = item;\n      while (current.parentId != null) {\n        level++;\n        const parent = map.get(current.parentId);\n        if (!parent) break;\n        current = parent;\n      }\n      item.level = level;\n    }\n\n    this._childCountCache.clear();\n    const countChildren = (item: DataSource): number => {\n      const children = this.getChildren(item);\n      if (!children?.length) return 0;\n      let count = 0;\n      for (const childId of children) {\n        const child = map.get(childId);\n        if (child) {\n          const childLeaves = countChildren(child);\n          count += childLeaves > 0 ? childLeaves : 1;\n        }\n      }\n      return count;\n    };\n    for (const item of this.dataSource) {\n      if (this.hasChildren(item)) {\n        this._childCountCache.set(item[this.idProp], countChildren(item));\n      }\n    }\n  }\n\n  public sortTreeOrder(items: DataSource[]): DataSource[] {\n    const itemSet = new Set(items.map(i => i[this.idProp]));\n    const visited = new Set<string | number>();\n    const ordered: DataSource[] = [];\n    const visit = (item: DataSource) => {\n      if (visited.has(item[this.idProp])) return;\n      if (!itemSet.has(item[this.idProp])) return;\n      visited.add(item[this.idProp]);\n      ordered.push(item);\n      const children = this.getChildren(item);\n      if (children?.length) {\n        for (const childId of children) {\n          const child = this._treeMap.get(childId);\n          if (child) {\n            visit(child);\n          }\n        }\n      }\n    };\n    for (const item of items) {\n      if (item.parentId == null) {\n        visit(item);\n      }\n    }\n    for (const item of items) {\n      if (!visited.has(item[this.idProp])) {\n        ordered.push(item);\n      }\n    }\n    return ordered;\n  }\n\n  public isTreeItemVisible(dsItem: DataSource): boolean {\n    if (dsItem.parentId == null) {\n      return true;\n    }\n    const parent = this._treeMap.get(dsItem.parentId);\n    if (!parent) {\n      return true;\n    }\n    return parent.isOpen && this.isTreeItemVisible(parent);\n  }\n\n  public toggleTreeNode(dsItem: DataSource): void {\n    dsItem.isOpen = !dsItem.isOpen;\n  }\n\n  public getChildCount(dsItem: DataSource): number {\n    return this._childCountCache.get(dsItem[this.idProp]) || 0;\n  }\n\n  public isTreeItemIndeterminate(dsItem: DataSource): boolean {\n    if (!this.hasChildren(dsItem)) return false;\n    const allDescendants = this.getAllDescendants(dsItem);\n    if (!allDescendants.length) return false;\n    const checkedCount = allDescendants.filter(d => d.checked).length;\n    return checkedCount > 0 && checkedCount < allDescendants.length;\n  }\n\n  private getAllDescendants(dsItem: DataSource): DataSource[] {\n    const result: DataSource[] = [];\n    const children = this.getChildren(dsItem);\n    if (!children?.length) return result;\n    for (const childId of children) {\n      const child = this._treeMap.get(childId);\n      if (child) {\n        result.push(child);\n        result.push(...this.getAllDescendants(child));\n      }\n    }\n    return result;\n  }\n\n  private updateParentCheckedState(dsItem: DataSource): void {\n    if (dsItem.parentId == null) return;\n    const parent = this._treeMap.get(dsItem.parentId);\n    if (!parent || !this.hasChildren(parent)) return;\n    const allDescendants = this.getAllDescendants(parent);\n    const allChecked = allDescendants.every(d => d.checked);\n    parent.checked = allChecked;\n    this.updateParentCheckedState(parent);\n  }\n\n  private cascadeToChildren(item: DataSource): void {\n    const children = this.getChildren(item);\n    if (!children?.length) return;\n    this.dataSource.forEach(data => {\n      if (item[this.idProp] == data[this.idProp]) {\n        return;\n      }\n      if (children.includes(<string>data[this.idProp])) {\n        data.checked = item.checked;\n        if (this.hasChildren(data)) {\n          this.cascadeToChildren(data);\n        }\n      }\n    });\n  }\n\n  public getTreeConnectors(dsItem: DataSource): string[] {\n    if (!dsItem.level) return [];\n\n    const isLastFlags: boolean[] = [];\n    let current: DataSource | undefined = dsItem;\n\n    for (let l = dsItem.level; l >= 1; l--) {\n      const parent = this._treeMap.get(current!.parentId!);\n      const parentChildren = parent ? this.getChildren(parent) : undefined;\n      if (!parentChildren?.length) {\n        isLastFlags.push(true);\n      } else {\n        const lastChildId = parentChildren[parentChildren.length - 1];\n        isLastFlags.push(current![this.idProp] === lastChildId);\n      }\n      current = parent;\n    }\n\n    isLastFlags.reverse();\n\n    const result: string[] = [];\n    for (let i = 0; i < isLastFlags.length; i++) {\n      const isItemLevel = (i === isLastFlags.length - 1);\n      const isLast = isLastFlags[i];\n\n      if (isItemLevel) {\n        result.push(isLast ? 'elbow' : 'branch');\n      } else {\n        result.push(isLast ? 'none' : 'through');\n      }\n    }\n    return result;\n  }\n\n  public getTreeMap(): Map<string | number, DataSource> {\n    return this._treeMap;\n  }\n}\n","<!-- Dropdown mode (default) -->\n<div class=\"zen-groups-dropdown\" *ngIf=\"!inline\" [style.width]=\"width\">\n    <button class=\"zen-groups-toggle\"\n            (click)=\"toggleDropdown()\"\n            [ngClass]=\"{'active': isOpen}\">\n        <span class=\"zen-groups-toggle-label\">\n            <span *ngIf=\"!selectedLabel\" class=\"zen-groups-placeholder\">{{ placeholder | translate }}</span>\n            <span *ngIf=\"selectedLabel\" class=\"zen-groups-value\">{{ selectedLabel }}</span>\n        </span>\n        <i class=\"material-icons zen-groups-chevron\">expand_more</i>\n    </button>\n\n    <div class=\"zen-groups-panel\" *ngIf=\"isOpen\" [class.open-upward]=\"openUpward\">\n        <div class=\"zen-groups-search\" *ngIf=\"!hideSearch\">\n            <zen-search-box [(text)]=\"searchText\"\n                            (textChange)=\"onSearchChange()\"></zen-search-box>\n        </div>\n        <ng-container *ngTemplateOutlet=\"treeContent\"></ng-container>\n    </div>\n</div>\n\n<!-- Inline mode (used inside zen-filter) -->\n<div class=\"zen-groups-inline\" *ngIf=\"inline\">\n    <div class=\"zen-groups-search\" *ngIf=\"!hideSearch\">\n        <zen-search-box [(text)]=\"searchText\"\n                        (textChange)=\"onSearchChange()\"></zen-search-box>\n    </div>\n    <ng-container *ngTemplateOutlet=\"treeContent\"></ng-container>\n</div>\n\n<!-- Shared tree content -->\n<ng-template #treeContent>\n    <div class=\"zen-groups-tree\">\n        <div class=\"action-item-checkbox select-all\" *ngIf=\"!hideSelectAll\">\n            <zen-checkbox *ngIf=\"dataSource.length === displayDataSource.length\"\n                          [(checked)]=\"isSelectedAll\"\n                          [indeterminate]=\"hasActiveItems && !isSelectedAll\"\n                          [label]=\"'Select All' | translate\"\n                          (checkedChange)=\"onSelectAll()\">\n            </zen-checkbox>\n        </div>\n\n        <ng-container *ngFor=\"let dsItem of displayDataSource\">\n            <div *ngIf=\"isTreeItemVisible(dsItem)\"\n                 class=\"action-item-checkbox tree-item\"\n                 [style.padding-left.px]=\"24 + (dsItem.level || 0) * 24\">\n                <ng-container *ngIf=\"dsItem.level > 0\">\n                    <div *ngFor=\"let connector of getTreeConnectors(dsItem); let i = index\"\n                         class=\"tree-connector\"\n                         [ngClass]=\"'tree-connector-' + connector\"\n                         [style.left.px]=\"32 + i * 24\">\n                    </div>\n                </ng-container>\n                <div class=\"tree-item-row\">\n                    <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                  [indeterminate]=\"isTreeItemIndeterminate(dsItem)\"\n                                  [imageUrl]=\"dsItem.imageUrl\"\n                                  (checkedChange)=\"onCheckChanged(dsItem)\"\n                                  [label]=\"dsItem[displayProp]?.toString() | translate\"></zen-checkbox>\n                    <span *ngIf=\"hasChildren(dsItem)\"\n                          class=\"tree-item-badge\">{{ getChildCount(dsItem) }}</span>\n                </div>\n                <button *ngIf=\"hasChildren(dsItem)\"\n                        class=\"tree-item-toggle\"\n                        (click)=\"toggleTreeNode(dsItem)\">\n                    <i class=\"material-icons tree-toggle-icon\"\n                       [class.open]=\"dsItem.isOpen\">expand_more</i>\n                </button>\n            </div>\n        </ng-container>\n\n        <div class=\"zen-groups-no-results\" *ngIf=\"searchText && displayDataSource.length === 0\">\n            {{ 'No Results Found' | translate }}\n        </div>\n    </div>\n</ng-template>\n"]}
|
|
351
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zendu-groups.component.js","sourceRoot":"","sources":["../../../../../projects/ng-zenduit/src/lib/groups/zendu-groups.component.ts","../../../../../projects/ng-zenduit/src/lib/groups/zendu-groups.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { DataSource } from '../filter/filtersConfig';\n\n@Component({\n  selector: 'zen-groups',\n  templateUrl: './zendu-groups.component.html',\n  styleUrls: ['./zendu-groups.component.scss'],\n})\nexport class ZenduGroupsComponent implements OnChanges {\n  @Input() dataSource: DataSource[] = [];\n  @Input() filteredDataSource: DataSource[] = [];\n  @Input() hideSelectAll = false;\n  @Input() isSelectedAll = false;\n  @Input() inline = false;\n  @Input() width = '300px';\n  @Input() placeholder = 'Select group';\n  @Input() hideSearch = false;\n  @Input() idProp: string = 'id';\n  @Input() displayProp: string = 'name';\n\n  @Output() isSelectedAllChange = new EventEmitter<boolean>();\n  @Output() checkedChange = new EventEmitter<DataSource>();\n\n  public isOpen = false;\n  public openUpward = false;\n  public searchText = '';\n  private _searchFilteredDataSource: DataSource[] | null = null;\n\n  private _treeMap = new Map<string | number, DataSource>();\n  private _childCountCache = new Map<string | number, number>();\n\n  constructor(private _elementRef: ElementRef) {}\n\n  private getChildren(item: any): string[] | undefined {\n    return item.children || item.Children || item.Childrens;\n  }\n\n  public hasChildren(item: any): boolean {\n    const children = this.getChildren(item);\n    return !!children && children.length > 0;\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes['dataSource']) {\n      this.buildTreeLevels();\n    }\n    if ((changes['filteredDataSource'] || changes['dataSource']) &&\n      this._treeMap.size > 0 && this.filteredDataSource?.length) {\n      this.filteredDataSource = this.sortTreeOrder(this.filteredDataSource);\n    }\n  }\n\n  @HostListener('window:mousedown', ['$event'])\n  onOutsideClick(event: MouseEvent) {\n    if (this.inline || !this.isOpen) return;\n    const target = event.target as HTMLElement;\n    if (!this._elementRef.nativeElement.contains(target)) {\n      this.isOpen = false;\n    }\n  }\n\n  public toggleDropdown(): void {\n    this.isOpen = !this.isOpen;\n    if (this.isOpen) {\n      this.openUpward = this.shouldOpenUpward(300);\n    } else {\n      this.searchText = '';\n      this._searchFilteredDataSource = null;\n    }\n  }\n\n  private shouldOpenUpward(dropdownHeight: number): boolean {\n    const rect = this._elementRef.nativeElement.getBoundingClientRect();\n    return (window.innerHeight - rect.bottom) < dropdownHeight;\n  }\n\n  public get displayDataSource(): DataSource[] {\n    if (this._searchFilteredDataSource !== null) {\n      return this._searchFilteredDataSource;\n    }\n    return this.filteredDataSource;\n  }\n\n  public onSearchChange(): void {\n    if (!this.searchText) {\n      this._searchFilteredDataSource = null;\n      return;\n    }\n\n    const lowerSearch = this.searchText.toLowerCase();\n    const matchingIds = new Set<string | number>();\n\n    for (const el of this.dataSource) {\n      const name = typeof el[this.displayProp] === 'number' ? el[this.displayProp].toString() : el[this.displayProp];\n      if (name.toLowerCase().includes(lowerSearch)) {\n        matchingIds.add(el[this.idProp]);\n        // Include all ancestors\n        let current = el;\n        while (current.parentId != null) {\n          matchingIds.add(current.parentId);\n          const parent = this._treeMap.get(current.parentId);\n          if (!parent) break;\n          current = parent;\n        }\n      }\n    }\n\n    let filtered = this.dataSource.filter(el => matchingIds.has(el[this.idProp]));\n\n    // Auto-expand parents when searching\n    for (const el of filtered) {\n      if (this.hasChildren(el)) {\n        el.isOpen = true;\n      }\n    }\n\n    this._searchFilteredDataSource = this.sortTreeOrder(filtered);\n  }\n\n  public get selectedCount(): number {\n    return this.dataSource?.filter(d => d.checked).length || 0;\n  }\n\n  public get selectedLabel(): string {\n    const count = this.selectedCount;\n    if (count === 0) return '';\n    if (count === 1) {\n      const item = this.dataSource.find(d => d.checked);\n      return item ? item[this.displayProp]?.toString() : '';\n    }\n    return `${count} selected`;\n  }\n\n  public get hasActiveItems(): boolean {\n    return this.dataSource?.some(d => d.checked) || false;\n  }\n\n  public onSelectAll(): void {\n    this.dataSource.forEach(d => (d.checked = this.isSelectedAll));\n    this.isSelectedAllChange.emit(this.isSelectedAll);\n  }\n\n  public onCheckChanged(dsItem: DataSource): void {\n    this.cascadeToChildren(dsItem);\n    this.updateParentCheckedState(dsItem);\n    this.checkedChange.emit(dsItem);\n  }\n\n  private buildTreeLevels(): void {\n    if (!this.dataSource?.length) return;\n    const hasChildren = this.dataSource.some(d => this.hasChildren(d));\n    if (!hasChildren) return;\n\n    const map = new Map<string | number, DataSource>();\n    for (const item of this.dataSource) {\n      map.set(item[this.idProp], item);\n    }\n    this._treeMap = map;\n\n    for (const item of this.dataSource) {\n      const children = this.getChildren(item);\n      if (children?.length) {\n        for (const childId of children) {\n          const child = map.get(childId);\n          if (child && child.parentId == null) {\n            child.parentId = item[this.idProp];\n          }\n        }\n      }\n    }\n\n    for (const item of this.dataSource) {\n      let level = 0;\n      let current = item;\n      while (current.parentId != null) {\n        level++;\n        const parent = map.get(current.parentId);\n        if (!parent) break;\n        current = parent;\n      }\n      item.level = level;\n    }\n\n    this._childCountCache.clear();\n    const countChildren = (item: DataSource): number => {\n      const children = this.getChildren(item);\n      if (!children?.length) return 0;\n      let count = 0;\n      for (const childId of children) {\n        const child = map.get(childId);\n        if (child) {\n          const childLeaves = countChildren(child);\n          count += childLeaves > 0 ? childLeaves : 1;\n        }\n      }\n      return count;\n    };\n    for (const item of this.dataSource) {\n      if (this.hasChildren(item)) {\n        this._childCountCache.set(item[this.idProp], countChildren(item));\n      }\n    }\n  }\n\n  public sortTreeOrder(items: DataSource[]): DataSource[] {\n    const itemSet = new Set(items.map(i => i[this.idProp]));\n    const visited = new Set<string | number>();\n    const ordered: DataSource[] = [];\n    const visit = (item: DataSource) => {\n      if (visited.has(item[this.idProp])) return;\n      if (!itemSet.has(item[this.idProp])) return;\n      visited.add(item[this.idProp]);\n      ordered.push(item);\n      const children = this.getChildren(item);\n      if (children?.length) {\n        for (const childId of children) {\n          const child = this._treeMap.get(childId);\n          if (child) {\n            visit(child);\n          }\n        }\n      }\n    };\n    for (const item of items) {\n      if (item.parentId == null) {\n        visit(item);\n      }\n    }\n    for (const item of items) {\n      if (!visited.has(item[this.idProp])) {\n        ordered.push(item);\n      }\n    }\n    return ordered;\n  }\n\n  public isTreeItemVisible(dsItem: DataSource): boolean {\n    if (dsItem.parentId == null) {\n      return true;\n    }\n    const parent = this._treeMap.get(dsItem.parentId);\n    if (!parent) {\n      return true;\n    }\n    return parent.isOpen && this.isTreeItemVisible(parent);\n  }\n\n  public toggleTreeNode(dsItem: DataSource): void {\n    dsItem.isOpen = !dsItem.isOpen;\n  }\n\n  public getChildCount(dsItem: DataSource): number {\n    return this._childCountCache.get(dsItem[this.idProp]) || 0;\n  }\n\n  public isTreeItemIndeterminate(dsItem: DataSource): boolean {\n    if (!this.hasChildren(dsItem)) return false;\n    const allDescendants = this.getAllDescendants(dsItem);\n    if (!allDescendants.length) return false;\n    const checkedCount = allDescendants.filter(d => d.checked).length;\n    return checkedCount > 0 && checkedCount < allDescendants.length;\n  }\n\n  private getAllDescendants(dsItem: DataSource): DataSource[] {\n    const result: DataSource[] = [];\n    const children = this.getChildren(dsItem);\n    if (!children?.length) return result;\n    for (const childId of children) {\n      const child = this._treeMap.get(childId);\n      if (child) {\n        result.push(child);\n        result.push(...this.getAllDescendants(child));\n      }\n    }\n    return result;\n  }\n\n  private updateParentCheckedState(dsItem: DataSource): void {\n    if (dsItem.parentId == null) return;\n    const parent = this._treeMap.get(dsItem.parentId);\n    if (!parent || !this.hasChildren(parent)) return;\n    const allDescendants = this.getAllDescendants(parent);\n    const allChecked = allDescendants.every(d => d.checked);\n    parent.checked = allChecked;\n    this.updateParentCheckedState(parent);\n  }\n\n  private cascadeToChildren(item: DataSource): void {\n    const children = this.getChildren(item);\n    if (!children?.length) return;\n    this.dataSource.forEach(data => {\n      if (item[this.idProp] == data[this.idProp]) {\n        return;\n      }\n      if (children.includes(<string>data[this.idProp])) {\n        data.checked = item.checked;\n        if (this.hasChildren(data)) {\n          this.cascadeToChildren(data);\n        }\n      }\n    });\n  }\n\n  public getTreeConnectors(dsItem: DataSource): string[] {\n    if (!dsItem.level) return [];\n\n    const isLastFlags: boolean[] = [];\n    let current: DataSource | undefined = dsItem;\n\n    for (let l = dsItem.level; l >= 1; l--) {\n      const parent = this._treeMap.get(current!.parentId!);\n      const parentChildren = parent ? this.getChildren(parent) : undefined;\n      if (!parentChildren?.length) {\n        isLastFlags.push(true);\n      } else {\n        const lastChildId = parentChildren[parentChildren.length - 1];\n        isLastFlags.push(current![this.idProp] === lastChildId);\n      }\n      current = parent;\n    }\n\n    isLastFlags.reverse();\n\n    const result: string[] = [];\n    for (let i = 0; i < isLastFlags.length; i++) {\n      const isItemLevel = (i === isLastFlags.length - 1);\n      const isLast = isLastFlags[i];\n\n      if (isItemLevel) {\n        result.push(isLast ? 'elbow' : 'branch');\n      } else {\n        result.push(isLast ? 'none' : 'through');\n      }\n    }\n    return result;\n  }\n\n  public getTreeMap(): Map<string | number, DataSource> {\n    return this._treeMap;\n  }\n}\n","<!-- Dropdown mode (default) -->\n<div class=\"zen-groups-dropdown\" *ngIf=\"!inline\" [style.width]=\"width\">\n    <button class=\"zen-groups-toggle\"\n            (click)=\"toggleDropdown()\"\n            [ngClass]=\"{'active': isOpen}\">\n        <span class=\"zen-groups-toggle-label\">\n            <span *ngIf=\"!selectedLabel\" class=\"zen-groups-placeholder\">{{ placeholder | translate }}</span>\n            <span *ngIf=\"selectedLabel\" class=\"zen-groups-value\">{{ selectedLabel }}</span>\n        </span>\n        <i class=\"material-icons zen-groups-chevron\">expand_more</i>\n    </button>\n\n    <div class=\"zen-groups-panel\" *ngIf=\"isOpen\" [class.open-upward]=\"openUpward\">\n        <div class=\"zen-groups-search\" *ngIf=\"!hideSearch\">\n            <zen-search-box [(text)]=\"searchText\"\n                            (textChange)=\"onSearchChange()\"></zen-search-box>\n        </div>\n        <ng-container *ngTemplateOutlet=\"treeContent\"></ng-container>\n    </div>\n</div>\n\n<!-- Inline mode (used inside zen-filter) -->\n<div class=\"zen-groups-inline\" *ngIf=\"inline\">\n    <div class=\"zen-groups-search\" *ngIf=\"!hideSearch\">\n        <zen-search-box [(text)]=\"searchText\"\n                        (textChange)=\"onSearchChange()\"></zen-search-box>\n    </div>\n    <ng-container *ngTemplateOutlet=\"treeContent\"></ng-container>\n</div>\n\n<!-- Shared tree content -->\n<ng-template #treeContent>\n    <div class=\"zen-groups-tree\">\n        <div class=\"action-item-checkbox select-all\" *ngIf=\"!hideSelectAll\">\n            <zen-checkbox *ngIf=\"dataSource.length === displayDataSource.length\"\n                          [(checked)]=\"isSelectedAll\"\n                          [indeterminate]=\"hasActiveItems && !isSelectedAll\"\n                          [label]=\"'Select All' | translate\"\n                          (checkedChange)=\"onSelectAll()\">\n            </zen-checkbox>\n        </div>\n\n        <ng-container *ngFor=\"let dsItem of displayDataSource\">\n            <div *ngIf=\"isTreeItemVisible(dsItem)\"\n                 class=\"action-item-checkbox tree-item\"\n                 [style.padding-left.px]=\"24 + (dsItem.level || 0) * 24\">\n                <ng-container *ngIf=\"dsItem.level > 0\">\n                    <div *ngFor=\"let connector of getTreeConnectors(dsItem); let i = index\"\n                         class=\"tree-connector\"\n                         [ngClass]=\"'tree-connector-' + connector\"\n                         [style.left.px]=\"32 + i * 24\">\n                    </div>\n                </ng-container>\n                <div class=\"tree-item-row\">\n                    <zen-checkbox [(checked)]=\"dsItem.checked\"\n                                  [indeterminate]=\"isTreeItemIndeterminate(dsItem)\"\n                                  [imageUrl]=\"dsItem.imageUrl\"\n                                  (checkedChange)=\"onCheckChanged(dsItem)\"\n                                  [label]=\"dsItem[displayProp]?.toString() | translate\"></zen-checkbox>\n                    <span *ngIf=\"hasChildren(dsItem)\"\n                          class=\"tree-item-badge\">{{ getChildCount(dsItem) }}</span>\n                </div>\n                <button *ngIf=\"hasChildren(dsItem)\"\n                        class=\"tree-item-toggle\"\n                        (click)=\"toggleTreeNode(dsItem)\">\n                    <i class=\"material-icons tree-toggle-icon\"\n                       [class.open]=\"dsItem.isOpen\">expand_more</i>\n                </button>\n            </div>\n        </ng-container>\n\n        <div class=\"zen-groups-no-results\" *ngIf=\"searchText && displayDataSource.length === 0\">\n            {{ 'No Results Found' | translate }}\n        </div>\n    </div>\n</ng-template>\n"]}
|
|
@@ -60,7 +60,7 @@ export class ZenduPaginationBarComponent {
|
|
|
60
60
|
}
|
|
61
61
|
}
|
|
62
62
|
ZenduPaginationBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
63
|
-
ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "label", "supportingText", "hintText", "placeholder", "leadingType", "leadingIcon", "leadingAvatar", "leadingDotColor", "displayProp", "idProp", "hasSearch", "isMultiselect", "multiselect", "hideSelectAll", "hideTreeSearch", "disabled", "error", "errorMessage", "destructive", "size", "returnOption", "isTruncate", "enableAddNewOption", "showDefaultAddOption", "newOptionText", "enableRemoveOption", "removeOptionText", "isLazyLoading", "lazyLoader", "preferredOpenDirection"], outputs: ["selectModelChange", "addNewOption", "removeOption", "closed"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
63
|
+
ZenduPaginationBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ZenduPaginationBarComponent, selector: "zen-pagination-bar", inputs: { page: "page", perPage: "perPage", count: "count" }, outputs: { pageChange: "pageChange", perPageChange: "perPageChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"], dependencies: [{ kind: "component", type: i1.ZenduSelectComponent, selector: "zen-select", inputs: ["selectModel", "options", "label", "supportingText", "hintText", "placeholder", "leadingType", "leadingIcon", "leadingAvatar", "leadingDotColor", "displayProp", "idProp", "hasSearch", "isMultiselect", "multiselect", "hideSelectAll", "hideTreeSearch", "required", "disabled", "error", "errorMessage", "destructive", "size", "returnOption", "isTruncate", "enableAddNewOption", "showDefaultAddOption", "newOptionText", "enableRemoveOption", "removeOptionText", "isLazyLoading", "lazyLoader", "preferredOpenDirection"], outputs: ["selectModelChange", "addNewOption", "removeOption", "closed"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
64
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ZenduPaginationBarComponent, decorators: [{
|
|
65
65
|
type: Component,
|
|
66
66
|
args: [{ selector: 'zen-pagination-bar', template: "<div class=\"pagination-component\">\n <div class=\"select-dropdown\">\n <label>{{\"Rows per page\" | translate}}:</label>\n <zen-select [(selectModel)]=\"perPage\"\n [options]=\"availablePagesSize\"\n [displayProp]=\"'text'\"\n [idProp]=\"'id'\"\n (selectModelChange)=\"updatePageSize()\"></zen-select>\n </div>\n <div class=\"pages\">\n <button class=\"pagination-button\"\n [disabled]=\"page - 1 <= 0\"\n (click)=\"prevPage()\">\n <i class=\"material-icons\">keyboard_arrow_left</i>\n </button>\n <label>{{((page - 1) * perPage) + 1 }} - {{endRowSize()}} of {{count}}</label>\n <button class=\"pagination-button\"\n [disabled]=\"page + 1 > totalPages\"\n (click)=\"nextPage()\">\n <i class=\"material-icons\">keyboard_arrow_right</i>\n </button>\n </div>\n</div>\n", styles: [".pagination-component{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.pagination-component .select-dropdown{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .select-dropdown label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:120%;color:#4f4f4f}.pagination-component .pages{display:flex;flex-direction:row;align-items:center;gap:8px}.pagination-component .pages label{margin:0;font-style:normal;font-weight:400;font-size:12px;line-height:16px;color:#828282}.pagination-component .pages .pagination-button{display:flex;flex-direction:row;align-items:center;height:16px;padding:0;box-sizing:border-box;white-space:nowrap;border:none;border-radius:50%;transition:.1s;cursor:pointer;color:#828282;background:#FFFFFF}.pagination-component .pages .pagination-button:hover{color:#4f4f4f;background:#F2F2F2}.pagination-component .pages .pagination-button:focus{outline:none;color:#2188d9;background:#F4F9FD}.pagination-component .pages .pagination-button:disabled{color:#e0e0e0;background:#FFFFFF;cursor:not-allowed}.pagination-component .pages .pagination-button .material-icons{font-size:16px;height:16px;width:16px}\n"] }]
|