Вложенные строки в пользовательских таблицах HTML - PullRequest
0 голосов
/ 09 декабря 2018

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

enter image description here

, когда я нажимаюэтот знак плюс строки этой конкретной строки должны быть связаны с следующей строкой ... enter image description here

Мои данные в этом формате:

tabledata = [
    {
      reference: "191782-01", name: "American Electric LLC", assigned: "Rusty", Ship: "PKUP", Open: "15", total: "30", percentage: "50", staged: "1/4", datetime: "07/25/18 7:51 AM",
       child: [{
        reference: "191782-01", name: "American Electric LLC", assigned: "Rusty", Ship: "PKUP", Open: "15", total: "30", percentage: "50", staged: "1/4", datetime: "07/25/18 7:51 AM"
      },
      {
        reference: "191782-01", name: "American Electric LLC", assigned: "Rusty", Ship: "PKUP", Open: "15", total: "30", percentage: "50", staged: "1/4", datetime: "07/25/18 7:51 AM"
      }]
    },
    { reference: "191780-02", name: "Good Business Company", assigned: "", Ship: "WISE", Open: "8", total: "8", percentage: "0", staged: "1/2", datetime: "07/25/18 8:12 AM", child: [] },
    { reference: "191782-02", name: "Cecchin Plumbing", assigned: "", Ship: "PKUP", Open: "23", total: "36", percentage: "36", staged: "1/3", datetime: "07/25/18 8:01 AM", child: [] },
    { reference: "191780-01", name: "Company Name 1", assigned: "MULTI", Ship: "PKUP", Open: "1", total: "1", percentage: "0", staged: "2/4", datetime: "07/25/18 8:05 AM", child: [] },
    { reference: "191702-02", name: "Leep's Supply", assigned: "MULTI", Ship: "WISE", Open: "3", total: "6", percentage: "50", staged: "2/4", datetime: "07/25/18 8:46 AM", child: [] }
  ]

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

Мой угловой код:

    <tbody>
            <tr *ngFor="let data of tabledata">
              <td class="text-left"><a href="javascript:void(0)">{{data.reference}}</a><span *ngIf="data.reference.includes('191782')"
                  class="badge badge-warning win-badge win-badge-warning win-badge-large ml-3"
                  style="border-radius: 1.4rem">Urgent</span></td>
              <td>{{data.name}}</td>
              <td><span [ngClass]="{'badge badge-secondary win-badge win-badge-secondary': data.assigned=='MULTI', 'bgtrans': data.assigned!='MULTI'}">{{data.assigned}}</span></td>
              <td>{{data.Ship}}</td>
              <td><span [ngClass]="{'alert alert-error mobile-error alert-dismissible': data.Open>10, 'bgtrans': data.Open<10}">{{data.Open}}</span></td>
              <td>{{data.total}}</td>
              <td>{{data.percentage}}</td>
              <td>{{data.staged}}</td>
              <td>{{data.datetime}}</td>
              <td><a href="javascript:void(0)"
                  *ngIf="data.child.length>0"><i class="fa fa-plus-square-o"></i></a> </td>
    </tr>
</tbody>

1 Ответ

0 голосов
/ 09 декабря 2018

Вы можете сначала отобразить массив, чтобы преобразовать его в плоский массив, а затем связать с результирующим массивом:

// pass a function to map
let arrays = tabledata.map(x => new Array(x).concat(x.child));

let flatTableData = [].concat.apply([], arrays);

Чтобы определить дочерние строки, просто найдите те, которые не имеют дочернего свойства

...