tdesign-vue
Version:
71 lines (67 loc) • 3.06 kB
JavaScript
/**
* tdesign v1.12.1
* (c) 2025 tdesign
* @license MIT
*/
import _defineProperty from '@babel/runtime/helpers/defineProperty';
import { toRefs, computed } from '@vue/composition-api';
import useClassName from './useClassName.js';
import useCommonClassName from '../../hooks/useCommonClassName.js';
import { useConfig } from '../../config-provider/useConfig.js';
import '../../config-provider/context.js';
import 'lodash-es';
import '../../_common/js/global-config/default-config.js';
import '../../_common/js/global-config/locale/zh_CN.js';
import '../../_chunks/dep-b0659553.js';
import '@babel/runtime/helpers/typeof';
import '../../_chunks/dep-79359026.js';
import 'dayjs';
import '../../_common/js/global-config/t.js';
import '@babel/runtime/helpers/slicedToArray';
function formatCSSUnit(unit) {
if (!unit) return unit;
return isNaN(Number(unit)) ? unit : "".concat(unit, "px");
}
function useStyle(props) {
var _toRefs = toRefs(props),
bordered = _toRefs.bordered,
stripe = _toRefs.stripe,
hover = _toRefs.hover,
verticalAlign = _toRefs.verticalAlign,
height = _toRefs.height,
maxHeight = _toRefs.maxHeight,
tableContentWidth = _toRefs.tableContentWidth;
var _useClassName = useClassName(),
tableBaseClass = _useClassName.tableBaseClass,
tableAlignClasses = _useClassName.tableAlignClasses;
var _useCommonClassName = useCommonClassName(),
sizeClassNames = _useCommonClassName.sizeClassNames;
var _useConfig = useConfig("table", props.locale),
global = _useConfig.global;
var tableSize = computed(function () {
var _props$size;
return (_props$size = props.size) !== null && _props$size !== void 0 ? _props$size : global.value.size;
});
var tableClasses = computed(function () {
return [tableBaseClass.table, _defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty(_defineProperty({}, sizeClassNames[tableSize.value], tableSize.value !== "medium"), tableBaseClass.bordered, bordered.value), tableBaseClass.striped, stripe.value), tableBaseClass.hover, hover.value), tableBaseClass.loading, props.loading), tableBaseClass.affixedHeader, props.headerAffixedTop), tableBaseClass.rowspanAndColspan, props.rowspanAndColspan), tableBaseClass.horizontalBarAffixed, props.horizontalScrollAffixedBottom), tableBaseClass.footerAffixed, props.footerAffixedBottom), tableAlignClasses[verticalAlign.value], verticalAlign.value !== "middle")];
});
var tableContentStyles = computed(function () {
return {
height: formatCSSUnit(height.value),
maxHeight: formatCSSUnit(maxHeight.value)
};
});
var tableElementStyles = computed(function () {
return {
width: formatCSSUnit(tableContentWidth.value)
};
});
return {
sizeClassNames: sizeClassNames,
tableClasses: tableClasses,
tableElementStyles: tableElementStyles,
tableContentStyles: tableContentStyles
};
}
export { useStyle as default, formatCSSUnit };
//# sourceMappingURL=useStyle.js.map