UNPKG

tdesign-vue-next

Version:
154 lines (150 loc) 4.96 kB
/** * tdesign v1.20.3 * (c) 2026 tdesign * @license MIT */ import { defineComponent, ref, watch, createVNode, mergeProps } from 'vue'; import _defineProperty from '@babel/runtime/helpers/defineProperty'; import { Input } from '../../../input/index.js'; import { g as getColorObject, C as Color } from '../../../_chunks/dep-8911ca0d.js'; import '@babel/runtime/helpers/classCallCheck'; import '@babel/runtime/helpers/createClass'; import '@babel/runtime/helpers/toConsumableArray'; import { useBaseClassName } from '../../hooks/index.js'; import 'lodash-es'; import '@babel/runtime/helpers/typeof'; import '../../../_chunks/dep-9a792278.js'; import { u as useCommonClassName } from '../../../_chunks/dep-18ea1a72.js'; import '../../../config-provider/hooks/useConfig.js'; import '@babel/runtime/helpers/slicedToArray'; import '../../../_chunks/dep-f7f14b1f.js'; import { u as useEventForward } from '../../../_chunks/dep-792b62d1.js'; import '../../../input/input.js'; import '@babel/runtime/helpers/objectWithoutProperties'; import 'tdesign-icons-vue-next'; import '../../../input/props.js'; import '../../../_chunks/dep-9adf4ccf.js'; import '../../../_chunks/dep-5cf1c7d3.js'; import '../../../_chunks/dep-1b677277.js'; import '../../../_chunks/dep-5222f6e9.js'; import '../../../_chunks/dep-e529aa30.js'; import '../../../_chunks/dep-ed00a348.js'; import '../../../_chunks/dep-87a0ac30.js'; import '../../../input/hooks/useInput.js'; import '../../../form/constants/index.js'; import '../../../_chunks/dep-0ad1fea4.js'; import '../../../config-provider/utils/context.js'; import '../../../_chunks/dep-5db45404.js'; import 'dayjs'; import '../../../_chunks/dep-fea684ae.js'; import '../../../input/hooks/useLengthLimit.js'; import '../../../_chunks/dep-a0745515.js'; import '../../../_chunks/dep-c368cb39.js'; import '../../../input/hooks/useInputEventHandler.js'; import '../../../input/hooks/useInputWidth.js'; import '../../../_chunks/dep-a7226924.js'; import '../../../input/input-group.js'; import '../../../input/input-group-props.js'; import '../../../_chunks/dep-b4c7b05a.js'; import 'tinycolor2'; import '../../../_chunks/dep-7fd41c1d.js'; var DefaultTrigger = defineComponent({ name: "DefaultTrigger", inheritAttrs: false, props: { color: { type: String, "default": "" }, disabled: { type: Boolean, "default": false }, borderless: { type: Boolean, "default": false }, clearable: { type: Boolean, "default": false }, inputProps: { type: Object, "default": function _default() { return { autoWidth: true }; } }, onTriggerChange: { type: Function, "default": function _default() { return function () {}; } }, onTriggerClear: { type: Function, "default": function _default() { return function () {}; } }, size: { type: String, "default": "medium" } }, setup: function setup(props) { var baseClassName = useBaseClassName(); var value = ref(props.color); var _useCommonClassName = useCommonClassName(), sizeClassNames = _useCommonClassName.SIZE; watch(function () { return [props.color]; }, function () { return value.value = props.color; }); var handleChange = function handleChange(input) { if (input !== props.color) { props.onTriggerChange(value.value, { color: getColorObject(new Color(input)), trigger: "input" }); } }; var handleClear = function handleClear(context) { var _props$onTriggerClear; return (_props$onTriggerClear = props.onTriggerClear) === null || _props$onTriggerClear === void 0 ? void 0 : _props$onTriggerClear.call(props, context); }; var inputEvents = useEventForward(props.inputProps, { onBlur: handleChange, onChange: handleChange, onClear: handleClear }); return function () { var inputSlots = { label: function label() { return createVNode("div", { "class": ["".concat(baseClassName.value, "__trigger--default__color"), "".concat(baseClassName.value, "--bg-alpha")] }, [createVNode("span", { "class": ["color-inner", _defineProperty({}, sizeClassNames.value[props.size], props.size !== "medium")], "style": { background: value.value } }, null)]); } }; return createVNode(Input, mergeProps({ "borderless": props.borderless, "clearable": props.clearable, "size": props.size, "modelValue": value.value, "onUpdate:modelValue": function onUpdateModelValue($event) { return value.value = $event; }, "disabled": props.disabled }, inputEvents.value), inputSlots); }; } }); export { DefaultTrigger as default }; //# sourceMappingURL=index.js.map