@ibdop/platform-kit 1.0.10 → 1.0.11

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.
@@ -6,4 +6,5 @@ export { useInfoData } from './useInfoData';
6
6
  export { useV1Config } from './useV1Config';
7
7
  export { useApi } from './useApi';
8
8
  export { usePermissions } from './usePermissions';
9
+ export { useFeatures, useFeatureAdmin, useMicrofrontendsFeatures, } from './useFeatures';
9
10
  //# 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,OAAO,EAAE,MAAM,gBAAgB,CAAA;AAEtD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAEjC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAA;AAEtD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAA;AAE3C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AAEjC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,EACL,WAAW,EACX,eAAe,EACf,yBAAyB,GAC1B,MAAM,eAAe,CAAA"}
@@ -0,0 +1,98 @@
1
+ import { FeatureToggleInfo, FeatureToggleAdmin, FeatureCreateRequest, FeatureUpdateRequest, MicrofrontendWithFeatures } from '../types';
2
+ /**
3
+ * Result of useFeatures hook
4
+ */
5
+ export interface UseFeaturesResult {
6
+ features: FeatureToggleInfo[];
7
+ totalCount: number;
8
+ userRoles: string[];
9
+ isLoading: boolean;
10
+ error: string | null;
11
+ refetch: () => Promise<void>;
12
+ isFeatureEnabled: (featureName: string) => boolean;
13
+ getFeaturesByMf: (mfName: string) => FeatureToggleInfo[];
14
+ }
15
+ /**
16
+ * Hook to get feature toggles for the current user
17
+ *
18
+ * @example
19
+ * ```typescript
20
+ * import { useFeatures } from '@ib-dop/platform-kit'
21
+ *
22
+ * function FeatureFlagComponent() {
23
+ * const { features, isFeatureEnabled, isLoading } = useFeatures()
24
+ *
25
+ * if (isLoading) return <Spinner />
26
+ *
27
+ * return (
28
+ * <div>
29
+ * {isFeatureEnabled('new-dashboard') && <NewDashboard />}
30
+ * {!isFeatureEnabled('new-dashboard') && <OldDashboard />}
31
+ * </div>
32
+ * )
33
+ * }
34
+ * ```
35
+ */
36
+ export declare function useFeatures(): UseFeaturesResult;
37
+ /**
38
+ * Result of useFeatureAdmin hook
39
+ */
40
+ export interface UseFeatureAdminResult {
41
+ features: FeatureToggleAdmin[];
42
+ microfrontends: string[];
43
+ isAdmin: boolean;
44
+ isLoading: boolean;
45
+ error: string | null;
46
+ refetch: () => Promise<void>;
47
+ createFeature: (feature: FeatureCreateRequest) => Promise<boolean>;
48
+ updateFeature: (name: string, feature: FeatureUpdateRequest) => Promise<boolean>;
49
+ toggleFeature: (name: string, enabled: boolean) => Promise<boolean>;
50
+ deleteFeature: (name: string) => Promise<boolean>;
51
+ }
52
+ /**
53
+ * Hook for admin operations with feature toggles
54
+ *
55
+ * @example
56
+ * ```typescript
57
+ * import { useFeatureAdmin } from '@ib-dop/platform-kit'
58
+ *
59
+ * function AdminPanel() {
60
+ * const {
61
+ * features,
62
+ * isAdmin,
63
+ * isLoading,
64
+ * toggleFeature
65
+ * } = useFeatureAdmin()
66
+ *
67
+ * if (isLoading) return <Spinner />
68
+ * if (!isAdmin) return <AccessDenied />
69
+ *
70
+ * return (
71
+ * <table>
72
+ * {features.map(f => (
73
+ * <tr key={f.name}>
74
+ * <td>{f.name}</td>
75
+ * <td>{f.enabled ? 'ON' : 'OFF'}</td>
76
+ * <button onClick={() => toggleFeature(f.name, !f.enabled)}>
77
+ * Toggle
78
+ * </button>
79
+ * </tr>
80
+ * ))}
81
+ * </table>
82
+ * )
83
+ * }
84
+ * ```
85
+ */
86
+ export declare function useFeatureAdmin(): UseFeatureAdminResult;
87
+ /**
88
+ * Hook to get microfrontends with their features
89
+ */
90
+ export interface UseMicrofrontendsFeaturesResult {
91
+ microfrontends: MicrofrontendWithFeatures[];
92
+ totalCount: number;
93
+ isLoading: boolean;
94
+ error: string | null;
95
+ refetch: () => Promise<void>;
96
+ }
97
+ export declare function useMicrofrontendsFeatures(): UseMicrofrontendsFeaturesResult;
98
+ //# sourceMappingURL=useFeatures.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeatures.d.ts","sourceRoot":"","sources":["../../src/hooks/useFeatures.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,KAAK,EACV,iBAAiB,EAEjB,kBAAkB,EAElB,oBAAoB,EACpB,oBAAoB,EACpB,yBAAyB,EAE1B,MAAM,UAAU,CAAA;AAEjB;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,QAAQ,EAAE,iBAAiB,EAAE,CAAA;IAC7B,UAAU,EAAE,MAAM,CAAA;IAClB,SAAS,EAAE,MAAM,EAAE,CAAA;IACnB,SAAS,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5B,gBAAgB,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,OAAO,CAAA;IAClD,eAAe,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,iBAAiB,EAAE,CAAA;CACzD;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,wBAAgB,WAAW,IAAI,iBAAiB,CA6E/C;AAED;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,kBAAkB,EAAE,CAAA;IAC9B,cAAc,EAAE,MAAM,EAAE,CAAA;IACxB,OAAO,EAAE,OAAO,CAAA;IAChB,SAAS,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5B,aAAa,EAAE,CAAC,OAAO,EAAE,oBAAoB,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;IAClE,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,oBAAoB,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;IAChF,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;IACnE,aAAa,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,CAAA;CAClD;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiCG;AACH,wBAAgB,eAAe,IAAI,qBAAqB,CAqMvD;AAED;;GAEG;AACH,MAAM,WAAW,+BAA+B;IAC9C,cAAc,EAAE,yBAAyB,EAAE,CAAA;IAC3C,UAAU,EAAE,MAAM,CAAA;IAClB,SAAS,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IACpB,OAAO,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;CAC7B;AAED,wBAAgB,yBAAyB,IAAI,+BAA+B,CAqD3E"}
package/dist/index.js CHANGED
@@ -1,18 +1,18 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const m=require("react"),Ft=require("axios"),Ve={log:(...t)=>{},warn:(...t)=>{}};function Q(){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 ze(){const[t,r]=m.useState(null),[o,u]=m.useState(!0),s=m.useRef(0),f=20,i=m.useCallback(()=>Q(),[]);m.useEffect(()=>{const y=i();if(y){r(y),u(!1);return}const g=l=>{r(l.detail),u(!1)},S=setInterval(()=>{s.current++;const l=i();l?(Ve.log("Auth found via polling, attempts:",s.current),r(l),u(!1),clearInterval(S)):s.current>=f&&(u(!1),clearInterval(S))},500);return window.addEventListener("shell-auth-ready",g),()=>{clearInterval(S),window.removeEventListener("shell-auth-ready",g)}},[i]);const p=t||{user:null,isAuthenticated:!1,isLoading:o,signinRedirect:async()=>{const y=Q();y?.signinRedirect?await y.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const y=Q();y?.removeUser&&await y.removeUser()}};return Ve.log("Auth result:",{isAuthenticated:p.isAuthenticated,isLoading:p.isLoading}),p}const Lt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function $t(t){if(t)return t;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function Ye(t){const[r,o]=m.useState(null),[u,s]=m.useState(!0),[f,i]=m.useState(null),b=m.useCallback(()=>{const y=$t(t?.mfeName).replace("@ib-dop/","");s(!0),i(null),fetch(`/svc/${y}/info.json`).then(g=>{if(!g.ok)throw new Error(`HTTP ${g.status}: ${g.statusText}`);return g.json()}).then(g=>{o(g)}).catch(g=>{Lt.error("Failed to load info:",g),i(g instanceof Error?g.message:String(g))}).finally(()=>{s(!1)})},[t?.mfeName]);return m.useEffect(()=>{b()},[b]),{data:r,isLoading:u,error:f,refetch:b}}const ce={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},X={authority:"",client_id:"",environment:"development"};function Ut(){const[t,r]=m.useState(null),[o,u]=m.useState(!0),[s,f]=m.useState(null);return m.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){f("sessionStorage not available"),r(X),u(!1);return}try{const b=sessionStorage.getItem("config");if(b){const p=JSON.parse(b);r({...X,...p}),f(null),ce.log("Config loaded successfully")}else r(X),f("Config not found in sessionStorage"),ce.warn("Config not found in sessionStorage")}catch(b){ce.error("Error parsing config:",b),r(X),f("Error parsing config")}finally{u(!1)}})()},[]),{data:t,isLoading:o,error:s}}function Je(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 We(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;Je({type:t.type==="network"?"warning":"error",title:u.title,message:r?`${u.message} (${r})`:u.message})}function Vt(t,r={}){const{notifyOnError:o=!0,notifyOnSuccess:u=!1,successMessage:s,errorContext:f,onSuccess:i,onError:b}=r,[p,y]=m.useState(null),[g,S]=m.useState(null),[l,v]=m.useState(!1),C=g!==null,k=p!==null&&!l&&!C,te=m.useCallback(async()=>{v(!0),S(null);try{const x=await t();if(x.ok)return y(x.data),u&&s&&Je({type:"success",title:"Успешно",message:s}),i?.(x.data),x.data;{const O={message:x.data||"Request failed",status:x.status,type:"client",timestamp:Date.now()};return S(O),o&&We(O,f),b?.(O),null}}catch(x){const O=x;return S(O),o&&We(O,f),b?.(O),null}finally{v(!1)}},[t,o,u,s,f,i,b]),j=m.useCallback(()=>{y(null),S(null),v(!1)},[]);return{data:p,error:g,isLoading:l,isError:C,isSuccess:k,execute:te,reset:j}}const Wt={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 Bt(t={}){const r=ze(),o=m.useMemo(()=>({...Wt,...t}),[t]),u=m.useMemo(()=>{const f=r.user?.profile?.realm_roles||r.user?.profile?.roles||[];return Array.isArray(f)?f:[f]},[r.user]),s=f=>f.includes("all")?!0:f.some(i=>u.includes(i));return{canView:s(o.canView),canEdit:s(o.canEdit),canDelete:s(o.canDelete),canAdmin:s(o.canAdmin),canViewSensitiveData:s(o.canViewSensitiveData),canExportData:s(o.canExportData),canManageUsers:s(o.canManageUsers)}}var Z={exports:{}},W={};var Be;function Ht(){if(Be)return W;Be=1;var t=m,r=Symbol.for("react.element"),o=Symbol.for("react.fragment"),u=Object.prototype.hasOwnProperty,s=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,f={key:!0,ref:!0,__self:!0,__source:!0};function i(b,p,y){var g,S={},l=null,v=null;y!==void 0&&(l=""+y),p.key!==void 0&&(l=""+p.key),p.ref!==void 0&&(v=p.ref);for(g in p)u.call(p,g)&&!f.hasOwnProperty(g)&&(S[g]=p[g]);if(b&&b.defaultProps)for(g in p=b.defaultProps,p)S[g]===void 0&&(S[g]=p[g]);return{$$typeof:r,type:b,key:l,ref:v,props:S,_owner:s.current}}return W.Fragment=o,W.jsx=i,W.jsxs=i,W}var B={};var He;function Gt(){return He||(He=1,process.env.NODE_ENV!=="production"&&(function(){var t=m,r=Symbol.for("react.element"),o=Symbol.for("react.portal"),u=Symbol.for("react.fragment"),s=Symbol.for("react.strict_mode"),f=Symbol.for("react.profiler"),i=Symbol.for("react.provider"),b=Symbol.for("react.context"),p=Symbol.for("react.forward_ref"),y=Symbol.for("react.suspense"),g=Symbol.for("react.suspense_list"),S=Symbol.for("react.memo"),l=Symbol.for("react.lazy"),v=Symbol.for("react.offscreen"),C=Symbol.iterator,k="@@iterator";function te(e){if(e===null||typeof e!="object")return null;var n=C&&e[C]||e[k];return typeof n=="function"?n:null}var j=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function x(e){{for(var n=arguments.length,a=new Array(n>1?n-1:0),c=1;c<n;c++)a[c-1]=arguments[c];O("error",e,a)}}function O(e,n,a){{var c=j.ReactDebugCurrentFrame,E=c.getStackAddendum();E!==""&&(n+="%s",a=a.concat([E]));var w=a.map(function(_){return String(_)});w.unshift("Warning: "+n),Function.prototype.apply.call(console[e],console,w)}}var nt=!1,ot=!1,at=!1,it=!1,st=!1,he;he=Symbol.for("react.module.reference");function ut(e){return!!(typeof e=="string"||typeof e=="function"||e===u||e===f||st||e===s||e===y||e===g||it||e===v||nt||ot||at||typeof e=="object"&&e!==null&&(e.$$typeof===l||e.$$typeof===S||e.$$typeof===i||e.$$typeof===b||e.$$typeof===p||e.$$typeof===he||e.getModuleId!==void 0))}function lt(e,n,a){var c=e.displayName;if(c)return c;var E=n.displayName||n.name||"";return E!==""?a+"("+E+")":a}function _e(e){return e.displayName||"Context"}function P(e){if(e==null)return null;if(typeof e.tag=="number"&&x("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 f:return"Profiler";case s:return"StrictMode";case y:return"Suspense";case g:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case b:var n=e;return _e(n)+".Consumer";case i:var a=e;return _e(a._context)+".Provider";case p:return lt(e,e.render,"ForwardRef");case S:var c=e.displayName||null;return c!==null?c:P(e.type)||"Memo";case l:{var E=e,w=E._payload,_=E._init;try{return P(_(w))}catch{return null}}}return null}var D=Object.assign,U=0,ve,Ee,ye,we,be,xe,Se;function Re(){}Re.__reactDisabledLog=!0;function ct(){{if(U===0){ve=console.log,Ee=console.info,ye=console.warn,we=console.error,be=console.group,xe=console.groupCollapsed,Se=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Re,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}U++}}function ft(){{if(U--,U===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:D({},e,{value:ve}),info:D({},e,{value:Ee}),warn:D({},e,{value:ye}),error:D({},e,{value:we}),group:D({},e,{value:be}),groupCollapsed:D({},e,{value:xe}),groupEnd:D({},e,{value:Se})})}U<0&&x("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var re=j.ReactCurrentDispatcher,ne;function Y(e,n,a){{if(ne===void 0)try{throw Error()}catch(E){var c=E.stack.trim().match(/\n( *(at )?)/);ne=c&&c[1]||""}return`
2
- `+ne+e}}var oe=!1,J;{var dt=typeof WeakMap=="function"?WeakMap:Map;J=new dt}function Ae(e,n){if(!e||oe)return"";{var a=J.get(e);if(a!==void 0)return a}var c;oe=!0;var E=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var w;w=re.current,re.current=null,ct();try{if(n){var _=function(){throw Error()};if(Object.defineProperty(_.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(_,[])}catch(I){c=I}Reflect.construct(e,[],_)}else{try{_.call()}catch(I){c=I}e.call(_.prototype)}}else{try{throw Error()}catch(I){c=I}e()}}catch(I){if(I&&c&&typeof I.stack=="string"){for(var h=I.stack.split(`
3
- `),M=c.stack.split(`
4
- `),R=h.length-1,A=M.length-1;R>=1&&A>=0&&h[R]!==M[A];)A--;for(;R>=1&&A>=0;R--,A--)if(h[R]!==M[A]){if(R!==1||A!==1)do if(R--,A--,A<0||h[R]!==M[A]){var N=`
5
- `+h[R].replace(" at new "," at ");return e.displayName&&N.includes("<anonymous>")&&(N=N.replace("<anonymous>",e.displayName)),typeof e=="function"&&J.set(e,N),N}while(R>=1&&A>=0);break}}}finally{oe=!1,re.current=w,ft(),Error.prepareStackTrace=E}var $=e?e.displayName||e.name:"",F=$?Y($):"";return typeof e=="function"&&J.set(e,F),F}function pt(e,n,a){return Ae(e,!1)}function gt(e){var n=e.prototype;return!!(n&&n.isReactComponent)}function q(e,n,a){if(e==null)return"";if(typeof e=="function")return Ae(e,gt(e));if(typeof e=="string")return Y(e);switch(e){case y:return Y("Suspense");case g:return Y("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case p:return pt(e.render);case S:return q(e.type,n,a);case l:{var c=e,E=c._payload,w=c._init;try{return q(w(E),n,a)}catch{}}}return""}var V=Object.prototype.hasOwnProperty,Ce={},Me=j.ReactDebugCurrentFrame;function K(e){if(e){var n=e._owner,a=q(e.type,e._source,n?n.type:null);Me.setExtraStackFrame(a)}else Me.setExtraStackFrame(null)}function mt(e,n,a,c,E){{var w=Function.call.bind(V);for(var _ in e)if(w(e,_)){var h=void 0;try{if(typeof e[_]!="function"){var M=Error((c||"React class")+": "+a+" type `"+_+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[_]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw M.name="Invariant Violation",M}h=e[_](n,_,c,a,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(R){h=R}h&&!(h instanceof Error)&&(K(E),x("%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,_,typeof h),K(null)),h instanceof Error&&!(h.message in Ce)&&(Ce[h.message]=!0,K(E),x("Failed %s type: %s",a,h.message),K(null))}}}var ht=Array.isArray;function ae(e){return ht(e)}function _t(e){{var n=typeof Symbol=="function"&&Symbol.toStringTag,a=n&&e[Symbol.toStringTag]||e.constructor.name||"Object";return a}}function vt(e){try{return Ie(e),!1}catch{return!0}}function Ie(e){return""+e}function Ne(e){if(vt(e))return x("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",_t(e)),Ie(e)}var Te=j.ReactCurrentOwner,Et={key:!0,ref:!0,__self:!0,__source:!0},ke,Oe;function yt(e){if(V.call(e,"ref")){var n=Object.getOwnPropertyDescriptor(e,"ref").get;if(n&&n.isReactWarning)return!1}return e.ref!==void 0}function wt(e){if(V.call(e,"key")){var n=Object.getOwnPropertyDescriptor(e,"key").get;if(n&&n.isReactWarning)return!1}return e.key!==void 0}function bt(e,n){typeof e.ref=="string"&&Te.current}function xt(e,n){{var a=function(){ke||(ke=!0,x("%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)",n))};a.isReactWarning=!0,Object.defineProperty(e,"key",{get:a,configurable:!0})}}function St(e,n){{var a=function(){Oe||(Oe=!0,x("%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)",n))};a.isReactWarning=!0,Object.defineProperty(e,"ref",{get:a,configurable:!0})}}var Rt=function(e,n,a,c,E,w,_){var h={$$typeof:r,type:e,key:n,ref:a,props:_,_owner:w};return h._store={},Object.defineProperty(h._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(h,"_self",{configurable:!1,enumerable:!1,writable:!1,value:c}),Object.defineProperty(h,"_source",{configurable:!1,enumerable:!1,writable:!1,value:E}),Object.freeze&&(Object.freeze(h.props),Object.freeze(h)),h};function At(e,n,a,c,E){{var w,_={},h=null,M=null;a!==void 0&&(Ne(a),h=""+a),wt(n)&&(Ne(n.key),h=""+n.key),yt(n)&&(M=n.ref,bt(n,E));for(w in n)V.call(n,w)&&!Et.hasOwnProperty(w)&&(_[w]=n[w]);if(e&&e.defaultProps){var R=e.defaultProps;for(w in R)_[w]===void 0&&(_[w]=R[w])}if(h||M){var A=typeof e=="function"?e.displayName||e.name||"Unknown":e;h&&xt(_,A),M&&St(_,A)}return Rt(e,h,M,E,c,Te.current,_)}}var ie=j.ReactCurrentOwner,je=j.ReactDebugCurrentFrame;function L(e){if(e){var n=e._owner,a=q(e.type,e._source,n?n.type:null);je.setExtraStackFrame(a)}else je.setExtraStackFrame(null)}var se;se=!1;function ue(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function Pe(){{if(ie.current){var e=P(ie.current.type);if(e)return`
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("react"),Dt=require("axios"),ze={log:(...t)=>{},warn:(...t)=>{}};function ne(){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 J(){const[t,r]=l.useState(null),[s,u]=l.useState(!0),o=l.useRef(0),p=20,a=l.useCallback(()=>ne(),[]);l.useEffect(()=>{const y=a();if(y){r(y),u(!1);return}const f=c=>{r(c.detail),u(!1)},_=setInterval(()=>{o.current++;const c=a();c?(ze.log("Auth found via polling, attempts:",o.current),r(c),u(!1),clearInterval(_)):o.current>=p&&(u(!1),clearInterval(_))},500);return window.addEventListener("shell-auth-ready",f),()=>{clearInterval(_),window.removeEventListener("shell-auth-ready",f)}},[a]);const d=t||{user:null,isAuthenticated:!1,isLoading:s,signinRedirect:async()=>{const y=ne();y?.signinRedirect?await y.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const y=ne();y?.removeUser&&await y.removeUser()}};return ze.log("Auth result:",{isAuthenticated:d.isAuthenticated,isLoading:d.isLoading}),d}const $t={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function Lt(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,s]=l.useState(null),[u,o]=l.useState(!0),[p,a]=l.useState(null),S=l.useCallback(()=>{const y=Lt(t?.mfeName).replace("@ib-dop/","");o(!0),a(null),fetch(`/svc/${y}/info.json`).then(f=>{if(!f.ok)throw new Error(`HTTP ${f.status}: ${f.statusText}`);return f.json()}).then(f=>{s(f)}).catch(f=>{$t.error("Failed to load info:",f),a(f instanceof Error?f.message:String(f))}).finally(()=>{o(!1)})},[t?.mfeName]);return l.useEffect(()=>{S()},[S]),{data:r,isLoading:u,error:p,refetch:S}}const pe={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},te={authority:"",client_id:"",environment:"development"};function Ut(){const[t,r]=l.useState(null),[s,u]=l.useState(!0),[o,p]=l.useState(null);return l.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){p("sessionStorage not available"),r(te),u(!1);return}try{const S=sessionStorage.getItem("config");if(S){const d=JSON.parse(S);r({...te,...d}),p(null),pe.log("Config loaded successfully")}else r(te),p("Config not found in sessionStorage"),pe.warn("Config not found in sessionStorage")}catch(S){pe.error("Error parsing config:",S),r(te),p("Error parsing config")}finally{u(!1)}})()},[]),{data:t,isLoading:s,error:o}}function Ke(t){if(typeof window>"u")return;const r=window.__MF_NAME__||"unknown",s={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:s,bubbles:!0}))}function We(t,r){const s={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=s[t.type]||s.unknown;Ke({type:t.type==="network"?"warning":"error",title:u.title,message:r?`${u.message} (${r})`:u.message})}function Vt(t,r={}){const{notifyOnError:s=!0,notifyOnSuccess:u=!1,successMessage:o,errorContext:p,onSuccess:a,onError:S}=r,[d,y]=l.useState(null),[f,_]=l.useState(null),[c,v]=l.useState(!1),b=f!==null,I=d!==null&&!c&&!b,T=l.useCallback(async()=>{v(!0),_(null);try{const h=await t();if(h.ok)return y(h.data),u&&o&&Ke({type:"success",title:"Успешно",message:o}),a?.(h.data),h.data;{const A={message:h.data||"Request failed",status:h.status,type:"client",timestamp:Date.now()};return _(A),s&&We(A,p),S?.(A),null}}catch(h){const A=h;return _(A),s&&We(A,p),S?.(A),null}finally{v(!1)}},[t,s,u,o,p,a,S]),x=l.useCallback(()=>{y(null),_(null),v(!1)},[]);return{data:d,error:f,isLoading:c,isError:b,isSuccess:I,execute:T,reset:x}}const Bt={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 Ht(t={}){const r=J(),s=l.useMemo(()=>({...Bt,...t}),[t]),u=l.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(a=>u.includes(a));return{canView:o(s.canView),canEdit:o(s.canEdit),canDelete:o(s.canDelete),canAdmin:o(s.canAdmin),canViewSensitiveData:o(s.canViewSensitiveData),canExportData:o(s.canExportData),canManageUsers:o(s.canManageUsers)}}function zt(){const t=J(),[r,s]=l.useState([]),[u,o]=l.useState(0),[p,a]=l.useState([]),[S,d]=l.useState(!0),[y,f]=l.useState(null),_=l.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatures] Not authenticated"),d(!1);return}d(!0),f(null);try{const b={"Content-Type":"application/json"},I=t.user?.access_token;I&&(b.Authorization=`Bearer ${I}`);const T=await fetch("/api/features",{headers:b});if(!T.ok)throw new Error(`HTTP ${T.status}: ${T.statusText}`);const x=await T.json();s(x.features||[]),o(x.totalCount||0),a(x.userRoles||[])}catch(b){console.debug("Features fetch error:",b),f(b instanceof Error?b.message:String(b)),s([]),a([])}finally{d(!1)}},[t.isAuthenticated,t.user?.access_token]);l.useEffect(()=>{_()},[_]);const c=l.useCallback(b=>r.find(T=>T.name===b)?.userEnabled??!1,[r]),v=l.useCallback(b=>r.filter(I=>I.mfDependencies?.includes(b)),[r]);return{features:r,totalCount:u,userRoles:p,isLoading:S,error:y,refetch:_,isFeatureEnabled:c,getFeaturesByMf:v}}function Wt(){const t=J(),[r,s]=l.useState([]),[u,o]=l.useState([]),[p,a]=l.useState(!1),[S,d]=l.useState(!0),[y,f]=l.useState(null),_=l.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatureAdmin] Not authenticated"),d(!1);return}d(!0),f(null);try{const T={"Content-Type":"application/json"},x=t.user?.access_token;x&&(T.Authorization=`Bearer ${x}`);const h=await fetch("/api/features/admin",{headers:T});if(!h.ok){if(h.status===403){console.warn("[useFeatureAdmin] 403 Forbidden - checking if token has admin role"),a(!1),s([]),o([]),d(!1);return}throw new Error(`HTTP ${h.status}: ${h.statusText}`)}const A=await h.json();s(A.featureToggles||[]),o(A.microfrontends||[]),a(A.isAdmin||!1)}catch(T){console.debug("FeatureAdmin fetch error:",T),s([]),o([]),a(!1)}finally{d(!1)}},[t.isAuthenticated,t.user?.access_token]),c=l.useCallback(async T=>{try{const x={"Content-Type":"application/json"},h=t.user?.access_token;h&&(x.Authorization=`Bearer ${h}`);const A=await fetch("/api/features/admin",{method:"POST",headers:x,body:JSON.stringify(T)});if(!A.ok){const P=await A.json().catch(()=>({}));throw new Error(P.error||`HTTP ${A.status}`)}return await _(),!0}catch(x){return f(x instanceof Error?x.message:String(x)),!1}},[_]),v=l.useCallback(async(T,x)=>{try{const h={"Content-Type":"application/json"},A=t.user?.access_token;A&&(h.Authorization=`Bearer ${A}`);const P=await fetch(`/api/features/admin/${encodeURIComponent(T)}`,{method:"PUT",headers:h,body:JSON.stringify(x)});if(!P.ok){const B=await P.json().catch(()=>({}));throw new Error(B.error||`HTTP ${P.status}`)}return await _(),!0}catch(h){return f(h instanceof Error?h.message:String(h)),!1}},[_]),b=l.useCallback(async(T,x)=>{try{const h={},A=t.user?.access_token;A&&(h.Authorization=`Bearer ${A}`);const P=await fetch(`/api/features/admin/${encodeURIComponent(T)}/toggle?enabled=${x}`,{method:"POST",headers:h});if(!P.ok){const B=await P.json().catch(()=>({}));throw new Error(B.error||`HTTP ${P.status}`)}return await _(),!0}catch(h){return f(h instanceof Error?h.message:String(h)),!1}},[_]),I=l.useCallback(async T=>{try{const x={},h=t.user?.access_token;h&&(x.Authorization=`Bearer ${h}`);const A=await fetch(`/api/features/admin/${encodeURIComponent(T)}`,{method:"DELETE",headers:x});if(!A.ok){const P=await A.json().catch(()=>({}));throw new Error(P.error||`HTTP ${A.status}`)}return await _(),!0}catch(x){return f(x instanceof Error?x.message:String(x)),!1}},[_]);return l.useEffect(()=>{_()},[_]),{features:r,microfrontends:u,isAdmin:p,isLoading:S,error:y,refetch:_,createFeature:c,updateFeature:v,toggleFeature:b,deleteFeature:I}}function Gt(){const t=J(),[r,s]=l.useState([]),[u,o]=l.useState(0),[p,a]=l.useState(!0),[S,d]=l.useState(null),y=l.useCallback(async()=>{if(!t.isAuthenticated){a(!1);return}a(!0),d(null);try{const f={"Content-Type":"application/json"},_=t.user?.access_token;_&&(f.Authorization=`Bearer ${_}`);const c=await fetch("/api/features/microfrontends",{headers:f});if(!c.ok)throw new Error(`HTTP ${c.status}: ${c.statusText}`);const v=await c.json();s(v.microfrontends||[]),o(v.totalCount||0)}catch(f){d(f instanceof Error?f.message:String(f))}finally{a(!1)}},[t.isAuthenticated,t.user?.access_token]);return l.useEffect(()=>{y()},[y]),{microfrontends:r,totalCount:u,isLoading:p,error:S,refetch:y}}var re={exports:{}},W={};var Ge;function Yt(){if(Ge)return W;Ge=1;var t=l,r=Symbol.for("react.element"),s=Symbol.for("react.fragment"),u=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 a(S,d,y){var f,_={},c=null,v=null;y!==void 0&&(c=""+y),d.key!==void 0&&(c=""+d.key),d.ref!==void 0&&(v=d.ref);for(f in d)u.call(d,f)&&!p.hasOwnProperty(f)&&(_[f]=d[f]);if(S&&S.defaultProps)for(f in d=S.defaultProps,d)_[f]===void 0&&(_[f]=d[f]);return{$$typeof:r,type:S,key:c,ref:v,props:_,_owner:o.current}}return W.Fragment=s,W.jsx=a,W.jsxs=a,W}var G={};var Ye;function Jt(){return Ye||(Ye=1,process.env.NODE_ENV!=="production"&&(function(){var t=l,r=Symbol.for("react.element"),s=Symbol.for("react.portal"),u=Symbol.for("react.fragment"),o=Symbol.for("react.strict_mode"),p=Symbol.for("react.profiler"),a=Symbol.for("react.provider"),S=Symbol.for("react.context"),d=Symbol.for("react.forward_ref"),y=Symbol.for("react.suspense"),f=Symbol.for("react.suspense_list"),_=Symbol.for("react.memo"),c=Symbol.for("react.lazy"),v=Symbol.for("react.offscreen"),b=Symbol.iterator,I="@@iterator";function T(e){if(e===null||typeof e!="object")return null;var n=b&&e[b]||e[I];return typeof n=="function"?n:null}var x=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function h(e){{for(var n=arguments.length,i=new Array(n>1?n-1:0),g=1;g<n;g++)i[g-1]=arguments[g];A("error",e,i)}}function A(e,n,i){{var g=x.ReactDebugCurrentFrame,C=g.getStackAddendum();C!==""&&(n+="%s",i=i.concat([C]));var k=i.map(function(w){return String(w)});k.unshift("Warning: "+n),Function.prototype.apply.call(console[e],console,k)}}var P=!1,B=!1,at=!1,ot=!1,it=!1,Ee;Ee=Symbol.for("react.module.reference");function ut(e){return!!(typeof e=="string"||typeof e=="function"||e===u||e===p||it||e===o||e===y||e===f||ot||e===v||P||B||at||typeof e=="object"&&e!==null&&(e.$$typeof===c||e.$$typeof===_||e.$$typeof===a||e.$$typeof===S||e.$$typeof===d||e.$$typeof===Ee||e.getModuleId!==void 0))}function ct(e,n,i){var g=e.displayName;if(g)return g;var C=n.displayName||n.name||"";return C!==""?i+"("+C+")":i}function ye(e){return e.displayName||"Context"}function D(e){if(e==null)return null;if(typeof e.tag=="number"&&h("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 s:return"Portal";case p:return"Profiler";case o:return"StrictMode";case y:return"Suspense";case f:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case S:var n=e;return ye(n)+".Consumer";case a:var i=e;return ye(i._context)+".Provider";case d:return ct(e,e.render,"ForwardRef");case _:var g=e.displayName||null;return g!==null?g:D(e.type)||"Memo";case c:{var C=e,k=C._payload,w=C._init;try{return D(w(k))}catch{return null}}}return null}var $=Object.assign,H=0,we,be,xe,Se,Ce,Ae,ke;function Te(){}Te.__reactDisabledLog=!0;function lt(){{if(H===0){we=console.log,be=console.info,xe=console.warn,Se=console.error,Ce=console.group,Ae=console.groupCollapsed,ke=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 ft(){{if(H--,H===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:$({},e,{value:we}),info:$({},e,{value:be}),warn:$({},e,{value:xe}),error:$({},e,{value:Se}),group:$({},e,{value:Ce}),groupCollapsed:$({},e,{value:Ae}),groupEnd:$({},e,{value:ke})})}H<0&&h("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var ae=x.ReactCurrentDispatcher,oe;function X(e,n,i){{if(oe===void 0)try{throw Error()}catch(C){var g=C.stack.trim().match(/\n( *(at )?)/);oe=g&&g[1]||""}return`
2
+ `+oe+e}}var ie=!1,Z;{var dt=typeof WeakMap=="function"?WeakMap:Map;Z=new dt}function Re(e,n){if(!e||ie)return"";{var i=Z.get(e);if(i!==void 0)return i}var g;ie=!0;var C=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var k;k=ae.current,ae.current=null,lt();try{if(n){var w=function(){throw Error()};if(Object.defineProperty(w.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(w,[])}catch(j){g=j}Reflect.construct(e,[],w)}else{try{w.call()}catch(j){g=j}e.call(w.prototype)}}else{try{throw Error()}catch(j){g=j}e()}}catch(j){if(j&&g&&typeof j.stack=="string"){for(var E=j.stack.split(`
3
+ `),N=g.stack.split(`
4
+ `),R=E.length-1,M=N.length-1;R>=1&&M>=0&&E[R]!==N[M];)M--;for(;R>=1&&M>=0;R--,M--)if(E[R]!==N[M]){if(R!==1||M!==1)do if(R--,M--,M<0||E[R]!==N[M]){var O=`
5
+ `+E[R].replace(" at new "," at ");return e.displayName&&O.includes("<anonymous>")&&(O=O.replace("<anonymous>",e.displayName)),typeof e=="function"&&Z.set(e,O),O}while(R>=1&&M>=0);break}}}finally{ie=!1,ae.current=k,ft(),Error.prepareStackTrace=C}var V=e?e.displayName||e.name:"",L=V?X(V):"";return typeof e=="function"&&Z.set(e,L),L}function pt(e,n,i){return Re(e,!1)}function ht(e){var n=e.prototype;return!!(n&&n.isReactComponent)}function Q(e,n,i){if(e==null)return"";if(typeof e=="function")return Re(e,ht(e));if(typeof e=="string")return X(e);switch(e){case y:return X("Suspense");case f:return X("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case d:return pt(e.render);case _:return Q(e.type,n,i);case c:{var g=e,C=g._payload,k=g._init;try{return Q(k(C),n,i)}catch{}}}return""}var z=Object.prototype.hasOwnProperty,Me={},Ie=x.ReactDebugCurrentFrame;function ee(e){if(e){var n=e._owner,i=Q(e.type,e._source,n?n.type:null);Ie.setExtraStackFrame(i)}else Ie.setExtraStackFrame(null)}function gt(e,n,i,g,C){{var k=Function.call.bind(z);for(var w in e)if(k(e,w)){var E=void 0;try{if(typeof e[w]!="function"){var N=Error((g||"React class")+": "+i+" type `"+w+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[w]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw N.name="Invariant Violation",N}E=e[w](n,w,g,i,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(R){E=R}E&&!(E instanceof Error)&&(ee(C),h("%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",i,w,typeof E),ee(null)),E instanceof Error&&!(E.message in Me)&&(Me[E.message]=!0,ee(C),h("Failed %s type: %s",i,E.message),ee(null))}}}var mt=Array.isArray;function ue(e){return mt(e)}function _t(e){{var n=typeof Symbol=="function"&&Symbol.toStringTag,i=n&&e[Symbol.toStringTag]||e.constructor.name||"Object";return i}}function vt(e){try{return Ne(e),!1}catch{return!0}}function Ne(e){return""+e}function je(e){if(vt(e))return h("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",_t(e)),Ne(e)}var Pe=x.ReactCurrentOwner,Et={key:!0,ref:!0,__self:!0,__source:!0},Oe,Fe;function yt(e){if(z.call(e,"ref")){var n=Object.getOwnPropertyDescriptor(e,"ref").get;if(n&&n.isReactWarning)return!1}return e.ref!==void 0}function wt(e){if(z.call(e,"key")){var n=Object.getOwnPropertyDescriptor(e,"key").get;if(n&&n.isReactWarning)return!1}return e.key!==void 0}function bt(e,n){typeof e.ref=="string"&&Pe.current}function xt(e,n){{var i=function(){Oe||(Oe=!0,h("%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)",n))};i.isReactWarning=!0,Object.defineProperty(e,"key",{get:i,configurable:!0})}}function St(e,n){{var i=function(){Fe||(Fe=!0,h("%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)",n))};i.isReactWarning=!0,Object.defineProperty(e,"ref",{get:i,configurable:!0})}}var Ct=function(e,n,i,g,C,k,w){var E={$$typeof:r,type:e,key:n,ref:i,props:w,_owner:k};return E._store={},Object.defineProperty(E._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(E,"_self",{configurable:!1,enumerable:!1,writable:!1,value:g}),Object.defineProperty(E,"_source",{configurable:!1,enumerable:!1,writable:!1,value:C}),Object.freeze&&(Object.freeze(E.props),Object.freeze(E)),E};function At(e,n,i,g,C){{var k,w={},E=null,N=null;i!==void 0&&(je(i),E=""+i),wt(n)&&(je(n.key),E=""+n.key),yt(n)&&(N=n.ref,bt(n,C));for(k in n)z.call(n,k)&&!Et.hasOwnProperty(k)&&(w[k]=n[k]);if(e&&e.defaultProps){var R=e.defaultProps;for(k in R)w[k]===void 0&&(w[k]=R[k])}if(E||N){var M=typeof e=="function"?e.displayName||e.name||"Unknown":e;E&&xt(w,M),N&&St(w,M)}return Ct(e,E,N,C,g,Pe.current,w)}}var ce=x.ReactCurrentOwner,De=x.ReactDebugCurrentFrame;function U(e){if(e){var n=e._owner,i=Q(e.type,e._source,n?n.type:null);De.setExtraStackFrame(i)}else De.setExtraStackFrame(null)}var le;le=!1;function fe(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function $e(){{if(ce.current){var e=D(ce.current.type);if(e)return`
6
6
 
7
- Check the render method of \``+e+"`."}return""}}function Ct(e){return""}var De={};function Mt(e){{var n=Pe();if(!n){var a=typeof e=="string"?e:e.displayName||e.name;a&&(n=`
7
+ Check the render method of \``+e+"`."}return""}}function kt(e){return""}var Le={};function Tt(e){{var n=$e();if(!n){var i=typeof e=="string"?e:e.displayName||e.name;i&&(n=`
8
8
 
9
- Check the top-level render call using <`+a+">.")}return n}}function Fe(e,n){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var a=Mt(n);if(De[a])return;De[a]=!0;var c="";e&&e._owner&&e._owner!==ie.current&&(c=" It was passed a child from "+P(e._owner.type)+"."),L(e),x('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),L(null)}}function Le(e,n){{if(typeof e!="object")return;if(ae(e))for(var a=0;a<e.length;a++){var c=e[a];ue(c)&&Fe(c,n)}else if(ue(e))e._store&&(e._store.validated=!0);else if(e){var E=te(e);if(typeof E=="function"&&E!==e.entries)for(var w=E.call(e),_;!(_=w.next()).done;)ue(_.value)&&Fe(_.value,n)}}}function It(e){{var n=e.type;if(n==null||typeof n=="string")return;var a;if(typeof n=="function")a=n.propTypes;else if(typeof n=="object"&&(n.$$typeof===p||n.$$typeof===S))a=n.propTypes;else return;if(a){var c=P(n);mt(a,e.props,"prop",c,e)}else if(n.PropTypes!==void 0&&!se){se=!0;var E=P(n);x("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",E||"Unknown")}typeof n.getDefaultProps=="function"&&!n.getDefaultProps.isReactClassApproved&&x("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function Nt(e){{for(var n=Object.keys(e.props),a=0;a<n.length;a++){var c=n[a];if(c!=="children"&&c!=="key"){L(e),x("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",c),L(null);break}}e.ref!==null&&(L(e),x("Invalid attribute `ref` supplied to `React.Fragment`."),L(null))}}var $e={};function Ue(e,n,a,c,E,w){{var _=ut(e);if(!_){var h="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(h+=" 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 M=Ct();M?h+=M:h+=Pe();var R;e===null?R="null":ae(e)?R="array":e!==void 0&&e.$$typeof===r?(R="<"+(P(e.type)||"Unknown")+" />",h=" Did you accidentally export a JSX literal instead of a component?"):R=typeof e,x("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",R,h)}var A=At(e,n,a,E,w);if(A==null)return A;if(_){var N=n.children;if(N!==void 0)if(c)if(ae(N)){for(var $=0;$<N.length;$++)Le(N[$],e);Object.freeze&&Object.freeze(N)}else x("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 Le(N,e)}if(V.call(n,"key")){var F=P(e),I=Object.keys(n).filter(function(Dt){return Dt!=="key"}),le=I.length>0?"{key: someKey, "+I.join(": ..., ")+": ...}":"{key: someKey}";if(!$e[F+le]){var Pt=I.length>0?"{"+I.join(": ..., ")+": ...}":"{}";x(`A props object containing a "key" prop is being spread into JSX:
9
+ Check the top-level render call using <`+i+">.")}return n}}function Ue(e,n){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var i=Tt(n);if(Le[i])return;Le[i]=!0;var g="";e&&e._owner&&e._owner!==ce.current&&(g=" It was passed a child from "+D(e._owner.type)+"."),U(e),h('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',i,g),U(null)}}function Ve(e,n){{if(typeof e!="object")return;if(ue(e))for(var i=0;i<e.length;i++){var g=e[i];fe(g)&&Ue(g,n)}else if(fe(e))e._store&&(e._store.validated=!0);else if(e){var C=T(e);if(typeof C=="function"&&C!==e.entries)for(var k=C.call(e),w;!(w=k.next()).done;)fe(w.value)&&Ue(w.value,n)}}}function Rt(e){{var n=e.type;if(n==null||typeof n=="string")return;var i;if(typeof n=="function")i=n.propTypes;else if(typeof n=="object"&&(n.$$typeof===d||n.$$typeof===_))i=n.propTypes;else return;if(i){var g=D(n);gt(i,e.props,"prop",g,e)}else if(n.PropTypes!==void 0&&!le){le=!0;var C=D(n);h("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",C||"Unknown")}typeof n.getDefaultProps=="function"&&!n.getDefaultProps.isReactClassApproved&&h("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function Mt(e){{for(var n=Object.keys(e.props),i=0;i<n.length;i++){var g=n[i];if(g!=="children"&&g!=="key"){U(e),h("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",g),U(null);break}}e.ref!==null&&(U(e),h("Invalid attribute `ref` supplied to `React.Fragment`."),U(null))}}var Be={};function He(e,n,i,g,C,k){{var w=ut(e);if(!w){var E="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(E+=" 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 N=kt();N?E+=N:E+=$e();var R;e===null?R="null":ue(e)?R="array":e!==void 0&&e.$$typeof===r?(R="<"+(D(e.type)||"Unknown")+" />",E=" Did you accidentally export a JSX literal instead of a component?"):R=typeof e,h("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",R,E)}var M=At(e,n,i,C,k);if(M==null)return M;if(w){var O=n.children;if(O!==void 0)if(g)if(ue(O)){for(var V=0;V<O.length;V++)Ve(O[V],e);Object.freeze&&Object.freeze(O)}else h("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 Ve(O,e)}if(z.call(n,"key")){var L=D(e),j=Object.keys(n).filter(function(Ft){return Ft!=="key"}),de=j.length>0?"{key: someKey, "+j.join(": ..., ")+": ...}":"{key: someKey}";if(!Be[L+de]){var Ot=j.length>0?"{"+j.join(": ..., ")+": ...}":"{}";h(`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} />`,le,F,Pt,F),$e[F+le]=!0}}return e===u?Nt(A):It(A),A}}function Tt(e,n,a){return Ue(e,n,a,!0)}function kt(e,n,a){return Ue(e,n,a,!1)}var Ot=kt,jt=Tt;B.Fragment=u,B.jsx=Ot,B.jsxs=jt})()),B}var Ge;function zt(){return Ge||(Ge=1,process.env.NODE_ENV==="production"?Z.exports=Ht():Z.exports=Gt()),Z.exports}var d=zt();const qe="platform-kit",Yt=!1,fe={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${qe}]`,...t)}};class Jt extends m.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 qe}shouldShowDetails(){if(this.props.showDetails!==void 0)return this.props.showDetails;if(typeof sessionStorage<"u")try{const r=sessionStorage.getItem("config");if(r){const o=JSON.parse(r);if(o.showErrorDetails!==void 0)return o.showErrorDetails}}catch{}return Yt}dispatchError(r,o){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const u=this.getMfeName();fe.error("ErrorBoundary caught:",r);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:u,error:r.message||String(r),stack:r.stack,componentStack:o?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(s){fe.error("Failed to dispatch mfe-error event:",s)}}static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,o){this.dispatchError(r,o),fe.error("Error info:",o.componentStack)}handleCopy=()=>{const r=`Error in ${this.getMfeName()}:
14
+ <%s key={someKey} {...props} />`,de,L,Ot,L),Be[L+de]=!0}}return e===u?Mt(M):Rt(M),M}}function It(e,n,i){return He(e,n,i,!0)}function Nt(e,n,i){return He(e,n,i,!1)}var jt=Nt,Pt=It;G.Fragment=u,G.jsx=jt,G.jsxs=Pt})()),G}var Je;function qt(){return Je||(Je=1,process.env.NODE_ENV==="production"?re.exports=Yt():re.exports=Jt()),re.exports}var m=qt();const Xe="platform-kit",Kt=!1,he={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Xe}]`,...t)}};class Xt extends l.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 Xe}shouldShowDetails(){if(this.props.showDetails!==void 0)return this.props.showDetails;if(typeof sessionStorage<"u")try{const r=sessionStorage.getItem("config");if(r){const s=JSON.parse(r);if(s.showErrorDetails!==void 0)return s.showErrorDetails}}catch{}return Kt}dispatchError(r,s){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const u=this.getMfeName();he.error("ErrorBoundary caught:",r);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:u,error:r.message||String(r),stack:r.stack,componentStack:s?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(o){he.error("Failed to dispatch mfe-error event:",o)}}static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,s){this.dispatchError(r,s),he.error("Error info:",s.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",o=this.state.error?.stack||"",u=this.shouldShowDetails(),s=this.getMfeName();return d.jsxs("div",{style:{padding:"20px",textAlign:"center",color:"#d32f2f",fontFamily:"monospace",background:"#ffebee",border:"1px solid #ef5350",borderRadius:"4px",margin:"10px"},children:[d.jsxs("h2",{style:{fontSize:"16px",margin:"0 0 8px 0"},children:["⚠️ Ошибка в ",s]}),d.jsx("p",{style:{fontSize:"12px",margin:0},children:"Произошла ошибка в микрофронтенде. Сообщение отправлено в shell."}),u&&d.jsxs("details",{style:{whiteSpace:"pre-wrap",textAlign:"left",marginTop:"10px",background:"#fff",padding:"8px",borderRadius:"4px"},children:[d.jsx("summary",{style:{cursor:"pointer",fontWeight:"bold"},children:"Детали ошибки"}),d.jsxs("pre",{style:{fontSize:"11px",overflow:"auto",maxHeight:"150px",margin:"8px 0 0 0",padding:"8px",background:"#f5f5f5",borderRadius:"4px"},children:[r,o&&`
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",s=this.state.error?.stack||"",u=this.shouldShowDetails(),o=this.getMfeName();return m.jsxs("div",{style:{padding:"20px",textAlign:"center",color:"#d32f2f",fontFamily:"monospace",background:"#ffebee",border:"1px solid #ef5350",borderRadius:"4px",margin:"10px"},children:[m.jsxs("h2",{style:{fontSize:"16px",margin:"0 0 8px 0"},children:["⚠️ Ошибка в ",o]}),m.jsx("p",{style:{fontSize:"12px",margin:0},children:"Произошла ошибка в микрофронтенде. Сообщение отправлено в shell."}),u&&m.jsxs("details",{style:{whiteSpace:"pre-wrap",textAlign:"left",marginTop:"10px",background:"#fff",padding:"8px",borderRadius:"4px"},children:[m.jsx("summary",{style:{cursor:"pointer",fontWeight:"bold"},children:"Детали ошибки"}),m.jsxs("pre",{style:{fontSize:"11px",overflow:"auto",maxHeight:"150px",margin:"8px 0 0 0",padding:"8px",background:"#f5f5f5",borderRadius:"4px"},children:[r,s&&`
17
17
 
18
- ${o}`]})]}),d.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[d.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),d.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),d.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 T={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function qt({mfeName:t}){const{data:r,isLoading:o,error:u}=Ye({mfeName:t}),[s,f]=m.useState(!1);if(o)return d.jsxs("span",{className:"text-muted small me-2",children:[d.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(u||!r)return d.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${u||"нет данных"}`,children:[d.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const i=r,b=i.BUILD_VERSION||i.IMAGE_VERSION||i.APP_NAME||"N/A",p=[];return i.APP_NAME&&p.push({key:"APP_NAME",value:i.APP_NAME,label:"Приложение",icon:T.apps}),i.BUILD_VERSION&&p.push({key:"BUILD_VERSION",value:i.BUILD_VERSION,label:"Версия",icon:T.tags}),i.IMAGE_VERSION&&p.push({key:"IMAGE_VERSION",value:i.IMAGE_VERSION,label:"Образ",icon:T.storage}),i.GIT_COMMIT&&p.push({key:"GIT_COMMIT",value:i.GIT_COMMIT,label:"Commit",icon:T.spreadsheet}),i.GIT_BRANCH&&p.push({key:"GIT_BRANCH",value:i.GIT_BRANCH,label:"Ветка",icon:T.spreadsheet}),i.CI_COMMIT_AUTHOR&&p.push({key:"CI_COMMIT_AUTHOR",value:i.CI_COMMIT_AUTHOR,label:"Автор",icon:T.user}),i.CI_COMMIT_TIMESTAMP&&p.push({key:"CI_COMMIT_TIMESTAMP",value:i.CI_COMMIT_TIMESTAMP,label:"Дата",icon:T.clock}),i.CI_JOB_URL&&p.push({key:"CI_JOB_URL",value:i.CI_JOB_URL,label:"CI Job",icon:T.link}),i.CI_PIPELINE_URL&&p.push({key:"CI_PIPELINE_URL",value:i.CI_PIPELINE_URL,label:"Pipeline",icon:T.link}),i.CI_COMMIT_MESSAGE&&(i.CI_COMMIT_MESSAGE.length>60?i.CI_COMMIT_MESSAGE.substring(0,57)+"":i.CI_COMMIT_MESSAGE,p.push({key:"CI_COMMIT_MESSAGE",value:i.CI_COMMIT_MESSAGE,label:"Сообщение",icon:T.code})),d.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[d.jsxs("button",{onClick:()=>f(!s),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[d.jsx("span",{className:"me-1",children:T.info}),d.jsx("span",{className:"text-dark",children:b})]}),s&&d.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:[d.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[d.jsx("span",{className:"me-2",children:T.apps}),d.jsx("strong",{children:i.APP_NAME||t})]}),d.jsxs("div",{style:{marginBottom:"12px"},children:[d.jsx("span",{className:"text-muted",children:"Версия: "}),d.jsx("strong",{children:b})]}),p.length>0&&d.jsx("div",{style:{fontSize:"13px"},children:p.map(({key:y,value:g,label:S,icon:l})=>{const v=g.length>40&&(y.includes("URL")||y.includes("MESSAGE"))?`${g.substring(0,37)}...`:g;return d.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[d.jsx("span",{className:"me-2",style:{flexShrink:0},children:l}),d.jsxs("div",{style:{flex:1,minWidth:0},children:[d.jsx("div",{className:"small text-muted",children:S}),d.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:g,children:y.includes("URL")?d.jsx("a",{href:g,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:v}):v})]})]},y)})}),p.length===0&&d.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),d.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),d.jsx("button",{onClick:()=>f(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),s&&d.jsx("div",{onClick:()=>f(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const de="platform-kit",Ke=m.createContext(null);function Kt({children:t}){const[r,o]=m.useState([]),u=typeof window<"u"&&window.__MF_NAME__||de,s=m.useCallback((l,v,C,k)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:l,title:v,message:C,mfeName:u,timestamp:Date.now(),duration:k}),[u]),f=m.useCallback(l=>{o(C=>[...C,l].slice(0,5));const v=l.duration||5e3;v>0&&setTimeout(()=>{o(C=>C.filter(k=>k.id!==l.id))},v)},[]),i=m.useCallback(l=>{const v=s(l.type,l.title,l.message,l.duration);f(v),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:v,bubbles:!0}))},[s,f]),b=m.useCallback((l,v="Успешно")=>{i({type:"success",title:v,message:l})},[i]),p=m.useCallback((l,v="Ошибка")=>{i({type:"error",title:v,message:l})},[i]),y=m.useCallback((l,v="Предупреждение")=>{i({type:"warning",title:v,message:l})},[i]),g=m.useCallback((l,v="Информация")=>{i({type:"info",title:v,message:l})},[i]),S=m.useCallback(l=>{o(v=>v.filter(C=>C.id!==l))},[]);return m.useEffect(()=>{if(typeof window>"u")return;const l=v=>{const C=v.detail;if(C&&C.type&&C.title&&C.message){const k={...C,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};f(k)}};return window.addEventListener("mfe-notification",l),()=>{window.removeEventListener("mfe-notification",l)}},[f]),d.jsxs(Ke.Provider,{value:{notify:i,notifySuccess:b,notifyError:p,notifyWarning:y,notifyInfo:g,removeNotification:S},children:[t,r.length>0&&d.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(l=>d.jsxs("div",{className:`notification notification-${l.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:l.type==="success"?"#d4edda":l.type==="error"?"#f8d7da":l.type==="warning"?"#fff3cd":"#d1ecf1",color:l.type==="success"?"#155724":l.type==="error"?"#721c24":l.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[d.jsxs("div",{style:{flex:1},children:[d.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:l.title}),d.jsx("p",{style:{margin:0,fontSize:"14px"},children:l.message}),d.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:l.mfeName})]}),d.jsx("button",{onClick:()=>S(l.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},l.id))})]})}function Xt(){const t=m.useContext(Ke);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function Zt(t){if(typeof window>"u")return;const r=window.__MF_NAME__||de,o={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:o,bubbles:!0}))}const Xe="platform-kit",H={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Xe}]`,...t)},info:(...t)=>{}};function Qt(){if(typeof window>"u")return{isAuthenticated:!1};const t=window.__SHELL_AUTH_INSTANCE__;if(t)return t;const r=window.__SHELL_AUTH__;return r?.authInstance?r.authInstance:{isAuthenticated:!1}}function er(){if(typeof window>"u")return;const t=window.__SHELL_AUTH_INSTANCE__;t?.signinRedirect?t.signinRedirect().catch(r=>{H.error("Failed to redirect to login:",r)}):window.location.href="/"}function tr(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}}function Ze(t={}){const r=t.name||Xe,o={log:(...s)=>H.log(`[API:${r}]`,...s),warn:(...s)=>H.warn(`[API:${r}]`,...s),error:(...s)=>H.error(`[API:${r}]`,...s),info:(...s)=>H.info(`[API:${r}]`,...s)},u=Ft.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return u.interceptors.request.use(s=>{const f=Qt();if(f?.isAuthenticated){const i=f.user?.profile?.access_token;i&&s.headers&&(s.headers.Authorization=`Bearer ${i}`,o.info("Auth token attached"))}else o.info("User not authenticated - request without token");return o.log(`${s.method?.toUpperCase()} ${s.url}`),s},s=>(o.error("Request interceptor error:",s.message),Promise.reject(s))),u.interceptors.response.use(s=>(o.log(`Response ${s.status}:`,s.config.url),s),s=>{const f=s.response?.status,i=s.config?.url;return f===401?(o.warn("401 Unauthorized - triggering re-auth"),er()):f===403?o.warn("403 Forbidden - insufficient permissions"):f===404?o.warn("404 Not found:",i):f===429?o.warn("429 Rate limited"):f===500?o.error("500 Server error:",i):s.response?o.warn(`Error ${f}:`,s.message):o.error("Network error - backend may be unavailable:",i),Promise.reject(tr(s))}),u}const G=Ze();async function rr(t,r,o=G){const u=await o.get(t,{params:r});return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function nr(t,r,o=G){const u=await o.post(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function or(t,r,o=G){const u=await o.put(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function ar(t,r=G){const o=await r.delete(t);return{data:o.data,status:o.status,ok:o.status>=200&&o.status<300}}function z(t,r){const o=r?.prefix?`[${r.prefix}]`:`[${t}]`;return{log:(...u)=>{},warn:(...u)=>{},error:(...u)=>{console.error(o,...u)},info:(...u)=>{}}}const ir=z("platform-kit",{prefix:"AUTH"}),sr=z("platform-kit",{prefix:"API"}),ur=z("platform-kit",{prefix:"ERROR"}),lr=z("platform-kit",{prefix:"INFO"}),cr={},fr={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function ge(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function Qe(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function et(){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 me(){const t=cr;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let ee=null,pe=!1;function tt(t,r){const o=ge(t);if(o)return o;if(pe&&ee)return ee;const u=[{source:"window.__MF_NAME__",value:Qe()},{source:"sessionStorage.mf-config",value:et()},{source:"import.meta.env.VITE_MFE_NAME",value:me()}];for(const{source:f,value:i}of u)if(i)return ee=i,pe=!0,i;if(r)return r;const s="Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw fr.error(s),new Error(s)}function dr(t){return tt(t)}function rt(t){return ge(t)?"props.mfeName":Qe()?"window.__MF_NAME__":et()?"sessionStorage.mf-config":me()?"import.meta.env.VITE_MFE_NAME":null}function pr(t){return rt(t)!==null}function gr(){ee=null,pe=!1}function mr(t){const r=[];return ge(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")),me()&&r.push("import.meta.env.VITE_MFE_NAME"),r}exports.ErrorBoundary=Jt;exports.NotificationProvider=Kt;exports.VersionInfo=qt;exports.api=G;exports.apiLogger=sr;exports.authLogger=ir;exports.createApiClient=Ze;exports.createMfLogger=z;exports.del=ar;exports.dispatchNotification=Zt;exports.errorLogger=ur;exports.get=rr;exports.getAllMfeNameSources=mr;exports.getAuth=Q;exports.getMfeName=tt;exports.getMfeNameSource=rt;exports.hasMfeName=pr;exports.infoLogger=lr;exports.post=nr;exports.put=or;exports.requireMfeName=dr;exports.resetMfeNameCache=gr;exports.useApi=Vt;exports.useInfoData=Ye;exports.useNotification=Xt;exports.usePermissions=Bt;exports.useShellAuth=ze;exports.useV1Config=Ut;
18
+ ${s}`]})]}),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 F={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function Zt({mfeName:t}){const{data:r,isLoading:s,error:u}=qe({mfeName:t}),[o,p]=l.useState(!1);if(s)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 a=r,S=a.BUILD_VERSION||a.IMAGE_VERSION||a.APP_NAME||"N/A",d=[];return a.APP_NAME&&d.push({key:"APP_NAME",value:a.APP_NAME,label:"Приложение",icon:F.apps}),a.BUILD_VERSION&&d.push({key:"BUILD_VERSION",value:a.BUILD_VERSION,label:"Версия",icon:F.tags}),a.IMAGE_VERSION&&d.push({key:"IMAGE_VERSION",value:a.IMAGE_VERSION,label:"Образ",icon:F.storage}),a.GIT_COMMIT&&d.push({key:"GIT_COMMIT",value:a.GIT_COMMIT,label:"Commit",icon:F.spreadsheet}),a.GIT_BRANCH&&d.push({key:"GIT_BRANCH",value:a.GIT_BRANCH,label:"Ветка",icon:F.spreadsheet}),a.CI_COMMIT_AUTHOR&&d.push({key:"CI_COMMIT_AUTHOR",value:a.CI_COMMIT_AUTHOR,label:"Автор",icon:F.user}),a.CI_COMMIT_TIMESTAMP&&d.push({key:"CI_COMMIT_TIMESTAMP",value:a.CI_COMMIT_TIMESTAMP,label:"Дата",icon:F.clock}),a.CI_JOB_URL&&d.push({key:"CI_JOB_URL",value:a.CI_JOB_URL,label:"CI Job",icon:F.link}),a.CI_PIPELINE_URL&&d.push({key:"CI_PIPELINE_URL",value:a.CI_PIPELINE_URL,label:"Pipeline",icon:F.link}),a.CI_COMMIT_MESSAGE&&(a.CI_COMMIT_MESSAGE.length>60?a.CI_COMMIT_MESSAGE.substring(0,57)+"":a.CI_COMMIT_MESSAGE,d.push({key:"CI_COMMIT_MESSAGE",value:a.CI_COMMIT_MESSAGE,label:"Сообщение",icon:F.code})),m.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[m.jsxs("button",{onClick:()=>p(!o),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:F.info}),m.jsx("span",{className:"text-dark",children:S})]}),o&&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:F.apps}),m.jsx("strong",{children:a.APP_NAME||t})]}),m.jsxs("div",{style:{marginBottom:"12px"},children:[m.jsx("span",{className:"text-muted",children:"Версия: "}),m.jsx("strong",{children:S})]}),d.length>0&&m.jsx("div",{style:{fontSize:"13px"},children:d.map(({key:y,value:f,label:_,icon:c})=>{const v=f.length>40&&(y.includes("URL")||y.includes("MESSAGE"))?`${f.substring(0,37)}...`:f;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:_}),m.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:f,children:y.includes("URL")?m.jsx("a",{href:f,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:v}):v})]})]},y)})}),d.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:()=>p(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),o&&m.jsx("div",{onClick:()=>p(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const ge="platform-kit",Ze=l.createContext(null);function Qt({children:t}){const[r,s]=l.useState([]),u=typeof window<"u"&&window.__MF_NAME__||ge,o=l.useCallback((c,v,b,I)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:c,title:v,message:b,mfeName:u,timestamp:Date.now(),duration:I}),[u]),p=l.useCallback(c=>{s(b=>[...b,c].slice(0,5));const v=c.duration||5e3;v>0&&setTimeout(()=>{s(b=>b.filter(I=>I.id!==c.id))},v)},[]),a=l.useCallback(c=>{const v=o(c.type,c.title,c.message,c.duration);p(v),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:v,bubbles:!0}))},[o,p]),S=l.useCallback((c,v="Успешно")=>{a({type:"success",title:v,message:c})},[a]),d=l.useCallback((c,v="Ошибка")=>{a({type:"error",title:v,message:c})},[a]),y=l.useCallback((c,v="Предупреждение")=>{a({type:"warning",title:v,message:c})},[a]),f=l.useCallback((c,v="Информация")=>{a({type:"info",title:v,message:c})},[a]),_=l.useCallback(c=>{s(v=>v.filter(b=>b.id!==c))},[]);return l.useEffect(()=>{if(typeof window>"u")return;const c=v=>{const b=v.detail;if(b&&b.type&&b.title&&b.message){const I={...b,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};p(I)}};return window.addEventListener("mfe-notification",c),()=>{window.removeEventListener("mfe-notification",c)}},[p]),m.jsxs(Ze.Provider,{value:{notify:a,notifySuccess:S,notifyError:d,notifyWarning:y,notifyInfo:f,removeNotification:_},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:()=>_(c.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},c.id))})]})}function er(){const t=l.useContext(Ze);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function tr(t){if(typeof window>"u")return;const r=window.__MF_NAME__||ge,s={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:s,bubbles:!0}))}const Qe="platform-kit",Y={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Qe}]`,...t)},info:(...t)=>{}};function rr(){if(typeof window>"u")return{isAuthenticated:!1};const t=window.__SHELL_AUTH_INSTANCE__;if(t)return t;const r=window.__SHELL_AUTH__;return r?.authInstance?r.authInstance:{isAuthenticated:!1}}function nr(){if(typeof window>"u")return;const t=window.__SHELL_AUTH_INSTANCE__;t?.signinRedirect?t.signinRedirect().catch(r=>{Y.error("Failed to redirect to login:",r)}):window.location.href="/"}function sr(t){const r=t.response;let s="unknown";return r?r.status===401?s="unauthorized":r.status===403?s="forbidden":r.status===404?s="not_found":r.status>=500&&(s="server"):s="network",{message:r?.data?.message??t.message??"Unknown error",code:r?.data?.code,status:r?.status,type:s,timestamp:Date.now(),url:t.config?.url}}function et(t={}){const r=t.name||Qe,s={log:(...o)=>Y.log(`[API:${r}]`,...o),warn:(...o)=>Y.warn(`[API:${r}]`,...o),error:(...o)=>Y.error(`[API:${r}]`,...o),info:(...o)=>Y.info(`[API:${r}]`,...o)},u=Dt.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return u.interceptors.request.use(o=>{const p=rr();if(p?.isAuthenticated){const a=p.user?.profile?.access_token;a&&o.headers&&(o.headers.Authorization=`Bearer ${a}`,s.info("Auth token attached"))}else s.info("User not authenticated - request without token");return s.log(`${o.method?.toUpperCase()} ${o.url}`),o},o=>(s.error("Request interceptor error:",o.message),Promise.reject(o))),u.interceptors.response.use(o=>(s.log(`Response ${o.status}:`,o.config.url),o),o=>{const p=o.response?.status,a=o.config?.url;return p===401?(s.warn("401 Unauthorized - triggering re-auth"),nr()):p===403?s.warn("403 Forbidden - insufficient permissions"):p===404?s.warn("404 Not found:",a):p===429?s.warn("429 Rate limited"):p===500?s.error("500 Server error:",a):o.response?s.warn(`Error ${p}:`,o.message):s.error("Network error - backend may be unavailable:",a),Promise.reject(sr(o))}),u}const q=et();async function ar(t,r,s=q){const u=await s.get(t,{params:r});return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function or(t,r,s=q){const u=await s.post(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function ir(t,r,s=q){const u=await s.put(t,r);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function ur(t,r=q){const s=await r.delete(t);return{data:s.data,status:s.status,ok:s.status>=200&&s.status<300}}function K(t,r){const s=r?.prefix?`[${r.prefix}]`:`[${t}]`;return{log:(...u)=>{},warn:(...u)=>{},error:(...u)=>{console.error(s,...u)},info:(...u)=>{}}}const cr=K("platform-kit",{prefix:"AUTH"}),lr=K("platform-kit",{prefix:"API"}),fr=K("platform-kit",{prefix:"ERROR"}),dr=K("platform-kit",{prefix:"INFO"}),pr={},hr={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function _e(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function tt(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function rt(){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 ve(){const t=pr;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let se=null,me=!1;function nt(t,r){const s=_e(t);if(s)return s;if(me&&se)return se;const u=[{source:"window.__MF_NAME__",value:tt()},{source:"sessionStorage.mf-config",value:rt()},{source:"import.meta.env.VITE_MFE_NAME",value:ve()}];for(const{source:p,value:a}of u)if(a)return se=a,me=!0,a;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 hr.error(o),new Error(o)}function gr(t){return nt(t)}function st(t){return _e(t)?"props.mfeName":tt()?"window.__MF_NAME__":rt()?"sessionStorage.mf-config":ve()?"import.meta.env.VITE_MFE_NAME":null}function mr(t){return st(t)!==null}function _r(){se=null,me=!1}function vr(t){const r=[];return _e(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")),ve()&&r.push("import.meta.env.VITE_MFE_NAME"),r}exports.ErrorBoundary=Xt;exports.NotificationProvider=Qt;exports.VersionInfo=Zt;exports.api=q;exports.apiLogger=lr;exports.authLogger=cr;exports.createApiClient=et;exports.createMfLogger=K;exports.del=ur;exports.dispatchNotification=tr;exports.errorLogger=fr;exports.get=ar;exports.getAllMfeNameSources=vr;exports.getAuth=ne;exports.getMfeName=nt;exports.getMfeNameSource=st;exports.hasMfeName=mr;exports.infoLogger=dr;exports.post=or;exports.put=ir;exports.requireMfeName=gr;exports.resetMfeNameCache=_r;exports.useApi=Vt;exports.useFeatureAdmin=Wt;exports.useFeatures=zt;exports.useInfoData=qe;exports.useMicrofrontendsFeatures=Gt;exports.useNotification=er;exports.usePermissions=Ht;exports.useShellAuth=J;exports.useV1Config=Ut;