@matechat/core 1.5.3 → 1.6.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/Input/index.css CHANGED
@@ -1 +1 @@
1
- @charset "UTF-8";.mc-textarea{width:100%;height:64px;padding:4px 0;color:var(--devui-text, #252b3a);font-size:var(--devui-font-size, 14px);background-color:var(--devui-form-control-bg, #ffffff);vertical-align:middle;outline:none;box-sizing:border-box;resize:none;border:none}.mc-textarea.mc-textarea-simple{height:32px}.mc-textarea.mc-textarea-disabled{color:var(--devui-disabled-text, #cfd0d3);background-color:var(--devui-disabled-bg, #f5f5f5);cursor:not-allowed}.mc-textarea::placeholder{color:var(--devui-placeholder, #babbc0)}.mc-button[data-v-183bc985]{position:relative;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;height:32px;line-height:1.5;color:var(--devui-light-text, #ffffff);font-size:var(--devui-font-size, 14px);padding:0 12px;border-radius:20px;background-color:var(--devui-primary, #5e7ce0);overflow:hidden;border:none;cursor:pointer;transition:background-color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1)),border-color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1)),color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1))}.mc-button.mc-button-loading svg[data-v-183bc985]{animation:rotating-183bc985 1s linear infinite}.mc-button.mousedown[data-v-183bc985]:not(:disabled){transform:scale(.95)}.mc-button.mc-button-simple[data-v-183bc985]{width:32px;padding:6px;flex-shrink:0;border-radius:100%}.mc-button.mc-button-simple svg[data-v-183bc985]{margin-right:0}.mc-button[data-v-183bc985]:hover{background-color:var(--devui-primary-hover, #7693f5)}.mc-button[data-v-183bc985]:active{background-color:var(--devui-primary-active, #344899)}.mc-button[data-v-183bc985]:disabled{color:var(--devui-light-text, #ffffff);background-color:var(--devui-primary-disabled, #beccfa);cursor:not-allowed}.mc-button .mc-button-content[data-v-183bc985]{display:inline-flex;align-items:center;font-size:var(--devui-font-size, 14px)}.mc-button .mc-button-water-wave[data-v-183bc985]{position:absolute;background-color:var(--devui-base-bg, #ffffff);border-radius:50%;opacity:0;width:20px;height:20px;transform:translate(-50%,-50%);animation:waterWave-183bc985 var(--devui-animation-duration-slow, .3s) var(--devui-animation-linear, cubic-bezier(0, 0, 1, 1))}.mc-button svg[data-v-183bc985]{margin-right:4px}.mc-button svg[data-v-183bc985] path{fill:var(--devui-light-text, #ffffff)}@keyframes rotating-183bc985{0%{transform:rotate(0)}to{transform:rotate(180deg)}}@keyframes waterWave-183bc985{0%{opacity:.2;width:30px;height:30px}to{opacity:0;width:200px;height:200px}}body[ui-theme=infinity-theme]{--mc-text: #aeaeae;--mc-box-shadow: rgba(25, 25, 25, .06)}body[ui-theme=galaxy-theme]{--mc-text: #4e5057;--mc-box-shadow: rgba(206, 209, 219, .06)}.mc-input{display:flex;flex-direction:column;width:100%;padding:12px 0;border:1px solid var(--devui-form-control-line, #d7d8da);border-radius:16px;box-sizing:border-box;background-color:var(--devui-base-bg, #ffffff)}.mc-input.mc-input-simple{border-radius:24px}.mc-input.mc-input-simple .mc-input-content{padding:0 20px}.mc-input.mc-input-borderless{border:none;box-shadow:0 1px 8px 0 var(--mc-box-shadow, rgba(25, 25, 25, .06))}.mc-input.mc-input-disabled{background-color:var(--devui-disabled-bg, #f5f5f5);cursor:not-allowed}.mc-input .mc-input-content{display:flex;align-items:flex-end;padding:0 16px}.mc-input .mc-input-foot{display:flex;justify-content:space-between;align-items:center;height:32px;padding:0 16px}.mc-input .mc-input-foot .mc-input-foot-left{flex:1;height:100%;display:flex;align-items:center}.mc-input .mc-input-foot .mc-input-foot-left .mc-input-foot-count{color:var(--mc-text, #aeaeae);font-size:var(--devui-font-size-sm, 12px)}
1
+ @charset "UTF-8";.mc-textarea{width:100%;height:64px;padding:4px 0;color:var(--devui-text, #252b3a);font-size:var(--devui-font-size, 14px);background-color:var(--devui-form-control-bg, #ffffff);vertical-align:middle;outline:none;box-sizing:border-box;resize:none;border:none}.mc-textarea.mc-textarea-simple{height:32px}.mc-textarea.mc-textarea-disabled{color:var(--devui-disabled-text, #cfd0d3);background-color:var(--devui-disabled-bg, #f5f5f5);cursor:not-allowed}.mc-textarea::placeholder{color:var(--devui-placeholder, #babbc0)}.mc-button[data-v-8b1b116f]{position:relative;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;height:32px;line-height:1.5;color:var(--devui-light-text, #ffffff);font-size:var(--devui-font-size, 14px);padding:0 12px;border-radius:20px;background-color:var(--devui-primary, #5e7ce0);overflow:hidden;border:none;cursor:pointer;transition:background-color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1)),border-color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1)),color var(--devui-animation-duration-slow, .3s) var(--devui-animation-ease-in-out-smooth, cubic-bezier(.645, .045, .355, 1))}.mc-button.mc-button-loading svg[data-v-8b1b116f]{animation:rotating-8b1b116f 1s linear infinite}.mc-button.mousedown[data-v-8b1b116f]:not(:disabled){transform:scale(.95)}.mc-button.mc-button-simple[data-v-8b1b116f]{width:32px;padding:6px;flex-shrink:0;border-radius:100%}.mc-button.mc-button-simple svg[data-v-8b1b116f]{margin-right:0}.mc-button[data-v-8b1b116f]:hover{background-color:var(--devui-primary-hover, #7693f5)}.mc-button[data-v-8b1b116f]:active{background-color:var(--devui-primary-active, #344899)}.mc-button[data-v-8b1b116f]:disabled{color:var(--devui-light-text, #ffffff);background-color:var(--devui-primary-disabled, #beccfa);cursor:not-allowed}.mc-button .mc-button-content[data-v-8b1b116f]{display:inline-flex;align-items:center;font-size:var(--devui-font-size, 14px)}.mc-button .mc-button-water-wave[data-v-8b1b116f]{position:absolute;background-color:var(--devui-base-bg, #ffffff);border-radius:50%;opacity:0;width:20px;height:20px;transform:translate(-50%,-50%);animation:waterWave-8b1b116f var(--devui-animation-duration-slow, .3s) var(--devui-animation-linear, cubic-bezier(0, 0, 1, 1))}.mc-button svg[data-v-8b1b116f]{margin-right:4px}.mc-button svg[data-v-8b1b116f] path{fill:var(--devui-light-text, #ffffff)}@keyframes rotating-8b1b116f{0%{transform:rotate(0)}to{transform:rotate(180deg)}}@keyframes waterWave-8b1b116f{0%{opacity:.2;width:30px;height:30px}to{opacity:0;width:200px;height:200px}}body[ui-theme=infinity-theme]{--mc-text: #aeaeae;--mc-box-shadow: rgba(25, 25, 25, .06)}body[ui-theme=galaxy-theme]{--mc-text: #4e5057;--mc-box-shadow: rgba(206, 209, 219, .06)}.mc-input{display:flex;flex-direction:column;width:100%;padding:12px 0;border:1px solid var(--devui-form-control-line, #d7d8da);border-radius:16px;box-sizing:border-box;background-color:var(--devui-base-bg, #ffffff)}.mc-input.mc-input-simple{border-radius:24px}.mc-input.mc-input-simple .mc-input-content{padding:0 20px}.mc-input.mc-input-borderless{border:none;box-shadow:0 1px 8px 0 var(--mc-box-shadow, rgba(25, 25, 25, .06))}.mc-input.mc-input-disabled{background-color:var(--devui-disabled-bg, #f5f5f5);cursor:not-allowed}.mc-input .mc-input-content{display:flex;align-items:flex-end;padding:0 16px}.mc-input .mc-input-foot{display:flex;justify-content:space-between;align-items:center;height:32px;padding:0 16px}.mc-input .mc-input-foot .mc-input-foot-left{flex:1;height:100%;display:flex;align-items:center}.mc-input .mc-input-foot .mc-input-foot-left .mc-input-foot-count{color:var(--mc-text, #aeaeae);font-size:var(--devui-font-size-sm, 12px)}
package/Input/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import "./index.css";
2
- import { defineComponent as k, inject as T, computed as M, withDirectives as j, createElementBlock as p, openBlock as u, normalizeClass as $, unref as n, isRef as z, vModelText as W, nextTick as A, createElementVNode as C, ref as S, reactive as O, createCommentVNode as _, createBlock as K, toDisplayString as x, normalizeStyle as R, watch as U, provide as X, renderSlot as v, createVNode as w } from "vue";
2
+ import { defineComponent as k, inject as T, computed as M, withDirectives as j, createElementBlock as p, openBlock as u, normalizeClass as $, unref as o, isRef as z, vModelText as W, nextTick as A, createElementVNode as C, ref as S, reactive as O, createCommentVNode as g, createBlock as K, toDisplayString as x, normalizeStyle as R, watch as U, provide as X, renderSlot as v, createVNode as w } from "vue";
3
3
  import { useMcI18n as F } from "@matechat/core/Locale";
4
- var b = /* @__PURE__ */ ((t) => (t.Simple = "simple", t.Full = "full", t))(b || {}), P = /* @__PURE__ */ ((t) => (t.Bordered = "bordered", t.BorderLess = "borderless", t))(P || {}), E = /* @__PURE__ */ ((t) => (t.Simple = "simple", t.Full = "full", t))(E || {}), y = /* @__PURE__ */ ((t) => (t.Enter = "enter", t.ShiftEnter = "shiftEnter", t))(y || {});
4
+ var _ = /* @__PURE__ */ ((t) => (t.Simple = "simple", t.Full = "full", t))(_ || {}), P = /* @__PURE__ */ ((t) => (t.Bordered = "bordered", t.BorderLess = "borderless", t))(P || {}), E = /* @__PURE__ */ ((t) => (t.Simple = "simple", t.Full = "full", t))(E || {}), y = /* @__PURE__ */ ((t) => (t.Enter = "enter", t.ShiftEnter = "shiftEnter", t))(y || {});
5
5
  const Y = {
6
6
  value: {
7
7
  type: String,
@@ -48,54 +48,54 @@ const Y = {
48
48
  }, q = ["change", "submit", "cancel", "focus", "blur"], B = "mc-input", G = ["placeholder", "disabled", "maxlength"], H = /* @__PURE__ */ k({
49
49
  __name: "textarea",
50
50
  setup(t) {
51
- const { t: o } = F(), { inputValue: s, rootProps: e, rootEmits: i } = T(B), a = M(() => {
52
- let r = "", f = "";
53
- return e.submitShortKey === y.Enter && (r = "Enter", f = "Shift + Enter"), e.submitShortKey === y.ShiftEnter && (r = "Shift + Enter", f = "Enter"), e.placeholder ?? (r ? o("Input.pleaseEnterPlaceholder", { enterKey: r, shiftEnterKey: f }) : o("Input.pleaseEnter"));
51
+ const { t: s } = F(), { inputValue: n, rootProps: e, rootEmits: i } = T(B), a = M(() => {
52
+ let r = "", m = "";
53
+ return e.submitShortKey === y.Enter && (r = "Enter", m = "Shift + Enter"), e.submitShortKey === y.ShiftEnter && (r = "Shift + Enter", m = "Enter"), e.placeholder ?? (r ? s("Input.pleaseEnterPlaceholder", { enterKey: r, shiftEnterKey: m }) : s("Input.pleaseEnter"));
54
54
  });
55
55
  let c = !1;
56
56
  const d = () => {
57
57
  A(() => {
58
- i("change", s.value);
58
+ i("change", n.value);
59
59
  });
60
60
  }, h = () => {
61
61
  c || d();
62
62
  }, l = () => {
63
63
  c = !0;
64
- }, g = () => {
64
+ }, b = () => {
65
65
  c = !1, d();
66
- }, m = (r) => {
66
+ }, f = (r) => {
67
67
  if (e.submitShortKey === null)
68
68
  return;
69
- (e.submitShortKey === y.Enter ? !r.shiftKey : e.submitShortKey === y.ShiftEnter ? r.shiftKey : !1) && r.key === "Enter" && !c && (r.preventDefault(), i("submit", s.value), s.value = "");
69
+ (e.submitShortKey === y.Enter ? !r.shiftKey : e.submitShortKey === y.ShiftEnter ? r.shiftKey : !1) && r.key === "Enter" && !c && (r.preventDefault(), i("submit", n.value), n.value = "", i("change", n.value));
70
70
  }, L = (r) => {
71
71
  i("focus", r);
72
72
  }, N = (r) => {
73
73
  i("blur", r);
74
74
  };
75
- return (r, f) => j((u(), p("textarea", {
76
- "onUpdate:modelValue": f[0] || (f[0] = (D) => z(s) ? s.value = D : null),
75
+ return (r, m) => j((u(), p("textarea", {
76
+ "onUpdate:modelValue": m[0] || (m[0] = (D) => z(n) ? n.value = D : null),
77
77
  placeholder: a.value,
78
- disabled: n(e).disabled,
79
- maxlength: n(e).maxLength,
78
+ disabled: o(e).disabled,
79
+ maxlength: o(e).maxLength,
80
80
  class: $([
81
81
  "mc-textarea",
82
- { "mc-textarea-simple": n(e).displayType === n(b).Simple, "mc-textarea-disabled": n(e).disabled }
82
+ { "mc-textarea-simple": o(e).displayType === o(_).Simple, "mc-textarea-disabled": o(e).disabled }
83
83
  ]),
84
84
  onInput: h,
85
85
  onCompositionstart: l,
86
- onCompositionend: g,
87
- onKeydown: m,
86
+ onCompositionend: b,
87
+ onKeydown: f,
88
88
  onFocus: L,
89
89
  onBlur: N
90
90
  }, null, 42, G)), [
91
- [W, n(s)]
91
+ [W, o(n)]
92
92
  ]);
93
93
  }
94
- }), I = (t, o) => {
95
- const s = t.__vccOpts || t;
96
- for (const [e, i] of o)
97
- s[e] = i;
98
- return s;
94
+ }), I = (t, s) => {
95
+ const n = t.__vccOpts || t;
96
+ for (const [e, i] of s)
97
+ n[e] = i;
98
+ return n;
99
99
  }, J = {}, Q = {
100
100
  width: "16px",
101
101
  height: "16px",
@@ -103,8 +103,8 @@ const Y = {
103
103
  version: "1.1",
104
104
  xmlns: "http://www.w3.org/2000/svg"
105
105
  };
106
- function e1(t, o) {
107
- return u(), p("svg", Q, o[0] || (o[0] = [
106
+ function e1(t, s) {
107
+ return u(), p("svg", Q, s[0] || (s[0] = [
108
108
  C(
109
109
  "g",
110
110
  {
@@ -128,8 +128,8 @@ const t1 = /* @__PURE__ */ I(J, [["render", e1]]), n1 = {}, o1 = {
128
128
  version: "1.1",
129
129
  xmlns: "http://www.w3.org/2000/svg"
130
130
  };
131
- function s1(t, o) {
132
- return u(), p("svg", o1, o[0] || (o[0] = [
131
+ function s1(t, s) {
132
+ return u(), p("svg", o1, s[0] || (s[0] = [
133
133
  C(
134
134
  "g",
135
135
  {
@@ -149,7 +149,7 @@ function s1(t, o) {
149
149
  const l1 = /* @__PURE__ */ I(n1, [["render", s1]]), r1 = ["disabled"], i1 = { class: "mc-button-content" }, a1 = { key: 2 }, u1 = /* @__PURE__ */ k({
150
150
  __name: "button",
151
151
  setup(t) {
152
- const { t: o } = F(), { inputValue: s, rootProps: e, rootEmits: i } = T(
152
+ const { t: s } = F(), { inputValue: n, rootProps: e, rootEmits: i } = T(
153
153
  B
154
154
  ), a = S(!1), c = S(!1), d = O({
155
155
  top: "0px",
@@ -159,29 +159,29 @@ const l1 = /* @__PURE__ */ I(n1, [["render", s1]]), r1 = ["disabled"], i1 = { cl
159
159
  "mc-button-loading": e.loading,
160
160
  mousedown: a.value,
161
161
  "mc-button-simple": e.sendBtnVariant === E.Simple
162
- })), l = (m) => {
163
- d.left = m.offsetX + "px", d.top = m.offsetY + "px", c.value = !0, setTimeout(() => {
162
+ })), l = (f) => {
163
+ d.left = f.offsetX + "px", d.top = f.offsetY + "px", c.value = !0, setTimeout(() => {
164
164
  c.value = !1;
165
165
  }, 300);
166
- }, g = (m) => {
167
- l(m), e.loading ? i("cancel") : (i("submit", s.value), s.value = "");
166
+ }, b = (f) => {
167
+ l(f), e.loading ? i("cancel") : (i("submit", n.value), n.value = "", i("change", n.value));
168
168
  };
169
- return (m, L) => (u(), p("button", {
170
- disabled: n(e).disabled || !n(e).loading && !n(s),
169
+ return (f, L) => (u(), p("button", {
170
+ disabled: o(e).disabled || !o(e).loading && !o(n),
171
171
  class: $(h.value),
172
- onClick: g,
172
+ onClick: b,
173
173
  onMousedown: L[0] || (L[0] = () => a.value = !0),
174
174
  onMouseup: L[1] || (L[1] = () => a.value = !1)
175
175
  }, [
176
176
  C("span", i1, [
177
- n(e).loading ? (u(), K(t1, { key: 0 })) : (u(), K(l1, { key: 1 })),
178
- n(e).sendBtnVariant === n(E).Full ? (u(), p(
177
+ o(e).loading ? (u(), K(t1, { key: 0 })) : (u(), K(l1, { key: 1 })),
178
+ o(e).sendBtnVariant === o(E).Full ? (u(), p(
179
179
  "span",
180
180
  a1,
181
- x(n(e).loading ? n(o)("Input.pauseAnswer") : n(o)("Input.send")),
181
+ x(o(e).loading ? o(s)("Input.pauseAnswer") : o(s)("Input.send")),
182
182
  1
183
183
  /* TEXT */
184
- )) : _("v-if", !0)
184
+ )) : g("v-if", !0)
185
185
  ]),
186
186
  c.value ? (u(), p(
187
187
  "div",
@@ -193,24 +193,24 @@ const l1 = /* @__PURE__ */ I(n1, [["render", s1]]), r1 = ["disabled"], i1 = { cl
193
193
  null,
194
194
  4
195
195
  /* STYLE */
196
- )) : _("v-if", !0)
196
+ )) : g("v-if", !0)
197
197
  ], 42, r1));
198
198
  }
199
- }), Z = /* @__PURE__ */ I(u1, [["__scopeId", "data-v-183bc985"]]), c1 = { class: "mc-input-content" }, p1 = {
199
+ }), Z = /* @__PURE__ */ I(u1, [["__scopeId", "data-v-8b1b116f"]]), c1 = { class: "mc-input-content" }, p1 = {
200
200
  key: 0,
201
201
  class: "mc-input-foot"
202
- }, d1 = { class: "mc-input-foot-left" }, m1 = {
202
+ }, d1 = { class: "mc-input-foot-left" }, f1 = {
203
203
  key: 0,
204
204
  class: "mc-input-foot-count"
205
205
  }, V = /* @__PURE__ */ k({
206
206
  __name: "Input",
207
207
  props: Y,
208
208
  emits: q,
209
- setup(t, { expose: o, emit: s }) {
210
- const e = t, i = s, a = S(""), c = M(() => ({
209
+ setup(t, { expose: s, emit: n }) {
210
+ const e = t, i = n, a = S(""), c = M(() => ({
211
211
  "mc-input": !0,
212
212
  "mc-input-disabled": e.disabled,
213
- "mc-input-simple": e.displayType === b.Simple,
213
+ "mc-input-simple": e.displayType === _.Simple,
214
214
  "mc-input-borderless": e.variant === P.BorderLess
215
215
  })), d = () => {
216
216
  a.value = "";
@@ -221,7 +221,7 @@ const l1 = /* @__PURE__ */ I(n1, [["render", s1]]), r1 = ["disabled"], i1 = { cl
221
221
  a.value = e.value;
222
222
  },
223
223
  { immediate: !0 }
224
- ), o({ clearInput: d, getInput: h }), X(B, { inputValue: a, rootProps: e, rootEmits: i }), (l, g) => (u(), p(
224
+ ), s({ clearInput: d, getInput: h }), X(B, { inputValue: a, rootProps: e, rootEmits: i }), (l, b) => (u(), p(
225
225
  "div",
226
226
  {
227
227
  class: $(c.value)
@@ -232,25 +232,25 @@ const l1 = /* @__PURE__ */ I(n1, [["render", s1]]), r1 = ["disabled"], i1 = { cl
232
232
  v(l.$slots, "prefix"),
233
233
  w(H),
234
234
  v(l.$slots, "suffix"),
235
- l.displayType === n(b).Simple ? v(l.$slots, "button", { key: 0 }, () => [
235
+ l.displayType === o(_).Simple ? v(l.$slots, "button", { key: 0 }, () => [
236
236
  w(Z)
237
- ]) : _("v-if", !0)
237
+ ]) : g("v-if", !0)
238
238
  ]),
239
- l.displayType === n(b).Full ? (u(), p("div", p1, [
239
+ l.displayType === o(_).Full ? (u(), p("div", p1, [
240
240
  C("div", d1, [
241
241
  v(l.$slots, "extra"),
242
242
  l.showCount ? (u(), p(
243
243
  "span",
244
- m1,
244
+ f1,
245
245
  x(a.value.length) + x(l.maxLength ?? !1 ? `/${l.maxLength}` : ""),
246
246
  1
247
247
  /* TEXT */
248
- )) : _("v-if", !0)
248
+ )) : g("v-if", !0)
249
249
  ]),
250
250
  v(l.$slots, "button", {}, () => [
251
251
  w(Z)
252
252
  ])
253
- ])) : _("v-if", !0)
253
+ ])) : g("v-if", !0)
254
254
  ],
255
255
  2
256
256
  /* CLASS */
package/List/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import "./index.css";
2
- import { computed as E, ref as L, onMounted as p, defineComponent as w, createElementBlock as u, openBlock as f, unref as c, normalizeClass as g, Fragment as b, renderList as z, renderSlot as h, createTextVNode as C, toDisplayString as T } from "vue";
3
- var v = /* @__PURE__ */ ((e) => (e.Horizontal = "horizontal", e.Vertical = "vertical", e))(v || {}), k = /* @__PURE__ */ ((e) => (e.Transparent = "transparent", e.Filled = "filled", e.Bordered = "bordered", e.None = "none", e))(k || {});
4
- const A = {
2
+ import { computed as E, ref as L, onMounted as p, onUnmounted as w, defineComponent as z, createElementBlock as f, openBlock as v, unref as c, normalizeClass as g, Fragment as b, renderList as C, renderSlot as h, createTextVNode as T, toDisplayString as A } from "vue";
3
+ var m = /* @__PURE__ */ ((e) => (e.Horizontal = "horizontal", e.Vertical = "vertical", e))(m || {}), k = /* @__PURE__ */ ((e) => (e.Transparent = "transparent", e.Filled = "filled", e.Bordered = "bordered", e.None = "none", e))(k || {});
4
+ const B = {
5
5
  direction: {
6
6
  type: String,
7
7
  default: "vertical"
@@ -35,85 +35,87 @@ const A = {
35
35
  type: Boolean,
36
36
  default: !0
37
37
  }
38
- }, B = 50, H = ["TEXTAREA", "INPUT"], I = "ArrowUp", _ = "ArrowDown", N = "Enter";
39
- function M(e, o) {
40
- const n = L(e.enableShortKey ? 0 : -1), i = (t) => {
38
+ }, H = 50, I = ["TEXTAREA", "INPUT"], _ = "ArrowUp", N = "ArrowDown", M = "Enter";
39
+ function D(e, r) {
40
+ let o;
41
+ const l = L(e.enableShortKey ? 0 : -1), i = (t) => {
41
42
  if (!t.disabled) {
42
43
  if (e.selectable)
43
- for (let l = 0; l < e.data.length; l++)
44
- e.data[l].active = e.data[l].value === t.value;
45
- o("select", { ...t });
44
+ for (let n = 0; n < e.data.length; n++)
45
+ e.data[n].active = e.data[n].value === t.value;
46
+ r("select", { ...t });
46
47
  }
47
- }, s = (t) => {
48
- if (!e.enableLazyLoad || e.direction !== v.Vertical)
48
+ }, y = (t) => {
49
+ if (!e.enableLazyLoad || e.direction !== m.Vertical)
49
50
  return;
50
- const l = t.target, r = l.scrollHeight, d = l.clientHeight, a = l.scrollTop;
51
- r - d - a < B && o("loadMore", t);
52
- }, m = (t) => {
53
- t.code === I && (n.value = n.value === 0 ? e.data.length - 1 : n.value - 1), t.code === _ && (n.value = n.value === e.data.length - 1 ? 0 : n.value + 1), t.code === N && (e.selectable && (e.data[n.value].active = !0), o("select", { ...e.data[n.value] }));
51
+ const n = t.target, d = n.scrollHeight, a = n.clientHeight, u = n.scrollTop;
52
+ d - a - u < H && r("loadMore", t);
53
+ }, s = (t) => {
54
+ t.code === _ && (l.value = l.value === 0 ? e.data.length - 1 : l.value - 1), t.code === N && (l.value = l.value === e.data.length - 1 ? 0 : l.value + 1), t.code === M && e.selectable && i(e.data[l.value]);
54
55
  };
55
56
  return p(() => {
56
- let t;
57
57
  if (e.inputEl) {
58
- const l = e.inputEl.$el ?? e.inputEl;
59
- H.includes(l.tagName) ? t = l : t = l.querySelector("textarea") || l.querySelector("input") || document;
58
+ const t = e.inputEl.$el ?? e.inputEl;
59
+ I.includes(t.tagName) ? o = t : o = t.querySelector("textarea") || t.querySelector("input") || document;
60
60
  } else
61
- t = document;
62
- e.enableShortKey && t.addEventListener("keydown", m);
63
- }), { preSelectIndex: n, onItemClick: i, onListScroll: s };
61
+ o = document;
62
+ e.enableShortKey && o.addEventListener("keydown", s);
63
+ }), w(() => {
64
+ o.removeEventListener("keydown", s);
65
+ }), { preSelectIndex: l, onItemClick: i, onListScroll: y };
64
66
  }
65
- function D(e) {
67
+ function K(e) {
66
68
  return { listClasses: E(() => ({
67
69
  "mc-list": !0,
68
- "mc-list-horizontal": e.direction === v.Horizontal,
69
- "mc-list-nowrap": e.direction === v.Horizontal && !e.autoWrap
70
+ "mc-list-horizontal": e.direction === m.Horizontal,
71
+ "mc-list-nowrap": e.direction === m.Horizontal && !e.autoWrap
70
72
  })) };
71
73
  }
72
- const K = ["onClick"], U = /* @__PURE__ */ w({
74
+ const U = ["onClick"], $ = /* @__PURE__ */ z({
73
75
  __name: "List",
74
- props: A,
76
+ props: B,
75
77
  emits: ["select", "loadMore"],
76
- setup(e, { emit: o }) {
77
- const n = e, i = o, { listClasses: s } = D(n), { preSelectIndex: m, onItemClick: t, onListScroll: l } = M(n, i);
78
- return (r, d) => (f(), u(
78
+ setup(e, { emit: r }) {
79
+ const o = e, l = r, { listClasses: i } = K(o), { preSelectIndex: y, onItemClick: s, onListScroll: t } = D(o, l);
80
+ return (n, d) => (v(), f(
79
81
  "div",
80
82
  {
81
- class: g(c(s)),
83
+ class: g(c(i)),
82
84
  onScroll: d[0] || (d[0] = //@ts-ignore
83
- (...a) => c(l) && c(l)(...a))
85
+ (...a) => c(t) && c(t)(...a))
84
86
  },
85
87
  [
86
- (f(!0), u(
88
+ (v(!0), f(
87
89
  b,
88
90
  null,
89
- z(r.data, (a, y) => (f(), u(
91
+ C(n.data, (a, u) => (v(), f(
90
92
  b,
91
- { key: y },
93
+ { key: u },
92
94
  [
93
- r.variant === c(k).None ? h(r.$slots, "item", {
95
+ n.variant === c(k).None ? h(n.$slots, "item", {
94
96
  key: 0,
95
97
  item: a
96
- }, void 0, !0) : (f(), u("div", {
98
+ }, void 0, !0) : (v(), f("div", {
97
99
  key: 1,
98
100
  class: g([
99
101
  "mc-list-item",
100
102
  {
101
103
  "mc-list-item-disabled": a.disabled,
102
104
  "mc-list-item-active": a.active,
103
- "mc-list-item-pre-selection": y === c(m)
105
+ "mc-list-item-pre-selection": u === c(y)
104
106
  },
105
- r.variant
107
+ n.variant
106
108
  ]),
107
- onClick: () => c(t)(a)
109
+ onClick: () => c(s)(a)
108
110
  }, [
109
- h(r.$slots, "item", { item: a }, () => [
110
- C(
111
- T(a.label),
111
+ h(n.$slots, "item", { item: a }, () => [
112
+ T(
113
+ A(a.label),
112
114
  1
113
115
  /* TEXT */
114
116
  )
115
117
  ], !0)
116
- ], 10, K))
118
+ ], 10, U))
117
119
  ],
118
120
  64
119
121
  /* STABLE_FRAGMENT */
@@ -126,18 +128,18 @@ const K = ["onClick"], U = /* @__PURE__ */ w({
126
128
  /* CLASS, NEED_HYDRATION */
127
129
  ));
128
130
  }
129
- }), $ = (e, o) => {
130
- const n = e.__vccOpts || e;
131
- for (const [i, s] of o)
132
- n[i] = s;
133
- return n;
134
- }, S = /* @__PURE__ */ $(U, [["__scopeId", "data-v-1a543233"]]);
131
+ }), q = (e, r) => {
132
+ const o = e.__vccOpts || e;
133
+ for (const [l, i] of r)
134
+ o[l] = i;
135
+ return o;
136
+ }, S = /* @__PURE__ */ q($, [["__scopeId", "data-v-1a543233"]]);
135
137
  S.install = (e) => {
136
138
  e.component("McList", S);
137
139
  };
138
140
  export {
139
- v as ListDirection,
141
+ m as ListDirection,
140
142
  k as ListVariant,
141
143
  S as McList,
142
- A as listProps
144
+ B as listProps
143
145
  };
package/Locale/index.js CHANGED
@@ -1,34 +1,34 @@
1
- import { ref as u, reactive as a } from "vue";
2
- function h(n) {
3
- return new p(n);
1
+ import { ref as u, reactive as l } from "vue";
2
+ function g(n) {
3
+ return new h(n);
4
4
  }
5
- let p = class {
5
+ let h = class {
6
6
  constructor(r) {
7
- this.locale = u("zh-cn"), this.messages = a({}), this.use = (e) => {
7
+ this.locale = u("zh-cn"), this.messages = l({}), this.use = (e) => {
8
8
  this.locale.value = e;
9
9
  }, this.t = (e, s = {}) => {
10
10
  const t = this.messages[this.locale.value];
11
- return f(e, s, t);
12
- }, this.mergeLocaleMessages = (e, s) => this.messages[e] ? (this.messages[e] = c(this.messages[e], s), c(this.messages[e], s)) : (this.messages[e] = s, this.messages), this.locale.value = r.locale, this.messages = a(r.messages);
11
+ return p(e, s, t);
12
+ }, this.mergeLocaleMessages = (e, s) => this.messages[e] ? (this.messages[e] = a(this.messages[e], s), a(this.messages[e], s)) : (this.messages[e] = s, this.messages), this.locale.value = r.locale, this.messages = l(r.messages);
13
13
  }
14
14
  };
15
- function f(n, r, e) {
15
+ function p(n, r, e) {
16
16
  const s = n.split(".");
17
17
  let t = e || {};
18
18
  return s.forEach((o) => {
19
19
  t = t[o] ?? n;
20
- }), typeof t == "function" ? t(r) : t.replace(/{(\w+)}/g, (o, l) => r[l] ?? `{${l}}`);
20
+ }), typeof t == "function" ? t(r) : t.replace(/{(\w+)}/g, (o, c) => r[c] ?? `{${c}}`);
21
21
  }
22
- function c(n, r) {
22
+ function a(n, r) {
23
23
  const e = { ...n };
24
24
  for (const s in r)
25
25
  if (Object.prototype.hasOwnProperty.call(r, s)) {
26
26
  const t = r[s], o = n[s];
27
- typeof t == "object" && t !== null ? typeof o == "object" && o !== null ? e[s] = c(o, t) : e[s] = { ...t } : e[s] = t;
27
+ typeof t == "object" && t !== null ? typeof o == "object" && o !== null ? e[s] = a(o, t) : e[s] = { ...t } : e[s] = t;
28
28
  }
29
29
  return e;
30
30
  }
31
- const g = {
31
+ const f = {
32
32
  Input: {
33
33
  send: "Send",
34
34
  pauseAnswer: "Stop",
@@ -37,9 +37,11 @@ const g = {
37
37
  },
38
38
  Md: {
39
39
  toggle: "Collapse/Expand",
40
- copy: "Copy"
40
+ copy: "Copy",
41
+ diagram: "Diagram",
42
+ code: "Code"
41
43
  }
42
- }, y = {
44
+ }, d = {
43
45
  Input: {
44
46
  send: "发送",
45
47
  pauseAnswer: "停止回答",
@@ -48,14 +50,16 @@ const g = {
48
50
  },
49
51
  Md: {
50
52
  toggle: "收起/展开",
51
- copy: "复制"
53
+ copy: "复制",
54
+ diagram: "图形",
55
+ code: "代码"
52
56
  }
53
- }, M = {
54
- "en-us": g,
55
- "zh-cn": y
56
- }, i = h({
57
+ }, y = {
58
+ "en-us": f,
59
+ "zh-cn": d
60
+ }, i = g({
57
61
  locale: "zh-cn",
58
- messages: M
62
+ messages: y
59
63
  });
60
64
  function E() {
61
65
  return i;
@@ -0,0 +1,53 @@
1
+ class n {
2
+ constructor(i = {}) {
3
+ this.config = i, this.mermaidInstance = null, this.isLoading = !1, this.lastValidResult = "";
4
+ }
5
+ async loadMermaid() {
6
+ if (this.mermaidInstance)
7
+ return this.mermaidInstance;
8
+ if (this.isLoading)
9
+ return new Promise((i) => {
10
+ const t = () => {
11
+ this.mermaidInstance ? i(this.mermaidInstance) : setTimeout(t, 50);
12
+ };
13
+ t();
14
+ });
15
+ this.isLoading = !0;
16
+ try {
17
+ const { default: i } = await import("mermaid");
18
+ return i.initialize({
19
+ theme: this.config.theme || "default",
20
+ ...this.config
21
+ }), this.mermaidInstance = i, i;
22
+ } catch (i) {
23
+ throw console.error("Failed to load mermaid:", i), new Error("Failed to load mermaid library");
24
+ } finally {
25
+ this.isLoading = !1;
26
+ }
27
+ }
28
+ async validateMermaidSyntax(i) {
29
+ try {
30
+ return await (await this.loadMermaid()).parse(i), !0;
31
+ } catch {
32
+ return !1;
33
+ }
34
+ }
35
+ async renderMermaid(i, t = "light") {
36
+ if (!await this.validateMermaidSyntax(i))
37
+ return this.lastValidResult;
38
+ try {
39
+ const a = await this.loadMermaid();
40
+ this.config.theme !== t && (this.config.theme = t, a.initialize({
41
+ ...this.config,
42
+ theme: t === "dark" ? "dark" : "default"
43
+ }));
44
+ const r = `mermaid_${Date.now()}_${Math.random().toString(36).substr(2, 9)}`, { svg: e } = await a.render(r, i);
45
+ return this.lastValidResult = e, e;
46
+ } catch {
47
+ return this.lastValidResult;
48
+ }
49
+ }
50
+ }
51
+ export {
52
+ n as MermaidService
53
+ };
@@ -1 +1 @@
1
- .mc-code-block-light[data-v-cb99045f] pre code.hljs{display:block;overflow-x:auto;padding:1em}.mc-code-block-light[data-v-cb99045f] code.hljs{padding:3px 5px}.mc-code-block-light[data-v-cb99045f] .hljs{background:#fefefe;color:#545454}.mc-code-block-light[data-v-cb99045f] .hljs-comment,.mc-code-block-light[data-v-cb99045f] .hljs-quote{color:#696969}.mc-code-block-light[data-v-cb99045f] .hljs-variable,.mc-code-block-light[data-v-cb99045f] .hljs-template-variable,.mc-code-block-light[data-v-cb99045f] .hljs-tag,.mc-code-block-light[data-v-cb99045f] .hljs-name,.mc-code-block-light[data-v-cb99045f] .hljs-selector-id,.mc-code-block-light[data-v-cb99045f] .hljs-selector-class,.mc-code-block-light[data-v-cb99045f] .hljs-regexp,.mc-code-block-light[data-v-cb99045f] .hljs-deletion{color:#d91e18}.mc-code-block-light[data-v-cb99045f] .hljs-number,.mc-code-block-light[data-v-cb99045f] .hljs-built_in,.mc-code-block-light[data-v-cb99045f] .hljs-literal,.mc-code-block-light[data-v-cb99045f] .hljs-type,.mc-code-block-light[data-v-cb99045f] .hljs-params,.mc-code-block-light[data-v-cb99045f] .hljs-meta,.mc-code-block-light[data-v-cb99045f] .hljs-link,.mc-code-block-light[data-v-cb99045f] .hljs-attribute{color:#aa5d00}.mc-code-block-light[data-v-cb99045f] .hljs-string,.mc-code-block-light[data-v-cb99045f] .hljs-symbol,.mc-code-block-light[data-v-cb99045f] .hljs-bullet,.mc-code-block-light[data-v-cb99045f] .hljs-addition{color:green}.mc-code-block-light[data-v-cb99045f] .hljs-title,.mc-code-block-light[data-v-cb99045f] .hljs-section{color:#007faa}.mc-code-block-light[data-v-cb99045f] .hljs-keyword,.mc-code-block-light[data-v-cb99045f] .hljs-selector-tag{color:#7928a1}.mc-code-block-light[data-v-cb99045f] .hljs-emphasis{font-style:italic}.mc-code-block-light[data-v-cb99045f] .hljs-strong{font-weight:700}@media screen and (-ms-high-contrast: active){.mc-code-block-light[data-v-cb99045f] .hljs-addition,.mc-code-block-light[data-v-cb99045f] .hljs-attribute,.mc-code-block-light[data-v-cb99045f] .hljs-built_in,.mc-code-block-light[data-v-cb99045f] .hljs-bullet,.mc-code-block-light[data-v-cb99045f] .hljs-comment,.mc-code-block-light[data-v-cb99045f] .hljs-link,.mc-code-block-light[data-v-cb99045f] .hljs-literal,.mc-code-block-light[data-v-cb99045f] .hljs-meta,.mc-code-block-light[data-v-cb99045f] .hljs-number,.mc-code-block-light[data-v-cb99045f] .hljs-params,.mc-code-block-light[data-v-cb99045f] .hljs-string,.mc-code-block-light[data-v-cb99045f] .hljs-symbol,.mc-code-block-light[data-v-cb99045f] .hljs-type,.mc-code-block-light[data-v-cb99045f] .hljs-quote{color:highlight}.mc-code-block-light[data-v-cb99045f] .hljs-keyword,.mc-code-block-light[data-v-cb99045f] .hljs-selector-tag{font-weight:700}}.mc-code-block-dark[data-v-cb99045f] pre code.hljs{display:block;overflow-x:auto;padding:1em}.mc-code-block-dark[data-v-cb99045f] code.hljs{padding:3px 5px}.mc-code-block-dark[data-v-cb99045f] .hljs{background:#2b2b2b;color:#f8f8f2}.mc-code-block-dark[data-v-cb99045f] .hljs-comment,.mc-code-block-dark[data-v-cb99045f] .hljs-quote{color:#d4d0ab}.mc-code-block-dark[data-v-cb99045f] .hljs-variable,.mc-code-block-dark[data-v-cb99045f] .hljs-template-variable,.mc-code-block-dark[data-v-cb99045f] .hljs-tag,.mc-code-block-dark[data-v-cb99045f] .hljs-name,.mc-code-block-dark[data-v-cb99045f] .hljs-selector-id,.mc-code-block-dark[data-v-cb99045f] .hljs-selector-class,.mc-code-block-dark[data-v-cb99045f] .hljs-regexp,.mc-code-block-dark[data-v-cb99045f] .hljs-deletion{color:#ffa07a}.mc-code-block-dark[data-v-cb99045f] .hljs-number,.mc-code-block-dark[data-v-cb99045f] .hljs-built_in,.mc-code-block-dark[data-v-cb99045f] .hljs-literal,.mc-code-block-dark[data-v-cb99045f] .hljs-type,.mc-code-block-dark[data-v-cb99045f] .hljs-params,.mc-code-block-dark[data-v-cb99045f] .hljs-meta,.mc-code-block-dark[data-v-cb99045f] .hljs-link{color:#f5ab35}.mc-code-block-dark[data-v-cb99045f] .hljs-attribute{color:gold}.mc-code-block-dark[data-v-cb99045f] .hljs-string,.mc-code-block-dark[data-v-cb99045f] .hljs-symbol,.mc-code-block-dark[data-v-cb99045f] .hljs-bullet,.mc-code-block-dark[data-v-cb99045f] .hljs-addition{color:#abe338}.mc-code-block-dark[data-v-cb99045f] .hljs-title,.mc-code-block-dark[data-v-cb99045f] .hljs-section{color:#00e0e0}.mc-code-block-dark[data-v-cb99045f] .hljs-keyword,.mc-code-block-dark[data-v-cb99045f] .hljs-selector-tag{color:#dcc6e0}.mc-code-block-dark[data-v-cb99045f] .hljs-emphasis{font-style:italic}.mc-code-block-dark[data-v-cb99045f] .hljs-strong{font-weight:700}@media screen and (-ms-high-contrast: active){.mc-code-block-dark[data-v-cb99045f] .hljs-addition,.mc-code-block-dark[data-v-cb99045f] .hljs-attribute,.mc-code-block-dark[data-v-cb99045f] .hljs-built_in,.mc-code-block-dark[data-v-cb99045f] .hljs-bullet,.mc-code-block-dark[data-v-cb99045f] .hljs-comment,.mc-code-block-dark[data-v-cb99045f] .hljs-link,.mc-code-block-dark[data-v-cb99045f] .hljs-literal,.mc-code-block-dark[data-v-cb99045f] .hljs-meta,.mc-code-block-dark[data-v-cb99045f] .hljs-number,.mc-code-block-dark[data-v-cb99045f] .hljs-params,.mc-code-block-dark[data-v-cb99045f] .hljs-string,.mc-code-block-dark[data-v-cb99045f] .hljs-symbol,.mc-code-block-dark[data-v-cb99045f] .hljs-type,.mc-code-block-dark[data-v-cb99045f] .hljs-quote{color:highlight}.mc-code-block-dark[data-v-cb99045f] .hljs-keyword,.mc-code-block-dark[data-v-cb99045f] .hljs-selector-tag{font-weight:700}}.v-enter-active[data-v-cb99045f],.v-leave-active[data-v-cb99045f]{transition:opacity .5s ease}.v-enter-from[data-v-cb99045f],.v-leave-to[data-v-cb99045f]{opacity:0}.mc-code-block[data-v-cb99045f]{margin:1rem 0;overflow:hidden;border-radius:14px}.mc-code-block pre[data-v-cb99045f]{margin:0}.mc-code-block .mc-action-btn[data-v-cb99045f]{width:24px;height:24px}.mc-code-block .mc-code-block-header[data-v-cb99045f]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem}.mc-code-block .mc-code-block-header .mc-code-lang[data-v-cb99045f]{font-size:var(--devui-font-size, 14px)}.mc-code-block .mc-code-block-actions[data-v-cb99045f]{display:flex;align-items:center}.mc-code-block .mc-code-block-actions .mc-copy-btn[data-v-cb99045f],.mc-code-block .mc-code-block-actions .mc-toggle-btn[data-v-cb99045f]{cursor:pointer;border-radius:4px;font-size:18px;padding:4px}.mc-code-block-light[data-v-cb99045f]{border:1px solid #d7d8da;background-color:#f5f5f5}.mc-code-block-light code.hljs[data-v-cb99045f]{padding:1em}.mc-code-block-light .mc-code-lang[data-v-cb99045f],.mc-code-block-light .mc-code-block-actions .mc-copy-btn[data-v-cb99045f],.mc-code-block-light .mc-code-block-actions .mc-toggle-btn[data-v-cb99045f]{color:#252b3a}.mc-code-block-light .mc-code-block-actions .mc-copy-btn[data-v-cb99045f]:hover,.mc-code-block-light .mc-code-block-actions .mc-toggle-btn[data-v-cb99045f]:hover{background-color:#ebebeb}.mc-code-block-dark[data-v-cb99045f]{border:1px solid #4e5057;background-color:#34363a}.mc-code-block-dark code.hljs[data-v-cb99045f]{padding:1em}.mc-code-block-dark .mc-code-lang[data-v-cb99045f],.mc-code-block-dark .mc-code-block-actions .mc-copy-btn[data-v-cb99045f],.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn[data-v-cb99045f]{color:#ced1db}.mc-code-block-dark .mc-code-block-actions .mc-copy-btn[data-v-cb99045f]:hover,.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn[data-v-cb99045f]:hover{background-color:#393a3e}.mc-code-block-dark .mc-code-block-actions .mc-copy-btn img[data-v-cb99045f],.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn img[data-v-cb99045f]{filter:brightness(1.5)}.collapse-transition-enter-from[data-v-cb99045f],.collapse-transition-leave-to[data-v-cb99045f]{opacity:0}.collapse-transition-enter-to[data-v-cb99045f],.collapse-transition-leave-from[data-v-cb99045f]{opacity:1}.collapse-transition-enter-active[data-v-cb99045f],.collapse-transition-leave-active[data-v-cb99045f]{transition:max-height .3s cubic-bezier(.5,.05,.5,.95),opacity .3s cubic-bezier(.5,.05,.5,.95)}.mc-markdown-render[data-v-6987322b] ul,.mc-markdown-render[data-v-6987322b] ol{list-style:none;margin:0;padding:0}.mc-markdown-render[data-v-6987322b] ul{list-style-type:disc;padding-left:16px}.mc-markdown-render[data-v-6987322b] ol{list-style-type:decimal;padding-left:16px}.mc-markdown-render[data-v-6987322b] p{line-height:28px;margin:0;padding:0;overflow-wrap:break-word}.mc-markdown-render[data-v-6987322b] h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render[data-v-6987322b] h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render[data-v-6987322b] table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render[data-v-6987322b] td,.mc-markdown-render[data-v-6987322b] th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render[data-v-6987322b] caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render[data-v-6987322b] th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render[data-v-6987322b] td p{margin:0;padding:0}.mc-markdown-render[data-v-6987322b] .h1,.mc-markdown-render[data-v-6987322b] .h2,.mc-markdown-render[data-v-6987322b] .h3,.mc-markdown-render[data-v-6987322b] .h4,.mc-markdown-render[data-v-6987322b] .h5,.mc-markdown-render[data-v-6987322b] .h6,.mc-markdown-render[data-v-6987322b] h1,.mc-markdown-render[data-v-6987322b] h2,.mc-markdown-render[data-v-6987322b] h3,.mc-markdown-render[data-v-6987322b] h4,.mc-markdown-render[data-v-6987322b] h5,.mc-markdown-render[data-v-6987322b] h6{line-height:1.1}.mc-markdown-render[data-v-6987322b] blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render[data-v-6987322b] a{color:var(--devui-link, #526ecc);text-decoration:underline;cursor:pointer}.mc-markdown-render[data-v-6987322b] a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render[data-v-6987322b] img{max-width:100%}.mc-markdown-render[data-v-6987322b]{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark[data-v-6987322b]{color:#ced1db}.mc-markdown-render.mc-markdown-render-light[data-v-6987322b]{color:#252b3a}[data-v-6987322b] .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}[data-v-6987322b] .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}[data-v-6987322b] .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}[data-v-6987322b] .mc-typewriter-cursor{font-weight:900;animation:typewriter-6987322b .8s linear 0s infinite}@keyframes typewriter-6987322b{0%{opacity:1}50%{opacity:0}to{opacity:1}}
1
+ .mc-code-block-light[data-v-a7f19fa4] pre code.hljs{display:block;overflow-x:auto;padding:1em}.mc-code-block-light[data-v-a7f19fa4] code.hljs{padding:3px 5px}.mc-code-block-light[data-v-a7f19fa4] .hljs{background:#fefefe;color:#545454}.mc-code-block-light[data-v-a7f19fa4] .hljs-comment,.mc-code-block-light[data-v-a7f19fa4] .hljs-quote{color:#696969}.mc-code-block-light[data-v-a7f19fa4] .hljs-variable,.mc-code-block-light[data-v-a7f19fa4] .hljs-template-variable,.mc-code-block-light[data-v-a7f19fa4] .hljs-tag,.mc-code-block-light[data-v-a7f19fa4] .hljs-name,.mc-code-block-light[data-v-a7f19fa4] .hljs-selector-id,.mc-code-block-light[data-v-a7f19fa4] .hljs-selector-class,.mc-code-block-light[data-v-a7f19fa4] .hljs-regexp,.mc-code-block-light[data-v-a7f19fa4] .hljs-deletion{color:#d91e18}.mc-code-block-light[data-v-a7f19fa4] .hljs-number,.mc-code-block-light[data-v-a7f19fa4] .hljs-built_in,.mc-code-block-light[data-v-a7f19fa4] .hljs-literal,.mc-code-block-light[data-v-a7f19fa4] .hljs-type,.mc-code-block-light[data-v-a7f19fa4] .hljs-params,.mc-code-block-light[data-v-a7f19fa4] .hljs-meta,.mc-code-block-light[data-v-a7f19fa4] .hljs-link,.mc-code-block-light[data-v-a7f19fa4] .hljs-attribute{color:#aa5d00}.mc-code-block-light[data-v-a7f19fa4] .hljs-string,.mc-code-block-light[data-v-a7f19fa4] .hljs-symbol,.mc-code-block-light[data-v-a7f19fa4] .hljs-bullet,.mc-code-block-light[data-v-a7f19fa4] .hljs-addition{color:green}.mc-code-block-light[data-v-a7f19fa4] .hljs-title,.mc-code-block-light[data-v-a7f19fa4] .hljs-section{color:#007faa}.mc-code-block-light[data-v-a7f19fa4] .hljs-keyword,.mc-code-block-light[data-v-a7f19fa4] .hljs-selector-tag{color:#7928a1}.mc-code-block-light[data-v-a7f19fa4] .hljs-emphasis{font-style:italic}.mc-code-block-light[data-v-a7f19fa4] .hljs-strong{font-weight:700}@media screen and (-ms-high-contrast: active){.mc-code-block-light[data-v-a7f19fa4] .hljs-addition,.mc-code-block-light[data-v-a7f19fa4] .hljs-attribute,.mc-code-block-light[data-v-a7f19fa4] .hljs-built_in,.mc-code-block-light[data-v-a7f19fa4] .hljs-bullet,.mc-code-block-light[data-v-a7f19fa4] .hljs-comment,.mc-code-block-light[data-v-a7f19fa4] .hljs-link,.mc-code-block-light[data-v-a7f19fa4] .hljs-literal,.mc-code-block-light[data-v-a7f19fa4] .hljs-meta,.mc-code-block-light[data-v-a7f19fa4] .hljs-number,.mc-code-block-light[data-v-a7f19fa4] .hljs-params,.mc-code-block-light[data-v-a7f19fa4] .hljs-string,.mc-code-block-light[data-v-a7f19fa4] .hljs-symbol,.mc-code-block-light[data-v-a7f19fa4] .hljs-type,.mc-code-block-light[data-v-a7f19fa4] .hljs-quote{color:highlight}.mc-code-block-light[data-v-a7f19fa4] .hljs-keyword,.mc-code-block-light[data-v-a7f19fa4] .hljs-selector-tag{font-weight:700}}.mc-code-block-dark[data-v-a7f19fa4] pre code.hljs{display:block;overflow-x:auto;padding:1em}.mc-code-block-dark[data-v-a7f19fa4] code.hljs{padding:3px 5px}.mc-code-block-dark[data-v-a7f19fa4] .hljs{background:#2b2b2b;color:#f8f8f2}.mc-code-block-dark[data-v-a7f19fa4] .hljs-comment,.mc-code-block-dark[data-v-a7f19fa4] .hljs-quote{color:#d4d0ab}.mc-code-block-dark[data-v-a7f19fa4] .hljs-variable,.mc-code-block-dark[data-v-a7f19fa4] .hljs-template-variable,.mc-code-block-dark[data-v-a7f19fa4] .hljs-tag,.mc-code-block-dark[data-v-a7f19fa4] .hljs-name,.mc-code-block-dark[data-v-a7f19fa4] .hljs-selector-id,.mc-code-block-dark[data-v-a7f19fa4] .hljs-selector-class,.mc-code-block-dark[data-v-a7f19fa4] .hljs-regexp,.mc-code-block-dark[data-v-a7f19fa4] .hljs-deletion{color:#ffa07a}.mc-code-block-dark[data-v-a7f19fa4] .hljs-number,.mc-code-block-dark[data-v-a7f19fa4] .hljs-built_in,.mc-code-block-dark[data-v-a7f19fa4] .hljs-literal,.mc-code-block-dark[data-v-a7f19fa4] .hljs-type,.mc-code-block-dark[data-v-a7f19fa4] .hljs-params,.mc-code-block-dark[data-v-a7f19fa4] .hljs-meta,.mc-code-block-dark[data-v-a7f19fa4] .hljs-link{color:#f5ab35}.mc-code-block-dark[data-v-a7f19fa4] .hljs-attribute{color:gold}.mc-code-block-dark[data-v-a7f19fa4] .hljs-string,.mc-code-block-dark[data-v-a7f19fa4] .hljs-symbol,.mc-code-block-dark[data-v-a7f19fa4] .hljs-bullet,.mc-code-block-dark[data-v-a7f19fa4] .hljs-addition{color:#abe338}.mc-code-block-dark[data-v-a7f19fa4] .hljs-title,.mc-code-block-dark[data-v-a7f19fa4] .hljs-section{color:#00e0e0}.mc-code-block-dark[data-v-a7f19fa4] .hljs-keyword,.mc-code-block-dark[data-v-a7f19fa4] .hljs-selector-tag{color:#dcc6e0}.mc-code-block-dark[data-v-a7f19fa4] .hljs-emphasis{font-style:italic}.mc-code-block-dark[data-v-a7f19fa4] .hljs-strong{font-weight:700}@media screen and (-ms-high-contrast: active){.mc-code-block-dark[data-v-a7f19fa4] .hljs-addition,.mc-code-block-dark[data-v-a7f19fa4] .hljs-attribute,.mc-code-block-dark[data-v-a7f19fa4] .hljs-built_in,.mc-code-block-dark[data-v-a7f19fa4] .hljs-bullet,.mc-code-block-dark[data-v-a7f19fa4] .hljs-comment,.mc-code-block-dark[data-v-a7f19fa4] .hljs-link,.mc-code-block-dark[data-v-a7f19fa4] .hljs-literal,.mc-code-block-dark[data-v-a7f19fa4] .hljs-meta,.mc-code-block-dark[data-v-a7f19fa4] .hljs-number,.mc-code-block-dark[data-v-a7f19fa4] .hljs-params,.mc-code-block-dark[data-v-a7f19fa4] .hljs-string,.mc-code-block-dark[data-v-a7f19fa4] .hljs-symbol,.mc-code-block-dark[data-v-a7f19fa4] .hljs-type,.mc-code-block-dark[data-v-a7f19fa4] .hljs-quote{color:highlight}.mc-code-block-dark[data-v-a7f19fa4] .hljs-keyword,.mc-code-block-dark[data-v-a7f19fa4] .hljs-selector-tag{font-weight:700}}.v-enter-active[data-v-a7f19fa4],.v-leave-active[data-v-a7f19fa4]{transition:opacity .5s ease}.v-enter-from[data-v-a7f19fa4],.v-leave-to[data-v-a7f19fa4]{opacity:0}.mc-code-block[data-v-a7f19fa4]{margin:1rem 0;overflow:hidden;border-radius:14px}.mc-code-block pre[data-v-a7f19fa4]{margin:0}.mc-code-block .mc-action-btn[data-v-a7f19fa4]{width:24px;height:24px}.mc-code-block .mc-code-block-header[data-v-a7f19fa4]{display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem}.mc-code-block .mc-code-block-header .mc-code-lang[data-v-a7f19fa4]{font-size:var(--devui-font-size, 14px)}.mc-code-block .mc-mermaid-content[data-v-a7f19fa4]{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.mc-code-block .mc-code-block-actions[data-v-a7f19fa4]{display:flex;align-items:center}.mc-code-block .mc-code-block-actions .mc-copy-btn[data-v-a7f19fa4],.mc-code-block .mc-code-block-actions .mc-toggle-btn[data-v-a7f19fa4]{cursor:pointer;border-radius:4px;font-size:18px;padding:4px}.mc-code-block .mc-diagram-switch[data-v-a7f19fa4]{display:flex;align-items:center;list-style:none;margin:0;padding:2px;border-radius:4px;background-color:var(--devui-icon-hover-bg);position:relative;transition:all .3s ease;overflow:hidden;height:24px}.mc-code-block .mc-diagram-switch[data-v-a7f19fa4]:before{content:"";position:absolute;top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px);background-color:var(--devui-base-bg, #ffffff);border-radius:4px;transition:transform .3s ease;box-shadow:0 1px 2px var(--devui-hover-shadow);z-index:1}.mc-code-block .mc-diagram-switch.mc-show-code[data-v-a7f19fa4]:before{transform:translate(100%)}.mc-code-block .mc-diagram-switch .mc-diagram-switch-active[data-v-a7f19fa4]{text-shadow:0 0 .4px var(--devui-text)}.mc-code-block .mc-diagram-switch li[data-v-a7f19fa4]{position:relative;padding:0 8px;font-size:12px;cursor:pointer;transition:color .3s ease;z-index:2;-webkit-user-select:none;user-select:none;width:50%;text-align:center;margin:0;display:flex;align-items:center;justify-content:center;height:100%}.mc-code-block-light[data-v-a7f19fa4]{border:1px solid #d7d8da;background-color:#f5f5f5}.mc-code-block-light code.hljs[data-v-a7f19fa4]{padding:1em}.mc-code-block-light .mc-code-lang[data-v-a7f19fa4],.mc-code-block-light .mc-code-block-actions .mc-copy-btn[data-v-a7f19fa4],.mc-code-block-light .mc-code-block-actions .mc-toggle-btn[data-v-a7f19fa4]{color:#252b3a}.mc-code-block-light .mc-code-block-actions .mc-copy-btn[data-v-a7f19fa4]:hover,.mc-code-block-light .mc-code-block-actions .mc-toggle-btn[data-v-a7f19fa4]:hover{background-color:#ebebeb}.mc-code-block-light .mc-mermaid-content[data-v-a7f19fa4]{background:#fefefe}.mc-code-block-dark[data-v-a7f19fa4]{border:1px solid #4e5057;background-color:#34363a}.mc-code-block-dark code.hljs[data-v-a7f19fa4]{padding:1em}.mc-code-block-dark .mc-code-lang[data-v-a7f19fa4],.mc-code-block-dark .mc-code-block-actions .mc-copy-btn[data-v-a7f19fa4],.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn[data-v-a7f19fa4]{color:#ced1db}.mc-code-block-dark .mc-code-block-actions .mc-copy-btn[data-v-a7f19fa4]:hover,.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn[data-v-a7f19fa4]:hover{background-color:#393a3e}.mc-code-block-dark .mc-code-block-actions .mc-copy-btn img[data-v-a7f19fa4],.mc-code-block-dark .mc-code-block-actions .mc-toggle-btn img[data-v-a7f19fa4]{filter:brightness(1.5)}.mc-code-block-dark .mc-mermaid-content[data-v-a7f19fa4]{background:#2b2b2b}.collapse-transition-enter-from[data-v-a7f19fa4],.collapse-transition-leave-to[data-v-a7f19fa4]{opacity:0}.collapse-transition-enter-to[data-v-a7f19fa4],.collapse-transition-leave-from[data-v-a7f19fa4]{opacity:1}.collapse-transition-enter-active[data-v-a7f19fa4],.collapse-transition-leave-active[data-v-a7f19fa4]{transition:max-height .3s cubic-bezier(.5,.05,.5,.95),opacity .3s cubic-bezier(.5,.05,.5,.95)}.mc-markdown-render[data-v-a40d857a] ul,.mc-markdown-render[data-v-a40d857a] ol{list-style:none;margin:0;padding:0}.mc-markdown-render[data-v-a40d857a] ul{list-style-type:disc;padding-left:16px}.mc-markdown-render[data-v-a40d857a] ol{list-style-type:decimal;padding-inline-start:1.75em}.mc-markdown-render[data-v-a40d857a] p{line-height:28px;margin:0;padding:0;overflow-wrap:break-word}.mc-markdown-render[data-v-a40d857a] h1{font-size:32px;line-height:40px;overflow-wrap:break-word}.mc-markdown-render[data-v-a40d857a] h3{line-height:28px;font-size:20px;overflow-wrap:break-word}.mc-markdown-render[data-v-a40d857a] table{margin-bottom:10px;border-collapse:collapse;display:table}.mc-markdown-render[data-v-a40d857a] td,.mc-markdown-render[data-v-a40d857a] th{padding:5px 10px;border:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-base-bg, #ffffff)}.mc-markdown-render[data-v-a40d857a] caption{border:1px dashed var(--devui-line, #d7d8da);border-bottom:0;padding:3px;text-align:center}.mc-markdown-render[data-v-a40d857a] th{border-top:1px solid var(--devui-dividing-line, #f2f2f3);background-color:var(--devui-global-bg, #f6f6f8)}.mc-markdown-render[data-v-a40d857a] td p{margin:0;padding:0}.mc-markdown-render[data-v-a40d857a] .h1,.mc-markdown-render[data-v-a40d857a] .h2,.mc-markdown-render[data-v-a40d857a] .h3,.mc-markdown-render[data-v-a40d857a] .h4,.mc-markdown-render[data-v-a40d857a] .h5,.mc-markdown-render[data-v-a40d857a] .h6,.mc-markdown-render[data-v-a40d857a] h1,.mc-markdown-render[data-v-a40d857a] h2,.mc-markdown-render[data-v-a40d857a] h3,.mc-markdown-render[data-v-a40d857a] h4,.mc-markdown-render[data-v-a40d857a] h5,.mc-markdown-render[data-v-a40d857a] h6{line-height:1.1}.mc-markdown-render[data-v-a40d857a] blockquote{padding:0 8px;margin:0;color:var(--devui-text-weak, #575d6c);border-left:5px solid var(--devui-dividing-line, #f2f2f3)}.mc-markdown-render[data-v-a40d857a] a{color:var(--devui-link, #526ecc);text-decoration:underline;cursor:pointer}.mc-markdown-render[data-v-a40d857a] a:hover{color:var(--devui-link-active, #526ecc)}.mc-markdown-render[data-v-a40d857a] img{max-width:100%}.mc-markdown-render[data-v-a40d857a]{font-size:var(--devui-font-size, 14px);overflow-x:auto}.mc-markdown-render.mc-markdown-render-dark[data-v-a40d857a]{color:#ced1db}.mc-markdown-render.mc-markdown-render-light[data-v-a40d857a]{color:#252b3a}[data-v-a40d857a] .mc-think-block{color:var(--devui-aide-text, #71757f);border-left:1px solid var(--devui-line, #d7d8da);padding-left:8px;margin-bottom:1rem}[data-v-a40d857a] .mc-typewriter-color{background-image:-webkit-linear-gradient(left,#191919,#5588f0,#e171ee,#f2c55c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}[data-v-a40d857a] .mc-typewriter-gradient{background:linear-gradient(to right,var(--devui-text, #252b3a),var(--devui-base-bg, #ffffff));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}[data-v-a40d857a] .mc-typewriter-cursor{font-weight:900;animation:typewriter-a40d857a .8s linear 0s infinite}@keyframes typewriter-a40d857a{0%{opacity:1}50%{opacity:0}to{opacity:1}}
@@ -1,21 +1,21 @@
1
1
  import "./index.css";
2
- import { defineComponent as Q, ref as f, computed as x, createElementBlock as D, openBlock as m, normalizeClass as B, renderSlot as S, createVNode as R, createElementVNode as L, toDisplayString as F, unref as v, Transition as $, withCtx as K, createCommentVNode as P, useSlots as J, watch as T, nextTick as V, h as C, onMounted as q, Fragment as ee, createBlock as te, resolveDynamicComponent as se } from "vue";
3
- import y from "highlight.js";
2
+ import { defineComponent as P, ref as w, computed as T, watch as k, nextTick as G, onMounted as Z, createElementBlock as y, openBlock as M, normalizeClass as C, renderSlot as E, createVNode as K, createElementVNode as h, toDisplayString as U, createCommentVNode as W, unref as v, Transition as J, withCtx as V, useSlots as q, h as A, Fragment as ee, createBlock as te, resolveDynamicComponent as se } from "vue";
3
+ import D from "highlight.js";
4
4
  import ie from "markdown-it";
5
5
  import { debounce as ne } from "lodash-es";
6
- import { getDefaultWhiteList as oe, getDefaultCSSWhiteList as le, filterXSS as ce } from "xss";
7
- import { useMcI18n as ae } from "@matechat/core/Locale";
8
- const re = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e全部收起%3c/title%3e%3cg%20id='全部收起'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cpath%20d='M4.715694,14.4114091%20C4.910563,14.5464051%205.179987,14.5271201%205.353553,14.3535531%20L5.353553,14.3535531%20L7.99999988,11.7070001%20L10.646447,14.3535531%20L10.715694,14.4114091%20C10.910563,14.5464051%2011.179987,14.5271201%2011.353553,14.3535531%20C11.548816,14.1582911%2011.548816,13.8417091%2011.353553,13.6464471%20L11.353553,13.6464471%20L8.353553,10.6464471%20L8.284306,10.5885911%20C8.089437,10.4535951%207.820013,10.4728801%207.646447,10.6464471%20L7.646447,10.6464471%20L4.646447,13.6464471%20L4.588591,13.7156941%20C4.453595,13.9105631%204.47288,14.1799871%204.646447,14.3535531%20L4.646447,14.3535531%20L4.715694,14.4114091%20Z%20M14.5,7.50000012%20C14.776142,7.50000012%2015,7.72385812%2015,8.00000012%20C15,8.27614212%2014.776142,8.50000012%2014.5,8.50000012%20L1.5,8.50000012%20C1.223858,8.50000012%201,8.27614212%201,8.00000012%20C1,7.72385812%201.223858,7.50000012%201.5,7.50000012%20L14.5,7.50000012%20Z%20M8.284306,5.41140912%20L8.353553,5.35355312%20L11.353553,2.35355312%20C11.548816,2.15829112%2011.548816,1.84170912%2011.353553,1.64644712%20C11.179987,1.47288012%2010.910563,1.45359512%2010.715694,1.58859112%20L10.646447,1.64644712%20L7.99999988,4.29300012%20L5.353553,1.64644712%20C5.179987,1.47288012%204.910563,1.45359512%204.715694,1.58859112%20L4.646447,1.64644712%20C4.47288,1.82001312%204.453595,2.08943712%204.588591,2.28430612%20L4.646447,2.35355312%20L7.646447,5.35355312%20C7.820013,5.52712012%208.089437,5.54640512%208.284306,5.41140912%20Z'%20id='形状结合'%20fill='%2371757F'%20fill-rule='nonzero'%3e%3c/path%3e%3c/g%3e%3c/svg%3e", de = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iMTZweCIgaGVpZ2h0PSIxNnB4IiB2aWV3Qm94PSIwIDAgMTYgMTYiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+CiAgICA8dGl0bGU+ZnVuY3Rpb24gaWNvbi9jb3B5PC90aXRsZT4KICAgIDxnIGlkPSLpobXpnaItMSIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+CiAgICAgICAgPGcgaWQ9IkFQSS1zdGFydGVyLeWbvuagh+WFpeW6kyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTU5Mi4wMDAwMDAsIC0yMDQuMDAwMDAwKSI+CiAgICAgICAgICAgIDxnIGlkPSLmlrnmoLzlpIfku70tMTYiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDU2MC4wMDAwMDAsIDE4MC4wMDAwMDApIj4KICAgICAgICAgICAgICAgIDx0ZXh0IGlkPSLlm77moIciIGZvbnQtZmFtaWx5PSJQaW5nRmFuZ1NDLVJlZ3VsYXIsIFBpbmdGYW5nIFNDIiBmb250LXNpemU9IjEyIiBmb250LXdlaWdodD0ibm9ybWFsIiBsaW5lLXNwYWNpbmc9IjE2IiBmaWxsPSIjNzE3NTdGIj4KICAgICAgICAgICAgICAgICAgICA8dHNwYW4geD0iMjcuMTM2IiB5PSI2MSI+5aSN5Yi2PC90c3Bhbj4KICAgICAgICAgICAgICAgIDwvdGV4dD4KICAgICAgICAgICAgPC9nPgogICAgICAgICAgICA8cGF0aCBkPSJNNjA0LjUsMjA2IEM2MDUuMjc5Njk2LDIwNiA2MDUuOTIwNDQ5LDIwNi41OTQ4ODggNjA1Ljk5MzEzMywyMDcuMzU1NTQgTDYwNiwyMDcuNSBMNjA2LDIxNC41IEM2MDYsMjE1LjI3OTY5NiA2MDUuNDA1MTEyLDIxNS45MjA0NDkgNjA0LjY0NDQ2LDIxNS45OTMxMzMgTDYwNC41LDIxNiBMNjA0LDIxNiBMNjA0LDIxNi41IEM2MDQsMjE3LjI3OTY5NiA2MDMuNDA1MTEyLDIxNy45MjA0NDkgNjAyLjY0NDQ2LDIxNy45OTMxMzMgTDYwMi41LDIxOCBMNTk1LjUsMjE4IEM1OTQuNjcxNTczLDIxOCA1OTQsMjE3LjMyODQyNyA1OTQsMjE2LjUgTDU5NCwyMTYuNSBMNTk0LDIwOS41IEM1OTQsMjA4LjY3MTU3MyA1OTQuNjcxNTczLDIwOCA1OTUuNSwyMDggTDU5NS41LDIwOCBMNTk2LDIwOCBMNTk2LDIwNy41IEM1OTYsMjA2LjcyMDMwNCA1OTYuNTk0ODg4LDIwNi4wNzk1NTEgNTk3LjM1NTU0LDIwNi4wMDY4NjcgTDU5Ny41LDIwNiBMNjA0LjUsMjA2IFogTTYwMi41LDIwOSBMNTk1LjUsMjA5IEM1OTUuMjIzODU4LDIwOSA1OTUsMjA5LjIyMzg1OCA1OTUsMjA5LjUgTDU5NSwyMDkuNSBMNTk1LDIxNi41IEM1OTUsMjE2Ljc3NjE0MiA1OTUuMjIzODU4LDIxNyA1OTUuNSwyMTcgTDU5NS41LDIxNyBMNjAyLjUsMjE3IEM2MDIuNzc2MTQyLDIxNyA2MDMsMjE2Ljc3NjE0MiA2MDMsMjE2LjUgTDYwMywyMTYuNSBMNjAzLDIwOS41IEM2MDMsMjA5LjIyMzg1OCA2MDIuNzc2MTQyLDIwOSA2MDIuNSwyMDkgTDYwMi41LDIwOSBaIE02MDQuNSwyMDcgTDU5Ny41LDIwNyBDNTk3LjI1NDU0LDIwNyA1OTcuMDUwMzkyLDIwNy4xNzY4NzUgNTk3LjAwODA1NiwyMDcuNDEwMTI0IEw1OTcsMjA3LjUgTDU5NywyMDggTDYwMi41LDIwOCBDNjAzLjI3OTY5NiwyMDggNjAzLjkyMDQ0OSwyMDguNTk0ODg4IDYwMy45OTMxMzMsMjA5LjM1NTU0IEw2MDQsMjA5LjUgTDYwNCwyMTUgTDYwNC41LDIxNSBDNjA0Ljc0NTQ2LDIxNSA2MDQuOTQ5NjA4LDIxNC44MjMxMjUgNjA0Ljk5MTk0NCwyMTQuNTg5ODc2IEw2MDUsMjE0LjUgTDYwNSwyMDcuNSBDNjA1LDIwNy4yNTQ1NCA2MDQuODIzMTI1LDIwNy4wNTAzOTIgNjA0LjU4OTg3NiwyMDcuMDA4MDU2IEw2MDQuNSwyMDcgWiIgaWQ9IuW9oueKtue7k+WQiCIgZmlsbD0iIzcxNzU3RiIgZmlsbC1ydWxlPSJub256ZXJvIj48L3BhdGg+CiAgICAgICAgPC9nPgogICAgPC9nPgo8L3N2Zz4=", ge = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3estatus/whiteBG/correct%3c/title%3e%3cdesc%3eCreated%20with%20Sketch.%3c/desc%3e%3cdefs%3e%3cpolygon%20id='path-1'%20points='6.53553391%209.77817459%2012.1923882%204.12132034%2013.6066017%205.53553391%206.53553391%2012.6066017%203%209.07106781%204.41421356%207.65685425%206.53553391%209.77817459'%3e%3c/polygon%3e%3c/defs%3e%3cg%20id='status/whiteBG/correct'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cmask%20id='mask-2'%20fill='white'%3e%3cuse%20xlink:href='%23path-1'%3e%3c/use%3e%3c/mask%3e%3cuse%20id='Mask'%20fill='%233DCCA6'%20xlink:href='%23path-1'%3e%3c/use%3e%3c/g%3e%3c/svg%3e";
9
- class G {
6
+ import { getDefaultWhiteList as oe, getDefaultCSSWhiteList as ae, filterXSS as le } from "xss";
7
+ import { useMcI18n as re } from "@matechat/core/Locale";
8
+ const ce = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3e全部收起%3c/title%3e%3cg%20id='全部收起'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cpath%20d='M4.715694,14.4114091%20C4.910563,14.5464051%205.179987,14.5271201%205.353553,14.3535531%20L5.353553,14.3535531%20L7.99999988,11.7070001%20L10.646447,14.3535531%20L10.715694,14.4114091%20C10.910563,14.5464051%2011.179987,14.5271201%2011.353553,14.3535531%20C11.548816,14.1582911%2011.548816,13.8417091%2011.353553,13.6464471%20L11.353553,13.6464471%20L8.353553,10.6464471%20L8.284306,10.5885911%20C8.089437,10.4535951%207.820013,10.4728801%207.646447,10.6464471%20L7.646447,10.6464471%20L4.646447,13.6464471%20L4.588591,13.7156941%20C4.453595,13.9105631%204.47288,14.1799871%204.646447,14.3535531%20L4.646447,14.3535531%20L4.715694,14.4114091%20Z%20M14.5,7.50000012%20C14.776142,7.50000012%2015,7.72385812%2015,8.00000012%20C15,8.27614212%2014.776142,8.50000012%2014.5,8.50000012%20L1.5,8.50000012%20C1.223858,8.50000012%201,8.27614212%201,8.00000012%20C1,7.72385812%201.223858,7.50000012%201.5,7.50000012%20L14.5,7.50000012%20Z%20M8.284306,5.41140912%20L8.353553,5.35355312%20L11.353553,2.35355312%20C11.548816,2.15829112%2011.548816,1.84170912%2011.353553,1.64644712%20C11.179987,1.47288012%2010.910563,1.45359512%2010.715694,1.58859112%20L10.646447,1.64644712%20L7.99999988,4.29300012%20L5.353553,1.64644712%20C5.179987,1.47288012%204.910563,1.45359512%204.715694,1.58859112%20L4.646447,1.64644712%20C4.47288,1.82001312%204.453595,2.08943712%204.588591,2.28430612%20L4.646447,2.35355312%20L7.646447,5.35355312%20C7.820013,5.52712012%208.089437,5.54640512%208.284306,5.41140912%20Z'%20id='形状结合'%20fill='%2371757F'%20fill-rule='nonzero'%3e%3c/path%3e%3c/g%3e%3c/svg%3e", de = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iMTZweCIgaGVpZ2h0PSIxNnB4IiB2aWV3Qm94PSIwIDAgMTYgMTYiIHZlcnNpb249IjEuMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayI+CiAgICA8dGl0bGU+ZnVuY3Rpb24gaWNvbi9jb3B5PC90aXRsZT4KICAgIDxnIGlkPSLpobXpnaItMSIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+CiAgICAgICAgPGcgaWQ9IkFQSS1zdGFydGVyLeWbvuagh+WFpeW6kyIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTU5Mi4wMDAwMDAsIC0yMDQuMDAwMDAwKSI+CiAgICAgICAgICAgIDxnIGlkPSLmlrnmoLzlpIfku70tMTYiIHRyYW5zZm9ybT0idHJhbnNsYXRlKDU2MC4wMDAwMDAsIDE4MC4wMDAwMDApIj4KICAgICAgICAgICAgICAgIDx0ZXh0IGlkPSLlm77moIciIGZvbnQtZmFtaWx5PSJQaW5nRmFuZ1NDLVJlZ3VsYXIsIFBpbmdGYW5nIFNDIiBmb250LXNpemU9IjEyIiBmb250LXdlaWdodD0ibm9ybWFsIiBsaW5lLXNwYWNpbmc9IjE2IiBmaWxsPSIjNzE3NTdGIj4KICAgICAgICAgICAgICAgICAgICA8dHNwYW4geD0iMjcuMTM2IiB5PSI2MSI+5aSN5Yi2PC90c3Bhbj4KICAgICAgICAgICAgICAgIDwvdGV4dD4KICAgICAgICAgICAgPC9nPgogICAgICAgICAgICA8cGF0aCBkPSJNNjA0LjUsMjA2IEM2MDUuMjc5Njk2LDIwNiA2MDUuOTIwNDQ5LDIwNi41OTQ4ODggNjA1Ljk5MzEzMywyMDcuMzU1NTQgTDYwNiwyMDcuNSBMNjA2LDIxNC41IEM2MDYsMjE1LjI3OTY5NiA2MDUuNDA1MTEyLDIxNS45MjA0NDkgNjA0LjY0NDQ2LDIxNS45OTMxMzMgTDYwNC41LDIxNiBMNjA0LDIxNiBMNjA0LDIxNi41IEM2MDQsMjE3LjI3OTY5NiA2MDMuNDA1MTEyLDIxNy45MjA0NDkgNjAyLjY0NDQ2LDIxNy45OTMxMzMgTDYwMi41LDIxOCBMNTk1LjUsMjE4IEM1OTQuNjcxNTczLDIxOCA1OTQsMjE3LjMyODQyNyA1OTQsMjE2LjUgTDU5NCwyMTYuNSBMNTk0LDIwOS41IEM1OTQsMjA4LjY3MTU3MyA1OTQuNjcxNTczLDIwOCA1OTUuNSwyMDggTDU5NS41LDIwOCBMNTk2LDIwOCBMNTk2LDIwNy41IEM1OTYsMjA2LjcyMDMwNCA1OTYuNTk0ODg4LDIwNi4wNzk1NTEgNTk3LjM1NTU0LDIwNi4wMDY4NjcgTDU5Ny41LDIwNiBMNjA0LjUsMjA2IFogTTYwMi41LDIwOSBMNTk1LjUsMjA5IEM1OTUuMjIzODU4LDIwOSA1OTUsMjA5LjIyMzg1OCA1OTUsMjA5LjUgTDU5NSwyMDkuNSBMNTk1LDIxNi41IEM1OTUsMjE2Ljc3NjE0MiA1OTUuMjIzODU4LDIxNyA1OTUuNSwyMTcgTDU5NS41LDIxNyBMNjAyLjUsMjE3IEM2MDIuNzc2MTQyLDIxNyA2MDMsMjE2Ljc3NjE0MiA2MDMsMjE2LjUgTDYwMywyMTYuNSBMNjAzLDIwOS41IEM2MDMsMjA5LjIyMzg1OCA2MDIuNzc2MTQyLDIwOSA2MDIuNSwyMDkgTDYwMi41LDIwOSBaIE02MDQuNSwyMDcgTDU5Ny41LDIwNyBDNTk3LjI1NDU0LDIwNyA1OTcuMDUwMzkyLDIwNy4xNzY4NzUgNTk3LjAwODA1NiwyMDcuNDEwMTI0IEw1OTcsMjA3LjUgTDU5NywyMDggTDYwMi41LDIwOCBDNjAzLjI3OTY5NiwyMDggNjAzLjkyMDQ0OSwyMDguNTk0ODg4IDYwMy45OTMxMzMsMjA5LjM1NTU0IEw2MDQsMjA5LjUgTDYwNCwyMTUgTDYwNC41LDIxNSBDNjA0Ljc0NTQ2LDIxNSA2MDQuOTQ5NjA4LDIxNC44MjMxMjUgNjA0Ljk5MTk0NCwyMTQuNTg5ODc2IEw2MDUsMjE0LjUgTDYwNSwyMDcuNSBDNjA1LDIwNy4yNTQ1NCA2MDQuODIzMTI1LDIwNy4wNTAzOTIgNjA0LjU4OTg3NiwyMDcuMDA4MDU2IEw2MDQuNSwyMDcgWiIgaWQ9IuW9oueKtue7k+WQiCIgZmlsbD0iIzcxNzU3RiIgZmlsbC1ydWxlPSJub256ZXJvIj48L3BhdGg+CiAgICAgICAgPC9nPgogICAgPC9nPgo8L3N2Zz4=", ge = "data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='UTF-8'?%3e%3csvg%20width='16px'%20height='16px'%20viewBox='0%200%2016%2016'%20version='1.1'%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3ctitle%3estatus/whiteBG/correct%3c/title%3e%3cdesc%3eCreated%20with%20Sketch.%3c/desc%3e%3cdefs%3e%3cpolygon%20id='path-1'%20points='6.53553391%209.77817459%2012.1923882%204.12132034%2013.6066017%205.53553391%206.53553391%2012.6066017%203%209.07106781%204.41421356%207.65685425%206.53553391%209.77817459'%3e%3c/polygon%3e%3c/defs%3e%3cg%20id='status/whiteBG/correct'%20stroke='none'%20stroke-width='1'%20fill='none'%20fill-rule='evenodd'%3e%3cmask%20id='mask-2'%20fill='white'%3e%3cuse%20xlink:href='%23path-1'%3e%3c/use%3e%3c/mask%3e%3cuse%20id='Mask'%20fill='%233DCCA6'%20xlink:href='%23path-1'%3e%3c/use%3e%3c/g%3e%3c/svg%3e";
9
+ class X {
10
10
  constructor() {
11
- this.xssWhiteList = oe(), this.cssWhiteList = le(), this.setDefaultXss();
11
+ this.xssWhiteList = oe(), this.cssWhiteList = ae(), this.setDefaultXss();
12
12
  }
13
13
  setDefaultXss() {
14
14
  this.xssWhiteList.input = ["type", "checked", "disabled", "class"], this.xssWhiteList.label = ["for"], this.xssWhiteList.ul = ["class"], this.xssWhiteList.div = ["class"], this.xssWhiteList.a = ["href", "class", "target", "name"], this.xssWhiteList.ol = ["start"], this.xssWhiteList.p = ["class"], this.xssWhiteList.span = ["style", "class", "title", "id"], this.xssWhiteList.svg = ["style", "class", "width", "height", "viewbox", "preserveaspectratio", "id", "fill", "stroke"], this.xssWhiteList.path = ["style", "class", "d", "id", "fill", "stroke"], this.xssWhiteList.th = ["style"], this.xssWhiteList.td = ["style"];
15
15
  }
16
- onIgnoreTagAttr(s, o, d, i) {
17
- if (!i && (o === "id" || s === "span" && o === "style"))
18
- return o + "=" + d;
16
+ onIgnoreTagAttr(s, a, g, i) {
17
+ if (!i && (a === "id" || s === "span" && a === "style"))
18
+ return a + "=" + g;
19
19
  }
20
20
  getXssWhiteList() {
21
21
  return this.xssWhiteList;
@@ -24,18 +24,18 @@ class G {
24
24
  this.xssWhiteList = s;
25
25
  }
26
26
  setCustomXssRules(s) {
27
- s && s.forEach((o) => {
28
- o.value === null ? delete this.xssWhiteList[o.key] : this.xssWhiteList[o.key] = o.value;
27
+ s && s.forEach((a) => {
28
+ a.value === null ? delete this.xssWhiteList[a.key] : this.xssWhiteList[a.key] = a.value;
29
29
  });
30
30
  }
31
- setMdPlugins(s, o) {
32
- s && s.length && s.forEach((d) => {
33
- const { plugin: i, opts: g } = d;
34
- o.use(i, g);
31
+ setMdPlugins(s, a) {
32
+ s && s.length && s.forEach((g) => {
33
+ const { plugin: i, opts: u } = g;
34
+ a.use(i, u);
35
35
  });
36
36
  }
37
37
  filterHtml(s) {
38
- return ce(s, {
38
+ return le(s, {
39
39
  whiteList: this.xssWhiteList,
40
40
  onIgnoreTagAttr: this.onIgnoreTagAttr,
41
41
  css: {
@@ -52,13 +52,16 @@ class G {
52
52
  const ue = {
53
53
  key: 0,
54
54
  class: "mc-code-block-header"
55
- }, he = { class: "mc-code-lang" }, Me = { class: "mc-code-block-actions" }, Ie = ["title"], me = ["title"], ye = {
55
+ }, me = { class: "mc-code-lang" }, he = { class: "mc-code-block-actions" }, Me = {
56
+ key: 0,
57
+ style: { "margin-right": "8px" }
58
+ }, ye = ["title"], Ie = ["title"], pe = {
56
59
  key: 0,
57
60
  src: de
58
- }, pe = {
61
+ }, De = {
59
62
  key: 1,
60
63
  src: ge
61
- }, De = { key: 0 }, Le = { key: 0 }, Ne = ["innerHTML"], we = /* @__PURE__ */ Q({
64
+ }, Le = { key: 0 }, we = ["innerHTML"], fe = { key: 1 }, Ne = ["innerHTML"], ve = /* @__PURE__ */ P({
62
65
  __name: "CodeBlock",
63
66
  props: {
64
67
  code: {
@@ -76,102 +79,176 @@ const ue = {
76
79
  theme: {
77
80
  type: String,
78
81
  default: "light"
82
+ },
83
+ enableMermaid: {
84
+ type: Boolean,
85
+ default: !1
86
+ },
87
+ mermaidConfig: {
88
+ type: Object,
89
+ default: () => ({})
79
90
  }
80
91
  },
81
- setup(r) {
82
- const s = r, { t: o } = ae(), d = new G(), i = f(!0), g = f(!1), M = x(() => {
92
+ setup(d) {
93
+ const s = d, { t: a } = re(), g = new X();
94
+ let i = null;
95
+ const u = w(!0), m = w(!1), f = w(""), c = w(!0), I = T(() => {
96
+ var e;
97
+ return s.enableMermaid && ((e = s.language) == null ? void 0 : e.toLowerCase()) === "mermaid";
98
+ }), L = T(() => {
83
99
  try {
84
- const t = s.code.indexOf('<span class="mc-typewriter');
85
- let l;
86
- return s.language && y.getLanguage(s.language) ? t !== -1 ? l = y.highlight(s.code.slice(0, t), { language: s.language }).value + s.code.slice(t) : l = y.highlight(s.code, { language: s.language }).value : typeof y.highlightAuto !== void 0 ? t !== -1 ? l = y.highlightAuto(s.code.slice(0, t)).value + s.code.slice(t) : l = y.highlightAuto(s.code).value : l = d.filterHtml(s.code), l;
100
+ const e = s.code.indexOf('<span class="mc-typewriter');
101
+ let n;
102
+ return s.language && D.getLanguage(s.language) ? e !== -1 ? n = D.highlight(s.code.slice(0, e), { language: s.language }).value + s.code.slice(e) : n = D.highlight(s.code, { language: s.language }).value : typeof D.highlightAuto !== void 0 ? e !== -1 ? n = D.highlightAuto(s.code.slice(0, e)).value + s.code.slice(e) : n = D.highlightAuto(s.code).value : n = g.filterHtml(s.code), n;
87
103
  } catch {
88
104
  }
89
- }), N = () => {
90
- i.value = !i.value;
91
- }, h = ne((t) => {
92
- const l = t.target;
105
+ }), N = async () => {
106
+ if (!(!I.value || !s.code)) {
107
+ if (!i)
108
+ try {
109
+ const { MermaidService: e } = await import("./MermaidService-QktyNvVC.js"), n = {
110
+ theme: s.theme === "dark" ? "dark" : "default",
111
+ ...s.mermaidConfig
112
+ };
113
+ i = new e(n);
114
+ } catch (e) {
115
+ console.error("Failed to load MermaidService:", e);
116
+ return;
117
+ }
118
+ try {
119
+ const e = await i.renderMermaid(s.code, s.theme);
120
+ f.value = e;
121
+ } catch {
122
+ }
123
+ }
124
+ }, p = () => {
125
+ u.value = !u.value;
126
+ }, x = ne((e) => {
127
+ const n = e.target;
93
128
  if (navigator.clipboard)
94
129
  navigator.clipboard.writeText(s.code);
95
130
  else {
96
- const e = document.createElement("textarea");
97
- e.style.position = "fixed", e.style.top = "-9999px", e.style.left = "-9999px", e.style.zIndex = "-1", e.value = s.code, document.body.appendChild(e), e.select(), document.execCommand("copy"), document.body.removeChild(e);
131
+ const r = document.createElement("textarea");
132
+ r.style.position = "fixed", r.style.top = "-9999px", r.style.left = "-9999px", r.style.zIndex = "-1", r.value = s.code, document.body.appendChild(r), r.select(), document.execCommand("copy"), document.body.removeChild(r);
98
133
  }
99
- l.classList.remove("icon-copy-new"), g.value = !0, setTimeout(() => {
100
- g.value = !1;
134
+ n.classList.remove("icon-copy-new"), m.value = !0, setTimeout(() => {
135
+ m.value = !1;
101
136
  }, 1500);
102
- }, 300), A = (t) => {
103
- t.dataset || (t.dataset = {}), t.style.height && (t.dataset.height = t.style.height), t.style.maxHeight = 0;
104
- }, p = (t) => {
137
+ }, 300), b = (e) => {
138
+ e.dataset || (e.dataset = {}), e.style.height && (e.dataset.height = e.style.height), e.style.maxHeight = 0;
139
+ }, O = (e) => {
105
140
  requestAnimationFrame(() => {
106
- t.dataset.oldOverflow = t.style.overflow, t.dataset.height ? t.style.maxHeight = t.dataset.height : t.scrollHeight !== 0 ? t.style.maxHeight = `${t.scrollHeight}px` : t.style.maxHeight = 0, t.style.overflow = "hidden";
141
+ e.dataset.oldOverflow = e.style.overflow, e.dataset.height ? e.style.maxHeight = e.dataset.height : e.scrollHeight !== 0 ? e.style.maxHeight = `${e.scrollHeight}px` : e.style.maxHeight = 0, e.style.overflow = "hidden";
142
+ });
143
+ }, S = (e) => {
144
+ e.style.maxHeight = "", e.style.overflow = e.dataset.oldOverflow;
145
+ }, B = (e) => {
146
+ e.dataset || (e.dataset = {}), e.dataset.oldOverflow = e.style.overflow, e.style.maxHeight = `${e.scrollHeight}px`, e.style.overflow = "hidden";
147
+ }, t = (e) => {
148
+ e.scrollHeight !== 0 && (e.style.maxHeight = 0);
149
+ }, o = (e) => {
150
+ e.style.maxHeight = "", e.style.overflow = e.dataset.oldOverflow;
151
+ }, l = T(() => s.theme === "dark" ? "mc-code-block-dark" : "mc-code-block-light");
152
+ return k(() => [s.code, s.theme, s.enableMermaid], () => {
153
+ I.value && G(() => {
154
+ N();
107
155
  });
108
- }, w = (t) => {
109
- t.style.maxHeight = "", t.style.overflow = t.dataset.oldOverflow;
110
- }, I = (t) => {
111
- t.dataset || (t.dataset = {}), t.dataset.oldOverflow = t.style.overflow, t.style.maxHeight = `${t.scrollHeight}px`, t.style.overflow = "hidden";
112
- }, j = (t) => {
113
- t.scrollHeight !== 0 && (t.style.maxHeight = 0);
114
- }, O = (t) => {
115
- t.style.maxHeight = "", t.style.overflow = t.dataset.oldOverflow;
116
- }, b = x(() => s.theme === "dark" ? "mc-code-block-dark" : "mc-code-block-light");
117
- return (t, l) => (m(), D(
156
+ }, { immediate: !0 }), Z(() => {
157
+ I.value && N();
158
+ }), (e, n) => (M(), y(
118
159
  "div",
119
160
  {
120
- class: B(["mc-code-block", b.value])
161
+ class: C(["mc-code-block", l.value])
121
162
  },
122
163
  [
123
- t.$slots.header ? S(t.$slots, "header", { key: 1 }, void 0, !0) : (m(), D("div", ue, [
124
- L(
164
+ e.$slots.header ? E(e.$slots, "header", { key: 1 }, void 0, !0) : (M(), y("div", ue, [
165
+ h(
125
166
  "span",
126
- he,
127
- F(r.language),
167
+ me,
168
+ U(d.language),
128
169
  1
129
170
  /* TEXT */
130
171
  ),
131
- S(t.$slots, "actions", {}, () => [
132
- L("div", Me, [
133
- L("div", {
172
+ E(e.$slots, "actions", {}, () => [
173
+ h("div", he, [
174
+ I.value ? (M(), y("div", Me, [
175
+ h(
176
+ "ul",
177
+ {
178
+ class: C(["mc-diagram-switch", { "mc-show-code": !c.value }])
179
+ },
180
+ [
181
+ h(
182
+ "li",
183
+ {
184
+ onClick: n[0] || (n[0] = (r) => c.value = !0),
185
+ class: C({ "mc-diagram-switch-active": c.value })
186
+ },
187
+ U(v(a)("Md.diagram")),
188
+ 3
189
+ /* TEXT, CLASS */
190
+ ),
191
+ h(
192
+ "li",
193
+ {
194
+ onClick: n[1] || (n[1] = (r) => c.value = !1),
195
+ class: C({ "mc-diagram-switch-active": !c.value })
196
+ },
197
+ U(v(a)("Md.code")),
198
+ 3
199
+ /* TEXT, CLASS */
200
+ )
201
+ ],
202
+ 2
203
+ /* CLASS */
204
+ )
205
+ ])) : W("v-if", !0),
206
+ h("div", {
134
207
  class: "mc-action-btn mc-toggle-btn",
135
- title: v(o)("Md.toggle"),
136
- onClick: N
137
- }, l[1] || (l[1] = [
138
- L(
208
+ title: v(a)("Md.toggle"),
209
+ onClick: p
210
+ }, n[3] || (n[3] = [
211
+ h(
139
212
  "img",
140
- { src: re },
213
+ { src: ce },
141
214
  null,
142
215
  -1
143
216
  /* CACHED */
144
217
  )
145
- ]), 8, Ie),
146
- L("div", {
218
+ ]), 8, ye),
219
+ h("div", {
147
220
  class: "mc-action-btn mc-copy-btn",
148
- title: v(o)("Md.copy"),
149
- onClick: l[0] || (l[0] = //@ts-ignore
150
- (...e) => v(h) && v(h)(...e))
221
+ title: v(a)("Md.copy"),
222
+ onClick: n[2] || (n[2] = //@ts-ignore
223
+ (...r) => v(x) && v(x)(...r))
151
224
  }, [
152
- g.value ? (m(), D("img", pe)) : (m(), D("img", ye))
153
- ], 8, me)
225
+ m.value ? (M(), y("img", De)) : (M(), y("img", pe))
226
+ ], 8, Ie)
154
227
  ])
155
228
  ], !0)
156
229
  ])),
157
- R($, {
230
+ K(J, {
158
231
  name: "collapse-transition",
159
- onBeforeEnter: A,
160
- onEnter: p,
161
- onAfterEnter: w,
162
- onBeforeLeave: I,
163
- onLeave: j,
164
- onAfterLeave: O
232
+ onBeforeEnter: b,
233
+ onEnter: O,
234
+ onAfterEnter: S,
235
+ onBeforeLeave: B,
236
+ onLeave: t,
237
+ onAfterLeave: o
165
238
  }, {
166
- default: K(() => [
167
- i.value ? (m(), D("div", De, [
168
- t.$slots.content ? S(t.$slots, "content", { key: 1 }, void 0, !0) : (m(), D("pre", Le, [
169
- L("code", {
170
- class: B(`hljs language-${r.language}`),
171
- innerHTML: M.value
239
+ default: V(() => [
240
+ u.value ? (M(), y("div", Le, [
241
+ I.value && c.value && !e.$slots.content ? (M(), y("div", {
242
+ key: 0,
243
+ class: "mc-mermaid-content",
244
+ innerHTML: f.value
245
+ }, null, 8, we)) : e.$slots.content ? E(e.$slots, "content", { key: 2 }, void 0, !0) : (M(), y("pre", fe, [
246
+ h("code", {
247
+ class: C(`hljs language-${d.language}`),
248
+ innerHTML: L.value
172
249
  }, null, 10, Ne)
173
250
  ]))
174
- ])) : P("v-if", !0)
251
+ ])) : W("v-if", !0)
175
252
  ]),
176
253
  _: 3
177
254
  /* FORWARDED */
@@ -181,16 +258,16 @@ const ue = {
181
258
  /* CLASS */
182
259
  ));
183
260
  }
184
- }), Z = (r, s) => {
185
- const o = r.__vccOpts || r;
186
- for (const [d, i] of s)
187
- o[d] = i;
188
- return o;
189
- }, Ce = /* @__PURE__ */ Z(we, [["__scopeId", "data-v-cb99045f"]]), z = {
261
+ }), $ = (d, s) => {
262
+ const a = d.__vccOpts || d;
263
+ for (const [g, i] of s)
264
+ a[g] = i;
265
+ return a;
266
+ }, Ce = /* @__PURE__ */ $(ve, [["__scopeId", "data-v-a7f19fa4"]]), Q = {
190
267
  step: 2,
191
268
  interval: 50,
192
269
  style: "normal"
193
- }, fe = {
270
+ }, Ae = {
194
271
  content: {
195
272
  type: String,
196
273
  default: ""
@@ -238,167 +315,177 @@ const ue = {
238
315
  theme: {
239
316
  type: String,
240
317
  default: "light"
318
+ },
319
+ enableMermaid: {
320
+ type: Boolean,
321
+ default: !1
322
+ },
323
+ mermaidConfig: {
324
+ type: Object,
325
+ default: () => ({})
241
326
  }
242
- }, Ae = /* @__PURE__ */ Q({
327
+ }, ke = /* @__PURE__ */ P({
243
328
  __name: "mdCard",
244
- props: fe,
329
+ props: Ae,
245
330
  emits: ["afterMdtInit", "typingStart", "typing", "typingEnd"],
246
- setup(r, { expose: s, emit: o }) {
247
- const d = new G(), i = r, g = o, M = J();
248
- let N = null;
249
- const h = ie({
331
+ setup(d, { expose: s, emit: a }) {
332
+ const g = new X(), i = d, u = a, m = q();
333
+ let f = null;
334
+ const c = ie({
250
335
  breaks: !0,
251
336
  linkify: !0,
252
337
  html: !0,
253
- highlight: (e, n) => {
254
- if (n && y.getLanguage(n))
338
+ highlight: (t, o) => {
339
+ if (o && D.getLanguage(o))
255
340
  try {
256
- return y.highlight(e, { language: n }).value;
341
+ return D.highlight(t, { language: o }).value;
257
342
  } catch {
258
343
  }
259
344
  return "";
260
345
  },
261
346
  ...i.mdOptions
262
347
  });
263
- h.renderer.rules.fence = (e, n) => `<!----MC_MARKDOWN_CODE_BLOCK_${n}---->`;
264
- const A = f({
348
+ c.renderer.rules.fence = (t, o) => `<!----MC_MARKDOWN_CODE_BLOCK_${o}---->`;
349
+ const I = w({
265
350
  tokens: [],
266
351
  html: ""
267
- }), p = f(0), w = f(!1), I = () => {
268
- var u;
269
- let e = i.content || "";
270
- if (i.typing && w.value) {
271
- e = i.content.slice(0, p.value) || "";
272
- const a = { ...z, ...i == null ? void 0 : i.typingOptions };
273
- a.style === "cursor" ? e += '<span class="mc-typewriter mc-typewriter-cursor">|</span>' : (a.style === "color" || a.style === "gradient") && (e = e.slice(0, -5) + `<span class="mc-typewriter mc-typewriter-${a.style}">${e.slice(-5)}</span>`);
352
+ }), L = w(0), N = w(!1), p = () => {
353
+ var e;
354
+ let t = i.content || "";
355
+ if (i.typing && N.value) {
356
+ t = i.content.slice(0, L.value) || "";
357
+ const n = { ...Q, ...i == null ? void 0 : i.typingOptions };
358
+ n.style === "cursor" ? t += '<span class="mc-typewriter mc-typewriter-cursor">|</span>' : (n.style === "color" || n.style === "gradient") && (t = t.slice(0, -5) + `<span class="mc-typewriter mc-typewriter-${n.style}">${t.slice(-5)}</span>`);
274
359
  }
275
360
  if (i.enableThink) {
276
- const a = ((u = i.thinkOptions) == null ? void 0 : u.customClass) || "mc-think-block";
277
- e = (e == null ? void 0 : e.replace("<think>", `<div class="${a}">`).replace("</think>", "</div>")) || "";
361
+ const n = ((e = i.thinkOptions) == null ? void 0 : e.customClass) || "mc-think-block";
362
+ t = (t == null ? void 0 : t.replace("<think>", `<div class="${n}">`).replace("</think>", "</div>")) || "";
278
363
  }
279
- const n = h.parse(e, {}), c = h.render(e);
280
- A.value = { tokens: n, html: c };
364
+ const o = c.parse(t, {}), l = c.render(t);
365
+ I.value = { tokens: o, html: l };
281
366
  };
282
- T(
367
+ k(
283
368
  () => {
284
- var e;
285
- return [i.enableThink, (e = i.thinkOptions) == null ? void 0 : e.customClass];
369
+ var t;
370
+ return [i.enableThink, (t = i.thinkOptions) == null ? void 0 : t.customClass];
286
371
  },
287
372
  () => {
288
- I();
373
+ p();
289
374
  }
290
375
  );
291
- const j = (e, n, c) => {
292
- const u = {
293
- actions: M.actions ? () => M.actions({ codeBlockData: { code: n, language: e } }) || null : void 0,
294
- header: M.header ? () => M.header({ codeBlockData: { code: n, language: e } }) || null : void 0,
295
- content: M.content ? () => M.content({ codeBlockData: { code: n, language: e } }) || null : void 0
376
+ const x = (t, o, l) => {
377
+ const e = {
378
+ actions: m.actions ? () => m.actions({ codeBlockData: { code: o, language: t } }) || null : void 0,
379
+ header: m.header ? () => m.header({ codeBlockData: { code: o, language: t } }) || null : void 0,
380
+ content: m.content ? () => m.content({ codeBlockData: { code: o, language: t } }) || null : void 0
296
381
  };
297
- return C(
382
+ return A(
298
383
  Ce,
299
384
  {
300
- language: e,
301
- code: n,
302
- blockIndex: c,
385
+ language: t,
386
+ code: o,
387
+ blockIndex: l,
303
388
  theme: i.theme,
304
- key: `code-block-${c}`
389
+ enableMermaid: i.enableMermaid,
390
+ mermaidConfig: i.mermaidConfig,
391
+ key: `code-block-${l}`
305
392
  },
306
- u
393
+ e
307
394
  );
308
395
  };
309
- T(
396
+ k(
310
397
  () => i.content,
311
- (e, n) => {
398
+ (t, o) => {
312
399
  if (!i.typing) {
313
- p.value = (e == null ? void 0 : e.length) || 0, I();
400
+ L.value = (t == null ? void 0 : t.length) || 0, p();
314
401
  return;
315
402
  }
316
- e.indexOf(n) === -1 && (p.value = 0), V(() => b());
403
+ t.indexOf(o) === -1 && (L.value = 0), G(() => O());
317
404
  },
318
405
  { immediate: !0 }
319
406
  );
320
- const O = () => {
321
- w.value = !1, g("typingEnd");
322
- }, b = () => {
323
- clearTimeout(N), w.value = !0, g("typingStart");
324
- const e = { ...z, ...i == null ? void 0 : i.typingOptions }, n = () => {
325
- let c = e.step;
326
- if (Array.isArray(e.step) && (c = e.step[0] + Math.floor(Math.random() * (e.step[1] - e.step[0]))), p.value += c, I(), g("typing"), p.value >= i.content.length) {
327
- O(), I();
407
+ const b = () => {
408
+ N.value = !1, u("typingEnd");
409
+ }, O = () => {
410
+ clearTimeout(f), N.value = !0, u("typingStart");
411
+ const t = { ...Q, ...i == null ? void 0 : i.typingOptions }, o = () => {
412
+ let l = t.step;
413
+ if (Array.isArray(t.step) && (l = t.step[0] + Math.floor(Math.random() * (t.step[1] - t.step[0]))), L.value += l, p(), u("typing"), L.value >= i.content.length) {
414
+ b(), p();
328
415
  return;
329
416
  }
330
- N = setTimeout(n, e.interval);
417
+ f = setTimeout(o, t.interval);
331
418
  };
332
- N = setTimeout(n);
333
- }, t = x(() => ({
419
+ f = setTimeout(o);
420
+ }, S = T(() => ({
334
421
  name: "MarkdownRenderer",
335
422
  render() {
336
- var _;
423
+ var Y;
337
424
  if (typeof document > "u")
338
- return C("div");
339
- const { html: e, tokens: n } = A.value, c = [];
340
- let u = 0, a;
341
- const E = /<!----MC_MARKDOWN_CODE_BLOCK_(\d+)---->/g;
342
- let U = 0, W = 0;
343
- for (; a = E.exec(e), !!a; ) {
344
- a.index > u && c.push(
345
- C("div", {
346
- innerHTML: e.slice(u, a.index),
347
- key: `markdown-segment-${W++}`
425
+ return A("div");
426
+ const { html: t, tokens: o } = I.value, l = [];
427
+ let e = 0, n;
428
+ const r = /<!----MC_MARKDOWN_CODE_BLOCK_(\d+)---->/g;
429
+ let _ = 0, z = 0;
430
+ for (; n = r.exec(t), !!n; ) {
431
+ n.index > e && l.push(
432
+ A("div", {
433
+ innerHTML: t.slice(e, n.index),
434
+ key: `markdown-segment-${z++}`
348
435
  })
349
436
  );
350
- const k = n[Number.parseInt(a[1])], H = ((_ = k == null ? void 0 : k.info) == null ? void 0 : _.replace(/<span\b[^>]*>/i, "").replace("</span>", "")) || "", X = k.content;
351
- c.push(j(H, X, U)), U++, u = E.lastIndex;
437
+ const j = o[Number.parseInt(n[1])], F = ((Y = j == null ? void 0 : j.info) == null ? void 0 : Y.replace(/<span\b[^>]*>/i, "").replace("</span>", "")) || "", R = j.content;
438
+ l.push(x(F, R, _)), _++, e = r.lastIndex;
352
439
  }
353
- return u < e.length && c.push(
354
- C("div", {
355
- innerHTML: e.slice(u),
356
- key: `markdown-segment-${W++}`
440
+ return e < t.length && l.push(
441
+ A("div", {
442
+ innerHTML: t.slice(e),
443
+ key: `markdown-segment-${z++}`
357
444
  })
358
- ), C("div", c);
445
+ ), A("div", l);
359
446
  }
360
447
  }));
361
- T(
448
+ k(
362
449
  () => i.customXssRules,
363
- (e) => {
364
- d.setCustomXssRules(e), I();
450
+ (t) => {
451
+ g.setCustomXssRules(t), p();
365
452
  },
366
453
  { deep: !1 }
367
- ), T(
454
+ ), k(
368
455
  () => i.mdPlugins,
369
- (e) => {
370
- d.setMdPlugins(e, h), I();
456
+ (t) => {
457
+ g.setMdPlugins(t, c), p();
371
458
  },
372
459
  { immediate: !0, deep: !1 }
373
460
  );
374
- const l = x(() => i.theme === "dark" ? "mc-markdown-render-dark" : "mc-markdown-render-light");
375
- return q(() => {
376
- g("afterMdtInit", h);
377
- }), s({ mdt: h }), (e, n) => (m(), D(
461
+ const B = T(() => i.theme === "dark" ? "mc-markdown-render-dark" : "mc-markdown-render-light");
462
+ return Z(() => {
463
+ u("afterMdtInit", c);
464
+ }), s({ mdt: c }), (t, o) => (M(), y(
378
465
  ee,
379
466
  null,
380
467
  [
381
- L(
468
+ h(
382
469
  "div",
383
470
  {
384
- class: B(["mc-markdown-render", l.value])
471
+ class: C(["mc-markdown-render", B.value])
385
472
  },
386
473
  [
387
- (m(), te(se(t.value)))
474
+ (M(), te(se(S.value)))
388
475
  ],
389
476
  2
390
477
  /* CLASS */
391
478
  ),
392
- P("v-if", !0)
479
+ W("v-if", !0)
393
480
  ],
394
481
  64
395
482
  /* STABLE_FRAGMENT */
396
483
  ));
397
484
  }
398
- }), Y = /* @__PURE__ */ Z(Ae, [["__scopeId", "data-v-6987322b"]]);
399
- Y.install = (r) => {
400
- r.component("McMarkdownCard", Y);
485
+ }), H = /* @__PURE__ */ $(ke, [["__scopeId", "data-v-a40d857a"]]);
486
+ H.install = (d) => {
487
+ d.component("McMarkdownCard", H);
401
488
  };
402
489
  export {
403
- Y as McMarkdownCard
490
+ H as McMarkdownCard
404
491
  };
package/package.json CHANGED
@@ -1,9 +1,16 @@
1
1
  {
2
2
  "name": "@matechat/core",
3
- "version": "1.5.3",
3
+ "version": "1.6.0-alpha.0",
4
4
  "license": "MIT",
5
5
  "description": "前端智能化场景解决方案UI库,轻松构建你的AI应用。",
6
- "keywords": ["AI", "GPT", "Chat", "vue-components", "vue3", "devui"],
6
+ "keywords": [
7
+ "AI",
8
+ "GPT",
9
+ "Chat",
10
+ "vue-components",
11
+ "vue3",
12
+ "devui"
13
+ ],
7
14
  "homepage": "https://matechat.gitcode.com/",
8
15
  "repository": {
9
16
  "type": "git",
@@ -11,7 +18,9 @@
11
18
  },
12
19
  "module": "mate-chat.js",
13
20
  "types": "index.d.ts",
14
- "sideEffects": ["**/*.css"],
21
+ "sideEffects": [
22
+ "**/*.css"
23
+ ],
15
24
  "dependencies": {
16
25
  "@floating-ui/dom": "^1.6.12",
17
26
  "@vue/shared": "^3.5.13",
@@ -24,4 +33,4 @@
24
33
  "peerDependencies": {
25
34
  "vue": "^3.5.13"
26
35
  }
27
- }
36
+ }