xdesign-vue-next
Version:
XDesign Component for vue-next
65 lines (61 loc) • 1.94 kB
JavaScript
/**
* xdesign v1.0.6
* (c) 2023 xdesign
* @license MIT
*/
import { defineComponent, computed, createVNode } from 'vue';
import { usePrefixClass } from '../hooks/useConfig.js';
import isString from 'lodash/isString';
import '../config-provider/useConfig.js';
import 'lodash/isFunction';
import 'lodash/cloneDeep';
import '../config-provider/context.js';
import 'lodash/mergeWith';
import 'lodash/merge';
import '../_common/js/global-config/default-config.js';
import '../_common/js/global-config/locale/en_US.js';
import '../_chunks/dep-3a1cce9f.js';
import 'lodash/isArray';
var _HighlightOption = defineComponent({
name: "XHighlightOption",
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(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.js.map