tdesign-vue
Version:
100 lines (94 loc) • 3.24 kB
JavaScript
/**
* tdesign v1.12.1
* (c) 2025 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var VueCompositionAPI = require('@vue/composition-api');
var hooks_useConfig = require('../hooks/useConfig.js');
var escapeRegExp = require('../_chunks/dep-29bbf269.js');
require('../config-provider/useConfig.js');
require('../_chunks/dep-6247fdbf.js');
require('../_common/js/global-config/default-config.js');
require('../_common/js/global-config/locale/zh_CN.js');
require('../_chunks/dep-3ed0c42e.js');
require('@babel/runtime/helpers/typeof');
require('../_chunks/dep-53935099.js');
require('dayjs');
require('../_chunks/dep-403352a7.js');
require('../_chunks/dep-cca66fee.js');
require('../_chunks/dep-4361b357.js');
require('../_chunks/dep-887c649b.js');
require('../_chunks/dep-411a10dd.js');
require('../_chunks/dep-5ea2b00f.js');
require('../_chunks/dep-51fe98f1.js');
require('../_chunks/dep-3d682642.js');
require('../_chunks/dep-dea23841.js');
require('../_chunks/dep-d7270eaf.js');
require('../_chunks/dep-9b72cbc5.js');
require('../_chunks/dep-4aa08166.js');
require('../_chunks/dep-ddc1429e.js');
require('../_chunks/dep-65896ff9.js');
require('../_chunks/dep-b65b2f55.js');
require('../_chunks/dep-6e7b8cda.js');
require('../_chunks/dep-98f48ff2.js');
require('../_chunks/dep-80e3757f.js');
require('../_chunks/dep-08d7842c.js');
require('../_chunks/dep-1ca3138c.js');
require('../_chunks/dep-e6ed4b1f.js');
require('../_chunks/dep-c44b2462.js');
require('../_common/js/global-config/t.js');
require('@babel/runtime/helpers/slicedToArray');
require('../_chunks/dep-6b60413b.js');
require('../_chunks/dep-e1cc6f64.js');
require('../_chunks/dep-7b78e8c3.js');
var _HighlightOption = VueCompositionAPI.defineComponent({
name: "HighlightOption",
props: {
content: String,
keyword: String
},
setup: function setup(props) {
var classPrefix = hooks_useConfig.usePrefixClass();
var words = VueCompositionAPI.computed(function () {
var _content$match;
var content = props.content,
keyword = props.keyword;
if (!content) return {
list: []
};
if (typeof content !== "string" || !keyword) return {
list: [content]
};
var regExp = new RegExp(escapeRegExp.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 {
words: words,
classPrefix: classPrefix
};
},
render: function render() {
var _this = this;
var h = arguments[0];
var _this$words = this.words,
list = _this$words.list,
keyword = _this$words.keyword;
return h("div", {
"class": "".concat(this.classPrefix, "-select-option__highlight-item")
}, [list.map(function (item, index) {
if (!index) return item;
return [h("b", {
"class": "".concat(_this.classPrefix, "-is-highlight"),
"key": item + keyword
}, [keyword]), item];
})]);
}
});
exports["default"] = _HighlightOption;
//# sourceMappingURL=highlight-option.js.map