gecko/browser/metro/base/content/TopSites.js

242 lines
6.9 KiB
JavaScript
Raw Normal View History

// -*- Mode: js2; tab-width: 2; indent-tabs-mode: nil; js2-basic-offset: 2; js2-skip-preprocessor-directives: t; -*-
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
'use strict';
let prefs = Components.classes["@mozilla.org/preferences-service;1"].
getService(Components.interfaces.nsIPrefBranch);
// singleton to provide data-level functionality to the views
let TopSites = {
pinSite: function(aId, aSlotIndex) {
Util.dumpLn("TopSites.pinSite: " + aId + ", (TODO)");
// FIXME: implementation needed
return true; // operation was successful
},
unpinSite: function(aId) {
Util.dumpLn("TopSites.unpinSite: " + aId + ", (TODO)");
// FIXME: implementation needed
return true; // operation was successful
},
hideSite: function(aId) {
Util.dumpLn("TopSites.hideSite: " + aId + ", (TODO)");
// FIXME: implementation needed
return true; // operation was successful
},
restoreSite: function(aId) {
Util.dumpLn("TopSites.restoreSite: " + aId + ", (TODO)");
// FIXME: implementation needed
return true; // operation was successful
}
};
function TopSitesView(aGrid, maxSites) {
this._set = aGrid;
this._set.controller = this;
this._topSitesMax = maxSites;
// handle selectionchange DOM events from the grid/tile group
this._set.addEventListener("context-action", this, false);
let history = Cc["@mozilla.org/browser/nav-history-service;1"].
getService(Ci.nsINavHistoryService);
history.addObserver(this, false);
}
TopSitesView.prototype = {
_set:null,
_topSitesMax: null,
handleItemClick: function tabview_handleItemClick(aItem) {
let url = aItem.getAttribute("value");
BrowserUI.goToURI(url);
},
doActionOnSelectedTiles: function(aActionName) {
let tileGroup = this._set;
let selectedTiles = tileGroup.selectedItems;
switch (aActionName){
case "delete":
Array.forEach(selectedTiles, function(aNode) {
let id = aNode.getAttribute("data-itemid");
// add some class to transition element before deletion?
if (TopSites.hideSite(id)) {
// success
aNode.contextActions.delete('delete');
aNode.contextActions.add('restore');
}
// TODO: we'll use some callback/event to remove the item or re-draw the grid
});
break;
case "pin":
Array.forEach(selectedTiles, function(aNode) {
let id = aNode.getAttribute("data-itemid");
if (TopSites.pinSite(id)) {
// success
aNode.contextActions.delete('pin');
aNode.contextActions.add('unpin');
}
// TODO: we'll use some callback/event to add some class to
// indicate element is pinned?
});
break;
case "unpin":
Array.forEach(selectedTiles, function(aNode) {
let id = aNode.getAttribute("data-itemid");
if (TopSites.unpinSite(id)) {
// success
aNode.contextActions.delete('unpin');
aNode.contextActions.add('pin');
}
// TODO: we'll use some callback/event to add some class to
// indicate element is pinned (or just redraw grid)
});
break;
// default: no action
}
},
handleEvent: function(aEvent) {
switch (aEvent.type){
case "context-action":
this.doActionOnSelectedTiles(aEvent.action);
break;
}
},
populateGrid: function populateGrid() {
let query = gHistSvc.getNewQuery();
let options = gHistSvc.getNewQueryOptions();
options.excludeQueries = true;
options.queryType = options.QUERY_TYPE_HISTORY;
options.maxResults = this._topSitesMax;
options.resultType = options.RESULTS_AS_URI;
options.sortingMode = options.SORT_BY_FRECENCY_DESCENDING;
let result = gHistSvc.executeQuery(query, options);
let rootNode = result.root;
rootNode.containerOpen = true;
let childCount = rootNode.childCount;
// use this property as the data-itemid attribute on the tiles
// which identifies the site
let identifier = 'uri';
function isPinned(aNode) {
// placeholder condition,
// FIXME: do the actual lookup/check
return (aNode.uri.indexOf('google') > -1);
}
for (let i = 0; i < childCount; i++) {
let node = rootNode.getChild(i);
let uri = node.uri;
let title = node.title || uri;
let supportedActions = ['delete'];
// placeholder condition - check field/property for this site
if (isPinned(node)) {
supportedActions.push('unpin');
} else {
supportedActions.push('pin');
}
let item = this._set.appendItem(title, uri);
item.setAttribute("iconURI", node.icon);
item.setAttribute("data-itemid", node[identifier]);
// here is where we could add verbs based on pinned etc. state
item.setAttribute("data-contextactions", supportedActions.join(','));
}
rootNode.containerOpen = false;
},
isFirstRun: function isFirstRun() {
return prefs.getBoolPref("browser.firstrun.show.localepicker");
},
destruct: function destruct() {
// remove the observers here
},
// nsINavHistoryObserver
onBeginUpdateBatch: function() {
},
onEndUpdateBatch: function() {
},
onVisit: function(aURI, aVisitID, aTime, aSessionID,
aReferringID, aTransitionType) {
},
onTitleChanged: function(aURI, aPageTitle) {
},
onDeleteURI: function(aURI) {
},
onClearHistory: function() {
this._set.clearAll();
},
onPageChanged: function(aURI, aWhat, aValue) {
},
onPageExpired: function(aURI, aVisitTime, aWholeEntry) {
},
QueryInterface: function(iid) {
if (iid.equals(Components.interfaces.nsINavHistoryObserver) ||
iid.equals(Components.interfaces.nsISupports)) {
return this;
}
throw Cr.NS_ERROR_NO_INTERFACE;
}
};
let TopSitesStartView = {
_view: null,
get _grid() { return document.getElementById("start-topsites-grid"); },
init: function init() {
this._view = new TopSitesView(this._grid, 9);
if (this._view.isFirstRun()) {
let topsitesVbox = document.getElementById("start-topsites");
topsitesVbox.setAttribute("hidden", "true");
}
this._view.populateGrid();
},
uninit: function uninit() {
this._view.destruct();
},
show: function show() {
this._grid.arrangeItems(3, 3);
},
};
let TopSitesSnappedView = {
get _grid() { return document.getElementById("snapped-topsite-grid"); },
show: function show() {
this._grid.arrangeItems(1, 9);
},
init: function() {
this._view = new TopSitesView(this._grid, 9);
if (this._view.isFirstRun()) {
let topsitesVbox = document.getElementById("snapped-topsites");
topsitesVbox.setAttribute("hidden", "true");
}
this._view.populateGrid();
},
uninit: function uninit() {
this._view.destruct();
},
};