|
77 | 77 | @if (column.Visible) |
78 | 78 | { |
79 | 79 | <th scope="col" style="@(!string.IsNullOrEmpty(column.Width) ? $"width:{column.Width};" : "") user-select: none" |
80 | | - @ondrop="@(() => HandleDrop(column))" |
81 | | - @ondragstart="@(() => HandleDragStart(column))" |
| 80 | + @ondrop="@(_ => HandleDrop(column))" |
| 81 | + @ondragstart="@(_ => HandleDragStart(column))" |
82 | 82 | ondragover="event.preventDefault();" |
83 | 83 | draggable="@(ColumnReorder.ToString())" |
84 | 84 | @key="column" |
|
145 | 145 | if (FilteredItems.Any()) |
146 | 146 | { |
147 | 147 | int i = 0; |
| 148 | + bool detailViewActive = _detailTemplate != null; |
148 | 149 |
|
149 | 150 | foreach (TableItem item in FilteredItems) |
150 | 151 | { |
151 | | - <tr @key="item" aria-selected="@(SelectedItems.Contains(item) ? "true" : null)" class="@RowClass(item) @(SelectedItems.Contains(item) ? "table-active" : "")" @onclick="(() => OnRowClickHandler(item))"> |
| 152 | + bool rowDisplayed = false; |
152 | 153 |
|
153 | | - @{ |
154 | | - int locali = i; |
155 | | - bool isOpen = detailsViewOpen.ContainsKey(locali) && detailsViewOpen[locali]; |
156 | | - } |
157 | | - @if (_detailTemplate != null) |
| 154 | + foreach (CustomRow<TableItem> customRow in CustomRows) |
| 155 | + { |
| 156 | + if (customRow.IsActiveForItem != null && customRow.IsActiveForItem(item)) |
158 | 157 | { |
159 | | - <td> |
160 | | - <a href="javascript:;" style="text-decoration: none" @onclick="@(() => { detailsViewOpen[locali] = !isOpen; StateHasChanged(); })" title="@Localization["TableDetailsView"]" aria-expanded="@(isOpen ? "true" : "false")"> |
161 | | - @if (isOpen) |
162 | | - {<span aria-hidden="true"><img src="_content/BlazorTable/images/minus.png" /></span>} |
163 | | - else |
164 | | - {<span aria-hidden="true"><img src="_content/BlazorTable/images/plus.png" /></span>} |
165 | | - </a> |
166 | | - </td> |
| 158 | + @customRow.ChildContent(item) |
| 159 | + rowDisplayed = true; |
| 160 | + break; |
167 | 161 | } |
| 162 | + } |
168 | 163 |
|
169 | | - @foreach (IColumn<TableItem> column in Columns) |
170 | | - { |
171 | | - @if (column.Visible) |
172 | | - { |
173 | | - <td @key="column" |
174 | | - style="@(column.Align > 0 ? $"text-align: {column.Align};" : "")" |
175 | | - class="@(column.Class)"> |
| 164 | + if (!rowDisplayed) |
| 165 | + { |
| 166 | + <tr @key="item" aria-selected="@(SelectedItems.Contains(item) ? "true" : null)" class="@RowClass(item) @(SelectedItems.Contains(item) ? "table-active" : "")" @onclick="(() => OnRowClickHandler(item))"> |
176 | 167 |
|
177 | | - @if (IsEditMode && column.EditTemplate != null) |
178 | | - @column.EditTemplate(item) |
179 | | - else if (column.Template == null) |
180 | | - @column.Render(item) |
181 | | - else |
182 | | - @column.Template(item) |
| 168 | + @{ |
| 169 | + int locali = i; |
| 170 | + if (!detailsViewOpen.ContainsKey(locali)) |
| 171 | + { |
| 172 | + detailsViewOpen[locali] = false; |
| 173 | + } |
| 174 | + } |
| 175 | + @if (detailViewActive) |
| 176 | + { |
| 177 | + <td> |
| 178 | + <a href="javascript:;" style="text-decoration: none" @onclick="@(() => { detailsViewOpen[locali] = !detailsViewOpen[locali]; StateHasChanged(); })" title="@Localization["TableDetailsView"]" aria-expanded="@(detailsViewOpen[locali] ? "true" : "false")"> |
| 179 | + @if (detailsViewOpen[locali]) |
| 180 | + {<span aria-hidden="true"><img src="_content/BlazorTable/images/minus.png" /></span>} |
| 181 | + else |
| 182 | + {<span aria-hidden="true"><img src="_content/BlazorTable/images/plus.png" /></span>} |
| 183 | + </a> |
183 | 184 | </td> |
184 | 185 | } |
185 | | - } |
186 | | - </tr> |
187 | 186 |
|
188 | | - if (_detailTemplate != null && isOpen) |
189 | | - { |
190 | | - <tr> |
191 | | - <td></td> |
192 | | - <td colspan="@(Columns.Count)"> |
193 | | - @_detailTemplate(item) |
194 | | - </td> |
| 187 | + @foreach (IColumn<TableItem> column in Columns) |
| 188 | + { |
| 189 | + @if (column.Visible) |
| 190 | + { |
| 191 | + <td @key="column" |
| 192 | + style="@(column.Align > 0 ? $"text-align: {column.Align};" : "")" |
| 193 | + class="@(column.Class)"> |
| 194 | + |
| 195 | + @if (IsEditMode && column.EditTemplate != null) |
| 196 | + @column.EditTemplate(item) |
| 197 | + else if (column.Template == null) |
| 198 | + @column.Render(item) |
| 199 | + else |
| 200 | + @column.Template(item) |
| 201 | + </td> |
| 202 | + } |
| 203 | + } |
195 | 204 | </tr> |
| 205 | + |
| 206 | + if (detailViewActive && detailsViewOpen[i]) |
| 207 | + { |
| 208 | + <tr> |
| 209 | + <td></td> |
| 210 | + <td colspan="@(Columns.Count)"> |
| 211 | + @_detailTemplate(item) |
| 212 | + </td> |
| 213 | + </tr> |
| 214 | + } |
196 | 215 | } |
197 | 216 |
|
198 | | - { i = locali + 1; } |
| 217 | + { i++; } |
199 | 218 | } |
200 | 219 | } |
201 | 220 | else if (_emptyDataTemplate != null) |
|
0 commit comments