'Currently playing' and 'all' tabs added, select 'video settings' by default

This commit is contained in:
Tamius Han 2018-11-18 23:54:54 +01:00
parent 5e7af00f24
commit f294865231

View File

@ -22,6 +22,11 @@ var settings = new Settings(undefined, () => updateConfig());
var site = undefined; var site = undefined;
// aside from hostname, this can have two additional values:
// __playing — commands get sent to all frames with videos of status 'playing'
// __all — commands get sent to all frames
var selectedFrame = '__playing';
var port = browser.runtime.connect({name: 'popup-port'}); var port = browser.runtime.connect({name: 'popup-port'});
port.onMessage.addListener( (m,p) => processReceivedMessage(m,p)); port.onMessage.addListener( (m,p) => processReceivedMessage(m,p));
@ -47,19 +52,36 @@ function loadFrames(videoTab) {
tablist['siteSettings'].removeSubitems(); tablist['siteSettings'].removeSubitems();
tablist['videoSettings'].removeSubitems(); tablist['videoSettings'].removeSubitems();
function onTabitemClick(item) {
tablist[selectedMenu].selectSubitem(item);
selectedSubitem[selectedMenu] = item;
}
for (var option of [{id: '__playing', label: 'Currently playing'}, {id: '__all', label: 'All'}]) {
const id = option.id;
var newItem = new TabItem(
undefined,
option.id,
option.label,
false,
() => onTabitemClick(id)
);
tablist['siteSettings'].insertSubitem(newItem);
tablist['videoSettings'].insertSubitem(newItem);
}
for (var frame in videoTab.frames) { for (var frame in videoTab.frames) {
const nid = `_vsi_${videoTab.id}-${videoTab.frames[frame].id}`; const nid = `${videoTab.id}-${videoTab.frames[frame].id}`;
var newItem = new TabItem( var newItem = new TabItem(
undefined, undefined,
nid, nid,
videoTab.frames[frame].host, videoTab.frames[frame].host,
videoTab.frames[frame].url != videoTab.url, videoTab.frames[frame].url != videoTab.url,
(click) => { (click) => onTabitemClick(nid)
tablist[selectedMenu].selectSubitem(nid); );
selectedSubitem[selectedMenu] = nid;
// todo: set selected subitem
}
)
tablist['siteSettings'].insertSubitem(newItem); tablist['siteSettings'].insertSubitem(newItem);
tablist['videoSettings'].insertSubitem(newItem); tablist['videoSettings'].insertSubitem(newItem);
@ -146,6 +168,11 @@ function stringToKeyCombo(key_in){
} }
function configurePopupTabs(site) { function configurePopupTabs(site) {
if (!selectedMenu) {
showMenu('videoSettings');
} else {
showMenu(selectedMenu);
}
return; return;
// todo: this can potentially be removed // todo: this can potentially be removed
@ -760,7 +787,6 @@ async function popup_init() {
hideWarning("script-not-running-warning"); hideWarning("script-not-running-warning");
while (true) { while (true) {
console.log("GETTING SITE")
getSite(); getSite();
await sleep(5000); await sleep(5000);
} }