This repository has been archived on 2024-07-27. You can view files and clone it, but cannot push or open issues or pull requests.
keksAccountGUI/node_modulesOLD/vuetify/lib/components/VTabs/VTabsBar.js

77 lines
1.8 KiB
JavaScript
Raw Permalink Normal View History

2019-08-11 18:48:02 +00:00
// Extensions
import { BaseSlideGroup } from '../VSlideGroup/VSlideGroup'; // Mixins
import Themeable from '../../mixins/themeable';
import SSRBootable from '../../mixins/ssr-bootable'; // Utilities
import mixins from '../../util/mixins';
export default mixins(BaseSlideGroup, SSRBootable, Themeable
/* @vue/component */
).extend({
name: 'v-tabs-bar',
provide() {
return {
tabsBar: this
};
},
computed: {
classes() {
return { ...BaseSlideGroup.options.computed.classes.call(this),
'v-tabs-bar': true,
...this.themeClasses
};
}
},
watch: {
items: 'callSlider',
internalValue: 'callSlider',
$route: 'onRouteChange'
},
methods: {
callSlider() {
if (!this.isBooted) return;
this.$emit('call:slider');
},
genContent() {
const render = BaseSlideGroup.options.methods.genContent.call(this);
render.data = render.data || {};
render.data.staticClass += ' v-tabs-bar__content';
return render;
},
onRouteChange(val, oldVal) {
/* istanbul ignore next */
if (this.mandatory) return;
const items = this.items;
const newPath = val.path;
const oldPath = oldVal.path;
let hasNew = false;
let hasOld = false;
for (const item of items) {
if (item.to === newPath) hasNew = true;else if (item.to === oldPath) hasOld = true;
if (hasNew && hasOld) break;
} // If we have an old item and not a new one
// it's assumed that the user navigated to
// a path that is not present in the items
if (!hasNew && hasOld) this.internalValue = undefined;
}
},
render(h) {
const render = BaseSlideGroup.options.render.call(this, h);
render.data.attrs = {
role: 'tablist'
};
return render;
}
});
//# sourceMappingURL=VTabsBar.js.map