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

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


The following commit(s) were added to refs/heads/color_picker by this push:
     new d65b3ac  Added ColorPicker as a combobox derivative.
d65b3ac is described below

commit d65b3ac39e26d57128231f17d4618434c22171d1
Author: DESKTOP-RH4S838\Yishay <[email protected]>
AuthorDate: Tue Mar 12 15:46:59 2019 +0200

    Added ColorPicker as a combobox derivative.
---
 .../Basic/src/main/resources/basic-manifest.xml    |  3 +-
 .../projects/Basic/src/main/resources/defaults.css |  8 +++
 .../projects/Basic/src/main/royale/BasicClasses.as |  1 +
 .../royale/html/{SwatchList.as => ColorPicker.as}  | 14 ++--
 .../apache/royale/html/beads/ColorPickerView.as    | 78 ++++++++++++++++++++++
 .../royale/html/{ => supportClasses}/SwatchList.as |  7 +-
 6 files changed, 102 insertions(+), 9 deletions(-)

diff --git a/frameworks/projects/Basic/src/main/resources/basic-manifest.xml 
b/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
index 1a0775a..0f80e7a 100644
--- a/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
+++ b/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
@@ -48,7 +48,8 @@
     <component id="DynamicList" class="org.apache.royale.html.DynamicList"/>
     <component id="PopUpList" class="org.apache.royale.html.PopUpList"/>
     <component id="SimpleList" class="org.apache.royale.html.SimpleList"/>
-    <component id="SwatchList" class="org.apache.royale.html.SwatchList"/>
+    <component id="SwatchList" 
class="org.apache.royale.html.supportClasses.SwatchList"/>
+    <component id="ColorPicker" class="org.apache.royale.html.ColorPicker"/>
     <component id="CheckBox" class="org.apache.royale.html.CheckBox"/>
     <component id="CSSCheckBox" class="org.apache.royale.html.CSSCheckBox"/>
     <component id="RadioButton" class="org.apache.royale.html.RadioButton"/>
diff --git a/frameworks/projects/Basic/src/main/resources/defaults.css 
b/frameworks/projects/Basic/src/main/resources/defaults.css
index 875f0c6..eb74391 100644
--- a/frameworks/projects/Basic/src/main/resources/defaults.css
+++ b/frameworks/projects/Basic/src/main/resources/defaults.css
@@ -59,6 +59,14 @@ ButtonBar
        border-style: none;
 }
 
+ColorPicker
+{
+       IBeadModel: 
ClassReference("org.apache.royale.html.beads.models.ComboBoxModel");
+       IBeadView: 
ClassReference("org.apache.royale.html.beads.ColorPickerView");
+       IBeadController: 
ClassReference("org.apache.royale.html.beads.controllers.ComboBoxController");
+       IPopUp: 
ClassReference("org.apache.royale.html.supportClasses.SwatchList");
+}
+
 ComboBox
 {
        IBeadModel: 
ClassReference("org.apache.royale.html.beads.models.ComboBoxModel");
diff --git a/frameworks/projects/Basic/src/main/royale/BasicClasses.as 
b/frameworks/projects/Basic/src/main/royale/BasicClasses.as
index beabf2e..c1871f8 100644
--- a/frameworks/projects/Basic/src/main/royale/BasicClasses.as
+++ b/frameworks/projects/Basic/src/main/royale/BasicClasses.as
@@ -81,6 +81,7 @@ internal class BasicClasses
                import org.apache.royale.html.beads.CheckBoxView; CheckBoxView;
        }
     import org.apache.royale.html.beads.ComboBoxView; ComboBoxView;
+    import org.apache.royale.html.beads.ColorPickerView; ColorPickerView;
     import org.apache.royale.html.MXMLBeadView; MXMLBeadView;
     import org.apache.royale.html.beads.GroupView; GroupView;
        import org.apache.royale.html.beads.ContainerView; ContainerView;
diff --git 
a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/ColorPicker.as
similarity index 80%
copy from 
frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
copy to 
frameworks/projects/Basic/src/main/royale/org/apache/royale/html/ColorPicker.as
index 50c9d2a..e9aa511 100644
--- 
a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
+++ 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/ColorPicker.as
@@ -18,30 +18,30 @@
 
////////////////////////////////////////////////////////////////////////////////
 package org.apache.royale.html
 {
-
        /**
-        *  The SwatchList class is use in a ColorPicker. It contains a list of 
predefined colors.
+        *  The ColorPicker class is a component that displays an input field 
and
+        *  pop-up List with some optional controls, such as a swatch and a 
color gradient.
         * 
-        *
-     *  @toplevel
         *  @langversion 3.0
         *  @playerversion Flash 10.2
         *  @playerversion AIR 2.6
         *  @productversion Royale 0.9.6
         */
-       public class SwatchList extends List
+       public class ColorPicker extends ComboBox
        {
                /**
-                *  constructor.
+                *  Constructor.
                 *
                 *  @langversion 3.0
                 *  @playerversion Flash 10.2
                 *  @playerversion AIR 2.6
                 *  @productversion Royale 0.9.6
                 */
-               public function SwatchList()
+               public function ColorPicker()
                {
                        super();
+            
+            typeNames = "ColorPicker";
                }
        }
 }
diff --git 
a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/ColorPickerView.as
 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/ColorPickerView.as
new file mode 100644
index 0000000..eac6c12
--- /dev/null
+++ 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/ColorPickerView.as
@@ -0,0 +1,78 @@
+////////////////////////////////////////////////////////////////////////////////
+//
+//  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 org.apache.royale.html.beads
+{
+       import org.apache.royale.core.IComboBoxModel;
+       import org.apache.royale.core.IPopUpHost;
+       import org.apache.royale.core.IUIBase;
+       import org.apache.royale.core.UIBase;
+       import org.apache.royale.geom.Point;
+       import org.apache.royale.utils.PointUtils;
+       import org.apache.royale.utils.UIUtils;
+       
+       /**
+        *  The ColorPickerView class creates the visual elements of the 
org.apache.royale.html.ColorPicker
+        *  component. The job of the view bead is to put together the parts of 
the ColorPicler such as the TextInput
+        *  control and org.apache.royale.html.Button to trigger the pop-up.
+        *  
+        *  @viewbead
+        *  @langversion 3.0
+        *  @playerversion Flash 10.2
+        *  @playerversion AIR 2.6
+        *  @productversion Royale 0.9.6
+        */
+       public class ColorPickerView extends ComboBoxView
+       {
+               public function ColorPickerView()
+               {
+                       super();
+               }
+               
+               /**
+                * @royaleignorecoercion org.apache.royale.core.IComboBoxModel
+                * @royaleignorecoercion org.apache.royale.core.IUIBase
+                */
+               override public function set popUpVisible(value:Boolean):void
+               {
+                       var list:UIBase = popUp as UIBase;
+                       var button:UIBase = popupButton as UIBase;
+                       if (value && !list.visible) {
+                               var model:IComboBoxModel = 
_strand.getBeadByType(IComboBoxModel) as IComboBoxModel;
+                               list.model = model;
+                               list.visible = true;
+                               
+                               var origin:Point = new Point(0, 
button.y+button.height);
+                               var relocated:Point = 
PointUtils.localToGlobal(origin,_strand);
+                               list.x = relocated.x
+                               list.y = relocated.y;
+                               COMPILE::JS {
+                                       list.element.style.position = 
"absolute";
+                               }
+                               
+                               var popupHost:IPopUpHost = 
UIUtils.findPopUpHost(_strand as IUIBase);
+                               popupHost.popUpParent.addElement(list);
+                       }
+
+                       else if (list.visible) {
+                               UIUtils.removePopUp(list);
+                               list.visible = false;
+                       }
+               }
+       }
+}
diff --git 
a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/supportClasses/SwatchList.as
similarity index 92%
rename from 
frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
rename to 
frameworks/projects/Basic/src/main/royale/org/apache/royale/html/supportClasses/SwatchList.as
index 50c9d2a..faab9d5 100644
--- 
a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/SwatchList.as
+++ 
b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/supportClasses/SwatchList.as
@@ -16,8 +16,9 @@
 //  limitations under the License.
 //
 
////////////////////////////////////////////////////////////////////////////////
-package org.apache.royale.html
+package org.apache.royale.html.supportClasses
 {
+       import org.apache.royale.html.List;
 
        /**
         *  The SwatchList class is use in a ColorPicker. It contains a list of 
predefined colors.
@@ -42,6 +43,10 @@ package org.apache.royale.html
                public function SwatchList()
                {
                        super();
+                       if (!width)
+                       {
+                               width = 300;
+                       }
                }
        }
 }

Reply via email to