mapa-library-ui 0.54.0 → 0.56.0
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 +2 -1
- package/esm2020/src/lib/components/dropdown-tree/lib/components/dropdown-tree/src/dropdown.component.mjs +2 -1
- package/esm2020/src/lib/components/group-report/lib/components/group-report/src/group-report.component.mjs +2 -2
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown-tree.mjs +2 -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 +2 -0
- package/fesm2015/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-group-report.mjs +1 -1
- package/fesm2015/mapa-library-ui-src-lib-components-group-report.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown-tree.mjs +1 -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 +1 -0
- package/fesm2020/mapa-library-ui-src-lib-components-dropdown.mjs.map +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-group-report.mjs +1 -1
- package/fesm2020/mapa-library-ui-src-lib-components-group-report.mjs.map +1 -1
- package/mapa-library-ui-0.56.0.tgz +0 -0
- package/package.json +1 -1
- package/mapa-library-ui-0.54.0.tgz +0 -0
package/esm2020/src/lib/components/dropdown/lib/components/dropdown-tree/src/dropdown.component.mjs
CHANGED
|
@@ -221,6 +221,7 @@ export class MapaDropdownTreeComponent {
|
|
|
221
221
|
selectSingleItem(node) {
|
|
222
222
|
this.checklistSelection.clear();
|
|
223
223
|
this.checklistSelection.select(node);
|
|
224
|
+
this.formGroup.get(this.element.key)?.patchValue({ value: node.value, key: node.key });
|
|
224
225
|
this.trigger.closeMenu();
|
|
225
226
|
}
|
|
226
227
|
}
|
|
@@ -246,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
246
247
|
type: ViewChild,
|
|
247
248
|
args: ["toggleAllCheckbox"]
|
|
248
249
|
}] } });
|
|
249
|
-
//# 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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        }),\n        { emitEvent: false }\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      const allValuesKeys = value.map((item: any) => item.key);\n      this.treeControl.dataNodes.map((node) => {\n        if (allValuesKeys.includes(node.key)) {\n          if (node.level === 0) {\n            this.todoItemSelectionToggle(node);\n          } else {\n            this.todoLeafItemSelectionToggle(node);\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    this.formGroup.get(this.element.key)?.patchValue([]);\n    this.toggleAllCheckbox.checked = false;\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    if (this.element.checkParent) {\n      this.checkAllParentsSelection(node);\n    }\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  selectSingleItem(node: DataFlatNode) {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.trigger.closeMenu();\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      <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            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          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\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          >\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              <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"]}
|
|
250
|
+
//# 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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        }),\n        { emitEvent: false }\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      const allValuesKeys = value.map((item: any) => item.key);\n      this.treeControl.dataNodes.map((node) => {\n        if (allValuesKeys.includes(node.key)) {\n          if (node.level === 0) {\n            this.todoItemSelectionToggle(node);\n          } else {\n            this.todoLeafItemSelectionToggle(node);\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    this.formGroup.get(this.element.key)?.patchValue([]);\n    this.toggleAllCheckbox.checked = false;\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    if (this.element.checkParent) {\n      this.checkAllParentsSelection(node);\n    }\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  selectSingleItem(node: DataFlatNode) {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup.get(this.element.key)?.patchValue(\n      { value: node.value, key: node.key }\n    );\n    this.trigger.closeMenu();\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      <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            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          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\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          >\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              <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"]}
|
|
@@ -221,6 +221,7 @@ export class MapaDropdownTreeComponent {
|
|
|
221
221
|
selectSingleItem(node) {
|
|
222
222
|
this.checklistSelection.clear();
|
|
223
223
|
this.checklistSelection.select(node);
|
|
224
|
+
this.formGroup.get(this.element.key)?.patchValue({ value: node.value, key: node.key });
|
|
224
225
|
this.trigger.closeMenu();
|
|
225
226
|
}
|
|
226
227
|
}
|
|
@@ -246,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
246
247
|
type: ViewChild,
|
|
247
248
|
args: ["toggleAllCheckbox"]
|
|
248
249
|
}] } });
|
|
249
|
-
//# 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":"AAAA,OAAO,EAEL,SAAS,EACT,KAAK,EAEL,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAa,MAAM,gBAAgB,CAAC;AAExD,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EACL,gBAAgB,EAChB,qBAAqB,GAEtB,MAAM,wBAAwB,CAAC;AAKhC,OAAO,EAAW,cAAc,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;;;AAEjE,MAAM,OAAO,QAAQ;IAMnB,gBAAe,CAAC;CACjB;AAED,iEAAiE;AACjE,MAAM,OAAO,YAAY;IAMvB,gBAAe,CAAC;CACjB;AAQD,MAAM,OAAO,yBAAyB;IAoCpC,YAAoB,SAA4B;QAA5B,cAAS,GAAT,SAAS,CAAmB;QA5BhD,mBAAc,GAAY,KAAK,CAAC;QAEhC,8FAA8F;QAC9F,gBAAW,GAAG,IAAI,GAAG,EAA0B,CAAC;QAEhD,kGAAkG;QAClG,kBAAa,GAAG,IAAI,GAAG,EAA0B,CAAC;QAElD,4CAA4C;QAC5C,mBAAc,GAAwB,IAAI,CAAC;QAE3C,0BAA0B;QAC1B,gBAAW,GAAG,EAAE,CAAC;QAQjB,kCAAkC;QAClC,uBAAkB,GAAG,IAAI,cAAc,CAAe,IAAI,CAAC,CAAC;QAE5D,aAAa;QACb,cAAS,GAAG,IAAI,WAAW,EAAE,CAAC;QAC9B,YAAO,GAAa,EAAE,CAAC;QAyGvB,aAAQ,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC;QAE9C,iBAAY,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC;QAEvD,gBAAW,GAAG,CAAC,IAAc,EAAc,EAAE,CAAC,IAAI,CAAC,QAAS,CAAC;QAE7D,aAAQ,GAAG,CAAC,CAAS,EAAE,SAAuB,EAAE,EAAE,CAAC,SAAS,CAAC,UAAU,CAAC;QAExE,iBAAY,GAAG,CAAC,CAAS,EAAE,SAAuB,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,KAAK,EAAE,CAAC;QAE9E;;WAEG;QACH,gBAAW,GAAG,CAAC,IAAc,EAAE,KAAa,EAAE,EAAE;YAC9C,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAClD,MAAM,QAAQ,GACZ,YAAY,IAAI,YAAY,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK;gBAC/C,CAAC,CAAC,YAAY;gBACd,CAAC,CAAC,IAAI,YAAY,EAAE,CAAC;YACzB,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC;YACxB,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YAC5B,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;YACvB,QAAQ,CAAC,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;YACtC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;YACrC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;YACvC,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC;IAhIiD,CAAC;IAEpD,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,gBAAgB,CACvC,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,WAAW,CACjB,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,eAAe,CACpC,IAAI,CAAC,QAAQ,EACb,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,IAAI,CAAC,UAAU,GAAG,IAAI,qBAAqB,CACzC,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,aAAa,CACnB,CAAC;QAEF,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACtD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,UAAU,CAC9C,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;gBACxC,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC;YACpD,CAAC,CAAC,EACF,EAAE,SAAS,EAAE,KAAK,EAAE,CACrB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACrE,MAAM,aAAa,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACzD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;gBACtC,IAAI,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;oBACpC,IAAI,IAAI,CAAC,KAAK,KAAK,CAAC,EAAE;wBACpB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;qBACpC;yBAAM;wBACL,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,CAAC;qBACxC;iBACF;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,CAAC;IAC/B,CAAC;IAED,SAAS,CAAC,KAAwB;QAChC,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAE9B,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACtC,IAAI,OAAO,EAAE;gBACX,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;aACxC;iBAAM;gBACL,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aACtC;YAED,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACrC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;YAC1D,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,WAAW,CAAC,CAAC;YAE/C,IAAI,OAAO,EAAE;gBACX,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;aACvE;iBAAM;gBACL,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;aACrE;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,UAAU,CAAC,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,iBAAiB,CAAC,OAAO,GAAG,KAAK,CAAC;IACzC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,KAAY,EAAE,IAAY;QAC/B,MAAM,QAAQ,GAAG,CACf,MAAa,EACb,MAAyC,EACzC,EAAE;YACF,IAAI,MAAM,CAAC,IAAI,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBAC7C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBACpB,OAAO,MAAM,CAAC;aACf;YACD,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE;gBAClC,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;gBACtD,IAAI,QAAQ,CAAC,MAAM;oBAAE,MAAM,CAAC,IAAI,CAAC,EAAE,GAAG,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;aAC3D;YACD,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IACjD,CAAC;IA8BD,4DAA4D;IAC5D,sBAAsB,CAAC,IAAkB;QACvC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAClD,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,KAAK,CAAC,CAC1C,CAAC;QACF,OAAO,eAAe,CAAC;IACzB,CAAC;IAED,mDAAmD;IACnD,4BAA4B,CAAC,IAAkB;QAC7C,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CACxC,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,KAAK,CAAC,CAC1C,CAAC;QACF,OAAO,MAAM,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAC;IACtD,CAAC;IAED,gFAAgF;IAChF,uBAAuB,CAAC,IAAkB;QACxC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1D,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC;YACtC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,GAAG,WAAW,CAAC;YAChD,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,GAAG,WAAW,CAAC,CAAC;QAErD,8BAA8B;QAC9B,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;QACxE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,uFAAuF;IACvF,2BAA2B,CAAC,IAAkB;QAC5C,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YAC5B,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;SACrC;IACH,CAAC;IAED,oEAAoE;IACpE,wBAAwB,CAAC,IAAkB;QACzC,IAAI,MAAM,GAAwB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC3D,OAAO,MAAM,EAAE;YACb,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;YACpC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;SACrC;IACH,CAAC;IAED,8DAA8D;IAC9D,sBAAsB,CAAC,IAAkB;QACvC,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC9D,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1D,MAAM,eAAe,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE,CAClD,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,KAAK,CAAC,CAC1C,CAAC;QACF,IAAI,YAAY,IAAI,CAAC,eAAe,EAAE;YACpC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;SACxC;aAAM,IAAI,CAAC,YAAY,IAAI,eAAe,EAAE;YAC3C,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACtC;IACH,CAAC;IAED,mCAAmC;IACnC,aAAa,CAAC,IAAkB;QAC9B,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAEzC,IAAI,YAAY,GAAG,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEhE,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACpC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAElD,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG,YAAY,EAAE;gBAC7C,OAAO,WAAW,CAAC;aACpB;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,MAAM;YAC1C,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QACxC,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ;aACpC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;aACnB,IAAI,CAAC,GAAG,CAAC;aACT,QAAQ,EAAE;aACV,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC;QAEvC,kGAAkG;QAClG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,WAAW,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC/C,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,gBAAgB,CAAC,IAAkB;QACjC,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;IAC3B,CAAC;;uHAlRU,yBAAyB;2GAAzB,yBAAyB,iUAKzB,cAAc,yJCrD3B,80IA8HA;4FD9Ea,yBAAyB;kBANrC,SAAS;+BACE,oBAAoB,iBAGf,iBAAiB,CAAC,IAAI;wGAG5B,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACa,YAAY;sBAA9B,SAAS;uBAAC,MAAM;gBACE,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBACU,OAAO;sBAAjC,SAAS;uBAAC,cAAc;gBACO,iBAAiB;sBAAhD,SAAS;uBAAC,mBAAmB","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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        }),\n        { emitEvent: false }\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      const allValuesKeys = value.map((item: any) => item.key);\n      this.treeControl.dataNodes.map((node) => {\n        if (allValuesKeys.includes(node.key)) {\n          if (node.level === 0) {\n            this.todoItemSelectionToggle(node);\n          } else {\n            this.todoLeafItemSelectionToggle(node);\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    this.formGroup.get(this.element.key)?.patchValue([]);\n    this.toggleAllCheckbox.checked = false;\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    if (this.element.checkParent) {\n      this.checkAllParentsSelection(node);\n    }\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  selectSingleItem(node: DataFlatNode) {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.trigger.closeMenu();\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      <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            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          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\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          >\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              <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"]}
|
|
250
|
+
//# 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      this.formGroup.get(this.element.key)?.patchValue(\n        selection.source.selected.map((checked) => {\n          return { value: checked.value, key: checked.key };\n        }),\n        { emitEvent: false }\n      );\n    });\n\n    this.formGroup.get(this.element.key)?.valueChanges.subscribe((value) => {\n      const allValuesKeys = value.map((item: any) => item.key);\n      this.treeControl.dataNodes.map((node) => {\n        if (allValuesKeys.includes(node.key)) {\n          if (node.level === 0) {\n            this.todoItemSelectionToggle(node);\n          } else {\n            this.todoLeafItemSelectionToggle(node);\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    this.formGroup.get(this.element.key)?.patchValue([]);\n    this.toggleAllCheckbox.checked = false;\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    if (this.element.checkParent) {\n      this.checkAllParentsSelection(node);\n    }\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  selectSingleItem(node: DataFlatNode) {\n    this.checklistSelection.clear();\n    this.checklistSelection.select(node);\n    this.formGroup.get(this.element.key)?.patchValue(\n      { value: node.value, key: node.key }\n    );\n    this.trigger.closeMenu();\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      <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            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          >\n            <label class=\"mapa-dropdown-tree__checkbox\">\n              <button mat-icon-button disabled></button>\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          >\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              <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"]}
|
|
@@ -57,7 +57,7 @@ export class MapaGroupReportComponent {
|
|
|
57
57
|
}
|
|
58
58
|
this.dataSource.data = data.sort((a, b) => {
|
|
59
59
|
const isAsc = sort.direction === "asc";
|
|
60
|
-
return this.compare(a[sort.active].
|
|
60
|
+
return this.compare(a[sort.active].classificationName, b[sort.active].classificationName, isAsc);
|
|
61
61
|
});
|
|
62
62
|
}
|
|
63
63
|
compare(a, b, isAsc) {
|
|
@@ -197,4 +197,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
197
197
|
type: ViewChild,
|
|
198
198
|
args: [MatSort]
|
|
199
199
|
}] } });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-report.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/group-report/src/group-report.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/group-report/src/group-report.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { FormGroup } from \"@angular/forms\";\nimport moment from \"moment\";\n\nimport { MatSort, Sort } from \"@angular/material/sort\";\nimport { MatTableDataSource } from \"@angular/material/table\";\n\nimport { TableColumn } from \"../../../core/interfaces/table-column.interface\";\nimport { GroupReportItem } from \"./group-report-interface\";\nimport { CapabilityItem } from \"../../capability/public-api\";\nimport { Dimension } from \"./group-report-interface\";\n\n@Component({\n  selector: \"mapa-group-report\",\n  templateUrl: \"./group-report.component.html\",\n  styleUrls: [\n    \"./group-report.component.scss\",\n    \"./../../capability/styles/capability.scss\",\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaGroupReportComponent implements OnInit, AfterViewInit {\n  @Input() groupReport: GroupReportItem[] = [];\n  @Input() showGroupReportGeneral: boolean | undefined = false;\n  @Output() onSortChange: EventEmitter<Sort> = new EventEmitter<Sort>();\n\n  @ViewChild(MatSort) sort!: MatSort;\n\n  dataSource!: MatTableDataSource<Object>;\n  displayedColumns: string[] = [];\n  currentSort: Sort | undefined;\n  columns: TableColumn[] = [];\n  data: Object[] = [];\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.generateColumns();\n    this.generateGroupData();\n  }\n\n  ngAfterViewInit(): void {\n    this.dataSource = new MatTableDataSource(this.data);\n    this.dataSource.sort = this.sort;\n    this.displayedColumns = this.columns.map((column) => column.key);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes[\"data\"]) {\n      if (this.dataSource) {\n        this.data = changes[\"data\"].currentValue;\n        this.dataSource = new MatTableDataSource(this.data);\n        this.dataSource.sort = this.sort;\n        this.displayedColumns = this.columns.map((column) => column.key);\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n  sortData(column: TableColumn): void {\n    if (column.sort) {\n      const sort: Sort = { active: column.key, direction: \"asc\" };\n\n      if (\n        this.currentSort &&\n        this.currentSort.active === column.key &&\n        this.currentSort.direction === \"asc\"\n      ) {\n        sort.direction = \"desc\";\n      }\n\n      this.currentSort = sort;\n      this.sortDataFunction(sort);\n    }\n  }\n\n  sortDataFunction(sort: Sort) {\n    const data = this.dataSource.data.slice();\n\n    if (!sort.active || sort.direction === \"\") {\n      this.dataSource.data = data;\n      return;\n    }\n\n    this.dataSource.data = data.sort((a: any, b: any) => {\n      const isAsc = sort.direction === \"asc\";\n      return this.compare(\n        a[sort.active].classification.classificationName,\n        b[sort.active].classification.classificationName,\n        isAsc\n      );\n    });\n  }\n\n  compare(a: any, b: any, isAsc: boolean) {\n    if (typeof a === \"string\" && typeof b === \"string\") {\n      return (a.toLowerCase() < b.toLowerCase() ? -1 : 1) * (isAsc ? 1 : -1);\n    }\n    return (a < b ? -1 : 1) * (isAsc ? 1 : -1);\n  }\n\n  generateColumns() {\n    let columns: TableColumn[] = [{ key: \"name\", label: \"\", sort: false }];\n\n    if (this.showGroupReportGeneral) {\n      columns.push({ key: \"general\", label: \"% Geral\", sort: false });\n    }\n\n    this.groupReport.forEach((reportItem) => {\n      reportItem.dimensions?.forEach((dimension: any) => {\n        const key = dimension.dimensionName.toLowerCase();\n        const label = dimension.dimensionName;\n        const classification = dimension.classification;\n        if (!this.columnExists(columns, key)) {\n          columns.push({\n            key,\n            label,\n            classification,\n            sort: true,\n          });\n        }\n      });\n    });\n\n    this.columns = columns;\n  }\n\n  columnExists(columns: TableColumn[], key: string): boolean {\n    return columns.some((column) => column.key === key);\n  }\n\n  generateGroupData() {\n    const result: { [key: string]: any }[] = [];\n\n    this.groupReport.forEach((item) => {\n      const dataItem: { [key: string]: any } = {\n        name: item.candidate.name,\n        cpf: item.candidate.cpf,\n        general: item.candidate.general,\n      };\n\n      item.dimensions?.forEach((dimension: any) => {\n        dataItem[dimension.dimensionName.toLowerCase()] = {\n          value: {\n            label: dimension.escoreT,\n            classification: {\n              classificationId: dimension.classificationId,\n              classificationName: dimension.classificationName,\n              classificationColor: dimension.classificationColor,\n            },\n          },\n          direction: dimension.direction,\n        };\n      });\n\n      result.push(dataItem);\n    });\n\n    this.data = result;\n  }\n\n  isBoolean(column: TableColumn, row: any): boolean {\n    return typeof row[column.key] === \"boolean\";\n  }\n\n  isMaskedData(column: TableColumn, row: any): boolean {\n    const formats = [moment.ISO_8601, \"MM/DD/YYYY  :)  HH*mm*ss\"];\n    const isDate = moment(row[column.key], formats, true).isValid();\n    return (column.mask && isDate) || false;\n  }\n\n  getValueAsDate(column: TableColumn, row: any): Date {\n    return new Date(row[column.key]);\n  }\n\n  getValue(row: any): any {\n    try {\n      if (row.value) {\n        return row.value;\n      } else {\n        return \"-\";\n      }\n    } catch {\n      return \"-\";\n    }\n  }\n\n  getBackgroundColor(column: TableColumn, row: any): string {\n    return column.status?.color?.[row[column.key] || 0] || \"\";\n  }\n\n  hasCustomClass(column: TableColumn, row: any, key: string): boolean {\n    if (\n      column?.class ||\n      row?.rowStyleClass ||\n      this.hasCellStyleClass(row, key)\n    ) {\n      return true;\n    }\n    return false;\n  }\n\n  getCustomClass(column: TableColumn, row: any, key: string): string {\n    if (this.hasCellStyleClass(row, key)) {\n      return this.getCellStyleClass(row, column.key);\n    } else if (column?.class) {\n      return column.class;\n    } else if (row?.rowStyleClass) {\n      return row.rowStyleClass;\n    }\n    return \"\";\n  }\n\n  hasCellStyleClass(row: any, key: string): boolean {\n    return row.styleClass?.key === key;\n  }\n\n  getCellStyleClass(row: any, key: string): string {\n    return row.styleClass?.key === key ? row.styleClass?.class : \"\";\n  }\n\n  hasIndividualMenu(row: any): boolean {\n    if (row !== \"\" && row !== null) return true;\n    return false;\n  }\n\n  createTag(item: Dimension) {\n    return {\n      bgColor: item.classificationColor || \"\",\n      fontSize: \"12px\",\n      size: \"small\",\n    };\n  }\n}\n","<section class=\"mapa-group-report\">\n  <table\n    mat-table\n    [dataSource]=\"dataSource\"\n    matSort\n    (matSortChange)=\"sortDataFunction($event)\"\n  >\n    <ng-container *ngFor=\"let column of columns\" [matColumnDef]=\"column.key\">\n      <th\n        mat-header-cell\n        *matHeaderCellDef\n        mat-sort-header\n        [disabled]=\"!(column.key !== 'actions' ? column.sort : null)\"\n      >\n        <div\n          [ngTemplateOutlet]=\"tableHeader\"\n          [ngTemplateOutletContext]=\"{ column }\"\n        ></div>\n      </th>\n      <td mat-cell *matCellDef=\"let row\" [style.width]=\"column?.width\">\n        <div\n          class=\"mapa-group-report__column\"\n          [class.mapa-group-report__column--center-cell]=\"column?.align === 'center' || column.key !== 'name'\"\n        >\n          <div class=\"mapa-group-report__content\">\n            <ng-container\n              *ngIf=\"column.key === 'name' || column.key === 'cpf' || column.key === 'general'; else valueContent\"\n            >\n              <div\n                *ngIf=\"column.key === 'name'\"\n                class=\"mapa-group-report__content--value\"\n              >\n                <div class=\"mapa-group-report__content--title\">\n                  {{ row.name }}<br />\n                </div>\n                <div class=\"mapa-group-report__content--subtitle\">\n                  {{ row.cpf }}\n                </div>\n              </div>\n              <div *ngIf=\"column.key === 'general'\" class=\"general\">\n                {{ row[column.key] | currency:'':'' }}%\n              </div>\n            </ng-container>\n            <ng-template #valueContent>\n              <div class=\"mapa-group-report__hover\">\n                <span class=\"mapa-group-report__hover--main\">\n                  <div\n                    class=\"mapa__tag--bg\"\n                    [class.mapa__tag--contrast]=\"getValue(row[column.key]).classification?.classificationId === 1\"\n                    [style.backgroundColor]=\"getValue(row[column.key]).classification?.classificationColor\"\n                  >\n                    {{\n                    getValue(row[column.key]).classification?.classificationName\n                    }}\n                  </div>\n                </span>\n                <span class=\"mapa-group-report__hover--hidden\">\n                  {{ getValue(row[column.key]).label }}\n                </span>\n              </div>\n            </ng-template>\n          </div>\n        </div>\n      </td>\n    </ng-container>\n\n    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n  </table>\n</section>\n\n<ng-template #tableHeader let-column=\"column\">\n  <div class=\"mapa-group-report__header\">\n    {{ column.label }}\n    <div *ngIf=\"column.sort\">\n      <mat-icon>filter_list</mat-icon>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-report.component.js","sourceRoot":"","sources":["../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/group-report/src/group-report.component.ts","../../../../../../../../../../../projects/mapa-library-ui/src/lib/components/group-report/src/group-report.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { FormGroup } from \"@angular/forms\";\nimport moment from \"moment\";\n\nimport { MatSort, Sort } from \"@angular/material/sort\";\nimport { MatTableDataSource } from \"@angular/material/table\";\n\nimport { TableColumn } from \"../../../core/interfaces/table-column.interface\";\nimport { GroupReportItem } from \"./group-report-interface\";\nimport { CapabilityItem } from \"../../capability/public-api\";\nimport { Dimension } from \"./group-report-interface\";\n\n@Component({\n  selector: \"mapa-group-report\",\n  templateUrl: \"./group-report.component.html\",\n  styleUrls: [\n    \"./group-report.component.scss\",\n    \"./../../capability/styles/capability.scss\",\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MapaGroupReportComponent implements OnInit, AfterViewInit {\n  @Input() groupReport: GroupReportItem[] = [];\n  @Input() showGroupReportGeneral: boolean | undefined = false;\n  @Output() onSortChange: EventEmitter<Sort> = new EventEmitter<Sort>();\n\n  @ViewChild(MatSort) sort!: MatSort;\n\n  dataSource!: MatTableDataSource<Object>;\n  displayedColumns: string[] = [];\n  currentSort: Sort | undefined;\n  columns: TableColumn[] = [];\n  data: Object[] = [];\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.generateColumns();\n    this.generateGroupData();\n  }\n\n  ngAfterViewInit(): void {\n    this.dataSource = new MatTableDataSource(this.data);\n    this.dataSource.sort = this.sort;\n    this.displayedColumns = this.columns.map((column) => column.key);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes[\"data\"]) {\n      if (this.dataSource) {\n        this.data = changes[\"data\"].currentValue;\n        this.dataSource = new MatTableDataSource(this.data);\n        this.dataSource.sort = this.sort;\n        this.displayedColumns = this.columns.map((column) => column.key);\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n  sortData(column: TableColumn): void {\n    if (column.sort) {\n      const sort: Sort = { active: column.key, direction: \"asc\" };\n\n      if (\n        this.currentSort &&\n        this.currentSort.active === column.key &&\n        this.currentSort.direction === \"asc\"\n      ) {\n        sort.direction = \"desc\";\n      }\n\n      this.currentSort = sort;\n      this.sortDataFunction(sort);\n    }\n  }\n\n  sortDataFunction(sort: Sort) {\n    const data = this.dataSource.data.slice();\n\n    if (!sort.active || sort.direction === \"\") {\n      this.dataSource.data = data;\n      return;\n    }\n\n    this.dataSource.data = data.sort((a: any, b: any) => {\n      const isAsc = sort.direction === \"asc\";\n      return this.compare(\n        a[sort.active].classificationName,\n        b[sort.active].classificationName,\n        isAsc\n      );\n    });\n  }\n\n  compare(a: any, b: any, isAsc: boolean) {\n    if (typeof a === \"string\" && typeof b === \"string\") {\n      return (a.toLowerCase() < b.toLowerCase() ? -1 : 1) * (isAsc ? 1 : -1);\n    }\n    return (a < b ? -1 : 1) * (isAsc ? 1 : -1);\n  }\n\n  generateColumns() {\n    let columns: TableColumn[] = [{ key: \"name\", label: \"\", sort: false }];\n\n    if (this.showGroupReportGeneral) {\n      columns.push({ key: \"general\", label: \"% Geral\", sort: false });\n    }\n\n    this.groupReport.forEach((reportItem) => {\n      reportItem.dimensions?.forEach((dimension: any) => {\n        const key = dimension.dimensionName.toLowerCase();\n        const label = dimension.dimensionName;\n        const classification = dimension.classification;\n        if (!this.columnExists(columns, key)) {\n          columns.push({\n            key,\n            label,\n            classification,\n            sort: true,\n          });\n        }\n      });\n    });\n\n    this.columns = columns;\n  }\n\n  columnExists(columns: TableColumn[], key: string): boolean {\n    return columns.some((column) => column.key === key);\n  }\n\n  generateGroupData() {\n    const result: { [key: string]: any }[] = [];\n\n    this.groupReport.forEach((item) => {\n      const dataItem: { [key: string]: any } = {\n        name: item.candidate.name,\n        cpf: item.candidate.cpf,\n        general: item.candidate.general,\n      };\n\n      item.dimensions?.forEach((dimension: any) => {\n        dataItem[dimension.dimensionName.toLowerCase()] = {\n          value: {\n            label: dimension.escoreT,\n            classification: {\n              classificationId: dimension.classificationId,\n              classificationName: dimension.classificationName,\n              classificationColor: dimension.classificationColor,\n            },\n          },\n          direction: dimension.direction,\n        };\n      });\n\n      result.push(dataItem);\n    });\n\n    this.data = result;\n  }\n\n  isBoolean(column: TableColumn, row: any): boolean {\n    return typeof row[column.key] === \"boolean\";\n  }\n\n  isMaskedData(column: TableColumn, row: any): boolean {\n    const formats = [moment.ISO_8601, \"MM/DD/YYYY  :)  HH*mm*ss\"];\n    const isDate = moment(row[column.key], formats, true).isValid();\n    return (column.mask && isDate) || false;\n  }\n\n  getValueAsDate(column: TableColumn, row: any): Date {\n    return new Date(row[column.key]);\n  }\n\n  getValue(row: any): any {\n    try {\n      if (row.value) {\n        return row.value;\n      } else {\n        return \"-\";\n      }\n    } catch {\n      return \"-\";\n    }\n  }\n\n  getBackgroundColor(column: TableColumn, row: any): string {\n    return column.status?.color?.[row[column.key] || 0] || \"\";\n  }\n\n  hasCustomClass(column: TableColumn, row: any, key: string): boolean {\n    if (\n      column?.class ||\n      row?.rowStyleClass ||\n      this.hasCellStyleClass(row, key)\n    ) {\n      return true;\n    }\n    return false;\n  }\n\n  getCustomClass(column: TableColumn, row: any, key: string): string {\n    if (this.hasCellStyleClass(row, key)) {\n      return this.getCellStyleClass(row, column.key);\n    } else if (column?.class) {\n      return column.class;\n    } else if (row?.rowStyleClass) {\n      return row.rowStyleClass;\n    }\n    return \"\";\n  }\n\n  hasCellStyleClass(row: any, key: string): boolean {\n    return row.styleClass?.key === key;\n  }\n\n  getCellStyleClass(row: any, key: string): string {\n    return row.styleClass?.key === key ? row.styleClass?.class : \"\";\n  }\n\n  hasIndividualMenu(row: any): boolean {\n    if (row !== \"\" && row !== null) return true;\n    return false;\n  }\n\n  createTag(item: Dimension) {\n    return {\n      bgColor: item.classificationColor || \"\",\n      fontSize: \"12px\",\n      size: \"small\",\n    };\n  }\n}\n","<section class=\"mapa-group-report\">\n  <table\n    mat-table\n    [dataSource]=\"dataSource\"\n    matSort\n    (matSortChange)=\"sortDataFunction($event)\"\n  >\n    <ng-container *ngFor=\"let column of columns\" [matColumnDef]=\"column.key\">\n      <th\n        mat-header-cell\n        *matHeaderCellDef\n        mat-sort-header\n        [disabled]=\"!(column.key !== 'actions' ? column.sort : null)\"\n      >\n        <div\n          [ngTemplateOutlet]=\"tableHeader\"\n          [ngTemplateOutletContext]=\"{ column }\"\n        ></div>\n      </th>\n      <td mat-cell *matCellDef=\"let row\" [style.width]=\"column?.width\">\n        <div\n          class=\"mapa-group-report__column\"\n          [class.mapa-group-report__column--center-cell]=\"column?.align === 'center' || column.key !== 'name'\"\n        >\n          <div class=\"mapa-group-report__content\">\n            <ng-container\n              *ngIf=\"column.key === 'name' || column.key === 'cpf' || column.key === 'general'; else valueContent\"\n            >\n              <div\n                *ngIf=\"column.key === 'name'\"\n                class=\"mapa-group-report__content--value\"\n              >\n                <div class=\"mapa-group-report__content--title\">\n                  {{ row.name }}<br />\n                </div>\n                <div class=\"mapa-group-report__content--subtitle\">\n                  {{ row.cpf }}\n                </div>\n              </div>\n              <div *ngIf=\"column.key === 'general'\" class=\"general\">\n                {{ row[column.key] | currency:'':'' }}%\n              </div>\n            </ng-container>\n            <ng-template #valueContent>\n              <div class=\"mapa-group-report__hover\">\n                <span class=\"mapa-group-report__hover--main\">\n                  <div\n                    class=\"mapa__tag--bg\"\n                    [class.mapa__tag--contrast]=\"getValue(row[column.key]).classification?.classificationId === 1\"\n                    [style.backgroundColor]=\"getValue(row[column.key]).classification?.classificationColor\"\n                  >\n                    {{\n                    getValue(row[column.key]).classification?.classificationName\n                    }}\n                  </div>\n                </span>\n                <span class=\"mapa-group-report__hover--hidden\">\n                  {{ getValue(row[column.key]).label }}\n                </span>\n              </div>\n            </ng-template>\n          </div>\n        </div>\n      </td>\n    </ng-container>\n\n    <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n    <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n  </table>\n</section>\n\n<ng-template #tableHeader let-column=\"column\">\n  <div class=\"mapa-group-report__header\">\n    {{ column.label }}\n    <div *ngIf=\"column.sort\">\n      <mat-icon>filter_list</mat-icon>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -601,8 +601,10 @@ class MapaDropdownTreeComponent {
|
|
|
601
601
|
this._database.filter("");
|
|
602
602
|
}
|
|
603
603
|
selectSingleItem(node) {
|
|
604
|
+
var _a;
|
|
604
605
|
this.checklistSelection.clear();
|
|
605
606
|
this.checklistSelection.select(node);
|
|
607
|
+
(_a = this.formGroup.get(this.element.key)) === null || _a === void 0 ? void 0 : _a.patchValue({ value: node.value, key: node.key });
|
|
606
608
|
this.trigger.closeMenu();
|
|
607
609
|
}
|
|
608
610
|
}
|