quasar
Version:
Build high-performance VueJS user interfaces (SPA, PWA, SSR, Mobile and Desktop) in record time
40 lines (30 loc) • 956 B
JavaScript
import { computed, watch } from 'vue'
import useRouterLink, { useRouterLinkProps } from '../../composables/private.use-router-link/use-router-link.js'
import useTab, { useTabProps, useTabEmits } from './use-tab.js'
import { createComponent } from '../../utils/private.create/create.js'
export default createComponent({
name: 'QRouteTab',
props: {
...useRouterLinkProps,
...useTabProps
},
emits: useTabEmits,
setup (props, { slots, emit }) {
const routeData = useRouterLink({
useDisableForRouterLinkProps: false
})
const { renderTab, $tabs } = useTab(
props,
slots,
emit,
{
exact: computed(() => props.exact),
...routeData
}
)
watch(() => `${ props.name } | ${ props.exact } | ${ (routeData.resolvedLink.value || {}).href }`, () => {
$tabs.verifyRouteModel()
})
return () => renderTab(routeData.linkTag.value, routeData.linkAttrs.value)
}
})