You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@royale.apache.org by ha...@apache.org on 2018/03/20 21:00:24 UTC

[royale-asjs] 02/02: Added InfiniteVScroller

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

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

commit 46285885bda44629db86f66d0a930b31f7595653
Author: Harbs <ha...@in-tools.com>
AuthorDate: Tue Mar 20 23:00:10 2018 +0200

    Added InfiniteVScroller
---
 .../ListExample/src/main/royale/MyInitialView.mxml |   4 +
 .../Basic/src/main/resources/basic-manifest.xml    |   1 +
 .../apache/royale/html/beads/InfiniteVScroller.as  | 157 +++++++++++++++++++++
 3 files changed, 162 insertions(+)

diff --git a/examples/royale/ListExample/src/main/royale/MyInitialView.mxml b/examples/royale/ListExample/src/main/royale/MyInitialView.mxml
index 2019a00..0d3507f 100644
--- a/examples/royale/ListExample/src/main/royale/MyInitialView.mxml
+++ b/examples/royale/ListExample/src/main/royale/MyInitialView.mxml
@@ -62,6 +62,9 @@ limitations under the License.
 			{
 				(applicationModel as ProductsModel).productNames.addItemAt("Wing Bats", 2);
 			}
+			private function onScrollEnd():void{
+				trace("scroll end");
+			}
 		]]>
 	</fx:Script>
 	
@@ -91,6 +94,7 @@ limitations under the License.
 				sourceID="applicationModel"
 				sourcePropertyName="states"
 				destinationPropertyName="dataProvider" />
+			<js:InfiniteVScroller scrollEnd="onScrollEnd()"/>
 		</js:beads>
 	</js:List>
 	
diff --git a/frameworks/projects/Basic/src/main/resources/basic-manifest.xml b/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
index 3836d1d..6d00cc9 100644
--- a/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
+++ b/frameworks/projects/Basic/src/main/resources/basic-manifest.xml
@@ -150,6 +150,7 @@
     <component id="ClippingViewport" class="org.apache.royale.html.supportClasses.Viewport" lookupOnly="true" />
     <component id="Viewport" class="org.apache.royale.html.supportClasses.Viewport" />
     <component id="OverflowViewport" class="org.apache.royale.html.supportClasses.OverflowViewport" />
+    <component id="InfiniteVScroller" class="org.apache.royale.html.beads.InfiniteVScroller" />
 
     <component id="ArraySelectionModel" class="org.apache.royale.html.beads.models.ArraySelectionModel" />
     <component id="ArrayListSelectionModel" class="org.apache.royale.html.beads.models.ArrayListSelectionModel" />
diff --git a/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/InfiniteVScroller.as b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/InfiniteVScroller.as
new file mode 100644
index 0000000..58992c7
--- /dev/null
+++ b/frameworks/projects/Basic/src/main/royale/org/apache/royale/html/beads/InfiniteVScroller.as
@@ -0,0 +1,157 @@
+////////////////////////////////////////////////////////////////////////////////
+//
+//  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.IBead;
+	import org.apache.royale.core.IStrand;
+	import org.apache.royale.core.IUIBase;
+	import org.apache.royale.events.EventDispatcher;
+
+	/**
+	 * The scrollEnd event is dispatched scrolled to the bottom.
+	 *
+	 *  @langversion 3.0
+	 *  @playerversion Flash 10.2
+	 *  @playerversion AIR 2.6
+	 *  @productversion Royale 0.9.3
+	 */
+    [Event(name="scrollEnd", type="org.apache.royale.events.Event")]
+	
+	/**
+	 * InfiniteVScroller dispatches an event when the component scrolls
+	 * to the bottom to allow loading more content dynamically.
+	 * 
+	 *  @langversion 3.0
+	 *  @playerversion Flash 10.2
+	 *  @playerversion AIR 2.6
+	 *  @productversion Royale 0.9.3
+	 */
+	public class InfiniteVScroller extends EventDispatcher implements IBead
+	{
+		/**
+		 * Constructor.
+		 *
+		 *  @langversion 3.0
+		 *  @playerversion Flash 10.2
+		 *  @playerversion AIR 2.6
+		 *  @productversion Royale 0.9.3
+		 */
+		public function InfiniteVScroller()
+		{
+			super();
+		}
+		
+		protected var _strand:IStrand;
+		
+		/**
+		 * @royaleignorecoercion org.apache.royale.core.IUIBase
+		 */
+		private function get host():IUIBase
+		{
+			return _strand as IUIBase;
+		}
+		
+		private var _offset:Number = 0;
+
+		/**
+		 *  offset specifies how many pixels before the end to dispatch scrollEnd.
+		 * 
+		 *  @langversion 3.0
+		 *  @playerversion Flash 10.2
+		 *  @playerversion AIR 2.6
+		 *  @productversion Royale 0.9.3
+		 */
+		public function get offset():Number
+		{
+			return _offset;
+		}
+
+		public function set offset(value:Number):void
+		{
+			_offset = value;
+		}
+
+		private var _interval:int = 1000;
+
+		/**
+		 *  Minimum number of milliseconds between scrollEnd events.
+		 *  default 1000
+		 * 
+		 *  @langversion 3.0
+		 *  @playerversion Flash 10.2
+		 *  @playerversion AIR 2.6
+		 *  @productversion Royale 0.9.3
+		 */
+		public function get interval():int
+		{
+			return _interval;
+		}
+
+		public function set interval(value:int):void
+		{
+			_interval = value;
+		}
+
+		/**
+		 *  @copy org.apache.royale.core.IBead#strand
+		 *
+		 *  @langversion 3.0
+		 *  @playerversion Flash 10.2
+		 *  @playerversion AIR 2.6
+		 *  @productversion Royale 0.9.3
+		 */
+		public function set strand(value:IStrand):void
+		{
+			_strand = value;
+			COMPILE::JS
+			{
+				host.positioner.addEventListener("scroll", handleScroll);
+			}
+		}
+		COMPILE::JS
+		private var lastTime:int = 0;
+		
+		COMPILE::JS
+		private var lastTop:Number = 0;
+
+		COMPILE::JS
+		private function handleScroll(ev:Object):void
+		{
+			var elem:HTMLElement = host.positioner;
+			// only handle down scrolling
+			var top:Number = elem.scrollTop;
+			if(top < lastTop) //scrolling up
+			{
+				lastTop = top;
+				return;
+			}
+			lastTop = top;
+
+			if(elem.offsetHeight + top >= elem.scrollHeight - _offset)
+			{
+				var time:int = new Date().getTime();
+				if(time - lastTime < _interval)
+					return;
+				lastTime = time;
+				dispatchEvent(new Event("scrollEnd"));
+			}
+		}
+
+	}
+}

-- 
To stop receiving notification emails like this one, please contact
harbs@apache.org.