Bug 525184: put mobile bookmarks in a virtual "Mobile" bookmarks root, r=mfinkle
authorGavin Sharp <gavin@gavinsharp.com>
Mon, 09 Nov 2009 10:01:21 -0500
changeset 65767 9738750b35f967e71e3e3fcb6dd57f155c382ca3
parent 65766 0161db35078d65ba5f73544431d47b95a63f991c
child 65768 b909a2459add4b1db332cd16892004c9d424ee57
push id1
push userroot
push dateTue, 26 Apr 2011 22:38:44 +0000
treeherdermozilla-beta@bfdb6e623a36 [default view] [failures only]
perfherder[talos] [build metrics] [platform microbench] (compared to previous push)
reviewersmfinkle
bugs525184
Bug 525184: put mobile bookmarks in a virtual "Mobile" bookmarks root, r=mfinkle
mobile/chrome/content/bindings.xml
mobile/chrome/content/browser-ui.js
mobile/chrome/tests/browser_bookmarks.js
mobile/chrome/tests/browser_bookmarks_folders.js
mobile/chrome/tests/browser_bookmarks_star.js
mobile/chrome/tests/browser_bookmarks_tags.js
mobile/locales/generic/profile/bookmarks.json.in
--- a/mobile/chrome/content/bindings.xml
+++ b/mobile/chrome/content/bindings.xml
@@ -667,21 +667,25 @@
       <field name="_children">
         document.getAnonymousElementByAttribute(this, "anonid", "child-items");
       </field>
 
       <property name="scrollBoxObject" readonly="true" onget="return this._children.scrollBoxObject;"/>
 
       <property name="items" readonly="true" onget="return this._children.childNodes"/>
 
+      <field name="mobileRoot"><![CDATA[
+        PlacesUtils.annotations.getItemsWithAnnotation("mobile/bookmarksRoot", {})[0];
+      ]]></field>
+
       <property name="isRootFolder" readonly="true">
         <getter>
           <![CDATA[
             let currentFolderId = this._parents.lastChild.getAttribute("itemid");
-            return currentFolderId == PlacesUtils.bookmarks.unfiledBookmarksFolder;
+            return currentFolderId == this.mobileRoot;
           ]]>
         </getter>
       </property>
 
       <property name="activeItem">
         <getter>
           <![CDATA[
             return this._activeItem;
@@ -760,17 +764,17 @@
           ]]>
         </body>
       </method>
 
       <method name="openFolder">
         <parameter name="aRootFolder"/>
         <body>
           <![CDATA[
-            aRootFolder = aRootFolder || PlacesUtils.bookmarks.unfiledBookmarksFolder;
+            aRootFolder = aRootFolder || this.mobileRoot;
 
             this._activeItem = null;
 
             let parents = this._parents;
             while (parents.firstChild)
               parents.removeChild(parents.firstChild);
 
             const XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
--- a/mobile/chrome/content/browser-ui.js
+++ b/mobile/chrome/content/browser-ui.js
@@ -716,17 +716,20 @@ var BrowserUI = {
       case "cmd_star":
       {
         var bookmarkURI = browser.currentURI;
         var bookmarkTitle = browser.contentDocument.title || bookmarkURI.spec;
 
         let autoClose = false;
 
         if (PlacesUtils.getMostRecentBookmarkForURI(bookmarkURI) == -1) {
-          var bookmarkId = PlacesUtils.bookmarks.insertBookmark(PlacesUtils.bookmarks.unfiledBookmarksFolder, bookmarkURI, PlacesUtils.bookmarks.DEFAULT_INDEX, bookmarkTitle);
+          let bmsvc = PlacesUtils.bookmarks;
+          let bookmarkId = bmsvc.insertBookmark(BookmarkList.mobileRoot, bookmarkURI,
+                                                bmsvc.DEFAULT_INDEX,
+                                                bookmarkTitle);
           this.updateStar();
 
           // autoclose the bookmark popup
           autoClose = true;
         }
 
         // Show/hide bookmark popup
         BookmarkPopup.toggle(autoClose);
@@ -925,16 +928,21 @@ var BookmarkHelper = {
   },
 };
 
 var BookmarkList = {
   _panel: null,
   _bookmarks: null,
   _manageButtton: null,
 
+  get mobileRoot() {
+    delete this.mobileRoot;
+    return this.mobileRoot = PlacesUtils.annotations.getItemsWithAnnotation("mobile/bookmarksRoot", {})[0];
+  },
+
   show: function() {
     this._panel = document.getElementById("bookmarklist-container");
     this._panel.width = window.innerWidth;
     this._panel.height = window.innerHeight;
     this._panel.hidden = false;
     BrowserUI.pushDialog(this);
 
     this._bookmarks = document.getElementById("bookmark-items");
--- a/mobile/chrome/tests/browser_bookmarks.js
+++ b/mobile/chrome/tests/browser_bookmarks.js
@@ -30,17 +30,17 @@ function runNextTest() {
   if (gTests.length > 0) {
     gCurrentTest = gTests.shift();
     info(gCurrentTest.desc);
     gCurrentTest.run();
   }
   else {
     // Cleanup. All tests are completed at this point
     try {
-      PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
+      PlacesUtils.bookmarks.removeFolderChildren(BookmarkList.mobileRoot);
     }
     finally {
       // We must finialize the tests
       finish();
     }
   }
 }
 
--- a/mobile/chrome/tests/browser_bookmarks_folders.js
+++ b/mobile/chrome/tests/browser_bookmarks_folders.js
@@ -61,17 +61,17 @@ function runNextTest() {
     gCurrentTest.run();
     while(!gCurrentTest.isCompleted) {
       thread.processNextEvent(true);
     }
     runNextTest();
   }
   else {
     // Cleanup. All tests are completed at this point
-    PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
+    PlacesUtils.bookmarks.removeFolderChildren(BookmarkList.mobileRoot);
     ok(true, "*** ALL TESTS COMPLETED ***");
   }
 }
 
 //------------------------------------------------------------------------------
 // Case: Test adding folder
 gTests.push({
   desc: "Test adding folder",
@@ -182,43 +182,47 @@ gTests.push({
       _currenttab.browser.removeEventListener("load", handleevent1, true);
       gCurrentTest.verify();
     };
     _currenttab.browser.addEventListener("load", handleevent1 , true);
   },
   
   verify: function() {
   
-    // the test bookmarks a page, then creates a folder, and then moves the bookmark into the folder
+    // creates a folder, and then moves the bookmark into the folder
     
     chromeWindow.BrowserUI.doCommand("cmd_star");
     
     chromeWindow.BrowserUI.showBookmarks();
     chromeWindow.BookmarkList.toggleManage();
-    
+
+    // Create new folder
     var bookmarkitems = chromeWindow.document.getElementById("bookmark-items");
     var newfolderbutton = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "class", "bookmark-folder-new");
     EventUtils.synthesizeMouse(newfolderbutton, newfolderbutton.clientWidth / 2, newfolderbutton.clientHeight / 2, {});
+
     var folderitem = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "title", "New folder");
     var nametextbox = chromeWindow.document.getAnonymousElementByAttribute(folderitem, "anonid", "name");
     nametextbox.value = "Test Folder 1";
     var donebutton = chromeWindow.document.getAnonymousElementByAttribute(folderitem, "anonid", "done-button");
     donebutton.click();
-    
+
     var bookmarkitemid = PlacesUtils.getMostRecentBookmarkForURI(uri(testURL_02));
+    is(PlacesUtils.bookmarks.getFolderIdForItem(bookmarkitemid), BookmarkList.mobileRoot, "bookmark starts off in root");
+
+    // Move bookmark
     var bookmarkitem = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "itemid", bookmarkitemid);
     var movebutton = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitem, "anonid", "folder-button");
     movebutton.click();
     
     var folderitems = chromeWindow.document.getElementById("folder-items");
     var destfolder = chromeWindow.document.getAnonymousElementByAttribute(folderitems, "itemid", folderitem.itemId);
     EventUtils.synthesizeMouse(destfolder, destfolder.clientWidth / 2, destfolder.clientHeight / 2, {});
-    
-    isnot(PlacesUtils.bookmarks.getFolderIdForItem(bookmarkitemid), PlacesUtils.bookmarks.unfiledBookmarksFolder, 
-      "Bookmark is no longer in Bookmarks Menu top level folder");
+
+    // Check that it moved
     is(PlacesUtils.bookmarks.getFolderIdForItem(bookmarkitemid), folderitem.itemId, "Bookmark is moved to a folder");
     
     chromeWindow.BookmarkList.close();
     chromeWindow.Browser.closeTab(_currenttab);
     
     gCurrentTest.isCompleted = true;
   },
   
@@ -233,37 +237,40 @@ gTests.push({
   run: function() {
   
     // the test creates a new folder ("Test Folder 2"), and then move a previously created folder ("Test Folder 1") 
     // into the newly created folder
     
     chromeWindow.BrowserUI.showBookmarks();
     chromeWindow.BookmarkList.toggleManage();    
     var bookmarkitems = chromeWindow.document.getElementById("bookmark-items");
-    
+
+    // Create the new folder
     var newfolderbutton = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "class", "bookmark-folder-new");
     EventUtils.synthesizeMouse(newfolderbutton, newfolderbutton.clientWidth / 2, newfolderbutton.clientHeight / 2, {});
     var folderitem2 = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "title", "New folder");
     var nametextbox = chromeWindow.document.getAnonymousElementByAttribute(folderitem2, "anonid", "name");
     nametextbox.value = "Test Folder 2";
     var donebutton = chromeWindow.document.getAnonymousElementByAttribute(folderitem2, "anonid", "done-button");
     donebutton.click();
     
+    // Check the old folder
     var folderitem1 = chromeWindow.document.getAnonymousElementByAttribute(bookmarkitems, "title", "Test Folder 1");
-    var foldetitem1id = folderitem1.itemId;
+    var folderitem1id = folderitem1.itemId;
+    is(foldetitem1id, BookmarksList.mobileRoot, "folder starts off in the root");
+
+    // Move new folder into old folder
     var movebutton = chromeWindow.document.getAnonymousElementByAttribute(folderitem1, "anonid", "folder-button");
     movebutton.click();
-    
+
     var folderitems = chromeWindow.document.getElementById("folder-items");
     var destfolder = chromeWindow.document.getAnonymousElementByAttribute(folderitems, "itemid", folderitem2.itemId);
     EventUtils.synthesizeMouse(destfolder, destfolder.clientWidth / 2, destfolder.clientHeight / 2, {});
-    
-    isnot(PlacesUtils.bookmarks.getFolderIdForItem(foldetitem1id), PlacesUtils.bookmarks.unfiledBookmarksFolder, 
-      "Folder created in previous test is no longer in Bookmarks Menu top level folder");
-    is(PlacesUtils.bookmarks.getFolderIdForItem(foldetitem1id), folderitem2.itemId, "Folder is moved to another folder");
+
+    is(PlacesUtils.bookmarks.getFolderIdForItem(folderitem1id), folderitem2.itemId, "Folder is moved to another folder");
     
     chromeWindow.BookmarkList.close();
     
     gCurrentTest.isCompleted = true;
   },
   
 });
 
--- a/mobile/chrome/tests/browser_bookmarks_star.js
+++ b/mobile/chrome/tests/browser_bookmarks_star.js
@@ -30,17 +30,17 @@ function runNextTest() {
   if (gTests.length > 0) {
     gCurrentTest = gTests.shift();
     info(gCurrentTest.desc);
     gCurrentTest.run();
   }
   else {
     // Cleanup. All tests are completed at this point
     try {
-      PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
+      PlacesUtils.bookmarks.removeFolderChildren(BookmarkList.mobileRoot);
     }
     finally {
       // We must finialize the tests
       finish();
     }
   }
 }
 
--- a/mobile/chrome/tests/browser_bookmarks_tags.js
+++ b/mobile/chrome/tests/browser_bookmarks_tags.js
@@ -30,17 +30,17 @@ function runNextTest() {
   if (gTests.length > 0) {
     gCurrentTest = gTests.shift();
     info(gCurrentTest.desc);
     gCurrentTest.run();
   }
   else {
     // Cleanup. All tests are completed at this point
     try {
-      PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
+      PlacesUtils.bookmarks.removeFolderChildren(BookmarkList.mobileRoot);
     }
     finally {
       // We must finialize the tests
       finish();
     }
   }
 }
 
--- a/mobile/locales/generic/profile/bookmarks.json.in
+++ b/mobile/locales/generic/profile/bookmarks.json.in
@@ -1,24 +1,23 @@
 #filter substitution
 {"type":"text/x-moz-place-container","root":"placesRoot","children":
-  [{"type":"text/x-moz-place-container","root":"unfiledBookmarksFolder","children":
-     [{"title":"@bookmarks_title@","type":"text/x-moz-place-container","children":
-          [
-            {          "title":"@bookmarks_welcome@",  "type":"text/x-moz-place", "uri":"about:firstrun",
-             "iconUri":"chrome://branding/content/favicon32.png"
-            },
-            {"index":1,"title":"@bookmarks_about@",    "type":"text/x-moz-place", "uri":"about:fennec",
-             "iconUri":"chrome://branding/content/favicon32.png"
-            },
-            {"index":2,"title":"@bookmarks_weave@",    "type":"text/x-moz-place", "uri":"https://addons.mozilla.org/@AB_CD@/mobile/addon/10868",
-             "icon":""
-            },
-            {"index":3,"title":"@bookmarks_addons@",   "type":"text/x-moz-place", "uri":"https://addons.mozilla.org/@AB_CD@/mobile",
-             "icon":""
-            },
-            {"index":4,"title":"@bookmarks_support@",  "type":"text/x-moz-place", "uri":"https://mobile.support.mozilla.com/@AB_CD@/kb/",
-             "icon":""
-            }
-          ]
-     }]
+  [{"type":"text/x-moz-place-container","title":"@bookmarks_title@","annos":[{"name":"mobile/bookmarksRoot","expires":4,"type":1,"value":1}],
+    "children":
+     [
+       {          "title":"@bookmarks_welcome@",  "type":"text/x-moz-place", "uri":"about:firstrun",
+        "iconUri":"chrome://branding/content/favicon32.png"
+       },
+       {"index":1,"title":"@bookmarks_about@",    "type":"text/x-moz-place", "uri":"about:fennec",
+        "iconUri":"chrome://branding/content/favicon32.png"
+       },
+       {"index":2,"title":"@bookmarks_weave@",    "type":"text/x-moz-place", "uri":"https://addons.mozilla.org/@AB_CD@/mobile/addon/10868",
+        "icon":""
+       },
+       {"index":3,"title":"@bookmarks_addons@",   "type":"text/x-moz-place", "uri":"https://addons.mozilla.org/@AB_CD@/mobile",
+        "icon":""
+       },
+       {"index":4,"title":"@bookmarks_support@",  "type":"text/x-moz-place", "uri":"https://mobile.support.mozilla.com/@AB_CD@/kb/",
+        "icon":""
+       }
+     ]
   }]
 }