Turn extract click listener back on.

Add shadow to tabs when there are more tabs that aren't displayed
This commit is contained in:
j433866 2019-05-29 16:29:34 +01:00
parent 12e4fe4120
commit 9b2f44efb1
3 changed files with 28 additions and 4 deletions

View file

@ -255,7 +255,7 @@ class InputWaiter {
this.removeLoaderWorker(this.getLoaderWorker(r.data)); this.removeLoaderWorker(this.getLoaderWorker(r.data));
break; break;
case "refreshTabs": case "refreshTabs":
this.refreshTabs(r.data.nums, r.data.activeTab); this.refreshTabs(r.data.nums, r.data.activeTab, r.data.tabsLeft, r.data.tabsRight);
break; break;
case "changeTab": case "changeTab":
this.changeTab(r.data, this.app.options.syncTabs); this.changeTab(r.data, this.app.options.syncTabs);
@ -965,8 +965,10 @@ class InputWaiter {
* *
* @param {number[]} nums - The inputNums of the tab bar to be drawn * @param {number[]} nums - The inputNums of the tab bar to be drawn
* @param {number} activeTab - The inputNum of the active tab * @param {number} activeTab - The inputNum of the active tab
* @param {boolean} tabsLeft - True if there are tabs to the left of the currently displayed tabs
* @param {boolean} tabsRight - True if there are tabs to the right of the currently displayed tabs
*/ */
refreshTabs(nums, activeTab) { refreshTabs(nums, activeTab, tabsLeft, tabsRight) {
const tabsList = document.getElementById("input-tabs"); const tabsList = document.getElementById("input-tabs");
for (let i = tabsList.children.length - 1; i >= 0; i--) { for (let i = tabsList.children.length - 1; i >= 0; i--) {
@ -979,6 +981,24 @@ class InputWaiter {
tabsList.appendChild(this.createTabElement(nums[i], active)); tabsList.appendChild(this.createTabElement(nums[i], active));
} }
const firstTabElement = document.getElementById("input-tabs").firstElementChild;
const lastTabElement = document.getElementById("input-tabs").lastElementChild;
if (firstTabElement) {
if (tabsLeft) {
firstTabElement.style.boxShadow = "15px 0px 15px -15px var(--primary-border-colour) inset";
} else {
firstTabElement.style.boxShadow = "";
}
}
if (lastTabElement) {
if (tabsRight) {
lastTabElement.style.boxShadow = "-15px 0px 15px -15px var(--primary-border-colour) inset";
} else {
lastTabElement.style.boxShadow = "";
}
}
if (nums.length > 1) { if (nums.length > 1) {
tabsList.parentElement.style.display = "block"; tabsList.parentElement.style.display = "block";

View file

@ -467,11 +467,15 @@ self.setInput = function(inputData) {
*/ */
self.refreshTabs = function(inputNum, direction) { self.refreshTabs = function(inputNum, direction) {
const nums = self.getNearbyNums(inputNum, direction); const nums = self.getNearbyNums(inputNum, direction);
const tabsLeft = (self.getSmallestInputNum() !== nums[0]);
const tabsRight = (self.getLargestInputNum() !== nums[nums.length - 1]);
self.postMessage({ self.postMessage({
action: "refreshTabs", action: "refreshTabs",
data: { data: {
nums: nums, nums: nums,
activeTab: (nums.includes(inputNum)) ? inputNum : self.getNextInputNum(inputNum) activeTab: (nums.includes(inputNum)) ? inputNum : self.getNextInputNum(inputNum),
tabsLeft: tabsLeft,
tabsRight: tabsRight
} }
}); });

View file

@ -196,7 +196,7 @@ class Manager {
this.addDynamicListener("#output-file-download", "click", this.output.downloadFile, this.output); this.addDynamicListener("#output-file-download", "click", this.output.downloadFile, this.output);
this.addDynamicListener("#output-file-slice i", "click", this.output.displayFileSlice, this.output); this.addDynamicListener("#output-file-slice i", "click", this.output.displayFileSlice, this.output);
document.getElementById("show-file-overlay").addEventListener("click", this.output.showFileOverlayClick.bind(this.output)); document.getElementById("show-file-overlay").addEventListener("click", this.output.showFileOverlayClick.bind(this.output));
// this.addDynamicListener(".extract-file,.extract-file i", "click", this.output.extractFileClick, this.output); this.addDynamicListener(".extract-file,.extract-file i", "click", this.output.extractFileClick, this.output);
this.addDynamicListener("#output-tabs-wrapper #output-tabs li .output-tab-content", "click", this.output.changeTabClick, this.output); this.addDynamicListener("#output-tabs-wrapper #output-tabs li .output-tab-content", "click", this.output.changeTabClick, this.output);
document.getElementById("btn-previous-output-tab").addEventListener("click", this.output.changeTabLeft.bind(this.output)); document.getElementById("btn-previous-output-tab").addEventListener("click", this.output.changeTabLeft.bind(this.output));
document.getElementById("btn-next-output-tab").addEventListener("click", this.output.changeTabRight.bind(this.output)); document.getElementById("btn-next-output-tab").addEventListener("click", this.output.changeTabRight.bind(this.output));