xdesign-vue-next
Version:
XDesign Component for vue-next
106 lines (102 loc) • 4.05 kB
JavaScript
/**
* xdesign v1.0.6
* (c) 2023 xdesign
* @license MIT
*/
import { _ as __unplugin_components_2 } from '../_chunks/dep-ae5efda0.js';
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import { defineComponent, ref, computed, createVNode } from 'vue';
import props from './props.js';
import tabPanelProps from './tab-panel-props.js';
import useRipple from '../hooks/useRipple.js';
import { usePrefixClass, useCommonClassName } from '../hooks/useConfig.js';
import '../hooks/useKeepAnimation.js';
import '../config-provider/useConfig.js';
import 'lodash/isFunction';
import 'lodash/cloneDeep';
import 'lodash/isString';
import '../config-provider/context.js';
import 'lodash/mergeWith';
import 'lodash/merge';
import '../_common/js/global-config/default-config.js';
import '../_common/js/global-config/locale/en_US.js';
import '../_chunks/dep-3a1cce9f.js';
import 'lodash/isArray';
import '../utils/set-style.js';
var TTabNavItem = defineComponent({
name: "XTabNavItem",
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 classPrefix = usePrefixClass();
var _useCommonClassName = useCommonClassName(),
STATUS = _useCommonClassName.STATUS,
SIZE = _useCommonClassName.SIZE;
var removeBtnClick = function removeBtnClick(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 () {
var _ref;
return _ref = {}, _defineProperty(_ref, COMPONENT_NAME.value, true), _defineProperty(_ref, "".concat(classPrefix.value, "-tabs__nav--card"), props.theme === "card"), _defineProperty(_ref, STATUS.value.disabled, props.disabled), _defineProperty(_ref, STATUS.value.active, props.active), _defineProperty(_ref, "".concat(classPrefix.value, "-is-left"), props.placement === "left"), _defineProperty(_ref, "".concat(classPrefix.value, "-is-right"), props.placement === "right"), _defineProperty(_ref, SIZE.value.medium, props.size === "medium"), _defineProperty(_ref, SIZE.value.large, props.size === "large"), _ref;
});
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(__unplugin_components_2, {
"class": "remove-btn",
"onClick": removeBtnClick
}, null) : null]);
};
var renderNormalItem = function renderNormalItem() {
var _ref2;
return createVNode("div", {
"class": navItemClass.value,
"onClick": onClickNav
}, [createVNode("div", {
"class": ["".concat(COMPONENT_NAME.value, "-wrapper"), (_ref2 = {}, _defineProperty(_ref2, STATUS.value.disabled, props.disabled), _defineProperty(_ref2, STATUS.value.active, props.active), _ref2)],
"ref": itemRef
}, [createVNode("span", {
"class": "".concat(COMPONENT_NAME.value, "-text-wrapper")
}, [props.label])]), props.removable && !props.disabled ? createVNode(__unplugin_components_2, {
"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