2023-09-02 01:27:33 +02:00
|
|
|
import { defineComponent, h } from "vue";
|
2020-12-26 02:01:32 +01:00
|
|
|
|
|
|
|
export default defineComponent({
|
|
|
|
props: {
|
|
|
|
src: {
|
|
|
|
type: String,
|
2020-12-26 02:47:36 +01:00
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
tag: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
2023-01-13 05:40:33 +01:00
|
|
|
default: "span",
|
2020-12-26 02:01:32 +01:00
|
|
|
},
|
2020-12-30 05:07:16 +01:00
|
|
|
textTag: {
|
|
|
|
type: String,
|
|
|
|
required: false,
|
|
|
|
default: null,
|
|
|
|
},
|
2020-12-26 02:01:32 +01:00
|
|
|
},
|
|
|
|
render() {
|
2020-12-26 02:47:36 +01:00
|
|
|
let str = this.src;
|
2023-01-13 05:40:33 +01:00
|
|
|
const parsed = [] as (string | { arg: string })[];
|
2020-12-26 02:47:36 +01:00
|
|
|
while (true) {
|
2023-01-13 05:40:33 +01:00
|
|
|
const nextBracketOpen = str.indexOf("{");
|
|
|
|
const nextBracketClose = str.indexOf("}");
|
2020-12-26 02:47:36 +01:00
|
|
|
|
|
|
|
if (nextBracketOpen === -1) {
|
|
|
|
parsed.push(str);
|
|
|
|
break;
|
|
|
|
}
|
2024-03-07 03:24:48 +01:00
|
|
|
if (nextBracketOpen > 0)
|
|
|
|
parsed.push(str.substring(0, nextBracketOpen + 1));
|
|
|
|
parsed.push({
|
|
|
|
arg: str.substring(nextBracketOpen + 1, nextBracketClose),
|
|
|
|
});
|
2020-12-26 02:47:36 +01:00
|
|
|
|
2024-03-07 03:24:48 +01:00
|
|
|
str = str.substring(nextBracketClose + 1);
|
2020-12-26 02:47:36 +01:00
|
|
|
}
|
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
return h(
|
|
|
|
this.tag,
|
|
|
|
parsed.map((x) =>
|
|
|
|
typeof x === "string"
|
|
|
|
? this.textTag
|
|
|
|
? h(this.textTag, x)
|
|
|
|
: x
|
|
|
|
: this.$slots[x.arg](),
|
|
|
|
),
|
|
|
|
);
|
2022-09-05 11:51:23 +02:00
|
|
|
},
|
2020-12-26 02:01:32 +01:00
|
|
|
});
|