@leanix/components 0.4.173 → 0.4.174

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/index.d.ts CHANGED
@@ -116,4 +116,5 @@ export * from './lib/popover-ui/directives/popover-hover.directive';
116
116
  export * from './lib/tab-ui/components/tab-group/tab-group.component';
117
117
  export * from './lib/tab-ui/components/tab/tab.component';
118
118
  export * from './lib/tab-ui/tab-ui.module';
119
- export * from './lib/configuration-ui/components/visibility-panel.component';
119
+ export * from './lib/configuration-ui/components/visibility-panel/visibility-panel.component';
120
+ export * from './lib/configuration-ui/components/visibility-panel/visibility-panel.interface';
@@ -0,0 +1,16 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { DragAndDropListActionEvent } from '../../../forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component';
3
+ import { DragAndDropListMoveIndexEvent } from '../../../forms-ui/components/drag-and-drop-list/drag-and-drop-list.component';
4
+ import { VisibilityPanelItem, VisibilityPanelItems } from './visibility-panel.interface';
5
+ import * as i0 from "@angular/core";
6
+ export declare class VisibilityPanelComponent {
7
+ readonly NAME = "VisibilityPanelComponent";
8
+ items: VisibilityPanelItems;
9
+ itemsChange: EventEmitter<VisibilityPanelItems>;
10
+ searchTerm: string;
11
+ makeVisible(hidden: VisibilityPanelItem): void;
12
+ moveToIndex(event: DragAndDropListMoveIndexEvent): void;
13
+ action(event: DragAndDropListActionEvent): void;
14
+ static ɵfac: i0.ɵɵFactoryDeclaration<VisibilityPanelComponent, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<VisibilityPanelComponent, "lx-visibility-panel", never, { "items": { "alias": "items"; "required": false; }; }, { "itemsChange": "itemsChange"; }, never, never, true, never>;
16
+ }
@@ -0,0 +1,8 @@
1
+ export interface VisibilityPanelItems {
2
+ hiddenItems: VisibilityPanelItem[];
3
+ visibleItems: VisibilityPanelItem[];
4
+ }
5
+ export interface VisibilityPanelItem {
6
+ label: string;
7
+ id: string;
8
+ }
@@ -0,0 +1,8 @@
1
+ import { PipeTransform } from '@angular/core';
2
+ import { VisibilityPanelItem } from './visibility-panel.interface';
3
+ import * as i0 from "@angular/core";
4
+ export declare class HiddenItems implements PipeTransform {
5
+ transform(value: VisibilityPanelItem[], searchTerm: string): VisibilityPanelItem[];
6
+ static ɵfac: i0.ɵɵFactoryDeclaration<HiddenItems, never>;
7
+ static ɵpipe: i0.ɵɵPipeDeclaration<HiddenItems, "hiddenItems", true>;
8
+ }
@@ -0,0 +1,10 @@
1
+ import { PipeTransform } from '@angular/core';
2
+ import { VisibilityPanelItems } from './visibility-panel.interface';
3
+ import * as i0 from "@angular/core";
4
+ export declare class VisibleItems implements PipeTransform {
5
+ transform(value: VisibilityPanelItems, searchTerm: string): string[];
6
+ private filterItems;
7
+ private mapLabelsToString;
8
+ static ɵfac: i0.ɵɵFactoryDeclaration<VisibleItems, never>;
9
+ static ɵpipe: i0.ɵɵPipeDeclaration<VisibleItems, "visibleItems", true>;
10
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@leanix/components",
3
- "version": "0.4.173",
3
+ "version": "0.4.174",
4
4
  "license": "Apache-2.0",
5
5
  "author": "LeanIX GmbH",
6
6
  "repository": {
@@ -1,72 +0,0 @@
1
- import { CdkDrag, CdkDropList } from '@angular/cdk/drag-drop';
2
- import { AsyncPipe } from '@angular/common';
3
- import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/core';
4
- import { TranslateModule } from '@ngx-translate/core';
5
- import { map, startWith } from 'rxjs';
6
- import { ButtonComponent } from '../../core-ui/components/button/button.component';
7
- import { KeyboardSortableItemDirective } from '../../forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive';
8
- import { KeyboardSortableListDirective } from '../../forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive';
9
- import * as i0 from "@angular/core";
10
- import * as i1 from "@ngx-translate/core";
11
- export class VisibilityPanelComponent {
12
- constructor() {
13
- this.NAME = 'VisibilityPanelComponent';
14
- this.items = { hiddenItems: [], visibleItems: [] };
15
- this.itemsChange = new EventEmitter();
16
- this.isSortingByKeyboard = false;
17
- this.keyboardItemBeingSorted = undefined;
18
- }
19
- ngAfterViewInit() {
20
- this.keyboardSortableItems$ = this._keyboardSortableItems.changes.pipe(startWith(this._keyboardSortableItems), map((items) => items.toArray()));
21
- this.allItemsData$ = this._keyboardSortableItems.changes.pipe(startWith(this._keyboardSortableItems), map((items) => items.toArray().map((item) => item.itemData)));
22
- }
23
- drop(event) {
24
- const draggedVisibleItem = this.items.visibleItems[event.previousIndex];
25
- if (draggedVisibleItem) {
26
- this.shiftArrayElements(this.items.visibleItems, event.previousIndex, event.currentIndex);
27
- this.itemsChange.emit(this.items);
28
- }
29
- }
30
- shiftArrayElements(array, previousPosition, newPosition) {
31
- if (previousPosition < 0 || newPosition < 0 || previousPosition >= array.length || newPosition >= array.length) {
32
- return array;
33
- }
34
- const [item] = array.splice(previousPosition, 1);
35
- if (item) {
36
- array.splice(newPosition, 0, item);
37
- }
38
- return array;
39
- }
40
- makeVisible(hidden) {
41
- this.items.visibleItems.push(hidden);
42
- this.items.hiddenItems = this.items.hiddenItems.filter((item) => item.id != hidden.id);
43
- this.itemsChange.emit(this.items);
44
- }
45
- makeHidden(visible) {
46
- this.items.hiddenItems = this.items.hiddenItems
47
- .concat(visible)
48
- .sort((a, b) => a.label.toLowerCase().localeCompare(b.label.toLowerCase()));
49
- this.items.visibleItems = this.items.visibleItems.filter((item) => item.id != visible.id);
50
- this.itemsChange.emit(this.items);
51
- }
52
- handleKeyboardSort(previousIndex, currentIndex) {
53
- if (this.isSortingByKeyboard) {
54
- this.shiftArrayElements(this.items.visibleItems, previousIndex, currentIndex);
55
- this.itemsChange.emit(this.items);
56
- }
57
- }
58
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: VisibilityPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
59
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.0", type: VisibilityPanelComponent, isStandalone: true, selector: "lx-visibility-panel", inputs: { items: "items" }, outputs: { itemsChange: "itemsChange" }, viewQueries: [{ propertyName: "_keyboardSortableItems", predicate: KeyboardSortableItemDirective, descendants: true }], ngImport: i0, template: "<div>\n <div class=\"manage-filters-title\">\n <h4>{{ NAME + '.manageFiltersHeader' | translate }}</h4>\n </div>\n <div class=\"visible-filters-title\">\n <h4>{{ NAME + '.visibleHeader' | translate }}</h4>\n </div>\n <div\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n lxKeyboardSortableList\n [keyboardSortableItems]=\"keyboardSortableItems$ | async\"\n class=\"tw-flex tw-flex-col\"\n >\n @for (visible of items.visibleItems; track visible.label) {\n <button\n class=\"item-button-visible\"\n lx-button\n size=\"large\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n [tabIndex]=\"0\"\n [lxKeyboardSortableItem]=\"allItemsData$ | async\"\n [lxKeyboardItemData]=\"visible.label\"\n [(isSortingByKeyboard)]=\"isSortingByKeyboard\"\n [(lxKeyboardItemBeingSorted)]=\"keyboardItemBeingSorted\"\n (sortItemsWithKeyboard)=\"handleKeyboardSort($event.previousIndex, $event.currentIndex)\"\n >\n <i class=\"far fa-bars drag-handle\" aria-hidden=\"true\"></i>\n <span class=\"item-label\">\n {{ visible.label }}\n </span>\n <button\n class=\"add-to-hidden-button\"\n lx-button\n (click)=\"makeHidden(visible)\"\n [title]=\"NAME + '.hide' | translate\"\n [attr.aria-label]=\"NAME + '.hide' | translate\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n >\n <i aria-hidden=\"true\" class=\"fa-times far\"></i>\n </button>\n </button>\n } @empty {\n {{ NAME + '.noFilterOptions' | translate }}\n }\n </div>\n\n <div class=\"hidden-filters-title\">\n <h4>{{ NAME + '.hiddenHeader' | translate }}</h4>\n </div>\n <div class=\"tw-flex tw-flex-col\">\n @for (hidden of items.hiddenItems; track hidden.id) {\n <button class=\"item-button-hidden\" lx-button [title]=\"'show'\" size=\"large\" color=\"light\" (click)=\"makeVisible(hidden)\">\n <span class=\"item-label\">\n {{ hidden.label }}\n </span>\n <button\n class=\"add-to-visible-button\"\n lx-button\n (click)=\"makeVisible(hidden)\"\n [title]=\"NAME + '.show' | translate\"\n [attr.aria-label]=\"NAME + '.show' | translate\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n >\n <i aria-hidden=\"true\" class=\"far fa-plus\"></i>\n </button>\n </button>\n } @empty {\n {{ NAME + '.noFilterOptions' | translate }}\n }\n </div>\n</div>\n", styles: [".item-button-visible{margin-bottom:8px;display:flex;align-items:center;padding:8px}.item-button-hidden{margin-bottom:8px;display:flex;align-items:center;padding:8px;border:1px solid #c2c9d6!important}.cdk-drag-placeholder{opacity:.3}.drag-handle{margin-right:4px;color:#61779d}.cdk-drop-list-dragging .cdk-drag{transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drag-animating{transition:transform .3s cubic-bezier(0,0,.2,1)}.add-to-visible-button{margin-left:auto}.fa-plus{color:#61779d}.add-to-hidden-button{margin-left:auto}.fa-times{color:#61779d}.visible-filters-title,.hidden-filters-title{color:#526179}.visible-filters-title{margin-top:24px}.hidden-filters-title{margin-top:16px}.item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], dependencies: [{ kind: "component", type: ButtonComponent, selector: "button[lx-button]", inputs: ["size", "color", "mode", "pressed", "selected", "square", "circle", "disabled", "showSpinner"] }, { kind: "directive", type: CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: KeyboardSortableListDirective, selector: "[lxKeyboardSortableList]", inputs: ["keyboardSortableItems"] }, { kind: "directive", type: KeyboardSortableItemDirective, selector: "[lxKeyboardSortableItem]", inputs: ["lxKeyboardSortableItem", "lxKeyboardItemData", "isSortingByKeyboard", "lxKeyboardItemBeingSorted"], outputs: ["isSortingByKeyboardChange", "lxKeyboardItemBeingSortedChange", "sortItemsWithKeyboard", "focusWithKeyboard"] }, { kind: "pipe", type: AsyncPipe, name: "async" }] }); }
60
- }
61
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: VisibilityPanelComponent, decorators: [{
62
- type: Component,
63
- args: [{ selector: 'lx-visibility-panel', standalone: true, imports: [ButtonComponent, CdkDropList, CdkDrag, TranslateModule, KeyboardSortableListDirective, KeyboardSortableItemDirective, AsyncPipe], template: "<div>\n <div class=\"manage-filters-title\">\n <h4>{{ NAME + '.manageFiltersHeader' | translate }}</h4>\n </div>\n <div class=\"visible-filters-title\">\n <h4>{{ NAME + '.visibleHeader' | translate }}</h4>\n </div>\n <div\n cdkDropList\n (cdkDropListDropped)=\"drop($event)\"\n lxKeyboardSortableList\n [keyboardSortableItems]=\"keyboardSortableItems$ | async\"\n class=\"tw-flex tw-flex-col\"\n >\n @for (visible of items.visibleItems; track visible.label) {\n <button\n class=\"item-button-visible\"\n lx-button\n size=\"large\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n [tabIndex]=\"0\"\n [lxKeyboardSortableItem]=\"allItemsData$ | async\"\n [lxKeyboardItemData]=\"visible.label\"\n [(isSortingByKeyboard)]=\"isSortingByKeyboard\"\n [(lxKeyboardItemBeingSorted)]=\"keyboardItemBeingSorted\"\n (sortItemsWithKeyboard)=\"handleKeyboardSort($event.previousIndex, $event.currentIndex)\"\n >\n <i class=\"far fa-bars drag-handle\" aria-hidden=\"true\"></i>\n <span class=\"item-label\">\n {{ visible.label }}\n </span>\n <button\n class=\"add-to-hidden-button\"\n lx-button\n (click)=\"makeHidden(visible)\"\n [title]=\"NAME + '.hide' | translate\"\n [attr.aria-label]=\"NAME + '.hide' | translate\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n >\n <i aria-hidden=\"true\" class=\"fa-times far\"></i>\n </button>\n </button>\n } @empty {\n {{ NAME + '.noFilterOptions' | translate }}\n }\n </div>\n\n <div class=\"hidden-filters-title\">\n <h4>{{ NAME + '.hiddenHeader' | translate }}</h4>\n </div>\n <div class=\"tw-flex tw-flex-col\">\n @for (hidden of items.hiddenItems; track hidden.id) {\n <button class=\"item-button-hidden\" lx-button [title]=\"'show'\" size=\"large\" color=\"light\" (click)=\"makeVisible(hidden)\">\n <span class=\"item-label\">\n {{ hidden.label }}\n </span>\n <button\n class=\"add-to-visible-button\"\n lx-button\n (click)=\"makeVisible(hidden)\"\n [title]=\"NAME + '.show' | translate\"\n [attr.aria-label]=\"NAME + '.show' | translate\"\n [square]=\"true\"\n mode=\"ghost\"\n size=\"small\"\n >\n <i aria-hidden=\"true\" class=\"far fa-plus\"></i>\n </button>\n </button>\n } @empty {\n {{ NAME + '.noFilterOptions' | translate }}\n }\n </div>\n</div>\n", styles: [".item-button-visible{margin-bottom:8px;display:flex;align-items:center;padding:8px}.item-button-hidden{margin-bottom:8px;display:flex;align-items:center;padding:8px;border:1px solid #c2c9d6!important}.cdk-drag-placeholder{opacity:.3}.drag-handle{margin-right:4px;color:#61779d}.cdk-drop-list-dragging .cdk-drag{transition:transform .25s cubic-bezier(0,0,.2,1)}.cdk-drag-animating{transition:transform .3s cubic-bezier(0,0,.2,1)}.add-to-visible-button{margin-left:auto}.fa-plus{color:#61779d}.add-to-hidden-button{margin-left:auto}.fa-times{color:#61779d}.visible-filters-title,.hidden-filters-title{color:#526179}.visible-filters-title{margin-top:24px}.hidden-filters-title{margin-top:16px}.item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"] }]
64
- }], propDecorators: { items: [{
65
- type: Input
66
- }], itemsChange: [{
67
- type: Output
68
- }], _keyboardSortableItems: [{
69
- type: ViewChildren,
70
- args: [KeyboardSortableItemDirective]
71
- }] } });
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"visibility-panel.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/configuration-ui/components/visibility-panel.component.ts","../../../../../../../libs/components/src/lib/configuration-ui/components/visibility-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop, CdkDropList } from '@angular/cdk/drag-drop';\nimport { AsyncPipe } from '@angular/common';\nimport { AfterViewInit, Component, EventEmitter, Input, Output, QueryList, ViewChildren } from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { Observable, map, startWith } from 'rxjs';\nimport { ButtonComponent } from '../../core-ui/components/button/button.component';\nimport { KeyboardSortableItemDirective } from '../../forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive';\nimport { KeyboardSortableListDirective } from '../../forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive';\n\nexport interface VisibilityPanelItems {\n  hiddenItems: visibilityPanelItem[];\n  visibleItems: visibilityPanelItem[];\n}\n\nexport interface visibilityPanelItem {\n  label: string;\n  id: string;\n}\n\n@Component({\n  selector: 'lx-visibility-panel',\n  templateUrl: './visibility-panel.component.html',\n  styleUrls: ['./visibility-panel.component.scss'],\n  standalone: true,\n  imports: [ButtonComponent, CdkDropList, CdkDrag, TranslateModule, KeyboardSortableListDirective, KeyboardSortableItemDirective, AsyncPipe]\n})\nexport class VisibilityPanelComponent implements AfterViewInit {\n  readonly NAME = 'VisibilityPanelComponent';\n\n  @Input() items: VisibilityPanelItems = { hiddenItems: [], visibleItems: [] };\n  @Output() itemsChange = new EventEmitter<VisibilityPanelItems>();\n\n  @ViewChildren(KeyboardSortableItemDirective)\n  private _keyboardSortableItems!: QueryList<KeyboardSortableItemDirective>;\n  keyboardSortableItems$!: Observable<KeyboardSortableItemDirective[]>;\n\n  isSortingByKeyboard: boolean = false;\n  keyboardItemBeingSorted: string | undefined = undefined;\n  allItemsData$!: Observable<string[]>;\n\n  ngAfterViewInit(): void {\n    this.keyboardSortableItems$ = this._keyboardSortableItems.changes.pipe(\n      startWith(this._keyboardSortableItems),\n      map((items: QueryList<KeyboardSortableItemDirective>) => items.toArray())\n    );\n\n    this.allItemsData$ = this._keyboardSortableItems.changes.pipe(\n      startWith(this._keyboardSortableItems),\n      map((items: QueryList<KeyboardSortableItemDirective>) => items.toArray().map((item) => item.itemData))\n    );\n  }\n\n  drop(event: CdkDragDrop<visibilityPanelItem[]>) {\n    const draggedVisibleItem = this.items.visibleItems[event.previousIndex];\n\n    if (draggedVisibleItem) {\n      this.shiftArrayElements(this.items.visibleItems, event.previousIndex, event.currentIndex);\n      this.itemsChange.emit(this.items);\n    }\n  }\n\n  shiftArrayElements(array: visibilityPanelItem[], previousPosition: number, newPosition: number) {\n    if (previousPosition < 0 || newPosition < 0 || previousPosition >= array.length || newPosition >= array.length) {\n      return array;\n    }\n    const [item] = array.splice(previousPosition, 1);\n    if (item) {\n      array.splice(newPosition, 0, item);\n    }\n    return array;\n  }\n\n  makeVisible(hidden: visibilityPanelItem) {\n    this.items.visibleItems.push(hidden);\n    this.items.hiddenItems = this.items.hiddenItems.filter((item) => item.id != hidden.id);\n    this.itemsChange.emit(this.items);\n  }\n\n  makeHidden(visible: visibilityPanelItem) {\n    this.items.hiddenItems = this.items.hiddenItems\n      .concat(visible)\n      .sort((a, b) => a.label.toLowerCase().localeCompare(b.label.toLowerCase()));\n    this.items.visibleItems = this.items.visibleItems.filter((item) => item.id != visible.id);\n    this.itemsChange.emit(this.items);\n  }\n\n  handleKeyboardSort(previousIndex: number, currentIndex: number) {\n    if (this.isSortingByKeyboard) {\n      this.shiftArrayElements(this.items.visibleItems, previousIndex, currentIndex);\n      this.itemsChange.emit(this.items);\n    }\n  }\n}\n","<div>\n  <div class=\"manage-filters-title\">\n    <h4>{{ NAME + '.manageFiltersHeader' | translate }}</h4>\n  </div>\n  <div class=\"visible-filters-title\">\n    <h4>{{ NAME + '.visibleHeader' | translate }}</h4>\n  </div>\n  <div\n    cdkDropList\n    (cdkDropListDropped)=\"drop($event)\"\n    lxKeyboardSortableList\n    [keyboardSortableItems]=\"keyboardSortableItems$ | async\"\n    class=\"tw-flex tw-flex-col\"\n  >\n    @for (visible of items.visibleItems; track visible.label) {\n      <button\n        class=\"item-button-visible\"\n        lx-button\n        size=\"large\"\n        cdkDrag\n        cdkDragLockAxis=\"y\"\n        [tabIndex]=\"0\"\n        [lxKeyboardSortableItem]=\"allItemsData$ | async\"\n        [lxKeyboardItemData]=\"visible.label\"\n        [(isSortingByKeyboard)]=\"isSortingByKeyboard\"\n        [(lxKeyboardItemBeingSorted)]=\"keyboardItemBeingSorted\"\n        (sortItemsWithKeyboard)=\"handleKeyboardSort($event.previousIndex, $event.currentIndex)\"\n      >\n        <i class=\"far fa-bars drag-handle\" aria-hidden=\"true\"></i>\n        <span class=\"item-label\">\n          {{ visible.label }}\n        </span>\n        <button\n          class=\"add-to-hidden-button\"\n          lx-button\n          (click)=\"makeHidden(visible)\"\n          [title]=\"NAME + '.hide' | translate\"\n          [attr.aria-label]=\"NAME + '.hide' | translate\"\n          [square]=\"true\"\n          mode=\"ghost\"\n          size=\"small\"\n        >\n          <i aria-hidden=\"true\" class=\"fa-times far\"></i>\n        </button>\n      </button>\n    } @empty {\n      {{ NAME + '.noFilterOptions' | translate }}\n    }\n  </div>\n\n  <div class=\"hidden-filters-title\">\n    <h4>{{ NAME + '.hiddenHeader' | translate }}</h4>\n  </div>\n  <div class=\"tw-flex tw-flex-col\">\n    @for (hidden of items.hiddenItems; track hidden.id) {\n      <button class=\"item-button-hidden\" lx-button [title]=\"'show'\" size=\"large\" color=\"light\" (click)=\"makeVisible(hidden)\">\n        <span class=\"item-label\">\n          {{ hidden.label }}\n        </span>\n        <button\n          class=\"add-to-visible-button\"\n          lx-button\n          (click)=\"makeVisible(hidden)\"\n          [title]=\"NAME + '.show' | translate\"\n          [attr.aria-label]=\"NAME + '.show' | translate\"\n          [square]=\"true\"\n          mode=\"ghost\"\n          size=\"small\"\n        >\n          <i aria-hidden=\"true\" class=\"far fa-plus\"></i>\n        </button>\n      </button>\n    } @empty {\n      {{ NAME + '.noFilterOptions' | translate }}\n    }\n  </div>\n</div>\n"]}
@@ -1,31 +0,0 @@
1
- import { CdkDragDrop } from '@angular/cdk/drag-drop';
2
- import { AfterViewInit, EventEmitter } from '@angular/core';
3
- import { Observable } from 'rxjs';
4
- import { KeyboardSortableItemDirective } from '../../forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive';
5
- import * as i0 from "@angular/core";
6
- export interface VisibilityPanelItems {
7
- hiddenItems: visibilityPanelItem[];
8
- visibleItems: visibilityPanelItem[];
9
- }
10
- export interface visibilityPanelItem {
11
- label: string;
12
- id: string;
13
- }
14
- export declare class VisibilityPanelComponent implements AfterViewInit {
15
- readonly NAME = "VisibilityPanelComponent";
16
- items: VisibilityPanelItems;
17
- itemsChange: EventEmitter<VisibilityPanelItems>;
18
- private _keyboardSortableItems;
19
- keyboardSortableItems$: Observable<KeyboardSortableItemDirective[]>;
20
- isSortingByKeyboard: boolean;
21
- keyboardItemBeingSorted: string | undefined;
22
- allItemsData$: Observable<string[]>;
23
- ngAfterViewInit(): void;
24
- drop(event: CdkDragDrop<visibilityPanelItem[]>): void;
25
- shiftArrayElements(array: visibilityPanelItem[], previousPosition: number, newPosition: number): visibilityPanelItem[];
26
- makeVisible(hidden: visibilityPanelItem): void;
27
- makeHidden(visible: visibilityPanelItem): void;
28
- handleKeyboardSort(previousIndex: number, currentIndex: number): void;
29
- static ɵfac: i0.ɵɵFactoryDeclaration<VisibilityPanelComponent, never>;
30
- static ɵcmp: i0.ɵɵComponentDeclaration<VisibilityPanelComponent, "lx-visibility-panel", never, { "items": { "alias": "items"; "required": false; }; }, { "itemsChange": "itemsChange"; }, never, never, true, never>;
31
- }