angular 7 получить значение родительского узла из ngx-treeview - PullRequest
1 голос
/ 05 мая 2019

Я использовал угловой 7 и компонент ngx-treeview.

Я использовал конфигурацию decoupleChildFromParent = true.

Из этого дерева мы получаем только значение дочернего дерева.Я хочу получить значение родительского узла.

это мой HTML-код:

  <ng-template #itemTemplate let-item="item" let-onCollapseExpand="onCollapseExpand" let-onCheckedChange="onCheckedChange">
      <div class="form-inline row-item">

        <i *ngIf="item.children" (click)="onCollapseExpand()" aria-hidden="true" class="fa" [class.fa-caret-right]="item.collapsed"
          [class.fa-caret-down]="!item.collapsed"></i>
        <div class="form-check">
          <input type="checkbox" class="form-check-input" [(ngModel)]="item.checked" (ngModelChange)="onCheckedChange()" [disabled]="item.disabled"
            [indeterminate]="item.indeterminate" />
          <label class="form-check-label" (click)="item.checked = !item.checked; onCheckedChange()">
            {{item.text}}
          </label>

        </div>
      </div>
    </ng-template>

    <div class="row">
      <div class="col-6">
        <div class="form-group">
          <div class="d-inline-block">
            <ngx-treeview [items]="items" [itemTemplate]="itemTemplate" (selectedChange)="onSelectedChange($event)">
            </ngx-treeview>
          </div>
        </div>
      </div>

    </div>

Я использовал функцию onSelectedChange с этим кодом:

 onSelectedChange(downlineItems: DownlineTreeviewItem[]) {
            this.rows = [];
            downlineItems.forEach(downlineItem => {
                const item = downlineItem.item;
                const value = item.value;
                const texts = [item.text];
                let parent = downlineItem.parent
                while (!isNil(parent)) {
                    texts.push(parent.item.text);
                    parent = parent.parent;
                }
                const reverseTexts = reverse(texts);
                const row = `${reverseTexts.join(' -> ')} : ${value}`;
                this.rows.push(row);
                this.rowsSelect=value;
            });
        }

, когда я проверяюродительский флажок, событие selectedChange с пустым массивом значений.

Я хотел бы получить значение выбранного родителя, когда ни один из дочерних элементов не выбран

...