Sometimes, you may need to associate files with a model that you edit in a grid.
To upload the files you would use a component like the FileSelect or Upload, and you need a way to know which row (model) they are about.
The typical approach would be to handle the appropriate component event and pass the current model through a lambda expression. Then, apply that metadata in the file saving logic.
In this example, the FileSelect
component is used and data from the model is used to save the files in specific folders (that depend on the "employee" ID) through the OnSelect
event.
With the Upload
component, you would choose what metadata to pass to the endpoint and implement the logic there (see the OnUpload
event).
In either case, you may want to also update the grid data source to "know" about the associated files. Typically, you would have the file upload in edit mode of the grid and that will make things easier (see grid editor template). In this example, such persistence is not implemented for the sake of brevity.
This approach (using lambda expressions to pass additional data from the current context) is suitable for other scenarios as well - such as editing a record in a treelist, listview or other data bound component, or for other situations where you may need the specific item from a repeated list.
This sample is a server-side
Blazor project where a FileSelect
component is straightforward to use. In a WebAssembly
app, you may want to consider the Telerik Upload
as your first choice, because it sends the file directly to your server endpoint, which you would otherwise have to implement on your own with a File Select type of component.