This is an automated email from the ASF dual-hosted git repository.

yishayw pushed a commit to branch develop
in repository https://gitbox.apache.org/repos/asf/royale-asjs.git


The following commit(s) were added to refs/heads/develop by this push:
     new 16ada08  Emulation - make sure headerRenderers are not ignored
16ada08 is described below

commit 16ada087c82ee0081bcb1217a234e095285e69f5
Author: Yishay Weiss <[email protected]>
AuthorDate: Tue Feb 15 14:34:28 2022 +0200

    Emulation - make sure headerRenderers are not ignored
---
 .../MXRoyale/src/main/resources/defaults.css       |   1 +
 .../src/main/resources/mx-royale-manifest.xml      |   3 +-
 .../controls/beads/layouts/DataGridHeaderLayout.as |   2 -
 .../HeaderRendererFactoryForArrayData.as           | 204 +++++++++++++++++++++
 4 files changed, 207 insertions(+), 3 deletions(-)

diff --git a/frameworks/projects/MXRoyale/src/main/resources/defaults.css 
b/frameworks/projects/MXRoyale/src/main/resources/defaults.css
index 24d52a5..b3f7665 100644
--- a/frameworks/projects/MXRoyale/src/main/resources/defaults.css
+++ b/frameworks/projects/MXRoyale/src/main/resources/defaults.css
@@ -82,6 +82,7 @@ Basic|DataGridColumnList {
 
 dg|DataGridButtonBar {
        IItemRenderer: 
ClassReference("mx.controls.dataGridClasses.DataGridHeaderRenderer");
+       IDataProviderItemRendererMapper: 
ClassReference("mx.controls.dataGridClasses.HeaderRendererFactoryForArrayData");
        position: absolute;
 }
 
diff --git 
a/frameworks/projects/MXRoyale/src/main/resources/mx-royale-manifest.xml 
b/frameworks/projects/MXRoyale/src/main/resources/mx-royale-manifest.xml
index 3cb6244..09c5ba5 100644
--- a/frameworks/projects/MXRoyale/src/main/resources/mx-royale-manifest.xml
+++ b/frameworks/projects/MXRoyale/src/main/resources/mx-royale-manifest.xml
@@ -234,6 +234,7 @@
    <!--<component id="ZipCodeValidator" 
class="mx.validators.ZipCodeValidator"/>-->
    <component id="PrintDataGrid" class="mx.printing.PrintDataGrid"/>
     <component id="HTML" class="mx.controls.HTML"/>
-   
+    <component id="HeaderRendererFactoryForArrayData" 
class="mx.controls.dataGridClasses.HeaderRendererFactoryForArrayData"/>
+    <component id="DataGridHeaderRenderer" 
class="mx.controls.dataGridClasses.DataGridHeaderRenderer"/>
 
 </componentPackage>
diff --git 
a/frameworks/projects/MXRoyale/src/main/royale/mx/controls/beads/layouts/DataGridHeaderLayout.as
 
b/frameworks/projects/MXRoyale/src/main/royale/mx/controls/beads/layouts/DataGridHeaderLayout.as
index 8c95b90..58d848f 100644
--- 
a/frameworks/projects/MXRoyale/src/main/royale/mx/controls/beads/layouts/DataGridHeaderLayout.as
+++ 
b/frameworks/projects/MXRoyale/src/main/royale/mx/controls/beads/layouts/DataGridHeaderLayout.as
@@ -19,7 +19,6 @@
 
 package mx.controls.beads.layouts
 {
-    import mx.controls.dataGridClasses.DataGridHeaderRenderer;
        import mx.core.EdgeMetrics;
        import mx.core.UIComponent;
        
@@ -148,7 +147,6 @@ public class DataGridHeaderLayout extends LayoutBase
         {      
             var ilc:ILayoutChild = contentView.getElementAt(i) as ILayoutChild;
             if (ilc == null || !ilc.visible) continue;
-            if (!(ilc is DataGridHeaderRenderer)) continue;
             
             COMPILE::SWF {
                 if (buttonWidths) {
diff --git 
a/frameworks/projects/MXRoyale/src/main/royale/mx/controls/dataGridClasses/HeaderRendererFactoryForArrayData.as
 
b/frameworks/projects/MXRoyale/src/main/royale/mx/controls/dataGridClasses/HeaderRendererFactoryForArrayData.as
new file mode 100644
index 0000000..a9cda3e
--- /dev/null
+++ 
b/frameworks/projects/MXRoyale/src/main/royale/mx/controls/dataGridClasses/HeaderRendererFactoryForArrayData.as
@@ -0,0 +1,204 @@
+////////////////////////////////////////////////////////////////////////////////
+//
+//  Licensed to the Apache Software Foundation (ASF) under one or more
+//  contributor license agreements.  See the NOTICE file distributed with
+//  this work for additional information regarding copyright ownership.
+//  The ASF licenses this file to You under the Apache License, Version 2.0
+//  (the "License"); you may not use this file except in compliance with
+//  the License.  You may obtain a copy of the License at
+//
+//      http://www.apache.org/licenses/LICENSE-2.0
+//
+//  Unless required by applicable law or agreed to in writing, software
+//  distributed under the License is distributed on an "AS IS" BASIS,
+//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+//  See the License for the specific language governing permissions and
+//  limitations under the License.
+//
+////////////////////////////////////////////////////////////////////////////////
+package mx.controls.dataGridClasses
+{
+       import org.apache.royale.core.IBead;
+       import org.apache.royale.core.IDataProviderItemRendererMapper;
+       import org.apache.royale.core.IItemRendererClassFactory;
+       import org.apache.royale.core.IItemRendererOwnerView;
+       import org.apache.royale.core.ISelectionModel;
+       import org.apache.royale.core.IStrand;
+       import org.apache.royale.core.IStrandWithModelView;
+       import org.apache.royale.core.ValuesManager;
+       import org.apache.royale.events.Event;
+       import org.apache.royale.events.EventDispatcher;
+       import org.apache.royale.events.ItemRendererEvent;
+       import org.apache.royale.events.IEventDispatcher;
+       import org.apache.royale.html.beads.IListView;
+       import org.apache.royale.utils.loadBeadFromValuesManager;
+       import org.apache.royale.core.DispatcherBead;
+       import org.apache.royale.utils.sendStrandEvent;
+       import org.apache.royale.core.ILabelFieldItemRenderer;
+       import org.apache.royale.core.IIndexedItemRenderer;
+       import org.apache.royale.html.util.getModelByType;
+       import org.apache.royale.core.IChild;
+       import mx.controls.DataGrid;
+       import mx.controls.dataGridClasses.DataGridColumn;
+       import mx.core.IFactory;
+       import mx.core.UIComponent;
+
+       
[Event(name="itemRendererCreated",type="org.apache.royale.events.ItemRendererEvent")]
+
+       /**
+        *  The TextItemRendererFactoryForArrayData class is the
+        *  IDataProviderItemRendererMapper for creating
+        *  ITextItemRenderers and assigning them data from an array.
+        *  Other IDataProviderItemRendererMapper implementations
+        *  assign specific array or vector types to item
+        *  renderers expecting those types.
+        *
+        *  @langversion 3.0
+        *  @playerversion Flash 10.2
+        *  @playerversion AIR 2.6
+        *  @productversion Royale 0.9.9
+        */
+       public class HeaderRendererFactoryForArrayData extends DispatcherBead 
implements IDataProviderItemRendererMapper
+       {
+               /**
+                *  Constructor.
+                *
+                *  @langversion 3.0
+                *  @playerversion Flash 10.2
+                *  @playerversion AIR 2.6
+                *  @productversion Royale 0.9.9
+                */
+               public function 
HeaderRendererFactoryForArrayData(target:Object=null)
+               {
+                       super(target);
+               }
+
+               private var selectionModel:ISelectionModel;
+
+               /**
+                *  @copy org.apache.royale.core.IBead#strand
+                *
+                *  @langversion 3.0
+                *  @playerversion Flash 10.2
+                *  @playerversion AIR 2.6
+                *  @productversion Royale 0.9.9
+                *  @royaleignorecoercion 
org.apache.royale.events.IEventDispatcher
+                */
+               override public function set strand(value:IStrand):void
+               {
+                       _strand = value;
+                       listenOnStrand("initComplete",finishSetup);
+               }
+
+               /**
+                * @royaleignorecoercion 
org.apache.royale.core.IItemRendererClassFactory
+                * @royaleignorecoercion org.apache.royale.core.ISelectionModel
+                */
+               private function finishSetup(event:Event):void
+               {
+                       selectionModel = 
getModelByType(_strand,ISelectionModel) as ISelectionModel;
+                       selectionModel.addEventListener("dataProviderChanged", 
dataProviderChangeHandler);
+
+                       // if the host component inherits from 
DataContainerBase, the itemRendererClassFactory will
+                       // already have been loaded by 
DataContainerBase.addedToParent function.
+                       if (!itemRendererFactory)
+                       {
+                               _itemRendererFactory = 
loadBeadFromValuesManager(IItemRendererClassFactory, 
"iItemRendererClassFactory", _strand) as IItemRendererClassFactory;
+                       }
+
+                       dataProviderChangeHandler(null);
+               }
+
+               private var _itemRendererFactory:IItemRendererClassFactory;
+
+               /**
+                *  An IItemRendererClassFactory that should generate 
ITextItemRenderers
+                *
+                *  @langversion 3.0
+                *  @playerversion Flash 10.2
+                *  @playerversion AIR 2.6
+                *  @productversion Royale 0.9.9
+                *  @royaleignorecoercion 
org.apache.royale.core.IItemRendererClassFactory
+                */
+               public function get 
itemRendererFactory():IItemRendererClassFactory
+               {
+                       if(!_itemRendererFactory)
+                               _itemRendererFactory = 
loadBeadFromValuesManager(IItemRendererClassFactory, 
"iItemRendererClassFactory", _strand) as IItemRendererClassFactory;
+                       
+                       return _itemRendererFactory
+               }
+
+               /**
+                *  @private
+                */
+               public function set 
itemRendererFactory(value:IItemRendererClassFactory):void
+               {
+                       _itemRendererFactory = value;
+               }
+
+               /**
+                *  The IItemRendererOwnerView that should parent the 
ITextItemRenderers
+                *
+                *  @langversion 3.0
+                *  @playerversion Flash 10.2
+                *  @playerversion AIR 2.6
+                *  @productversion Royale 0.9.9
+                *  @royaleignorecoercion Array
+                *  @royaleignorecoercion 
org.apache.royale.core.ILabelFieldItemRenderer
+                *  @royaleignorecoercion 
org.apache.royale.events.IEventDispatcher
+                *  @royaleignorecoercion 
org.apache.royale.core.IStrandWithModelView
+                *  @royaleignorecoercion org.apache.royale.html.beads.IListView
+                *  @royaleignorecoercion 
org.apache.royale.core.IIndexedItemRenderer
+                */
+               protected function dataProviderChangeHandler(event:Event):void
+               {
+                       var dp:Array = selectionModel.dataProvider as Array;
+                       if (!dp)
+                               return;
+
+                       var view:IListView = (_strand as 
IStrandWithModelView).view as IListView;
+                       var dataGroup:IItemRendererOwnerView = view.dataGroup;
+
+                       dataGroup.removeAllItemRenderers();
+
+                       var n:int = dp.length;
+                       for (var i:int = 0; i < n; i++)
+                       {
+
+                               var ir:IIndexedItemRenderer = null;
+                               var owner:DataGrid = ((_strand as 
IChild).parent as DataGrid);
+                               var columns:Array = owner.columns;
+                               if (columns)
+                               {
+                                       var headFactory:IFactory =  (columns[i] 
as DataGridColumn).headerRenderer;
+                                       if (headFactory)
+                                       {
+                                               ir = headFactory.newInstance() 
as IIndexedItemRenderer;
+                                               if (ir is UIComponent)
+                                               {
+                                                       (ir as 
UIComponent).owner = owner;
+                                               }
+                                       }
+                               }
+                               if (!ir)
+                               {
+                                       ir = 
itemRendererFactory.createItemRenderer() as IIndexedItemRenderer;
+                               }
+                               var tf:ILabelFieldItemRenderer = ir as 
ILabelFieldItemRenderer;
+                               ir.index = i;
+                               dataGroup.addItemRenderer(ir, false);
+                               if (tf && selectionModel.labelField) {
+                                       tf.labelField = 
selectionModel.labelField;
+                               }
+                               ir.data = dp[i];
+
+                               var newEvent:ItemRendererEvent = new 
ItemRendererEvent(ItemRendererEvent.CREATED);
+                               newEvent.itemRenderer = ir;
+                               dispatchEvent(newEvent);
+                       }
+
+                       sendStrandEvent(_strand,"itemsCreated");
+               }
+
+       }
+}

Reply via email to