tdesign-vue-next
Version:
TDesign Component for vue-next
67 lines (63 loc) • 2.89 kB
JavaScript
/**
* tdesign v1.11.5
* (c) 2025 tdesign
* @license MIT
*/
import { _ as _toConsumableArray } from '../_chunks/dep-03e058e5.mjs';
import { _ as _defineProperty } from '../_chunks/dep-da95471f.mjs';
import { defineComponent, computed, createVNode } from 'vue';
import { usePrefixClass, useCommonClassName } from '../hooks/useConfig.mjs';
import { a as useContent, u as useTNodeJSX } from '../_chunks/dep-46ec3e86.mjs';
import { useDisabled } from '../hooks/useDisabled.mjs';
import props from './props.mjs';
import { useConfig } from '../config-provider/hooks/useConfig.mjs';
import '../_chunks/dep-9f375e51.mjs';
import '../_chunks/dep-4ed7019e.mjs';
import 'lodash-es';
import '../utils/render-tnode.mjs';
import '../config-provider/utils/context.mjs';
import '../_chunks/dep-a5ae2f3f.mjs';
import '../_chunks/dep-82d2a14f.mjs';
import '../_chunks/dep-37fa6ccb.mjs';
import '../_chunks/dep-7fb24b17.mjs';
var _Link = defineComponent({
name: "TLink",
props: props,
emits: ["click"],
setup: function setup(props2, _ref) {
var emit = _ref.emit;
var renderContent = useContent();
var renderTNodeJSX = useTNodeJSX();
var COMPONENT_NAME = usePrefixClass("link");
var _useCommonClassName = useCommonClassName(),
STATUS = _useCommonClassName.STATUS,
SIZE = _useCommonClassName.SIZE;
var _useConfig = useConfig("classPrefix"),
classPrefix = _useConfig.classPrefix;
var isDisabled = useDisabled();
var linkClass = computed(function () {
return ["".concat(COMPONENT_NAME.value), "".concat(COMPONENT_NAME.value, "--theme-").concat(props2.theme), _defineProperty(_defineProperty(_defineProperty(_defineProperty({}, SIZE.value[props2.size], props2.size !== "medium"), STATUS.value.disabled, isDisabled.value), "".concat(classPrefix.value, "-is-underline"), props2.underline), "".concat(COMPONENT_NAME.value, "--hover-").concat(props2.hover), !isDisabled.value)];
});
var handleClick = function handleClick(event) {
if (!isDisabled.value) emit("click", event);
};
return function () {
var linkContent = renderContent("default", "content");
var prefix = renderTNodeJSX("prefixIcon");
var suffix = renderTNodeJSX("suffixIcon");
return createVNode("a", {
"class": _toConsumableArray(linkClass.value),
"href": isDisabled.value || !props2.href ? void 0 : props2.href,
"target": !props2.target ? void 0 : props2.target,
"download": !props2.download ? void 0 : props2.download,
"onClick": handleClick
}, [prefix ? createVNode("span", {
"class": "".concat(COMPONENT_NAME.value, "__prefix-icon")
}, [prefix]) : null, linkContent, suffix ? createVNode("span", {
"class": "".concat(COMPONENT_NAME.value, "__suffix-icon")
}, [suffix]) : null]);
};
}
});
export { _Link as default };
//# sourceMappingURL=link.mjs.map