tdesign-vue-next
Version:
TDesign Component for vue-next
103 lines (99 loc) • 3.48 kB
JavaScript
/**
* tdesign v1.19.2
* (c) 2026 tdesign
* @license MIT
*/
import { defineComponent, createVNode } from 'vue';
import { FileCopyIcon } from 'tdesign-icons-vue-next';
import { copyText } from './utils/index.js';
import { MessagePlugin } from '../message/plugin.js';
import props from './anchor-target-props.js';
import { Popup } from '../popup/index.js';
import 'lodash-es';
import '@babel/runtime/helpers/toConsumableArray';
import '@babel/runtime/helpers/typeof';
import '../_chunks/dep-c68ea098.js';
import { u as usePrefixClass } from '../_chunks/dep-e8dd47a9.js';
import { u as useGlobalIcon } from '../_chunks/dep-52eae58a.js';
import '@babel/runtime/helpers/slicedToArray';
import '../_chunks/dep-91fc762d.js';
import '@babel/runtime/helpers/defineProperty';
import { useConfig } from '../config-provider/hooks/useConfig.js';
import '../_chunks/dep-f0f392fb.js';
import '../_chunks/dep-d518fdfb.js';
import '../message/message-list.js';
import '../_chunks/dep-81616fe9.js';
import '../_chunks/dep-7bdccf65.js';
import '../_chunks/dep-8d4d971b.js';
import '../loading/index.js';
import '../loading/directive.js';
import '../loading/plugin.js';
import '../_chunks/dep-2a7145b5.js';
import '../loading/icon/gradient.js';
import '../_chunks/dep-ef7a41ce.js';
import '../_chunks/dep-fbf70ecb.js';
import '@babel/runtime/helpers/objectWithoutProperties';
import '../_chunks/dep-98d89c71.js';
import '../loading/props.js';
import '../config-provider/utils/context.js';
import '../_chunks/dep-509ddbe3.js';
import 'dayjs';
import '@babel/runtime/helpers/createClass';
import '@babel/runtime/helpers/classCallCheck';
import '../_chunks/dep-ae3e94b6.js';
import '../message/props.js';
import '../popup/popup.js';
import '@popperjs/core';
import '../_chunks/dep-e332908e.js';
import '../popup/container.js';
import '../popup/props.js';
import '../_chunks/dep-d5fc4caa.js';
var _AnchorTarget = defineComponent({
name: "TAnchorTarget",
props: props,
setup: function setup(props2, _ref) {
var slots = _ref.slots;
var _useConfig = useConfig("anchor"),
globalConfig = _useConfig.globalConfig,
classPrefix = _useConfig.classPrefix;
var _useGlobalIcon = useGlobalIcon({
FileCopyIcon: FileCopyIcon
}),
FileCopyIcon$1 = _useGlobalIcon.FileCopyIcon;
var COMPONENT_NAME = usePrefixClass("anchor");
var toCopyText = function toCopyText() {
var a = document.createElement("a");
a.href = "#".concat(props2.id);
copyText(a.href);
MessagePlugin.success(globalConfig.value.copySuccessText, 1e3);
};
return function () {
var children = slots["default"];
var TAG = props2.tag,
id = props2.id;
var className = ["".concat(COMPONENT_NAME.value, "__target")];
var iconClassName = "".concat(classPrefix.value, "-copy");
return createVNode(TAG, {
"id": id,
"class": className
}, {
"default": function _default() {
return [children && children(null), createVNode(Popup, {
"content": globalConfig.value.copyText,
"placement": "top",
"showArrow": true,
"class": iconClassName
}, {
"default": function _default() {
return [createVNode(FileCopyIcon$1, {
"onClick": toCopyText
}, null)];
}
})];
}
});
};
}
});
export { _AnchorTarget as default };
//# sourceMappingURL=anchor-target.js.map