<?xml version="1.0" encoding="utf-8"?>
<mx:VBox xmlns:fx="http://ns.adobe.com/mxml/2009" 
         xmlns:s="library://ns.adobe.com/flex/spark" 
         xmlns:mx="library://ns.adobe.com/flex/mx" width="100%" height="100%" 
         xmlns:nestedtreedatagrid="com.flexicious.nestedtreedatagrid.*" xmlns:billing="com.flexicious.example.model.billing.*"
         xmlns:controls="com.flexicious.controls.*" xmlns:mate="http://mate.asfusion.com/" creationComplete="vbox1_creationCompleteHandler(event)">
    <fx:Script>
        <![CDATA[
            import com.flexicious.example.serviceproxies.BusinessService;
            import com.flexicious.example.utils.ExampleUtils;
            import com.flexicious.utils.UIUtils;
            
            import mx.events.FlexEvent;
            import mx.rpc.AsyncToken;
            import mx.rpc.events.ResultEvent;
            
            import pdf.AlivePdfGenerator;
            
            protected function vbox1_creationCompleteHandler(event:FlexEvent):void
            {
                BusinessService.getInstance().getDeepOrgList(function(evt:ResultEvent,token:AsyncToken):void{grid.dataProvider=evt.result})
            }
            
        ]]>
    </fx:Script>
    <fx:Declarations>
        <!-- Place non-visual elements (e.g., services, value objects) here -->
    </fx:Declarations>
    <nestedtreedatagrid:FlexDataGrid id="grid" width="100%" height="100%" enablePrint="true" 
                                     enablePreferencePersistence="true" enableDrillDown="true"
                                     enableExport="true" enableCopy="true"
                                     pdfBytesReady="new AlivePdfGenerator().generate(event.target as FlexDataGrid ,event.printOptions)"
                                     preferencePersistenceKey="levelRenderers">
        
        <nestedtreedatagrid:columnLevel >
            <nestedtreedatagrid:FlexDataGridColumnLevel enableFilters="true" enablePaging="true" 
                                                        pageSize="20" childrenField="deals" enableFooters="true" selectedKeyField="id"
                                                        footerDrawTopBorder="true">
                <nestedtreedatagrid:columns>
                    <nestedtreedatagrid:FlexDataGridCheckBoxColumn  />
                    <nestedtreedatagrid:FlexDataGridColumn enableCellClickRowSelect="false" columnWidthMode="fitToContent" 
                                                           selectable="true" dataField="id" headerText="ID" filterControl="TextInput"/>
                    <nestedtreedatagrid:FlexDataGridColumn truncateToFit="true" enableCellClickRowSelect="false" 
                                                           selectable="true" dataField="legalName" headerText="Legal Name" width="150" columnWidthMode="fixed"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="headquarterAddress.line1" headerText="Address Line 1" footerLabel="Count:" footerOperation="count"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="headquarterAddress.line2" headerText="Address Line 2"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="headquarterAddress.city.name" headerText="City" filterControl="MultiSelectComboBox" filterComboBoxBuildFromGrid="true" filterComboBoxWidth="150"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="headquarterAddress.state.name" headerText="State" filterControl="MultiSelectComboBox" filterComboBoxBuildFromGrid="true" filterComboBoxWidth="150"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="headquarterAddress.country.name" headerText="Country" filterControl="MultiSelectComboBox" filterComboBoxBuildFromGrid="true" filterComboBoxWidth="150"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="annualRevenue" headerText="Annual Revenue" columnWidthMode="fitToContent" 
                                                           textAlign="right" headerAlign="center" footerLabel="Avg:" footerOperation="average" footerAlign="center" columnWidthModeFitToContentExcludeHeader="true"
                                                           footerOperationPrecision="2" footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="numEmployees" headerText="Num Employees" columnWidthMode="fitToContent" columnWidthModeFitToContentExcludeHeader="true"
                                                           textAlign="right" footerLabel="Avg:" footerOperation="average" footerOperationPrecision="2" 
                                                           footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="earningsPerShare" headerText="EPS" columnWidthMode="fitToContent" columnWidthModeFitToContentExcludeHeader="true"
                                                           textAlign="right" footerLabel="Avg:" footerOperation="average" footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                    <nestedtreedatagrid:FlexDataGridColumn dataField="lastStockPrice" headerText="Stock Price" columnWidthMode="fitToContent" columnWidthModeFitToContentExcludeHeader="true"
                                                           textAlign="right" footerLabel="Avg:" footerOperation="average" footerOperationPrecision="2" 
                                                           footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                </nestedtreedatagrid:columns>
                <nestedtreedatagrid:nextLevel>
                    <nestedtreedatagrid:FlexDataGridColumnLevel childrenField="invoices" enableFooters="true" selectedKeyField="id">
                        <nestedtreedatagrid:columns>
                            <nestedtreedatagrid:FlexDataGridCheckBoxColumn />
                            <nestedtreedatagrid:FlexDataGridColumn editable="true" dataField="dealDescription" headerText="Deal Description" 
                                                                   footerLabel="Count:" footerOperation="count" footerAlign="center"
                                                                   />
                            <nestedtreedatagrid:FlexDataGridColumn editable="true" dataField="dealAmount" headerText="Deal Amount" textAlign="right" 
                                                                   footerLabel="Total:" footerOperation="sum" footerAlign="right"
                                                                   footerOperationPrecision="2" footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                            <nestedtreedatagrid:FlexDataGridColumn dataField="dealDate" headerText="Deal Date" labelFunction="UIUtils.dataGridFormatDateLabelFunction"/>
                        </nestedtreedatagrid:columns>
                        <nestedtreedatagrid:nextLevel>
                            <nestedtreedatagrid:FlexDataGridColumnLevel childrenField="lineItems" enableFooters="true" enablePaging="true" pageSize="5"
                                                                        selectedKeyField="id" rendererDrawTopBorder="true"> 
                                <nestedtreedatagrid:columns>
                                    <nestedtreedatagrid:FlexDataGridCheckBoxColumn />
                                    <nestedtreedatagrid:FlexDataGridColumn editable="true" dataField="id" headerText="Invoice Number" 
                                                                           footerLabel="Count:" footerOperation="count" footerAlign="center" 
                                                                           />
                                    <nestedtreedatagrid:FlexDataGridColumn editable="true" dataField="invoiceAmount" headerText="Invoice Amount" textAlign="right" 
                                                                           footerLabel="Total:" footerOperation="sum" footerAlign="right"
                                                                           footerOperationPrecision="2" footerFormatter="{ExampleUtils.globalCurrencyFormatter}" labelFunction="UIUtils.dataGridFormatCurrencyLabelFunction"/>
                                    <nestedtreedatagrid:FlexDataGridColumn editable="true" dataField="invoiceStatus.name" headerText="Invoice Status" />
                                    
                                    <nestedtreedatagrid:FlexDataGridColumn dataField="invoiceDate" headerText="Invoice Date" 
                                                                           labelFunction="UIUtils.dataGridFormatDateLabelFunction"/>
                                    <nestedtreedatagrid:FlexDataGridColumn dataField="dueDate" headerText="Due Date" 
                                                                           labelFunction="UIUtils.dataGridFormatDateLabelFunction"/>
                                </nestedtreedatagrid:columns>
                                <nestedtreedatagrid:nextLevelRenderer>
                                    <fx:Component>
                                        <mx:HBox horizontalScrollPolicy="off" verticalScrollPolicy="off" 
                                                 width="100%" height="75" verticalGap="0" horizontalGap="0"
                                                 paddingTop="0" paddingBottom="0" paddingLeft="0" paddingRight="0">
                                            <fx:Script>
                                                <![CDATA[
                                                    import com.flexicious.example.model.billing.Invoice;
                                                    import com.flexicious.utils.UIUtils;
                                                    [Bindable(private var invoice:Invoice;
                                                    
                                                    public override function set data(val:Object):void{
                                                        super.data=val;
                                                        invoice = data as Invoice;
                                                        
                                                    }
                                                ]]>
                                            </fx:Script>
                                            <mx:Form width="33%" verticalGap="0" horizontalGap="0" 
                                                     paddingTop="0" paddingBottom="0" paddingLeft="0" paddingRight="0">
                                                <mx:FormItem label="Invoice Number">
                                                    <mx:Label text="{invoice.invoiceNumber}"/>
                                                </mx:FormItem>    
                                                <mx:FormItem label="Invoice Date">
                                                    <mx:Label text="{UIUtils.formatDate(invoice.invoiceDate)}"/>
                                                </mx:FormItem>    
                                                <mx:FormItem label="Due Date">
                                                    <mx:Label text="{UIUtils.formatDate(invoice.dueDate)}"/>
                                                </mx:FormItem>    
                                            </mx:Form>
                                            <mx:Form width="33%" verticalGap="0" horizontalGap="0" 
                                                     paddingTop="0" paddingBottom="0" paddingLeft="0" paddingRight="0">
                                                <mx:FormItem label="Deal Description:">
                                                    <mx:Label text="{invoice.deal.dealDescription}"/>
                                                </mx:FormItem>    
                                                <mx:FormItem label="Deal Amount:">
                                                    <mx:Label text="{UIUtils.formatCurrency(invoice.deal.dealAmount)}"/>
                                                </mx:FormItem>    
                                                <mx:FormItem label="Deal Status:">
                                                    <mx:Label text="{invoice.deal.dealStatus.name}"/>
                                                </mx:FormItem>    
                                            </mx:Form>
                                            <mx:Form width="33%" verticalGap="0" horizontalGap="0" 
                                                     paddingTop="0" paddingBottom="0" paddingLeft="0" paddingRight="0">
                                                <mx:FormItem label="Client Name:">
                                                    <mx:Label text="{invoice.deal.customer.legalName}"/>
                                                </mx:FormItem>    
                                                <mx:FormItem label="Relationship Amount:">
                                                    <mx:Label text="{UIUtils.formatCurrency(invoice.deal.customer.relationshipAmount)}"/>
                                                </mx:FormItem>    
                                            </mx:Form>
                                        </mx:HBox>                                            
                                    </fx:Component>
                                </nestedtreedatagrid:nextLevelRenderer>
                            </nestedtreedatagrid:FlexDataGridColumnLevel>
                        </nestedtreedatagrid:nextLevel>
                    </nestedtreedatagrid:FlexDataGridColumnLevel>
                </nestedtreedatagrid:nextLevel>
        </nestedtreedatagrid:FlexDataGridColumnLevel>
    </nestedtreedatagrid:columnLevel>
    </nestedtreedatagrid:FlexDataGrid>
</mx:VBox >