Upgrade to ExtJS 3.1.0 - Released 12/16/2009
[extjs.git] / src / core / Element.insertion-more.js
index ffe1d48..61ca695 100644 (file)
@@ -1,5 +1,5 @@
 /*!
- * Ext JS Library 3.0.3
+ * Ext JS Library 3.1.0
  * Copyright(c) 2006-2009 Ext JS, LLC
  * licensing@extjs.com
  * http://www.extjs.com/license
@@ -18,32 +18,37 @@ Ext.apply(Ext.Element.prototype, function() {
             * @param {Mixed/Object/Array} el The id, element to insert or a DomHelper config to create and insert *or* an array of any of those.\r
             * @param {String} where (optional) 'before' or 'after' defaults to before\r
             * @param {Boolean} returnDom (optional) True to return the raw DOM element instead of Ext.Element\r
-            * @return {Ext.Element} the inserted Element\r
+            * @return {Ext.Element} The inserted Element. If an array is passed, the last inserted element is returned.\r
             */\r
            insertSibling: function(el, where, returnDom){\r
                var me = this,\r
-                       rt;\r
+                       rt,\r
+                isAfter = (where || 'before').toLowerCase() == 'after',\r
+                insertEl;\r
                        \r
-               if(Ext.isArray(el)){            \r
+               if(Ext.isArray(el)){\r
+                insertEl = me;\r
                    Ext.each(el, function(e) {\r
-                           rt = me.insertSibling(e, where, returnDom);\r
+                           rt = Ext.fly(insertEl, '_internal').insertSibling(e, where, returnDom);\r
+                    if(isAfter){\r
+                        insertEl = rt;\r
+                    }\r
                    });\r
                    return rt;\r
                }\r
                        \r
-               where = (where || 'before').toLowerCase();\r
                el = el || {};\r
                \r
             if(el.nodeType || el.dom){\r
-                rt = me.dom.parentNode.insertBefore(GETDOM(el), where == 'before' ? me.dom : me.dom.nextSibling);\r
+                rt = me.dom.parentNode.insertBefore(GETDOM(el), isAfter ? me.dom.nextSibling : me.dom);\r
                 if (!returnDom) {\r
                     rt = GET(rt);\r
                 }\r
             }else{\r
-                if (where == 'after' && !me.dom.nextSibling) {\r
+                if (isAfter && !me.dom.nextSibling) {\r
                     rt = DH.append(me.dom.parentNode, el, !returnDom);\r
                 } else {                    \r
-                    rt = DH[where == 'after' ? 'insertAfter' : 'insertBefore'](me.dom, el, !returnDom);\r
+                    rt = DH[isAfter ? 'insertAfter' : 'insertBefore'](me.dom, el, !returnDom);\r
                 }\r
             }\r
                return rt;\r