@ibdop/platform-kit 1.0.12 → 1.0.13
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 +0 -0
- package/dist/components/ErrorBoundary.d.ts +0 -0
- package/dist/components/ErrorBoundary.d.ts.map +0 -0
- package/dist/components/Notification.d.ts +0 -0
- package/dist/components/Notification.d.ts.map +0 -0
- package/dist/components/VersionInfo.d.ts +0 -0
- package/dist/components/VersionInfo.d.ts.map +0 -0
- package/dist/components/index.d.ts +0 -0
- package/dist/components/index.d.ts.map +0 -0
- package/dist/hooks/index.d.ts +2 -1
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/useApi.d.ts +13 -2
- package/dist/hooks/useApi.d.ts.map +1 -1
- package/dist/hooks/useFeatures.d.ts +0 -0
- package/dist/hooks/useFeatures.d.ts.map +0 -0
- package/dist/hooks/useInfoData.d.ts +0 -0
- package/dist/hooks/useInfoData.d.ts.map +0 -0
- package/dist/hooks/usePermissions.d.ts +0 -0
- package/dist/hooks/usePermissions.d.ts.map +0 -0
- package/dist/hooks/useShellAuth.d.ts +0 -0
- package/dist/hooks/useShellAuth.d.ts.map +0 -0
- package/dist/hooks/useV1Config.d.ts +0 -0
- package/dist/hooks/useV1Config.d.ts.map +0 -0
- package/dist/index.d.ts +0 -0
- package/dist/index.d.ts.map +0 -0
- package/dist/index.js +10 -10
- package/dist/index.mjs +726 -701
- package/dist/index.umd.js +9 -9
- package/dist/services/api.d.ts +0 -0
- package/dist/services/api.d.ts.map +1 -1
- package/dist/services/index.d.ts +0 -0
- package/dist/services/index.d.ts.map +0 -0
- package/dist/services/logger.d.ts +0 -0
- package/dist/services/logger.d.ts.map +0 -0
- package/dist/types/index.d.ts +0 -23
- package/dist/types/index.d.ts.map +1 -1
- package/dist/utils/index.d.ts +0 -0
- package/dist/utils/index.d.ts.map +0 -0
- package/dist/utils/mfeName.d.ts +0 -0
- package/dist/utils/mfeName.d.ts.map +0 -0
- package/dist/utils/shellAuth.d.ts +1 -0
- package/dist/utils/shellAuth.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/components/ErrorBoundary.tsx +0 -0
- package/src/components/Notification.tsx +0 -0
- package/src/components/VersionInfo.tsx +0 -0
- package/src/components/index.ts +0 -0
- package/src/global.d.ts +0 -0
- package/src/hooks/index.ts +2 -1
- package/src/hooks/useApi.ts +48 -40
- package/src/hooks/useFeatures.ts +0 -0
- package/src/hooks/useInfoData.ts +0 -0
- package/src/hooks/usePermissions.ts +0 -0
- package/src/hooks/useShellAuth.ts +0 -0
- package/src/hooks/useV1Config.ts +0 -0
- package/src/index.ts +0 -0
- package/src/services/api.ts +4 -1
- package/src/services/index.ts +0 -0
- package/src/services/logger.ts +0 -0
- package/src/types/index.ts +1 -24
- package/src/utils/index.ts +0 -0
- package/src/utils/mfeName.ts +0 -0
- package/src/utils/shellAuth.ts +1 -0
package/README.md
CHANGED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/dist/hooks/index.d.ts
CHANGED
|
@@ -4,7 +4,8 @@
|
|
|
4
4
|
export { useShellAuth, getShellAuth } from './useShellAuth';
|
|
5
5
|
export { useInfoData } from './useInfoData';
|
|
6
6
|
export { useV1Config } from './useV1Config';
|
|
7
|
-
export { useApi } from './useApi';
|
|
7
|
+
export { useApi, useGet, usePost, usePut, useDel } from './useApi';
|
|
8
|
+
export type { UseApiConfig, UseApiResult, UseGetConfig } from './useApi';
|
|
8
9
|
export { usePermissions } from './usePermissions';
|
|
9
10
|
export { useFeatures, useFeatureAdmin, useMicrofrontendsFeatures, } from './useFeatures';
|
|
10
11
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAA;AAE3D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAClE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAExE,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,EACL,WAAW,EACX,eAAe,EACf,yBAAyB,GAC1B,MAAM,eAAe,CAAA"}
|
package/dist/hooks/useApi.d.ts
CHANGED
|
@@ -50,9 +50,20 @@ export interface UseApiResult<T> {
|
|
|
50
50
|
*/
|
|
51
51
|
export declare function useApi<T>(request: (signal?: AbortSignal) => Promise<ApiResponse<T>>, config?: UseApiConfig<T>): UseApiResult<T>;
|
|
52
52
|
/**
|
|
53
|
-
* GET
|
|
53
|
+
* GET request config with auto-execute support
|
|
54
54
|
*/
|
|
55
|
-
export
|
|
55
|
+
export interface UseGetConfig<T> extends UseApiConfig<T> {
|
|
56
|
+
/** Skip request (don't execute) */
|
|
57
|
+
skip?: boolean;
|
|
58
|
+
/** Dynamic headers function */
|
|
59
|
+
headers?: () => Record<string, string>;
|
|
60
|
+
/** Auto-execute on mount (default: true for useGet) */
|
|
61
|
+
immediate?: boolean;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* GET request with AbortController and auto-execute
|
|
65
|
+
*/
|
|
66
|
+
export declare function useGet<T>(url: string, config?: UseGetConfig<T>): UseApiResult<T>;
|
|
56
67
|
/**
|
|
57
68
|
* POST запрос с AbortController
|
|
58
69
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useApi.d.ts","sourceRoot":"","sources":["../../src/hooks/useApi.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"useApi.d.ts","sourceRoot":"","sources":["../../src/hooks/useApi.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAuB1E;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,mBAAmB,EAAE,WAAW,GAAG,SAAS,CAAC,GAAG,IAAI,CAiB3G;AAED;;GAEG;AACH,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAuCjF;AAED;;GAEG;AACH,MAAM,WAAW,YAAY,CAAC,CAAC,GAAG,KAAK;IACrC,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAA;IAC7B,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAA;IACnC,6CAA6C;IAC7C,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,YAAY,CAAC,CAAC;IAC7B,IAAI,EAAE,CAAC,GAAG,IAAI,CAAA;IACd,KAAK,EAAE,QAAQ,GAAG,IAAI,CAAA;IACtB,SAAS,EAAE,OAAO,CAAA;IAClB,OAAO,EAAE,OAAO,CAAA;IAChB,SAAS,EAAE,OAAO,CAAA;IAClB,OAAO,EAAE,MAAM,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IAChC,KAAK,EAAE,MAAM,IAAI,CAAA;IACjB,KAAK,EAAE,MAAM,IAAI,CAAA;CAClB;AASD;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,OAAO,EAAE,CAAC,MAAM,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAC1D,MAAM,GAAE,YAAY,CAAC,CAAC,CAAM,GAC3B,YAAY,CAAC,CAAC,CAAC,CAmIjB;AAID;;GAEG;AACH,MAAM,WAAW,YAAY,CAAC,CAAC,CAAE,SAAQ,YAAY,CAAC,CAAC,CAAC;IACtD,mCAAmC;IACnC,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,+BAA+B;IAC/B,OAAO,CAAC,EAAE,MAAM,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACtC,uDAAuD;IACvD,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAED;;GAEG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,GAAG,EAAE,MAAM,EACX,MAAM,GAAE,YAAY,CAAC,CAAC,CAAM,GAC3B,YAAY,CAAC,CAAC,CAAC,CA0BjB;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,CAAC,EACvB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,MAAM,GAAE,YAAY,CAAC,CAAC,CAAM,GAC3B,YAAY,CAAC,CAAC,CAAC,CAQjB;AAED;;GAEG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,MAAM,GAAE,YAAY,CAAC,CAAC,CAAM,GAC3B,YAAY,CAAC,CAAC,CAAC,CAQjB;AAED;;GAEG;AACH,wBAAgB,MAAM,CAAC,CAAC,EACtB,GAAG,EAAE,MAAM,EACX,MAAM,GAAE,YAAY,CAAC,CAAC,CAAM,GAC3B,YAAY,CAAC,CAAC,CAAC,CAQjB"}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/dist/index.d.ts
CHANGED
|
File without changes
|
package/dist/index.d.ts.map
CHANGED
|
File without changes
|
package/dist/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const i=require("react"),Lt=require("axios");function L(){if(typeof window>"u")return null;const t=window;if(t.__SHELL_AUTH_INSTANCE__)return t.__SHELL_AUTH_INSTANCE__;const r=window;return r.__SHELL_AUTH__?.authInstance?r.__SHELL_AUTH__.authInstance:null}function Ke(){const t=L();return t?{isAuthenticated:t.isAuthenticated,user:t.user??void 0}:{isAuthenticated:!1}}function Ut(){const t=L();return t?.isAuthenticated?t.user?.profile?.access_token??null:null}function Vt(){return L()?.isAuthenticated??!1}async function Xe(){const t=L();t?.signinRedirect?await t.signinRedirect():typeof window<"u"&&(window.location.href="/")}async function Bt(){const t=L();t?.removeUser&&await t.removeUser()}const He={log:(...t)=>{},warn:(...t)=>{}};function q(){const[t,r]=i.useState(null),[o,u]=i.useState(!0),l=i.useRef(0),g=20,n=i.useCallback(()=>L(),[]);i.useEffect(()=>{const y=n();if(y){r(y),u(!1);return}const d=c=>{r(c.detail),u(!1)},h=setInterval(()=>{l.current++;const c=n();c?(He.log("Auth found via polling, attempts:",l.current),r(c),u(!1),clearInterval(h)):l.current>=g&&(u(!1),clearInterval(h))},500);return window.addEventListener("shell-auth-ready",d),()=>{clearInterval(h),window.removeEventListener("shell-auth-ready",d)}},[n]);const f=t||{user:null,isAuthenticated:!1,isLoading:o,signinRedirect:async()=>{const y=L();y?.signinRedirect?await y.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const y=L();y?.removeUser&&await y.removeUser()}};return He.log("Auth result:",{isAuthenticated:f.isAuthenticated,isLoading:f.isLoading}),f}const Wt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function zt(t){if(t)return t;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function Ze(t){const[r,o]=i.useState(null),[u,l]=i.useState(!0),[g,n]=i.useState(null),_=i.useCallback(()=>{const y=zt(t?.mfeName).replace("@ib-dop/","");l(!0),n(null),fetch(`/svc/${y}/info.json`).then(d=>{if(!d.ok)throw new Error(`HTTP ${d.status}: ${d.statusText}`);return d.json()}).then(d=>{o(d)}).catch(d=>{Wt.error("Failed to load info:",d),n(d instanceof Error?d.message:String(d))}).finally(()=>{l(!1)})},[t?.mfeName]);return i.useEffect(()=>{_()},[_]),{data:r,isLoading:u,error:g,refetch:_}}const ge={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},re={authority:"",client_id:"",environment:"development"};function Ht(){const[t,r]=i.useState(null),[o,u]=i.useState(!0),[l,g]=i.useState(null);return i.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){g("sessionStorage not available"),r(re),u(!1);return}try{const _=sessionStorage.getItem("config");if(_){const f=JSON.parse(_);r({...re,...f}),g(null),ge.log("Config loaded successfully")}else r(re),g("Config not found in sessionStorage"),ge.warn("Config not found in sessionStorage")}catch(_){ge.error("Error parsing config:",_),r(re),g("Error parsing config")}finally{u(!1)}})()},[]),{data:t,isLoading:o,error:l}}function Qe(t){if(typeof window>"u")return;const r=window.__MF_NAME__||"unknown",o={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:o,bubbles:!0}))}function Ge(t,r){const o={network:{title:"Нет подключения",message:"Сервер недоступен. Проверьте подключение к интернету."},unauthorized:{title:"Требуется вход",message:"Ваша сессия истекла. Войдите в систему снова."},forbidden:{title:"Доступ запрещён",message:"У вас нет прав для выполнения этого действия."},not_found:{title:"Не найдено",message:"Запрошенный ресурс не найден."},server:{title:"Ошибка сервера",message:"Произошла ошибка на сервере. Попробуйте позже."},client:{title:"Ошибка",message:t.message||"Произошла ошибка при выполнении запроса."},unknown:{title:"Неизвестная ошибка",message:t.message||"Произошла неизвестная ошибка."}},u=o[t.type]||o.unknown;Qe({type:t.type==="network"?"warning":"error",title:u.title,message:r?`${u.message} (${r})`:u.message})}function Gt(t){return t instanceof Error&&t.name==="AbortError"}function Yt(t,r={}){const{notifyOnError:o=!0,notifyOnSuccess:u=!1,successMessage:l,errorContext:g,onSuccess:n,onError:_}=r,[f,y]=i.useState(null),[d,h]=i.useState(null),[c,w]=i.useState(!1),E=i.useRef(null),I=d!==null,k=f!==null&&!c&&!I;i.useEffect(()=>()=>{E.current&&E.current.abort()},[]);const S=i.useCallback(()=>{E.current&&(E.current.abort(),E.current=null,w(!1))},[]),v=i.useCallback(async()=>{E.current&&E.current.abort(),E.current=new AbortController;const N=E.current.signal;w(!0),h(null);try{const j=await t(N);if(N.aborted)return null;if(j.ok)return y(j.data),u&&l&&Qe({type:"success",title:"Успешно",message:l}),n?.(j.data),j.data;{const $={message:j.data||"Request failed",status:j.status,type:"client",timestamp:Date.now()};return h($),o&&Ge($,g),_?.($),null}}catch(j){if(Gt(j))return null;const $=j;return h($),o&&Ge($,g),_?.($),null}finally{N.aborted||w(!1),E.current=null}},[t,o,u,l,g,n,_]),R=i.useCallback(()=>{y(null),h(null),w(!1)},[]);return{data:f,error:d,isLoading:c,isError:I,isSuccess:k,execute:v,reset:R,abort:S}}const Jt={canView:["all"],canEdit:["ibdop-user","ibdop-admin","ibdop-devops"],canDelete:["ibdop-admin","ibdop-devops"],canAdmin:["ibdop-admin"],canViewSensitiveData:["ibdop-admin","ibdop-devops"],canExportData:["ibdop-user"],canManageUsers:["ibdop-admin"]};function qt(t={}){const r=q(),o=i.useMemo(()=>({...Jt,...t}),[t]),u=i.useMemo(()=>{const g=r.user?.profile?.realm_roles||r.user?.profile?.roles||[];return Array.isArray(g)?g:[g]},[r.user]),l=g=>g.includes("all")?!0:g.some(n=>u.includes(n));return{canView:l(o.canView),canEdit:l(o.canEdit),canDelete:l(o.canDelete),canAdmin:l(o.canAdmin),canViewSensitiveData:l(o.canViewSensitiveData),canExportData:l(o.canExportData),canManageUsers:l(o.canManageUsers)}}function Kt(){const t=q(),[r,o]=i.useState([]),[u,l]=i.useState(0),[g,n]=i.useState([]),[_,f]=i.useState(!0),[y,d]=i.useState(null),h=i.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatures] Not authenticated"),f(!1);return}f(!0),d(null);try{const E={"Content-Type":"application/json"},I=t.user?.access_token;I&&(E.Authorization=`Bearer ${I}`);const k=await fetch("/api/features",{headers:E});if(!k.ok)throw new Error(`HTTP ${k.status}: ${k.statusText}`);const S=await k.json();o(S.features||[]),l(S.totalCount||0),n(S.userRoles||[])}catch(E){console.debug("Features fetch error:",E),d(E instanceof Error?E.message:String(E)),o([]),n([])}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]);i.useEffect(()=>{h()},[h]);const c=i.useCallback(E=>r.find(k=>k.name===E)?.userEnabled??!1,[r]),w=i.useCallback(E=>r.filter(I=>I.mfDependencies?.includes(E)),[r]);return{features:r,totalCount:u,userRoles:g,isLoading:_,error:y,refetch:h,isFeatureEnabled:c,getFeaturesByMf:w}}function Xt(){const t=q(),[r,o]=i.useState([]),[u,l]=i.useState([]),[g,n]=i.useState(!1),[_,f]=i.useState(!0),[y,d]=i.useState(null),h=i.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatureAdmin] Not authenticated"),f(!1);return}f(!0),d(null);try{const k={"Content-Type":"application/json"},S=t.user?.access_token;S&&(k.Authorization=`Bearer ${S}`);const v=await fetch("/api/features/admin",{headers:k});if(!v.ok){if(v.status===403){console.warn("[useFeatureAdmin] 403 Forbidden - checking if token has admin role"),n(!1),o([]),l([]),f(!1);return}throw new Error(`HTTP ${v.status}: ${v.statusText}`)}const R=await v.json();o(R.featureToggles||[]),l(R.microfrontends||[]),n(R.isAdmin||!1)}catch(k){console.debug("FeatureAdmin fetch error:",k),o([]),l([]),n(!1)}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]),c=i.useCallback(async k=>{try{const S={"Content-Type":"application/json"},v=t.user?.access_token;v&&(S.Authorization=`Bearer ${v}`);const R=await fetch("/api/features/admin",{method:"POST",headers:S,body:JSON.stringify(k)});if(!R.ok){const N=await R.json().catch(()=>({}));throw new Error(N.error||`HTTP ${R.status}`)}return await h(),!0}catch(S){return d(S instanceof Error?S.message:String(S)),!1}},[h]),w=i.useCallback(async(k,S)=>{try{const v={"Content-Type":"application/json"},R=t.user?.access_token;R&&(v.Authorization=`Bearer ${R}`);const N=await fetch(`/api/features/admin/${encodeURIComponent(k)}`,{method:"PUT",headers:v,body:JSON.stringify(S)});if(!N.ok){const j=await N.json().catch(()=>({}));throw new Error(j.error||`HTTP ${N.status}`)}return await h(),!0}catch(v){return d(v instanceof Error?v.message:String(v)),!1}},[h]),E=i.useCallback(async(k,S)=>{try{const v={},R=t.user?.access_token;R&&(v.Authorization=`Bearer ${R}`);const N=await fetch(`/api/features/admin/${encodeURIComponent(k)}/toggle?enabled=${S}`,{method:"POST",headers:v});if(!N.ok){const j=await N.json().catch(()=>({}));throw new Error(j.error||`HTTP ${N.status}`)}return await h(),!0}catch(v){return d(v instanceof Error?v.message:String(v)),!1}},[h]),I=i.useCallback(async k=>{try{const S={},v=t.user?.access_token;v&&(S.Authorization=`Bearer ${v}`);const R=await fetch(`/api/features/admin/${encodeURIComponent(k)}`,{method:"DELETE",headers:S});if(!R.ok){const N=await R.json().catch(()=>({}));throw new Error(N.error||`HTTP ${R.status}`)}return await h(),!0}catch(S){return d(S instanceof Error?S.message:String(S)),!1}},[h]);return i.useEffect(()=>{h()},[h]),{features:r,microfrontends:u,isAdmin:g,isLoading:_,error:y,refetch:h,createFeature:c,updateFeature:w,toggleFeature:E,deleteFeature:I}}function Zt(){const t=q(),[r,o]=i.useState([]),[u,l]=i.useState(0),[g,n]=i.useState(!0),[_,f]=i.useState(null),y=i.useCallback(async()=>{if(!t.isAuthenticated){n(!1);return}n(!0),f(null);try{const d={"Content-Type":"application/json"},h=t.user?.access_token;h&&(d.Authorization=`Bearer ${h}`);const c=await fetch("/api/features/microfrontends",{headers:d});if(!c.ok)throw new Error(`HTTP ${c.status}: ${c.statusText}`);const w=await c.json();o(w.microfrontends||[]),l(w.totalCount||0)}catch(d){f(d instanceof Error?d.message:String(d))}finally{n(!1)}},[t.isAuthenticated,t.user?.access_token]);return i.useEffect(()=>{y()},[y]),{microfrontends:r,totalCount:u,isLoading:g,error:_,refetch:y}}var ne={exports:{}},Y={};var Ye;function Qt(){if(Ye)return Y;Ye=1;var t=i,r=Symbol.for("react.element"),o=Symbol.for("react.fragment"),u=Object.prototype.hasOwnProperty,l=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,g={key:!0,ref:!0,__self:!0,__source:!0};function n(_,f,y){var d,h={},c=null,w=null;y!==void 0&&(c=""+y),f.key!==void 0&&(c=""+f.key),f.ref!==void 0&&(w=f.ref);for(d in f)u.call(f,d)&&!g.hasOwnProperty(d)&&(h[d]=f[d]);if(_&&_.defaultProps)for(d in f=_.defaultProps,f)h[d]===void 0&&(h[d]=f[d]);return{$$typeof:r,type:_,key:c,ref:w,props:h,_owner:l.current}}return Y.Fragment=o,Y.jsx=n,Y.jsxs=n,Y}var J={};var Je;function er(){return Je||(Je=1,process.env.NODE_ENV!=="production"&&(function(){var t=i,r=Symbol.for("react.element"),o=Symbol.for("react.portal"),u=Symbol.for("react.fragment"),l=Symbol.for("react.strict_mode"),g=Symbol.for("react.profiler"),n=Symbol.for("react.provider"),_=Symbol.for("react.context"),f=Symbol.for("react.forward_ref"),y=Symbol.for("react.suspense"),d=Symbol.for("react.suspense_list"),h=Symbol.for("react.memo"),c=Symbol.for("react.lazy"),w=Symbol.for("react.offscreen"),E=Symbol.iterator,I="@@iterator";function k(e){if(e===null||typeof e!="object")return null;var s=E&&e[E]||e[I];return typeof s=="function"?s:null}var S=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function v(e){{for(var s=arguments.length,a=new Array(s>1?s-1:0),p=1;p<s;p++)a[p-1]=arguments[p];R("error",e,a)}}function R(e,s,a){{var p=S.ReactDebugCurrentFrame,C=p.getStackAddendum();C!==""&&(s+="%s",a=a.concat([C]));var A=a.map(function(x){return String(x)});A.unshift("Warning: "+s),Function.prototype.apply.call(console[e],console,A)}}var N=!1,j=!1,$=!1,ut=!1,ct=!1,ye;ye=Symbol.for("react.module.reference");function lt(e){return!!(typeof e=="string"||typeof e=="function"||e===u||e===g||ct||e===l||e===y||e===d||ut||e===w||N||j||$||typeof e=="object"&&e!==null&&(e.$$typeof===c||e.$$typeof===h||e.$$typeof===n||e.$$typeof===_||e.$$typeof===f||e.$$typeof===ye||e.getModuleId!==void 0))}function ft(e,s,a){var p=e.displayName;if(p)return p;var C=s.displayName||s.name||"";return C!==""?a+"("+C+")":a}function we(e){return e.displayName||"Context"}function U(e){if(e==null)return null;if(typeof e.tag=="number"&&v("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case u:return"Fragment";case o:return"Portal";case g:return"Profiler";case l:return"StrictMode";case y:return"Suspense";case d:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case _:var s=e;return we(s)+".Consumer";case n:var a=e;return we(a._context)+".Provider";case f:return ft(e,e.render,"ForwardRef");case h:var p=e.displayName||null;return p!==null?p:U(e.type)||"Memo";case c:{var C=e,A=C._payload,x=C._init;try{return U(x(A))}catch{return null}}}return null}var V=Object.assign,H=0,be,xe,Se,Ce,Ae,ke,Re;function Te(){}Te.__reactDisabledLog=!0;function dt(){{if(H===0){be=console.log,xe=console.info,Se=console.warn,Ce=console.error,Ae=console.group,ke=console.groupCollapsed,Re=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Te,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}H++}}function pt(){{if(H--,H===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:V({},e,{value:be}),info:V({},e,{value:xe}),warn:V({},e,{value:Se}),error:V({},e,{value:Ce}),group:V({},e,{value:Ae}),groupCollapsed:V({},e,{value:ke}),groupEnd:V({},e,{value:Re})})}H<0&&v("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var ae=S.ReactCurrentDispatcher,ie;function Z(e,s,a){{if(ie===void 0)try{throw Error()}catch(C){var p=C.stack.trim().match(/\n( *(at )?)/);ie=p&&p[1]||""}return`
|
|
2
|
-
`+
|
|
3
|
-
`),P=
|
|
4
|
-
`),
|
|
5
|
-
`+b[
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=require("react"),Ut=require("axios");function L(){if(typeof window>"u")return null;const t=window;if(t.__SHELL_AUTH_INSTANCE__)return t.__SHELL_AUTH_INSTANCE__;const r=window;return r.__SHELL_AUTH__?.authInstance?r.__SHELL_AUTH__.authInstance:null}function Xe(){const t=L();return t?{isAuthenticated:t.isAuthenticated,user:t.user??void 0}:{isAuthenticated:!1}}function Vt(){const t=L();return t?.isAuthenticated?t.user?.profile?.access_token??null:null}function Bt(){return L()?.isAuthenticated??!1}async function Ze(){const t=L();t?.signinRedirect?await t.signinRedirect():typeof window<"u"&&(window.location.href="/")}async function Wt(){const t=L();t?.removeUser&&await t.removeUser()}const Ge={log:(...t)=>{},warn:(...t)=>{}};function K(){const[t,r]=c.useState(null),[a,i]=c.useState(!0),o=c.useRef(0),p=20,n=c.useCallback(()=>L(),[]);c.useEffect(()=>{const E=n();if(E){r(E),i(!1);return}const l=d=>{r(d.detail),i(!1)},m=setInterval(()=>{o.current++;const d=n();d?(Ge.log("Auth found via polling, attempts:",o.current),r(d),i(!1),clearInterval(m)):o.current>=p&&(i(!1),clearInterval(m))},500);return window.addEventListener("shell-auth-ready",l),()=>{clearInterval(m),window.removeEventListener("shell-auth-ready",l)}},[n]);const f=t||{user:null,isAuthenticated:!1,isLoading:a,signinRedirect:async()=>{const E=L();E?.signinRedirect?await E.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const E=L();E?.removeUser&&await E.removeUser()}};return Ge.log("Auth result:",{isAuthenticated:f.isAuthenticated,isLoading:f.isLoading}),f}const zt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function Ht(t){if(t)return t;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function Qe(t){const[r,a]=c.useState(null),[i,o]=c.useState(!0),[p,n]=c.useState(null),h=c.useCallback(()=>{const E=Ht(t?.mfeName).replace("@ib-dop/","");o(!0),n(null),fetch(`/svc/${E}/info.json`).then(l=>{if(!l.ok)throw new Error(`HTTP ${l.status}: ${l.statusText}`);return l.json()}).then(l=>{a(l)}).catch(l=>{zt.error("Failed to load info:",l),n(l instanceof Error?l.message:String(l))}).finally(()=>{o(!1)})},[t?.mfeName]);return c.useEffect(()=>{h()},[h]),{data:r,isLoading:i,error:p,refetch:h}}const ge={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},ne={authority:"",client_id:"",environment:"development"};function Gt(){const[t,r]=c.useState(null),[a,i]=c.useState(!0),[o,p]=c.useState(null);return c.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){p("sessionStorage not available"),r(ne),i(!1);return}try{const h=sessionStorage.getItem("config");if(h){const f=JSON.parse(h);r({...ne,...f}),p(null),ge.log("Config loaded successfully")}else r(ne),p("Config not found in sessionStorage"),ge.warn("Config not found in sessionStorage")}catch(h){ge.error("Error parsing config:",h),r(ne),p("Error parsing config")}finally{i(!1)}})()},[]),{data:t,isLoading:a,error:o}}const et="platform-kit",se={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${et}]`,...t)},info:(...t)=>{}};function Yt(t){const r=t.response;let a="unknown";return r?r.status===401?a="unauthorized":r.status===403?a="forbidden":r.status===404?a="not_found":r.status>=500&&(a="server"):a="network",{message:r?.data?.message??t.message??"Unknown error",code:r?.data?.code,status:r?.status,type:a,timestamp:Date.now(),url:t.config?.url}}const qt=3,Jt=1e3;function Kt(t){return!t||t>=500||t===429}function Xt(t){return new Promise(r=>setTimeout(r,t))}function tt(t={}){const r=t.name||et,a=t.retries??qt,i=t.retryDelay??Jt,o={log:(...n)=>se.log(`[API:${r}]`,...n),warn:(...n)=>se.warn(`[API:${r}]`,...n),error:(...n)=>se.error(`[API:${r}]`,...n),info:(...n)=>se.info(`[API:${r}]`,...n)},p=Ut.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return p.interceptors.request.use(n=>{const h=Xe();if(h?.isAuthenticated){const f=h.user?.access_token||h.user?.profile?.access_token;f&&n.headers?(n.headers.Authorization=`Bearer ${f}`,o.info("Auth token attached")):o.warn("User is authenticated but no token found")}else o.info("User not authenticated - request without token");return o.log(`${n.method?.toUpperCase()} ${n.url}`),n},n=>(o.error("Request interceptor error:",n.message),Promise.reject(n))),p.interceptors.response.use(n=>(o.log(`Response ${n.status}:`,n.config.url),n),async n=>{const h=n.response?.status,f=n.config?.url,E=n.config?._retryCount??0;if(Kt(h)&&E<a){const l=n.config;l._retryCount=E+1;const m=i*Math.pow(2,E);return o.warn(`Retrying (${l._retryCount}/${a}) after ${m}ms:`,f),await Xt(m),p.request(l)}return h===401?(o.warn("401 Unauthorized - triggering re-auth"),Ze()):h===403?o.warn("403 Forbidden - insufficient permissions"):h===404?o.warn("404 Not found:",f):h===429?o.warn("429 Rate limited"):h===500?o.error("500 Server error:",f):n.response?o.warn(`Error ${h}:`,n.message):o.error("Network error - backend may be unavailable:",f),Promise.reject(Yt(n))}),p}const U=tt();async function Zt(t,r,a=U){const i=await a.get(t,{params:r});return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function Qt(t,r,a=U){const i=await a.post(t,r);return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function er(t,r,a=U){const i=await a.put(t,r);return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function tr(t,r=U){const a=await r.delete(t);return{data:a.data,status:a.status,ok:a.status>=200&&a.status<300}}function rt(t){if(typeof window>"u")return;const r=window.__MF_NAME__||"unknown",a={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}function Ye(t,r){const a={network:{title:"Нет подключения",message:"Сервер недоступен. Проверьте подключение к интернету."},unauthorized:{title:"Требуется вход",message:"Ваша сессия истекла. Войдите в систему снова."},forbidden:{title:"Доступ запрещён",message:"У вас нет прав для выполнения этого действия."},not_found:{title:"Не найдено",message:"Запрошенный ресурс не найден."},server:{title:"Ошибка сервера",message:"Произошла ошибка на сервере. Попробуйте позже."},client:{title:"Ошибка",message:t.message||"Произошла ошибка при выполнении запроса."},unknown:{title:"Неизвестная ошибка",message:t.message||"Произошла неизвестная ошибка."}},i=a[t.type]||a.unknown;rt({type:t.type==="network"?"warning":"error",title:i.title,message:r?`${i.message} (${r})`:i.message})}function rr(t){return t instanceof Error&&t.name==="AbortError"}function X(t,r={}){const{notifyOnError:a=!0,notifyOnSuccess:i=!1,successMessage:o,errorContext:p,onSuccess:n,onError:h}=r,[f,E]=c.useState(null),[l,m]=c.useState(null),[d,w]=c.useState(!1),y=c.useRef(null),I=l!==null,k=f!==null&&!d&&!I;c.useEffect(()=>()=>{y.current&&y.current.abort()},[]);const S=c.useCallback(()=>{y.current&&(y.current.abort(),y.current=null,w(!1))},[]),v=c.useCallback(async()=>{y.current&&y.current.abort(),y.current=new AbortController;const N=y.current.signal;w(!0),m(null);try{const j=await t(N);if(N.aborted)return null;if(j.ok)return E(j.data),i&&o&&rt({type:"success",title:"Успешно",message:o}),n?.(j.data),j.data;{const $={message:j.data||"Request failed",status:j.status,type:"client",timestamp:Date.now()};return m($),a&&Ye($,p),h?.($),null}}catch(j){if(rr(j))return null;const $=j;return m($),a&&Ye($,p),h?.($),null}finally{N.aborted||w(!1),y.current=null}},[t,a,i,o,p,n,h]),T=c.useCallback(()=>{E(null),m(null),w(!1)},[]);return{data:f,error:l,isLoading:d,isError:I,isSuccess:k,execute:v,reset:T,abort:S}}function nr(t,r={}){const{skip:a=!1,headers:i,immediate:o=!0,...p}=r,n=c.useMemo(()=>f=>{const E=i?i():{};return U.get(t,{headers:{"Content-Type":"application/json",...E},signal:f}).then(l=>({data:l.data,status:l.status,ok:l.status>=200&&l.status<300}))},[t,i]),h=X(n,{...p});return c.useEffect(()=>{o&&!a&&h.execute()},[o,a,t]),h}function sr(t,r,a={}){return X(o=>U.post(t,r,{signal:o}).then(p=>({data:p.data,status:p.status,ok:p.status>=200&&p.status<300})),a)}function ar(t,r,a={}){return X(o=>U.put(t,r,{signal:o}).then(p=>({data:p.data,status:p.status,ok:p.status>=200&&p.status<300})),a)}function or(t,r={}){return X(i=>U.delete(t,{signal:i}).then(o=>({data:o.data,status:o.status,ok:o.status>=200&&o.status<300})),r)}const ir={canView:["all"],canEdit:["ibdop-user","ibdop-admin","ibdop-devops"],canDelete:["ibdop-admin","ibdop-devops"],canAdmin:["ibdop-admin"],canViewSensitiveData:["ibdop-admin","ibdop-devops"],canExportData:["ibdop-user"],canManageUsers:["ibdop-admin"]};function ur(t={}){const r=K(),a=c.useMemo(()=>({...ir,...t}),[t]),i=c.useMemo(()=>{const p=r.user?.profile?.realm_roles||r.user?.profile?.roles||[];return Array.isArray(p)?p:[p]},[r.user]),o=p=>p.includes("all")?!0:p.some(n=>i.includes(n));return{canView:o(a.canView),canEdit:o(a.canEdit),canDelete:o(a.canDelete),canAdmin:o(a.canAdmin),canViewSensitiveData:o(a.canViewSensitiveData),canExportData:o(a.canExportData),canManageUsers:o(a.canManageUsers)}}function cr(){const t=K(),[r,a]=c.useState([]),[i,o]=c.useState(0),[p,n]=c.useState([]),[h,f]=c.useState(!0),[E,l]=c.useState(null),m=c.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatures] Not authenticated"),f(!1);return}f(!0),l(null);try{const y={"Content-Type":"application/json"},I=t.user?.access_token;I&&(y.Authorization=`Bearer ${I}`);const k=await fetch("/api/features",{headers:y});if(!k.ok)throw new Error(`HTTP ${k.status}: ${k.statusText}`);const S=await k.json();a(S.features||[]),o(S.totalCount||0),n(S.userRoles||[])}catch(y){console.debug("Features fetch error:",y),l(y instanceof Error?y.message:String(y)),a([]),n([])}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]);c.useEffect(()=>{m()},[m]);const d=c.useCallback(y=>r.find(k=>k.name===y)?.userEnabled??!1,[r]),w=c.useCallback(y=>r.filter(I=>I.mfDependencies?.includes(y)),[r]);return{features:r,totalCount:i,userRoles:p,isLoading:h,error:E,refetch:m,isFeatureEnabled:d,getFeaturesByMf:w}}function lr(){const t=K(),[r,a]=c.useState([]),[i,o]=c.useState([]),[p,n]=c.useState(!1),[h,f]=c.useState(!0),[E,l]=c.useState(null),m=c.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatureAdmin] Not authenticated"),f(!1);return}f(!0),l(null);try{const k={"Content-Type":"application/json"},S=t.user?.access_token;S&&(k.Authorization=`Bearer ${S}`);const v=await fetch("/api/features/admin",{headers:k});if(!v.ok){if(v.status===403){console.warn("[useFeatureAdmin] 403 Forbidden - checking if token has admin role"),n(!1),a([]),o([]),f(!1);return}throw new Error(`HTTP ${v.status}: ${v.statusText}`)}const T=await v.json();a(T.featureToggles||[]),o(T.microfrontends||[]),n(T.isAdmin||!1)}catch(k){console.debug("FeatureAdmin fetch error:",k),a([]),o([]),n(!1)}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]),d=c.useCallback(async k=>{try{const S={"Content-Type":"application/json"},v=t.user?.access_token;v&&(S.Authorization=`Bearer ${v}`);const T=await fetch("/api/features/admin",{method:"POST",headers:S,body:JSON.stringify(k)});if(!T.ok){const N=await T.json().catch(()=>({}));throw new Error(N.error||`HTTP ${T.status}`)}return await m(),!0}catch(S){return l(S instanceof Error?S.message:String(S)),!1}},[m]),w=c.useCallback(async(k,S)=>{try{const v={"Content-Type":"application/json"},T=t.user?.access_token;T&&(v.Authorization=`Bearer ${T}`);const N=await fetch(`/api/features/admin/${encodeURIComponent(k)}`,{method:"PUT",headers:v,body:JSON.stringify(S)});if(!N.ok){const j=await N.json().catch(()=>({}));throw new Error(j.error||`HTTP ${N.status}`)}return await m(),!0}catch(v){return l(v instanceof Error?v.message:String(v)),!1}},[m]),y=c.useCallback(async(k,S)=>{try{const v={},T=t.user?.access_token;T&&(v.Authorization=`Bearer ${T}`);const N=await fetch(`/api/features/admin/${encodeURIComponent(k)}/toggle?enabled=${S}`,{method:"POST",headers:v});if(!N.ok){const j=await N.json().catch(()=>({}));throw new Error(j.error||`HTTP ${N.status}`)}return await m(),!0}catch(v){return l(v instanceof Error?v.message:String(v)),!1}},[m]),I=c.useCallback(async k=>{try{const S={},v=t.user?.access_token;v&&(S.Authorization=`Bearer ${v}`);const T=await fetch(`/api/features/admin/${encodeURIComponent(k)}`,{method:"DELETE",headers:S});if(!T.ok){const N=await T.json().catch(()=>({}));throw new Error(N.error||`HTTP ${T.status}`)}return await m(),!0}catch(S){return l(S instanceof Error?S.message:String(S)),!1}},[m]);return c.useEffect(()=>{m()},[m]),{features:r,microfrontends:i,isAdmin:p,isLoading:h,error:E,refetch:m,createFeature:d,updateFeature:w,toggleFeature:y,deleteFeature:I}}function fr(){const t=K(),[r,a]=c.useState([]),[i,o]=c.useState(0),[p,n]=c.useState(!0),[h,f]=c.useState(null),E=c.useCallback(async()=>{if(!t.isAuthenticated){n(!1);return}n(!0),f(null);try{const l={"Content-Type":"application/json"},m=t.user?.access_token;m&&(l.Authorization=`Bearer ${m}`);const d=await fetch("/api/features/microfrontends",{headers:l});if(!d.ok)throw new Error(`HTTP ${d.status}: ${d.statusText}`);const w=await d.json();a(w.microfrontends||[]),o(w.totalCount||0)}catch(l){f(l instanceof Error?l.message:String(l))}finally{n(!1)}},[t.isAuthenticated,t.user?.access_token]);return c.useEffect(()=>{E()},[E]),{microfrontends:r,totalCount:i,isLoading:p,error:h,refetch:E}}var ae={exports:{}},q={};var qe;function dr(){if(qe)return q;qe=1;var t=c,r=Symbol.for("react.element"),a=Symbol.for("react.fragment"),i=Object.prototype.hasOwnProperty,o=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function n(h,f,E){var l,m={},d=null,w=null;E!==void 0&&(d=""+E),f.key!==void 0&&(d=""+f.key),f.ref!==void 0&&(w=f.ref);for(l in f)i.call(f,l)&&!p.hasOwnProperty(l)&&(m[l]=f[l]);if(h&&h.defaultProps)for(l in f=h.defaultProps,f)m[l]===void 0&&(m[l]=f[l]);return{$$typeof:r,type:h,key:d,ref:w,props:m,_owner:o.current}}return q.Fragment=a,q.jsx=n,q.jsxs=n,q}var J={};var Je;function pr(){return Je||(Je=1,process.env.NODE_ENV!=="production"&&(function(){var t=c,r=Symbol.for("react.element"),a=Symbol.for("react.portal"),i=Symbol.for("react.fragment"),o=Symbol.for("react.strict_mode"),p=Symbol.for("react.profiler"),n=Symbol.for("react.provider"),h=Symbol.for("react.context"),f=Symbol.for("react.forward_ref"),E=Symbol.for("react.suspense"),l=Symbol.for("react.suspense_list"),m=Symbol.for("react.memo"),d=Symbol.for("react.lazy"),w=Symbol.for("react.offscreen"),y=Symbol.iterator,I="@@iterator";function k(e){if(e===null||typeof e!="object")return null;var s=y&&e[y]||e[I];return typeof s=="function"?s:null}var S=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function v(e){{for(var s=arguments.length,u=new Array(s>1?s-1:0),g=1;g<s;g++)u[g-1]=arguments[g];T("error",e,u)}}function T(e,s,u){{var g=S.ReactDebugCurrentFrame,C=g.getStackAddendum();C!==""&&(s+="%s",u=u.concat([C]));var A=u.map(function(x){return String(x)});A.unshift("Warning: "+s),Function.prototype.apply.call(console[e],console,A)}}var N=!1,j=!1,$=!1,ct=!1,lt=!1,we;we=Symbol.for("react.module.reference");function ft(e){return!!(typeof e=="string"||typeof e=="function"||e===i||e===p||lt||e===o||e===E||e===l||ct||e===w||N||j||$||typeof e=="object"&&e!==null&&(e.$$typeof===d||e.$$typeof===m||e.$$typeof===n||e.$$typeof===h||e.$$typeof===f||e.$$typeof===we||e.getModuleId!==void 0))}function dt(e,s,u){var g=e.displayName;if(g)return g;var C=s.displayName||s.name||"";return C!==""?u+"("+C+")":u}function be(e){return e.displayName||"Context"}function V(e){if(e==null)return null;if(typeof e.tag=="number"&&v("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case i:return"Fragment";case a:return"Portal";case p:return"Profiler";case o:return"StrictMode";case E:return"Suspense";case l:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case h:var s=e;return be(s)+".Consumer";case n:var u=e;return be(u._context)+".Provider";case f:return dt(e,e.render,"ForwardRef");case m:var g=e.displayName||null;return g!==null?g:V(e.type)||"Memo";case d:{var C=e,A=C._payload,x=C._init;try{return V(x(A))}catch{return null}}}return null}var B=Object.assign,G=0,xe,Se,Ce,Ae,ke,Te,Re;function Me(){}Me.__reactDisabledLog=!0;function pt(){{if(G===0){xe=console.log,Se=console.info,Ce=console.warn,Ae=console.error,ke=console.group,Te=console.groupCollapsed,Re=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Me,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}G++}}function ht(){{if(G--,G===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:B({},e,{value:xe}),info:B({},e,{value:Se}),warn:B({},e,{value:Ce}),error:B({},e,{value:Ae}),group:B({},e,{value:ke}),groupCollapsed:B({},e,{value:Te}),groupEnd:B({},e,{value:Re})})}G<0&&v("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var ie=S.ReactCurrentDispatcher,ue;function Q(e,s,u){{if(ue===void 0)try{throw Error()}catch(C){var g=C.stack.trim().match(/\n( *(at )?)/);ue=g&&g[1]||""}return`
|
|
2
|
+
`+ue+e}}var ce=!1,ee;{var gt=typeof WeakMap=="function"?WeakMap:Map;ee=new gt}function Ie(e,s){if(!e||ce)return"";{var u=ee.get(e);if(u!==void 0)return u}var g;ce=!0;var C=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var A;A=ie.current,ie.current=null,pt();try{if(s){var x=function(){throw Error()};if(Object.defineProperty(x.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(x,[])}catch(O){g=O}Reflect.construct(e,[],x)}else{try{x.call()}catch(O){g=O}e.call(x.prototype)}}else{try{throw Error()}catch(O){g=O}e()}}catch(O){if(O&&g&&typeof O.stack=="string"){for(var b=O.stack.split(`
|
|
3
|
+
`),P=g.stack.split(`
|
|
4
|
+
`),R=b.length-1,M=P.length-1;R>=1&&M>=0&&b[R]!==P[M];)M--;for(;R>=1&&M>=0;R--,M--)if(b[R]!==P[M]){if(R!==1||M!==1)do if(R--,M--,M<0||b[R]!==P[M]){var F=`
|
|
5
|
+
`+b[R].replace(" at new "," at ");return e.displayName&&F.includes("<anonymous>")&&(F=F.replace("<anonymous>",e.displayName)),typeof e=="function"&&ee.set(e,F),F}while(R>=1&&M>=0);break}}}finally{ce=!1,ie.current=A,ht(),Error.prepareStackTrace=C}var H=e?e.displayName||e.name:"",W=H?Q(H):"";return typeof e=="function"&&ee.set(e,W),W}function mt(e,s,u){return Ie(e,!1)}function _t(e){var s=e.prototype;return!!(s&&s.isReactComponent)}function te(e,s,u){if(e==null)return"";if(typeof e=="function")return Ie(e,_t(e));if(typeof e=="string")return Q(e);switch(e){case E:return Q("Suspense");case l:return Q("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case f:return mt(e.render);case m:return te(e.type,s,u);case d:{var g=e,C=g._payload,A=g._init;try{return te(A(C),s,u)}catch{}}}return""}var Y=Object.prototype.hasOwnProperty,Ne={},je=S.ReactDebugCurrentFrame;function re(e){if(e){var s=e._owner,u=te(e.type,e._source,s?s.type:null);je.setExtraStackFrame(u)}else je.setExtraStackFrame(null)}function vt(e,s,u,g,C){{var A=Function.call.bind(Y);for(var x in e)if(A(e,x)){var b=void 0;try{if(typeof e[x]!="function"){var P=Error((g||"React class")+": "+u+" type `"+x+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[x]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw P.name="Invariant Violation",P}b=e[x](s,x,g,u,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(R){b=R}b&&!(b instanceof Error)&&(re(C),v("%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).",g||"React class",u,x,typeof b),re(null)),b instanceof Error&&!(b.message in Ne)&&(Ne[b.message]=!0,re(C),v("Failed %s type: %s",u,b.message),re(null))}}}var Et=Array.isArray;function le(e){return Et(e)}function yt(e){{var s=typeof Symbol=="function"&&Symbol.toStringTag,u=s&&e[Symbol.toStringTag]||e.constructor.name||"Object";return u}}function wt(e){try{return Pe(e),!1}catch{return!0}}function Pe(e){return""+e}function Oe(e){if(wt(e))return v("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",yt(e)),Pe(e)}var Fe=S.ReactCurrentOwner,bt={key:!0,ref:!0,__self:!0,__source:!0},De,$e;function xt(e){if(Y.call(e,"ref")){var s=Object.getOwnPropertyDescriptor(e,"ref").get;if(s&&s.isReactWarning)return!1}return e.ref!==void 0}function St(e){if(Y.call(e,"key")){var s=Object.getOwnPropertyDescriptor(e,"key").get;if(s&&s.isReactWarning)return!1}return e.key!==void 0}function Ct(e,s){typeof e.ref=="string"&&Fe.current}function At(e,s){{var u=function(){De||(De=!0,v("%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)",s))};u.isReactWarning=!0,Object.defineProperty(e,"key",{get:u,configurable:!0})}}function kt(e,s){{var u=function(){$e||($e=!0,v("%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)",s))};u.isReactWarning=!0,Object.defineProperty(e,"ref",{get:u,configurable:!0})}}var Tt=function(e,s,u,g,C,A,x){var b={$$typeof:r,type:e,key:s,ref:u,props:x,_owner:A};return b._store={},Object.defineProperty(b._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(b,"_self",{configurable:!1,enumerable:!1,writable:!1,value:g}),Object.defineProperty(b,"_source",{configurable:!1,enumerable:!1,writable:!1,value:C}),Object.freeze&&(Object.freeze(b.props),Object.freeze(b)),b};function Rt(e,s,u,g,C){{var A,x={},b=null,P=null;u!==void 0&&(Oe(u),b=""+u),St(s)&&(Oe(s.key),b=""+s.key),xt(s)&&(P=s.ref,Ct(s,C));for(A in s)Y.call(s,A)&&!bt.hasOwnProperty(A)&&(x[A]=s[A]);if(e&&e.defaultProps){var R=e.defaultProps;for(A in R)x[A]===void 0&&(x[A]=R[A])}if(b||P){var M=typeof e=="function"?e.displayName||e.name||"Unknown":e;b&&At(x,M),P&&kt(x,M)}return Tt(e,b,P,C,g,Fe.current,x)}}var fe=S.ReactCurrentOwner,Le=S.ReactDebugCurrentFrame;function z(e){if(e){var s=e._owner,u=te(e.type,e._source,s?s.type:null);Le.setExtraStackFrame(u)}else Le.setExtraStackFrame(null)}var de;de=!1;function pe(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function Ue(){{if(fe.current){var e=V(fe.current.type);if(e)return`
|
|
6
6
|
|
|
7
|
-
Check the render method of \``+e+"`."}return""}}function
|
|
7
|
+
Check the render method of \``+e+"`."}return""}}function Mt(e){return""}var Ve={};function It(e){{var s=Ue();if(!s){var u=typeof e=="string"?e:e.displayName||e.name;u&&(s=`
|
|
8
8
|
|
|
9
|
-
Check the top-level render call using <`+
|
|
9
|
+
Check the top-level render call using <`+u+">.")}return s}}function Be(e,s){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var u=It(s);if(Ve[u])return;Ve[u]=!0;var g="";e&&e._owner&&e._owner!==fe.current&&(g=" It was passed a child from "+V(e._owner.type)+"."),z(e),v('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',u,g),z(null)}}function We(e,s){{if(typeof e!="object")return;if(le(e))for(var u=0;u<e.length;u++){var g=e[u];pe(g)&&Be(g,s)}else if(pe(e))e._store&&(e._store.validated=!0);else if(e){var C=k(e);if(typeof C=="function"&&C!==e.entries)for(var A=C.call(e),x;!(x=A.next()).done;)pe(x.value)&&Be(x.value,s)}}}function Nt(e){{var s=e.type;if(s==null||typeof s=="string")return;var u;if(typeof s=="function")u=s.propTypes;else if(typeof s=="object"&&(s.$$typeof===f||s.$$typeof===m))u=s.propTypes;else return;if(u){var g=V(s);vt(u,e.props,"prop",g,e)}else if(s.PropTypes!==void 0&&!de){de=!0;var C=V(s);v("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",C||"Unknown")}typeof s.getDefaultProps=="function"&&!s.getDefaultProps.isReactClassApproved&&v("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function jt(e){{for(var s=Object.keys(e.props),u=0;u<s.length;u++){var g=s[u];if(g!=="children"&&g!=="key"){z(e),v("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",g),z(null);break}}e.ref!==null&&(z(e),v("Invalid attribute `ref` supplied to `React.Fragment`."),z(null))}}var ze={};function He(e,s,u,g,C,A){{var x=ft(e);if(!x){var b="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(b+=" You likely forgot to export your component from the file it's defined in, or you might have mixed up default and named imports.");var P=Mt();P?b+=P:b+=Ue();var R;e===null?R="null":le(e)?R="array":e!==void 0&&e.$$typeof===r?(R="<"+(V(e.type)||"Unknown")+" />",b=" Did you accidentally export a JSX literal instead of a component?"):R=typeof e,v("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",R,b)}var M=Rt(e,s,u,C,A);if(M==null)return M;if(x){var F=s.children;if(F!==void 0)if(g)if(le(F)){for(var H=0;H<F.length;H++)We(F[H],e);Object.freeze&&Object.freeze(F)}else v("React.jsx: Static children should always be an array. You are likely explicitly calling React.jsxs or React.jsxDEV. Use the Babel transform instead.");else We(F,e)}if(Y.call(s,"key")){var W=V(e),O=Object.keys(s).filter(function(Lt){return Lt!=="key"}),he=O.length>0?"{key: someKey, "+O.join(": ..., ")+": ...}":"{key: someKey}";if(!ze[W+he]){var $t=O.length>0?"{"+O.join(": ..., ")+": ...}":"{}";v(`A props object containing a "key" prop is being spread into JSX:
|
|
10
10
|
let props = %s;
|
|
11
11
|
<%s {...props} />
|
|
12
12
|
React keys must be passed directly to JSX without using spread:
|
|
13
13
|
let props = %s;
|
|
14
|
-
<%s key={someKey} {...props} />`,
|
|
14
|
+
<%s key={someKey} {...props} />`,he,W,$t,W),ze[W+he]=!0}}return e===i?jt(M):Nt(M),M}}function Pt(e,s,u){return He(e,s,u,!0)}function Ot(e,s,u){return He(e,s,u,!1)}var Ft=Ot,Dt=Pt;J.Fragment=i,J.jsx=Ft,J.jsxs=Dt})()),J}var Ke;function hr(){return Ke||(Ke=1,process.env.NODE_ENV==="production"?ae.exports=dr():ae.exports=pr()),ae.exports}var _=hr();const nt="platform-kit",gr=!1,me={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${nt}]`,...t)}};class mr extends c.Component{hasDispatched=!1;constructor(r){super(r),this.state={hasError:!1}}getMfeName(){if(this.props.mfeName)return this.props.mfeName;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return nt}shouldShowDetails(){if(this.props.showDetails!==void 0)return this.props.showDetails;if(typeof sessionStorage<"u")try{const r=sessionStorage.getItem("config");if(r){const a=JSON.parse(r);if(a.showErrorDetails!==void 0)return a.showErrorDetails}}catch{}return gr}dispatchError(r,a){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const i=this.getMfeName();me.error("ErrorBoundary caught:",r);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:i,error:r.message||String(r),stack:r.stack,componentStack:a?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(o){me.error("Failed to dispatch mfe-error event:",o)}}static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,a){this.dispatchError(r,a),me.error("Error info:",a.componentStack)}handleCopy=()=>{const r=`Error in ${this.getMfeName()}:
|
|
15
15
|
${this.state.error?.message}
|
|
16
|
-
${this.state.error?.stack}`;typeof navigator<"u"&&navigator.clipboard&&navigator.clipboard.writeText(r).then(()=>{alert("Ошибка скопирована в буфер обмена")}).catch(()=>{prompt("Скопируйте ошибку:",r)})};handleRetry=()=>{this.setState({hasError:!1,error:void 0}),this.hasDispatched=!1,typeof window<"u"&&window.location.reload()};handleGoHome=()=>{typeof window<"u"&&(window.location.href="/")};render(){if(this.state.hasError){const r=this.state.error?.message||"Unknown error",
|
|
16
|
+
${this.state.error?.stack}`;typeof navigator<"u"&&navigator.clipboard&&navigator.clipboard.writeText(r).then(()=>{alert("Ошибка скопирована в буфер обмена")}).catch(()=>{prompt("Скопируйте ошибку:",r)})};handleRetry=()=>{this.setState({hasError:!1,error:void 0}),this.hasDispatched=!1,typeof window<"u"&&window.location.reload()};handleGoHome=()=>{typeof window<"u"&&(window.location.href="/")};render(){if(this.state.hasError){const r=this.state.error?.message||"Unknown error",a=this.state.error?.stack||"",i=this.shouldShowDetails(),o=this.getMfeName();return _.jsxs("div",{style:{padding:"20px",textAlign:"center",color:"#d32f2f",fontFamily:"monospace",background:"#ffebee",border:"1px solid #ef5350",borderRadius:"4px",margin:"10px"},children:[_.jsxs("h2",{style:{fontSize:"16px",margin:"0 0 8px 0"},children:["⚠️ Ошибка в ",o]}),_.jsx("p",{style:{fontSize:"12px",margin:0},children:"Произошла ошибка в микрофронтенде. Сообщение отправлено в shell."}),i&&_.jsxs("details",{style:{whiteSpace:"pre-wrap",textAlign:"left",marginTop:"10px",background:"#fff",padding:"8px",borderRadius:"4px"},children:[_.jsx("summary",{style:{cursor:"pointer",fontWeight:"bold"},children:"Детали ошибки"}),_.jsxs("pre",{style:{fontSize:"11px",overflow:"auto",maxHeight:"150px",margin:"8px 0 0 0",padding:"8px",background:"#f5f5f5",borderRadius:"4px"},children:[r,a&&`
|
|
17
17
|
|
|
18
|
-
${o}`]})]}),m.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[m.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),m.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),m.jsx("button",{onClick:this.handleGoHome,style:{padding:"8px 12px",background:"#1976d2",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🏠 На главную"})]})]})}return this.props.children==null?null:this.props.children}}const D={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function sr({mfeName:t}){const{data:r,isLoading:o,error:u}=Ze({mfeName:t}),[l,g]=i.useState(!1);if(o)return m.jsxs("span",{className:"text-muted small me-2",children:[m.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(u||!r)return m.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${u||"нет данных"}`,children:[m.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const n=r,_=n.BUILD_VERSION||n.IMAGE_VERSION||n.APP_NAME||"N/A",f=[];return n.APP_NAME&&f.push({key:"APP_NAME",value:n.APP_NAME,label:"Приложение",icon:D.apps}),n.BUILD_VERSION&&f.push({key:"BUILD_VERSION",value:n.BUILD_VERSION,label:"Версия",icon:D.tags}),n.IMAGE_VERSION&&f.push({key:"IMAGE_VERSION",value:n.IMAGE_VERSION,label:"Образ",icon:D.storage}),n.GIT_COMMIT&&f.push({key:"GIT_COMMIT",value:n.GIT_COMMIT,label:"Commit",icon:D.spreadsheet}),n.GIT_BRANCH&&f.push({key:"GIT_BRANCH",value:n.GIT_BRANCH,label:"Ветка",icon:D.spreadsheet}),n.CI_COMMIT_AUTHOR&&f.push({key:"CI_COMMIT_AUTHOR",value:n.CI_COMMIT_AUTHOR,label:"Автор",icon:D.user}),n.CI_COMMIT_TIMESTAMP&&f.push({key:"CI_COMMIT_TIMESTAMP",value:n.CI_COMMIT_TIMESTAMP,label:"Дата",icon:D.clock}),n.CI_JOB_URL&&f.push({key:"CI_JOB_URL",value:n.CI_JOB_URL,label:"CI Job",icon:D.link}),n.CI_PIPELINE_URL&&f.push({key:"CI_PIPELINE_URL",value:n.CI_PIPELINE_URL,label:"Pipeline",icon:D.link}),n.CI_COMMIT_MESSAGE&&(n.CI_COMMIT_MESSAGE.length>60?n.CI_COMMIT_MESSAGE.substring(0,57)+"":n.CI_COMMIT_MESSAGE,f.push({key:"CI_COMMIT_MESSAGE",value:n.CI_COMMIT_MESSAGE,label:"Сообщение",icon:D.code})),m.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[m.jsxs("button",{onClick:()=>g(!l),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[m.jsx("span",{className:"me-1",children:D.info}),m.jsx("span",{className:"text-dark",children:_})]}),l&&m.jsxs("div",{style:{position:"absolute",top:"100%",right:0,zIndex:1e3,minWidth:"300px",background:"white",border:"1px solid #dee2e6",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",padding:"16px",marginTop:"4px"},children:[m.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[m.jsx("span",{className:"me-2",children:D.apps}),m.jsx("strong",{children:n.APP_NAME||t})]}),m.jsxs("div",{style:{marginBottom:"12px"},children:[m.jsx("span",{className:"text-muted",children:"Версия: "}),m.jsx("strong",{children:_})]}),f.length>0&&m.jsx("div",{style:{fontSize:"13px"},children:f.map(({key:y,value:d,label:h,icon:c})=>{const w=d.length>40&&(y.includes("URL")||y.includes("MESSAGE"))?`${d.substring(0,37)}...`:d;return m.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[m.jsx("span",{className:"me-2",style:{flexShrink:0},children:c}),m.jsxs("div",{style:{flex:1,minWidth:0},children:[m.jsx("div",{className:"small text-muted",children:h}),m.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:d,children:y.includes("URL")?m.jsx("a",{href:d,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:w}):w})]})]},y)})}),f.length===0&&m.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),m.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),m.jsx("button",{onClick:()=>g(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),l&&m.jsx("div",{onClick:()=>g(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const me="platform-kit",tt=i.createContext(null);function or({children:t}){const[r,o]=i.useState([]),u=typeof window<"u"&&window.__MF_NAME__||me,l=i.useCallback((c,w,E,I)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:c,title:w,message:E,mfeName:u,timestamp:Date.now(),duration:I}),[u]),g=i.useCallback(c=>{o(E=>[...E,c].slice(0,5));const w=c.duration||5e3;w>0&&setTimeout(()=>{o(E=>E.filter(I=>I.id!==c.id))},w)},[]),n=i.useCallback(c=>{const w=l(c.type,c.title,c.message,c.duration);g(w),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:w,bubbles:!0}))},[l,g]),_=i.useCallback((c,w="Успешно")=>{n({type:"success",title:w,message:c})},[n]),f=i.useCallback((c,w="Ошибка")=>{n({type:"error",title:w,message:c})},[n]),y=i.useCallback((c,w="Предупреждение")=>{n({type:"warning",title:w,message:c})},[n]),d=i.useCallback((c,w="Информация")=>{n({type:"info",title:w,message:c})},[n]),h=i.useCallback(c=>{o(w=>w.filter(E=>E.id!==c))},[]);return i.useEffect(()=>{if(typeof window>"u")return;const c=w=>{const E=w.detail;if(E&&E.type&&E.title&&E.message){const I={...E,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};g(I)}};return window.addEventListener("mfe-notification",c),()=>{window.removeEventListener("mfe-notification",c)}},[g]),m.jsxs(tt.Provider,{value:{notify:n,notifySuccess:_,notifyError:f,notifyWarning:y,notifyInfo:d,removeNotification:h},children:[t,r.length>0&&m.jsx("div",{style:{position:"fixed",top:"80px",right:"20px",zIndex:9998,maxWidth:"400px",width:"100%",display:"flex",flexDirection:"column",gap:"8px",pointerEvents:"none"},children:r.map(c=>m.jsxs("div",{className:`notification notification-${c.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:c.type==="success"?"#d4edda":c.type==="error"?"#f8d7da":c.type==="warning"?"#fff3cd":"#d1ecf1",color:c.type==="success"?"#155724":c.type==="error"?"#721c24":c.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[m.jsxs("div",{style:{flex:1},children:[m.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:c.title}),m.jsx("p",{style:{margin:0,fontSize:"14px"},children:c.message}),m.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:c.mfeName})]}),m.jsx("button",{onClick:()=>h(c.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},c.id))})]})}function ar(){const t=i.useContext(tt);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function ir(t){if(typeof window>"u")return;const r=window.__MF_NAME__||me,o={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:o,bubbles:!0}))}const rt="platform-kit",se={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${rt}]`,...t)},info:(...t)=>{}};function ur(t){const r=t.response;let o="unknown";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",{message:r?.data?.message??t.message??"Unknown error",code:r?.data?.code,status:r?.status,type:o,timestamp:Date.now(),url:t.config?.url}}const cr=3,lr=1e3;function fr(t){return!t||t>=500||t===429}function dr(t){return new Promise(r=>setTimeout(r,t))}function nt(t={}){const r=t.name||rt,o=t.retries??cr,u=t.retryDelay??lr,l={log:(...n)=>se.log(`[API:${r}]`,...n),warn:(...n)=>se.warn(`[API:${r}]`,...n),error:(...n)=>se.error(`[API:${r}]`,...n),info:(...n)=>se.info(`[API:${r}]`,...n)},g=Lt.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return g.interceptors.request.use(n=>{const _=Ke();if(_?.isAuthenticated){const f=_.user?.profile?.access_token;f&&n.headers&&(n.headers.Authorization=`Bearer ${f}`,l.info("Auth token attached"))}else l.info("User not authenticated - request without token");return l.log(`${n.method?.toUpperCase()} ${n.url}`),n},n=>(l.error("Request interceptor error:",n.message),Promise.reject(n))),g.interceptors.response.use(n=>(l.log(`Response ${n.status}:`,n.config.url),n),async n=>{const _=n.response?.status,f=n.config?.url,y=n.config?._retryCount??0;if(fr(_)&&y<o){const d=n.config;d._retryCount=y+1;const h=u*Math.pow(2,y);return l.warn(`Retrying (${d._retryCount}/${o}) after ${h}ms:`,f),await dr(h),g.request(d)}return _===401?(l.warn("401 Unauthorized - triggering re-auth"),Xe()):_===403?l.warn("403 Forbidden - insufficient permissions"):_===404?l.warn("404 Not found:",f):_===429?l.warn("429 Rate limited"):_===500?l.error("500 Server error:",f):n.response?l.warn(`Error ${_}:`,n.message):l.error("Network error - backend may be unavailable:",f),Promise.reject(ur(n))}),g}const K=nt();async function pr(t,r,o=K){const u=await o.get(t,{params:r});return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function gr(t,r,o=K){const u=await o.post(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function hr(t,r,o=K){const u=await o.put(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function mr(t,r=K){const o=await r.delete(t);return{data:o.data,status:o.status,ok:o.status>=200&&o.status<300}}function X(t,r){const o=r?.prefix?`[${r.prefix}]`:`[${t}]`;return{log:(...u)=>{},warn:(...u)=>{},error:(...u)=>{console.error(o,...u)},info:(...u)=>{}}}const _r=X("platform-kit",{prefix:"AUTH"}),vr=X("platform-kit",{prefix:"API"}),Er=X("platform-kit",{prefix:"ERROR"}),yr=X("platform-kit",{prefix:"INFO"}),wr={},br={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function ve(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function st(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function ot(){if(typeof window>"u")return null;try{const t=sessionStorage.getItem("mf-config");if(t){const r=JSON.parse(t);if(r.mfeName)return r.mfeName;if(r.name)return r.name;if(r.appName)return r.appName}}catch{}return null}function Ee(){const t=wr;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let oe=null,_e=!1;function at(t,r){const o=ve(t);if(o)return o;if(_e&&oe)return oe;const u=[{source:"window.__MF_NAME__",value:st()},{source:"sessionStorage.mf-config",value:ot()},{source:"import.meta.env.VITE_MFE_NAME",value:Ee()}];for(const{source:g,value:n}of u)if(n)return oe=n,_e=!0,n;if(r)return r;const l="Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw br.error(l),new Error(l)}function xr(t){return at(t)}function it(t){return ve(t)?"props.mfeName":st()?"window.__MF_NAME__":ot()?"sessionStorage.mf-config":Ee()?"import.meta.env.VITE_MFE_NAME":null}function Sr(t){return it(t)!==null}function Cr(){oe=null,_e=!1}function Ar(t){const r=[];return ve(t)&&r.push("props.mfeName"),typeof window<"u"&&(window.__MF_NAME__&&r.push("window.__MF_NAME__"),sessionStorage.getItem("mf-config")&&r.push("sessionStorage.mf-config")),Ee()&&r.push("import.meta.env.VITE_MFE_NAME"),r}exports.ErrorBoundary=nr;exports.NotificationProvider=or;exports.VersionInfo=sr;exports.api=K;exports.apiLogger=vr;exports.authLogger=_r;exports.createApiClient=nt;exports.createMfLogger=X;exports.del=mr;exports.dispatchNotification=ir;exports.errorLogger=Er;exports.get=pr;exports.getAccessToken=Ut;exports.getAllMfeNameSources=Ar;exports.getAuthState=Ke;exports.getMfeName=at;exports.getMfeNameSource=it;exports.getShellAuth=L;exports.hasMfeName=Sr;exports.infoLogger=yr;exports.isAuthenticated=Vt;exports.logout=Bt;exports.post=gr;exports.put=hr;exports.redirectToLogin=Xe;exports.requireMfeName=xr;exports.resetMfeNameCache=Cr;exports.useApi=Yt;exports.useFeatureAdmin=Xt;exports.useFeatures=Kt;exports.useInfoData=Ze;exports.useMicrofrontendsFeatures=Zt;exports.useNotification=ar;exports.usePermissions=qt;exports.useShellAuth=q;exports.useV1Config=Ht;
|
|
18
|
+
${a}`]})]}),_.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[_.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),_.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),_.jsx("button",{onClick:this.handleGoHome,style:{padding:"8px 12px",background:"#1976d2",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🏠 На главную"})]})]})}return this.props.children==null?null:this.props.children}}const D={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function _r({mfeName:t}){const{data:r,isLoading:a,error:i}=Qe({mfeName:t}),[o,p]=c.useState(!1);if(a)return _.jsxs("span",{className:"text-muted small me-2",children:[_.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(i||!r)return _.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${i||"нет данных"}`,children:[_.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const n=r,h=n.BUILD_VERSION||n.IMAGE_VERSION||n.APP_NAME||"N/A",f=[];return n.APP_NAME&&f.push({key:"APP_NAME",value:n.APP_NAME,label:"Приложение",icon:D.apps}),n.BUILD_VERSION&&f.push({key:"BUILD_VERSION",value:n.BUILD_VERSION,label:"Версия",icon:D.tags}),n.IMAGE_VERSION&&f.push({key:"IMAGE_VERSION",value:n.IMAGE_VERSION,label:"Образ",icon:D.storage}),n.GIT_COMMIT&&f.push({key:"GIT_COMMIT",value:n.GIT_COMMIT,label:"Commit",icon:D.spreadsheet}),n.GIT_BRANCH&&f.push({key:"GIT_BRANCH",value:n.GIT_BRANCH,label:"Ветка",icon:D.spreadsheet}),n.CI_COMMIT_AUTHOR&&f.push({key:"CI_COMMIT_AUTHOR",value:n.CI_COMMIT_AUTHOR,label:"Автор",icon:D.user}),n.CI_COMMIT_TIMESTAMP&&f.push({key:"CI_COMMIT_TIMESTAMP",value:n.CI_COMMIT_TIMESTAMP,label:"Дата",icon:D.clock}),n.CI_JOB_URL&&f.push({key:"CI_JOB_URL",value:n.CI_JOB_URL,label:"CI Job",icon:D.link}),n.CI_PIPELINE_URL&&f.push({key:"CI_PIPELINE_URL",value:n.CI_PIPELINE_URL,label:"Pipeline",icon:D.link}),n.CI_COMMIT_MESSAGE&&(n.CI_COMMIT_MESSAGE.length>60?n.CI_COMMIT_MESSAGE.substring(0,57)+"":n.CI_COMMIT_MESSAGE,f.push({key:"CI_COMMIT_MESSAGE",value:n.CI_COMMIT_MESSAGE,label:"Сообщение",icon:D.code})),_.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[_.jsxs("button",{onClick:()=>p(!o),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[_.jsx("span",{className:"me-1",children:D.info}),_.jsx("span",{className:"text-dark",children:h})]}),o&&_.jsxs("div",{style:{position:"absolute",top:"100%",right:0,zIndex:1e3,minWidth:"300px",background:"white",border:"1px solid #dee2e6",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",padding:"16px",marginTop:"4px"},children:[_.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[_.jsx("span",{className:"me-2",children:D.apps}),_.jsx("strong",{children:n.APP_NAME||t})]}),_.jsxs("div",{style:{marginBottom:"12px"},children:[_.jsx("span",{className:"text-muted",children:"Версия: "}),_.jsx("strong",{children:h})]}),f.length>0&&_.jsx("div",{style:{fontSize:"13px"},children:f.map(({key:E,value:l,label:m,icon:d})=>{const w=l.length>40&&(E.includes("URL")||E.includes("MESSAGE"))?`${l.substring(0,37)}...`:l;return _.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[_.jsx("span",{className:"me-2",style:{flexShrink:0},children:d}),_.jsxs("div",{style:{flex:1,minWidth:0},children:[_.jsx("div",{className:"small text-muted",children:m}),_.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:l,children:E.includes("URL")?_.jsx("a",{href:l,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:w}):w})]})]},E)})}),f.length===0&&_.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),_.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),_.jsx("button",{onClick:()=>p(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),o&&_.jsx("div",{onClick:()=>p(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const _e="platform-kit",st=c.createContext(null);function vr({children:t}){const[r,a]=c.useState([]),i=typeof window<"u"&&window.__MF_NAME__||_e,o=c.useCallback((d,w,y,I)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:d,title:w,message:y,mfeName:i,timestamp:Date.now(),duration:I}),[i]),p=c.useCallback(d=>{a(y=>[...y,d].slice(0,5));const w=d.duration||5e3;w>0&&setTimeout(()=>{a(y=>y.filter(I=>I.id!==d.id))},w)},[]),n=c.useCallback(d=>{const w=o(d.type,d.title,d.message,d.duration);p(w),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:w,bubbles:!0}))},[o,p]),h=c.useCallback((d,w="Успешно")=>{n({type:"success",title:w,message:d})},[n]),f=c.useCallback((d,w="Ошибка")=>{n({type:"error",title:w,message:d})},[n]),E=c.useCallback((d,w="Предупреждение")=>{n({type:"warning",title:w,message:d})},[n]),l=c.useCallback((d,w="Информация")=>{n({type:"info",title:w,message:d})},[n]),m=c.useCallback(d=>{a(w=>w.filter(y=>y.id!==d))},[]);return c.useEffect(()=>{if(typeof window>"u")return;const d=w=>{const y=w.detail;if(y&&y.type&&y.title&&y.message){const I={...y,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};p(I)}};return window.addEventListener("mfe-notification",d),()=>{window.removeEventListener("mfe-notification",d)}},[p]),_.jsxs(st.Provider,{value:{notify:n,notifySuccess:h,notifyError:f,notifyWarning:E,notifyInfo:l,removeNotification:m},children:[t,r.length>0&&_.jsx("div",{style:{position:"fixed",top:"80px",right:"20px",zIndex:9998,maxWidth:"400px",width:"100%",display:"flex",flexDirection:"column",gap:"8px",pointerEvents:"none"},children:r.map(d=>_.jsxs("div",{className:`notification notification-${d.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:d.type==="success"?"#d4edda":d.type==="error"?"#f8d7da":d.type==="warning"?"#fff3cd":"#d1ecf1",color:d.type==="success"?"#155724":d.type==="error"?"#721c24":d.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[_.jsxs("div",{style:{flex:1},children:[_.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:d.title}),_.jsx("p",{style:{margin:0,fontSize:"14px"},children:d.message}),_.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:d.mfeName})]}),_.jsx("button",{onClick:()=>m(d.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},d.id))})]})}function Er(){const t=c.useContext(st);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function yr(t){if(typeof window>"u")return;const r=window.__MF_NAME__||_e,a={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}function Z(t,r){const a=r?.prefix?`[${r.prefix}]`:`[${t}]`;return{log:(...i)=>{},warn:(...i)=>{},error:(...i)=>{console.error(a,...i)},info:(...i)=>{}}}const wr=Z("platform-kit",{prefix:"AUTH"}),br=Z("platform-kit",{prefix:"API"}),xr=Z("platform-kit",{prefix:"ERROR"}),Sr=Z("platform-kit",{prefix:"INFO"}),Cr={},Ar={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function Ee(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function at(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function ot(){if(typeof window>"u")return null;try{const t=sessionStorage.getItem("mf-config");if(t){const r=JSON.parse(t);if(r.mfeName)return r.mfeName;if(r.name)return r.name;if(r.appName)return r.appName}}catch{}return null}function ye(){const t=Cr;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let oe=null,ve=!1;function it(t,r){const a=Ee(t);if(a)return a;if(ve&&oe)return oe;const i=[{source:"window.__MF_NAME__",value:at()},{source:"sessionStorage.mf-config",value:ot()},{source:"import.meta.env.VITE_MFE_NAME",value:ye()}];for(const{source:p,value:n}of i)if(n)return oe=n,ve=!0,n;if(r)return r;const o="Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw Ar.error(o),new Error(o)}function kr(t){return it(t)}function ut(t){return Ee(t)?"props.mfeName":at()?"window.__MF_NAME__":ot()?"sessionStorage.mf-config":ye()?"import.meta.env.VITE_MFE_NAME":null}function Tr(t){return ut(t)!==null}function Rr(){oe=null,ve=!1}function Mr(t){const r=[];return Ee(t)&&r.push("props.mfeName"),typeof window<"u"&&(window.__MF_NAME__&&r.push("window.__MF_NAME__"),sessionStorage.getItem("mf-config")&&r.push("sessionStorage.mf-config")),ye()&&r.push("import.meta.env.VITE_MFE_NAME"),r}exports.ErrorBoundary=mr;exports.NotificationProvider=vr;exports.VersionInfo=_r;exports.api=U;exports.apiLogger=br;exports.authLogger=wr;exports.createApiClient=tt;exports.createMfLogger=Z;exports.del=tr;exports.dispatchNotification=yr;exports.errorLogger=xr;exports.get=Zt;exports.getAccessToken=Vt;exports.getAllMfeNameSources=Mr;exports.getAuthState=Xe;exports.getMfeName=it;exports.getMfeNameSource=ut;exports.getShellAuth=L;exports.hasMfeName=Tr;exports.infoLogger=Sr;exports.isAuthenticated=Bt;exports.logout=Wt;exports.post=Qt;exports.put=er;exports.redirectToLogin=Ze;exports.requireMfeName=kr;exports.resetMfeNameCache=Rr;exports.useApi=X;exports.useDel=or;exports.useFeatureAdmin=lr;exports.useFeatures=cr;exports.useGet=nr;exports.useInfoData=Qe;exports.useMicrofrontendsFeatures=fr;exports.useNotification=Er;exports.usePermissions=ur;exports.usePost=sr;exports.usePut=ar;exports.useShellAuth=K;exports.useV1Config=Gt;
|