@ibdop/platform-kit 1.0.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/README.md +63 -0
- package/dist/components/ErrorBoundary.d.ts +68 -0
- package/dist/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/Notification.d.ts +46 -0
- package/dist/components/Notification.d.ts.map +1 -0
- package/dist/components/VersionInfo.d.ts +18 -0
- package/dist/components/VersionInfo.d.ts.map +1 -0
- package/dist/components/index.d.ts +8 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/hooks/index.d.ts +9 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/useApi.d.ts +65 -0
- package/dist/hooks/useApi.d.ts.map +1 -0
- package/dist/hooks/useInfoData.d.ts +35 -0
- package/dist/hooks/useInfoData.d.ts.map +1 -0
- package/dist/hooks/usePermissions.d.ts +23 -0
- package/dist/hooks/usePermissions.d.ts.map +1 -0
- package/dist/hooks/useShellAuth.d.ts +23 -0
- package/dist/hooks/useShellAuth.d.ts.map +1 -0
- package/dist/hooks/useV1Config.d.ts +27 -0
- package/dist/hooks/useV1Config.d.ts.map +1 -0
- package/dist/index.cjs.js +18 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.es.js +1500 -0
- package/dist/index.umd.js +18 -0
- package/dist/services/api.d.ts +59 -0
- package/dist/services/api.d.ts.map +1 -0
- package/dist/services/index.d.ts +8 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/logger.d.ts +41 -0
- package/dist/services/logger.d.ts.map +1 -0
- package/dist/types/index.d.ts +178 -0
- package/dist/types/index.d.ts.map +1 -0
- package/package.json +90 -0
- package/src/components/ErrorBoundary.tsx +292 -0
- package/src/components/Notification.tsx +297 -0
- package/src/components/VersionInfo.tsx +271 -0
- package/src/components/index.ts +14 -0
- package/src/global.d.ts +40 -0
- package/src/hooks/index.ts +13 -0
- package/src/hooks/useApi.ts +314 -0
- package/src/hooks/useInfoData.ts +124 -0
- package/src/hooks/usePermissions.ts +88 -0
- package/src/hooks/useShellAuth.ts +145 -0
- package/src/hooks/useV1Config.ts +112 -0
- package/src/index.ts +17 -0
- package/src/services/api.ts +290 -0
- package/src/services/index.ts +9 -0
- package/src/services/logger.ts +71 -0
- package/src/types/index.ts +215 -0
package/dist/index.es.js
ADDED
|
@@ -0,0 +1,1500 @@
|
|
|
1
|
+
import Ge, { useState as T, useRef as kt, useCallback as j, useEffect as Z, useMemo as Fe, Component as Ot, createContext as jt, useContext as Mt } from "react";
|
|
2
|
+
import Nt from "axios";
|
|
3
|
+
const Ue = {
|
|
4
|
+
log: (...n) => {
|
|
5
|
+
},
|
|
6
|
+
warn: (...n) => {
|
|
7
|
+
}
|
|
8
|
+
};
|
|
9
|
+
function ce() {
|
|
10
|
+
if (typeof window > "u") return null;
|
|
11
|
+
const n = window;
|
|
12
|
+
if (n.__SHELL_AUTH_INSTANCE__)
|
|
13
|
+
return n.__SHELL_AUTH_INSTANCE__;
|
|
14
|
+
const r = window;
|
|
15
|
+
return r.__SHELL_AUTH__?.authInstance ? r.__SHELL_AUTH__.authInstance : null;
|
|
16
|
+
}
|
|
17
|
+
function Pt() {
|
|
18
|
+
const [n, r] = T(null), [o, l] = T(!0), i = kt(0), d = 20, s = j(() => ce(), []);
|
|
19
|
+
Z(() => {
|
|
20
|
+
const y = s();
|
|
21
|
+
if (y) {
|
|
22
|
+
r(y), l(!1);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const h = (u) => {
|
|
26
|
+
r(u.detail), l(!1);
|
|
27
|
+
}, b = setInterval(() => {
|
|
28
|
+
i.current++;
|
|
29
|
+
const u = s();
|
|
30
|
+
u ? (Ue.log("Auth found via polling, attempts:", i.current), r(u), l(!1), clearInterval(b)) : i.current >= d && (l(!1), clearInterval(b));
|
|
31
|
+
}, 500);
|
|
32
|
+
return window.addEventListener("shell-auth-ready", h), () => {
|
|
33
|
+
clearInterval(b), window.removeEventListener("shell-auth-ready", h);
|
|
34
|
+
};
|
|
35
|
+
}, [s]);
|
|
36
|
+
const p = n || {
|
|
37
|
+
user: null,
|
|
38
|
+
isAuthenticated: !1,
|
|
39
|
+
isLoading: o,
|
|
40
|
+
signinRedirect: async () => {
|
|
41
|
+
const y = ce();
|
|
42
|
+
y?.signinRedirect ? await y.signinRedirect() : typeof window < "u" && (window.location.href = "/");
|
|
43
|
+
},
|
|
44
|
+
removeUser: async () => {
|
|
45
|
+
const y = ce();
|
|
46
|
+
y?.removeUser && await y.removeUser();
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
return Ue.log("Auth result:", { isAuthenticated: p.isAuthenticated, isLoading: p.isLoading }), p;
|
|
50
|
+
}
|
|
51
|
+
const Dt = {
|
|
52
|
+
log: (...n) => {
|
|
53
|
+
},
|
|
54
|
+
warn: (...n) => {
|
|
55
|
+
},
|
|
56
|
+
error: (...n) => {
|
|
57
|
+
console.error("[useInfoData]", ...n);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
function Lt(n) {
|
|
61
|
+
if (n) return n;
|
|
62
|
+
if (typeof window < "u") {
|
|
63
|
+
const r = window;
|
|
64
|
+
if (r.__MF_NAME__) return r.__MF_NAME__;
|
|
65
|
+
}
|
|
66
|
+
return "unknown-mfe";
|
|
67
|
+
}
|
|
68
|
+
function $t(n) {
|
|
69
|
+
const [r, o] = T(null), [l, i] = T(!0), [d, s] = T(null), x = j(() => {
|
|
70
|
+
const y = Lt(n?.mfeName).replace("@ib-dop/", "");
|
|
71
|
+
i(!0), s(null), fetch(`/svc/${y}/info.json`).then((h) => {
|
|
72
|
+
if (!h.ok)
|
|
73
|
+
throw new Error(`HTTP ${h.status}: ${h.statusText}`);
|
|
74
|
+
return h.json();
|
|
75
|
+
}).then((h) => {
|
|
76
|
+
o(h);
|
|
77
|
+
}).catch((h) => {
|
|
78
|
+
Dt.error("Failed to load info:", h), s(h instanceof Error ? h.message : String(h));
|
|
79
|
+
}).finally(() => {
|
|
80
|
+
i(!1);
|
|
81
|
+
});
|
|
82
|
+
}, [n?.mfeName]);
|
|
83
|
+
return Z(() => {
|
|
84
|
+
x();
|
|
85
|
+
}, [x]), {
|
|
86
|
+
data: r,
|
|
87
|
+
isLoading: l,
|
|
88
|
+
error: d,
|
|
89
|
+
refetch: x
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
const fe = {
|
|
93
|
+
log: (...n) => {
|
|
94
|
+
},
|
|
95
|
+
warn: (...n) => {
|
|
96
|
+
},
|
|
97
|
+
error: (...n) => {
|
|
98
|
+
console.error("[useV1Config]", ...n);
|
|
99
|
+
}
|
|
100
|
+
}, K = {
|
|
101
|
+
authority: "",
|
|
102
|
+
client_id: "",
|
|
103
|
+
environment: "development"
|
|
104
|
+
};
|
|
105
|
+
function Kt() {
|
|
106
|
+
const [n, r] = T(null), [o, l] = T(!0), [i, d] = T(null);
|
|
107
|
+
return Z(() => {
|
|
108
|
+
(() => {
|
|
109
|
+
if (typeof sessionStorage > "u") {
|
|
110
|
+
d("sessionStorage not available"), r(K), l(!1);
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
try {
|
|
114
|
+
const x = sessionStorage.getItem("config");
|
|
115
|
+
if (x) {
|
|
116
|
+
const p = JSON.parse(x);
|
|
117
|
+
r({ ...K, ...p }), d(null), fe.log("Config loaded successfully");
|
|
118
|
+
} else
|
|
119
|
+
r(K), d("Config not found in sessionStorage"), fe.warn("Config not found in sessionStorage");
|
|
120
|
+
} catch (x) {
|
|
121
|
+
fe.error("Error parsing config:", x), r(K), d("Error parsing config");
|
|
122
|
+
} finally {
|
|
123
|
+
l(!1);
|
|
124
|
+
}
|
|
125
|
+
})();
|
|
126
|
+
}, []), {
|
|
127
|
+
data: n,
|
|
128
|
+
isLoading: o,
|
|
129
|
+
error: i
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
function ze(n) {
|
|
133
|
+
if (typeof window > "u") return;
|
|
134
|
+
const r = window.__MF_NAME__ || "unknown", o = {
|
|
135
|
+
...n,
|
|
136
|
+
mfeName: r,
|
|
137
|
+
timestamp: Date.now()
|
|
138
|
+
};
|
|
139
|
+
window.dispatchEvent(new CustomEvent("mfe-notification", {
|
|
140
|
+
detail: o,
|
|
141
|
+
bubbles: !0
|
|
142
|
+
}));
|
|
143
|
+
}
|
|
144
|
+
function Ve(n, r) {
|
|
145
|
+
const o = {
|
|
146
|
+
network: {
|
|
147
|
+
title: "Нет подключения",
|
|
148
|
+
message: "Сервер недоступен. Проверьте подключение к интернету."
|
|
149
|
+
},
|
|
150
|
+
unauthorized: {
|
|
151
|
+
title: "Требуется вход",
|
|
152
|
+
message: "Ваша сессия истекла. Войдите в систему снова."
|
|
153
|
+
},
|
|
154
|
+
forbidden: {
|
|
155
|
+
title: "Доступ запрещён",
|
|
156
|
+
message: "У вас нет прав для выполнения этого действия."
|
|
157
|
+
},
|
|
158
|
+
not_found: {
|
|
159
|
+
title: "Не найдено",
|
|
160
|
+
message: "Запрошенный ресурс не найден."
|
|
161
|
+
},
|
|
162
|
+
server: {
|
|
163
|
+
title: "Ошибка сервера",
|
|
164
|
+
message: "Произошла ошибка на сервере. Попробуйте позже."
|
|
165
|
+
},
|
|
166
|
+
client: {
|
|
167
|
+
title: "Ошибка",
|
|
168
|
+
message: n.message || "Произошла ошибка при выполнении запроса."
|
|
169
|
+
},
|
|
170
|
+
unknown: {
|
|
171
|
+
title: "Неизвестная ошибка",
|
|
172
|
+
message: n.message || "Произошла неизвестная ошибка."
|
|
173
|
+
}
|
|
174
|
+
}, l = o[n.type] || o.unknown;
|
|
175
|
+
ze({
|
|
176
|
+
type: n.type === "network" ? "warning" : "error",
|
|
177
|
+
title: l.title,
|
|
178
|
+
message: r ? `${l.message} (${r})` : l.message
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
function Xt(n, r = {}) {
|
|
182
|
+
const {
|
|
183
|
+
notifyOnError: o = !0,
|
|
184
|
+
notifyOnSuccess: l = !1,
|
|
185
|
+
successMessage: i,
|
|
186
|
+
errorContext: d,
|
|
187
|
+
onSuccess: s,
|
|
188
|
+
onError: x
|
|
189
|
+
} = r, [p, y] = T(null), [h, b] = T(null), [u, v] = T(!1), C = h !== null, M = p !== null && !u && !C, te = j(async () => {
|
|
190
|
+
v(!0), b(null);
|
|
191
|
+
try {
|
|
192
|
+
const w = await n();
|
|
193
|
+
if (w.ok)
|
|
194
|
+
return y(w.data), l && i && ze({
|
|
195
|
+
type: "success",
|
|
196
|
+
title: "Успешно",
|
|
197
|
+
message: i
|
|
198
|
+
}), s?.(w.data), w.data;
|
|
199
|
+
{
|
|
200
|
+
const N = {
|
|
201
|
+
message: w.data || "Request failed",
|
|
202
|
+
status: w.status,
|
|
203
|
+
type: "client",
|
|
204
|
+
timestamp: Date.now()
|
|
205
|
+
};
|
|
206
|
+
return b(N), o && Ve(N, d), x?.(N), null;
|
|
207
|
+
}
|
|
208
|
+
} catch (w) {
|
|
209
|
+
const N = w;
|
|
210
|
+
return b(N), o && Ve(N, d), x?.(N), null;
|
|
211
|
+
} finally {
|
|
212
|
+
v(!1);
|
|
213
|
+
}
|
|
214
|
+
}, [n, o, l, i, d, s, x]), P = j(() => {
|
|
215
|
+
y(null), b(null), v(!1);
|
|
216
|
+
}, []);
|
|
217
|
+
return {
|
|
218
|
+
data: p,
|
|
219
|
+
error: h,
|
|
220
|
+
isLoading: u,
|
|
221
|
+
isError: C,
|
|
222
|
+
isSuccess: M,
|
|
223
|
+
execute: te,
|
|
224
|
+
reset: P
|
|
225
|
+
};
|
|
226
|
+
}
|
|
227
|
+
const Ft = {
|
|
228
|
+
canView: ["all"],
|
|
229
|
+
canEdit: ["ibdop-user", "ibdop-admin", "ibdop-devops"],
|
|
230
|
+
canDelete: ["ibdop-admin", "ibdop-devops"],
|
|
231
|
+
canAdmin: ["ibdop-admin"],
|
|
232
|
+
canViewSensitiveData: ["ibdop-admin", "ibdop-devops"],
|
|
233
|
+
canExportData: ["ibdop-user"],
|
|
234
|
+
canManageUsers: ["ibdop-admin"]
|
|
235
|
+
};
|
|
236
|
+
function Zt(n = {}) {
|
|
237
|
+
const r = Pt(), o = Fe(() => ({
|
|
238
|
+
...Ft,
|
|
239
|
+
...n
|
|
240
|
+
}), [n]), l = Fe(() => {
|
|
241
|
+
const d = r.user?.profile?.realm_roles || r.user?.profile?.roles || [];
|
|
242
|
+
return Array.isArray(d) ? d : [d];
|
|
243
|
+
}, [r.user]), i = (d) => d.includes("all") ? !0 : d.some((s) => l.includes(s));
|
|
244
|
+
return {
|
|
245
|
+
canView: i(o.canView),
|
|
246
|
+
canEdit: i(o.canEdit),
|
|
247
|
+
canDelete: i(o.canDelete),
|
|
248
|
+
canAdmin: i(o.canAdmin),
|
|
249
|
+
canViewSensitiveData: i(o.canViewSensitiveData),
|
|
250
|
+
canExportData: i(o.canExportData),
|
|
251
|
+
canManageUsers: i(o.canManageUsers)
|
|
252
|
+
};
|
|
253
|
+
}
|
|
254
|
+
var X = { exports: {} }, B = {};
|
|
255
|
+
var We;
|
|
256
|
+
function Ut() {
|
|
257
|
+
if (We) return B;
|
|
258
|
+
We = 1;
|
|
259
|
+
var n = Ge, r = /* @__PURE__ */ Symbol.for("react.element"), o = /* @__PURE__ */ Symbol.for("react.fragment"), l = Object.prototype.hasOwnProperty, i = n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner, d = { key: !0, ref: !0, __self: !0, __source: !0 };
|
|
260
|
+
function s(x, p, y) {
|
|
261
|
+
var h, b = {}, u = null, v = null;
|
|
262
|
+
y !== void 0 && (u = "" + y), p.key !== void 0 && (u = "" + p.key), p.ref !== void 0 && (v = p.ref);
|
|
263
|
+
for (h in p) l.call(p, h) && !d.hasOwnProperty(h) && (b[h] = p[h]);
|
|
264
|
+
if (x && x.defaultProps) for (h in p = x.defaultProps, p) b[h] === void 0 && (b[h] = p[h]);
|
|
265
|
+
return { $$typeof: r, type: x, key: u, ref: v, props: b, _owner: i.current };
|
|
266
|
+
}
|
|
267
|
+
return B.Fragment = o, B.jsx = s, B.jsxs = s, B;
|
|
268
|
+
}
|
|
269
|
+
var H = {};
|
|
270
|
+
var Be;
|
|
271
|
+
function Vt() {
|
|
272
|
+
return Be || (Be = 1, process.env.NODE_ENV !== "production" && (function() {
|
|
273
|
+
var n = Ge, r = /* @__PURE__ */ Symbol.for("react.element"), o = /* @__PURE__ */ Symbol.for("react.portal"), l = /* @__PURE__ */ Symbol.for("react.fragment"), i = /* @__PURE__ */ Symbol.for("react.strict_mode"), d = /* @__PURE__ */ Symbol.for("react.profiler"), s = /* @__PURE__ */ Symbol.for("react.provider"), x = /* @__PURE__ */ Symbol.for("react.context"), p = /* @__PURE__ */ Symbol.for("react.forward_ref"), y = /* @__PURE__ */ Symbol.for("react.suspense"), h = /* @__PURE__ */ Symbol.for("react.suspense_list"), b = /* @__PURE__ */ Symbol.for("react.memo"), u = /* @__PURE__ */ Symbol.for("react.lazy"), v = /* @__PURE__ */ Symbol.for("react.offscreen"), C = Symbol.iterator, M = "@@iterator";
|
|
274
|
+
function te(e) {
|
|
275
|
+
if (e === null || typeof e != "object")
|
|
276
|
+
return null;
|
|
277
|
+
var t = C && e[C] || e[M];
|
|
278
|
+
return typeof t == "function" ? t : null;
|
|
279
|
+
}
|
|
280
|
+
var P = n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;
|
|
281
|
+
function w(e) {
|
|
282
|
+
{
|
|
283
|
+
for (var t = arguments.length, a = new Array(t > 1 ? t - 1 : 0), c = 1; c < t; c++)
|
|
284
|
+
a[c - 1] = arguments[c];
|
|
285
|
+
N("error", e, a);
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
function N(e, t, a) {
|
|
289
|
+
{
|
|
290
|
+
var c = P.ReactDebugCurrentFrame, _ = c.getStackAddendum();
|
|
291
|
+
_ !== "" && (t += "%s", a = a.concat([_]));
|
|
292
|
+
var E = a.map(function(m) {
|
|
293
|
+
return String(m);
|
|
294
|
+
});
|
|
295
|
+
E.unshift("Warning: " + t), Function.prototype.apply.call(console[e], console, E);
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
var Ke = !1, Xe = !1, Ze = !1, Qe = !1, et = !1, he;
|
|
299
|
+
he = /* @__PURE__ */ Symbol.for("react.module.reference");
|
|
300
|
+
function tt(e) {
|
|
301
|
+
return !!(typeof e == "string" || typeof e == "function" || e === l || e === d || et || e === i || e === y || e === h || Qe || e === v || Ke || Xe || Ze || typeof e == "object" && e !== null && (e.$$typeof === u || e.$$typeof === b || e.$$typeof === s || e.$$typeof === x || e.$$typeof === p || // This needs to include all possible module reference object
|
|
302
|
+
// types supported by any Flight configuration anywhere since
|
|
303
|
+
// we don't know which Flight build this will end up being used
|
|
304
|
+
// with.
|
|
305
|
+
e.$$typeof === he || e.getModuleId !== void 0));
|
|
306
|
+
}
|
|
307
|
+
function rt(e, t, a) {
|
|
308
|
+
var c = e.displayName;
|
|
309
|
+
if (c)
|
|
310
|
+
return c;
|
|
311
|
+
var _ = t.displayName || t.name || "";
|
|
312
|
+
return _ !== "" ? a + "(" + _ + ")" : a;
|
|
313
|
+
}
|
|
314
|
+
function ge(e) {
|
|
315
|
+
return e.displayName || "Context";
|
|
316
|
+
}
|
|
317
|
+
function D(e) {
|
|
318
|
+
if (e == null)
|
|
319
|
+
return null;
|
|
320
|
+
if (typeof e.tag == "number" && w("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."), typeof e == "function")
|
|
321
|
+
return e.displayName || e.name || null;
|
|
322
|
+
if (typeof e == "string")
|
|
323
|
+
return e;
|
|
324
|
+
switch (e) {
|
|
325
|
+
case l:
|
|
326
|
+
return "Fragment";
|
|
327
|
+
case o:
|
|
328
|
+
return "Portal";
|
|
329
|
+
case d:
|
|
330
|
+
return "Profiler";
|
|
331
|
+
case i:
|
|
332
|
+
return "StrictMode";
|
|
333
|
+
case y:
|
|
334
|
+
return "Suspense";
|
|
335
|
+
case h:
|
|
336
|
+
return "SuspenseList";
|
|
337
|
+
}
|
|
338
|
+
if (typeof e == "object")
|
|
339
|
+
switch (e.$$typeof) {
|
|
340
|
+
case x:
|
|
341
|
+
var t = e;
|
|
342
|
+
return ge(t) + ".Consumer";
|
|
343
|
+
case s:
|
|
344
|
+
var a = e;
|
|
345
|
+
return ge(a._context) + ".Provider";
|
|
346
|
+
case p:
|
|
347
|
+
return rt(e, e.render, "ForwardRef");
|
|
348
|
+
case b:
|
|
349
|
+
var c = e.displayName || null;
|
|
350
|
+
return c !== null ? c : D(e.type) || "Memo";
|
|
351
|
+
case u: {
|
|
352
|
+
var _ = e, E = _._payload, m = _._init;
|
|
353
|
+
try {
|
|
354
|
+
return D(m(E));
|
|
355
|
+
} catch {
|
|
356
|
+
return null;
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
return null;
|
|
361
|
+
}
|
|
362
|
+
var L = Object.assign, V = 0, me, ve, _e, ye, Ee, xe, we;
|
|
363
|
+
function be() {
|
|
364
|
+
}
|
|
365
|
+
be.__reactDisabledLog = !0;
|
|
366
|
+
function nt() {
|
|
367
|
+
{
|
|
368
|
+
if (V === 0) {
|
|
369
|
+
me = console.log, ve = console.info, _e = console.warn, ye = console.error, Ee = console.group, xe = console.groupCollapsed, we = console.groupEnd;
|
|
370
|
+
var e = {
|
|
371
|
+
configurable: !0,
|
|
372
|
+
enumerable: !0,
|
|
373
|
+
value: be,
|
|
374
|
+
writable: !0
|
|
375
|
+
};
|
|
376
|
+
Object.defineProperties(console, {
|
|
377
|
+
info: e,
|
|
378
|
+
log: e,
|
|
379
|
+
warn: e,
|
|
380
|
+
error: e,
|
|
381
|
+
group: e,
|
|
382
|
+
groupCollapsed: e,
|
|
383
|
+
groupEnd: e
|
|
384
|
+
});
|
|
385
|
+
}
|
|
386
|
+
V++;
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
function ot() {
|
|
390
|
+
{
|
|
391
|
+
if (V--, V === 0) {
|
|
392
|
+
var e = {
|
|
393
|
+
configurable: !0,
|
|
394
|
+
enumerable: !0,
|
|
395
|
+
writable: !0
|
|
396
|
+
};
|
|
397
|
+
Object.defineProperties(console, {
|
|
398
|
+
log: L({}, e, {
|
|
399
|
+
value: me
|
|
400
|
+
}),
|
|
401
|
+
info: L({}, e, {
|
|
402
|
+
value: ve
|
|
403
|
+
}),
|
|
404
|
+
warn: L({}, e, {
|
|
405
|
+
value: _e
|
|
406
|
+
}),
|
|
407
|
+
error: L({}, e, {
|
|
408
|
+
value: ye
|
|
409
|
+
}),
|
|
410
|
+
group: L({}, e, {
|
|
411
|
+
value: Ee
|
|
412
|
+
}),
|
|
413
|
+
groupCollapsed: L({}, e, {
|
|
414
|
+
value: xe
|
|
415
|
+
}),
|
|
416
|
+
groupEnd: L({}, e, {
|
|
417
|
+
value: we
|
|
418
|
+
})
|
|
419
|
+
});
|
|
420
|
+
}
|
|
421
|
+
V < 0 && w("disabledDepth fell below zero. This is a bug in React. Please file an issue.");
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
var re = P.ReactCurrentDispatcher, ne;
|
|
425
|
+
function z(e, t, a) {
|
|
426
|
+
{
|
|
427
|
+
if (ne === void 0)
|
|
428
|
+
try {
|
|
429
|
+
throw Error();
|
|
430
|
+
} catch (_) {
|
|
431
|
+
var c = _.stack.trim().match(/\n( *(at )?)/);
|
|
432
|
+
ne = c && c[1] || "";
|
|
433
|
+
}
|
|
434
|
+
return `
|
|
435
|
+
` + ne + e;
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
var oe = !1, Y;
|
|
439
|
+
{
|
|
440
|
+
var at = typeof WeakMap == "function" ? WeakMap : Map;
|
|
441
|
+
Y = new at();
|
|
442
|
+
}
|
|
443
|
+
function Re(e, t) {
|
|
444
|
+
if (!e || oe)
|
|
445
|
+
return "";
|
|
446
|
+
{
|
|
447
|
+
var a = Y.get(e);
|
|
448
|
+
if (a !== void 0)
|
|
449
|
+
return a;
|
|
450
|
+
}
|
|
451
|
+
var c;
|
|
452
|
+
oe = !0;
|
|
453
|
+
var _ = Error.prepareStackTrace;
|
|
454
|
+
Error.prepareStackTrace = void 0;
|
|
455
|
+
var E;
|
|
456
|
+
E = re.current, re.current = null, nt();
|
|
457
|
+
try {
|
|
458
|
+
if (t) {
|
|
459
|
+
var m = function() {
|
|
460
|
+
throw Error();
|
|
461
|
+
};
|
|
462
|
+
if (Object.defineProperty(m.prototype, "props", {
|
|
463
|
+
set: function() {
|
|
464
|
+
throw Error();
|
|
465
|
+
}
|
|
466
|
+
}), typeof Reflect == "object" && Reflect.construct) {
|
|
467
|
+
try {
|
|
468
|
+
Reflect.construct(m, []);
|
|
469
|
+
} catch (I) {
|
|
470
|
+
c = I;
|
|
471
|
+
}
|
|
472
|
+
Reflect.construct(e, [], m);
|
|
473
|
+
} else {
|
|
474
|
+
try {
|
|
475
|
+
m.call();
|
|
476
|
+
} catch (I) {
|
|
477
|
+
c = I;
|
|
478
|
+
}
|
|
479
|
+
e.call(m.prototype);
|
|
480
|
+
}
|
|
481
|
+
} else {
|
|
482
|
+
try {
|
|
483
|
+
throw Error();
|
|
484
|
+
} catch (I) {
|
|
485
|
+
c = I;
|
|
486
|
+
}
|
|
487
|
+
e();
|
|
488
|
+
}
|
|
489
|
+
} catch (I) {
|
|
490
|
+
if (I && c && typeof I.stack == "string") {
|
|
491
|
+
for (var g = I.stack.split(`
|
|
492
|
+
`), A = c.stack.split(`
|
|
493
|
+
`), R = g.length - 1, S = A.length - 1; R >= 1 && S >= 0 && g[R] !== A[S]; )
|
|
494
|
+
S--;
|
|
495
|
+
for (; R >= 1 && S >= 0; R--, S--)
|
|
496
|
+
if (g[R] !== A[S]) {
|
|
497
|
+
if (R !== 1 || S !== 1)
|
|
498
|
+
do
|
|
499
|
+
if (R--, S--, S < 0 || g[R] !== A[S]) {
|
|
500
|
+
var k = `
|
|
501
|
+
` + g[R].replace(" at new ", " at ");
|
|
502
|
+
return e.displayName && k.includes("<anonymous>") && (k = k.replace("<anonymous>", e.displayName)), typeof e == "function" && Y.set(e, k), k;
|
|
503
|
+
}
|
|
504
|
+
while (R >= 1 && S >= 0);
|
|
505
|
+
break;
|
|
506
|
+
}
|
|
507
|
+
}
|
|
508
|
+
} finally {
|
|
509
|
+
oe = !1, re.current = E, ot(), Error.prepareStackTrace = _;
|
|
510
|
+
}
|
|
511
|
+
var U = e ? e.displayName || e.name : "", $ = U ? z(U) : "";
|
|
512
|
+
return typeof e == "function" && Y.set(e, $), $;
|
|
513
|
+
}
|
|
514
|
+
function it(e, t, a) {
|
|
515
|
+
return Re(e, !1);
|
|
516
|
+
}
|
|
517
|
+
function st(e) {
|
|
518
|
+
var t = e.prototype;
|
|
519
|
+
return !!(t && t.isReactComponent);
|
|
520
|
+
}
|
|
521
|
+
function J(e, t, a) {
|
|
522
|
+
if (e == null)
|
|
523
|
+
return "";
|
|
524
|
+
if (typeof e == "function")
|
|
525
|
+
return Re(e, st(e));
|
|
526
|
+
if (typeof e == "string")
|
|
527
|
+
return z(e);
|
|
528
|
+
switch (e) {
|
|
529
|
+
case y:
|
|
530
|
+
return z("Suspense");
|
|
531
|
+
case h:
|
|
532
|
+
return z("SuspenseList");
|
|
533
|
+
}
|
|
534
|
+
if (typeof e == "object")
|
|
535
|
+
switch (e.$$typeof) {
|
|
536
|
+
case p:
|
|
537
|
+
return it(e.render);
|
|
538
|
+
case b:
|
|
539
|
+
return J(e.type, t, a);
|
|
540
|
+
case u: {
|
|
541
|
+
var c = e, _ = c._payload, E = c._init;
|
|
542
|
+
try {
|
|
543
|
+
return J(E(_), t, a);
|
|
544
|
+
} catch {
|
|
545
|
+
}
|
|
546
|
+
}
|
|
547
|
+
}
|
|
548
|
+
return "";
|
|
549
|
+
}
|
|
550
|
+
var W = Object.prototype.hasOwnProperty, Se = {}, Ce = P.ReactDebugCurrentFrame;
|
|
551
|
+
function q(e) {
|
|
552
|
+
if (e) {
|
|
553
|
+
var t = e._owner, a = J(e.type, e._source, t ? t.type : null);
|
|
554
|
+
Ce.setExtraStackFrame(a);
|
|
555
|
+
} else
|
|
556
|
+
Ce.setExtraStackFrame(null);
|
|
557
|
+
}
|
|
558
|
+
function lt(e, t, a, c, _) {
|
|
559
|
+
{
|
|
560
|
+
var E = Function.call.bind(W);
|
|
561
|
+
for (var m in e)
|
|
562
|
+
if (E(e, m)) {
|
|
563
|
+
var g = void 0;
|
|
564
|
+
try {
|
|
565
|
+
if (typeof e[m] != "function") {
|
|
566
|
+
var A = Error((c || "React class") + ": " + a + " type `" + m + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof e[m] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");
|
|
567
|
+
throw A.name = "Invariant Violation", A;
|
|
568
|
+
}
|
|
569
|
+
g = e[m](t, m, c, a, null, "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED");
|
|
570
|
+
} catch (R) {
|
|
571
|
+
g = R;
|
|
572
|
+
}
|
|
573
|
+
g && !(g instanceof Error) && (q(_), w("%s: type specification of %s `%s` is invalid; the type checker function must return `null` or an `Error` but returned a %s. You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument).", c || "React class", a, m, typeof g), q(null)), g instanceof Error && !(g.message in Se) && (Se[g.message] = !0, q(_), w("Failed %s type: %s", a, g.message), q(null));
|
|
574
|
+
}
|
|
575
|
+
}
|
|
576
|
+
}
|
|
577
|
+
var ut = Array.isArray;
|
|
578
|
+
function ae(e) {
|
|
579
|
+
return ut(e);
|
|
580
|
+
}
|
|
581
|
+
function ct(e) {
|
|
582
|
+
{
|
|
583
|
+
var t = typeof Symbol == "function" && Symbol.toStringTag, a = t && e[Symbol.toStringTag] || e.constructor.name || "Object";
|
|
584
|
+
return a;
|
|
585
|
+
}
|
|
586
|
+
}
|
|
587
|
+
function ft(e) {
|
|
588
|
+
try {
|
|
589
|
+
return Ae(e), !1;
|
|
590
|
+
} catch {
|
|
591
|
+
return !0;
|
|
592
|
+
}
|
|
593
|
+
}
|
|
594
|
+
function Ae(e) {
|
|
595
|
+
return "" + e;
|
|
596
|
+
}
|
|
597
|
+
function Ie(e) {
|
|
598
|
+
if (ft(e))
|
|
599
|
+
return w("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.", ct(e)), Ae(e);
|
|
600
|
+
}
|
|
601
|
+
var Te = P.ReactCurrentOwner, dt = {
|
|
602
|
+
key: !0,
|
|
603
|
+
ref: !0,
|
|
604
|
+
__self: !0,
|
|
605
|
+
__source: !0
|
|
606
|
+
}, ke, Oe;
|
|
607
|
+
function pt(e) {
|
|
608
|
+
if (W.call(e, "ref")) {
|
|
609
|
+
var t = Object.getOwnPropertyDescriptor(e, "ref").get;
|
|
610
|
+
if (t && t.isReactWarning)
|
|
611
|
+
return !1;
|
|
612
|
+
}
|
|
613
|
+
return e.ref !== void 0;
|
|
614
|
+
}
|
|
615
|
+
function ht(e) {
|
|
616
|
+
if (W.call(e, "key")) {
|
|
617
|
+
var t = Object.getOwnPropertyDescriptor(e, "key").get;
|
|
618
|
+
if (t && t.isReactWarning)
|
|
619
|
+
return !1;
|
|
620
|
+
}
|
|
621
|
+
return e.key !== void 0;
|
|
622
|
+
}
|
|
623
|
+
function gt(e, t) {
|
|
624
|
+
typeof e.ref == "string" && Te.current;
|
|
625
|
+
}
|
|
626
|
+
function mt(e, t) {
|
|
627
|
+
{
|
|
628
|
+
var a = function() {
|
|
629
|
+
ke || (ke = !0, w("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", t));
|
|
630
|
+
};
|
|
631
|
+
a.isReactWarning = !0, Object.defineProperty(e, "key", {
|
|
632
|
+
get: a,
|
|
633
|
+
configurable: !0
|
|
634
|
+
});
|
|
635
|
+
}
|
|
636
|
+
}
|
|
637
|
+
function vt(e, t) {
|
|
638
|
+
{
|
|
639
|
+
var a = function() {
|
|
640
|
+
Oe || (Oe = !0, w("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)", t));
|
|
641
|
+
};
|
|
642
|
+
a.isReactWarning = !0, Object.defineProperty(e, "ref", {
|
|
643
|
+
get: a,
|
|
644
|
+
configurable: !0
|
|
645
|
+
});
|
|
646
|
+
}
|
|
647
|
+
}
|
|
648
|
+
var _t = function(e, t, a, c, _, E, m) {
|
|
649
|
+
var g = {
|
|
650
|
+
// This tag allows us to uniquely identify this as a React Element
|
|
651
|
+
$$typeof: r,
|
|
652
|
+
// Built-in properties that belong on the element
|
|
653
|
+
type: e,
|
|
654
|
+
key: t,
|
|
655
|
+
ref: a,
|
|
656
|
+
props: m,
|
|
657
|
+
// Record the component responsible for creating this element.
|
|
658
|
+
_owner: E
|
|
659
|
+
};
|
|
660
|
+
return g._store = {}, Object.defineProperty(g._store, "validated", {
|
|
661
|
+
configurable: !1,
|
|
662
|
+
enumerable: !1,
|
|
663
|
+
writable: !0,
|
|
664
|
+
value: !1
|
|
665
|
+
}), Object.defineProperty(g, "_self", {
|
|
666
|
+
configurable: !1,
|
|
667
|
+
enumerable: !1,
|
|
668
|
+
writable: !1,
|
|
669
|
+
value: c
|
|
670
|
+
}), Object.defineProperty(g, "_source", {
|
|
671
|
+
configurable: !1,
|
|
672
|
+
enumerable: !1,
|
|
673
|
+
writable: !1,
|
|
674
|
+
value: _
|
|
675
|
+
}), Object.freeze && (Object.freeze(g.props), Object.freeze(g)), g;
|
|
676
|
+
};
|
|
677
|
+
function yt(e, t, a, c, _) {
|
|
678
|
+
{
|
|
679
|
+
var E, m = {}, g = null, A = null;
|
|
680
|
+
a !== void 0 && (Ie(a), g = "" + a), ht(t) && (Ie(t.key), g = "" + t.key), pt(t) && (A = t.ref, gt(t, _));
|
|
681
|
+
for (E in t)
|
|
682
|
+
W.call(t, E) && !dt.hasOwnProperty(E) && (m[E] = t[E]);
|
|
683
|
+
if (e && e.defaultProps) {
|
|
684
|
+
var R = e.defaultProps;
|
|
685
|
+
for (E in R)
|
|
686
|
+
m[E] === void 0 && (m[E] = R[E]);
|
|
687
|
+
}
|
|
688
|
+
if (g || A) {
|
|
689
|
+
var S = typeof e == "function" ? e.displayName || e.name || "Unknown" : e;
|
|
690
|
+
g && mt(m, S), A && vt(m, S);
|
|
691
|
+
}
|
|
692
|
+
return _t(e, g, A, _, c, Te.current, m);
|
|
693
|
+
}
|
|
694
|
+
}
|
|
695
|
+
var ie = P.ReactCurrentOwner, je = P.ReactDebugCurrentFrame;
|
|
696
|
+
function F(e) {
|
|
697
|
+
if (e) {
|
|
698
|
+
var t = e._owner, a = J(e.type, e._source, t ? t.type : null);
|
|
699
|
+
je.setExtraStackFrame(a);
|
|
700
|
+
} else
|
|
701
|
+
je.setExtraStackFrame(null);
|
|
702
|
+
}
|
|
703
|
+
var se;
|
|
704
|
+
se = !1;
|
|
705
|
+
function le(e) {
|
|
706
|
+
return typeof e == "object" && e !== null && e.$$typeof === r;
|
|
707
|
+
}
|
|
708
|
+
function Me() {
|
|
709
|
+
{
|
|
710
|
+
if (ie.current) {
|
|
711
|
+
var e = D(ie.current.type);
|
|
712
|
+
if (e)
|
|
713
|
+
return `
|
|
714
|
+
|
|
715
|
+
Check the render method of \`` + e + "`.";
|
|
716
|
+
}
|
|
717
|
+
return "";
|
|
718
|
+
}
|
|
719
|
+
}
|
|
720
|
+
function Et(e) {
|
|
721
|
+
return "";
|
|
722
|
+
}
|
|
723
|
+
var Ne = {};
|
|
724
|
+
function xt(e) {
|
|
725
|
+
{
|
|
726
|
+
var t = Me();
|
|
727
|
+
if (!t) {
|
|
728
|
+
var a = typeof e == "string" ? e : e.displayName || e.name;
|
|
729
|
+
a && (t = `
|
|
730
|
+
|
|
731
|
+
Check the top-level render call using <` + a + ">.");
|
|
732
|
+
}
|
|
733
|
+
return t;
|
|
734
|
+
}
|
|
735
|
+
}
|
|
736
|
+
function Pe(e, t) {
|
|
737
|
+
{
|
|
738
|
+
if (!e._store || e._store.validated || e.key != null)
|
|
739
|
+
return;
|
|
740
|
+
e._store.validated = !0;
|
|
741
|
+
var a = xt(t);
|
|
742
|
+
if (Ne[a])
|
|
743
|
+
return;
|
|
744
|
+
Ne[a] = !0;
|
|
745
|
+
var c = "";
|
|
746
|
+
e && e._owner && e._owner !== ie.current && (c = " It was passed a child from " + D(e._owner.type) + "."), F(e), w('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.', a, c), F(null);
|
|
747
|
+
}
|
|
748
|
+
}
|
|
749
|
+
function De(e, t) {
|
|
750
|
+
{
|
|
751
|
+
if (typeof e != "object")
|
|
752
|
+
return;
|
|
753
|
+
if (ae(e))
|
|
754
|
+
for (var a = 0; a < e.length; a++) {
|
|
755
|
+
var c = e[a];
|
|
756
|
+
le(c) && Pe(c, t);
|
|
757
|
+
}
|
|
758
|
+
else if (le(e))
|
|
759
|
+
e._store && (e._store.validated = !0);
|
|
760
|
+
else if (e) {
|
|
761
|
+
var _ = te(e);
|
|
762
|
+
if (typeof _ == "function" && _ !== e.entries)
|
|
763
|
+
for (var E = _.call(e), m; !(m = E.next()).done; )
|
|
764
|
+
le(m.value) && Pe(m.value, t);
|
|
765
|
+
}
|
|
766
|
+
}
|
|
767
|
+
}
|
|
768
|
+
function wt(e) {
|
|
769
|
+
{
|
|
770
|
+
var t = e.type;
|
|
771
|
+
if (t == null || typeof t == "string")
|
|
772
|
+
return;
|
|
773
|
+
var a;
|
|
774
|
+
if (typeof t == "function")
|
|
775
|
+
a = t.propTypes;
|
|
776
|
+
else if (typeof t == "object" && (t.$$typeof === p || // Note: Memo only checks outer props here.
|
|
777
|
+
// Inner props are checked in the reconciler.
|
|
778
|
+
t.$$typeof === b))
|
|
779
|
+
a = t.propTypes;
|
|
780
|
+
else
|
|
781
|
+
return;
|
|
782
|
+
if (a) {
|
|
783
|
+
var c = D(t);
|
|
784
|
+
lt(a, e.props, "prop", c, e);
|
|
785
|
+
} else if (t.PropTypes !== void 0 && !se) {
|
|
786
|
+
se = !0;
|
|
787
|
+
var _ = D(t);
|
|
788
|
+
w("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?", _ || "Unknown");
|
|
789
|
+
}
|
|
790
|
+
typeof t.getDefaultProps == "function" && !t.getDefaultProps.isReactClassApproved && w("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.");
|
|
791
|
+
}
|
|
792
|
+
}
|
|
793
|
+
function bt(e) {
|
|
794
|
+
{
|
|
795
|
+
for (var t = Object.keys(e.props), a = 0; a < t.length; a++) {
|
|
796
|
+
var c = t[a];
|
|
797
|
+
if (c !== "children" && c !== "key") {
|
|
798
|
+
F(e), w("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.", c), F(null);
|
|
799
|
+
break;
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
e.ref !== null && (F(e), w("Invalid attribute `ref` supplied to `React.Fragment`."), F(null));
|
|
803
|
+
}
|
|
804
|
+
}
|
|
805
|
+
var Le = {};
|
|
806
|
+
function $e(e, t, a, c, _, E) {
|
|
807
|
+
{
|
|
808
|
+
var m = tt(e);
|
|
809
|
+
if (!m) {
|
|
810
|
+
var g = "";
|
|
811
|
+
(e === void 0 || typeof e == "object" && e !== null && Object.keys(e).length === 0) && (g += " You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");
|
|
812
|
+
var A = Et();
|
|
813
|
+
A ? g += A : g += Me();
|
|
814
|
+
var R;
|
|
815
|
+
e === null ? R = "null" : ae(e) ? R = "array" : e !== void 0 && e.$$typeof === r ? (R = "<" + (D(e.type) || "Unknown") + " />", g = " Did you accidentally export a JSX literal instead of a component?") : R = typeof e, w("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s", R, g);
|
|
816
|
+
}
|
|
817
|
+
var S = yt(e, t, a, _, E);
|
|
818
|
+
if (S == null)
|
|
819
|
+
return S;
|
|
820
|
+
if (m) {
|
|
821
|
+
var k = t.children;
|
|
822
|
+
if (k !== void 0)
|
|
823
|
+
if (c)
|
|
824
|
+
if (ae(k)) {
|
|
825
|
+
for (var U = 0; U < k.length; U++)
|
|
826
|
+
De(k[U], e);
|
|
827
|
+
Object.freeze && Object.freeze(k);
|
|
828
|
+
} else
|
|
829
|
+
w("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");
|
|
830
|
+
else
|
|
831
|
+
De(k, e);
|
|
832
|
+
}
|
|
833
|
+
if (W.call(t, "key")) {
|
|
834
|
+
var $ = D(e), I = Object.keys(t).filter(function(Tt) {
|
|
835
|
+
return Tt !== "key";
|
|
836
|
+
}), ue = I.length > 0 ? "{key: someKey, " + I.join(": ..., ") + ": ...}" : "{key: someKey}";
|
|
837
|
+
if (!Le[$ + ue]) {
|
|
838
|
+
var It = I.length > 0 ? "{" + I.join(": ..., ") + ": ...}" : "{}";
|
|
839
|
+
w(`A props object containing a "key" prop is being spread into JSX:
|
|
840
|
+
let props = %s;
|
|
841
|
+
<%s {...props} />
|
|
842
|
+
React keys must be passed directly to JSX without using spread:
|
|
843
|
+
let props = %s;
|
|
844
|
+
<%s key={someKey} {...props} />`, ue, $, It, $), Le[$ + ue] = !0;
|
|
845
|
+
}
|
|
846
|
+
}
|
|
847
|
+
return e === l ? bt(S) : wt(S), S;
|
|
848
|
+
}
|
|
849
|
+
}
|
|
850
|
+
function Rt(e, t, a) {
|
|
851
|
+
return $e(e, t, a, !0);
|
|
852
|
+
}
|
|
853
|
+
function St(e, t, a) {
|
|
854
|
+
return $e(e, t, a, !1);
|
|
855
|
+
}
|
|
856
|
+
var Ct = St, At = Rt;
|
|
857
|
+
H.Fragment = l, H.jsx = Ct, H.jsxs = At;
|
|
858
|
+
})()), H;
|
|
859
|
+
}
|
|
860
|
+
var He;
|
|
861
|
+
function Wt() {
|
|
862
|
+
return He || (He = 1, process.env.NODE_ENV === "production" ? X.exports = Ut() : X.exports = Vt()), X.exports;
|
|
863
|
+
}
|
|
864
|
+
var f = Wt();
|
|
865
|
+
const Ye = "platform-kit", Bt = !1, de = {
|
|
866
|
+
log: (...n) => {
|
|
867
|
+
},
|
|
868
|
+
warn: (...n) => {
|
|
869
|
+
},
|
|
870
|
+
error: (...n) => {
|
|
871
|
+
console.error(`[${Ye}]`, ...n);
|
|
872
|
+
}
|
|
873
|
+
};
|
|
874
|
+
class Qt extends Ot {
|
|
875
|
+
hasDispatched = !1;
|
|
876
|
+
constructor(r) {
|
|
877
|
+
super(r), this.state = { hasError: !1 };
|
|
878
|
+
}
|
|
879
|
+
/**
|
|
880
|
+
* Получить имя MF из props или window
|
|
881
|
+
*/
|
|
882
|
+
getMfeName() {
|
|
883
|
+
if (this.props.mfeName) return this.props.mfeName;
|
|
884
|
+
if (typeof window < "u") {
|
|
885
|
+
const r = window;
|
|
886
|
+
if (r.__MF_NAME__) return r.__MF_NAME__;
|
|
887
|
+
}
|
|
888
|
+
return Ye;
|
|
889
|
+
}
|
|
890
|
+
/**
|
|
891
|
+
* Определить нужно ли показывать детали ошибки
|
|
892
|
+
*/
|
|
893
|
+
shouldShowDetails() {
|
|
894
|
+
if (this.props.showDetails !== void 0)
|
|
895
|
+
return this.props.showDetails;
|
|
896
|
+
if (typeof sessionStorage < "u")
|
|
897
|
+
try {
|
|
898
|
+
const r = sessionStorage.getItem("config");
|
|
899
|
+
if (r) {
|
|
900
|
+
const o = JSON.parse(r);
|
|
901
|
+
if (o.showErrorDetails !== void 0)
|
|
902
|
+
return o.showErrorDetails;
|
|
903
|
+
}
|
|
904
|
+
} catch {
|
|
905
|
+
}
|
|
906
|
+
return Bt;
|
|
907
|
+
}
|
|
908
|
+
/**
|
|
909
|
+
* Dispatch ошибки в shell
|
|
910
|
+
*/
|
|
911
|
+
dispatchError(r, o) {
|
|
912
|
+
if (this.hasDispatched || typeof window > "u") return;
|
|
913
|
+
this.hasDispatched = !0;
|
|
914
|
+
const l = this.getMfeName();
|
|
915
|
+
de.error("ErrorBoundary caught:", r);
|
|
916
|
+
try {
|
|
917
|
+
window.dispatchEvent(new CustomEvent("mfe-error", {
|
|
918
|
+
detail: {
|
|
919
|
+
mfeName: l,
|
|
920
|
+
error: r.message || String(r),
|
|
921
|
+
stack: r.stack,
|
|
922
|
+
componentStack: o?.componentStack,
|
|
923
|
+
timestamp: Date.now()
|
|
924
|
+
},
|
|
925
|
+
bubbles: !0
|
|
926
|
+
}));
|
|
927
|
+
} catch (i) {
|
|
928
|
+
de.error("Failed to dispatch mfe-error event:", i);
|
|
929
|
+
}
|
|
930
|
+
}
|
|
931
|
+
/**
|
|
932
|
+
* Получить derived state из ошибки
|
|
933
|
+
*/
|
|
934
|
+
static getDerivedStateFromError(r) {
|
|
935
|
+
return { hasError: !0, error: r };
|
|
936
|
+
}
|
|
937
|
+
/**
|
|
938
|
+
* Обработать ошибку
|
|
939
|
+
*/
|
|
940
|
+
componentDidCatch(r, o) {
|
|
941
|
+
this.dispatchError(r, o), de.error("Error info:", o.componentStack);
|
|
942
|
+
}
|
|
943
|
+
/**
|
|
944
|
+
* Копировать ошибку в буфер обмена
|
|
945
|
+
*/
|
|
946
|
+
handleCopy = () => {
|
|
947
|
+
const r = `Error in ${this.getMfeName()}:
|
|
948
|
+
${this.state.error?.message}
|
|
949
|
+
${this.state.error?.stack}`;
|
|
950
|
+
typeof navigator < "u" && navigator.clipboard && navigator.clipboard.writeText(r).then(() => {
|
|
951
|
+
alert("Ошибка скопирована в буфер обмена");
|
|
952
|
+
}).catch(() => {
|
|
953
|
+
prompt("Скопируйте ошибку:", r);
|
|
954
|
+
});
|
|
955
|
+
};
|
|
956
|
+
/**
|
|
957
|
+
* Повторить рендер
|
|
958
|
+
*/
|
|
959
|
+
handleRetry = () => {
|
|
960
|
+
this.setState({ hasError: !1, error: void 0 }), this.hasDispatched = !1, typeof window < "u" && window.location.reload();
|
|
961
|
+
};
|
|
962
|
+
/**
|
|
963
|
+
* Перейти на главную
|
|
964
|
+
*/
|
|
965
|
+
handleGoHome = () => {
|
|
966
|
+
typeof window < "u" && (window.location.href = "/");
|
|
967
|
+
};
|
|
968
|
+
/**
|
|
969
|
+
* Рендер
|
|
970
|
+
*/
|
|
971
|
+
render() {
|
|
972
|
+
if (this.state.hasError) {
|
|
973
|
+
const r = this.state.error?.message || "Unknown error", o = this.state.error?.stack || "", l = this.shouldShowDetails(), i = this.getMfeName();
|
|
974
|
+
return /* @__PURE__ */ f.jsxs("div", { style: {
|
|
975
|
+
padding: "20px",
|
|
976
|
+
textAlign: "center",
|
|
977
|
+
color: "#d32f2f",
|
|
978
|
+
fontFamily: "monospace",
|
|
979
|
+
background: "#ffebee",
|
|
980
|
+
border: "1px solid #ef5350",
|
|
981
|
+
borderRadius: "4px",
|
|
982
|
+
margin: "10px"
|
|
983
|
+
}, children: [
|
|
984
|
+
/* @__PURE__ */ f.jsxs("h2", { style: { fontSize: "16px", margin: "0 0 8px 0" }, children: [
|
|
985
|
+
"⚠️ Ошибка в ",
|
|
986
|
+
i
|
|
987
|
+
] }),
|
|
988
|
+
/* @__PURE__ */ f.jsx("p", { style: { fontSize: "12px", margin: 0 }, children: "Произошла ошибка в микрофронтенде. Сообщение отправлено в shell." }),
|
|
989
|
+
l && /* @__PURE__ */ f.jsxs("details", { style: {
|
|
990
|
+
whiteSpace: "pre-wrap",
|
|
991
|
+
textAlign: "left",
|
|
992
|
+
marginTop: "10px",
|
|
993
|
+
background: "#fff",
|
|
994
|
+
padding: "8px",
|
|
995
|
+
borderRadius: "4px"
|
|
996
|
+
}, children: [
|
|
997
|
+
/* @__PURE__ */ f.jsx("summary", { style: { cursor: "pointer", fontWeight: "bold" }, children: "Детали ошибки" }),
|
|
998
|
+
/* @__PURE__ */ f.jsxs("pre", { style: {
|
|
999
|
+
fontSize: "11px",
|
|
1000
|
+
overflow: "auto",
|
|
1001
|
+
maxHeight: "150px",
|
|
1002
|
+
margin: "8px 0 0 0",
|
|
1003
|
+
padding: "8px",
|
|
1004
|
+
background: "#f5f5f5",
|
|
1005
|
+
borderRadius: "4px"
|
|
1006
|
+
}, children: [
|
|
1007
|
+
r,
|
|
1008
|
+
o && `
|
|
1009
|
+
|
|
1010
|
+
${o}`
|
|
1011
|
+
] })
|
|
1012
|
+
] }),
|
|
1013
|
+
/* @__PURE__ */ f.jsxs("div", { style: { marginTop: "12px", display: "flex", gap: "8px", justifyContent: "center" }, children: [
|
|
1014
|
+
/* @__PURE__ */ f.jsx(
|
|
1015
|
+
"button",
|
|
1016
|
+
{
|
|
1017
|
+
onClick: this.handleCopy,
|
|
1018
|
+
style: {
|
|
1019
|
+
padding: "8px 12px",
|
|
1020
|
+
background: "#666",
|
|
1021
|
+
color: "white",
|
|
1022
|
+
border: "none",
|
|
1023
|
+
borderRadius: "4px",
|
|
1024
|
+
cursor: "pointer"
|
|
1025
|
+
},
|
|
1026
|
+
children: "📋 Копировать"
|
|
1027
|
+
}
|
|
1028
|
+
),
|
|
1029
|
+
/* @__PURE__ */ f.jsx(
|
|
1030
|
+
"button",
|
|
1031
|
+
{
|
|
1032
|
+
onClick: this.handleRetry,
|
|
1033
|
+
style: {
|
|
1034
|
+
padding: "8px 12px",
|
|
1035
|
+
background: "#d32f2f",
|
|
1036
|
+
color: "white",
|
|
1037
|
+
border: "none",
|
|
1038
|
+
borderRadius: "4px",
|
|
1039
|
+
cursor: "pointer"
|
|
1040
|
+
},
|
|
1041
|
+
children: "🔄 Обновить"
|
|
1042
|
+
}
|
|
1043
|
+
),
|
|
1044
|
+
/* @__PURE__ */ f.jsx(
|
|
1045
|
+
"button",
|
|
1046
|
+
{
|
|
1047
|
+
onClick: this.handleGoHome,
|
|
1048
|
+
style: {
|
|
1049
|
+
padding: "8px 12px",
|
|
1050
|
+
background: "#1976d2",
|
|
1051
|
+
color: "white",
|
|
1052
|
+
border: "none",
|
|
1053
|
+
borderRadius: "4px",
|
|
1054
|
+
cursor: "pointer"
|
|
1055
|
+
},
|
|
1056
|
+
children: "🏠 На главную"
|
|
1057
|
+
}
|
|
1058
|
+
)
|
|
1059
|
+
] })
|
|
1060
|
+
] });
|
|
1061
|
+
}
|
|
1062
|
+
return this.props.children == null ? null : this.props.children;
|
|
1063
|
+
}
|
|
1064
|
+
}
|
|
1065
|
+
const O = {
|
|
1066
|
+
info: "ℹ️",
|
|
1067
|
+
code: "💻",
|
|
1068
|
+
link: "🔗",
|
|
1069
|
+
user: "👤",
|
|
1070
|
+
clock: "🕐",
|
|
1071
|
+
apps: "📦",
|
|
1072
|
+
storage: "💾",
|
|
1073
|
+
tags: "🏷️",
|
|
1074
|
+
spreadsheet: "📊"
|
|
1075
|
+
};
|
|
1076
|
+
function er({ mfeName: n }) {
|
|
1077
|
+
const { data: r, isLoading: o, error: l } = $t({ mfeName: n }), [i, d] = T(!1);
|
|
1078
|
+
if (o)
|
|
1079
|
+
return /* @__PURE__ */ f.jsxs("span", { className: "text-muted small me-2", children: [
|
|
1080
|
+
/* @__PURE__ */ f.jsx("span", { className: "me-1", children: "⏳" }),
|
|
1081
|
+
"Загрузка..."
|
|
1082
|
+
] });
|
|
1083
|
+
if (l || !r)
|
|
1084
|
+
return /* @__PURE__ */ f.jsxs("span", { className: "text-muted small me-2", title: `Ошибка: ${l || "нет данных"}`, children: [
|
|
1085
|
+
/* @__PURE__ */ f.jsx("span", { className: "me-1", children: "ℹ️" }),
|
|
1086
|
+
"N/A"
|
|
1087
|
+
] });
|
|
1088
|
+
const s = r, x = s.BUILD_VERSION || s.IMAGE_VERSION || s.APP_NAME || "N/A", p = [];
|
|
1089
|
+
return s.APP_NAME && p.push({ key: "APP_NAME", value: s.APP_NAME, label: "Приложение", icon: O.apps }), s.BUILD_VERSION && p.push({ key: "BUILD_VERSION", value: s.BUILD_VERSION, label: "Версия", icon: O.tags }), s.IMAGE_VERSION && p.push({ key: "IMAGE_VERSION", value: s.IMAGE_VERSION, label: "Образ", icon: O.storage }), s.GIT_COMMIT && p.push({ key: "GIT_COMMIT", value: s.GIT_COMMIT, label: "Commit", icon: O.spreadsheet }), s.GIT_BRANCH && p.push({ key: "GIT_BRANCH", value: s.GIT_BRANCH, label: "Ветка", icon: O.spreadsheet }), s.CI_COMMIT_AUTHOR && p.push({ key: "CI_COMMIT_AUTHOR", value: s.CI_COMMIT_AUTHOR, label: "Автор", icon: O.user }), s.CI_COMMIT_TIMESTAMP && p.push({ key: "CI_COMMIT_TIMESTAMP", value: s.CI_COMMIT_TIMESTAMP, label: "Дата", icon: O.clock }), s.CI_JOB_URL && p.push({ key: "CI_JOB_URL", value: s.CI_JOB_URL, label: "CI Job", icon: O.link }), s.CI_PIPELINE_URL && p.push({ key: "CI_PIPELINE_URL", value: s.CI_PIPELINE_URL, label: "Pipeline", icon: O.link }), s.CI_COMMIT_MESSAGE && (s.CI_COMMIT_MESSAGE.length > 60 ? s.CI_COMMIT_MESSAGE.substring(0, 57) + "" : s.CI_COMMIT_MESSAGE, p.push({ key: "CI_COMMIT_MESSAGE", value: s.CI_COMMIT_MESSAGE, label: "Сообщение", icon: O.code })), /* @__PURE__ */ f.jsxs("div", { style: { display: "inline-block", position: "relative" }, children: [
|
|
1090
|
+
/* @__PURE__ */ f.jsxs(
|
|
1091
|
+
"button",
|
|
1092
|
+
{
|
|
1093
|
+
onClick: () => d(!i),
|
|
1094
|
+
style: {
|
|
1095
|
+
background: "transparent",
|
|
1096
|
+
border: "none",
|
|
1097
|
+
cursor: "pointer",
|
|
1098
|
+
padding: "4px 8px",
|
|
1099
|
+
fontSize: "14px",
|
|
1100
|
+
display: "inline-flex",
|
|
1101
|
+
alignItems: "center"
|
|
1102
|
+
},
|
|
1103
|
+
title: "Информация о версии",
|
|
1104
|
+
children: [
|
|
1105
|
+
/* @__PURE__ */ f.jsx("span", { className: "me-1", children: O.info }),
|
|
1106
|
+
/* @__PURE__ */ f.jsx("span", { className: "text-dark", children: x })
|
|
1107
|
+
]
|
|
1108
|
+
}
|
|
1109
|
+
),
|
|
1110
|
+
i && /* @__PURE__ */ f.jsxs(
|
|
1111
|
+
"div",
|
|
1112
|
+
{
|
|
1113
|
+
style: {
|
|
1114
|
+
position: "absolute",
|
|
1115
|
+
top: "100%",
|
|
1116
|
+
right: 0,
|
|
1117
|
+
zIndex: 1e3,
|
|
1118
|
+
minWidth: "300px",
|
|
1119
|
+
background: "white",
|
|
1120
|
+
border: "1px solid #dee2e6",
|
|
1121
|
+
borderRadius: "8px",
|
|
1122
|
+
boxShadow: "0 4px 12px rgba(0,0,0,0.15)",
|
|
1123
|
+
padding: "16px",
|
|
1124
|
+
marginTop: "4px"
|
|
1125
|
+
},
|
|
1126
|
+
children: [
|
|
1127
|
+
/* @__PURE__ */ f.jsxs("div", { style: {
|
|
1128
|
+
marginBottom: "12px",
|
|
1129
|
+
paddingBottom: "8px",
|
|
1130
|
+
borderBottom: "1px solid #dee2e6",
|
|
1131
|
+
display: "flex",
|
|
1132
|
+
alignItems: "center"
|
|
1133
|
+
}, children: [
|
|
1134
|
+
/* @__PURE__ */ f.jsx("span", { className: "me-2", children: O.apps }),
|
|
1135
|
+
/* @__PURE__ */ f.jsx("strong", { children: s.APP_NAME || n })
|
|
1136
|
+
] }),
|
|
1137
|
+
/* @__PURE__ */ f.jsxs("div", { style: { marginBottom: "12px" }, children: [
|
|
1138
|
+
/* @__PURE__ */ f.jsx("span", { className: "text-muted", children: "Версия: " }),
|
|
1139
|
+
/* @__PURE__ */ f.jsx("strong", { children: x })
|
|
1140
|
+
] }),
|
|
1141
|
+
p.length > 0 && /* @__PURE__ */ f.jsx("div", { style: { fontSize: "13px" }, children: p.map(({ key: y, value: h, label: b, icon: u }) => {
|
|
1142
|
+
const v = h.length > 40 && (y.includes("URL") || y.includes("MESSAGE")) ? `${h.substring(0, 37)}...` : h;
|
|
1143
|
+
return /* @__PURE__ */ f.jsxs("div", { style: { marginBottom: "8px", display: "flex", alignItems: "flex-start" }, children: [
|
|
1144
|
+
/* @__PURE__ */ f.jsx("span", { className: "me-2", style: { flexShrink: 0 }, children: u }),
|
|
1145
|
+
/* @__PURE__ */ f.jsxs("div", { style: { flex: 1, minWidth: 0 }, children: [
|
|
1146
|
+
/* @__PURE__ */ f.jsx("div", { className: "small text-muted", children: b }),
|
|
1147
|
+
/* @__PURE__ */ f.jsx(
|
|
1148
|
+
"div",
|
|
1149
|
+
{
|
|
1150
|
+
className: "font-monospace small text-truncate",
|
|
1151
|
+
style: { maxWidth: "100%" },
|
|
1152
|
+
title: h,
|
|
1153
|
+
children: y.includes("URL") ? /* @__PURE__ */ f.jsx(
|
|
1154
|
+
"a",
|
|
1155
|
+
{
|
|
1156
|
+
href: h,
|
|
1157
|
+
target: "_blank",
|
|
1158
|
+
rel: "noopener noreferrer",
|
|
1159
|
+
style: { color: "#007bff" },
|
|
1160
|
+
children: v
|
|
1161
|
+
}
|
|
1162
|
+
) : v
|
|
1163
|
+
}
|
|
1164
|
+
)
|
|
1165
|
+
] })
|
|
1166
|
+
] }, y);
|
|
1167
|
+
}) }),
|
|
1168
|
+
p.length === 0 && /* @__PURE__ */ f.jsx("div", { className: "text-center text-muted py-2 small", children: "Нет информации о версии" }),
|
|
1169
|
+
/* @__PURE__ */ f.jsx("div", { style: {
|
|
1170
|
+
marginTop: "12px",
|
|
1171
|
+
paddingTop: "8px",
|
|
1172
|
+
borderTop: "1px solid #dee2e6",
|
|
1173
|
+
textAlign: "center",
|
|
1174
|
+
fontSize: "12px",
|
|
1175
|
+
color: "#6c757d"
|
|
1176
|
+
}, children: "IngoBank DevOps Platform" }),
|
|
1177
|
+
/* @__PURE__ */ f.jsx(
|
|
1178
|
+
"button",
|
|
1179
|
+
{
|
|
1180
|
+
onClick: () => d(!1),
|
|
1181
|
+
style: {
|
|
1182
|
+
position: "absolute",
|
|
1183
|
+
top: "8px",
|
|
1184
|
+
right: "8px",
|
|
1185
|
+
background: "transparent",
|
|
1186
|
+
border: "none",
|
|
1187
|
+
cursor: "pointer",
|
|
1188
|
+
fontSize: "16px",
|
|
1189
|
+
color: "#6c757d"
|
|
1190
|
+
},
|
|
1191
|
+
children: "×"
|
|
1192
|
+
}
|
|
1193
|
+
)
|
|
1194
|
+
]
|
|
1195
|
+
}
|
|
1196
|
+
),
|
|
1197
|
+
i && /* @__PURE__ */ f.jsx(
|
|
1198
|
+
"div",
|
|
1199
|
+
{
|
|
1200
|
+
onClick: () => d(!1),
|
|
1201
|
+
style: {
|
|
1202
|
+
position: "fixed",
|
|
1203
|
+
top: 0,
|
|
1204
|
+
left: 0,
|
|
1205
|
+
right: 0,
|
|
1206
|
+
bottom: 0,
|
|
1207
|
+
zIndex: 999
|
|
1208
|
+
}
|
|
1209
|
+
}
|
|
1210
|
+
)
|
|
1211
|
+
] });
|
|
1212
|
+
}
|
|
1213
|
+
const pe = "platform-kit", Je = jt(null);
|
|
1214
|
+
function tr({ children: n }) {
|
|
1215
|
+
const [r, o] = T([]), l = typeof window < "u" && window.__MF_NAME__ || pe, i = j((u, v, C, M) => ({
|
|
1216
|
+
id: `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`,
|
|
1217
|
+
type: u,
|
|
1218
|
+
title: v,
|
|
1219
|
+
message: C,
|
|
1220
|
+
mfeName: l,
|
|
1221
|
+
timestamp: Date.now(),
|
|
1222
|
+
duration: M
|
|
1223
|
+
}), [l]), d = j((u) => {
|
|
1224
|
+
o((C) => [...C, u].slice(0, 5));
|
|
1225
|
+
const v = u.duration || 5e3;
|
|
1226
|
+
v > 0 && setTimeout(() => {
|
|
1227
|
+
o((C) => C.filter((M) => M.id !== u.id));
|
|
1228
|
+
}, v);
|
|
1229
|
+
}, []), s = j((u) => {
|
|
1230
|
+
const v = i(u.type, u.title, u.message, u.duration);
|
|
1231
|
+
d(v), typeof window < "u" && window.dispatchEvent(new CustomEvent("mfe-notification", {
|
|
1232
|
+
detail: v,
|
|
1233
|
+
bubbles: !0
|
|
1234
|
+
}));
|
|
1235
|
+
}, [i, d]), x = j((u, v = "Успешно") => {
|
|
1236
|
+
s({ type: "success", title: v, message: u });
|
|
1237
|
+
}, [s]), p = j((u, v = "Ошибка") => {
|
|
1238
|
+
s({ type: "error", title: v, message: u });
|
|
1239
|
+
}, [s]), y = j((u, v = "Предупреждение") => {
|
|
1240
|
+
s({ type: "warning", title: v, message: u });
|
|
1241
|
+
}, [s]), h = j((u, v = "Информация") => {
|
|
1242
|
+
s({ type: "info", title: v, message: u });
|
|
1243
|
+
}, [s]), b = j((u) => {
|
|
1244
|
+
o((v) => v.filter((C) => C.id !== u));
|
|
1245
|
+
}, []);
|
|
1246
|
+
return Z(() => {
|
|
1247
|
+
if (typeof window > "u") return;
|
|
1248
|
+
const u = (v) => {
|
|
1249
|
+
const C = v.detail;
|
|
1250
|
+
if (C && C.type && C.title && C.message) {
|
|
1251
|
+
const M = {
|
|
1252
|
+
...C,
|
|
1253
|
+
id: `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`
|
|
1254
|
+
};
|
|
1255
|
+
d(M);
|
|
1256
|
+
}
|
|
1257
|
+
};
|
|
1258
|
+
return window.addEventListener("mfe-notification", u), () => {
|
|
1259
|
+
window.removeEventListener("mfe-notification", u);
|
|
1260
|
+
};
|
|
1261
|
+
}, [d]), /* @__PURE__ */ f.jsxs(Je.Provider, { value: {
|
|
1262
|
+
notify: s,
|
|
1263
|
+
notifySuccess: x,
|
|
1264
|
+
notifyError: p,
|
|
1265
|
+
notifyWarning: y,
|
|
1266
|
+
notifyInfo: h,
|
|
1267
|
+
removeNotification: b
|
|
1268
|
+
}, children: [
|
|
1269
|
+
n,
|
|
1270
|
+
r.length > 0 && /* @__PURE__ */ f.jsx(
|
|
1271
|
+
"div",
|
|
1272
|
+
{
|
|
1273
|
+
style: {
|
|
1274
|
+
position: "fixed",
|
|
1275
|
+
top: "80px",
|
|
1276
|
+
right: "20px",
|
|
1277
|
+
zIndex: 9998,
|
|
1278
|
+
maxWidth: "400px",
|
|
1279
|
+
width: "100%",
|
|
1280
|
+
display: "flex",
|
|
1281
|
+
flexDirection: "column",
|
|
1282
|
+
gap: "8px",
|
|
1283
|
+
pointerEvents: "none"
|
|
1284
|
+
},
|
|
1285
|
+
children: r.map((u) => /* @__PURE__ */ f.jsxs(
|
|
1286
|
+
"div",
|
|
1287
|
+
{
|
|
1288
|
+
className: `notification notification-${u.type}`,
|
|
1289
|
+
style: {
|
|
1290
|
+
pointerEvents: "auto",
|
|
1291
|
+
padding: "12px 16px",
|
|
1292
|
+
borderRadius: "8px",
|
|
1293
|
+
background: u.type === "success" ? "#d4edda" : u.type === "error" ? "#f8d7da" : u.type === "warning" ? "#fff3cd" : "#d1ecf1",
|
|
1294
|
+
color: u.type === "success" ? "#155724" : u.type === "error" ? "#721c24" : u.type === "warning" ? "#856404" : "#0c5460",
|
|
1295
|
+
boxShadow: "0 4px 12px rgba(0,0,0,0.15)",
|
|
1296
|
+
display: "flex",
|
|
1297
|
+
alignItems: "flex-start",
|
|
1298
|
+
gap: "12px"
|
|
1299
|
+
},
|
|
1300
|
+
children: [
|
|
1301
|
+
/* @__PURE__ */ f.jsxs("div", { style: { flex: 1 }, children: [
|
|
1302
|
+
/* @__PURE__ */ f.jsx("strong", { style: { display: "block", marginBottom: "4px" }, children: u.title }),
|
|
1303
|
+
/* @__PURE__ */ f.jsx("p", { style: { margin: 0, fontSize: "14px" }, children: u.message }),
|
|
1304
|
+
/* @__PURE__ */ f.jsx("small", { style: { opacity: 0.7, fontSize: "12px" }, children: u.mfeName })
|
|
1305
|
+
] }),
|
|
1306
|
+
/* @__PURE__ */ f.jsx(
|
|
1307
|
+
"button",
|
|
1308
|
+
{
|
|
1309
|
+
onClick: () => b(u.id),
|
|
1310
|
+
style: {
|
|
1311
|
+
background: "transparent",
|
|
1312
|
+
border: "none",
|
|
1313
|
+
cursor: "pointer",
|
|
1314
|
+
fontSize: "18px",
|
|
1315
|
+
lineHeight: 1,
|
|
1316
|
+
opacity: 0.5
|
|
1317
|
+
},
|
|
1318
|
+
children: "×"
|
|
1319
|
+
}
|
|
1320
|
+
)
|
|
1321
|
+
]
|
|
1322
|
+
},
|
|
1323
|
+
u.id
|
|
1324
|
+
))
|
|
1325
|
+
}
|
|
1326
|
+
)
|
|
1327
|
+
] });
|
|
1328
|
+
}
|
|
1329
|
+
function rr() {
|
|
1330
|
+
const n = Mt(Je);
|
|
1331
|
+
return n || {
|
|
1332
|
+
notify: () => {
|
|
1333
|
+
},
|
|
1334
|
+
notifySuccess: () => {
|
|
1335
|
+
},
|
|
1336
|
+
notifyError: () => {
|
|
1337
|
+
},
|
|
1338
|
+
notifyWarning: () => {
|
|
1339
|
+
},
|
|
1340
|
+
notifyInfo: () => {
|
|
1341
|
+
},
|
|
1342
|
+
removeNotification: () => {
|
|
1343
|
+
}
|
|
1344
|
+
};
|
|
1345
|
+
}
|
|
1346
|
+
function nr(n) {
|
|
1347
|
+
if (typeof window > "u") return;
|
|
1348
|
+
const r = window.__MF_NAME__ || pe, o = {
|
|
1349
|
+
...n,
|
|
1350
|
+
mfeName: r,
|
|
1351
|
+
timestamp: Date.now()
|
|
1352
|
+
};
|
|
1353
|
+
window.dispatchEvent(new CustomEvent("mfe-notification", {
|
|
1354
|
+
detail: o,
|
|
1355
|
+
bubbles: !0
|
|
1356
|
+
}));
|
|
1357
|
+
}
|
|
1358
|
+
const qe = "platform-kit", G = {
|
|
1359
|
+
log: (...n) => {
|
|
1360
|
+
},
|
|
1361
|
+
warn: (...n) => {
|
|
1362
|
+
},
|
|
1363
|
+
error: (...n) => {
|
|
1364
|
+
console.error(`[${qe}]`, ...n);
|
|
1365
|
+
},
|
|
1366
|
+
info: (...n) => {
|
|
1367
|
+
}
|
|
1368
|
+
};
|
|
1369
|
+
function Ht() {
|
|
1370
|
+
if (typeof window > "u")
|
|
1371
|
+
return { isAuthenticated: !1 };
|
|
1372
|
+
const n = window.__SHELL_AUTH_INSTANCE__;
|
|
1373
|
+
if (n)
|
|
1374
|
+
return n;
|
|
1375
|
+
const r = window.__SHELL_AUTH__;
|
|
1376
|
+
return r?.authInstance ? r.authInstance : { isAuthenticated: !1 };
|
|
1377
|
+
}
|
|
1378
|
+
function Gt() {
|
|
1379
|
+
if (typeof window > "u") return;
|
|
1380
|
+
const n = window.__SHELL_AUTH_INSTANCE__;
|
|
1381
|
+
n?.signinRedirect ? n.signinRedirect().catch((r) => {
|
|
1382
|
+
G.error("Failed to redirect to login:", r);
|
|
1383
|
+
}) : window.location.href = "/";
|
|
1384
|
+
}
|
|
1385
|
+
function zt(n) {
|
|
1386
|
+
const r = n.response;
|
|
1387
|
+
let o = "unknown";
|
|
1388
|
+
return r ? r.status === 401 ? o = "unauthorized" : r.status === 403 ? o = "forbidden" : r.status === 404 ? o = "not_found" : r.status >= 500 && (o = "server") : o = "network", {
|
|
1389
|
+
message: r?.data?.message ?? n.message ?? "Unknown error",
|
|
1390
|
+
code: r?.data?.code,
|
|
1391
|
+
status: r?.status,
|
|
1392
|
+
type: o,
|
|
1393
|
+
timestamp: Date.now(),
|
|
1394
|
+
url: n.config?.url
|
|
1395
|
+
};
|
|
1396
|
+
}
|
|
1397
|
+
function Yt(n = {}) {
|
|
1398
|
+
const r = n.name || qe, o = {
|
|
1399
|
+
log: (...i) => G.log(`[API:${r}]`, ...i),
|
|
1400
|
+
warn: (...i) => G.warn(`[API:${r}]`, ...i),
|
|
1401
|
+
error: (...i) => G.error(`[API:${r}]`, ...i),
|
|
1402
|
+
info: (...i) => G.info(`[API:${r}]`, ...i)
|
|
1403
|
+
}, l = Nt.create({
|
|
1404
|
+
timeout: n.timeout ?? 1e4,
|
|
1405
|
+
baseURL: n.baseURL ?? "",
|
|
1406
|
+
headers: {
|
|
1407
|
+
"Content-Type": "application/json"
|
|
1408
|
+
}
|
|
1409
|
+
});
|
|
1410
|
+
return l.interceptors.request.use(
|
|
1411
|
+
(i) => {
|
|
1412
|
+
const d = Ht();
|
|
1413
|
+
if (d?.isAuthenticated) {
|
|
1414
|
+
const s = d.user?.profile?.access_token;
|
|
1415
|
+
s && i.headers && (i.headers.Authorization = `Bearer ${s}`, o.info("Auth token attached"));
|
|
1416
|
+
} else
|
|
1417
|
+
o.info("User not authenticated - request without token");
|
|
1418
|
+
return o.log(`${i.method?.toUpperCase()} ${i.url}`), i;
|
|
1419
|
+
},
|
|
1420
|
+
(i) => (o.error("Request interceptor error:", i.message), Promise.reject(i))
|
|
1421
|
+
), l.interceptors.response.use(
|
|
1422
|
+
(i) => (o.log(`Response ${i.status}:`, i.config.url), i),
|
|
1423
|
+
(i) => {
|
|
1424
|
+
const d = i.response?.status, s = i.config?.url;
|
|
1425
|
+
return d === 401 ? (o.warn("401 Unauthorized - triggering re-auth"), Gt()) : d === 403 ? o.warn("403 Forbidden - insufficient permissions") : d === 404 ? o.warn("404 Not found:", s) : d === 429 ? o.warn("429 Rate limited") : d === 500 ? o.error("500 Server error:", s) : i.response ? o.warn(`Error ${d}:`, i.message) : o.error("Network error - backend may be unavailable:", s), Promise.reject(zt(i));
|
|
1426
|
+
}
|
|
1427
|
+
), l;
|
|
1428
|
+
}
|
|
1429
|
+
const Q = Yt();
|
|
1430
|
+
async function or(n, r, o = Q) {
|
|
1431
|
+
const l = await o.get(n, { params: r });
|
|
1432
|
+
return {
|
|
1433
|
+
data: l.data,
|
|
1434
|
+
status: l.status,
|
|
1435
|
+
ok: l.status >= 200 && l.status < 300
|
|
1436
|
+
};
|
|
1437
|
+
}
|
|
1438
|
+
async function ar(n, r, o = Q) {
|
|
1439
|
+
const l = await o.post(n, r);
|
|
1440
|
+
return {
|
|
1441
|
+
data: l.data,
|
|
1442
|
+
status: l.status,
|
|
1443
|
+
ok: l.status >= 200 && l.status < 300
|
|
1444
|
+
};
|
|
1445
|
+
}
|
|
1446
|
+
async function ir(n, r, o = Q) {
|
|
1447
|
+
const l = await o.put(n, r);
|
|
1448
|
+
return {
|
|
1449
|
+
data: l.data,
|
|
1450
|
+
status: l.status,
|
|
1451
|
+
ok: l.status >= 200 && l.status < 300
|
|
1452
|
+
};
|
|
1453
|
+
}
|
|
1454
|
+
async function sr(n, r = Q) {
|
|
1455
|
+
const o = await r.delete(n);
|
|
1456
|
+
return {
|
|
1457
|
+
data: o.data,
|
|
1458
|
+
status: o.status,
|
|
1459
|
+
ok: o.status >= 200 && o.status < 300
|
|
1460
|
+
};
|
|
1461
|
+
}
|
|
1462
|
+
function ee(n, r) {
|
|
1463
|
+
const o = r?.prefix ? `[${r.prefix}]` : `[${n}]`;
|
|
1464
|
+
return {
|
|
1465
|
+
log: (...l) => {
|
|
1466
|
+
},
|
|
1467
|
+
warn: (...l) => {
|
|
1468
|
+
},
|
|
1469
|
+
error: (...l) => {
|
|
1470
|
+
console.error(o, ...l);
|
|
1471
|
+
},
|
|
1472
|
+
info: (...l) => {
|
|
1473
|
+
}
|
|
1474
|
+
};
|
|
1475
|
+
}
|
|
1476
|
+
const lr = ee("platform-kit", { prefix: "AUTH" }), ur = ee("platform-kit", { prefix: "API" }), cr = ee("platform-kit", { prefix: "ERROR" }), fr = ee("platform-kit", { prefix: "INFO" });
|
|
1477
|
+
export {
|
|
1478
|
+
Qt as ErrorBoundary,
|
|
1479
|
+
tr as NotificationProvider,
|
|
1480
|
+
er as VersionInfo,
|
|
1481
|
+
Q as api,
|
|
1482
|
+
ur as apiLogger,
|
|
1483
|
+
lr as authLogger,
|
|
1484
|
+
Yt as createApiClient,
|
|
1485
|
+
ee as createMfLogger,
|
|
1486
|
+
sr as del,
|
|
1487
|
+
nr as dispatchNotification,
|
|
1488
|
+
cr as errorLogger,
|
|
1489
|
+
or as get,
|
|
1490
|
+
ce as getAuth,
|
|
1491
|
+
fr as infoLogger,
|
|
1492
|
+
ar as post,
|
|
1493
|
+
ir as put,
|
|
1494
|
+
Xt as useApi,
|
|
1495
|
+
$t as useInfoData,
|
|
1496
|
+
rr as useNotification,
|
|
1497
|
+
Zt as usePermissions,
|
|
1498
|
+
Pt as useShellAuth,
|
|
1499
|
+
Kt as useV1Config
|
|
1500
|
+
};
|