Command Column
The Smart.Grid built-in Command Column
can be used to Edit, Delete or perform any other custom function on a row.
To create a command column, create a new instance of GridEditing()
object
and set the Visible property of the GridCommandColumn
Finally, attach the editing object to the Grid:
@inject WeatherForecastService ForecastService <Grid Editing="@editing"> <Columns> <Column DataField="Date" Label="Date"> </Column> <Column DataField="TemperatureC" Label="Temp. (C)"> </Column> <Column DataField="TemperatureF" Label="Temp. (F)"> </Column> <Column DataField="Summary" Label="Summary"> </Column> </Columns> </Grid> @code{ GridEditing editing = new GridEditing() { Enabled = true, Action = GridEditingAction.None, Mode = GridEditingMode.Row, CommandColumn = new GridEditingCommandColumn() { Visible = true } }; private WeatherForecast[] forecast; protected override async Task OnInitializedAsync() { forecast = await ForecastService.GetForecastAsync(DateTime.Now); } }
data:image/s3,"s3://crabby-images/7e63c/7e63c7c390dfc2bdb2ee9805ca53f905f1da123e" alt="Command column"
Command Column Inline
The Command Column can be displayed inline, meaning that it only appears when the row is hovered.
GridEditing editing = new GridEditing() { Enabled = true, Action = GridEditingAction.None, Mode = GridEditingMode.Row, CommandColumn = new GridEditingCommandColumn() { Visible = true, Inline = true} };
data:image/s3,"s3://crabby-images/1bb9a/1bb9af6ee860c4e418453a20b1dac0baf78a3ec3" alt="Inline command column"
Command Column Position
It is possible to change the position of the command column by using the Position
property.
GridEditing editing = new GridEditing() { Enabled = true, Action = GridEditingAction.None, Mode = GridEditingMode.Row, CommandColumn = new GridEditingCommandColumn() { Visible = true, Position = Position.Near} };
data:image/s3,"s3://crabby-images/5e3fe/5e3fe4e89c1058a28d52137016a1cbb690136140" alt="Command column position set to near"
Custom Command Column
You can also create a custom command column by using the DataSource
property.
In this example, we hide the Delete Column and create a new custom one:
GridEditing editing = new GridEditing() { Enabled = true, Action = GridEditingAction.None, Mode = GridEditingMode.Row, CommandColumn = new GridEditingCommandColumn() { Visible = true, Inline = false, DataSource = new GridEditingCommandColumnDataSource() { CommandColumnDelete = new GridCommand() { Visible = false }, CommandColumnCustom = new GridCommand() { Icon = "smart-icon-star", Command = "notify", Visible = true, Label = "Notify Me" } } } };
data:image/s3,"s3://crabby-images/73ed6/73ed64b6adfec0c54970f42b0455172486af74ea" alt="Custom command column"