UNPKG

@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
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 };