mirror of
https://github.com/zen-browser/desktop.git
synced 2025-10-01 23:48:37 +00:00
Show panel and website controls for website side panels
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
|
||||
var ZenSidebarManager = {
|
||||
_sidebarElement: null,
|
||||
_currentPanel: null,
|
||||
|
||||
init() {
|
||||
this.update();
|
||||
@@ -34,21 +35,79 @@ var ZenSidebarManager = {
|
||||
let button = document.createXULElement("toolbarbutton");
|
||||
button.classList.add("zen-sidebar-panel-button", "toolbarbutton-1", "chromeclass-toolbar-additional");
|
||||
button.setAttribute("flex", "1");
|
||||
button.setAttribute("zen-sidebar-id", site);
|
||||
button.style.listStyleImage = this._getWebPanelIcon(panel.url);
|
||||
button.addEventListener("click", this._handleClick.bind(this));
|
||||
this.sidebarElement.appendChild(button);
|
||||
}
|
||||
},
|
||||
|
||||
_openAndGetWebPanelWrapper() {
|
||||
let sidebar = document.getElementById("zen-sidebar-web-panel");
|
||||
sidebar.removeAttribute("hidden");
|
||||
return sidebar;
|
||||
},
|
||||
|
||||
_closeSidebarPanel() {
|
||||
let sidebar = document.getElementById("zen-sidebar-web-panel");
|
||||
sidebar.setAttribute("hidden", "true");
|
||||
},
|
||||
|
||||
_handleClick(event) {
|
||||
let target = event.target;
|
||||
let panelId = target.getAttribute("zen-sidebar-id");
|
||||
if (this._currentPanel === panelId) {
|
||||
return;
|
||||
}
|
||||
this._currentPanel = panelId;
|
||||
this._updateButtons();
|
||||
this._updateWebPanel();
|
||||
},
|
||||
|
||||
_updateButtons() {
|
||||
for (let button of this.sidebarElement.querySelectorAll(".zen-sidebar-panel-button")) {
|
||||
if (button.getAttribute("zen-sidebar-id") === this._currentPanel) {
|
||||
button.setAttribute("selected", "true");
|
||||
} else {
|
||||
button.removeAttribute("selected");
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
_updateWebPanel() {
|
||||
let sidebar = this._openAndGetWebPanelWrapper();
|
||||
},
|
||||
|
||||
_getWebPanelIcon(url) {
|
||||
return `url(page-icon:${url})`;
|
||||
},
|
||||
|
||||
reload() {
|
||||
|
||||
},
|
||||
|
||||
forward() {
|
||||
|
||||
},
|
||||
|
||||
back() {
|
||||
|
||||
},
|
||||
|
||||
home() {
|
||||
|
||||
},
|
||||
|
||||
close() {
|
||||
this._closeSidebarPanel();
|
||||
},
|
||||
|
||||
get sidebarElement() {
|
||||
if (!this._sidebarElement) {
|
||||
this._sidebarElement = document.getElementById("zen-sidebar-panels-wrapper");
|
||||
}
|
||||
return this._sidebarElement;
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
ZenSidebarManager.init();
|
||||
|
Reference in New Issue
Block a user