Угловое 6 Материал Дерево - PullRequest
0 голосов
/ 12 июня 2018

Я пытаюсь создать материальное угловое дерево, основанное на документах , но, похоже, возникла ошибка, которую я не могу диагностировать.Chromes выдает ошибку, которая Cannot read property 'children' of undefined в строке 8 моего HTML.Кажется, что дерево загружается в nestedDataSource просто отлично, но ничего не отображается.Правда, я не совсем уверен, как работает дерево угловых материалов, поэтому я, возможно, только что испортил HTML.

На угловых 6.01

category-picker.component.html:

<mat-tree [dataSource]="nestedDataSource" [treeControl]="nestedTreeControl" class="category-picker">
  <mat-tree-node *matTreeNodeDef="let node">
    <li class="mat-tree-node">
      {{node.category.name}}
    </li>
  </mat-tree-node>

  <mat-nested-tree-node *matTreeNodeDef="let node; when: node.children.length">
    <li>
      {{node.category.name}}
      <ul [class.example-tree-invisible]="!nestedTreeControl.isExpanded(node)">
        <ng-container matTreeNodeOutlet></ng-container>
      </ul>
    </li>
  </mat-nested-tree-node>
</mat-tree>

category-picker.component.ts:

import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
import {NestedTreeControl} from '@angular/cdk/tree';

import {MatSelectModule} from '@angular/material';
import {MatTreeNestedDataSource} from '@angular/material/tree';

import { DataBrokerService } from '../data-broker.service';
import { Category } from '../datatypes'
import { observable, of } from 'rxjs';

export class CategoryNode {
  children: CategoryNode[];
  category: Category;
}


@Component({
  selector: 'app-category-picker',
  templateUrl: './category-picker.component.html',
  styleUrls: ['./category-picker.component.scss']
})
export class CategoryPickerComponent implements OnInit {

  // Does not follow main/sub category - just has a simple category!
  @Input() categoryID: number;
  @Output() categoryIDChange:EventEmitter<number> = new EventEmitter<number>();

  nestedTreeControl: NestedTreeControl<CategoryNode>;

  nestedDataSource: MatTreeNestedDataSource<CategoryNode>;

  constructor(
    private dataBrokerService: DataBrokerService
  ) { 
    this.nestedTreeControl = new NestedTreeControl(node => of(node.children));
    this.nestedDataSource = new MatTreeNestedDataSource();
  }

  ngOnInit() {
    this.dataBrokerService.getCategories().subscribe(categories => this.nestedDataSource.data = this.buildTree(categories));
  }

  onChange(){
    this.categoryIDChange.emit(this.categoryID);
  }

  private buildTree(categories:Category[]):CategoryNode[]{
    console.log("tree");

    let tree:CategoryNode[] = [];
    let map: {[s:number]: CategoryNode} = {};

    // Build an index of the nodes
    categories.forEach(cat => {
      map[cat.id] = {children:[], category:cat};
    });

    // Start adding nodes to tree 
    for (let key of Object.keys(map)){
      let catNode = map[+key];

      if (map[catNode.category.parent_id]){
        // Add it to the parent
        map[catNode.category.parent_id].children.push(catNode);
      }
      else{
        // Add it to root
        tree.push(catNode);
      }
    };
    console.log(tree);
    return tree;
  }
}

Ответы [ 2 ]

0 голосов
/ 12 сентября 2018

category-picker.component.html: <mat-nested-tree-node *matTreeNodeDef="let node; when: hasNestedChild">

category-picker.component.ts: hasNestedChild=(_: number, nodeData) => {return nodeData.children.length}

0 голосов
/ 12 июня 2018

Оказывается, я неправильно реализовал функцию when MatTreeNodeDef.В моем HTML мне нужно было изменить when: node.children.length на when: hasNestedChild, который определен как = (_: number, nodeData) => {return nodeData.children.length} в файле .ts.Другими словами, , когда - обязательный параметр, который принимает функцию с двумя входами (число и узел).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...