UNPKG

tdesign-vue-next

Version:
72 lines (68 loc) 2.34 kB
/** * tdesign v1.20.3 * (c) 2026 tdesign * @license MIT */ import { defineComponent, computed, createVNode } from 'vue'; import { u as usePrefixClass } from '../../_chunks/dep-5975d369.mjs'; import { isString, escapeRegExp } from 'lodash-es'; import '../../_chunks/dep-adf8ce39.mjs'; import '../../_chunks/dep-390963eb.mjs'; import '../../_chunks/dep-d84a2ec7.mjs'; import '../../_chunks/dep-12b4e978.mjs'; import '../../_chunks/dep-0841ee8f.mjs'; import '../../config-provider/hooks/useConfig.mjs'; import '../../config-provider/utils/context.mjs'; import '../../_chunks/dep-cf105282.mjs'; import '../../_chunks/dep-dcbc09c5.mjs'; import '../../_chunks/dep-9fc6972b.mjs'; import '../../_chunks/dep-ff183185.mjs'; import '../../_chunks/dep-a1cbfaae.mjs'; import '../../_chunks/dep-3f53eff0.mjs'; import '../../_chunks/dep-4c65e11b.mjs'; import '../../_chunks/dep-46776e3b.mjs'; import '../../_chunks/dep-07d8f2aa.mjs'; import '../../_chunks/dep-8aebe545.mjs'; var _HighlightOption = defineComponent({ name: "HighlightOption", props: { content: String, keyword: String }, setup: function setup(props) { var classPrefix = usePrefixClass(); var words = computed(function () { var _content$match; var content = props.content, keyword = props.keyword; if (!content) return { list: [] }; if (!isString(content) || !keyword) return { list: [content] }; var regExp = new RegExp(escapeRegExp(keyword), "i"); var splitKeyword = (_content$match = content.match(regExp)) === null || _content$match === void 0 ? void 0 : _content$match[0]; return { list: content.split(splitKeyword), keyword: splitKeyword }; }); return function () { var _words$value = words.value, list = _words$value.list, keyword = _words$value.keyword; return createVNode("div", { "class": "".concat(classPrefix.value, "-select-option__highlight-item") }, [list.map(function (item, index) { if (!index) return item; return [createVNode("b", { "class": "".concat(classPrefix.value, "-is-highlight"), "key": item + keyword }, [keyword]), item]; })]); }; } }); export { _HighlightOption as default }; //# sourceMappingURL=highlight-option.mjs.map