2020-06-23 08:45:38 +00:00
|
|
|
import _ from 'lodash'
|
2020-05-19 09:02:56 +00:00
|
|
|
import App from '../base'
|
2020-06-23 08:45:38 +00:00
|
|
|
App.directive('bookmarkableTabset', $location => ({
|
2020-05-19 09:02:56 +00:00
|
|
|
restrict: 'A',
|
|
|
|
require: 'tabset',
|
|
|
|
link(scope, el, attrs, tabset) {
|
|
|
|
const _makeActive = function(hash) {
|
|
|
|
if (hash && hash !== '') {
|
|
|
|
const matchingTab = _.find(
|
|
|
|
tabset.tabs,
|
|
|
|
tab => tab.bookmarkableTabId === hash
|
|
|
|
)
|
|
|
|
if (matchingTab) {
|
|
|
|
matchingTab.select()
|
|
|
|
return el.children()[0].scrollIntoView({ behavior: 'smooth' })
|
2018-11-05 10:06:39 +00:00
|
|
|
}
|
|
|
|
}
|
2020-05-19 09:02:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
scope.$applyAsync(function() {
|
|
|
|
// for page load
|
|
|
|
const hash = $location.hash()
|
|
|
|
_makeActive(hash)
|
2018-11-05 10:06:39 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
// for links within page to a tab
|
|
|
|
// this needs to be within applyAsync because there could be a link
|
|
|
|
// within a tab to another tab
|
|
|
|
const linksToTabs = document.querySelectorAll('.link-to-tab')
|
|
|
|
const _clickLinkToTab = event => {
|
|
|
|
const hash = event.currentTarget
|
|
|
|
.getAttribute('href')
|
|
|
|
.split('#')
|
|
|
|
.pop()
|
2018-11-05 10:06:39 +00:00
|
|
|
_makeActive(hash)
|
2020-05-19 09:02:56 +00:00
|
|
|
}
|
2018-11-05 10:06:39 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
if (linksToTabs) {
|
|
|
|
Array.from(linksToTabs).map(link =>
|
|
|
|
link.addEventListener('click', _clickLinkToTab)
|
|
|
|
)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}))
|
2018-11-05 10:06:39 +00:00
|
|
|
|
2020-05-19 09:02:56 +00:00
|
|
|
App.directive('bookmarkableTab', $location => ({
|
|
|
|
restrict: 'A',
|
|
|
|
require: 'tab',
|
|
|
|
link(scope, el, attrs, tab) {
|
|
|
|
const tabScope = el.isolateScope()
|
|
|
|
const tabId = attrs.bookmarkableTab
|
|
|
|
if (tabScope && tabId && tabId !== '') {
|
|
|
|
tabScope.bookmarkableTabId = tabId
|
|
|
|
tabScope.$watch('active', function(isActive, wasActive) {
|
|
|
|
if (isActive && !wasActive && $location.hash() !== tabId) {
|
|
|
|
return $location.hash(tabId)
|
2018-11-05 10:06:39 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2020-05-19 09:02:56 +00:00
|
|
|
}
|
|
|
|
}))
|