mvframe 1.0.17 → 1.0.20

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.
@@ -1,11 +1,12 @@
1
1
  import { g as k } from "./vendor.js";
2
2
  import { a as ie, m as le, b as se, c as ae, p as ce, u as ue } from "./vendor.js";
3
- const O = "lang", D = (t) => {
4
- var o, s;
5
- const e = typeof window < "u", r = () => {
6
- if (!e)
3
+ const O = "lang", D = (t, e) => {
4
+ var l, s;
5
+ const r = typeof window < "u", n = () => {
6
+ var b;
7
+ if (!r)
7
8
  return { innerWidth: 1920, innerHeight: 1080 };
8
- const i = window, l = typeof navigator < "u" ? i.navigator : {}, c = i.screen || {}, a = i.visualViewport, u = {
9
+ const i = window, a = typeof navigator < "u" ? i.navigator : {}, c = i.screen || {}, u = i.visualViewport, f = {
9
10
  innerWidth: i.innerWidth,
10
11
  innerHeight: i.innerHeight,
11
12
  outerWidth: i.outerWidth,
@@ -14,62 +15,63 @@ const O = "lang", D = (t) => {
14
15
  screenHeight: c.height ?? i.innerHeight,
15
16
  availWidth: c.availWidth ?? i.innerWidth,
16
17
  availHeight: c.availHeight ?? i.innerHeight,
17
- devicePixelRatio: i.devicePixelRatio || 1
18
+ devicePixelRatio: i.devicePixelRatio || 1,
19
+ bodyHeight: i.innerHeight - ((b = e.pinia) != null && b.useTab ? 36 : 0) - 64 - 32
18
20
  };
19
- a && (u.visualViewportWidth = a.width, u.visualViewportHeight = a.height, u.visualViewportScale = a.scale);
20
- const g = l.userAgent || "";
21
- return u.env = {
22
- userAgent: g,
23
- language: l.language || "",
24
- languages: l.languages ? [...l.languages] : [],
25
- platform: l.platform || "",
26
- cookieEnabled: !!l.cookieEnabled,
27
- onLine: l.onLine !== !1,
28
- maxTouchPoints: l.maxTouchPoints || 0,
29
- isTouch: "ontouchstart" in i || (l.maxTouchPoints || 0) > 0,
21
+ u && (f.visualViewportWidth = u.width, f.visualViewportHeight = u.height, f.visualViewportScale = u.scale);
22
+ const p = a.userAgent || "";
23
+ return f.env = {
24
+ userAgent: p,
25
+ language: a.language || "",
26
+ languages: a.languages ? [...a.languages] : [],
27
+ platform: a.platform || "",
28
+ cookieEnabled: !!a.cookieEnabled,
29
+ onLine: a.onLine !== !1,
30
+ maxTouchPoints: a.maxTouchPoints || 0,
31
+ isTouch: "ontouchstart" in i || (a.maxTouchPoints || 0) > 0,
30
32
  isMobile: /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini|Mobile/i.test(
31
- g
33
+ p
32
34
  )
33
- }, u;
34
- }, n = () => {
35
- var l;
36
- const i = r();
35
+ }, console.info(f), f;
36
+ }, o = () => {
37
+ var a;
38
+ const i = n();
37
39
  globalThis.$config = globalThis.$config || {}, globalThis.$config.options = {
38
40
  ...globalThis.$config.options || {},
39
41
  ...i
40
- }, (l = t == null ? void 0 : t.config) != null && l.globalProperties && (t.config.globalProperties.$config = globalThis.$config);
42
+ }, (a = t == null ? void 0 : t.config) != null && a.globalProperties && (t.config.globalProperties.$config = globalThis.$config);
41
43
  };
42
- n(), e && (window.addEventListener("resize", n, { passive: !0 }), (s = (o = window.visualViewport) == null ? void 0 : o.addEventListener) == null || s.call(o, "resize", n, {
44
+ o(), r && (window.addEventListener("resize", o, { passive: !0 }), (s = (l = window.visualViewport) == null ? void 0 : l.addEventListener) == null || s.call(l, "resize", o, {
43
45
  passive: !0
44
46
  }));
45
47
  }, X = (t, e) => {
46
- var l, c;
47
- const r = e || {}, o = (typeof localStorage < "u" ? localStorage.getItem(O) : null) || ((l = globalThis.$config) == null ? void 0 : l.lang) || "en_us", s = Object.assign(
48
+ var i, a;
49
+ const r = e || {}, o = (typeof localStorage < "u" ? localStorage.getItem(O) : null) || ((i = globalThis.$config) == null ? void 0 : i.lang) || "en_us", l = Object.assign(
48
50
  {},
49
51
  k(o),
50
- ((c = globalThis.$config) == null ? void 0 : c.langMaps) || {},
52
+ ((a = globalThis.$config) == null ? void 0 : a.langMaps) || {},
51
53
  r.langMaps || {}
52
- ), i = (a, u) => {
53
- if (a)
54
+ ), s = (c, u) => {
55
+ if (c)
54
56
  if (u && globalThis.$getType(u) === "Object") {
55
- let g = s[a] || a;
56
- return Object.keys(u).forEach((y) => {
57
- g[`{${y}}`] = u[y];
58
- }), g;
57
+ let f = l[c] || c;
58
+ return Object.keys(u).forEach((p) => {
59
+ f[`{${p}}`] = u[p];
60
+ }), f;
59
61
  } else
60
- return s[a] || a;
62
+ return l[c] || c;
61
63
  else
62
- return a;
64
+ return c;
63
65
  };
64
- globalThis.$patchLangMaps = (a) => {
65
- a && globalThis.$getType(a) === "Object" && Object.assign(s, a);
66
- }, globalThis.$l = i, t.config.globalProperties.$l = i, t.config.globalProperties.$patchLangMaps = globalThis.$patchLangMaps, String.prototype.$l = function() {
66
+ globalThis.$patchLangMaps = (c) => {
67
+ c && globalThis.$getType(c) === "Object" && Object.assign(l, c);
68
+ }, globalThis.$l = s, t.config.globalProperties.$l = s, t.config.globalProperties.$patchLangMaps = globalThis.$patchLangMaps, String.prototype.$l = function() {
67
69
  return $l(this);
68
70
  };
69
71
  }, Q = (t, e) => {
70
72
  if (!t || !e) return !1;
71
- const r = t.getBoundingClientRect(), n = e.getBoundingClientRect(), o = n.right > r.left && n.left < r.right, s = n.bottom > r.top && n.top < r.bottom;
72
- return o && s;
73
+ const r = t.getBoundingClientRect(), n = e.getBoundingClientRect(), o = n.right > r.left && n.left < r.right, l = n.bottom > r.top && n.top < r.bottom;
74
+ return o && l;
73
75
  }, _ = (t, e) => {
74
76
  if (t === e) return !0;
75
77
  if (t == null || e == null || typeof t != "object" || typeof e != "object")
@@ -79,16 +81,16 @@ const O = "lang", D = (t) => {
79
81
  for (const o of r)
80
82
  if (!n.includes(o) || !_(t[o], e[o])) return !1;
81
83
  return !0;
82
- }, M = "download", A = 150, B = (t, e = M) => {
83
- const r = e || M, n = String(t ?? "").trim();
84
+ }, P = "download", A = 150, H = (t, e = P) => {
85
+ const r = e || P, n = String(t ?? "").trim();
84
86
  if (!n) return r;
85
- const s = n.replace(/[/\\?%*:|"<>]/g, "_").replace(/\.\./g, "_").split(/[/\\]/).pop() || r, i = 200;
86
- return s.length > i ? s.slice(0, i) : s;
87
- }, H = (t) => {
87
+ const l = n.replace(/[/\\?%*:|"<>]/g, "_").replace(/\.\./g, "_").split(/[/\\]/).pop() || r, s = 200;
88
+ return l.length > s ? l.slice(0, s) : l;
89
+ }, B = (t) => {
88
90
  const e = ((t == null ? void 0 : t.type) || "").toLowerCase();
89
91
  return e ? e.includes("spreadsheet") || e.includes("ms-excel") || e.includes("excel") && e.includes("application") : !1;
90
- }, v = (t, e) => {
91
- const r = URL.createObjectURL(t), n = B(e), o = document.createElement("a");
92
+ }, T = (t, e) => {
93
+ const r = URL.createObjectURL(t), n = H(e), o = document.createElement("a");
92
94
  o.href = r, o.download = n, o.style.display = "none", document.body.appendChild(o);
93
95
  try {
94
96
  o.click();
@@ -98,103 +100,103 @@ const O = "lang", D = (t) => {
98
100
  }, I = (t) => {
99
101
  if (!t || t.source !== void 0 || t.type === void 0)
100
102
  return t;
101
- const { type: e, data: r, url: n, headers: o, name: s, filename: i, init: l, ...c } = t, a = i ?? s;
103
+ const { type: e, data: r, url: n, headers: o, name: l, filename: s, init: i, ...a } = t, c = s ?? l;
102
104
  return e === "csv" ? {
103
- ...c,
105
+ ...a,
104
106
  source: "inline",
105
107
  content: r,
106
- filename: a,
108
+ filename: c,
107
109
  bom: t.bom
108
110
  } : e === "excel" ? {
109
- ...c,
111
+ ...a,
110
112
  source: "fetch",
111
113
  url: n,
112
- init: { ...l || {}, headers: o ?? (l == null ? void 0 : l.headers) },
114
+ init: { ...i || {}, headers: o ?? (i == null ? void 0 : i.headers) },
113
115
  response: "blob",
114
116
  expectExcel: !0,
115
- filename: a
117
+ filename: c
116
118
  } : t;
117
119
  }, Z = async (t = {}) => {
118
120
  const e = I(t), {
119
121
  source: r = "inline",
120
122
  content: n,
121
123
  blob: o,
122
- bom: s = !0,
123
- mime: i,
124
- url: l,
125
- init: c,
126
- response: a = "blob",
124
+ bom: l = !0,
125
+ mime: s,
126
+ url: i,
127
+ init: a,
128
+ response: c = "blob",
127
129
  openIn: u = "self",
128
- expectExcel: g,
129
- filename: y,
130
- name: L,
131
- error: p = () => {
130
+ expectExcel: f,
131
+ filename: p,
132
+ name: b,
133
+ error: d = () => {
132
134
  },
133
135
  // 避免 legacy 字段渗入后续逻辑
134
136
  type: q,
135
137
  data: G,
136
138
  headers: Y,
137
139
  ...J
138
- } = e, b = y ?? L;
140
+ } = e, E = p ?? b;
139
141
  try {
140
142
  if (r === "inline") {
141
143
  if (o instanceof Blob) {
142
- v(o, b);
144
+ T(o, E);
143
145
  return;
144
146
  }
145
147
  if (n == null) {
146
- p(new Error("content or blob is required for inline"));
148
+ d(new Error("content or blob is required for inline"));
147
149
  return;
148
150
  }
149
- const f = typeof n == "string" ? n : String(n), E = s ? "\uFEFF" + f : f, w = i || (s ? "text/csv;charset=utf-8" : "text/plain;charset=utf-8");
150
- v(new Blob([E], { type: w }), b);
151
+ const g = typeof n == "string" ? n : String(n), w = l ? "\uFEFF" + g : g, v = s || (l ? "text/csv;charset=utf-8" : "text/plain;charset=utf-8");
152
+ T(new Blob([w], { type: v }), E);
151
153
  return;
152
154
  }
153
155
  if (r === "fetch") {
154
- if (!l) {
155
- p(new Error("url is required for fetch"));
156
+ if (!i) {
157
+ d(new Error("url is required for fetch"));
156
158
  return;
157
159
  }
158
- const f = await fetch(l, c);
159
- if (!f.ok) {
160
- p(new Error(`fetch failed: ${f.status}`));
160
+ const g = await fetch(i, a);
161
+ if (!g.ok) {
162
+ d(new Error(`fetch failed: ${g.status}`));
161
163
  return;
162
164
  }
163
- if (a === "text") {
164
- const w = await f.text(), R = s ? "\uFEFF" + w : w, $ = i || (s ? "text/csv;charset=utf-8" : "text/plain;charset=utf-8");
165
- v(new Blob([R], { type: $ }), b);
165
+ if (c === "text") {
166
+ const v = await g.text(), R = l ? "\uFEFF" + v : v, $ = s || (l ? "text/csv;charset=utf-8" : "text/plain;charset=utf-8");
167
+ T(new Blob([R], { type: $ }), E);
166
168
  return;
167
169
  }
168
- const E = await f.blob();
169
- if (g && !H(E)) {
170
- p(new Error("excel does not exist"));
170
+ const w = await g.blob();
171
+ if (f && !B(w)) {
172
+ d(new Error("excel does not exist"));
171
173
  return;
172
174
  }
173
- v(E, b);
175
+ T(w, E);
174
176
  return;
175
177
  }
176
178
  if (r === "open") {
177
- if (!l) {
178
- p(new Error("url is required for open"));
179
+ if (!i) {
180
+ d(new Error("url is required for open"));
179
181
  return;
180
182
  }
181
- u === "blank" ? window.open(l, "_blank", "noopener,noreferrer") : window.location.href = l;
183
+ u === "blank" ? window.open(i, "_blank", "noopener,noreferrer") : window.location.href = i;
182
184
  return;
183
185
  }
184
- p(new Error(`unknown source: ${r}`));
185
- } catch (f) {
186
- p(f instanceof Error ? f : new Error(String(f)));
186
+ d(new Error(`unknown source: ${r}`));
187
+ } catch (g) {
188
+ d(g instanceof Error ? g : new Error(String(g)));
187
189
  }
188
190
  };
189
191
  function j(t, e, r) {
190
192
  if (e === "" || e === void 0 || e === null)
191
193
  return "";
192
- const n = globalThis.$fa, o = globalThis.$fu, s = (r == null ? void 0 : r.precision) ?? 2, i = r == null ? void 0 : r.unit;
193
- if ((i === "currency" || i === "%") && o) {
194
- const l = {
194
+ const n = globalThis.$fa, o = globalThis.$fu, l = (r == null ? void 0 : r.precision) ?? 2, s = r == null ? void 0 : r.unit;
195
+ if ((s === "currency" || s === "%") && o) {
196
+ const i = {
195
197
  [t]: {
196
- unit: i === "currency" ? "currency" : "%",
197
- precision: s
198
+ unit: s === "currency" ? "currency" : "%",
199
+ precision: l
198
200
  }
199
201
  };
200
202
  try {
@@ -202,14 +204,14 @@ function j(t, e, r) {
202
204
  prop: t,
203
205
  currency: r == null ? void 0 : r.currency,
204
206
  value: e,
205
- obj: l
207
+ obj: i
206
208
  });
207
209
  } catch {
208
210
  }
209
211
  }
210
212
  if (n)
211
213
  try {
212
- return n(e, s);
214
+ return n(e, l);
213
215
  } catch {
214
216
  return String(e);
215
217
  }
@@ -217,22 +219,22 @@ function j(t, e, r) {
217
219
  }
218
220
  function ee(t, e, r = {}) {
219
221
  const { columns: n = [] } = t || {}, { resolveMetric: o } = r;
220
- return !n.length || !e || typeof e != "object" ? [] : n.map((s) => {
221
- const i = s.property ?? s.prop ?? "";
222
- if (!i)
222
+ return !n.length || !e || typeof e != "object" ? [] : n.map((l) => {
223
+ const s = l.property ?? l.prop ?? "";
224
+ if (!s)
223
225
  return "";
224
- let l = e[i];
225
- if (l === void 0 && (l = ""), l === "")
226
+ let i = e[s];
227
+ if (i === void 0 && (i = ""), i === "")
226
228
  return "";
227
- const c = typeof o == "function" ? o(i) : void 0;
229
+ const a = typeof o == "function" ? o(s) : void 0;
228
230
  try {
229
- return j(i, l, c);
231
+ return j(s, i, a);
230
232
  } catch {
231
- return String(l);
233
+ return String(i);
232
234
  }
233
235
  });
234
236
  }
235
- const T = "mvframe_primary", P = "mvframe_theme", m = { r: 255, g: 255, b: 255 }, W = { r: 0, g: 0, b: 0 }, V = [
237
+ const S = "mvframe_primary", x = "mvframe_theme", y = { r: 255, g: 255, b: 255 }, W = { r: 0, g: 0, b: 0 }, V = [
236
238
  "--el-color-primary-light-3",
237
239
  "--el-color-primary-light-5",
238
240
  "--el-color-primary-light-7",
@@ -240,7 +242,7 @@ const T = "mvframe_primary", P = "mvframe_theme", m = { r: 255, g: 255, b: 255 }
240
242
  "--el-color-primary-light-9",
241
243
  "--el-color-primary-dark-2"
242
244
  ];
243
- function S(t) {
245
+ function M(t) {
244
246
  let e = String(t).trim().replace(/^#/, "");
245
247
  if (e.length === 3 && (e = e.split("").map((n) => n + n).join("")), e.length >= 8 && (e = e.slice(0, 6)), e.length !== 6 || Number.isNaN(parseInt(e, 16)))
246
248
  return null;
@@ -251,7 +253,7 @@ function S(t) {
251
253
  b: r & 255
252
254
  };
253
255
  }
254
- function d(t, e, r) {
256
+ function h(t, e, r) {
255
257
  const n = (o) => Math.max(0, Math.min(255, Math.round(o)));
256
258
  return `#${[n(t), n(e), n(r)].map((o) => o.toString(16).padStart(2, "0")).join("")}`;
257
259
  }
@@ -259,10 +261,10 @@ function C(t) {
259
261
  const e = [t.r, t.g, t.b].map((r) => (r /= 255, r <= 0.03928 ? r / 12.92 : ((r + 0.055) / 1.055) ** 2.4));
260
262
  return 0.2126 * e[0] + 0.7152 * e[1] + 0.0722 * e[2];
261
263
  }
262
- function x(t) {
264
+ function L(t) {
263
265
  return C(t) > 0.5 ? "#1a1a1a" : "#ffffff";
264
266
  }
265
- function h(t, e, r) {
267
+ function m(t, e, r) {
266
268
  const n = r / 100, o = 1 - n;
267
269
  return {
268
270
  r: t.r * n + e.r * o,
@@ -271,17 +273,17 @@ function h(t, e, r) {
271
273
  };
272
274
  }
273
275
  function N(t) {
274
- const e = S(t);
276
+ const e = M(t);
275
277
  if (!e)
276
278
  return null;
277
- const r = h(m, e, 30), n = h(m, e, 50), o = h(m, e, 70), s = h(m, e, 80), i = h(m, e, 90), l = h(W, e, 20);
279
+ const r = m(y, e, 30), n = m(y, e, 50), o = m(y, e, 70), l = m(y, e, 80), s = m(y, e, 90), i = m(W, e, 20);
278
280
  return {
279
- "--el-color-primary-light-3": d(r.r, r.g, r.b),
280
- "--el-color-primary-light-5": d(n.r, n.g, n.b),
281
- "--el-color-primary-light-7": d(o.r, o.g, o.b),
282
- "--el-color-primary-light-8": d(s.r, s.g, s.b),
283
- "--el-color-primary-light-9": d(i.r, i.g, i.b),
284
- "--el-color-primary-dark-2": d(l.r, l.g, l.b)
281
+ "--el-color-primary-light-3": h(r.r, r.g, r.b),
282
+ "--el-color-primary-light-5": h(n.r, n.g, n.b),
283
+ "--el-color-primary-light-7": h(o.r, o.g, o.b),
284
+ "--el-color-primary-light-8": h(l.r, l.g, l.b),
285
+ "--el-color-primary-light-9": h(s.r, s.g, s.b),
286
+ "--el-color-primary-dark-2": h(i.r, i.g, i.b)
285
287
  };
286
288
  }
287
289
  function U(t) {
@@ -290,13 +292,13 @@ function U(t) {
290
292
  t.style.removeProperty(e);
291
293
  }
292
294
  function F(t, e) {
293
- const r = S(e.startsWith("#") ? e : `#${e}`);
295
+ const r = M(e.startsWith("#") ? e : `#${e}`);
294
296
  if (!r)
295
297
  return !1;
296
- const n = d(r.r, r.g, r.b);
297
- t.style.setProperty("--color-primary", n), t.style.setProperty("--el-color-primary", n), t.style.setProperty("--color-on-primary-text", x(r));
298
+ const n = h(r.r, r.g, r.b);
299
+ t.style.setProperty("--color-primary", n), t.style.setProperty("--el-color-primary", n), t.style.setProperty("--color-on-primary-text", L(r));
298
300
  const o = N(n);
299
- return o && Object.entries(o).forEach(([s, i]) => t.style.setProperty(s, i)), !0;
301
+ return o && Object.entries(o).forEach(([l, s]) => t.style.setProperty(l, s)), !0;
300
302
  }
301
303
  function z(t = {}) {
302
304
  const e = document.documentElement;
@@ -304,18 +306,18 @@ function z(t = {}) {
304
306
  const n = String(t.primary).trim();
305
307
  if (!F(e, n)) {
306
308
  e.style.setProperty("--color-primary", n), e.style.setProperty("--el-color-primary", n);
307
- const o = S(n.startsWith("#") ? n : `#${n}`);
308
- o && e.style.setProperty("--color-on-primary-text", x(o));
309
+ const o = M(n.startsWith("#") ? n : `#${n}`);
310
+ o && e.style.setProperty("--color-on-primary-text", L(o));
309
311
  }
310
312
  } else (t.primary === null || t.primary === "") && (e.style.removeProperty("--color-primary"), U(e));
311
313
  const r = t.mode ?? (e.classList.contains("dark") ? "dark" : "light");
312
314
  e.classList.toggle("dark", r === "dark");
313
315
  }
314
316
  function te(t) {
315
- t.primary !== void 0 && (t.primary == null || t.primary === "" ? localStorage.removeItem(T) : localStorage.setItem(T, String(t.primary))), t.mode !== void 0 && localStorage.setItem(P, t.mode);
317
+ t.primary !== void 0 && (t.primary == null || t.primary === "" ? localStorage.removeItem(S) : localStorage.setItem(S, String(t.primary))), t.mode !== void 0 && localStorage.setItem(x, t.mode);
316
318
  }
317
319
  function re() {
318
- const t = localStorage.getItem(T), r = localStorage.getItem(P) === "dark" ? "dark" : "light";
320
+ const t = localStorage.getItem(S), r = localStorage.getItem(x) === "dark" ? "dark" : "light";
319
321
  z({
320
322
  primary: t != null && t !== "" ? t : null,
321
323
  mode: r
@@ -323,8 +325,8 @@ function re() {
323
325
  }
324
326
  export {
325
327
  O as MVFRAME_STORAGE_LANG,
326
- T as MVFRAME_STORAGE_PRIMARY,
327
- P as MVFRAME_STORAGE_THEME,
328
+ S as MVFRAME_STORAGE_PRIMARY,
329
+ x as MVFRAME_STORAGE_THEME,
328
330
  z as applyMvframeTheme,
329
331
  _ as deepEqual,
330
332
  Z as download,
@@ -337,7 +339,7 @@ export {
337
339
  ae as mergeMaps,
338
340
  ce as patchMaps,
339
341
  te as persistMvframeTheme,
340
- B as sanitizeDownloadFileName,
342
+ H as sanitizeDownloadFileName,
341
343
  X as useLang,
342
344
  ue as useMap,
343
345
  D as useOptions,
package/dist/css/cpt.css CHANGED
@@ -1 +1 @@
1
- @charset "UTF-8";.MvcBtnGroup[data-v-25601eb8]{padding:.25rem;background:var(--color-white);border-radius:.375rem;-webkit-user-select:none;user-select:none}.MvcBtnGroup.sizeSmall[data-v-25601eb8]{padding:2px;border-radius:.25rem}.MvcBtnGroup.sizeSmall .btnItem[data-v-25601eb8]{padding:.25rem .625rem;font-size:.75rem;line-height:1.5;border-radius:.1875rem}.MvcBtnGroup.sizeLarge[data-v-25601eb8]{padding:.375rem;border-radius:.5rem}.MvcBtnGroup.sizeLarge .btnItem[data-v-25601eb8]{padding:.5rem 1.125rem;font-size:1rem;line-height:1.5;border-radius:.375rem}.MvcBtnGroup .btnItem[data-v-25601eb8]{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .875rem;font-size:.875rem;line-height:1.5;color:var(--color-txt-p);background:transparent;border:none;border-radius:.3125rem;cursor:pointer;transition:var(--trans-all)}.MvcBtnGroup .btnItem[data-v-25601eb8]:hover:not(:disabled):not(.isActive){background:var(--color-bg-menu-item-hover)}.MvcBtnGroup .btnItem.isActive[data-v-25601eb8]{color:var(--color-on-primary-text);background:var(--color-primary);position:relative}.MvcBtnGroup .btnItem.isActive[data-v-25601eb8]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.MvcBtnGroup .btnItem[data-v-25601eb8]:disabled{opacity:.5;cursor:not-allowed}.MvcCard[data-v-a45ce05e]{position:relative;border:var(--border-d);border-radius:.5rem;background:var(--color-bg-page-header);box-sizing:border-box;transition:box-shadow var(--trans)}.MvcCard[data-v-a45ce05e]:hover{box-shadow:0 .5rem .5rem color-mix(in srgb,var(--color-bg-dark) 6%,var(--color-white))}.MvcCard .header[data-v-a45ce05e]{position:relative;padding:.75rem 1rem;border-block-end:var(--border-d);z-index:2;-webkit-user-select:none;user-select:none}.MvcCard .header .headerTitle[data-v-a45ce05e]{margin:0;font-size:.875rem;font-weight:700;color:var(--color-txt-h2)}.MvcCard .body[data-v-a45ce05e]{position:relative;padding:1rem;min-height:6.25rem;z-index:1}.MvcCard .footer[data-v-a45ce05e]{position:relative;padding:.75rem 1rem;border-block-start:var(--border-d);z-index:2;-webkit-user-select:none;user-select:none}.dragArea[data-v-665c2158]{position:absolute;top:0;left:0;bottom:0;width:1rem;display:flex;align-items:center;z-index:99}.dragArea .dragHandle[data-v-665c2158]{display:flex;align-items:center;width:.875rem;height:1.75rem;background-color:var(--color-border);border-radius:0 .125rem .125rem 0;opacity:0;cursor:ew-resize;z-index:99;transition:var(--trans-all)}.dragArea .dragHandle[data-v-665c2158]:hover,.dragArea .dragHandle.active[data-v-665c2158]{opacity:1;color:var(--color-white);background-color:var(--color-primary);box-shadow:.25rem 0 .5rem var(--color-dark1)}.dragArea:hover .dragHandle[data-v-665c2158]{opacity:1}.MvcDrawerBody[data-v-1df88ac3]{position:relative;width:100%;overflow:hidden}.drawerFooter[data-v-1df88ac3]{background-image:linear-gradient(to top,50% var(--color-white),100 transparent)}.FrameTab .tabShadow[data-v-4b47340e]{position:absolute;top:100%;left:0;right:0;height:.5rem;background-image:linear-gradient(to bottom,rgba(0,0,0,.05) 0,transparent 100%);opacity:0;transition:opacity var(--trans)}.FrameTab .tabShadow.visible[data-v-4b47340e]{opacity:1}.FrameTab .tabArea[data-v-4b47340e]:after{content:"";position:absolute;top:2.175rem;left:0;right:0;border-bottom:var(--border-d);z-index:1}.FrameTab .tabItem[data-v-4b47340e]{margin-block-end:-1px;border:var(--border-d);border-block-end-color:transparent;border-radius:.25rem .25rem 0 0;background-color:var(--color-white);opacity:.5;overflow:hidden;transition:var(--trans-all)}.FrameTab .tabItem[data-v-4b47340e]:hover{opacity:.8}.FrameTab .tabItem.active[data-v-4b47340e]{opacity:1;border-block-end-color:var(--color-white);z-index:3}.FrameTab .tabItem .abs[data-v-4b47340e]{transition:var(--trans-all);transform:translate(2.25rem)}.FrameTab .tabItem .abs[data-v-4b47340e]:hover{opacity:.8;color:var(--color-primary)}.FrameTab .tabItem.hoverItem.active[data-v-4b47340e]{padding-inline-end:2.25rem}.FrameTab .tabItem.hoverItem.active .abs[data-v-4b47340e]{transform:translate(-.375rem)}.FrameTab .tabItem.hoverItem[data-v-4b47340e]:hover{padding-inline-end:2.25rem}.FrameTab .tabItem.hoverItem:hover .abs[data-v-4b47340e]{transform:translate(-.375rem)}.FrameTab .tabItem.disabled[data-v-4b47340e]{opacity:.7;cursor:not-allowed}.FrameMenu[data-v-fd4f2416]{width:12rem;background-color:var(--color-bg-menu);overflow:hidden}.FrameMenu[data-v-fd4f2416]:after{content:"";position:absolute;top:0;right:0;bottom:0;border-right:var(--border-d)}.FrameMenu:hover .logomini[data-v-fd4f2416]{opacity:.1}.FrameMenu:hover .collapseArea[data-v-fd4f2416]{display:block!important}.FrameMenu .LogoArea .logomini[data-v-fd4f2416]{display:none}.FrameMenu .collapseArea[data-v-fd4f2416]{top:50%;right:1rem;height:1.25rem;width:1.24rem;transform:translateY(-50%)}.FrameMenu .MenuArea[data-v-fd4f2416]{height:calc(100vh - 8rem)}.FrameMenu .MenuArea .menuItem[data-v-fd4f2416]{height:2.75rem;transition:var(--trans-all)}.FrameMenu .MenuArea .menuItem[data-v-fd4f2416]:hover{background-color:var(--color-bg-menu-item-hover)}.FrameMenu .MenuArea .menuItem.active[data-v-fd4f2416]:hover{background-color:var(--color-primary);opacity:.8}.FrameMenu .MenuArea .menuItem.active .itemIcon[data-v-fd4f2416]{color:var(--color-on-primary-text)}.FrameMenu .MenuArea .childrenItem[data-v-fd4f2416]{transition:var(--trans-all)}.FrameMenu .MenuArea .childrenItem[data-v-fd4f2416]:hover{background-color:var(--color-bg-menu-children-item-hover)}.FrameMenu .MenuArea .childrenItem.active[data-v-fd4f2416]:hover{background-color:var(--color-primary);opacity:.8}.FrameMenu .MenuArea .itemChildrenArea[data-v-fd4f2416]{background-color:var(--color-bg-menu-children)}.FrameMenu .MenuArea .itemTitle.active[data-v-fd4f2416]{color:var(--color-on-primary-text)}.FrameMenu.collapse[data-v-fd4f2416]{width:4rem}.FrameMenu.collapse .collapseArea[data-v-fd4f2416]{right:1.5rem;display:none}.FrameMenu.collapse .LogoArea .logo[data-v-fd4f2416]{display:none}.FrameMenu.collapse .LogoArea .logomini[data-v-fd4f2416]{display:block;transition:opacity var(--trans)}.FrameMenu.collapse .MenuArea .menuItem.activeChild[data-v-fd4f2416]{position:relative}.FrameMenu.collapse .MenuArea .menuItem.activeChild[data-v-fd4f2416]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.FrameMenu.collapse .MenuArea .itemChildrenArea[data-v-fd4f2416]{display:none}.FrameFooter[data-v-c3ba0162]{display:flex;height:3rem;padding:.5rem 1rem;gap:.5rem;font-size:14px}.MvcFrame[data-v-d4996e9c]{display:flex}.MvcFrame .PageArea[data-v-d4996e9c]{flex-grow:1;max-width:100%;position:relative;min-height:0}.loadingFade-enter-active[data-v-d89fa752],.loadingFade-leave-active[data-v-d89fa752]{transition:opacity var(--trans)}.loadingFade-enter-from[data-v-d89fa752],.loadingFade-leave-to[data-v-d89fa752]{opacity:0}.MvcLoading[data-v-d89fa752]{pointer-events:auto;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem)}.loaderTxt[data-v-d89fa752]{max-width:15rem;word-break:break-word}.MvcLogin[data-v-6faa6992]{background-color:var(--color-bg-body)}.panelWrap[data-v-6faa6992]{background-color:var(--color-bg-menu);box-shadow:0 .25rem 1rem #0000000f}.qr-dingtalk[data-v-6faa6992]{background:#0089ff}.qr-feishu[data-v-6faa6992]{background:#3370ff}.qr-wechat[data-v-6faa6992]{background:#07c160}.oauthGoogle[data-v-6faa6992]{display:flex;align-items:center;justify-content:center;gap:.75rem;min-height:2.5rem;padding:.5rem 1rem;box-sizing:border-box;background:#fff;border:1px solid #747775;border-radius:.25rem;font-family:Roboto,system-ui,-apple-system,Segoe UI,sans-serif;font-size:.875rem;font-weight:500;line-height:1.25;color:#1f1f1f;cursor:pointer;transition:var(--trans-all)}.oauthGoogle[data-v-6faa6992]:hover:not(:disabled){box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.oauthGoogle[data-v-6faa6992]:disabled{opacity:.38;cursor:not-allowed}.oauthGoogle[data-v-6faa6992]:focus-visible{outline:2px solid #4285f4;outline-offset:2px}.oauthApple[data-v-6faa6992]{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:2.5rem;padding:.5rem 1rem;box-sizing:border-box;background:#000;border:none;border-radius:.375rem;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;font-size:1.0625rem;font-weight:600;line-height:1.2;color:#fff;cursor:pointer;transition:var(--trans-all)}.oauthApple[data-v-6faa6992]:hover:not(:disabled){opacity:.88}.oauthApple[data-v-6faa6992]:disabled{opacity:.3;cursor:not-allowed}.oauthApple[data-v-6faa6992]:focus-visible{outline:2px solid #fff;outline-offset:2px}.MvcNote[data-v-e3e84cc8]{position:relative;padding:.5rem 1rem;background-color:var(--color-bg-menu);font-size:.875rem;border-radius:0 .5rem .5rem 0}.MvcNote[data-v-e3e84cc8]:hover:before{opacity:1}.MvcNote[data-v-e3e84cc8]:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;pointer-events:none;border-radius:0 .5rem .5rem 0;border:1px solid var(--color-gray);transition:opacity var(--trans)}.MvcPage[data-v-7d18d3b1]{min-height:calc(100vh - 48px)}.MvcPage .PageHeader[data-v-7d18d3b1]{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;min-height:4rem;border-bottom:var(--border-d);background-color:var(--color-bg-page-header)}.MvcPage .PageHeader .PageHeaderTitle[data-v-7d18d3b1]{margin:0}.MvcPage .PageHeader .PageHeaderSubTitle[data-v-7d18d3b1]{margin:0;font-size:12px;color:var(--color-txt-p)}.MvcPage .PageBody[data-v-7d18d3b1]{padding:1rem;background-color:var(--color-bg-page-body)}.ghost[data-v-1927ce52]{cursor:grabbing}.typeItem[data-v-1927ce52]{cursor:pointer}.typeItem[data-v-1927ce52]:hover{background-color:var(--mg-gray3)}.typeItem.active[data-v-1927ce52]{color:var(--mg-white);background-color:var(--mg-primary)}.columnItem[data-v-1927ce52]:hover{background-color:var(--mg-gray3)}.columnItem .fixedBtn[data-v-1927ce52]{cursor:pointer}.columnItem .fixedBtn[data-v-1927ce52]:hover{background-color:var(--mg-primary1)}.MainTable[data-v-39b022f5]{max-width:calc(100% + 2px);width:calc(100% + 2px);margin:0 -1px}[data-v-4dba94bf] .el-textarea__inner{box-sizing:border-box}.ghost[data-v-73161392]{cursor:grabbing}.typeItem[data-v-73161392]{cursor:pointer}.typeItem[data-v-73161392]:hover{background-color:var(--mg-gray3)}.typeItem.active[data-v-73161392]{color:var(--color-txt-white);background-color:var(--color-bg-menu-item-active);position:relative}.typeItem.active[data-v-73161392]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.columnItem[data-v-73161392]:hover{background-color:var(--color-bg-menu-item-hover)}.columnItem .fixedBtn[data-v-73161392]{cursor:pointer}.columnItem .fixedBtn[data-v-73161392]:hover{background-color:var(--mg-primary1)}.tableFooter[data-v-d32455fb]{margin-block-start:-1px;border-block-start:var(--border-d);border-radius:0 0 .5rem .5rem}.vtableHost[data-v-d32455fb]{min-height:10rem;background-color:var(--color-white)}.vtableHostFill[data-v-d32455fb]{height:100%}.treeCellLoadMask[data-v-d32455fb]{z-index:10;box-sizing:border-box;pointer-events:auto;cursor:wait;background-color:#ffffffb8;border-radius:.125rem}.treeCellLoadMask .loadMaskIcon[data-v-d32455fb]{pointer-events:none}
1
+ @charset "UTF-8";.MvcBtnGroup[data-v-25601eb8]{padding:.25rem;background:var(--color-white);border-radius:.375rem;-webkit-user-select:none;user-select:none}.MvcBtnGroup.sizeSmall[data-v-25601eb8]{padding:2px;border-radius:.25rem}.MvcBtnGroup.sizeSmall .btnItem[data-v-25601eb8]{padding:.25rem .625rem;font-size:.75rem;line-height:1.5;border-radius:.1875rem}.MvcBtnGroup.sizeLarge[data-v-25601eb8]{padding:.375rem;border-radius:.5rem}.MvcBtnGroup.sizeLarge .btnItem[data-v-25601eb8]{padding:.5rem 1.125rem;font-size:1rem;line-height:1.5;border-radius:.375rem}.MvcBtnGroup .btnItem[data-v-25601eb8]{display:inline-flex;align-items:center;justify-content:center;gap:.25rem;padding:.375rem .875rem;font-size:.875rem;line-height:1.5;color:var(--color-txt-p);background:transparent;border:none;border-radius:.3125rem;cursor:pointer;transition:var(--trans-all)}.MvcBtnGroup .btnItem[data-v-25601eb8]:hover:not(:disabled):not(.isActive){background:var(--color-bg-menu-item-hover)}.MvcBtnGroup .btnItem.isActive[data-v-25601eb8]{color:var(--color-on-primary-text);background:var(--color-primary);position:relative}.MvcBtnGroup .btnItem.isActive[data-v-25601eb8]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.MvcBtnGroup .btnItem[data-v-25601eb8]:disabled{opacity:.5;cursor:not-allowed}.MvcCard[data-v-677436e0]{position:relative;border:var(--border-d);border-radius:.5rem;background:var(--color-bg-page-header);box-sizing:border-box;transition:box-shadow var(--trans)}.MvcCard[data-v-677436e0]:hover{box-shadow:0 .5rem .5rem color-mix(in srgb,var(--color-dark) 6%,var(--color-white))}.MvcCard.MvcCard--fillParent[data-v-677436e0]{display:flex;flex-direction:column;align-self:stretch;min-height:0;height:100%}.MvcCard .header[data-v-677436e0]{position:relative;padding:.75rem 1rem;border-block-end:var(--border-d);z-index:2;flex-shrink:0;-webkit-user-select:none;user-select:none}.MvcCard .header .headerTitle[data-v-677436e0]{margin:0;font-size:.875rem;font-weight:700;color:var(--color-txt-h2)}.MvcCard .body[data-v-677436e0]{position:relative;padding:1rem;min-height:6.25rem;overflow:auto;z-index:1}.MvcCard.MvcCard--fillParent .body[data-v-677436e0]{flex:1 1 auto;min-height:0}.MvcCard .footer[data-v-677436e0]{position:relative;padding:.75rem 1rem;border-block-start:var(--border-d);z-index:2;flex-shrink:0;-webkit-user-select:none;user-select:none}.dragArea[data-v-665c2158]{position:absolute;top:0;left:0;bottom:0;width:1rem;display:flex;align-items:center;z-index:99}.dragArea .dragHandle[data-v-665c2158]{display:flex;align-items:center;width:.875rem;height:1.75rem;background-color:var(--color-border);border-radius:0 .125rem .125rem 0;opacity:0;cursor:ew-resize;z-index:99;transition:var(--trans-all)}.dragArea .dragHandle[data-v-665c2158]:hover,.dragArea .dragHandle.active[data-v-665c2158]{opacity:1;color:var(--color-white);background-color:var(--color-primary);box-shadow:.25rem 0 .5rem var(--color-dark1)}.dragArea:hover .dragHandle[data-v-665c2158]{opacity:1}.MvcDrawerBody[data-v-1df88ac3]{position:relative;width:100%;overflow:hidden}.drawerFooter[data-v-1df88ac3]{background-image:linear-gradient(to top,50% var(--color-white),100 transparent)}.FrameTab .tabShadow[data-v-4344d2df]{position:absolute;top:100%;left:0;right:0;height:.5rem;background-image:linear-gradient(to bottom,rgba(0,0,0,.05) 0,transparent 100%);opacity:0;transition:opacity var(--trans)}.FrameTab .tabShadow.visible[data-v-4344d2df]{opacity:1}.FrameTab .tabArea[data-v-4344d2df]:after{content:"";position:absolute;top:2.175rem;left:0;right:0;border-bottom:var(--border-d);z-index:1}.FrameTab .tabItem[data-v-4344d2df]{margin-block-end:-1px;border:var(--border-d);border-block-end-color:transparent;border-radius:.25rem .25rem 0 0;background-color:var(--color-white);opacity:.5;overflow:hidden;transition:var(--trans-all)}.FrameTab .tabItem[data-v-4344d2df]:hover{opacity:.8}.FrameTab .tabItem.active[data-v-4344d2df]{opacity:1;border-block-end-color:var(--color-white);z-index:3;background-color:var(--color-bg-page-header)}.FrameTab .tabItem .abs[data-v-4344d2df]{transition:var(--trans-all);transform:translate(2.25rem)}.FrameTab .tabItem .abs[data-v-4344d2df]:hover{opacity:.8;color:var(--color-primary)}.FrameTab .tabItem.hoverItem.active[data-v-4344d2df]{padding-inline-end:2.25rem}.FrameTab .tabItem.hoverItem.active .abs[data-v-4344d2df]{transform:translate(-.375rem)}.FrameTab .tabItem.hoverItem[data-v-4344d2df]:hover{padding-inline-end:2.25rem}.FrameTab .tabItem.hoverItem:hover .abs[data-v-4344d2df]{transform:translate(-.375rem)}.FrameTab .tabItem.disabled[data-v-4344d2df]{opacity:.7;cursor:not-allowed}.FrameMenu[data-v-d7eb624b]{width:12rem;background-color:var(--color-bg-menu);overflow:hidden}.FrameMenu[data-v-d7eb624b]:after{content:"";position:absolute;top:0;right:0;bottom:0;border-right:var(--border-d)}.FrameMenu:hover .logomini[data-v-d7eb624b]{opacity:.1}.FrameMenu:hover .collapseArea[data-v-d7eb624b]{display:block!important}.FrameMenu .LogoArea .logomini[data-v-d7eb624b]{display:none}.FrameMenu .collapseArea[data-v-d7eb624b]{top:50%;right:1rem;height:1.25rem;width:1.24rem;transform:translateY(-50%)}.FrameMenu .MenuArea[data-v-d7eb624b]{height:calc(100vh - 8rem)}.FrameMenu .MenuArea .menuItem[data-v-d7eb624b]{height:2.75rem;transition:var(--trans-all)}.FrameMenu .MenuArea .menuItem[data-v-d7eb624b]:hover{background-color:var(--color-bg-menu-item-hover)}.FrameMenu .MenuArea .menuItem.active[data-v-d7eb624b]:hover{background-color:var(--color-primary);opacity:.8}.FrameMenu .MenuArea .menuItem.active .itemIcon[data-v-d7eb624b]{color:var(--color-on-primary-text)}.FrameMenu .MenuArea .childrenItem[data-v-d7eb624b]{transition:var(--trans-all)}.FrameMenu .MenuArea .childrenItem[data-v-d7eb624b]:hover{background-color:var(--color-bg-menu-children-item-hover)}.FrameMenu .MenuArea .childrenItem.active[data-v-d7eb624b]:hover{background-color:var(--color-primary);opacity:.8}.FrameMenu .MenuArea .itemChildrenArea[data-v-d7eb624b]{background-color:var(--color-bg-menu-children)}.FrameMenu .MenuArea .itemTitle.active[data-v-d7eb624b]{color:var(--color-on-primary-text)}.FrameMenu.collapse[data-v-d7eb624b]{width:4rem}.FrameMenu.collapse .collapseArea[data-v-d7eb624b]{right:1.5rem;display:none}.FrameMenu.collapse .LogoArea .logo[data-v-d7eb624b]{display:none}.FrameMenu.collapse .LogoArea .logomini[data-v-d7eb624b]{display:block;transition:opacity var(--trans)}.FrameMenu.collapse .MenuArea .menuItem.activeChild[data-v-d7eb624b]{position:relative}.FrameMenu.collapse .MenuArea .menuItem.activeChild[data-v-d7eb624b]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.FrameMenu.collapse .MenuArea .itemChildrenArea[data-v-d7eb624b]{display:none}.FrameFooter[data-v-c3ba0162]{display:flex;height:3rem;padding:.5rem 1rem;gap:.5rem;font-size:14px}.MvcFrame[data-v-b25da17b]{display:flex}.MvcFrame .PageArea[data-v-b25da17b]{flex-grow:1;position:relative;min-height:0}.MvcList[data-v-6a45c452]{display:flex;flex-direction:column;width:100%;min-height:0;flex:1 1 auto;height:100%;-webkit-user-select:none;user-select:none}.MvcList .listViewport[data-v-6a45c452]{position:relative;flex:1 1 auto;min-height:0;overflow:hidden}.MvcList .listScroll[data-v-6a45c452]{position:relative;box-sizing:border-box;height:100%;max-height:100%}.MvcList .listItem[data-v-6a45c452]{padding:.5rem;margin-block-end:.25rem}.MvcList .listItem[data-v-6a45c452]:last-child{margin-block-end:0}.MvcList .listItem[data-v-6a45c452]{font-size:.75rem;line-height:1.5;color:var(--color-txt-p);background:transparent;border-radius:.25rem;cursor:pointer;transition:var(--trans-all)}.MvcList .listItem[data-v-6a45c452]:hover:not(.active):not(.isDisabled){background:var(--color-bg-menu-item-hover)}.MvcList .listItem.active[data-v-6a45c452]{position:sticky!important;top:0;color:var(--color-on-primary-text);background:var(--color-primary);z-index:9;position:relative}.MvcList .listItem.active[data-v-6a45c452]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.MvcList .listItem.isDisabled[data-v-6a45c452]{opacity:.5;cursor:not-allowed}.MvcList.sizeSmall .listItem[data-v-6a45c452]{padding:.25rem .375rem;margin-block-end:.125rem;font-size:.6875rem;border-radius:.1875rem}.MvcList.sizeSmall .listItem[data-v-6a45c452]:last-child{margin-block-end:0}.MvcList.sizeLarge .listItem[data-v-6a45c452]{padding:.625rem .75rem;margin-block-end:.5rem;font-size:.875rem;border-radius:.375rem}.MvcList.sizeLarge .listItem[data-v-6a45c452]:last-child{margin-block-end:0}.loadingFade-enter-active[data-v-d89fa752],.loadingFade-leave-active[data-v-d89fa752]{transition:opacity var(--trans)}.loadingFade-enter-from[data-v-d89fa752],.loadingFade-leave-to[data-v-d89fa752]{opacity:0}.MvcLoading[data-v-d89fa752]{pointer-events:auto;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem)}.loaderTxt[data-v-d89fa752]{max-width:15rem;word-break:break-word}.MvcLogin[data-v-6faa6992]{background-color:var(--color-bg-body)}.panelWrap[data-v-6faa6992]{background-color:var(--color-bg-menu);box-shadow:0 .25rem 1rem #0000000f}.qr-dingtalk[data-v-6faa6992]{background:#0089ff}.qr-feishu[data-v-6faa6992]{background:#3370ff}.qr-wechat[data-v-6faa6992]{background:#07c160}.oauthGoogle[data-v-6faa6992]{display:flex;align-items:center;justify-content:center;gap:.75rem;min-height:2.5rem;padding:.5rem 1rem;box-sizing:border-box;background:#fff;border:1px solid #747775;border-radius:.25rem;font-family:Roboto,system-ui,-apple-system,Segoe UI,sans-serif;font-size:.875rem;font-weight:500;line-height:1.25;color:#1f1f1f;cursor:pointer;transition:var(--trans-all)}.oauthGoogle[data-v-6faa6992]:hover:not(:disabled){box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.oauthGoogle[data-v-6faa6992]:disabled{opacity:.38;cursor:not-allowed}.oauthGoogle[data-v-6faa6992]:focus-visible{outline:2px solid #4285f4;outline-offset:2px}.oauthApple[data-v-6faa6992]{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:2.5rem;padding:.5rem 1rem;box-sizing:border-box;background:#000;border:none;border-radius:.375rem;font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Helvetica Neue,sans-serif;font-size:1.0625rem;font-weight:600;line-height:1.2;color:#fff;cursor:pointer;transition:var(--trans-all)}.oauthApple[data-v-6faa6992]:hover:not(:disabled){opacity:.88}.oauthApple[data-v-6faa6992]:disabled{opacity:.3;cursor:not-allowed}.oauthApple[data-v-6faa6992]:focus-visible{outline:2px solid #fff;outline-offset:2px}.MvcNote[data-v-e3e84cc8]{position:relative;padding:.5rem 1rem;background-color:var(--color-bg-menu);font-size:.875rem;border-radius:0 .5rem .5rem 0}.MvcNote[data-v-e3e84cc8]:hover:before{opacity:1}.MvcNote[data-v-e3e84cc8]:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;opacity:0;pointer-events:none;border-radius:0 .5rem .5rem 0;border:1px solid var(--color-gray);transition:opacity var(--trans)}.MvcPage[data-v-2e97618a]{min-height:calc(100vh - 3rem)}.MvcPage .PageHeader[data-v-2e97618a]{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem;min-height:4rem;border-bottom:var(--border-d);background-color:var(--color-bg-page-header)}.MvcPage .PageHeader .PageHeaderTitle[data-v-2e97618a]{margin:0}.MvcPage .PageHeader .PageHeaderSubTitle[data-v-2e97618a]{margin:0;font-size:.875rem;color:var(--color-txt-p)}.MvcPage .PageBody[data-v-2e97618a]{padding:1rem;background-color:var(--color-bg-page-body)}.ghost[data-v-1927ce52]{cursor:grabbing}.typeItem[data-v-1927ce52]{cursor:pointer}.typeItem[data-v-1927ce52]:hover{background-color:var(--mg-gray3)}.typeItem.active[data-v-1927ce52]{color:var(--mg-white);background-color:var(--mg-primary)}.columnItem[data-v-1927ce52]:hover{background-color:var(--mg-gray3)}.columnItem .fixedBtn[data-v-1927ce52]{cursor:pointer}.columnItem .fixedBtn[data-v-1927ce52]:hover{background-color:var(--mg-primary1)}.MainTable[data-v-39b022f5]{max-width:calc(100% + 2px);width:calc(100% + 2px);margin:0 -1px}[data-v-4dba94bf] .el-textarea__inner{box-sizing:border-box}.ghost[data-v-73161392]{cursor:grabbing}.typeItem[data-v-73161392]{cursor:pointer}.typeItem[data-v-73161392]:hover{background-color:var(--mg-gray3)}.typeItem.active[data-v-73161392]{color:var(--color-txt-white);background-color:var(--color-bg-menu-item-active);position:relative}.typeItem.active[data-v-73161392]:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;opacity:.25;background-color:var(--color-primary);transform:translateY(25%);pointer-events:none;filter:blur(10px);z-index:0}.columnItem[data-v-73161392]:hover{background-color:var(--color-bg-menu-item-hover)}.columnItem .fixedBtn[data-v-73161392]{cursor:pointer}.columnItem .fixedBtn[data-v-73161392]:hover{background-color:var(--mg-primary1)}.tableFooter[data-v-a13ba899]{margin-block-start:-1px;border-block-start:var(--border-d);border-radius:0 0 .5rem .5rem}.vtableHost[data-v-a13ba899]{min-height:10rem;background-color:var(--color-white)}.vtableHostFill[data-v-a13ba899]{height:100%}.treeCellLoadMask[data-v-a13ba899]{z-index:10;box-sizing:border-box;pointer-events:auto;cursor:wait;background-color:#ffffffb8;border-radius:.125rem}.treeCellLoadMask .loadMaskIcon[data-v-a13ba899]{pointer-events:none}