@gnai/message-templates-vue
Version:
A flexible Vue 3 component library for rendering various platform message templates (WeChat, Xiaohongshu, Douyin, etc.)
314 lines (313 loc) • 19.2 kB
JavaScript
import { defineComponent as U, computed as B, createElementBlock as o, openBlock as d, normalizeStyle as I, normalizeClass as Q, createElementVNode as i, unref as m, toDisplayString as c } from "vue";
const F = "", t = {
avatar: "https://gnlab.com/assets/scene/icons/person.png",
link: "https://gnlab.com/assets/scene/icons/link.png"
}, b = (l) => {
var s, v, g, p, u, r, n, y, k, h, C;
const e = {
type: "text",
content: ""
};
try {
let A = l.wechat_data;
if (typeof A == "string" && A)
try {
A = JSON.parse(A);
} catch (j) {
console.error("Failed to parse WeChat message:", j);
}
const { wechat_type: f } = l, a = (A == null ? void 0 : A.content) || {};
switch (f) {
case 0:
e.type = "emoji", e.url = (l == null ? void 0 : l.file_url) || "";
break;
case 1:
case 2:
e.type = "link", e.content = (a == null ? void 0 : a.title) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.url) || "", e.avatar = (a == null ? void 0 : a.image_url) || t.link;
break;
case 100:
e.type = "link", e.content = ((s = a == null ? void 0 : a.link) == null ? void 0 : s.title) || "", e.desc = ((v = a == null ? void 0 : a.link) == null ? void 0 : v.des) || "", e.url = ((g = a == null ? void 0 : a.link) == null ? void 0 : g.url) || "", e.avatar = ((p = a == null ? void 0 : a.link) == null ? void 0 : p.thumb_url) || t.link;
break;
case 3:
e.type = "videonum", e.content = (a == null ? void 0 : a.nickname) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.cover_url) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
case 102:
e.type = "videonum", e.content = ((u = a == null ? void 0 : a.finder_feed) == null ? void 0 : u.name) || "", e.desc = "", e.url = ((r = a == null ? void 0 : a.finder_feed) == null ? void 0 : r.thumb) || "", e.avatar = ((n = a == null ? void 0 : a.finder_feed) == null ? void 0 : n.avatar) || t.avatar;
break;
case 4:
e.type = "miniprogram", e.content = (a == null ? void 0 : a.appname) || "", e.desc = (a == null ? void 0 : a.title) || "", e.url = (A == null ? void 0 : A.file_path) || "", e.avatar = (a == null ? void 0 : a.appicon) || t.avatar;
break;
case 101:
e.type = "miniprogram", e.content = ((y = a == null ? void 0 : a.miniprogram) == null ? void 0 : y.show_name) || "", e.desc = ((k = a == null ? void 0 : a.miniprogram) == null ? void 0 : k.title) || "", e.url = ((h = a == null ? void 0 : a.miniprogram) == null ? void 0 : h.cover_url) || "", e.avatar = ((C = a == null ? void 0 : a.miniprogram) == null ? void 0 : C.icon_url) || t.avatar;
break;
case 5:
e.type = "location", e.content = (a == null ? void 0 : a.title) || "", e.desc = (a == null ? void 0 : a.address) || "", e.url = `https://map.qq.com/?type=marker&isopeninfowin=1&markertype=1&pointx=${(a == null ? void 0 : a.longitude) || 0}&pointy=${(a == null ? void 0 : a.latitude) || 0}&name=${(a == null ? void 0 : a.title) || ""}&addr=${(a == null ? void 0 : a.address) || ""}`;
break;
case 6:
e.type = "emoji", e.url = (a == null ? void 0 : a.url) || "";
break;
case 7:
e.type = "card", e.content = (a == null ? void 0 : a.nickname) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
case 8:
e.type = "videonumlive", e.content = (a == null ? void 0 : a.nickname) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.cover_url) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
case "video":
e.type = "video", e.content = (a == null ? void 0 : a.content) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.url) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
case "audio":
e.type = "audio", e.content = (a == null ? void 0 : a.content) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.url) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
case "raw_file":
e.type = "file", e.content = (a == null ? void 0 : a.content) || "", e.desc = (a == null ? void 0 : a.desc) || "", e.url = (a == null ? void 0 : a.url) || "", e.avatar = (a == null ? void 0 : a.avatar) || t.avatar;
break;
default:
a != null && a.text || a != null && a.content ? (e.type = "text", e.content = (a == null ? void 0 : a.text) || (a == null ? void 0 : a.content) || "") : a != null && a.url && (a != null && a.url.includes("http") || a != null && a.url.includes("://")) ? (e.type = "link", e.content = (a == null ? void 0 : a.title) || (a == null ? void 0 : a.text) || "链接", e.url = a == null ? void 0 : a.url, e.avatar = (a == null ? void 0 : a.image_url) || t.link) : (e.type = "text", e.content = (a == null ? void 0 : a.text) || (a == null ? void 0 : a.content) || "未知消息类型");
}
} catch (A) {
console.error("Failed to parse WeChat message:", A), e.type = "text", e.content = "消息解析失败";
}
return e;
}, S = (l) => ({
type: "text",
content: ""
}), J = (l) => ({
type: "text",
content: ""
}), x = (l) => {
const e = l;
switch (e.platform) {
case "wechat":
return b(e.data);
case "xiaohongshu":
return S(e.data);
case "douyin":
return J(e.data);
default:
return {
type: "text",
content: "不支持的消息类型"
};
}
}, K = {
key: 0,
class: "person-content"
}, q = { class: "avatar" }, V = ["src"], _ = { class: "name" }, W = {
key: 1,
class: "image-wrapper"
}, R = ["src"], M = { class: "title" }, T = { class: "box" }, w = { class: "desc" }, Y = ["src"], G = { class: "title" }, O = { class: "desc" }, z = {
key: 4,
class: "minip-content"
}, N = { class: "name" }, P = { class: "avatar" }, L = ["src"], H = { class: "line-1" }, D = { class: "title line-2" }, X = { class: "cover" }, Z = ["src"], $ = {
key: 5,
class: "minip-content"
}, aa = { class: "name" }, ea = { class: "avatar" }, sa = ["src"], ia = { class: "line-1" }, la = { class: "title line-2" }, ra = { class: "cover" }, ta = ["src"], oa = {
key: 6,
class: "sph-content"
}, da = { class: "cover" }, Aa = ["src"], ca = { class: "bottom" }, ua = {
key: 7,
class: "audio-content"
}, ga = ["src"], va = {
key: 8,
class: "video-content"
}, pa = ["src"], na = {
key: 9,
class: "file-content"
}, ma = { class: "top" }, ya = { class: "left" }, ka = { class: "name" }, ha = {
key: 10,
class: "text-content"
}, Ca = ["innerHTML"], Ba = { key: 1 }, Ia = /* @__PURE__ */ U({
__name: "MessageTemplate",
props: {
message: {},
options: { default: () => ({}) }
},
setup(l) {
const e = l, s = B(() => x(e.message)), v = B(() => e.options.customStyles || {}), g = (u) => {
const r = u.target;
r.src = t.avatar;
}, p = (u) => {
e.options.onLinkClick ? e.options.onLinkClick(u) : window.open(u, "_blank");
};
return (u, r) => (d(), o("div", {
class: Q(["message-template", [`message-template--${u.options.theme || "light"}`, `message-template--${u.options.size || "medium"}`]]),
style: I(v.value)
}, [
i("div", {
class: Q(["message-template__content", s.value.type])
}, [
s.value.type === "card" ? (d(), o("div", K, [
i("div", q, [
i("img", {
src: s.value.avatar || m(t).avatar,
onError: g
}, null, 40, V)
]),
i("div", null, [
i("div", _, c(s.value.content), 1),
r[2] || (r[2] = i("div", { class: "person" }, "名片", -1))
])
])) : s.value.type === "emoji" ? (d(), o("div", W, [
i("img", {
src: s.value.url,
style: { objectFit: "cover", width: "200px" }
}, null, 8, R)
])) : s.value.type === "link" ? (d(), o("div", {
key: 2,
class: "link-content",
onClick: r[0] || (r[0] = (n) => s.value.url && p(s.value.url))
}, [
i("div", M, c(s.value.content), 1),
i("div", T, [
i("div", w, c(s.value.desc), 1),
i("img", {
src: s.value.avatar || m(t).link
}, null, 8, Y)
])
])) : s.value.type === "location" ? (d(), o("div", {
key: 3,
class: "position-content",
onClick: r[1] || (r[1] = (n) => s.value.url && p(s.value.url))
}, [
i("div", G, c(s.value.content), 1),
i("div", O, c(s.value.desc), 1)
])) : s.value.type === "miniprogram" ? (d(), o("div", z, [
i("div", N, [
i("div", P, [
i("img", {
src: s.value.avatar || m(t).avatar,
onError: g
}, null, 40, L)
]),
i("div", H, c(s.value.content), 1),
r[3] || (r[3] = i("div", { class: "label" }, "小程序", -1))
]),
i("div", D, c(s.value.desc), 1),
i("div", X, [
i("img", {
src: s.value.url,
width: "100%",
height: 220,
style: { objectFit: "cover", borderRadius: "2px" }
}, null, 8, Z)
])
])) : s.value.type === "videonum" ? (d(), o("div", $, [
i("div", aa, [
i("div", ea, [
i("img", {
src: s.value.avatar || m(t).avatar,
onError: g
}, null, 40, sa)
]),
i("div", ia, c(s.value.content), 1),
r[4] || (r[4] = i("div", { class: "label" }, "视频号", -1))
]),
i("div", la, c(s.value.desc), 1),
i("div", ra, [
i("img", {
src: s.value.url,
width: "100%",
height: 220,
style: { objectFit: "cover", borderRadius: "2px" }
}, null, 8, ta)
])
])) : s.value.type === "videonumlive" ? (d(), o("div", oa, [
i("div", da, [
i("img", {
class: "content-img",
src: s.value.url
}, null, 8, Aa)
]),
i("div", ca, [
r[5] || (r[5] = i("img", {
src: F,
alt: "",
style: { width: "24px", height: "24px" }
}, null, -1)),
i("span", {
style: I({ color: s.value.avatar ? "#fff" : "#000" })
}, c(s.value.content), 5)
])
])) : s.value.type === "audio" ? (d(), o("div", ua, [
i("audio", {
src: s.value.url,
controls: "",
controlslist: "nodownload noplaybackrate",
disablePictureInPicture: ""
}, null, 8, ga)
])) : s.value.type === "video" ? (d(), o("div", va, [
i("video", {
src: s.value.url,
style: { width: "220px" },
controls: "",
controlslist: "nodownload noplaybackrate",
disablePictureInPicture: ""
}, null, 8, pa)
])) : s.value.type === "file" ? (d(), o("div", na, [
i("div", ma, [
i("div", ya, [
i("div", ka, c(s.value.content), 1)
])
])
])) : (d(), o("div", ha, [
u.options.highlight ? (d(), o("span", {
key: 0,
class: "highlight",
innerHTML: s.value.content
}, null, 8, Ca)) : (d(), o("span", Ba, c(s.value.content), 1))
]))
], 2)
], 6));
}
}), Qa = (l, e) => {
const s = l.__vccOpts || l;
for (const [v, g] of e)
s[v] = g;
return s;
}, Ea = /* @__PURE__ */ Qa(Ia, [["__scopeId", "data-v-e27a5802"]]), E = {
wechat: {
name: "微信",
icon: "💬",
colors: {
primary: "#07C160",
secondary: "#2A313D",
background: "#FFFFFF"
},
messageTypes: ["text", "image", "video", "audio", "file", "link", "location", "card", "miniprogram", "videonum", "emoji"]
},
xiaohongshu: {
name: "小红书",
icon: "📖",
colors: {
primary: "#FF2442",
secondary: "#333333",
background: "#FFFFFF"
},
messageTypes: ["text"]
},
douyin: {
name: "抖音",
icon: "🎵",
colors: {
primary: "#000000",
secondary: "#333333",
background: "#FFFFFF"
},
messageTypes: ["text"]
}
}, ja = (l) => E[l] || E.wechat, Ua = {
install: (l) => {
l.component("MessageTemplate", Ea);
}
};
export {
Ea as MessageTemplate,
Ua as default,
t as defaultAssets,
ja as getPlatformConfig,
J as parseDouyinMessage,
x as parseMessage,
b as parseWeChatMessage,
S as parseXiaohongshuMessage,
E as platformConfigs
};