From e306ac72fc0cc09ed3563d883fcc5bd3ff98dfdf Mon Sep 17 00:00:00 2001
From: Aleksander Machniak <alec@alec.pl>
Date: Tue, 24 Jun 2014 06:03:53 -0400
Subject: [PATCH] Merge branch 'master' of github.com:roundcube/roundcubemail

---
 program/js/treelist.js |   10 +++++++---
 1 files changed, 7 insertions(+), 3 deletions(-)

diff --git a/program/js/treelist.js b/program/js/treelist.js
index 631a81a..052d77b 100644
--- a/program/js/treelist.js
+++ b/program/js/treelist.js
@@ -339,18 +339,22 @@
       if (updates.id || updates.html || updates.children || updates.classes || updates.parent) {
         if (updates.parent && (parent_node = indexbyid[updates.parent])) {
           // remove reference from old parent's child list
-          if (old_parent = indexbyid[dom2id(parent_ul.closest('li'))]) {
+          if (parent_ul.closest('li').length && (old_parent = indexbyid[dom2id(parent_ul.closest('li'))])) {
             old_parent.children = $.grep(old_parent.children, function(elem, i){ return elem.id != node.id; });
           }
+
           // append to new parent node
           parent_ul = id2dom(updates.parent).children('ul').first();
           if (!parent_node.children)
             parent_node.children = [];
           parent_node.children.push(node);
         }
+        else if (updates.parent !== undefined) {
+          parent_ul = container;
+        }
 
         $.extend(node, updates);
-        render_node(node, parent_ul, li);
+        li = render_node(node, parent_ul, li);
       }
 
       if (node.id != id) {
@@ -677,7 +681,7 @@
    */
   function dom2id(li)
   {
-    var domid = li.attr('id').replace(new RegExp('^' + (p.id_prefix) || '%'), '').replace(/--xsR$/, '');
+    var domid = String(li.attr('id')).replace(new RegExp('^' + (p.id_prefix) || '%'), '').replace(/--xsR$/, '');
     return p.id_decode ? p.id_decode(domid) : domid;
   }
 

--
Gitblit v1.9.1