admin
2024-08-26 7b8eb1a221c4f6dbee63471137f9dd16e0cdead4
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
Quintiq file version 2.0
#parent: #root
Method WriteToFile (String exportID_i) id:Method_LibDIF_pnlButtonExportToXLS_WriteToFile
{
  #keys: '[146730.0.581585050]'
  Body:
  [*
    // See if the current Client initiated export; if so, then get the data and write it to a file.
    api := dhIntegrationAPI.Data();
    if( not isnull( api ) )
    {
      // Only do something if the current Client 'recognizes' ExportID,
      // which means that it has triggered the export.
      if( lblMyExportID.Text() <> "" and
          exportID_i = lblMyExportID.Text() )
      {
        // Get the ExportData right away to prevent that it might be overwritten by next export-action
        // while the user is selecting a file.
        binData := api.GetExportDataXLS().AsBinaryData();
    
        // Ask the user for the filename. Use the DataTransformationID as default name.
        dataTransformationID := this.GetDataTransformationID();
        fileName := Application.GetSaveFileName( dataTransformationID, "xlsx", "XLSX-files" );
    
        if( fileName <> "" )
        {
          // Write the data to a file on the Client-machine.
          Application.WriteBinaryFile( fileName, binData );
    
          // Check if the file has been written succesfully.
          if( not Application.ClientFileExists( fileName ) )
          {
            LibDIF_Util::Info( "something went wrong while writing file '" + fileName + "'." );
          }
        }
    
        // Reset
        lblMyExportID.Text( "" );
      }
    }
  *]
}