UNPKG

primevue

Version:

PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBloc

220 lines (214 loc) 7.25 kB
import { cn } from '@primeuix/utils'; import { focus, findSingle, getAttribute } from '@primeuix/utils/dom'; import { equals } from '@primeuix/utils/object'; import Ripple from 'primevue/ripple'; import { mergeProps, resolveDirective, withDirectives, renderSlot, createBlock, openBlock, resolveDynamicComponent, withCtx, normalizeClass } from 'vue'; import BaseComponent from '@primevue/core/basecomponent'; import TabStyle from 'primevue/tab/style'; var script$1 = { name: 'BaseTab', "extends": BaseComponent, props: { value: { type: [String, Number], "default": undefined }, disabled: { type: Boolean, "default": false }, as: { type: [String, Object], "default": 'BUTTON' }, asChild: { type: Boolean, "default": false } }, style: TabStyle, provide: function provide() { return { $pcTab: this, $parentInstance: this }; } }; var script = { name: 'Tab', "extends": script$1, inheritAttrs: false, inject: ['$pcTabs', '$pcTabList'], methods: { onFocus: function onFocus() { this.$pcTabs.selectOnFocus && this.changeActiveValue(); }, onClick: function onClick() { this.changeActiveValue(); }, onKeydown: function onKeydown(event) { switch (event.code) { case 'ArrowRight': this.onArrowRightKey(event); break; case 'ArrowLeft': this.onArrowLeftKey(event); break; case 'Home': this.onHomeKey(event); break; case 'End': this.onEndKey(event); break; case 'PageDown': this.onPageDownKey(event); break; case 'PageUp': this.onPageUpKey(event); break; case 'Enter': case 'NumpadEnter': case 'Space': this.onEnterKey(event); break; } }, onArrowRightKey: function onArrowRightKey(event) { var nextTab = this.findNextTab(event.currentTarget); nextTab ? this.changeFocusedTab(event, nextTab) : this.onHomeKey(event); event.preventDefault(); }, onArrowLeftKey: function onArrowLeftKey(event) { var prevTab = this.findPrevTab(event.currentTarget); prevTab ? this.changeFocusedTab(event, prevTab) : this.onEndKey(event); event.preventDefault(); }, onHomeKey: function onHomeKey(event) { var firstTab = this.findFirstTab(); this.changeFocusedTab(event, firstTab); event.preventDefault(); }, onEndKey: function onEndKey(event) { var lastTab = this.findLastTab(); this.changeFocusedTab(event, lastTab); event.preventDefault(); }, onPageDownKey: function onPageDownKey(event) { this.scrollInView(this.findLastTab()); event.preventDefault(); }, onPageUpKey: function onPageUpKey(event) { this.scrollInView(this.findFirstTab()); event.preventDefault(); }, onEnterKey: function onEnterKey(event) { this.changeActiveValue(); event.preventDefault(); }, findNextTab: function findNextTab(tabElement) { var selfCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var element = selfCheck ? tabElement : tabElement.nextElementSibling; return element ? getAttribute(element, 'data-p-disabled') || getAttribute(element, 'data-pc-section') === 'activebar' ? this.findNextTab(element) : findSingle(element, '[data-pc-name="tab"]') : null; }, findPrevTab: function findPrevTab(tabElement) { var selfCheck = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false; var element = selfCheck ? tabElement : tabElement.previousElementSibling; return element ? getAttribute(element, 'data-p-disabled') || getAttribute(element, 'data-pc-section') === 'activebar' ? this.findPrevTab(element) : findSingle(element, '[data-pc-name="tab"]') : null; }, findFirstTab: function findFirstTab() { return this.findNextTab(this.$pcTabList.$refs.tabs.firstElementChild, true); }, findLastTab: function findLastTab() { return this.findPrevTab(this.$pcTabList.$refs.tabs.lastElementChild, true); }, changeActiveValue: function changeActiveValue() { this.$pcTabs.updateValue(this.value); }, changeFocusedTab: function changeFocusedTab(event, element) { focus(element); this.scrollInView(element); }, scrollInView: function scrollInView(element) { var _element$scrollIntoVi; element === null || element === void 0 || (_element$scrollIntoVi = element.scrollIntoView) === null || _element$scrollIntoVi === void 0 || _element$scrollIntoVi.call(element, { block: 'nearest' }); } }, computed: { active: function active() { var _this$$pcTabs; return equals((_this$$pcTabs = this.$pcTabs) === null || _this$$pcTabs === void 0 ? void 0 : _this$$pcTabs.d_value, this.value); }, id: function id() { var _this$$pcTabs2; return "".concat((_this$$pcTabs2 = this.$pcTabs) === null || _this$$pcTabs2 === void 0 ? void 0 : _this$$pcTabs2.$id, "_tab_").concat(this.value); }, ariaControls: function ariaControls() { var _this$$pcTabs3; return "".concat((_this$$pcTabs3 = this.$pcTabs) === null || _this$$pcTabs3 === void 0 ? void 0 : _this$$pcTabs3.$id, "_tabpanel_").concat(this.value); }, attrs: function attrs() { return mergeProps(this.asAttrs, this.a11yAttrs, this.ptmi('root', this.ptParams)); }, asAttrs: function asAttrs() { return this.as === 'BUTTON' ? { type: 'button', disabled: this.disabled } : undefined; }, a11yAttrs: function a11yAttrs() { return { id: this.id, tabindex: this.active ? this.$pcTabs.tabindex : -1, role: 'tab', 'aria-selected': this.active, 'aria-controls': this.ariaControls, 'data-pc-name': 'tab', 'data-p-disabled': this.disabled, 'data-p-active': this.active, onFocus: this.onFocus, onKeydown: this.onKeydown }; }, ptParams: function ptParams() { return { context: { active: this.active } }; }, dataP: function dataP() { return cn({ active: this.active }); } }, directives: { ripple: Ripple } }; function render(_ctx, _cache, $props, $setup, $data, $options) { var _directive_ripple = resolveDirective("ripple"); return !_ctx.asChild ? withDirectives((openBlock(), createBlock(resolveDynamicComponent(_ctx.as), mergeProps({ key: 0, "class": _ctx.cx('root'), "data-p": $options.dataP, onClick: $options.onClick }, $options.attrs), { "default": withCtx(function () { return [renderSlot(_ctx.$slots, "default")]; }), _: 3 }, 16, ["class", "data-p", "onClick"])), [[_directive_ripple]]) : renderSlot(_ctx.$slots, "default", { key: 1, dataP: $options.dataP, "class": normalizeClass(_ctx.cx('root')), active: $options.active, a11yAttrs: $options.a11yAttrs, onClick: $options.onClick }); } script.render = render; export { script as default }; //# sourceMappingURL=index.mjs.map