@ibdop/platform-kit 1.0.0 → 1.0.2

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/dist/index.umd.js CHANGED
@@ -1,18 +1,18 @@
1
- (function(E,p){typeof exports=="object"&&typeof module<"u"?p(exports,require("react"),require("axios")):typeof define=="function"&&define.amd?define(["exports","react","axios"],p):(E=typeof globalThis<"u"?globalThis:E||self,p(E.PlatformKit={},E.React,E.axios))})(this,(function(E,p,Ze){"use strict";const pe={log:(...n)=>{},warn:(...n)=>{}};function K(){if(typeof window>"u")return null;const n=window;if(n.__SHELL_AUTH_INSTANCE__)return n.__SHELL_AUTH_INSTANCE__;const r=window;return r.__SHELL_AUTH__?.authInstance?r.__SHELL_AUTH__.authInstance:null}function he(){const[n,r]=p.useState(null),[a,l]=p.useState(!0),s=p.useRef(0),d=20,i=p.useCallback(()=>K(),[]);p.useEffect(()=>{const b=i();if(b){r(b),l(!1);return}const g=c=>{r(c.detail),l(!1)},R=setInterval(()=>{s.current++;const c=i();c?(pe.log("Auth found via polling, attempts:",s.current),r(c),l(!1),clearInterval(R)):s.current>=d&&(l(!1),clearInterval(R))},500);return window.addEventListener("shell-auth-ready",g),()=>{clearInterval(R),window.removeEventListener("shell-auth-ready",g)}},[i]);const h=n||{user:null,isAuthenticated:!1,isLoading:a,signinRedirect:async()=>{const b=K();b?.signinRedirect?await b.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const b=K();b?.removeUser&&await b.removeUser()}};return pe.log("Auth result:",{isAuthenticated:h.isAuthenticated,isLoading:h.isLoading}),h}const Qe={log:(...n)=>{},warn:(...n)=>{},error:(...n)=>{console.error("[useInfoData]",...n)}};function $e(n){if(n)return n;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function ge(n){const[r,a]=p.useState(null),[l,s]=p.useState(!0),[d,i]=p.useState(null),x=p.useCallback(()=>{const b=$e(n?.mfeName).replace("@ib-dop/","");s(!0),i(null),fetch(`/svc/${b}/info.json`).then(g=>{if(!g.ok)throw new Error(`HTTP ${g.status}: ${g.statusText}`);return g.json()}).then(g=>{a(g)}).catch(g=>{Qe.error("Failed to load info:",g),i(g instanceof Error?g.message:String(g))}).finally(()=>{s(!1)})},[n?.mfeName]);return p.useEffect(()=>{x()},[x]),{data:r,isLoading:l,error:d,refetch:x}}const te={log:(...n)=>{},warn:(...n)=>{},error:(...n)=>{console.error("[useV1Config]",...n)}},X={authority:"",client_id:"",environment:"development"};function qe(){const[n,r]=p.useState(null),[a,l]=p.useState(!0),[s,d]=p.useState(null);return p.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){d("sessionStorage not available"),r(X),l(!1);return}try{const x=sessionStorage.getItem("config");if(x){const h=JSON.parse(x);r({...X,...h}),d(null),te.log("Config loaded successfully")}else r(X),d("Config not found in sessionStorage"),te.warn("Config not found in sessionStorage")}catch(x){te.error("Error parsing config:",x),r(X),d("Error parsing config")}finally{l(!1)}})()},[]),{data:n,isLoading:a,error:s}}function me(n){if(typeof window>"u")return;const r=window.__MF_NAME__||"unknown",a={...n,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}function ve(n,r){const a={network:{title:"Нет подключения",message:"Сервер недоступен. Проверьте подключение к интернету."},unauthorized:{title:"Требуется вход",message:"Ваша сессия истекла. Войдите в систему снова."},forbidden:{title:"Доступ запрещён",message:"У вас нет прав для выполнения этого действия."},not_found:{title:"Не найдено",message:"Запрошенный ресурс не найден."},server:{title:"Ошибка сервера",message:"Произошла ошибка на сервере. Попробуйте позже."},client:{title:"Ошибка",message:n.message||"Произошла ошибка при выполнении запроса."},unknown:{title:"Неизвестная ошибка",message:n.message||"Произошла неизвестная ошибка."}},l=a[n.type]||a.unknown;me({type:n.type==="network"?"warning":"error",title:l.title,message:r?`${l.message} (${r})`:l.message})}function et(n,r={}){const{notifyOnError:a=!0,notifyOnSuccess:l=!1,successMessage:s,errorContext:d,onSuccess:i,onError:x}=r,[h,b]=p.useState(null),[g,R]=p.useState(null),[c,_]=p.useState(!1),I=g!==null,M=h!==null&&!c&&!I,ae=p.useCallback(async()=>{_(!0),R(null);try{const S=await n();if(S.ok)return b(S.data),l&&s&&me({type:"success",title:"Успешно",message:s}),i?.(S.data),S.data;{const N={message:S.data||"Request failed",status:S.status,type:"client",timestamp:Date.now()};return R(N),a&&ve(N,d),x?.(N),null}}catch(S){const N=S;return R(N),a&&ve(N,d),x?.(N),null}finally{_(!1)}},[n,a,l,s,d,i,x]),P=p.useCallback(()=>{b(null),R(null),_(!1)},[]);return{data:h,error:g,isLoading:c,isError:I,isSuccess:M,execute:ae,reset:P}}const tt={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 rt(n={}){const r=he(),a=p.useMemo(()=>({...tt,...n}),[n]),l=p.useMemo(()=>{const d=r.user?.profile?.realm_roles||r.user?.profile?.roles||[];return Array.isArray(d)?d:[d]},[r.user]),s=d=>d.includes("all")?!0:d.some(i=>l.includes(i));return{canView:s(a.canView),canEdit:s(a.canEdit),canDelete:s(a.canDelete),canAdmin:s(a.canAdmin),canViewSensitiveData:s(a.canViewSensitiveData),canExportData:s(a.canExportData),canManageUsers:s(a.canManageUsers)}}var Z={exports:{}},B={};var _e;function nt(){if(_e)return B;_e=1;var n=p,r=Symbol.for("react.element"),a=Symbol.for("react.fragment"),l=Object.prototype.hasOwnProperty,s=n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,d={key:!0,ref:!0,__self:!0,__source:!0};function i(x,h,b){var g,R={},c=null,_=null;b!==void 0&&(c=""+b),h.key!==void 0&&(c=""+h.key),h.ref!==void 0&&(_=h.ref);for(g in h)l.call(h,g)&&!d.hasOwnProperty(g)&&(R[g]=h[g]);if(x&&x.defaultProps)for(g in h=x.defaultProps,h)R[g]===void 0&&(R[g]=h[g]);return{$$typeof:r,type:x,key:c,ref:_,props:R,_owner:s.current}}return B.Fragment=a,B.jsx=i,B.jsxs=i,B}var W={};var ye;function at(){return ye||(ye=1,process.env.NODE_ENV!=="production"&&(function(){var n=p,r=Symbol.for("react.element"),a=Symbol.for("react.portal"),l=Symbol.for("react.fragment"),s=Symbol.for("react.strict_mode"),d=Symbol.for("react.profiler"),i=Symbol.for("react.provider"),x=Symbol.for("react.context"),h=Symbol.for("react.forward_ref"),b=Symbol.for("react.suspense"),g=Symbol.for("react.suspense_list"),R=Symbol.for("react.memo"),c=Symbol.for("react.lazy"),_=Symbol.for("react.offscreen"),I=Symbol.iterator,M="@@iterator";function ae(e){if(e===null||typeof e!="object")return null;var t=I&&e[I]||e[M];return typeof t=="function"?t:null}var P=n.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function S(e){{for(var t=arguments.length,o=new Array(t>1?t-1:0),u=1;u<t;u++)o[u-1]=arguments[u];N("error",e,o)}}function N(e,t,o){{var u=P.ReactDebugCurrentFrame,y=u.getStackAddendum();y!==""&&(t+="%s",o=o.concat([y]));var w=o.map(function(v){return String(v)});w.unshift("Warning: "+t),Function.prototype.apply.call(console[e],console,w)}}var xt=!1,St=!1,Rt=!1,Ct=!1,At=!1,Re;Re=Symbol.for("react.module.reference");function It(e){return!!(typeof e=="string"||typeof e=="function"||e===l||e===d||At||e===s||e===b||e===g||Ct||e===_||xt||St||Rt||typeof e=="object"&&e!==null&&(e.$$typeof===c||e.$$typeof===R||e.$$typeof===i||e.$$typeof===x||e.$$typeof===h||e.$$typeof===Re||e.getModuleId!==void 0))}function kt(e,t,o){var u=e.displayName;if(u)return u;var y=t.displayName||t.name||"";return y!==""?o+"("+y+")":o}function Ce(e){return e.displayName||"Context"}function D(e){if(e==null)return null;if(typeof e.tag=="number"&&S("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 l:return"Fragment";case a:return"Portal";case d:return"Profiler";case s:return"StrictMode";case b:return"Suspense";case g:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case x:var t=e;return Ce(t)+".Consumer";case i:var o=e;return Ce(o._context)+".Provider";case h:return kt(e,e.render,"ForwardRef");case R:var u=e.displayName||null;return u!==null?u:D(e.type)||"Memo";case c:{var y=e,w=y._payload,v=y._init;try{return D(v(w))}catch{return null}}}return null}var L=Object.assign,Y=0,Ae,Ie,ke,Te,Oe,je,Me;function Ne(){}Ne.__reactDisabledLog=!0;function Tt(){{if(Y===0){Ae=console.log,Ie=console.info,ke=console.warn,Te=console.error,Oe=console.group,je=console.groupCollapsed,Me=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Ne,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}Y++}}function Ot(){{if(Y--,Y===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:L({},e,{value:Ae}),info:L({},e,{value:Ie}),warn:L({},e,{value:ke}),error:L({},e,{value:Te}),group:L({},e,{value:Oe}),groupCollapsed:L({},e,{value:je}),groupEnd:L({},e,{value:Me})})}Y<0&&S("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var oe=P.ReactCurrentDispatcher,se;function Q(e,t,o){{if(se===void 0)try{throw Error()}catch(y){var u=y.stack.trim().match(/\n( *(at )?)/);se=u&&u[1]||""}return`
2
- `+se+e}}var ie=!1,$;{var jt=typeof WeakMap=="function"?WeakMap:Map;$=new jt}function Pe(e,t){if(!e||ie)return"";{var o=$.get(e);if(o!==void 0)return o}var u;ie=!0;var y=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var w;w=oe.current,oe.current=null,Tt();try{if(t){var v=function(){throw Error()};if(Object.defineProperty(v.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(v,[])}catch(T){u=T}Reflect.construct(e,[],v)}else{try{v.call()}catch(T){u=T}e.call(v.prototype)}}else{try{throw Error()}catch(T){u=T}e()}}catch(T){if(T&&u&&typeof T.stack=="string"){for(var m=T.stack.split(`
3
- `),k=u.stack.split(`
4
- `),C=m.length-1,A=k.length-1;C>=1&&A>=0&&m[C]!==k[A];)A--;for(;C>=1&&A>=0;C--,A--)if(m[C]!==k[A]){if(C!==1||A!==1)do if(C--,A--,A<0||m[C]!==k[A]){var j=`
5
- `+m[C].replace(" at new "," at ");return e.displayName&&j.includes("<anonymous>")&&(j=j.replace("<anonymous>",e.displayName)),typeof e=="function"&&$.set(e,j),j}while(C>=1&&A>=0);break}}}finally{ie=!1,oe.current=w,Ot(),Error.prepareStackTrace=y}var V=e?e.displayName||e.name:"",F=V?Q(V):"";return typeof e=="function"&&$.set(e,F),F}function Mt(e,t,o){return Pe(e,!1)}function Nt(e){var t=e.prototype;return!!(t&&t.isReactComponent)}function q(e,t,o){if(e==null)return"";if(typeof e=="function")return Pe(e,Nt(e));if(typeof e=="string")return Q(e);switch(e){case b:return Q("Suspense");case g:return Q("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case h:return Mt(e.render);case R:return q(e.type,t,o);case c:{var u=e,y=u._payload,w=u._init;try{return q(w(y),t,o)}catch{}}}return""}var J=Object.prototype.hasOwnProperty,De={},Le=P.ReactDebugCurrentFrame;function ee(e){if(e){var t=e._owner,o=q(e.type,e._source,t?t.type:null);Le.setExtraStackFrame(o)}else Le.setExtraStackFrame(null)}function Pt(e,t,o,u,y){{var w=Function.call.bind(J);for(var v in e)if(w(e,v)){var m=void 0;try{if(typeof e[v]!="function"){var k=Error((u||"React class")+": "+o+" type `"+v+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[v]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw k.name="Invariant Violation",k}m=e[v](t,v,u,o,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(C){m=C}m&&!(m instanceof Error)&&(ee(y),S("%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).",u||"React class",o,v,typeof m),ee(null)),m instanceof Error&&!(m.message in De)&&(De[m.message]=!0,ee(y),S("Failed %s type: %s",o,m.message),ee(null))}}}var Dt=Array.isArray;function le(e){return Dt(e)}function Lt(e){{var t=typeof Symbol=="function"&&Symbol.toStringTag,o=t&&e[Symbol.toStringTag]||e.constructor.name||"Object";return o}}function Ft(e){try{return Fe(e),!1}catch{return!0}}function Fe(e){return""+e}function Ue(e){if(Ft(e))return S("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",Lt(e)),Fe(e)}var Ve=P.ReactCurrentOwner,Ut={key:!0,ref:!0,__self:!0,__source:!0},Be,We;function Vt(e){if(J.call(e,"ref")){var t=Object.getOwnPropertyDescriptor(e,"ref").get;if(t&&t.isReactWarning)return!1}return e.ref!==void 0}function Bt(e){if(J.call(e,"key")){var t=Object.getOwnPropertyDescriptor(e,"key").get;if(t&&t.isReactWarning)return!1}return e.key!==void 0}function Wt(e,t){typeof e.ref=="string"&&Ve.current}function Ht(e,t){{var o=function(){Be||(Be=!0,S("%s: `key` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",t))};o.isReactWarning=!0,Object.defineProperty(e,"key",{get:o,configurable:!0})}}function Gt(e,t){{var o=function(){We||(We=!0,S("%s: `ref` is not a prop. Trying to access it will result in `undefined` being returned. If you need to access the same value within the child component, you should pass it as a different prop. (https://reactjs.org/link/special-props)",t))};o.isReactWarning=!0,Object.defineProperty(e,"ref",{get:o,configurable:!0})}}var zt=function(e,t,o,u,y,w,v){var m={$$typeof:r,type:e,key:t,ref:o,props:v,_owner:w};return m._store={},Object.defineProperty(m._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(m,"_self",{configurable:!1,enumerable:!1,writable:!1,value:u}),Object.defineProperty(m,"_source",{configurable:!1,enumerable:!1,writable:!1,value:y}),Object.freeze&&(Object.freeze(m.props),Object.freeze(m)),m};function Yt(e,t,o,u,y){{var w,v={},m=null,k=null;o!==void 0&&(Ue(o),m=""+o),Bt(t)&&(Ue(t.key),m=""+t.key),Vt(t)&&(k=t.ref,Wt(t,y));for(w in t)J.call(t,w)&&!Ut.hasOwnProperty(w)&&(v[w]=t[w]);if(e&&e.defaultProps){var C=e.defaultProps;for(w in C)v[w]===void 0&&(v[w]=C[w])}if(m||k){var A=typeof e=="function"?e.displayName||e.name||"Unknown":e;m&&Ht(v,A),k&&Gt(v,A)}return zt(e,m,k,y,u,Ve.current,v)}}var ce=P.ReactCurrentOwner,He=P.ReactDebugCurrentFrame;function U(e){if(e){var t=e._owner,o=q(e.type,e._source,t?t.type:null);He.setExtraStackFrame(o)}else He.setExtraStackFrame(null)}var ue;ue=!1;function fe(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function Ge(){{if(ce.current){var e=D(ce.current.type);if(e)return`
1
+ (function(_,p){typeof exports=="object"&&typeof module<"u"?p(exports,require("react"),require("axios")):typeof define=="function"&&define.amd?define(["exports","react","axios"],p):(_=typeof globalThis<"u"?globalThis:_||self,p(_.PlatformKit={},_.React,_.axios))})(this,(function(_,p,at){"use strict";const _e={log:(...t)=>{},warn:(...t)=>{}};function K(){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 ve(){const[t,r]=p.useState(null),[a,l]=p.useState(!0),s=p.useRef(0),d=20,i=p.useCallback(()=>K(),[]);p.useEffect(()=>{const w=i();if(w){r(w),l(!1);return}const m=u=>{r(u.detail),l(!1)},R=setInterval(()=>{s.current++;const u=i();u?(_e.log("Auth found via polling, attempts:",s.current),r(u),l(!1),clearInterval(R)):s.current>=d&&(l(!1),clearInterval(R))},500);return window.addEventListener("shell-auth-ready",m),()=>{clearInterval(R),window.removeEventListener("shell-auth-ready",m)}},[i]);const g=t||{user:null,isAuthenticated:!1,isLoading:a,signinRedirect:async()=>{const w=K();w?.signinRedirect?await w.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const w=K();w?.removeUser&&await w.removeUser()}};return _e.log("Auth result:",{isAuthenticated:g.isAuthenticated,isLoading:g.isLoading}),g}const ot={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function it(t){if(t)return t;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function Ee(t){const[r,a]=p.useState(null),[l,s]=p.useState(!0),[d,i]=p.useState(null),x=p.useCallback(()=>{const w=it(t?.mfeName).replace("@ib-dop/","");s(!0),i(null),fetch(`/svc/${w}/info.json`).then(m=>{if(!m.ok)throw new Error(`HTTP ${m.status}: ${m.statusText}`);return m.json()}).then(m=>{a(m)}).catch(m=>{ot.error("Failed to load info:",m),i(m instanceof Error?m.message:String(m))}).finally(()=>{s(!1)})},[t?.mfeName]);return p.useEffect(()=>{x()},[x]),{data:r,isLoading:l,error:d,refetch:x}}const re={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},X={authority:"",client_id:"",environment:"development"};function st(){const[t,r]=p.useState(null),[a,l]=p.useState(!0),[s,d]=p.useState(null);return p.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){d("sessionStorage not available"),r(X),l(!1);return}try{const x=sessionStorage.getItem("config");if(x){const g=JSON.parse(x);r({...X,...g}),d(null),re.log("Config loaded successfully")}else r(X),d("Config not found in sessionStorage"),re.warn("Config not found in sessionStorage")}catch(x){re.error("Error parsing config:",x),r(X),d("Error parsing config")}finally{l(!1)}})()},[]),{data:t,isLoading:a,error:s}}function ye(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 we(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||"Произошла неизвестная ошибка."}},l=a[t.type]||a.unknown;ye({type:t.type==="network"?"warning":"error",title:l.title,message:r?`${l.message} (${r})`:l.message})}function lt(t,r={}){const{notifyOnError:a=!0,notifyOnSuccess:l=!1,successMessage:s,errorContext:d,onSuccess:i,onError:x}=r,[g,w]=p.useState(null),[m,R]=p.useState(null),[u,E]=p.useState(!1),M=m!==null,O=g!==null&&!u&&!M,le=p.useCallback(async()=>{E(!0),R(null);try{const S=await t();if(S.ok)return w(S.data),l&&s&&ye({type:"success",title:"Успешно",message:s}),i?.(S.data),S.data;{const j={message:S.data||"Request failed",status:S.status,type:"client",timestamp:Date.now()};return R(j),a&&we(j,d),x?.(j),null}}catch(S){const j=S;return R(j),a&&we(j,d),x?.(j),null}finally{E(!1)}},[t,a,l,s,d,i,x]),P=p.useCallback(()=>{w(null),R(null),E(!1)},[]);return{data:g,error:m,isLoading:u,isError:M,isSuccess:O,execute:le,reset:P}}const ut={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 ct(t={}){const r=ve(),a=p.useMemo(()=>({...ut,...t}),[t]),l=p.useMemo(()=>{const d=r.user?.profile?.realm_roles||r.user?.profile?.roles||[];return Array.isArray(d)?d:[d]},[r.user]),s=d=>d.includes("all")?!0:d.some(i=>l.includes(i));return{canView:s(a.canView),canEdit:s(a.canEdit),canDelete:s(a.canDelete),canAdmin:s(a.canAdmin),canViewSensitiveData:s(a.canViewSensitiveData),canExportData:s(a.canExportData),canManageUsers:s(a.canManageUsers)}}var Z={exports:{}},W={};var be;function ft(){if(be)return W;be=1;var t=p,r=Symbol.for("react.element"),a=Symbol.for("react.fragment"),l=Object.prototype.hasOwnProperty,s=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,d={key:!0,ref:!0,__self:!0,__source:!0};function i(x,g,w){var m,R={},u=null,E=null;w!==void 0&&(u=""+w),g.key!==void 0&&(u=""+g.key),g.ref!==void 0&&(E=g.ref);for(m in g)l.call(g,m)&&!d.hasOwnProperty(m)&&(R[m]=g[m]);if(x&&x.defaultProps)for(m in g=x.defaultProps,g)R[m]===void 0&&(R[m]=g[m]);return{$$typeof:r,type:x,key:u,ref:E,props:R,_owner:s.current}}return W.Fragment=a,W.jsx=i,W.jsxs=i,W}var B={};var xe;function dt(){return xe||(xe=1,process.env.NODE_ENV!=="production"&&(function(){var t=p,r=Symbol.for("react.element"),a=Symbol.for("react.portal"),l=Symbol.for("react.fragment"),s=Symbol.for("react.strict_mode"),d=Symbol.for("react.profiler"),i=Symbol.for("react.provider"),x=Symbol.for("react.context"),g=Symbol.for("react.forward_ref"),w=Symbol.for("react.suspense"),m=Symbol.for("react.suspense_list"),R=Symbol.for("react.memo"),u=Symbol.for("react.lazy"),E=Symbol.for("react.offscreen"),M=Symbol.iterator,O="@@iterator";function le(e){if(e===null||typeof e!="object")return null;var n=M&&e[M]||e[O];return typeof n=="function"?n:null}var P=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function S(e){{for(var n=arguments.length,o=new Array(n>1?n-1:0),c=1;c<n;c++)o[c-1]=arguments[c];j("error",e,o)}}function j(e,n,o){{var c=P.ReactDebugCurrentFrame,y=c.getStackAddendum();y!==""&&(n+="%s",o=o.concat([y]));var b=o.map(function(v){return String(v)});b.unshift("Warning: "+n),Function.prototype.apply.call(console[e],console,b)}}var Ft=!1,Lt=!1,Ut=!1,Vt=!1,Wt=!1,Oe;Oe=Symbol.for("react.module.reference");function Bt(e){return!!(typeof e=="string"||typeof e=="function"||e===l||e===d||Wt||e===s||e===w||e===m||Vt||e===E||Ft||Lt||Ut||typeof e=="object"&&e!==null&&(e.$$typeof===u||e.$$typeof===R||e.$$typeof===i||e.$$typeof===x||e.$$typeof===g||e.$$typeof===Oe||e.getModuleId!==void 0))}function Ht(e,n,o){var c=e.displayName;if(c)return c;var y=n.displayName||n.name||"";return y!==""?o+"("+y+")":o}function je(e){return e.displayName||"Context"}function D(e){if(e==null)return null;if(typeof e.tag=="number"&&S("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 l:return"Fragment";case a:return"Portal";case d:return"Profiler";case s:return"StrictMode";case w:return"Suspense";case m:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case x:var n=e;return je(n)+".Consumer";case i:var o=e;return je(o._context)+".Provider";case g:return Ht(e,e.render,"ForwardRef");case R:var c=e.displayName||null;return c!==null?c:D(e.type)||"Memo";case u:{var y=e,b=y._payload,v=y._init;try{return D(v(b))}catch{return null}}}return null}var F=Object.assign,Y=0,Pe,De,Fe,Le,Ue,Ve,We;function Be(){}Be.__reactDisabledLog=!0;function Gt(){{if(Y===0){Pe=console.log,De=console.info,Fe=console.warn,Le=console.error,Ue=console.group,Ve=console.groupCollapsed,We=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Be,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}Y++}}function zt(){{if(Y--,Y===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:F({},e,{value:Pe}),info:F({},e,{value:De}),warn:F({},e,{value:Fe}),error:F({},e,{value:Le}),group:F({},e,{value:Ue}),groupCollapsed:F({},e,{value:Ve}),groupEnd:F({},e,{value:We})})}Y<0&&S("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var ue=P.ReactCurrentDispatcher,ce;function $(e,n,o){{if(ce===void 0)try{throw Error()}catch(y){var c=y.stack.trim().match(/\n( *(at )?)/);ce=c&&c[1]||""}return`
2
+ `+ce+e}}var fe=!1,q;{var Yt=typeof WeakMap=="function"?WeakMap:Map;q=new Yt}function He(e,n){if(!e||fe)return"";{var o=q.get(e);if(o!==void 0)return o}var c;fe=!0;var y=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var b;b=ue.current,ue.current=null,Gt();try{if(n){var v=function(){throw Error()};if(Object.defineProperty(v.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(v,[])}catch(N){c=N}Reflect.construct(e,[],v)}else{try{v.call()}catch(N){c=N}e.call(v.prototype)}}else{try{throw Error()}catch(N){c=N}e()}}catch(N){if(N&&c&&typeof N.stack=="string"){for(var h=N.stack.split(`
3
+ `),I=c.stack.split(`
4
+ `),A=h.length-1,C=I.length-1;A>=1&&C>=0&&h[A]!==I[C];)C--;for(;A>=1&&C>=0;A--,C--)if(h[A]!==I[C]){if(A!==1||C!==1)do if(A--,C--,C<0||h[A]!==I[C]){var k=`
5
+ `+h[A].replace(" at new "," at ");return e.displayName&&k.includes("<anonymous>")&&(k=k.replace("<anonymous>",e.displayName)),typeof e=="function"&&q.set(e,k),k}while(A>=1&&C>=0);break}}}finally{fe=!1,ue.current=b,zt(),Error.prepareStackTrace=y}var V=e?e.displayName||e.name:"",L=V?$(V):"";return typeof e=="function"&&q.set(e,L),L}function Jt(e,n,o){return He(e,!1)}function Kt(e){var n=e.prototype;return!!(n&&n.isReactComponent)}function ee(e,n,o){if(e==null)return"";if(typeof e=="function")return He(e,Kt(e));if(typeof e=="string")return $(e);switch(e){case w:return $("Suspense");case m:return $("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case g:return Jt(e.render);case R:return ee(e.type,n,o);case u:{var c=e,y=c._payload,b=c._init;try{return ee(b(y),n,o)}catch{}}}return""}var J=Object.prototype.hasOwnProperty,Ge={},ze=P.ReactDebugCurrentFrame;function te(e){if(e){var n=e._owner,o=ee(e.type,e._source,n?n.type:null);ze.setExtraStackFrame(o)}else ze.setExtraStackFrame(null)}function Xt(e,n,o,c,y){{var b=Function.call.bind(J);for(var v in e)if(b(e,v)){var h=void 0;try{if(typeof e[v]!="function"){var I=Error((c||"React class")+": "+o+" type `"+v+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[v]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw I.name="Invariant Violation",I}h=e[v](n,v,c,o,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(A){h=A}h&&!(h instanceof Error)&&(te(y),S("%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",o,v,typeof h),te(null)),h instanceof Error&&!(h.message in Ge)&&(Ge[h.message]=!0,te(y),S("Failed %s type: %s",o,h.message),te(null))}}}var Zt=Array.isArray;function de(e){return Zt(e)}function Qt(e){{var n=typeof Symbol=="function"&&Symbol.toStringTag,o=n&&e[Symbol.toStringTag]||e.constructor.name||"Object";return o}}function $t(e){try{return Ye(e),!1}catch{return!0}}function Ye(e){return""+e}function Je(e){if($t(e))return S("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",Qt(e)),Ye(e)}var Ke=P.ReactCurrentOwner,qt={key:!0,ref:!0,__self:!0,__source:!0},Xe,Ze;function er(e){if(J.call(e,"ref")){var n=Object.getOwnPropertyDescriptor(e,"ref").get;if(n&&n.isReactWarning)return!1}return e.ref!==void 0}function tr(e){if(J.call(e,"key")){var n=Object.getOwnPropertyDescriptor(e,"key").get;if(n&&n.isReactWarning)return!1}return e.key!==void 0}function rr(e,n){typeof e.ref=="string"&&Ke.current}function nr(e,n){{var o=function(){Xe||(Xe=!0,S("%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))};o.isReactWarning=!0,Object.defineProperty(e,"key",{get:o,configurable:!0})}}function ar(e,n){{var o=function(){Ze||(Ze=!0,S("%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))};o.isReactWarning=!0,Object.defineProperty(e,"ref",{get:o,configurable:!0})}}var or=function(e,n,o,c,y,b,v){var h={$$typeof:r,type:e,key:n,ref:o,props:v,_owner:b};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:y}),Object.freeze&&(Object.freeze(h.props),Object.freeze(h)),h};function ir(e,n,o,c,y){{var b,v={},h=null,I=null;o!==void 0&&(Je(o),h=""+o),tr(n)&&(Je(n.key),h=""+n.key),er(n)&&(I=n.ref,rr(n,y));for(b in n)J.call(n,b)&&!qt.hasOwnProperty(b)&&(v[b]=n[b]);if(e&&e.defaultProps){var A=e.defaultProps;for(b in A)v[b]===void 0&&(v[b]=A[b])}if(h||I){var C=typeof e=="function"?e.displayName||e.name||"Unknown":e;h&&nr(v,C),I&&ar(v,C)}return or(e,h,I,y,c,Ke.current,v)}}var pe=P.ReactCurrentOwner,Qe=P.ReactDebugCurrentFrame;function U(e){if(e){var n=e._owner,o=ee(e.type,e._source,n?n.type:null);Qe.setExtraStackFrame(o)}else Qe.setExtraStackFrame(null)}var ge;ge=!1;function me(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function $e(){{if(pe.current){var e=D(pe.current.type);if(e)return`
6
6
 
7
- Check the render method of \``+e+"`."}return""}}function Jt(e){return""}var ze={};function Kt(e){{var t=Ge();if(!t){var o=typeof e=="string"?e:e.displayName||e.name;o&&(t=`
7
+ Check the render method of \``+e+"`."}return""}}function sr(e){return""}var qe={};function lr(e){{var n=$e();if(!n){var o=typeof e=="string"?e:e.displayName||e.name;o&&(n=`
8
8
 
9
- Check the top-level render call using <`+o+">.")}return t}}function Ye(e,t){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var o=Kt(t);if(ze[o])return;ze[o]=!0;var u="";e&&e._owner&&e._owner!==ce.current&&(u=" It was passed a child from "+D(e._owner.type)+"."),U(e),S('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',o,u),U(null)}}function Je(e,t){{if(typeof e!="object")return;if(le(e))for(var o=0;o<e.length;o++){var u=e[o];fe(u)&&Ye(u,t)}else if(fe(e))e._store&&(e._store.validated=!0);else if(e){var y=ae(e);if(typeof y=="function"&&y!==e.entries)for(var w=y.call(e),v;!(v=w.next()).done;)fe(v.value)&&Ye(v.value,t)}}}function Xt(e){{var t=e.type;if(t==null||typeof t=="string")return;var o;if(typeof t=="function")o=t.propTypes;else if(typeof t=="object"&&(t.$$typeof===h||t.$$typeof===R))o=t.propTypes;else return;if(o){var u=D(t);Pt(o,e.props,"prop",u,e)}else if(t.PropTypes!==void 0&&!ue){ue=!0;var y=D(t);S("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",y||"Unknown")}typeof t.getDefaultProps=="function"&&!t.getDefaultProps.isReactClassApproved&&S("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function Zt(e){{for(var t=Object.keys(e.props),o=0;o<t.length;o++){var u=t[o];if(u!=="children"&&u!=="key"){U(e),S("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",u),U(null);break}}e.ref!==null&&(U(e),S("Invalid attribute `ref` supplied to `React.Fragment`."),U(null))}}var Ke={};function Xe(e,t,o,u,y,w){{var v=It(e);if(!v){var m="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(m+=" 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 k=Jt();k?m+=k:m+=Ge();var C;e===null?C="null":le(e)?C="array":e!==void 0&&e.$$typeof===r?(C="<"+(D(e.type)||"Unknown")+" />",m=" Did you accidentally export a JSX literal instead of a component?"):C=typeof e,S("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",C,m)}var A=Yt(e,t,o,y,w);if(A==null)return A;if(v){var j=t.children;if(j!==void 0)if(u)if(le(j)){for(var V=0;V<j.length;V++)Je(j[V],e);Object.freeze&&Object.freeze(j)}else S("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 Je(j,e)}if(J.call(t,"key")){var F=D(e),T=Object.keys(t).filter(function(rr){return rr!=="key"}),de=T.length>0?"{key: someKey, "+T.join(": ..., ")+": ...}":"{key: someKey}";if(!Ke[F+de]){var tr=T.length>0?"{"+T.join(": ..., ")+": ...}":"{}";S(`A props object containing a "key" prop is being spread into JSX:
9
+ Check the top-level render call using <`+o+">.")}return n}}function et(e,n){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var o=lr(n);if(qe[o])return;qe[o]=!0;var c="";e&&e._owner&&e._owner!==pe.current&&(c=" It was passed a child from "+D(e._owner.type)+"."),U(e),S('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',o,c),U(null)}}function tt(e,n){{if(typeof e!="object")return;if(de(e))for(var o=0;o<e.length;o++){var c=e[o];me(c)&&et(c,n)}else if(me(e))e._store&&(e._store.validated=!0);else if(e){var y=le(e);if(typeof y=="function"&&y!==e.entries)for(var b=y.call(e),v;!(v=b.next()).done;)me(v.value)&&et(v.value,n)}}}function ur(e){{var n=e.type;if(n==null||typeof n=="string")return;var o;if(typeof n=="function")o=n.propTypes;else if(typeof n=="object"&&(n.$$typeof===g||n.$$typeof===R))o=n.propTypes;else return;if(o){var c=D(n);Xt(o,e.props,"prop",c,e)}else if(n.PropTypes!==void 0&&!ge){ge=!0;var y=D(n);S("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",y||"Unknown")}typeof n.getDefaultProps=="function"&&!n.getDefaultProps.isReactClassApproved&&S("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function cr(e){{for(var n=Object.keys(e.props),o=0;o<n.length;o++){var c=n[o];if(c!=="children"&&c!=="key"){U(e),S("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",c),U(null);break}}e.ref!==null&&(U(e),S("Invalid attribute `ref` supplied to `React.Fragment`."),U(null))}}var rt={};function nt(e,n,o,c,y,b){{var v=Bt(e);if(!v){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 I=sr();I?h+=I:h+=$e();var A;e===null?A="null":de(e)?A="array":e!==void 0&&e.$$typeof===r?(A="<"+(D(e.type)||"Unknown")+" />",h=" Did you accidentally export a JSX literal instead of a component?"):A=typeof e,S("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",A,h)}var C=ir(e,n,o,y,b);if(C==null)return C;if(v){var k=n.children;if(k!==void 0)if(c)if(de(k)){for(var V=0;V<k.length;V++)tt(k[V],e);Object.freeze&&Object.freeze(k)}else S("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 tt(k,e)}if(J.call(n,"key")){var L=D(e),N=Object.keys(n).filter(function(hr){return hr!=="key"}),he=N.length>0?"{key: someKey, "+N.join(": ..., ")+": ...}":"{key: someKey}";if(!rt[L+he]){var mr=N.length>0?"{"+N.join(": ..., ")+": ...}":"{}";S(`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} />`,de,F,tr,F),Ke[F+de]=!0}}return e===l?Zt(A):Xt(A),A}}function Qt(e,t,o){return Xe(e,t,o,!0)}function $t(e,t,o){return Xe(e,t,o,!1)}var qt=$t,er=Qt;W.Fragment=l,W.jsx=qt,W.jsxs=er})()),W}var Ee;function ot(){return Ee||(Ee=1,process.env.NODE_ENV==="production"?Z.exports=nt():Z.exports=at()),Z.exports}var f=ot();const be="platform-kit",st=!1,re={log:(...n)=>{},warn:(...n)=>{},error:(...n)=>{console.error(`[${be}]`,...n)}};class it extends p.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 be}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 st}dispatchError(r,a){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const l=this.getMfeName();re.error("ErrorBoundary caught:",r);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:l,error:r.message||String(r),stack:r.stack,componentStack:a?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(s){re.error("Failed to dispatch mfe-error event:",s)}}static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,a){this.dispatchError(r,a),re.error("Error info:",a.componentStack)}handleCopy=()=>{const r=`Error in ${this.getMfeName()}:
14
+ <%s key={someKey} {...props} />`,he,L,mr,L),rt[L+he]=!0}}return e===l?cr(C):ur(C),C}}function fr(e,n,o){return nt(e,n,o,!0)}function dr(e,n,o){return nt(e,n,o,!1)}var pr=dr,gr=fr;B.Fragment=l,B.jsx=pr,B.jsxs=gr})()),B}var Se;function pt(){return Se||(Se=1,process.env.NODE_ENV==="production"?Z.exports=ft():Z.exports=dt()),Z.exports}var f=pt();const Re="platform-kit",gt=!1,ne={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Re}]`,...t)}};class mt extends p.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 Re}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 gt}dispatchError(r,a){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const l=this.getMfeName();ne.error("ErrorBoundary caught:",r);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:l,error:r.message||String(r),stack:r.stack,componentStack:a?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(s){ne.error("Failed to dispatch mfe-error event:",s)}}static getDerivedStateFromError(r){return{hasError:!0,error:r}}componentDidCatch(r,a){this.dispatchError(r,a),ne.error("Error info:",a.componentStack)}handleCopy=()=>{const r=`Error in ${this.getMfeName()}:
15
15
  ${this.state.error?.message}
16
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||"",l=this.shouldShowDetails(),s=this.getMfeName();return f.jsxs("div",{style:{padding:"20px",textAlign:"center",color:"#d32f2f",fontFamily:"monospace",background:"#ffebee",border:"1px solid #ef5350",borderRadius:"4px",margin:"10px"},children:[f.jsxs("h2",{style:{fontSize:"16px",margin:"0 0 8px 0"},children:["⚠️ Ошибка в ",s]}),f.jsx("p",{style:{fontSize:"12px",margin:0},children:"Произошла ошибка в микрофронтенде. Сообщение отправлено в shell."}),l&&f.jsxs("details",{style:{whiteSpace:"pre-wrap",textAlign:"left",marginTop:"10px",background:"#fff",padding:"8px",borderRadius:"4px"},children:[f.jsx("summary",{style:{cursor:"pointer",fontWeight:"bold"},children:"Детали ошибки"}),f.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
- ${a}`]})]}),f.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[f.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),f.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),f.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 O={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function lt({mfeName:n}){const{data:r,isLoading:a,error:l}=ge({mfeName:n}),[s,d]=p.useState(!1);if(a)return f.jsxs("span",{className:"text-muted small me-2",children:[f.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(l||!r)return f.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${l||"нет данных"}`,children:[f.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const i=r,x=i.BUILD_VERSION||i.IMAGE_VERSION||i.APP_NAME||"N/A",h=[];return i.APP_NAME&&h.push({key:"APP_NAME",value:i.APP_NAME,label:"Приложение",icon:O.apps}),i.BUILD_VERSION&&h.push({key:"BUILD_VERSION",value:i.BUILD_VERSION,label:"Версия",icon:O.tags}),i.IMAGE_VERSION&&h.push({key:"IMAGE_VERSION",value:i.IMAGE_VERSION,label:"Образ",icon:O.storage}),i.GIT_COMMIT&&h.push({key:"GIT_COMMIT",value:i.GIT_COMMIT,label:"Commit",icon:O.spreadsheet}),i.GIT_BRANCH&&h.push({key:"GIT_BRANCH",value:i.GIT_BRANCH,label:"Ветка",icon:O.spreadsheet}),i.CI_COMMIT_AUTHOR&&h.push({key:"CI_COMMIT_AUTHOR",value:i.CI_COMMIT_AUTHOR,label:"Автор",icon:O.user}),i.CI_COMMIT_TIMESTAMP&&h.push({key:"CI_COMMIT_TIMESTAMP",value:i.CI_COMMIT_TIMESTAMP,label:"Дата",icon:O.clock}),i.CI_JOB_URL&&h.push({key:"CI_JOB_URL",value:i.CI_JOB_URL,label:"CI Job",icon:O.link}),i.CI_PIPELINE_URL&&h.push({key:"CI_PIPELINE_URL",value:i.CI_PIPELINE_URL,label:"Pipeline",icon:O.link}),i.CI_COMMIT_MESSAGE&&(i.CI_COMMIT_MESSAGE.length>60?i.CI_COMMIT_MESSAGE.substring(0,57)+"":i.CI_COMMIT_MESSAGE,h.push({key:"CI_COMMIT_MESSAGE",value:i.CI_COMMIT_MESSAGE,label:"Сообщение",icon:O.code})),f.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[f.jsxs("button",{onClick:()=>d(!s),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[f.jsx("span",{className:"me-1",children:O.info}),f.jsx("span",{className:"text-dark",children:x})]}),s&&f.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:[f.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[f.jsx("span",{className:"me-2",children:O.apps}),f.jsx("strong",{children:i.APP_NAME||n})]}),f.jsxs("div",{style:{marginBottom:"12px"},children:[f.jsx("span",{className:"text-muted",children:"Версия: "}),f.jsx("strong",{children:x})]}),h.length>0&&f.jsx("div",{style:{fontSize:"13px"},children:h.map(({key:b,value:g,label:R,icon:c})=>{const _=g.length>40&&(b.includes("URL")||b.includes("MESSAGE"))?`${g.substring(0,37)}...`:g;return f.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[f.jsx("span",{className:"me-2",style:{flexShrink:0},children:c}),f.jsxs("div",{style:{flex:1,minWidth:0},children:[f.jsx("div",{className:"small text-muted",children:R}),f.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:g,children:b.includes("URL")?f.jsx("a",{href:g,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:_}):_})]})]},b)})}),h.length===0&&f.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),f.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),f.jsx("button",{onClick:()=>d(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),s&&f.jsx("div",{onClick:()=>d(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const ne="platform-kit",we=p.createContext(null);function ct({children:n}){const[r,a]=p.useState([]),l=typeof window<"u"&&window.__MF_NAME__||ne,s=p.useCallback((c,_,I,M)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:c,title:_,message:I,mfeName:l,timestamp:Date.now(),duration:M}),[l]),d=p.useCallback(c=>{a(I=>[...I,c].slice(0,5));const _=c.duration||5e3;_>0&&setTimeout(()=>{a(I=>I.filter(M=>M.id!==c.id))},_)},[]),i=p.useCallback(c=>{const _=s(c.type,c.title,c.message,c.duration);d(_),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:_,bubbles:!0}))},[s,d]),x=p.useCallback((c,_="Успешно")=>{i({type:"success",title:_,message:c})},[i]),h=p.useCallback((c,_="Ошибка")=>{i({type:"error",title:_,message:c})},[i]),b=p.useCallback((c,_="Предупреждение")=>{i({type:"warning",title:_,message:c})},[i]),g=p.useCallback((c,_="Информация")=>{i({type:"info",title:_,message:c})},[i]),R=p.useCallback(c=>{a(_=>_.filter(I=>I.id!==c))},[]);return p.useEffect(()=>{if(typeof window>"u")return;const c=_=>{const I=_.detail;if(I&&I.type&&I.title&&I.message){const M={...I,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};d(M)}};return window.addEventListener("mfe-notification",c),()=>{window.removeEventListener("mfe-notification",c)}},[d]),f.jsxs(we.Provider,{value:{notify:i,notifySuccess:x,notifyError:h,notifyWarning:b,notifyInfo:g,removeNotification:R},children:[n,r.length>0&&f.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=>f.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:[f.jsxs("div",{style:{flex:1},children:[f.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:c.title}),f.jsx("p",{style:{margin:0,fontSize:"14px"},children:c.message}),f.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:c.mfeName})]}),f.jsx("button",{onClick:()=>R(c.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},c.id))})]})}function ut(){const n=p.useContext(we);return n||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function ft(n){if(typeof window>"u")return;const r=window.__MF_NAME__||ne,a={...n,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}const xe="platform-kit",H={log:(...n)=>{},warn:(...n)=>{},error:(...n)=>{console.error(`[${xe}]`,...n)},info:(...n)=>{}};function dt(){if(typeof window>"u")return{isAuthenticated:!1};const n=window.__SHELL_AUTH_INSTANCE__;if(n)return n;const r=window.__SHELL_AUTH__;return r?.authInstance?r.authInstance:{isAuthenticated:!1}}function pt(){if(typeof window>"u")return;const n=window.__SHELL_AUTH_INSTANCE__;n?.signinRedirect?n.signinRedirect().catch(r=>{H.error("Failed to redirect to login:",r)}):window.location.href="/"}function ht(n){const r=n.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??n.message??"Unknown error",code:r?.data?.code,status:r?.status,type:a,timestamp:Date.now(),url:n.config?.url}}function Se(n={}){const r=n.name||xe,a={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)},l=Ze.create({timeout:n.timeout??1e4,baseURL:n.baseURL??"",headers:{"Content-Type":"application/json"}});return l.interceptors.request.use(s=>{const d=dt();if(d?.isAuthenticated){const i=d.user?.profile?.access_token;i&&s.headers&&(s.headers.Authorization=`Bearer ${i}`,a.info("Auth token attached"))}else a.info("User not authenticated - request without token");return a.log(`${s.method?.toUpperCase()} ${s.url}`),s},s=>(a.error("Request interceptor error:",s.message),Promise.reject(s))),l.interceptors.response.use(s=>(a.log(`Response ${s.status}:`,s.config.url),s),s=>{const d=s.response?.status,i=s.config?.url;return d===401?(a.warn("401 Unauthorized - triggering re-auth"),pt()):d===403?a.warn("403 Forbidden - insufficient permissions"):d===404?a.warn("404 Not found:",i):d===429?a.warn("429 Rate limited"):d===500?a.error("500 Server error:",i):s.response?a.warn(`Error ${d}:`,s.message):a.error("Network error - backend may be unavailable:",i),Promise.reject(ht(s))}),l}const G=Se();async function gt(n,r,a=G){const l=await a.get(n,{params:r});return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function mt(n,r,a=G){const l=await a.post(n,r);return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function vt(n,r,a=G){const l=await a.put(n,r);return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function _t(n,r=G){const a=await r.delete(n);return{data:a.data,status:a.status,ok:a.status>=200&&a.status<300}}function z(n,r){const a=r?.prefix?`[${r.prefix}]`:`[${n}]`;return{log:(...l)=>{},warn:(...l)=>{},error:(...l)=>{console.error(a,...l)},info:(...l)=>{}}}const yt=z("platform-kit",{prefix:"AUTH"}),Et=z("platform-kit",{prefix:"API"}),bt=z("platform-kit",{prefix:"ERROR"}),wt=z("platform-kit",{prefix:"INFO"});E.ErrorBoundary=it,E.NotificationProvider=ct,E.VersionInfo=lt,E.api=G,E.apiLogger=Et,E.authLogger=yt,E.createApiClient=Se,E.createMfLogger=z,E.del=_t,E.dispatchNotification=ft,E.errorLogger=bt,E.get=gt,E.getAuth=K,E.infoLogger=wt,E.post=mt,E.put=vt,E.useApi=et,E.useInfoData=ge,E.useNotification=ut,E.usePermissions=rt,E.useShellAuth=he,E.useV1Config=qe,Object.defineProperty(E,Symbol.toStringTag,{value:"Module"})}));
18
+ ${a}`]})]}),f.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[f.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),f.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),f.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 ht({mfeName:t}){const{data:r,isLoading:a,error:l}=Ee({mfeName:t}),[s,d]=p.useState(!1);if(a)return f.jsxs("span",{className:"text-muted small me-2",children:[f.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(l||!r)return f.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${l||"нет данных"}`,children:[f.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const i=r,x=i.BUILD_VERSION||i.IMAGE_VERSION||i.APP_NAME||"N/A",g=[];return i.APP_NAME&&g.push({key:"APP_NAME",value:i.APP_NAME,label:"Приложение",icon:T.apps}),i.BUILD_VERSION&&g.push({key:"BUILD_VERSION",value:i.BUILD_VERSION,label:"Версия",icon:T.tags}),i.IMAGE_VERSION&&g.push({key:"IMAGE_VERSION",value:i.IMAGE_VERSION,label:"Образ",icon:T.storage}),i.GIT_COMMIT&&g.push({key:"GIT_COMMIT",value:i.GIT_COMMIT,label:"Commit",icon:T.spreadsheet}),i.GIT_BRANCH&&g.push({key:"GIT_BRANCH",value:i.GIT_BRANCH,label:"Ветка",icon:T.spreadsheet}),i.CI_COMMIT_AUTHOR&&g.push({key:"CI_COMMIT_AUTHOR",value:i.CI_COMMIT_AUTHOR,label:"Автор",icon:T.user}),i.CI_COMMIT_TIMESTAMP&&g.push({key:"CI_COMMIT_TIMESTAMP",value:i.CI_COMMIT_TIMESTAMP,label:"Дата",icon:T.clock}),i.CI_JOB_URL&&g.push({key:"CI_JOB_URL",value:i.CI_JOB_URL,label:"CI Job",icon:T.link}),i.CI_PIPELINE_URL&&g.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,g.push({key:"CI_COMMIT_MESSAGE",value:i.CI_COMMIT_MESSAGE,label:"Сообщение",icon:T.code})),f.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[f.jsxs("button",{onClick:()=>d(!s),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[f.jsx("span",{className:"me-1",children:T.info}),f.jsx("span",{className:"text-dark",children:x})]}),s&&f.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:[f.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[f.jsx("span",{className:"me-2",children:T.apps}),f.jsx("strong",{children:i.APP_NAME||t})]}),f.jsxs("div",{style:{marginBottom:"12px"},children:[f.jsx("span",{className:"text-muted",children:"Версия: "}),f.jsx("strong",{children:x})]}),g.length>0&&f.jsx("div",{style:{fontSize:"13px"},children:g.map(({key:w,value:m,label:R,icon:u})=>{const E=m.length>40&&(w.includes("URL")||w.includes("MESSAGE"))?`${m.substring(0,37)}...`:m;return f.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[f.jsx("span",{className:"me-2",style:{flexShrink:0},children:u}),f.jsxs("div",{style:{flex:1,minWidth:0},children:[f.jsx("div",{className:"small text-muted",children:R}),f.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:m,children:w.includes("URL")?f.jsx("a",{href:m,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:E}):E})]})]},w)})}),g.length===0&&f.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),f.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),f.jsx("button",{onClick:()=>d(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),s&&f.jsx("div",{onClick:()=>d(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const ae="platform-kit",Ae=p.createContext(null);function _t({children:t}){const[r,a]=p.useState([]),l=typeof window<"u"&&window.__MF_NAME__||ae,s=p.useCallback((u,E,M,O)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:u,title:E,message:M,mfeName:l,timestamp:Date.now(),duration:O}),[l]),d=p.useCallback(u=>{a(M=>[...M,u].slice(0,5));const E=u.duration||5e3;E>0&&setTimeout(()=>{a(M=>M.filter(O=>O.id!==u.id))},E)},[]),i=p.useCallback(u=>{const E=s(u.type,u.title,u.message,u.duration);d(E),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:E,bubbles:!0}))},[s,d]),x=p.useCallback((u,E="Успешно")=>{i({type:"success",title:E,message:u})},[i]),g=p.useCallback((u,E="Ошибка")=>{i({type:"error",title:E,message:u})},[i]),w=p.useCallback((u,E="Предупреждение")=>{i({type:"warning",title:E,message:u})},[i]),m=p.useCallback((u,E="Информация")=>{i({type:"info",title:E,message:u})},[i]),R=p.useCallback(u=>{a(E=>E.filter(M=>M.id!==u))},[]);return p.useEffect(()=>{if(typeof window>"u")return;const u=E=>{const M=E.detail;if(M&&M.type&&M.title&&M.message){const O={...M,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};d(O)}};return window.addEventListener("mfe-notification",u),()=>{window.removeEventListener("mfe-notification",u)}},[d]),f.jsxs(Ae.Provider,{value:{notify:i,notifySuccess:x,notifyError:g,notifyWarning:w,notifyInfo:m,removeNotification:R},children:[t,r.length>0&&f.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(u=>f.jsxs("div",{className:`notification notification-${u.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:u.type==="success"?"#d4edda":u.type==="error"?"#f8d7da":u.type==="warning"?"#fff3cd":"#d1ecf1",color:u.type==="success"?"#155724":u.type==="error"?"#721c24":u.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[f.jsxs("div",{style:{flex:1},children:[f.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:u.title}),f.jsx("p",{style:{margin:0,fontSize:"14px"},children:u.message}),f.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:u.mfeName})]}),f.jsx("button",{onClick:()=>R(u.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},u.id))})]})}function vt(){const t=p.useContext(Ae);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function Et(t){if(typeof window>"u")return;const r=window.__MF_NAME__||ae,a={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}const Ce="platform-kit",H={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Ce}]`,...t)},info:(...t)=>{}};function yt(){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 wt(){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 bt(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}}function Me(t={}){const r=t.name||Ce,a={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)},l=at.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return l.interceptors.request.use(s=>{const d=yt();if(d?.isAuthenticated){const i=d.user?.profile?.access_token;i&&s.headers&&(s.headers.Authorization=`Bearer ${i}`,a.info("Auth token attached"))}else a.info("User not authenticated - request without token");return a.log(`${s.method?.toUpperCase()} ${s.url}`),s},s=>(a.error("Request interceptor error:",s.message),Promise.reject(s))),l.interceptors.response.use(s=>(a.log(`Response ${s.status}:`,s.config.url),s),s=>{const d=s.response?.status,i=s.config?.url;return d===401?(a.warn("401 Unauthorized - triggering re-auth"),wt()):d===403?a.warn("403 Forbidden - insufficient permissions"):d===404?a.warn("404 Not found:",i):d===429?a.warn("429 Rate limited"):d===500?a.error("500 Server error:",i):s.response?a.warn(`Error ${d}:`,s.message):a.error("Network error - backend may be unavailable:",i),Promise.reject(bt(s))}),l}const G=Me();async function xt(t,r,a=G){const l=await a.get(t,{params:r});return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function St(t,r,a=G){const l=await a.post(t,r);return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function Rt(t,r,a=G){const l=await a.put(t,r);return{data:l.data,status:l.status,ok:l.status>=200&&l.status<300}}async function At(t,r=G){const a=await r.delete(t);return{data:a.data,status:a.status,ok:a.status>=200&&a.status<300}}function z(t,r){const a=r?.prefix?`[${r.prefix}]`:`[${t}]`;return{log:(...l)=>{},warn:(...l)=>{},error:(...l)=>{console.error(a,...l)},info:(...l)=>{}}}const Ct=z("platform-kit",{prefix:"AUTH"}),Mt=z("platform-kit",{prefix:"API"}),It=z("platform-kit",{prefix:"ERROR"}),Nt=z("platform-kit",{prefix:"INFO"}),Tt={},kt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function oe(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function Ie(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function Ne(){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 ie(){const t=Tt;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let Q=null,se=!1;function Te(t,r){const a=oe(t);if(a)return a;if(se&&Q)return Q;const l=[{source:"window.__MF_NAME__",value:Ie()},{source:"sessionStorage.mf-config",value:Ne()},{source:"import.meta.env.VITE_MFE_NAME",value:ie()}];for(const{source:d,value:i}of l)if(i)return Q=i,se=!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 kt.error(s),new Error(s)}function Ot(t){return Te(t)}function ke(t){return oe(t)?"props.mfeName":Ie()?"window.__MF_NAME__":Ne()?"sessionStorage.mf-config":ie()?"import.meta.env.VITE_MFE_NAME":null}function jt(t){return ke(t)!==null}function Pt(){Q=null,se=!1}function Dt(t){const r=[];return oe(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")),ie()&&r.push("import.meta.env.VITE_MFE_NAME"),r}_.ErrorBoundary=mt,_.NotificationProvider=_t,_.VersionInfo=ht,_.api=G,_.apiLogger=Mt,_.authLogger=Ct,_.createApiClient=Me,_.createMfLogger=z,_.del=At,_.dispatchNotification=Et,_.errorLogger=It,_.get=xt,_.getAllMfeNameSources=Dt,_.getAuth=K,_.getMfeName=Te,_.getMfeNameSource=ke,_.hasMfeName=jt,_.infoLogger=Nt,_.post=St,_.put=Rt,_.requireMfeName=Ot,_.resetMfeNameCache=Pt,_.useApi=lt,_.useInfoData=Ee,_.useNotification=vt,_.usePermissions=ct,_.useShellAuth=ve,_.useV1Config=st,Object.defineProperty(_,Symbol.toStringTag,{value:"Module"})}));
@@ -175,4 +175,8 @@ export interface MFENotificationEventDetail {
175
175
  timestamp: number;
176
176
  duration?: number;
177
177
  }
178
+ /**
179
+ * Source of MFE name
180
+ */
181
+ export type MfeNameSource = 'props.mfeName' | 'window.__MF_NAME__' | 'sessionStorage.mf-config' | 'import.meta.env.VITE_MFE_NAME' | 'import.meta.env.MFE_NAME';
178
182
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Utils barrel export
3
+ */
4
+ export { getMfeName, requireMfeName, hasMfeName, getMfeNameSource, getAllMfeNameSources, resetMfeNameCache, } from './mfeName';
5
+ export type { MfeNameSource, } from '../types';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EACL,UAAU,EACV,cAAc,EACd,UAAU,EACV,gBAAgB,EAChB,oBAAoB,EACpB,iBAAiB,GAClB,MAAM,WAAW,CAAA;AAElB,YAAY,EACV,aAAa,GACd,MAAM,UAAU,CAAA"}
@@ -0,0 +1,52 @@
1
+ import { MfeNameSource } from '../types';
2
+ /**
3
+ * Интерфейс для пропсов с именем MFE
4
+ */
5
+ export interface MfeNameProps {
6
+ mfeName?: string;
7
+ name?: string;
8
+ }
9
+ /**
10
+ * Централизованная функция для получения имени микрофронтенда
11
+ *
12
+ * @param props - пропсы с mfeName или name
13
+ * @param fallback - fallback имя если не удалось определить
14
+ * @returns Имя MFE
15
+ *
16
+ * @example
17
+ * ```ts
18
+ * import { getMfeName } from '@ib-dop/platform-kit'
19
+ *
20
+ * // Из пропсов (приоритет)
21
+ * const mfeName = getMfeName({ mfeName: 'mf-home' })
22
+ *
23
+ * // Без пропсов - использует другие источники
24
+ * const mfeName = getMfeName()
25
+ * const mfeName = getMfeName(undefined, 'fallback-name')
26
+ * ```
27
+ */
28
+ export declare function getMfeName(props?: MfeNameProps, fallback?: string): string;
29
+ /**
30
+ * Получить имя MFE с обязательным параметром
31
+ *
32
+ * @throws Error если имя не удалось определить
33
+ */
34
+ export declare function requireMfeName(props?: MfeNameProps): string;
35
+ /**
36
+ * Получить источник имени MFE
37
+ */
38
+ export declare function getMfeNameSource(props?: MfeNameProps): MfeNameSource | null;
39
+ /**
40
+ * Проверить определено ли имя MFE
41
+ */
42
+ export declare function hasMfeName(props?: MfeNameProps): boolean;
43
+ /**
44
+ * Сбросить кэш имени MFE
45
+ * (полезно для тестов)
46
+ */
47
+ export declare function resetMfeNameCache(): void;
48
+ /**
49
+ * Получить все доступные источники имени MFE
50
+ */
51
+ export declare function getAllMfeNameSources(props?: MfeNameProps): MfeNameSource[];
52
+ //# sourceMappingURL=mfeName.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mfeName.d.ts","sourceRoot":"","sources":["../../src/utils/mfeName.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAoB7C;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAqED;;;;;;;;;;;;;;;;;;GAkBG;AACH,wBAAgB,UAAU,CAAC,KAAK,CAAC,EAAE,YAAY,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAuC1E;AAED;;;;GAIG;AACH,wBAAgB,cAAc,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,MAAM,CAE3D;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,aAAa,GAAG,IAAI,CAQ3E;AAED;;GAEG;AACH,wBAAgB,UAAU,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,OAAO,CAExD;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAIxC;AAED;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,KAAK,CAAC,EAAE,YAAY,GAAG,aAAa,EAAE,CAoB1E"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ibdop/platform-kit",
3
- "version": "1.0.0",
3
+ "version": "1.0.2",
4
4
  "private": false,
5
5
  "description": "Platform Kit - переиспользуемые хуки и компоненты для MF IngoBank DevOps Platform",
6
6
  "main": "dist/index.js",
package/src/index.ts CHANGED
@@ -15,3 +15,6 @@ export * from './components'
15
15
 
16
16
  // Services
17
17
  export * from './services'
18
+
19
+ // Utils
20
+ export * from './utils'
@@ -213,3 +213,15 @@ export interface MFENotificationEventDetail {
213
213
  timestamp: number
214
214
  duration?: number
215
215
  }
216
+
217
+ // ==================== MFE Name Types ====================
218
+
219
+ /**
220
+ * Source of MFE name
221
+ */
222
+ export type MfeNameSource =
223
+ | 'props.mfeName'
224
+ | 'window.__MF_NAME__'
225
+ | 'sessionStorage.mf-config'
226
+ | 'import.meta.env.VITE_MFE_NAME'
227
+ | 'import.meta.env.MFE_NAME'
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Utils barrel export
3
+ */
4
+
5
+ export {
6
+ getMfeName,
7
+ requireMfeName,
8
+ hasMfeName,
9
+ getMfeNameSource,
10
+ getAllMfeNameSources,
11
+ resetMfeNameCache,
12
+ } from './mfeName'
13
+
14
+ export type {
15
+ MfeNameSource,
16
+ } from '../types'
@@ -0,0 +1,228 @@
1
+ /**
2
+ * getMfeName - Централизованная утилита для получения имени микрофронтенда
3
+ *
4
+ * Паттерны получения MFE имени (по приоритету):
5
+ * 1. props.mfeName или props.name - явно переданное имя
6
+ * 2. window.__MF_NAME__ - устанавливается shell при загрузке MF
7
+ * 3. sessionStorage.getItem('mf-config') - конфигурация MF
8
+ * 4. VITE_MFE_NAME - environment variable (для сборки)
9
+ */
10
+
11
+ import type { MfeNameSource } from '../types'
12
+
13
+ // Development mode flag
14
+ const isDev = import.meta.env?.DEV === true || import.meta.env?.MODE === 'development'
15
+
16
+ /**
17
+ * Logger
18
+ */
19
+ const logger = {
20
+ log: (...args: unknown[]) => {
21
+ if (isDev) console.log('[getMfeName]', ...args)
22
+ },
23
+ warn: (...args: unknown[]) => {
24
+ if (isDev) console.warn('[getMfeName]', ...args)
25
+ },
26
+ error: (...args: unknown[]) => {
27
+ console.error('[getMfeName]', ...args)
28
+ },
29
+ }
30
+
31
+ /**
32
+ * Интерфейс для пропсов с именем MFE
33
+ */
34
+ export interface MfeNameProps {
35
+ mfeName?: string
36
+ name?: string
37
+ }
38
+
39
+ /**
40
+ * Получить имя MFE из пропсов
41
+ */
42
+ function getFromProps(props?: MfeNameProps): string | null {
43
+ if (!props) return null
44
+
45
+ if (props.mfeName) return props.mfeName
46
+ if (props.name) return props.name.replace('@ib-dop/', '')
47
+
48
+ return null
49
+ }
50
+
51
+ /**
52
+ * Получить имя MFE из window.__MF_NAME__
53
+ */
54
+ function getFromWindow(): string | null {
55
+ if (typeof window === 'undefined') return null
56
+
57
+ const win = window as unknown as { __MF_NAME__?: string }
58
+ if (win.__MF_NAME__) {
59
+ return win.__MF_NAME__
60
+ }
61
+
62
+ return null
63
+ }
64
+
65
+ /**
66
+ * Получить имя MFE из sessionStorage mf-config
67
+ */
68
+ function getFromSessionStorage(): string | null {
69
+ if (typeof window === 'undefined') return null
70
+
71
+ try {
72
+ const configStr = sessionStorage.getItem('mf-config')
73
+ if (configStr) {
74
+ const config = JSON.parse(configStr)
75
+
76
+ // Try multiple paths for MFE name
77
+ if (config.mfeName) return config.mfeName
78
+ if (config.name) return config.name
79
+ if (config.appName) return config.appName
80
+ }
81
+ } catch (error) {
82
+ logger.warn('Failed to parse mf-config:', error)
83
+ }
84
+
85
+ return null
86
+ }
87
+
88
+ /**
89
+ * Получить имя MFE из environment variables
90
+ */
91
+ function getFromEnv(): string | null {
92
+ const env = import.meta.env as Record<string, unknown>
93
+
94
+ if (env.VITE_MFE_NAME) return String(env.VITE_MFE_NAME)
95
+ if (env.MFE_NAME) return String(env.MFE_NAME)
96
+
97
+ return null
98
+ }
99
+
100
+ /**
101
+ * Кэш для имени MFE (для случаев без пропсов)
102
+ */
103
+ let cachedMfeName: string | null = null
104
+ let cacheInitialized = false
105
+
106
+ /**
107
+ * Централизованная функция для получения имени микрофронтенда
108
+ *
109
+ * @param props - пропсы с mfeName или name
110
+ * @param fallback - fallback имя если не удалось определить
111
+ * @returns Имя MFE
112
+ *
113
+ * @example
114
+ * ```ts
115
+ * import { getMfeName } from '@ib-dop/platform-kit'
116
+ *
117
+ * // Из пропсов (приоритет)
118
+ * const mfeName = getMfeName({ mfeName: 'mf-home' })
119
+ *
120
+ * // Без пропсов - использует другие источники
121
+ * const mfeName = getMfeName()
122
+ * const mfeName = getMfeName(undefined, 'fallback-name')
123
+ * ```
124
+ */
125
+ export function getMfeName(props?: MfeNameProps, fallback?: string): string {
126
+ // Приоритет 1: Из пропсов
127
+ const fromProps = getFromProps(props)
128
+ if (fromProps) {
129
+ logger.log('Found MFE name from props:', fromProps)
130
+ return fromProps
131
+ }
132
+
133
+ // Return cached value if available (for cases without props)
134
+ if (cacheInitialized && cachedMfeName) {
135
+ return cachedMfeName
136
+ }
137
+
138
+ // Приоритет 2-4: Другие источники
139
+ const sources: { source: MfeNameSource; value: string | null }[] = [
140
+ { source: 'window.__MF_NAME__', value: getFromWindow() },
141
+ { source: 'sessionStorage.mf-config', value: getFromSessionStorage() },
142
+ { source: 'import.meta.env.VITE_MFE_NAME', value: getFromEnv() },
143
+ ]
144
+
145
+ for (const { source, value } of sources) {
146
+ if (value) {
147
+ cachedMfeName = value
148
+ cacheInitialized = true
149
+ logger.log(`Found MFE name from ${source}:`, value)
150
+ return value
151
+ }
152
+ }
153
+
154
+ // No source provided a name
155
+ if (fallback) {
156
+ logger.warn('Could not determine MFE name, using fallback:', fallback)
157
+ return fallback
158
+ }
159
+
160
+ // Throw error - MFE name is required
161
+ const errorMsg = 'Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME'
162
+ logger.error(errorMsg)
163
+ throw new Error(errorMsg)
164
+ }
165
+
166
+ /**
167
+ * Получить имя MFE с обязательным параметром
168
+ *
169
+ * @throws Error если имя не удалось определить
170
+ */
171
+ export function requireMfeName(props?: MfeNameProps): string {
172
+ return getMfeName(props)
173
+ }
174
+
175
+ /**
176
+ * Получить источник имени MFE
177
+ */
178
+ export function getMfeNameSource(props?: MfeNameProps): MfeNameSource | null {
179
+ // Props имеет высший приоритет
180
+ if (getFromProps(props)) return 'props.mfeName'
181
+
182
+ if (getFromWindow()) return 'window.__MF_NAME__'
183
+ if (getFromSessionStorage()) return 'sessionStorage.mf-config'
184
+ if (getFromEnv()) return 'import.meta.env.VITE_MFE_NAME'
185
+ return null
186
+ }
187
+
188
+ /**
189
+ * Проверить определено ли имя MFE
190
+ */
191
+ export function hasMfeName(props?: MfeNameProps): boolean {
192
+ return getMfeNameSource(props) !== null
193
+ }
194
+
195
+ /**
196
+ * Сбросить кэш имени MFE
197
+ * (полезно для тестов)
198
+ */
199
+ export function resetMfeNameCache(): void {
200
+ cachedMfeName = null
201
+ cacheInitialized = false
202
+ logger.log('MFE name cache reset')
203
+ }
204
+
205
+ /**
206
+ * Получить все доступные источники имени MFE
207
+ */
208
+ export function getAllMfeNameSources(props?: MfeNameProps): MfeNameSource[] {
209
+ const sources: MfeNameSource[] = []
210
+
211
+ if (getFromProps(props)) {
212
+ sources.push('props.mfeName')
213
+ }
214
+
215
+ if (typeof window !== 'undefined') {
216
+ if ((window as unknown as { __MF_NAME__?: string }).__MF_NAME__) {
217
+ sources.push('window.__MF_NAME__')
218
+ }
219
+ if (sessionStorage.getItem('mf-config')) {
220
+ sources.push('sessionStorage.mf-config')
221
+ }
222
+ }
223
+ if (getFromEnv()) {
224
+ sources.push('import.meta.env.VITE_MFE_NAME')
225
+ }
226
+
227
+ return sources
228
+ }