mapa-library-ui 0.70.0 → 0.70.2
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/src/lib/components/dropdown/lib/components/dropdown-tree/src/dropdown.component.mjs +4 -4
- package/esm2020/src/lib/components/dropdown-tree/lib/components/dropdown-tree/src/dropdown.component.mjs +4 -4
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs +3 -3
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs +3 -3
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs +3 -3
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs +3 -3
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/mapa-library-ui-0.70.2.tgz +0 -0
- package/package.json +1 -1
- package/mapa-library-ui-0.70.0.tgz +0 -0
package/esm2020/src/lib/components/dropdown/lib/components/dropdown-tree/src/dropdown.component.mjs
CHANGED
|
@@ -224,11 +224,11 @@ export class MapaDropdownTreeComponent {
|
|
|
224
224
|
getSelectedItems() {
|
|
225
225
|
if (!this.checklistSelection.selected.length)
|
|
226
226
|
return this.element.placeholder || '';
|
|
227
|
-
return this.checklistSelection.selected
|
|
228
|
-
.map((s) => s
|
|
227
|
+
return this.checklistSelection.selected ? this.checklistSelection.selected
|
|
228
|
+
.map((s) => s?.value || s || '')
|
|
229
229
|
.join(',')
|
|
230
230
|
.toString()
|
|
231
|
-
.replace(/\,/g, ', ');
|
|
231
|
+
.replace(/\,/g, ', ') : this.element.placeholder || '';
|
|
232
232
|
}
|
|
233
233
|
filterChanged(event) {
|
|
234
234
|
const filterText = event.target?.value;
|
|
@@ -282,4 +282,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
282
282
|
type: ViewChild,
|
|
283
283
|
args: ['toggleAllCheckbox']
|
|
284
284
|
}] } });
|
|
285
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { DropdownTree } from '../../../core/elements/dropdown-tree';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl } from '@angular/cdk/tree';\nimport {\n  MatTreeFlattener,\n  MatTreeFlatDataSource,\n  MatTree,\n} from '@angular/material/tree';\nimport { Observable } from 'rxjs';\nimport { ChecklistDatabase } from './checklist-database';\nimport { MatAutocomplete } from '@angular/material/autocomplete';\nimport { MatCheckbox, MatCheckboxChange } from '@angular/material/checkbox';\nimport { MatMenu, MatMenuTrigger } from '@angular/material/menu';\n\nexport class DataNode {\n  key!: string;\n  value!: string;\n  children?: DataNode[];\n  isLeaf?: boolean;\n\n  constructor() {}\n}\n\n/** Flat to-do item node with expandable and level information */\nexport class DataFlatNode {\n  key!: string;\n  value!: string;\n  level!: number;\n  expandable!: boolean;\n\n  constructor() {}\n}\n\n@Component({\n  selector: 'mapa-dropdown-tree',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownTreeComponent implements OnInit, AfterViewInit {\n  @Input() formGroup!: FormGroup;\n  @Input() element!: DropdownTree;\n  @ViewChild('auto') autocomplete!: MatAutocomplete;\n  @ViewChild('tree') tree!: MatTree<DataNode>;\n  @ViewChild(MatMenuTrigger) trigger!: MatMenuTrigger;\n  @ViewChild('toggleAllCheckbox') toggleAllCheckbox!: MatCheckbox;\n\n  isMenuExpanded: boolean = false;\n\n  /** Map from flat node to nested node. This helps us finding the nested node to be modified */\n  flatNodeMap = new Map<DataFlatNode, DataNode>();\n\n  /** Map from nested node to flattened node. This helps us to keep the same object for selection */\n  nestedNodeMap = new Map<DataNode, DataFlatNode>();\n\n  /** A selected parent node to be inserted */\n  selectedParent: DataFlatNode | null = null;\n\n  /** The new item's name */\n  newItemName = '';\n\n  treeControl!: FlatTreeControl<DataFlatNode>;\n\n  treeFlattener!: MatTreeFlattener<DataNode, DataFlatNode>;\n\n  dataSource!: MatTreeFlatDataSource<DataNode, DataFlatNode>;\n\n  /** The selection for checklist */\n  checklistSelection = new SelectionModel<DataFlatNode>(true);\n\n  /// Filtering\n  myControl = new FormControl();\n  options: string[] = [];\n  filteredOptions!: Observable<string[]>;\n\n  constructor(private _database: ChecklistDatabase) {}\n\n  ngOnInit(): void {\n    this._database.initialize(this.element.tree);\n    this.treeFlattener = new MatTreeFlattener(\n      this.transformer,\n      this.getLevel,\n      this.isExpandable,\n      this.getChildren\n    );\n    this.treeControl = new FlatTreeControl<DataFlatNode>(\n      this.getLevel,\n      this.isExpandable\n    );\n    this.dataSource = new MatTreeFlatDataSource(\n      this.treeControl,\n      this.treeFlattener\n    );\n\n    this._database.dataChange.subscribe((data) => {\n      this.dataSource.data = data;\n      this.treeControl.expandAll();\n    });\n\n    this.checklistSelection.changed.subscribe((selection) => {\n      if (selection.source.selected.length > 0) {\n        this.formGroup.get(this.element.key)?.patchValue(\n          this.element.multiple\n            ? selection.source.selected.map((checked) => {\n                return { value: checked.value, key: checked.key };\n              })\n            : {\n                value: selection.source.selected[0].value,\n                key: selection.source.selected[0].key,\n              },\n          { emitEvent: false }\n        );\n      }\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      if (value) {\n        if (this.element.multiple) {\n          const allValuesKeys = this.element.multiple\n            ? value.map((item: any) => item.key)\n            : [value.key];\n\n          this.treeControl.dataNodes.map((node) => {\n            if (allValuesKeys.includes(node.key)) {\n              if (this.element.multiple && node.level === 0) {\n                this.todoItemSelectionToggle(node);\n              } else {\n                this.todoLeafItemSelectionToggle(node);\n              }\n            }\n          });\n        } else {\n          this.selectSingleItem(\n            this.treeControl.dataNodes?.find(\n              (node) => node.key === value.key\n            ) as DataFlatNode\n          );\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  toggleAll(event: MatCheckboxChange) {\n    const checked = event.checked;\n\n    this.treeControl.dataNodes.map((node) => {\n      if (checked) {\n        this.checklistSelection.deselect(node);\n      } else {\n        this.checklistSelection.select(node);\n      }\n\n      this.checklistSelection.toggle(node);\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.select(...descendants);\n\n      if (checked) {\n        descendants.every((child) => this.checklistSelection.deselect(child));\n      } else {\n        descendants.every((child) => this.checklistSelection.select(child));\n      }\n    });\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    if (this.element.multiple) {\n      this.formGroup.get(this.element.key)?.patchValue([]);\n      this.toggleAllCheckbox.checked = false;\n    } else {\n      this.formGroup.get(this.element.key)?.patchValue(null);\n    }\n  }\n\n  onPanelChange() {\n    this.isMenuExpanded = !this.isMenuExpanded;\n  }\n\n  filter(array: any[], text: string) {\n    const getNodes = (\n      result: any[],\n      object: { name: string; children: any[] }\n    ) => {\n      if (object.name?.toLowerCase().includes(text)) {\n        result.push(object);\n        return result;\n      }\n      if (Array.isArray(object.children)) {\n        const children = object.children.reduce(getNodes, []);\n        if (children.length) result.push({ ...object, children });\n      }\n      return result;\n    };\n\n    this.element.tree = array.reduce(getNodes, []);\n  }\n\n  getLevel = (node: DataFlatNode) => node.level;\n\n  isExpandable = (node: DataFlatNode) => node.expandable;\n\n  getChildren = (node: DataNode): DataNode[] => node.children!;\n\n  hasChild = (_: number, _nodeData: DataFlatNode) => _nodeData.expandable;\n\n  hasNoContent = (_: number, _nodeData: DataFlatNode) => _nodeData.value === '';\n\n  /**\n   * Transformer to convert nested node to flat node. Record the nodes in maps for later use.\n   */\n  transformer = (node: DataNode, level: number) => {\n    const existingNode = this.nestedNodeMap.get(node);\n    const flatNode =\n      existingNode && existingNode.value === node.value\n        ? existingNode\n        : new DataFlatNode();\n    flatNode.key = node.key;\n    flatNode.value = node.value;\n    flatNode.level = level;\n    flatNode.expandable = !!node.children;\n    this.flatNodeMap.set(flatNode, node);\n    this.nestedNodeMap.set(node, flatNode);\n    return flatNode;\n  };\n\n  /** Whether all the descendants of the node are selected. */\n  descendantsAllSelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return descAllSelected;\n  }\n\n  /** Whether part of the descendants are selected */\n  descendantsPartiallySelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const result = descendants.some((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return result && !this.descendantsAllSelected(node);\n  }\n\n  /** Toggle the to-do item selection. Select/deselect all the descendants node */\n  todoItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    if (this.element.checkChildren) {\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.isSelected(node)\n        ? this.checklistSelection.select(...descendants)\n        : this.checklistSelection.deselect(...descendants);\n\n      // Force update for the parent\n      descendants.every((child) => this.checklistSelection.isSelected(child));\n      this.checkAllParentsSelection(node);\n    }\n  }\n\n  /** Toggle a leaf to-do item selection. Check all the parents to see if they changed */\n  todoLeafItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    this.checkAllParentsSelection(node);\n  }\n\n  /* Checks all the parents when a leaf node is selected/unselected */\n  checkAllParentsSelection(node: DataFlatNode): void {\n    let parent: DataFlatNode | null = this.getParentNode(node);\n    while (parent) {\n      this.checkRootNodeSelection(parent);\n      parent = this.getParentNode(parent);\n    }\n  }\n\n  /** Check root node checked state and change it accordingly */\n  checkRootNodeSelection(node: DataFlatNode): void {\n    const nodeSelected = this.checklistSelection.isSelected(node);\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n\n    if (nodeSelected && !descAllSelected) {\n      this.checklistSelection.deselect(node);\n    } else if (!nodeSelected && descAllSelected) {\n      this.checklistSelection.select(node);\n    }\n  }\n\n  /* Get the parent node of a node */\n  getParentNode(node: DataFlatNode): DataFlatNode | null {\n    const currentLevel = this.getLevel(node);\n\n    if (currentLevel < 1) {\n      return null;\n    }\n\n    const startIndex = this.treeControl.dataNodes.indexOf(node) - 1;\n\n    for (let i = startIndex; i >= 0; i--) {\n      const currentNode = this.treeControl.dataNodes[i];\n\n      if (this.getLevel(currentNode) < currentLevel) {\n        return currentNode;\n      }\n    }\n    return null;\n  }\n\n  getSelectedItems(): string {\n    if (!this.checklistSelection.selected.length)\n      return this.element.placeholder || '';\n    return this.checklistSelection.selected\n      .map((s) => s.value)\n      .join(',')\n      .toString()\n      .replace(/\\,/g, ', ');\n  }\n\n  filterChanged(event: any): void {\n    const filterText = event.target?.value;\n\n    // ChecklistDatabase.filter method which actually filters the tree and gives back a tree structure\n    this._database.filter(filterText);\n  }\n\n  clearSearchValue(): void {\n    this.element.search?.formControl?.setValue('');\n    this._database.filter('');\n  }\n\n  selectSingleItem(node: DataFlatNode): void {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup\n      .get(this.element.key)\n      ?.patchValue({ value: node.value, key: node.key }, { emitEvent: false });\n    this.trigger.closeMenu();\n  }\n\n  hasValue(): boolean {\n    return !!this.formGroup.get(this.element.key)?.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formGroup.get(this.element.key)?.patchValue(null);\n    this.checklistSelection.clear();\n  }\n\n  isAllNodeSelected(): boolean {\n    return !!(\n      this.treeControl.dataNodes.length ===\n      this.checklistSelection.selected.length\n    );\n  }\n}\n","<form\n  [formGroup]=\"formGroup\"\n  *ngIf=\"formGroup && element\"\n  class=\"mapa-dropdown-tree\"\n>\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown-tree__label\">\n    {{ element.label }}\n  </label>\n  <button\n    class=\"mapa-dropdown-tree__dropdown\"\n    #menuOption=\"matMenuTrigger\"\n    [matMenuTriggerFor]=\"menu\"\n  >\n    <div class=\"mapa-dropdown-tree__dropdown--value\">\n      {{ getSelectedItems() }}\n    </div>\n\n    <mat-icon *ngIf=\"hasValue()\" (click)=\"clearValue($event)\" matSuffix\n      >close</mat-icon\n    >\n    <mat-icon>\n      {{ menuOption.menuOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down' }}\n    </mat-icon>\n  </button>\n  <mat-menu #menu=\"matMenu\">\n    <div (click)=\"$event.stopPropagation()\">\n      <div class=\"mapa-dropdown-tree__search\" *ngIf=\"element.search\">\n        <mat-form-field appearance=\"outline\">\n          <input\n            matInput\n            #searchInput\n            [formControl]=\"element.search?.formControl!\"\n            [placeholder]=\"element.search?.placeholder || ''\"\n            (keydown)=\"$event.stopPropagation()\"\n            (keyup)=\"filterChanged($event)\"\n          />\n          <mat-icon\n            *ngIf=\"!!element.search?.formControl?.value && !element.search?.formControl?.disabled\"\n            (click)=\"clearSearchValue()\"\n            matSuffix\n            >close</mat-icon\n          >\n        </mat-form-field>\n      </div>\n      <section [formGroup]=\"formGroup\">\n        <label\n          *ngIf=\"element.multiple === true\"\n          class=\"mapa-dropdown-tree__toggle-all mapa-dropdown-tree__checkbox\"\n        >\n          <mat-checkbox\n            #toggleAllCheckbox\n            class=\"checklist-leaf-node\"\n            (change)=\"toggleAll($event)\"\n            [checked]=\"isAllNodeSelected()\"\n            [indeterminate]=\"!isAllNodeSelected() && checklistSelection.hasValue()\"\n            color=\"accent\"\n            >Selecionar todos</mat-checkbox\n          >\n        </label>\n\n        <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n          <mat-tree-node\n            *matTreeNodeDef=\"let node\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\n              <!-- LEAF CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                class=\"checklist-leaf-node\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                (change)=\"todoLeafItemSelectionToggle(node)\"\n                color=\"accent\"\n                >{{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n\n          <mat-tree-node\n            *matTreeNodeDef=\"let node; when: hasChild\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <!-- <button\n                mat-icon-button\n                matTreeNodeToggle\n                [attr.aria-label]=\"'toggle ' + node.filename\"\n              >\n                <mat-icon class=\"mat-icon-rtl-mirror\">\n                  {{treeControl.isExpanded(node) ? 'expand_more' :\n                  'chevron_right'}}\n                </mat-icon>\n              </button> -->\n              <!-- [checked]=\"descendantsAllSelected(node)\" -->\n              <!-- PARENT CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                [indeterminate]=\"descendantsPartiallySelected(node)\"\n                (change)=\"todoItemSelectionToggle(node)\"\n                color=\"accent\"\n              >\n                {{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n        </mat-tree>\n      </section>\n      <button\n        *ngIf=\"element.multiple === true\"\n        mat-button\n        class=\"mapa-dropdown-tree__button\"\n        color=\"primary\"\n        (click)=\"clearAll()\"\n      >\n        Limpar todos\n      </button>\n    </div>\n  </mat-menu>\n</form>\n"]}
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { DropdownTree } from '../../../core/elements/dropdown-tree';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl } from '@angular/cdk/tree';\nimport {\n  MatTreeFlattener,\n  MatTreeFlatDataSource,\n  MatTree,\n} from '@angular/material/tree';\nimport { Observable } from 'rxjs';\nimport { ChecklistDatabase } from './checklist-database';\nimport { MatAutocomplete } from '@angular/material/autocomplete';\nimport { MatCheckbox, MatCheckboxChange } from '@angular/material/checkbox';\nimport { MatMenu, MatMenuTrigger } from '@angular/material/menu';\n\nexport class DataNode {\n  key!: string;\n  value!: string;\n  children?: DataNode[];\n  isLeaf?: boolean;\n\n  constructor() {}\n}\n\n/** Flat to-do item node with expandable and level information */\nexport class DataFlatNode {\n  key!: string;\n  value!: string;\n  level!: number;\n  expandable!: boolean;\n\n  constructor() {}\n}\n\n@Component({\n  selector: 'mapa-dropdown-tree',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownTreeComponent implements OnInit, AfterViewInit {\n  @Input() formGroup!: FormGroup;\n  @Input() element!: DropdownTree;\n  @ViewChild('auto') autocomplete!: MatAutocomplete;\n  @ViewChild('tree') tree!: MatTree<DataNode>;\n  @ViewChild(MatMenuTrigger) trigger!: MatMenuTrigger;\n  @ViewChild('toggleAllCheckbox') toggleAllCheckbox!: MatCheckbox;\n\n  isMenuExpanded: boolean = false;\n\n  /** Map from flat node to nested node. This helps us finding the nested node to be modified */\n  flatNodeMap = new Map<DataFlatNode, DataNode>();\n\n  /** Map from nested node to flattened node. This helps us to keep the same object for selection */\n  nestedNodeMap = new Map<DataNode, DataFlatNode>();\n\n  /** A selected parent node to be inserted */\n  selectedParent: DataFlatNode | null = null;\n\n  /** The new item's name */\n  newItemName = '';\n\n  treeControl!: FlatTreeControl<DataFlatNode>;\n\n  treeFlattener!: MatTreeFlattener<DataNode, DataFlatNode>;\n\n  dataSource!: MatTreeFlatDataSource<DataNode, DataFlatNode>;\n\n  /** The selection for checklist */\n  checklistSelection = new SelectionModel<DataFlatNode>(true);\n\n  /// Filtering\n  myControl = new FormControl();\n  options: string[] = [];\n  filteredOptions!: Observable<string[]>;\n\n  constructor(private _database: ChecklistDatabase) {}\n\n  ngOnInit(): void {\n    this._database.initialize(this.element.tree);\n    this.treeFlattener = new MatTreeFlattener(\n      this.transformer,\n      this.getLevel,\n      this.isExpandable,\n      this.getChildren\n    );\n    this.treeControl = new FlatTreeControl<DataFlatNode>(\n      this.getLevel,\n      this.isExpandable\n    );\n    this.dataSource = new MatTreeFlatDataSource(\n      this.treeControl,\n      this.treeFlattener\n    );\n\n    this._database.dataChange.subscribe((data) => {\n      this.dataSource.data = data;\n      this.treeControl.expandAll();\n    });\n\n    this.checklistSelection.changed.subscribe((selection) => {\n      if (selection.source.selected.length > 0) {\n        this.formGroup.get(this.element.key)?.patchValue(\n          this.element.multiple\n            ? selection.source.selected.map((checked) => {\n                return { value: checked.value, key: checked.key };\n              })\n            : {\n                value: selection.source.selected[0].value,\n                key: selection.source.selected[0].key,\n              },\n          { emitEvent: false }\n        );\n      }\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      if (value) {\n        if (this.element.multiple) {\n          const allValuesKeys = this.element.multiple\n            ? value.map((item: any) => item.key)\n            : [value.key];\n\n          this.treeControl.dataNodes.map((node) => {\n            if (allValuesKeys.includes(node.key)) {\n              if (this.element.multiple && node.level === 0) {\n                this.todoItemSelectionToggle(node);\n              } else {\n                this.todoLeafItemSelectionToggle(node);\n              }\n            }\n          });\n        } else {\n          this.selectSingleItem(\n            this.treeControl.dataNodes?.find(\n              (node) => node.key === value.key\n            ) as DataFlatNode\n          );\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  toggleAll(event: MatCheckboxChange) {\n    const checked = event.checked;\n\n    this.treeControl.dataNodes.map((node) => {\n      if (checked) {\n        this.checklistSelection.deselect(node);\n      } else {\n        this.checklistSelection.select(node);\n      }\n\n      this.checklistSelection.toggle(node);\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.select(...descendants);\n\n      if (checked) {\n        descendants.every((child) => this.checklistSelection.deselect(child));\n      } else {\n        descendants.every((child) => this.checklistSelection.select(child));\n      }\n    });\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    if (this.element.multiple) {\n      this.formGroup.get(this.element.key)?.patchValue([]);\n      this.toggleAllCheckbox.checked = false;\n    } else {\n      this.formGroup.get(this.element.key)?.patchValue(null);\n    }\n  }\n\n  onPanelChange() {\n    this.isMenuExpanded = !this.isMenuExpanded;\n  }\n\n  filter(array: any[], text: string) {\n    const getNodes = (\n      result: any[],\n      object: { name: string; children: any[] }\n    ) => {\n      if (object.name?.toLowerCase().includes(text)) {\n        result.push(object);\n        return result;\n      }\n      if (Array.isArray(object.children)) {\n        const children = object.children.reduce(getNodes, []);\n        if (children.length) result.push({ ...object, children });\n      }\n      return result;\n    };\n\n    this.element.tree = array.reduce(getNodes, []);\n  }\n\n  getLevel = (node: DataFlatNode) => node.level;\n\n  isExpandable = (node: DataFlatNode) => node.expandable;\n\n  getChildren = (node: DataNode): DataNode[] => node.children!;\n\n  hasChild = (_: number, _nodeData: DataFlatNode) => _nodeData.expandable;\n\n  hasNoContent = (_: number, _nodeData: DataFlatNode) => _nodeData.value === '';\n\n  /**\n   * Transformer to convert nested node to flat node. Record the nodes in maps for later use.\n   */\n  transformer = (node: DataNode, level: number) => {\n    const existingNode = this.nestedNodeMap.get(node);\n    const flatNode =\n      existingNode && existingNode.value === node.value\n        ? existingNode\n        : new DataFlatNode();\n    flatNode.key = node.key;\n    flatNode.value = node.value;\n    flatNode.level = level;\n    flatNode.expandable = !!node.children;\n    this.flatNodeMap.set(flatNode, node);\n    this.nestedNodeMap.set(node, flatNode);\n    return flatNode;\n  };\n\n  /** Whether all the descendants of the node are selected. */\n  descendantsAllSelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return descAllSelected;\n  }\n\n  /** Whether part of the descendants are selected */\n  descendantsPartiallySelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const result = descendants.some((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return result && !this.descendantsAllSelected(node);\n  }\n\n  /** Toggle the to-do item selection. Select/deselect all the descendants node */\n  todoItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    if (this.element.checkChildren) {\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.isSelected(node)\n        ? this.checklistSelection.select(...descendants)\n        : this.checklistSelection.deselect(...descendants);\n\n      // Force update for the parent\n      descendants.every((child) => this.checklistSelection.isSelected(child));\n      this.checkAllParentsSelection(node);\n    }\n  }\n\n  /** Toggle a leaf to-do item selection. Check all the parents to see if they changed */\n  todoLeafItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    this.checkAllParentsSelection(node);\n  }\n\n  /* Checks all the parents when a leaf node is selected/unselected */\n  checkAllParentsSelection(node: DataFlatNode): void {\n    let parent: DataFlatNode | null = this.getParentNode(node);\n    while (parent) {\n      this.checkRootNodeSelection(parent);\n      parent = this.getParentNode(parent);\n    }\n  }\n\n  /** Check root node checked state and change it accordingly */\n  checkRootNodeSelection(node: DataFlatNode): void {\n    const nodeSelected = this.checklistSelection.isSelected(node);\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n\n    if (nodeSelected && !descAllSelected) {\n      this.checklistSelection.deselect(node);\n    } else if (!nodeSelected && descAllSelected) {\n      this.checklistSelection.select(node);\n    }\n  }\n\n  /* Get the parent node of a node */\n  getParentNode(node: DataFlatNode): DataFlatNode | null {\n    const currentLevel = this.getLevel(node);\n\n    if (currentLevel < 1) {\n      return null;\n    }\n\n    const startIndex = this.treeControl.dataNodes.indexOf(node) - 1;\n\n    for (let i = startIndex; i >= 0; i--) {\n      const currentNode = this.treeControl.dataNodes[i];\n\n      if (this.getLevel(currentNode) < currentLevel) {\n        return currentNode;\n      }\n    }\n    return null;\n  }\n\n  getSelectedItems(): string {\n    if (!this.checklistSelection.selected.length)\n      return this.element.placeholder || '';\n    \n    return this.checklistSelection.selected ? this.checklistSelection.selected\n      .map((s) => s?.value || s || '')\n      .join(',')\n      .toString()\n      .replace(/\\,/g, ', ') : this.element.placeholder || '';\n  }\n\n  filterChanged(event: any): void {\n    const filterText = event.target?.value;\n\n    // ChecklistDatabase.filter method which actually filters the tree and gives back a tree structure\n    this._database.filter(filterText);\n  }\n\n  clearSearchValue(): void {\n    this.element.search?.formControl?.setValue('');\n    this._database.filter('');\n  }\n\n  selectSingleItem(node: DataFlatNode): void {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup\n      .get(this.element.key)\n      ?.patchValue({ value: node.value, key: node.key }, { emitEvent: false });\n    this.trigger.closeMenu();\n  }\n\n  hasValue(): boolean {\n    return !!this.formGroup.get(this.element.key)?.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formGroup.get(this.element.key)?.patchValue(null);\n    this.checklistSelection.clear();\n  }\n\n  isAllNodeSelected(): boolean {\n    return !!(\n      this.treeControl.dataNodes.length ===\n      this.checklistSelection.selected.length\n    );\n  }\n}\n","<form\n  [formGroup]=\"formGroup\"\n  *ngIf=\"formGroup && element\"\n  class=\"mapa-dropdown-tree\"\n>\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown-tree__label\">\n    {{ element.label }}\n  </label>\n  <button\n    class=\"mapa-dropdown-tree__dropdown\"\n    #menuOption=\"matMenuTrigger\"\n    [matMenuTriggerFor]=\"menu\"\n  >\n    <div class=\"mapa-dropdown-tree__dropdown--value\">\n      {{ getSelectedItems() }}\n    </div>\n\n    <mat-icon *ngIf=\"hasValue()\" (click)=\"clearValue($event)\" matSuffix\n      >close</mat-icon\n    >\n    <mat-icon>\n      {{ menuOption.menuOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down' }}\n    </mat-icon>\n  </button>\n  <mat-menu #menu=\"matMenu\">\n    <div (click)=\"$event.stopPropagation()\">\n      <div class=\"mapa-dropdown-tree__search\" *ngIf=\"element.search\">\n        <mat-form-field appearance=\"outline\">\n          <input\n            matInput\n            #searchInput\n            [formControl]=\"element.search?.formControl!\"\n            [placeholder]=\"element.search?.placeholder || ''\"\n            (keydown)=\"$event.stopPropagation()\"\n            (keyup)=\"filterChanged($event)\"\n          />\n          <mat-icon\n            *ngIf=\"!!element.search?.formControl?.value && !element.search?.formControl?.disabled\"\n            (click)=\"clearSearchValue()\"\n            matSuffix\n            >close</mat-icon\n          >\n        </mat-form-field>\n      </div>\n      <section [formGroup]=\"formGroup\">\n        <label\n          *ngIf=\"element.multiple === true\"\n          class=\"mapa-dropdown-tree__toggle-all mapa-dropdown-tree__checkbox\"\n        >\n          <mat-checkbox\n            #toggleAllCheckbox\n            class=\"checklist-leaf-node\"\n            (change)=\"toggleAll($event)\"\n            [checked]=\"isAllNodeSelected()\"\n            [indeterminate]=\"!isAllNodeSelected() && checklistSelection.hasValue()\"\n            color=\"accent\"\n            >Selecionar todos</mat-checkbox\n          >\n        </label>\n\n        <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n          <mat-tree-node\n            *matTreeNodeDef=\"let node\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\n              <!-- LEAF CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                class=\"checklist-leaf-node\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                (change)=\"todoLeafItemSelectionToggle(node)\"\n                color=\"accent\"\n                >{{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n\n          <mat-tree-node\n            *matTreeNodeDef=\"let node; when: hasChild\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <!-- <button\n                mat-icon-button\n                matTreeNodeToggle\n                [attr.aria-label]=\"'toggle ' + node.filename\"\n              >\n                <mat-icon class=\"mat-icon-rtl-mirror\">\n                  {{treeControl.isExpanded(node) ? 'expand_more' :\n                  'chevron_right'}}\n                </mat-icon>\n              </button> -->\n              <!-- [checked]=\"descendantsAllSelected(node)\" -->\n              <!-- PARENT CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                [indeterminate]=\"descendantsPartiallySelected(node)\"\n                (change)=\"todoItemSelectionToggle(node)\"\n                color=\"accent\"\n              >\n                {{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n        </mat-tree>\n      </section>\n      <button\n        *ngIf=\"element.multiple === true\"\n        mat-button\n        class=\"mapa-dropdown-tree__button\"\n        color=\"primary\"\n        (click)=\"clearAll()\"\n      >\n        Limpar todos\n      </button>\n    </div>\n  </mat-menu>\n</form>\n"]}
|
|
@@ -224,11 +224,11 @@ export class MapaDropdownTreeComponent {
|
|
|
224
224
|
getSelectedItems() {
|
|
225
225
|
if (!this.checklistSelection.selected.length)
|
|
226
226
|
return this.element.placeholder || '';
|
|
227
|
-
return this.checklistSelection.selected
|
|
228
|
-
.map((s) => s
|
|
227
|
+
return this.checklistSelection.selected ? this.checklistSelection.selected
|
|
228
|
+
.map((s) => s?.value || s || '')
|
|
229
229
|
.join(',')
|
|
230
230
|
.toString()
|
|
231
|
-
.replace(/\,/g, ', ');
|
|
231
|
+
.replace(/\,/g, ', ') : this.element.placeholder || '';
|
|
232
232
|
}
|
|
233
233
|
filterChanged(event) {
|
|
234
234
|
const filterText = event.target?.value;
|
|
@@ -282,4 +282,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
282
282
|
type: ViewChild,
|
|
283
283
|
args: ['toggleAllCheckbox']
|
|
284
284
|
}] } });
|
|
285
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { DropdownTree } from '../../../core/elements/dropdown-tree';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl } from '@angular/cdk/tree';\nimport {\n  MatTreeFlattener,\n  MatTreeFlatDataSource,\n  MatTree,\n} from '@angular/material/tree';\nimport { Observable } from 'rxjs';\nimport { ChecklistDatabase } from './checklist-database';\nimport { MatAutocomplete } from '@angular/material/autocomplete';\nimport { MatCheckbox, MatCheckboxChange } from '@angular/material/checkbox';\nimport { MatMenu, MatMenuTrigger } from '@angular/material/menu';\n\nexport class DataNode {\n  key!: string;\n  value!: string;\n  children?: DataNode[];\n  isLeaf?: boolean;\n\n  constructor() {}\n}\n\n/** Flat to-do item node with expandable and level information */\nexport class DataFlatNode {\n  key!: string;\n  value!: string;\n  level!: number;\n  expandable!: boolean;\n\n  constructor() {}\n}\n\n@Component({\n  selector: 'mapa-dropdown-tree',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownTreeComponent implements OnInit, AfterViewInit {\n  @Input() formGroup!: FormGroup;\n  @Input() element!: DropdownTree;\n  @ViewChild('auto') autocomplete!: MatAutocomplete;\n  @ViewChild('tree') tree!: MatTree<DataNode>;\n  @ViewChild(MatMenuTrigger) trigger!: MatMenuTrigger;\n  @ViewChild('toggleAllCheckbox') toggleAllCheckbox!: MatCheckbox;\n\n  isMenuExpanded: boolean = false;\n\n  /** Map from flat node to nested node. This helps us finding the nested node to be modified */\n  flatNodeMap = new Map<DataFlatNode, DataNode>();\n\n  /** Map from nested node to flattened node. This helps us to keep the same object for selection */\n  nestedNodeMap = new Map<DataNode, DataFlatNode>();\n\n  /** A selected parent node to be inserted */\n  selectedParent: DataFlatNode | null = null;\n\n  /** The new item's name */\n  newItemName = '';\n\n  treeControl!: FlatTreeControl<DataFlatNode>;\n\n  treeFlattener!: MatTreeFlattener<DataNode, DataFlatNode>;\n\n  dataSource!: MatTreeFlatDataSource<DataNode, DataFlatNode>;\n\n  /** The selection for checklist */\n  checklistSelection = new SelectionModel<DataFlatNode>(true);\n\n  /// Filtering\n  myControl = new FormControl();\n  options: string[] = [];\n  filteredOptions!: Observable<string[]>;\n\n  constructor(private _database: ChecklistDatabase) {}\n\n  ngOnInit(): void {\n    this._database.initialize(this.element.tree);\n    this.treeFlattener = new MatTreeFlattener(\n      this.transformer,\n      this.getLevel,\n      this.isExpandable,\n      this.getChildren\n    );\n    this.treeControl = new FlatTreeControl<DataFlatNode>(\n      this.getLevel,\n      this.isExpandable\n    );\n    this.dataSource = new MatTreeFlatDataSource(\n      this.treeControl,\n      this.treeFlattener\n    );\n\n    this._database.dataChange.subscribe((data) => {\n      this.dataSource.data = data;\n      this.treeControl.expandAll();\n    });\n\n    this.checklistSelection.changed.subscribe((selection) => {\n      if (selection.source.selected.length > 0) {\n        this.formGroup.get(this.element.key)?.patchValue(\n          this.element.multiple\n            ? selection.source.selected.map((checked) => {\n                return { value: checked.value, key: checked.key };\n              })\n            : {\n                value: selection.source.selected[0].value,\n                key: selection.source.selected[0].key,\n              },\n          { emitEvent: false }\n        );\n      }\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      if (value) {\n        if (this.element.multiple) {\n          const allValuesKeys = this.element.multiple\n            ? value.map((item: any) => item.key)\n            : [value.key];\n\n          this.treeControl.dataNodes.map((node) => {\n            if (allValuesKeys.includes(node.key)) {\n              if (this.element.multiple && node.level === 0) {\n                this.todoItemSelectionToggle(node);\n              } else {\n                this.todoLeafItemSelectionToggle(node);\n              }\n            }\n          });\n        } else {\n          this.selectSingleItem(\n            this.treeControl.dataNodes?.find(\n              (node) => node.key === value.key\n            ) as DataFlatNode\n          );\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  toggleAll(event: MatCheckboxChange) {\n    const checked = event.checked;\n\n    this.treeControl.dataNodes.map((node) => {\n      if (checked) {\n        this.checklistSelection.deselect(node);\n      } else {\n        this.checklistSelection.select(node);\n      }\n\n      this.checklistSelection.toggle(node);\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.select(...descendants);\n\n      if (checked) {\n        descendants.every((child) => this.checklistSelection.deselect(child));\n      } else {\n        descendants.every((child) => this.checklistSelection.select(child));\n      }\n    });\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    if (this.element.multiple) {\n      this.formGroup.get(this.element.key)?.patchValue([]);\n      this.toggleAllCheckbox.checked = false;\n    } else {\n      this.formGroup.get(this.element.key)?.patchValue(null);\n    }\n  }\n\n  onPanelChange() {\n    this.isMenuExpanded = !this.isMenuExpanded;\n  }\n\n  filter(array: any[], text: string) {\n    const getNodes = (\n      result: any[],\n      object: { name: string; children: any[] }\n    ) => {\n      if (object.name?.toLowerCase().includes(text)) {\n        result.push(object);\n        return result;\n      }\n      if (Array.isArray(object.children)) {\n        const children = object.children.reduce(getNodes, []);\n        if (children.length) result.push({ ...object, children });\n      }\n      return result;\n    };\n\n    this.element.tree = array.reduce(getNodes, []);\n  }\n\n  getLevel = (node: DataFlatNode) => node.level;\n\n  isExpandable = (node: DataFlatNode) => node.expandable;\n\n  getChildren = (node: DataNode): DataNode[] => node.children!;\n\n  hasChild = (_: number, _nodeData: DataFlatNode) => _nodeData.expandable;\n\n  hasNoContent = (_: number, _nodeData: DataFlatNode) => _nodeData.value === '';\n\n  /**\n   * Transformer to convert nested node to flat node. Record the nodes in maps for later use.\n   */\n  transformer = (node: DataNode, level: number) => {\n    const existingNode = this.nestedNodeMap.get(node);\n    const flatNode =\n      existingNode && existingNode.value === node.value\n        ? existingNode\n        : new DataFlatNode();\n    flatNode.key = node.key;\n    flatNode.value = node.value;\n    flatNode.level = level;\n    flatNode.expandable = !!node.children;\n    this.flatNodeMap.set(flatNode, node);\n    this.nestedNodeMap.set(node, flatNode);\n    return flatNode;\n  };\n\n  /** Whether all the descendants of the node are selected. */\n  descendantsAllSelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return descAllSelected;\n  }\n\n  /** Whether part of the descendants are selected */\n  descendantsPartiallySelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const result = descendants.some((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return result && !this.descendantsAllSelected(node);\n  }\n\n  /** Toggle the to-do item selection. Select/deselect all the descendants node */\n  todoItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    if (this.element.checkChildren) {\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.isSelected(node)\n        ? this.checklistSelection.select(...descendants)\n        : this.checklistSelection.deselect(...descendants);\n\n      // Force update for the parent\n      descendants.every((child) => this.checklistSelection.isSelected(child));\n      this.checkAllParentsSelection(node);\n    }\n  }\n\n  /** Toggle a leaf to-do item selection. Check all the parents to see if they changed */\n  todoLeafItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    this.checkAllParentsSelection(node);\n  }\n\n  /* Checks all the parents when a leaf node is selected/unselected */\n  checkAllParentsSelection(node: DataFlatNode): void {\n    let parent: DataFlatNode | null = this.getParentNode(node);\n    while (parent) {\n      this.checkRootNodeSelection(parent);\n      parent = this.getParentNode(parent);\n    }\n  }\n\n  /** Check root node checked state and change it accordingly */\n  checkRootNodeSelection(node: DataFlatNode): void {\n    const nodeSelected = this.checklistSelection.isSelected(node);\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n\n    if (nodeSelected && !descAllSelected) {\n      this.checklistSelection.deselect(node);\n    } else if (!nodeSelected && descAllSelected) {\n      this.checklistSelection.select(node);\n    }\n  }\n\n  /* Get the parent node of a node */\n  getParentNode(node: DataFlatNode): DataFlatNode | null {\n    const currentLevel = this.getLevel(node);\n\n    if (currentLevel < 1) {\n      return null;\n    }\n\n    const startIndex = this.treeControl.dataNodes.indexOf(node) - 1;\n\n    for (let i = startIndex; i >= 0; i--) {\n      const currentNode = this.treeControl.dataNodes[i];\n\n      if (this.getLevel(currentNode) < currentLevel) {\n        return currentNode;\n      }\n    }\n    return null;\n  }\n\n  getSelectedItems(): string {\n    if (!this.checklistSelection.selected.length)\n      return this.element.placeholder || '';\n    return this.checklistSelection.selected\n      .map((s) => s.value)\n      .join(',')\n      .toString()\n      .replace(/\\,/g, ', ');\n  }\n\n  filterChanged(event: any): void {\n    const filterText = event.target?.value;\n\n    // ChecklistDatabase.filter method which actually filters the tree and gives back a tree structure\n    this._database.filter(filterText);\n  }\n\n  clearSearchValue(): void {\n    this.element.search?.formControl?.setValue('');\n    this._database.filter('');\n  }\n\n  selectSingleItem(node: DataFlatNode): void {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup\n      .get(this.element.key)\n      ?.patchValue({ value: node.value, key: node.key }, { emitEvent: false });\n    this.trigger.closeMenu();\n  }\n\n  hasValue(): boolean {\n    return !!this.formGroup.get(this.element.key)?.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formGroup.get(this.element.key)?.patchValue(null);\n    this.checklistSelection.clear();\n  }\n\n  isAllNodeSelected(): boolean {\n    return !!(\n      this.treeControl.dataNodes.length ===\n      this.checklistSelection.selected.length\n    );\n  }\n}\n","<form\n  [formGroup]=\"formGroup\"\n  *ngIf=\"formGroup && element\"\n  class=\"mapa-dropdown-tree\"\n>\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown-tree__label\">\n    {{ element.label }}\n  </label>\n  <button\n    class=\"mapa-dropdown-tree__dropdown\"\n    #menuOption=\"matMenuTrigger\"\n    [matMenuTriggerFor]=\"menu\"\n  >\n    <div class=\"mapa-dropdown-tree__dropdown--value\">\n      {{ getSelectedItems() }}\n    </div>\n\n    <mat-icon *ngIf=\"hasValue()\" (click)=\"clearValue($event)\" matSuffix\n      >close</mat-icon\n    >\n    <mat-icon>\n      {{ menuOption.menuOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down' }}\n    </mat-icon>\n  </button>\n  <mat-menu #menu=\"matMenu\">\n    <div (click)=\"$event.stopPropagation()\">\n      <div class=\"mapa-dropdown-tree__search\" *ngIf=\"element.search\">\n        <mat-form-field appearance=\"outline\">\n          <input\n            matInput\n            #searchInput\n            [formControl]=\"element.search?.formControl!\"\n            [placeholder]=\"element.search?.placeholder || ''\"\n            (keydown)=\"$event.stopPropagation()\"\n            (keyup)=\"filterChanged($event)\"\n          />\n          <mat-icon\n            *ngIf=\"!!element.search?.formControl?.value && !element.search?.formControl?.disabled\"\n            (click)=\"clearSearchValue()\"\n            matSuffix\n            >close</mat-icon\n          >\n        </mat-form-field>\n      </div>\n      <section [formGroup]=\"formGroup\">\n        <label\n          *ngIf=\"element.multiple === true\"\n          class=\"mapa-dropdown-tree__toggle-all mapa-dropdown-tree__checkbox\"\n        >\n          <mat-checkbox\n            #toggleAllCheckbox\n            class=\"checklist-leaf-node\"\n            (change)=\"toggleAll($event)\"\n            [checked]=\"isAllNodeSelected()\"\n            [indeterminate]=\"!isAllNodeSelected() && checklistSelection.hasValue()\"\n            color=\"accent\"\n            >Selecionar todos</mat-checkbox\n          >\n        </label>\n\n        <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n          <mat-tree-node\n            *matTreeNodeDef=\"let node\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\n              <!-- LEAF CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                class=\"checklist-leaf-node\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                (change)=\"todoLeafItemSelectionToggle(node)\"\n                color=\"accent\"\n                >{{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n\n          <mat-tree-node\n            *matTreeNodeDef=\"let node; when: hasChild\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <!-- <button\n                mat-icon-button\n                matTreeNodeToggle\n                [attr.aria-label]=\"'toggle ' + node.filename\"\n              >\n                <mat-icon class=\"mat-icon-rtl-mirror\">\n                  {{treeControl.isExpanded(node) ? 'expand_more' :\n                  'chevron_right'}}\n                </mat-icon>\n              </button> -->\n              <!-- [checked]=\"descendantsAllSelected(node)\" -->\n              <!-- PARENT CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                [indeterminate]=\"descendantsPartiallySelected(node)\"\n                (change)=\"todoItemSelectionToggle(node)\"\n                color=\"accent\"\n              >\n                {{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n        </mat-tree>\n      </section>\n      <button\n        *ngIf=\"element.multiple === true\"\n        mat-button\n        class=\"mapa-dropdown-tree__button\"\n        color=\"primary\"\n        (click)=\"clearAll()\"\n      >\n        Limpar todos\n      </button>\n    </div>\n  </mat-menu>\n</form>\n"]}
|
|
285
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/dropdown-tree/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  Input,\n  OnInit,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { DropdownTree } from '../../../core/elements/dropdown-tree';\nimport { SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl } from '@angular/cdk/tree';\nimport {\n  MatTreeFlattener,\n  MatTreeFlatDataSource,\n  MatTree,\n} from '@angular/material/tree';\nimport { Observable } from 'rxjs';\nimport { ChecklistDatabase } from './checklist-database';\nimport { MatAutocomplete } from '@angular/material/autocomplete';\nimport { MatCheckbox, MatCheckboxChange } from '@angular/material/checkbox';\nimport { MatMenu, MatMenuTrigger } from '@angular/material/menu';\n\nexport class DataNode {\n  key!: string;\n  value!: string;\n  children?: DataNode[];\n  isLeaf?: boolean;\n\n  constructor() {}\n}\n\n/** Flat to-do item node with expandable and level information */\nexport class DataFlatNode {\n  key!: string;\n  value!: string;\n  level!: number;\n  expandable!: boolean;\n\n  constructor() {}\n}\n\n@Component({\n  selector: 'mapa-dropdown-tree',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaDropdownTreeComponent implements OnInit, AfterViewInit {\n  @Input() formGroup!: FormGroup;\n  @Input() element!: DropdownTree;\n  @ViewChild('auto') autocomplete!: MatAutocomplete;\n  @ViewChild('tree') tree!: MatTree<DataNode>;\n  @ViewChild(MatMenuTrigger) trigger!: MatMenuTrigger;\n  @ViewChild('toggleAllCheckbox') toggleAllCheckbox!: MatCheckbox;\n\n  isMenuExpanded: boolean = false;\n\n  /** Map from flat node to nested node. This helps us finding the nested node to be modified */\n  flatNodeMap = new Map<DataFlatNode, DataNode>();\n\n  /** Map from nested node to flattened node. This helps us to keep the same object for selection */\n  nestedNodeMap = new Map<DataNode, DataFlatNode>();\n\n  /** A selected parent node to be inserted */\n  selectedParent: DataFlatNode | null = null;\n\n  /** The new item's name */\n  newItemName = '';\n\n  treeControl!: FlatTreeControl<DataFlatNode>;\n\n  treeFlattener!: MatTreeFlattener<DataNode, DataFlatNode>;\n\n  dataSource!: MatTreeFlatDataSource<DataNode, DataFlatNode>;\n\n  /** The selection for checklist */\n  checklistSelection = new SelectionModel<DataFlatNode>(true);\n\n  /// Filtering\n  myControl = new FormControl();\n  options: string[] = [];\n  filteredOptions!: Observable<string[]>;\n\n  constructor(private _database: ChecklistDatabase) {}\n\n  ngOnInit(): void {\n    this._database.initialize(this.element.tree);\n    this.treeFlattener = new MatTreeFlattener(\n      this.transformer,\n      this.getLevel,\n      this.isExpandable,\n      this.getChildren\n    );\n    this.treeControl = new FlatTreeControl<DataFlatNode>(\n      this.getLevel,\n      this.isExpandable\n    );\n    this.dataSource = new MatTreeFlatDataSource(\n      this.treeControl,\n      this.treeFlattener\n    );\n\n    this._database.dataChange.subscribe((data) => {\n      this.dataSource.data = data;\n      this.treeControl.expandAll();\n    });\n\n    this.checklistSelection.changed.subscribe((selection) => {\n      if (selection.source.selected.length > 0) {\n        this.formGroup.get(this.element.key)?.patchValue(\n          this.element.multiple\n            ? selection.source.selected.map((checked) => {\n                return { value: checked.value, key: checked.key };\n              })\n            : {\n                value: selection.source.selected[0].value,\n                key: selection.source.selected[0].key,\n              },\n          { emitEvent: false }\n        );\n      }\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      if (value) {\n        if (this.element.multiple) {\n          const allValuesKeys = this.element.multiple\n            ? value.map((item: any) => item.key)\n            : [value.key];\n\n          this.treeControl.dataNodes.map((node) => {\n            if (allValuesKeys.includes(node.key)) {\n              if (this.element.multiple && node.level === 0) {\n                this.todoItemSelectionToggle(node);\n              } else {\n                this.todoLeafItemSelectionToggle(node);\n              }\n            }\n          });\n        } else {\n          this.selectSingleItem(\n            this.treeControl.dataNodes?.find(\n              (node) => node.key === value.key\n            ) as DataFlatNode\n          );\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  toggleAll(event: MatCheckboxChange) {\n    const checked = event.checked;\n\n    this.treeControl.dataNodes.map((node) => {\n      if (checked) {\n        this.checklistSelection.deselect(node);\n      } else {\n        this.checklistSelection.select(node);\n      }\n\n      this.checklistSelection.toggle(node);\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.select(...descendants);\n\n      if (checked) {\n        descendants.every((child) => this.checklistSelection.deselect(child));\n      } else {\n        descendants.every((child) => this.checklistSelection.select(child));\n      }\n    });\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    if (this.element.multiple) {\n      this.formGroup.get(this.element.key)?.patchValue([]);\n      this.toggleAllCheckbox.checked = false;\n    } else {\n      this.formGroup.get(this.element.key)?.patchValue(null);\n    }\n  }\n\n  onPanelChange() {\n    this.isMenuExpanded = !this.isMenuExpanded;\n  }\n\n  filter(array: any[], text: string) {\n    const getNodes = (\n      result: any[],\n      object: { name: string; children: any[] }\n    ) => {\n      if (object.name?.toLowerCase().includes(text)) {\n        result.push(object);\n        return result;\n      }\n      if (Array.isArray(object.children)) {\n        const children = object.children.reduce(getNodes, []);\n        if (children.length) result.push({ ...object, children });\n      }\n      return result;\n    };\n\n    this.element.tree = array.reduce(getNodes, []);\n  }\n\n  getLevel = (node: DataFlatNode) => node.level;\n\n  isExpandable = (node: DataFlatNode) => node.expandable;\n\n  getChildren = (node: DataNode): DataNode[] => node.children!;\n\n  hasChild = (_: number, _nodeData: DataFlatNode) => _nodeData.expandable;\n\n  hasNoContent = (_: number, _nodeData: DataFlatNode) => _nodeData.value === '';\n\n  /**\n   * Transformer to convert nested node to flat node. Record the nodes in maps for later use.\n   */\n  transformer = (node: DataNode, level: number) => {\n    const existingNode = this.nestedNodeMap.get(node);\n    const flatNode =\n      existingNode && existingNode.value === node.value\n        ? existingNode\n        : new DataFlatNode();\n    flatNode.key = node.key;\n    flatNode.value = node.value;\n    flatNode.level = level;\n    flatNode.expandable = !!node.children;\n    this.flatNodeMap.set(flatNode, node);\n    this.nestedNodeMap.set(node, flatNode);\n    return flatNode;\n  };\n\n  /** Whether all the descendants of the node are selected. */\n  descendantsAllSelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return descAllSelected;\n  }\n\n  /** Whether part of the descendants are selected */\n  descendantsPartiallySelected(node: DataFlatNode): boolean {\n    const descendants = this.treeControl.getDescendants(node);\n    const result = descendants.some((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n    return result && !this.descendantsAllSelected(node);\n  }\n\n  /** Toggle the to-do item selection. Select/deselect all the descendants node */\n  todoItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    if (this.element.checkChildren) {\n      const descendants = this.treeControl.getDescendants(node);\n      this.checklistSelection.isSelected(node)\n        ? this.checklistSelection.select(...descendants)\n        : this.checklistSelection.deselect(...descendants);\n\n      // Force update for the parent\n      descendants.every((child) => this.checklistSelection.isSelected(child));\n      this.checkAllParentsSelection(node);\n    }\n  }\n\n  /** Toggle a leaf to-do item selection. Check all the parents to see if they changed */\n  todoLeafItemSelectionToggle(node: DataFlatNode): void {\n    this.checklistSelection.toggle(node);\n\n    this.checkAllParentsSelection(node);\n  }\n\n  /* Checks all the parents when a leaf node is selected/unselected */\n  checkAllParentsSelection(node: DataFlatNode): void {\n    let parent: DataFlatNode | null = this.getParentNode(node);\n    while (parent) {\n      this.checkRootNodeSelection(parent);\n      parent = this.getParentNode(parent);\n    }\n  }\n\n  /** Check root node checked state and change it accordingly */\n  checkRootNodeSelection(node: DataFlatNode): void {\n    const nodeSelected = this.checklistSelection.isSelected(node);\n    const descendants = this.treeControl.getDescendants(node);\n    const descAllSelected = descendants.every((child) =>\n      this.checklistSelection.isSelected(child)\n    );\n\n    if (nodeSelected && !descAllSelected) {\n      this.checklistSelection.deselect(node);\n    } else if (!nodeSelected && descAllSelected) {\n      this.checklistSelection.select(node);\n    }\n  }\n\n  /* Get the parent node of a node */\n  getParentNode(node: DataFlatNode): DataFlatNode | null {\n    const currentLevel = this.getLevel(node);\n\n    if (currentLevel < 1) {\n      return null;\n    }\n\n    const startIndex = this.treeControl.dataNodes.indexOf(node) - 1;\n\n    for (let i = startIndex; i >= 0; i--) {\n      const currentNode = this.treeControl.dataNodes[i];\n\n      if (this.getLevel(currentNode) < currentLevel) {\n        return currentNode;\n      }\n    }\n    return null;\n  }\n\n  getSelectedItems(): string {\n    if (!this.checklistSelection.selected.length)\n      return this.element.placeholder || '';\n    \n    return this.checklistSelection.selected ? this.checklistSelection.selected\n      .map((s) => s?.value || s || '')\n      .join(',')\n      .toString()\n      .replace(/\\,/g, ', ') : this.element.placeholder || '';\n  }\n\n  filterChanged(event: any): void {\n    const filterText = event.target?.value;\n\n    // ChecklistDatabase.filter method which actually filters the tree and gives back a tree structure\n    this._database.filter(filterText);\n  }\n\n  clearSearchValue(): void {\n    this.element.search?.formControl?.setValue('');\n    this._database.filter('');\n  }\n\n  selectSingleItem(node: DataFlatNode): void {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup\n      .get(this.element.key)\n      ?.patchValue({ value: node.value, key: node.key }, { emitEvent: false });\n    this.trigger.closeMenu();\n  }\n\n  hasValue(): boolean {\n    return !!this.formGroup.get(this.element.key)?.value;\n  }\n\n  clearValue(event: any): void {\n    event.stopPropagation();\n    this.formGroup.get(this.element.key)?.patchValue(null);\n    this.checklistSelection.clear();\n  }\n\n  isAllNodeSelected(): boolean {\n    return !!(\n      this.treeControl.dataNodes.length ===\n      this.checklistSelection.selected.length\n    );\n  }\n}\n","<form\n  [formGroup]=\"formGroup\"\n  *ngIf=\"formGroup && element\"\n  class=\"mapa-dropdown-tree\"\n>\n  <label *ngIf=\"element.label\" class=\"mapa-dropdown-tree__label\">\n    {{ element.label }}\n  </label>\n  <button\n    class=\"mapa-dropdown-tree__dropdown\"\n    #menuOption=\"matMenuTrigger\"\n    [matMenuTriggerFor]=\"menu\"\n  >\n    <div class=\"mapa-dropdown-tree__dropdown--value\">\n      {{ getSelectedItems() }}\n    </div>\n\n    <mat-icon *ngIf=\"hasValue()\" (click)=\"clearValue($event)\" matSuffix\n      >close</mat-icon\n    >\n    <mat-icon>\n      {{ menuOption.menuOpen ? 'keyboard_arrow_up' : 'keyboard_arrow_down' }}\n    </mat-icon>\n  </button>\n  <mat-menu #menu=\"matMenu\">\n    <div (click)=\"$event.stopPropagation()\">\n      <div class=\"mapa-dropdown-tree__search\" *ngIf=\"element.search\">\n        <mat-form-field appearance=\"outline\">\n          <input\n            matInput\n            #searchInput\n            [formControl]=\"element.search?.formControl!\"\n            [placeholder]=\"element.search?.placeholder || ''\"\n            (keydown)=\"$event.stopPropagation()\"\n            (keyup)=\"filterChanged($event)\"\n          />\n          <mat-icon\n            *ngIf=\"!!element.search?.formControl?.value && !element.search?.formControl?.disabled\"\n            (click)=\"clearSearchValue()\"\n            matSuffix\n            >close</mat-icon\n          >\n        </mat-form-field>\n      </div>\n      <section [formGroup]=\"formGroup\">\n        <label\n          *ngIf=\"element.multiple === true\"\n          class=\"mapa-dropdown-tree__toggle-all mapa-dropdown-tree__checkbox\"\n        >\n          <mat-checkbox\n            #toggleAllCheckbox\n            class=\"checklist-leaf-node\"\n            (change)=\"toggleAll($event)\"\n            [checked]=\"isAllNodeSelected()\"\n            [indeterminate]=\"!isAllNodeSelected() && checklistSelection.hasValue()\"\n            color=\"accent\"\n            >Selecionar todos</mat-checkbox\n          >\n        </label>\n\n        <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n          <mat-tree-node\n            *matTreeNodeDef=\"let node\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\n              <!-- LEAF CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                class=\"checklist-leaf-node\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                (change)=\"todoLeafItemSelectionToggle(node)\"\n                color=\"accent\"\n                >{{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n\n          <mat-tree-node\n            *matTreeNodeDef=\"let node; when: hasChild\"\n            matTreeNodePadding\n            matTreeNodePaddingIndent=\"13\"\n            [class.mapa-dropdown-tree__checkbox--checked]=\"checklistSelection.isSelected(node)\"\n          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <!-- <button\n                mat-icon-button\n                matTreeNodeToggle\n                [attr.aria-label]=\"'toggle ' + node.filename\"\n              >\n                <mat-icon class=\"mat-icon-rtl-mirror\">\n                  {{treeControl.isExpanded(node) ? 'expand_more' :\n                  'chevron_right'}}\n                </mat-icon>\n              </button> -->\n              <!-- [checked]=\"descendantsAllSelected(node)\" -->\n              <!-- PARENT CHECKBOX -->\n              <mat-checkbox\n                *ngIf=\"element.multiple === true; else noCheckbox\"\n                [checked]=\"checklistSelection.isSelected(node)\"\n                [indeterminate]=\"descendantsPartiallySelected(node)\"\n                (change)=\"todoItemSelectionToggle(node)\"\n                color=\"accent\"\n              >\n                {{node.value}}</mat-checkbox\n              >\n              <ng-template #noCheckbox>\n                <div (click)=\"selectSingleItem(node)\">\n                  {{node.value}}\n                </div>\n              </ng-template>\n            </label>\n          </mat-tree-node>\n        </mat-tree>\n      </section>\n      <button\n        *ngIf=\"element.multiple === true\"\n        mat-button\n        class=\"mapa-dropdown-tree__button\"\n        color=\"primary\"\n        (click)=\"clearAll()\"\n      >\n        Limpar todos\n      </button>\n    </div>\n  </mat-menu>\n</form>\n"]}
|
|
@@ -607,11 +607,11 @@ class MapaDropdownTreeComponent {
|
|
|
607
607
|
getSelectedItems() {
|
|
608
608
|
if (!this.checklistSelection.selected.length)
|
|
609
609
|
return this.element.placeholder || '';
|
|
610
|
-
return this.checklistSelection.selected
|
|
611
|
-
.map((s) => s.value)
|
|
610
|
+
return this.checklistSelection.selected ? this.checklistSelection.selected
|
|
611
|
+
.map((s) => (s === null || s === void 0 ? void 0 : s.value) || s || '')
|
|
612
612
|
.join(',')
|
|
613
613
|
.toString()
|
|
614
|
-
.replace(/\,/g, ', ');
|
|
614
|
+
.replace(/\,/g, ', ') : this.element.placeholder || '';
|
|
615
615
|
}
|
|
616
616
|
filterChanged(event) {
|
|
617
617
|
var _a;
|