UNPKG

tdesign-vue-next

Version:
150 lines (146 loc) 4.81 kB
/** * tdesign v1.20.2 * (c) 2026 tdesign * @license MIT */ import { defineComponent, ref, watch, createVNode, mergeProps } from 'vue'; import { _ as _defineProperty } from '../../../_chunks/dep-98dac781.mjs'; import { Input } from '../../../input/index.mjs'; import '../../utils/index.mjs'; import { useBaseClassName } from '../../hooks/index.mjs'; import { c as useCommonClassName, p as useEventForward } from '../../../_chunks/dep-9ce910b6.mjs'; import { g as getColorObject, C as Color } from '../../../_chunks/dep-6c281967.mjs'; import '../../../_chunks/dep-f038e2b4.mjs'; import '../../../input/input.mjs'; import '../../../_chunks/dep-4de66dd0.mjs'; import 'tdesign-icons-vue-next'; import '../../../input/props.mjs'; import '../../../input/hooks/index.mjs'; import '../../../input/hooks/useInput.mjs'; import '../../../_chunks/dep-ea5fbe21.mjs'; import '../../../_chunks/dep-26d65784.mjs'; import '../../../form/constants/index.mjs'; import 'lodash-es'; import '../../../_chunks/dep-557b68dd.mjs'; import '../../../_chunks/dep-05bddb06.mjs'; import '../../../_chunks/dep-57027bda.mjs'; import '../../../config-provider/hooks/useConfig.mjs'; import '../../../config-provider/utils/context.mjs'; import '../../../_chunks/dep-57949dcd.mjs'; import '../../../_chunks/dep-cafb5eac.mjs'; import '../../../_chunks/dep-f1da7269.mjs'; import '../../../_chunks/dep-192d0c88.mjs'; import '../../../_chunks/dep-652c99fe.mjs'; import '../../../_chunks/dep-5b369203.mjs'; import '../../../_chunks/dep-a4f55e3b.mjs'; import '../../../_chunks/dep-920eff5b.mjs'; import '../../../input/hooks/useLengthLimit.mjs'; import '../../../_chunks/dep-73946420.mjs'; import '../../../_chunks/dep-9b3b77bb.mjs'; import '../../../input/hooks/useInputEventHandler.mjs'; import '../../../input/hooks/useInputWidth.mjs'; import '../../../input/input-group.mjs'; import '../../../input/input-group-props.mjs'; import './style/css.mjs'; import '../../../_chunks/dep-863731bb.mjs'; import '../../../_chunks/dep-a8b40385.mjs'; 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.mjs.map