Refactoring of index.js

This commit is contained in:
baku 2017-01-07 00:03:34 +01:00
parent 108673b492
commit d7d7eeaacb
2 changed files with 147 additions and 144 deletions

273
index.js
View file

@ -8,162 +8,157 @@ const tabs = require('sdk/tabs');
const webExtension = require('sdk/webextension'); const webExtension = require('sdk/webextension');
const { viewFor } = require("sdk/view/core"); const { viewFor } = require("sdk/view/core");
/* Let's start enabling Containers */ let ContainerService =
var prefs = [ {
[ "privacy.userContext.enabled", true ], _identitiesState: {},
[ "privacy.userContext.ui.enabled", true ],
[ "privacy.usercontext.about_newtab_segregation.enabled", true ],
[ "privacy.usercontext.longPressBehavior", 1 ]
];
const prefService = require("sdk/preferences/service"); init() {
prefs.forEach((pref) => { // Enabling preferences
prefService.set(pref[0], pref[1]);
});
const identitiesState = { let prefs = [
}; [ "privacy.userContext.enabled", true ],
[ "privacy.userContext.ui.enabled", true ],
[ "privacy.usercontext.about_newtab_segregation.enabled", true ],
[ "privacy.usercontext.longPressBehavior", 1 ]
];
function convert(identity) { const prefService = require("sdk/preferences/service");
let hiddenTabUrls = []; prefs.forEach((pref) => {
prefService.set(pref[0], pref[1]);
});
if (identity.userContextId in identitiesState) { // Message routing
hiddenTabUrls = identitiesState[identity.userContextId].hiddenTabUrls;
}
const result = {
name: ContextualIdentityService.getUserContextLabel(identity.userContextId),
icon: identity.icon,
color: identity.color,
userContextId: identity.userContextId,
hiddenTabUrls: hiddenTabUrls
};
return result; // only these methods are allowed. We have a 1:1 mapping between messages
} // and methods. These methods must return a promise.
let methods = [
'queryTabs',
'hideTabs',
'showTabs',
'removeTabs',
'openTab',
'queryIdentities',
'getIdentitiesState',
];
function queryContainers(details) { webExtension.startup().then(api => {
const identities = []; api.browser.runtime.onMessage.addListener((message, sender, sendReply) => {
if ("method" in message && methods.indexOf(message.method) != -1) {
sendReply(this[message.method](message));
}
});
});
},
ContextualIdentityService.getIdentities().forEach(identity=> { // utility methods
if (details && details.name &&
ContextualIdentityService.getUserContextLabel(identity.userContextId) !== details.name) { _convert(identity) {
return; let hiddenTabUrls = [];
if (identity.userContextId in this._identitiesState) {
hiddenTabUrls = this._identitiesState[identity.userContextId].hiddenTabUrls;
} }
const convertedIdentity = convert(identity); return {
name: ContextualIdentityService.getUserContextLabel(identity.userContextId),
icon: identity.icon,
color: identity.color,
userContextId: identity.userContextId,
hiddenTabUrls: hiddenTabUrls
};
},
identities.push(convertedIdentity); // Tabs management
if (!(convertedIdentity.userContextId in identitiesState)) {
identitiesState[convertedIdentity.userContextId] = {hiddenTabUrls: []};
}
});
return Promise.resolve(identities); queryTabs(args) {
} return new Promise((resolve, reject) => {
let tabList = [];
function removeContainer(userContextId) { for (let tab of tabs) {
if (!userContextId) { let xulTab = viewFor(tab);
return Promise.resolve(null); let userContextId = parseInt(xulTab.getAttribute('usercontextid') || 0, 10);
}
const identity = ContextualIdentityService.getIdentityFromId(userContextId); if ("userContextId" in args && args.userContextId != userContextId) {
continue;
}
if (!identity) { tabList.push({
return Promise.resolve(null); id: tab.id,
} url: tab.url,
userContextId: userContextId,
// We have to create the identity object before removing it. });
const convertedIdentity = convert(identity);
if (!ContextualIdentityService.remove(identity.userContextId)) {
return Promise.resolve(null);
}
return Promise.resolve(convertedIdentity);
}
function openTab(args) {
let browserWin = Services.wm.getMostRecentWindow('navigator:browser');
// This should not really happen.
if (!browserWin || !browserWin.gBrowser) {
return Promise.resolve(false);
}
let userContextId = 0;
if ('userContextId' in args) {
userContextId = args.userContextId;
}
let tab = browserWin.gBrowser.addTab(args.url || null,
{ userContextId: userContextId })
browserWin.gBrowser.selectedTab = tab;
return Promise.resolve(true);
}
function queryTabs(args) {
return new Promise((resolve, reject) => {
let tabList = [];
for (let tab of tabs) {
let xulTab = viewFor(tab);
let userContextId = parseInt(xulTab.getAttribute('usercontextid') || 0, 10);
if ("userContextId" in args && args.userContextId != userContextId) {
continue;
} }
tabList.push({ resolve(tabList);
id: tab.id, });
url: tab.url, },
userContextId: userContextId,
hideTabs(args) {
this._identitiesState[args.userContextId].hiddenTabUrls = args.tabUrlsToSave;
return Promise.resolve(null);
},
showTabs(args) {
return new Promise((resolve, reject) => {
let hiddenTabUrls = this._identitiesState[args.userContextId].hiddenTabUrls;
this._identitiesState[args.userContextId].hiddenTabUrls = [];
resolve(hiddenTabUrls);
});
},
removeTabs(args) {
return new Promise((resolve, reject) => {
for (let tab of tabs) {
if (args.tabIds.indexOf(tab.id) != -1) {
tab.close();
}
}
resolve(null);
});
},
openTab(args) {
return new Promise((resolve, reject) => {
let browserWin = Services.wm.getMostRecentWindow('navigator:browser');
// This should not really happen.
if (!browserWin || !browserWin.gBrowser) {
return Promise.resolve(false);
}
let userContextId = 0;
if ('userContextId' in args) {
userContextId = args.userContextId;
}
let tab = browserWin.gBrowser.addTab(args.url || null,
{ userContextId: userContextId })
browserWin.gBrowser.selectedTab = tab;
resolve(true);
});
},
// Identities management
queryIdentities(args) {
return new Promise((resolve, reject) => {
let identities = [];
ContextualIdentityService.getIdentities().forEach(identity => {
let convertedIdentity = this._convert(identity);
identities.push(convertedIdentity);
if (!(convertedIdentity.userContextId in this._identitiesState)) {
this._identitiesState[convertedIdentity.userContextId] = {hiddenTabUrls: []};
}
}); });
}
resolve(tabList); resolve(identities);
}); });
} },
function removeTabs(ids) { getIdentitiesState(args) {
for (let tab of tabs) { return Promise.resolve(this._identitiesState);
if (ids.indexOf(tab.id) != -1) { },
tab.close(); };
}
}
return Promise.resolve(null); ContainerService.init();
}
function handleWebExtensionMessage(message, sender, sendReply) {
switch (message.method) {
case 'queryIdentities':
sendReply(queryContainers(message.arguments));
break;
case 'queryTabs':
sendReply(queryTabs(message));
break;
case 'hideTabs':
identitiesState[message.userContextId].hiddenTabUrls = message.tabUrlsToSave;
break;
case 'showTabs':
sendReply(identitiesState[message.userContextId].hiddenTabUrls);
identitiesState[message.userContextId].hiddenTabUrls = [];
break;
case 'removeTabs':
sendReply(removeTabs(message.tabIds));
identitiesState[message.userContextId].hiddenTabUrls = [];
break;
case 'getIdentitiesState':
sendReply(identitiesState);
break;
case 'openTab':
sendReply(openTab(message));
break;
}
}
webExtension.startup().then(api=> {
const {browser} = api;
browser.runtime.onMessage.addListener(handleWebExtensionMessage);
});

View file

@ -20,10 +20,11 @@ function hideContainerTabs(userContextId) {
userContextId: userContextId, userContextId: userContextId,
tabUrlsToSave: tabUrlsToSave tabUrlsToSave: tabUrlsToSave
}).then(()=> { }).then(()=> {
browser.runtime.sendMessage({ return browser.runtime.sendMessage({
method: 'removeTabs', method: 'removeTabs',
tabIds: tabIdsToRemove tabIds: tabIdsToRemove
}); });
}).then(() => {
hideorshowIcon.src = CONTAINER_UNHIDE_SRC; hideorshowIcon.src = CONTAINER_UNHIDE_SRC;
}); });
}); });
@ -43,8 +44,9 @@ function showContainerTabs(userContextId) {
url: url url: url
}); });
}); });
}).then(() => {
hideorshowIcon.src = CONTAINER_HIDE_SRC;
}); });
hideorshowIcon.src = CONTAINER_HIDE_SRC;
} }
if (localStorage.getItem('onboarded2')) { if (localStorage.getItem('onboarded2')) {
@ -128,8 +130,12 @@ browser.runtime.sendMessage({method: 'queryIdentities'}).then(identities=> {
} }
}); });
} else if (e.target.matches('.newtab-icon')) { } else if (e.target.matches('.newtab-icon')) {
browser.runtime.sendMessage({method: 'openTab', userContextId: userContextId}); browser.runtime.sendMessage({
window.close(); method: 'openTab',
userContextId: userContextId})
.then(() => {
window.close();
});
} }
}); });
}); });
@ -154,7 +160,9 @@ function moveTabs(sortedTabsArray) {
} }
document.querySelector('#sort-containers-link').addEventListener('click', ()=> { document.querySelector('#sort-containers-link').addEventListener('click', ()=> {
browser.runtime.sendMessage({method: 'queryIdentities'}).then(identities=> { browser.runtime.sendMessage({
method: 'queryIdentities'
}).then(identities=> {
identities.unshift({userContextId: 0}); identities.unshift({userContextId: 0});
browser.runtime.sendMessage({method: 'queryTabs'}).then(tabsArray=> { browser.runtime.sendMessage({method: 'queryTabs'}).then(tabsArray=> {