Quintiq file version 2.0 
 | 
#parent: #root 
 | 
StaticMethod Download ( 
 | 
  MacroPlan macroPlan 
 | 
) as BinaryValue 
 | 
{ 
 | 
  TextBody: 
 | 
  [* 
 | 
    xmlDOMI      := XMLDOMImplementation::Create(); 
 | 
    xmlDOM       := xmlDOMI.CreateDocumentFromString( '<?xml version="1.0" encoding="UTF-16"?><table><name>Sheet1</name></table>' ); 
 | 
     
 | 
    tableElement := xmlDOM.GetElementByTagName( "table", 0 ); 
 | 
     
 | 
    // 第一列(名称) 
 | 
    tprs        := selectsortedset( macroPlan, TransferPlanRow, tempTPR, true, tempTPR.SourceStockpoingPointID(), tempTPR.TargetStockpoingPointID(), tempTPR.ProductID() ); 
 | 
    firstColumn := xmlDOM.CreateElement( "column" ); 
 | 
    firstName   := xmlDOM.CreateElement( "name" ); 
 | 
    firstType   := xmlDOM.CreateElement( "type" ); 
 | 
    firstName.TextContent( "" ); 
 | 
    firstType.TextContent( "String" ); 
 | 
    firstColumn.AppendChild( firstName ); 
 | 
    firstColumn.AppendChild( firstType ); 
 | 
    traverse ( tprs, Elements, tpr ) { 
 | 
      firstCell := xmlDOM.CreateElement( "cell" ); 
 | 
      firstCell.SetAttribute( "value", tpr.Name() ); 
 | 
      firstColumn.AppendChild( firstCell ); 
 | 
    } 
 | 
    tableElement.AppendChild( firstColumn ); 
 | 
     
 | 
    tpcs := selectsortedset( macroPlan, TransferPlanColumn, tempTPC, true, tempTPC.ColumnDate() ); 
 | 
    traverse ( tpcs, Elements, tpc ) { 
 | 
      column := xmlDOM.CreateElement( "column" ); 
 | 
      name   := xmlDOM.CreateElement( "name" ); 
 | 
      type   := xmlDOM.CreateElement( "type" ); 
 | 
      name.TextContent( tpc.ColumnName() ); 
 | 
      type.TextContent( /*ifexpr( tpc.ColumnDate().IsMinInfinity(), "String", "Number" )*/ "String" ); 
 | 
      column.AppendChild( name ); 
 | 
      column.AppendChild( type ); 
 | 
       
 | 
      traverse ( tprs, Elements, tpr ) { 
 | 
        c    := select( tpc, TransferPlanCell, tempTPC, tempTPC.TransferPlanRow() = tpr ); 
 | 
        cell := xmlDOM.CreateElement( "cell" ); 
 | 
        cell.SetAttribute( "value", guard( c.Value(), "" ) ); 
 | 
        column.AppendChild( cell ); 
 | 
      } 
 | 
      tableElement.AppendChild( column ); 
 | 
    } 
 | 
     
 | 
    xmlString := xmlDOMI.CreateSerializer().WriteToString( xmlDOM ) 
 | 
     
 | 
    //info( xmlString ); 
 | 
     
 | 
    tableGroupHandle := TableGroupHandle::Create( "Sheet1" ); 
 | 
    tableHandle      := TableHandle::ImportXML( BinaryValue::Construct( xmlString ) ); 
 | 
    tableGroupHandle.Add( tableHandle ); 
 | 
     
 | 
    binaryData := XLS::SaveTableGroupToBinaryData( tableGroupHandle, true ); 
 | 
     
 | 
    return binaryData.AsBinaryValue(); 
 | 
  *] 
 | 
} 
 |