Backed out changeset 0c4d0fc3b6c6 (
bug 525184, going to wait for post-b5)
--- a/mobile/chrome/content/bindings.xml
+++ b/mobile/chrome/content/bindings.xml
@@ -667,25 +667,21 @@
<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 == this.mobileRoot;
+ return currentFolderId == PlacesUtils.bookmarks.unfiledBookmarksFolder;
]]>
</getter>
</property>
<property name="activeItem">
<getter>
<![CDATA[
return this._activeItem;
@@ -764,17 +760,17 @@
]]>
</body>
</method>
<method name="openFolder">
<parameter name="aRootFolder"/>
<body>
<![CDATA[
- aRootFolder = aRootFolder || this.mobileRoot;
+ aRootFolder = aRootFolder || PlacesUtils.bookmarks.unfiledBookmarksFolder;
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,20 +716,17 @@ var BrowserUI = {
case "cmd_star":
{
var bookmarkURI = browser.currentURI;
var bookmarkTitle = browser.contentDocument.title || bookmarkURI.spec;
let autoClose = false;
if (PlacesUtils.getMostRecentBookmarkForURI(bookmarkURI) == -1) {
- let bmsvc = PlacesUtils.bookmarks;
- let bookmarkId = bmsvc.insertBookmark(BookmarkList.mobileRoot, bookmarkURI,
- bmsvc.DEFAULT_INDEX,
- bookmarkTitle);
+ var bookmarkId = PlacesUtils.bookmarks.insertBookmark(PlacesUtils.bookmarks.unfiledBookmarksFolder, bookmarkURI, PlacesUtils.bookmarks.DEFAULT_INDEX, bookmarkTitle);
this.updateStar();
// autoclose the bookmark popup
autoClose = true;
}
// Show/hide bookmark popup
BookmarkPopup.toggle(autoClose);
@@ -928,21 +925,16 @@ 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(BookmarkList.mobileRoot);
+ PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
}
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(BookmarkList.mobileRoot);
+ PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
ok(true, "*** ALL TESTS COMPLETED ***");
}
}
//------------------------------------------------------------------------------
// Case: Test adding folder
gTests.push({
desc: "Test adding folder",
@@ -182,47 +182,43 @@ gTests.push({
_currenttab.browser.removeEventListener("load", handleevent1, true);
gCurrentTest.verify();
};
_currenttab.browser.addEventListener("load", handleevent1 , true);
},
verify: function() {
- // creates a folder, and then moves the bookmark into the folder
+ // the test bookmarks a page, then 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, {});
-
- // Check that it moved
+
+ isnot(PlacesUtils.bookmarks.getFolderIdForItem(bookmarkitemid), PlacesUtils.bookmarks.unfiledBookmarksFolder,
+ "Bookmark is no longer in Bookmarks Menu top level folder");
is(PlacesUtils.bookmarks.getFolderIdForItem(bookmarkitemid), folderitem.itemId, "Bookmark is moved to a folder");
chromeWindow.BookmarkList.close();
chromeWindow.Browser.closeTab(_currenttab);
gCurrentTest.isCompleted = true;
},
@@ -237,40 +233,37 @@ 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 folderitem1id = folderitem1.itemId;
- is(foldetitem1id, BookmarksList.mobileRoot, "folder starts off in the root");
-
- // Move new folder into old folder
+ var foldetitem1id = folderitem1.itemId;
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, {});
-
- is(PlacesUtils.bookmarks.getFolderIdForItem(folderitem1id), folderitem2.itemId, "Folder is moved to another folder");
+
+ 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");
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(BookmarkList.mobileRoot);
+ PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
}
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(BookmarkList.mobileRoot);
+ PlacesUtils.bookmarks.removeFolderChildren(PlacesUtils.bookmarks.unfiledBookmarksFolder);
}
finally {
// We must finialize the tests
finish();
}
}
}
--- a/mobile/locales/generic/profile/bookmarks.json.in
+++ b/mobile/locales/generic/profile/bookmarks.json.in
@@ -1,23 +1,24 @@
#filter substitution
{"type":"text/x-moz-place-container","root":"placesRoot","children":
- [{"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":""
- }
- ]
+ [{"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":""
+ }
+ ]
+ }]
}]
}