How would you make rows expandable in angular material tables? One requirement is that I need to be using the angular material table. I would also prefer to use the material
As mentioned here by Andrew Seguin this is already feasible out of the box: using the when predicate.
See this example: https://stackblitz.com/edit/angular-material-expandable-table-rows (thx to Lakston)
Inside of the mat-table tag you have to use the mat-row component with a matRipple directive. When you click on a row the row element will be assigned to the expandedElement variable:
But now we have to add our expanded row, that is hidden by default and will be shown if the user clicks on the row above:
Important is here the already mentioned when predicate. This calls a isExpansionDetailRow function that is defined in the component itself and checks if the row has a detailRow property:
isExpansionDetailRow = (row: any) => row.hasOwnProperty('detailRow');
Since RC0 the first param is the index:
isExpansionDetailRow = (i: number, row: any) => row.hasOwnProperty('detailRow');
If you want to have an expanded view for every row, you have to add an "ExpansionDetailRow" identified by the detailRow property for every row like this:
connect(): Observable {
const rows = [];
data.forEach(element => rows.push(element, { detailRow: true, element }));
return Observable.of(rows);
}
If you would log the rows variable to the console output, it will look like this:
Mat Table expandable rows (sorting, pagination and filtering)