tdesign-vue-next
Version:
TDesign Component for vue-next
103 lines (99 loc) • 3.48 kB
JavaScript
/**
* tdesign v1.20.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-d9440b5f.js';
import { u as usePrefixClass } from '../_chunks/dep-4d7f902f.js';
import { u as useGlobalIcon } from '../_chunks/dep-b4a20622.js';
import '@babel/runtime/helpers/slicedToArray';
import '../_chunks/dep-dfeea6f5.js';
import '@babel/runtime/helpers/defineProperty';
import { useConfig } from '../config-provider/hooks/useConfig.js';
import '../_chunks/dep-a6042a25.js';
import '../_chunks/dep-41cafcc6.js';
import '../_chunks/dep-fb6bde9b.js';
import '../_chunks/dep-b3575781.js';
import '../_chunks/dep-43a3baa0.js';
import '../loading/index.js';
import '../loading/directive.js';
import '../loading/plugin.js';
import '../_chunks/dep-c9b67f18.js';
import '../loading/icon/gradient.js';
import '../_chunks/dep-cdc7f78f.js';
import '../_chunks/dep-9e860115.js';
import '@babel/runtime/helpers/objectWithoutProperties';
import '../_chunks/dep-9e2a2dff.js';
import '../loading/props.js';
import '../config-provider/utils/context.js';
import '../_chunks/dep-854d2777.js';
import 'dayjs';
import '@babel/runtime/helpers/createClass';
import '@babel/runtime/helpers/classCallCheck';
import '../_chunks/dep-c53cb022.js';
import '../message/props.js';
import '../message/message-list.js';
import '../popup/popup.js';
import '@popperjs/core';
import '../_chunks/dep-cc2cf248.js';
import '../popup/container.js';
import '../popup/props.js';
import '../_chunks/dep-b239e51b.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