mapa-library-ui 0.50.3 → 0.50.4
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 +8 -1
- package/esm2020/src/lib/components/dropdown-tree/lib/components/dropdown-tree/src/dropdown.component.mjs +8 -1
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs +8 -0
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs +8 -0
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs +7 -0
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs +7 -0
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/mapa-library-ui-0.50.4.tgz +0 -0
- package/package.json +1 -1
- package/mapa-library-ui-0.50.3.tgz +0 -0
package/esm2020/src/lib/components/dropdown/lib/components/dropdown-tree/src/dropdown.component.mjs
CHANGED
|
@@ -74,6 +74,13 @@ export class MapaDropdownTreeComponent {
|
|
|
74
74
|
return { value: checked.value, key: checked.key };
|
|
75
75
|
}));
|
|
76
76
|
});
|
|
77
|
+
this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {
|
|
78
|
+
value.map((item) => {
|
|
79
|
+
if (!this.checklistSelection.hasValue) {
|
|
80
|
+
this.todoItemSelectionToggle(item);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
});
|
|
77
84
|
}
|
|
78
85
|
ngAfterViewInit() {
|
|
79
86
|
this.treeControl.expandAll();
|
|
@@ -198,4 +205,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
198
205
|
type: ViewChild,
|
|
199
206
|
args: ["tree"]
|
|
200
207
|
}] } });
|
|
201
|
-
//# 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\";\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\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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        })\n      );\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    this.formGroup.get(this.element.key)?.patchValue([]);\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    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  /** 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    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    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) {\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() {\n    this.element.search?.formControl?.setValue(\"\");\n    this._database.filter(\"\");\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>\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\n      <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node\n          *matTreeNodeDef=\"let node\"\n          matTreeNodeToggle\n          matTreeNodePadding\n        >\n          <button mat-icon-button disabled></button>\n          <mat-checkbox\n            class=\"checklist-leaf-node\"\n            [checked]=\"checklistSelection.isSelected(node)\"\n            (change)=\"todoLeafItemSelectionToggle(node)\"\n            >{{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n\n        <mat-tree-node\n          *matTreeNodeDef=\"let node; when: hasChild\"\n          matTreeNodePadding\n        >\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' : 'chevron_right'}}\n            </mat-icon>\n          </button>\n          <mat-checkbox\n            [checked]=\"descendantsAllSelected(node)\"\n            [indeterminate]=\"descendantsPartiallySelected(node)\"\n            (change)=\"todoItemSelectionToggle(node)\"\n          >\n            {{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n      </mat-tree>\n      <button\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"]}
|
|
208
|
+
//# 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\";\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\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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        })\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      value.map((item: DataFlatNode) => {\n        if (!this.checklistSelection.hasValue) {\n          this.todoItemSelectionToggle(item);\n        }\n      });\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    this.formGroup.get(this.element.key)?.patchValue([]);\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    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  /** 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    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    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) {\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() {\n    this.element.search?.formControl?.setValue(\"\");\n    this._database.filter(\"\");\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>\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\n      <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node\n          *matTreeNodeDef=\"let node\"\n          matTreeNodeToggle\n          matTreeNodePadding\n        >\n          <button mat-icon-button disabled></button>\n          <mat-checkbox\n            class=\"checklist-leaf-node\"\n            [checked]=\"checklistSelection.isSelected(node)\"\n            (change)=\"todoLeafItemSelectionToggle(node)\"\n            >{{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n\n        <mat-tree-node\n          *matTreeNodeDef=\"let node; when: hasChild\"\n          matTreeNodePadding\n        >\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' : 'chevron_right'}}\n            </mat-icon>\n          </button>\n          <mat-checkbox\n            [checked]=\"descendantsAllSelected(node)\"\n            [indeterminate]=\"descendantsPartiallySelected(node)\"\n            (change)=\"todoItemSelectionToggle(node)\"\n          >\n            {{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n      </mat-tree>\n      <button\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"]}
|
|
@@ -74,6 +74,13 @@ export class MapaDropdownTreeComponent {
|
|
|
74
74
|
return { value: checked.value, key: checked.key };
|
|
75
75
|
}));
|
|
76
76
|
});
|
|
77
|
+
this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {
|
|
78
|
+
value.map((item) => {
|
|
79
|
+
if (!this.checklistSelection.hasValue) {
|
|
80
|
+
this.todoItemSelectionToggle(item);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
});
|
|
77
84
|
}
|
|
78
85
|
ngAfterViewInit() {
|
|
79
86
|
this.treeControl.expandAll();
|
|
@@ -198,4 +205,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
198
205
|
type: ViewChild,
|
|
199
206
|
args: ["tree"]
|
|
200
207
|
}] } });
|
|
201
|
-
//# 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\";\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\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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        })\n      );\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    this.formGroup.get(this.element.key)?.patchValue([]);\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    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  /** 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    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    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) {\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() {\n    this.element.search?.formControl?.setValue(\"\");\n    this._database.filter(\"\");\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>\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\n      <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node\n          *matTreeNodeDef=\"let node\"\n          matTreeNodeToggle\n          matTreeNodePadding\n        >\n          <button mat-icon-button disabled></button>\n          <mat-checkbox\n            class=\"checklist-leaf-node\"\n            [checked]=\"checklistSelection.isSelected(node)\"\n            (change)=\"todoLeafItemSelectionToggle(node)\"\n            >{{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n\n        <mat-tree-node\n          *matTreeNodeDef=\"let node; when: hasChild\"\n          matTreeNodePadding\n        >\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' : 'chevron_right'}}\n            </mat-icon>\n          </button>\n          <mat-checkbox\n            [checked]=\"descendantsAllSelected(node)\"\n            [indeterminate]=\"descendantsPartiallySelected(node)\"\n            (change)=\"todoItemSelectionToggle(node)\"\n          >\n            {{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n      </mat-tree>\n      <button\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"]}
|
|
208
|
+
//# 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\";\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\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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        })\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      value.map((item: DataFlatNode) => {\n        if (!this.checklistSelection.hasValue) {\n          this.todoItemSelectionToggle(item);\n        }\n      });\n    });\n  }\n\n  ngAfterViewInit() {\n    this.treeControl.expandAll();\n  }\n\n  clearAll() {\n    this.checklistSelection.clear();\n    this.formGroup.get(this.element.key)?.patchValue([]);\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    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  /** 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    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    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) {\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() {\n    this.element.search?.formControl?.setValue(\"\");\n    this._database.filter(\"\");\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>\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\n      <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node\n          *matTreeNodeDef=\"let node\"\n          matTreeNodeToggle\n          matTreeNodePadding\n        >\n          <button mat-icon-button disabled></button>\n          <mat-checkbox\n            class=\"checklist-leaf-node\"\n            [checked]=\"checklistSelection.isSelected(node)\"\n            (change)=\"todoLeafItemSelectionToggle(node)\"\n            >{{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n\n        <mat-tree-node\n          *matTreeNodeDef=\"let node; when: hasChild\"\n          matTreeNodePadding\n        >\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' : 'chevron_right'}}\n            </mat-icon>\n          </button>\n          <mat-checkbox\n            [checked]=\"descendantsAllSelected(node)\"\n            [indeterminate]=\"descendantsPartiallySelected(node)\"\n            (change)=\"todoItemSelectionToggle(node)\"\n          >\n            {{node.value}}</mat-checkbox\n          >\n        </mat-tree-node>\n      </mat-tree>\n      <button\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"]}
|
|
@@ -437,6 +437,7 @@ class MapaDropdownTreeComponent {
|
|
|
437
437
|
};
|
|
438
438
|
}
|
|
439
439
|
ngOnInit() {
|
|
440
|
+
var _a;
|
|
440
441
|
this._database.initialize(this.element.tree);
|
|
441
442
|
this.treeFlattener = new MatTreeFlattener(this.transformer, this.getLevel, this.isExpandable, this.getChildren);
|
|
442
443
|
this.treeControl = new FlatTreeControl(this.getLevel, this.isExpandable);
|
|
@@ -451,6 +452,13 @@ class MapaDropdownTreeComponent {
|
|
|
451
452
|
return { value: checked.value, key: checked.key };
|
|
452
453
|
}));
|
|
453
454
|
});
|
|
455
|
+
(_a = this.formGroup.get(this.element.key)) === null || _a === void 0 ? void 0 : _a.valueChanges.subscribe((value) => {
|
|
456
|
+
value.map((item) => {
|
|
457
|
+
if (!this.checklistSelection.hasValue) {
|
|
458
|
+
this.todoItemSelectionToggle(item);
|
|
459
|
+
}
|
|
460
|
+
});
|
|
461
|
+
});
|
|
454
462
|
}
|
|
455
463
|
ngAfterViewInit() {
|
|
456
464
|
this.treeControl.expandAll();
|