diff --git a/addon/manifest.json b/addon/manifest.json index 15431b27b..9084973e0 100644 --- a/addon/manifest.json +++ b/addon/manifest.json @@ -8,7 +8,7 @@ }, "author": "mbnuqw", "name": "__MSG_ExtName__", - "version": "4.1.1", + "version": "4.1.2", "default_locale": "en", "description": "__MSG_ExtDesc__", "homepage_url": "https://github.com/mbnuqw/sidebery", diff --git a/package.json b/package.json index ab3a56b66..dcecdc84e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "sidebery", - "version": "4.1.1", + "version": "4.1.2", "description": "Manage your tabs and bookmarks in sidebar", "main": "index.js", "scripts": { diff --git a/src/sidebar/actions/tabs.js b/src/sidebar/actions/tabs.js index bbd60e6cf..93c0ab032 100644 --- a/src/sidebar/actions/tabs.js +++ b/src/sidebar/actions/tabs.js @@ -1308,7 +1308,14 @@ function expTabsBranch(tabId) { // Auto fold if (this.state.autoFoldTabs) { - autoFold.sort((a, b) => a.lastAccessed - b.lastAccessed) + autoFold.sort((a, b) => { + let aMax = a.lastAccessed + let bMax = b.lastAccessed + if (a.childLastAccessed) aMax = Math.max(a.lastAccessed, a.childLastAccessed) + if (b.childLastAccessed) bMax = Math.max(b.lastAccessed, b.childLastAccessed) + return aMax - bMax + }) + if (this.state.autoFoldTabsExcept > 0) { autoFold = autoFold.slice(0, -this.state.autoFoldTabsExcept) } @@ -1641,6 +1648,15 @@ async function dropToTabsNative(event, dropIndex, dropParent, destCtx, pin) { } if (url && destCtx) { + let panel = this.state.panels[this.state.panelIndex] + if (panel && panel.tabs) { + if (!this.state.newTabsPosition) this.state.newTabsPosition = {} + this.state.newTabsPosition[dropIndex] = { + parent: dropParent < 0 ? undefined : dropParent, + panel: panel.id, + } + } + browser.tabs.create({ active: true, url, diff --git a/src/sidebar/handlers/tabs.js b/src/sidebar/handlers/tabs.js index 61589b624..ee2699207 100644 --- a/src/sidebar/handlers/tabs.js +++ b/src/sidebar/handlers/tabs.js @@ -46,6 +46,8 @@ function onTabCreated(tab) { index = this.actions.getIndexForNewTab(panel, tab) tab.openerTabId = this.actions.getParentForNewTab(panel, tab.openerTabId) if (index === undefined) { + let prevTab = this.state.tabs[tab.index - 1] + if (prevTab && prevTab.panelId !== panel.id) panel = this.state.panelsMap[prevTab.panelId] if (panel.moveTabCtx !== 'none' && tab.openerTabId === undefined) { index = panel.tabs.length ? panel.endIndex + 1 : panel.endIndex } else { @@ -669,19 +671,34 @@ function onTabActivated(info) { // Remove updated flag tab.updated = false let panel = this.state.panelsMap[tab.panelId] + if (!panel) return + if (panel) { let i = panel.updated.indexOf(tab.id) panel.updated.splice(i, 1) } - // Find panel of activated tab - if (!panel) return - // Switch to activated tab's panel if (!tab.pinned && (!currentPanel || !currentPanel.lockedPanel)) { this.actions.setPanel(panel.index) } + // Propagate access time to parent tabs for autoFolding feature + if ( + this.state.tabsTree && + tab.parentId > -1 && + this.state.autoFoldTabs && + this.state.autoFoldTabsExcept > 0 + ) { + let parent = this.state.tabsMap[tab.parentId] + if (parent) { + parent.childLastAccessed = tab.lastAccessed + while ((parent = this.state.tabsMap[parent.parentId])) { + parent.childLastAccessed = tab.lastAccessed + } + } + } + // Auto expand tabs group if (this.state.autoExpandTabs && tab.isParent && tab.folded && !this.dragMode) { let prevActiveChild