UNPKG

xdesign-vue-next

Version:

XDesign Component for vue-next

190 lines (186 loc) 6.84 kB
/** * xdesign v1.0.6 * (c) 2023 xdesign * @license MIT */ import { _ as _defineProperty } from '../_chunks/dep-f9e836af.mjs'; import { _ as _slicedToArray } from '../_chunks/dep-32d4c595.mjs'; import { defineComponent, toRefs, provide, createVNode, mergeProps } from 'vue'; import _TabPanel from './tab-panel.mjs'; import TTabNav from './tab-nav.mjs'; import props from './props.mjs'; import { useTNodeJSX } from '../hooks/tnode.mjs'; import { usePrefixClass } from '../hooks/useConfig.mjs'; import useVModel from '../hooks/useVModel.mjs'; import { i as isArray_1 } from '../_chunks/dep-a95026f2.mjs'; import '../_chunks/dep-82805301.mjs'; import '../_chunks/dep-89b966f4.mjs'; import './tab-panel-props.mjs'; import '../hooks/useDestroyOnClose.mjs'; import '../_chunks/dep-35169507.mjs'; import '../_chunks/dep-8b4428a1.mjs'; import '../_chunks/dep-6af44080.mjs'; import '../_chunks/dep-0c786bea.mjs'; import '../_chunks/dep-10a947a6.mjs'; import '../_chunks/dep-6ad18815.mjs'; import '../_chunks/dep-1cc1c24f.mjs'; import '../_chunks/dep-b75d8d74.mjs'; import '../_chunks/dep-e727a519.mjs'; import '../_chunks/dep-7dcfa37a.mjs'; import '../_chunks/dep-addc2a84.mjs'; import '../_common/js/tabs/base.mjs'; import './tab-nav-item.mjs'; import '../_chunks/dep-7f8588b1.mjs'; import '../hooks/useRipple.mjs'; import '../hooks/useKeepAnimation.mjs'; import '../_chunks/dep-b09f48fa.mjs'; import '../_chunks/dep-81c83986.mjs'; import '../_chunks/dep-6aa0223b.mjs'; import '../_chunks/dep-db381ece.mjs'; import '../_chunks/dep-5755c21c.mjs'; import '../_chunks/dep-7f239c43.mjs'; import '../_chunks/dep-6f04869e.mjs'; import '../_chunks/dep-d32fbbb3.mjs'; import '../_chunks/dep-dafada74.mjs'; import '../_chunks/dep-068e912d.mjs'; import '../_chunks/dep-6e7b37b8.mjs'; import '../_chunks/dep-e1ab85c5.mjs'; import '../_chunks/dep-5f0e0453.mjs'; import '../_chunks/dep-71f84cf2.mjs'; import '../_chunks/dep-0e832fc7.mjs'; import '../_chunks/dep-26bf361a.mjs'; import '../_chunks/dep-3ec3335a.mjs'; import '../_chunks/dep-ed4e7c50.mjs'; import '../_chunks/dep-a666b9ad.mjs'; import '../_common/js/global-config/default-config.mjs'; import '../_common/js/global-config/locale/en_US.mjs'; import '../config-provider/useConfig.mjs'; import '../_chunks/dep-91ac8f71.mjs'; import '../_chunks/dep-c4737535.mjs'; import '../_chunks/dep-69963a8c.mjs'; import '../_chunks/dep-8d1c9a23.mjs'; import '../_chunks/dep-03412fab.mjs'; import '../_chunks/dep-205ff58d.mjs'; import '../_chunks/dep-11fa9c2c.mjs'; import '../config-provider/type.mjs'; import '../utils/set-style.mjs'; import './tab-nav-bar.mjs'; import '../utils/helper.mjs'; import '../_chunks/dep-53e379cd.mjs'; import '../_chunks/dep-a628549d.mjs'; import '../_chunks/dep-4903a8a8.mjs'; import '../_chunks/dep-f4eba04c.mjs'; import '../_chunks/dep-735bcd0d.mjs'; import '../_chunks/dep-765678ef.mjs'; import '../_chunks/dep-8db27830.mjs'; import '../_chunks/dep-1bae6a97.mjs'; import '../_chunks/dep-5a2ce53e.mjs'; import '../_chunks/dep-23f91684.mjs'; import '../hooks/useListener.mjs'; import '../hooks/useDragSort.mjs'; import '../_chunks/dep-ae4bffa5.mjs'; import '../utils/render-tnode.mjs'; import '../_chunks/dep-9d7ebc32.mjs'; var _Tabs = defineComponent({ name: "XTabs", props: props, setup: function setup(props2) { var COMPONENT_NAME = usePrefixClass("tabs"); var classPrefix = usePrefixClass(); var renderTNodeJSX = useTNodeJSX(); var _toRefs = toRefs(props2), value = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = useVModel(value, modelValue, props2.defaultValue || "", props2.onChange), _useVModel2 = _slicedToArray(_useVModel, 2), tabValue = _useVModel2[0], setTabValue = _useVModel2[1]; provide("tabs", { value: tabValue }); var onTabAdd = function onTabAdd(context) { var _props2$onAdd; (_props2$onAdd = props2.onAdd) === null || _props2$onAdd === void 0 ? void 0 : _props2$onAdd.call(props2, { e: context.e }); }; var onTabChange = function onTabChange(value2) { setTabValue(value2); }; var onTabRemove = function onTabRemove(_ref) { var e = _ref.e, value2 = _ref.value, index = _ref.index; props2.onRemove({ value: value2, index: index, e: e }); }; var getSlotPanels = function getSlotPanels() { var content = renderTNodeJSX("default"); if (!content) return []; content = content.map(function (item) { if (item.children && isArray_1(item.children)) return item.children; return item; }).flat().filter(function (item) { return item.type.name === "XTabPanel"; }); return content; }; var renderHeader = function renderHeader() { var _props2$list, _ref2; var panels = ((_props2$list = props2.list) !== null && _props2$list !== void 0 && _props2$list.length ? props2.list : getSlotPanels()) || []; var panelsData = panels.map(function (item) { var selfItem = item; if (item.props) { Object.keys(item.props).forEach(function (key) { selfItem[key] = item.props[key]; }); } return selfItem; }); var tabNavProps = { theme: props2.theme, value: tabValue.value, size: props2.size, disabled: props2.disabled, placement: props2.placement, addable: props2.addable, panels: panelsData, dragSort: props2.dragSort }; return createVNode("div", { "class": (_ref2 = {}, _defineProperty(_ref2, "".concat(classPrefix.value, "-tabs__header"), true), _defineProperty(_ref2, "".concat(classPrefix.value, "-is-").concat(props2.placement), true), _ref2) }, [createVNode(TTabNav, mergeProps(tabNavProps, { "onDragSort": props2.onDragSort, "onChange": onTabChange, "onAdd": onTabAdd, "onRemove": onTabRemove }), null)]); }; var renderContent = function renderContent() { var _props2$list2; var panels = getSlotPanels(); if ((_props2$list2 = props2.list) !== null && _props2$list2 !== void 0 && _props2$list2.length) { return props2.list.map(function (item) { return createVNode(_TabPanel, mergeProps(item, { "onRemove": onTabRemove }), null); }); } if (panels && panels.length) { return createVNode("div", { "class": ["".concat(classPrefix.value, "-tabs__content")] }, [panels]); } }; return function () { return createVNode("div", { "class": [COMPONENT_NAME.value] }, [props2.placement !== "bottom" ? [renderHeader(), renderContent()] : [renderContent(), renderHeader()]]); }; } }); export { _Tabs as default }; //# sourceMappingURL=tabs.mjs.map