X++ Upload and Download file - D365 FO
class RetailSharedParameters_Eventhandlers { /// <summary> /// Event handler for the "UploadFile" button click event. /// </summary> /// <param name="sender">The form control that triggered the event.</param> /// <param name="e">Event arguments.</param> [FormControlEventHandler(formControlStr(RetailSharedParameters, UploadFile), FormControlEventType::Clicked)] public static void UploadFile_OnClicked(FormControl sender, FormControlEventArgs e) { // Get the button that triggered the event FormButtonControl callerButton = sender as FormButtonControl; // Get the form run instance FormRun form = callerButton.formRun(); // Get the data source for the RetailSharedParameters table FormDataSource RetailSharedParameters_ds = form.dataSource(formDataSourceStr(RetailSharedParameters, RetailSharedParameters)) as FormDataSource; // Get the current record from the data source RetailSharedParameters RetailSharedParameters = RetailSharedParameters_ds.cursor(); // Prompt the user to upload a file FileUploadTemporaryStorageResult result = File::GetFileFromUser() as FileUploadTemporaryStorageResult; // Check if the file upload was successful if (result && result.getUploadStatus()) { // Store the file name and download URL in the table RetailSharedParameters.FileName = result.getFileName(); RetailSharedParameters.SoundFile = result.getDownloadUrl(); // Save the changes to the database RetailSharedParameters.write(); } } /// <summary> /// Event handler for the "DownloadFile" button click event. /// </summary> /// <param name="sender">The form control that triggered the event.</param> /// <param name="e">Event arguments.</param> [FormControlEventHandler(formControlStr(RetailSharedParameters, DownloadFile), FormControlEventType::Clicked)] public static void DownloadFile_OnClicked(FormControl sender, FormControlEventArgs e) { // Variable to store the file URL str fileUrl = ''; // Get the button that triggered the event FormButtonControl callerButton = sender as FormButtonControl; // Get the form run instance FormRun form = callerButton.formRun(); // Get the data source for the RetailSharedParameters table FormDataSource RetailSharedParameters_ds = form.dataSource(formDataSourceStr(RetailSharedParameters, RetailSharedParameters)) as FormDataSource; // Get the current record from the data source RetailSharedParameters RetailSharedParameters = RetailSharedParameters_ds.cursor(); // Retrieve the stored file URL fileUrl = RetailSharedParameters.SoundFile; // Open the file URL in a browser if (fileUrl) { new Browser().navigate(fileUrl); } else { // Notify the user if no file URL is found warning("No file URL found."); } } }
Published on:
Learn moreRelated posts
New Feature in Dynamics 365 F&O 10.0.45 Preview: Customer Invoice Logging and Traceability Framework
Have you been posting Sales Order Invoices and Customer Free Text Invoices through batch jobs, only to struggle with tracking the status of th...
Part-10: Create your Custom Agent for D365 F&O[Chart of Account Agent]
Enough talk. Let’s see Copilot Studio in action. Over the weekend, I built something powerful – a custom AI agent for Microsoft Dynamics 365 F...
New Approved Customer List mapping for Items in Dynamics 365 Finance and operations
Take control of your sales process with the latest feature in Microsoft Dynamics 365 Finance – the Approved Customer List! This powerful new f...
Part-9: Connect and Query Dynamics 365 Finance and operations data with Copilot studio
In this video, we kick off an exciting new series focused on extending Copilot Studio capabilities by connecting it to real enterprise data! �...
How to Create Deep Links to D365 F&O Records with Dataverse Virtual Tables
It is a common requirement for SaaS platform that exposes form over data to be able to share a secure link (a.k.a. Deep Link) to access a give...
Simplifying License Management for Dynamics 365 Finance and Operations: Improved User License Validation
Starting April 30th, Dynamics 365 administrators will gain access to new license usage reporting tools, centralizing user license management. ...
D365FO Integration: Import Sales Orders from an External Web Application
Learn how to implement robust and efficient process to import complex documents into Dynamics 365 Finance and Operations from external Web ser...