tdesign-vue-next
Version:
TDesign Component for vue-next
112 lines (108 loc) • 4.26 kB
JavaScript
/**
* tdesign v1.15.2
* (c) 2025 tdesign
* @license MIT
*/
import { defineComponent, ref, computed, createVNode } from 'vue';
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import { CloseIcon } from 'tdesign-icons-vue-next';
import props from './props.js';
import tabPanelProps from './tab-panel-props.js';
import 'lodash-es';
import '@babel/runtime/helpers/toConsumableArray';
import '@babel/runtime/helpers/typeof';
import '../_chunks/dep-e604a5ce.js';
import { u as useCommonClassName } from '../_chunks/dep-b9ab7399.js';
import { u as usePrefixClass } from '../_chunks/dep-79c44a11.js';
import { u as useGlobalIcon } from '../_chunks/dep-2ac22271.js';
import '@babel/runtime/helpers/slicedToArray';
import '../_chunks/dep-7324137b.js';
import { u as useRipple } from '../_chunks/dep-7b209207.js';
import '../_chunks/dep-7fac49fa.js';
import '../config-provider/hooks/useConfig.js';
import '../config-provider/utils/context.js';
import '../_chunks/dep-3b49fbbe.js';
import 'dayjs';
import '@babel/runtime/helpers/createClass';
import '@babel/runtime/helpers/classCallCheck';
import '../_chunks/dep-3ba91e12.js';
var TTabNavItem = defineComponent({
name: "TTabNavItem",
props: {
index: Number,
active: {
type: Boolean
},
theme: props.theme,
size: props.size,
placement: props.placement,
label: {
type: null
},
disabled: tabPanelProps.disabled,
removable: tabPanelProps.removable,
value: tabPanelProps.value,
onClick: Function,
onRemove: Function
},
setup: function setup(props) {
var itemRef = ref();
useRipple(itemRef);
var COMPONENT_NAME = usePrefixClass("tabs__nav-item");
var _useGlobalIcon = useGlobalIcon({
CloseIcon: CloseIcon
}),
CloseIcon$1 = _useGlobalIcon.CloseIcon;
var classPrefix = usePrefixClass();
var _useCommonClassName = useCommonClassName(),
STATUS = _useCommonClassName.STATUS,
SIZE = _useCommonClassName.SIZE;
var removeBtnClick = function removeBtnClick(_ref) {
var e = _ref.e;
if (e) e.stopPropagation();
props.onRemove({
e: e,
value: props.value,
index: props.index
});
};
var onClickNav = function onClickNav(e) {
if (props.disabled) return;
props.onClick(e);
};
var navItemClass = computed(function () {
return _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, COMPONENT_NAME.value, true), "".concat(classPrefix.value, "-tabs__nav--card"), props.theme === "card"), STATUS.value.disabled, props.disabled), STATUS.value.active, props.active), "".concat(classPrefix.value, "-is-left"), props.placement === "left"), "".concat(classPrefix.value, "-is-right"), props.placement === "right"), SIZE.value.medium, props.size === "medium"), SIZE.value.large, props.size === "large");
});
var renderCardItem = function renderCardItem() {
return createVNode("div", {
"class": navItemClass.value,
"onClick": onClickNav,
"ref": itemRef
}, [createVNode("span", {
"class": "".concat(COMPONENT_NAME.value, "-text-wrapper")
}, [props.label]), props.removable && !props.disabled ? createVNode(CloseIcon$1, {
"class": "remove-btn",
"onClick": removeBtnClick
}, null) : null]);
};
var renderNormalItem = function renderNormalItem() {
return createVNode("div", {
"class": navItemClass.value,
"onClick": onClickNav
}, [createVNode("div", {
"class": ["".concat(COMPONENT_NAME.value, "-wrapper"), _defineProperty(_defineProperty({}, STATUS.value.disabled, props.disabled), STATUS.value.active, props.active)],
"ref": itemRef
}, [createVNode("span", {
"class": "".concat(COMPONENT_NAME.value, "-text-wrapper")
}, [props.label])]), props.removable && !props.disabled ? createVNode(CloseIcon$1, {
"class": "remove-btn",
"onClick": removeBtnClick
}, null) : null]);
};
return function () {
return props.theme === "card" ? renderCardItem() : renderNormalItem();
};
}
});
export { TTabNavItem as default };
//# sourceMappingURL=tab-nav-item.js.map