@ibdop/platform-kit 1.0.1 → 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(_,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,nt){"use strict";const me={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 _e(){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 h=u=>{r(u.detail),l(!1)},R=setInterval(()=>{s.current++;const u=i();u?(me.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",h),()=>{clearInterval(R),window.removeEventListener("shell-auth-ready",h)}},[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 me.log("Auth result:",{isAuthenticated:g.isAuthenticated,isLoading:g.isLoading}),g}const at={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function ot(t){if(t)return t;if(typeof window<"u"){const r=window;if(r.__MF_NAME__)return r.__MF_NAME__}return"unknown-mfe"}function ve(t){const[r,a]=p.useState(null),[l,s]=p.useState(!0),[d,i]=p.useState(null),x=p.useCallback(()=>{const w=ot(t?.mfeName).replace("@ib-dop/","");s(!0),i(null),fetch(`/svc/${w}/info.json`).then(h=>{if(!h.ok)throw new Error(`HTTP ${h.status}: ${h.statusText}`);return h.json()}).then(h=>{a(h)}).catch(h=>{at.error("Failed to load info:",h),i(h instanceof Error?h.message:String(h))}).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 Ee(t){if(typeof window>"u")return;const r=window.__MF_NAME__||"unknown",a={...t,mfeName:r,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}function ye(t,r){const a={network:{title:"Нет подключения",message:"Сервер недоступен. Проверьте подключение к интернету."},unauthorized:{title:"Требуется вход",message:"Ваша сессия истекла. Войдите в систему снова."},forbidden:{title:"Доступ запрещён",message:"У вас нет прав для выполнения этого действия."},not_found:{title:"Не найдено",message:"Запрошенный ресурс не найден."},server:{title:"Ошибка сервера",message:"Произошла ошибка на сервере. Попробуйте позже."},client:{title:"Ошибка",message:t.message||"Произошла ошибка при выполнении запроса."},unknown:{title:"Неизвестная ошибка",message:t.message||"Произошла неизвестная ошибка."}},l=a[t.type]||a.unknown;Ee({type:t.type==="network"?"warning":"error",title:l.title,message:r?`${l.message} (${r})`:l.message})}function it(t,r={}){const{notifyOnError:a=!0,notifyOnSuccess:l=!1,successMessage:s,errorContext:d,onSuccess:i,onError:x}=r,[g,w]=p.useState(null),[h,R]=p.useState(null),[u,E]=p.useState(!1),M=h!==null,O=g!==null&&!u&&!M,ie=p.useCallback(async()=>{E(!0),R(null);try{const S=await t();if(S.ok)return w(S.data),l&&s&&Ee({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&&ye(j,d),x?.(j),null}}catch(S){const j=S;return R(j),a&&ye(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:h,isLoading:u,isError:M,isSuccess:O,execute:ie,reset:P}}const lt={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 ut(t={}){const r=_e(),a=p.useMemo(()=>({...lt,...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 we;function ct(){if(we)return W;we=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 h,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(h in g)l.call(g,h)&&!d.hasOwnProperty(h)&&(R[h]=g[h]);if(x&&x.defaultProps)for(h in g=x.defaultProps,g)R[h]===void 0&&(R[h]=g[h]);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 be;function ft(){return be||(be=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"),h=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 ie(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 Dt=!1,Ft=!1,Lt=!1,Ut=!1,Vt=!1,ke;ke=Symbol.for("react.module.reference");function Wt(e){return!!(typeof e=="string"||typeof e=="function"||e===l||e===d||Vt||e===s||e===w||e===h||Ut||e===E||Dt||Ft||Lt||typeof e=="object"&&e!==null&&(e.$$typeof===u||e.$$typeof===R||e.$$typeof===i||e.$$typeof===x||e.$$typeof===g||e.$$typeof===ke||e.getModuleId!==void 0))}function Bt(e,n,o){var c=e.displayName;if(c)return c;var y=n.displayName||n.name||"";return y!==""?o+"("+y+")":o}function Oe(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 h:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case x:var n=e;return Oe(n)+".Consumer";case i:var o=e;return Oe(o._context)+".Provider";case g:return Bt(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,je,Pe,De,Fe,Le,Ue,Ve;function We(){}We.__reactDisabledLog=!0;function Ht(){{if(Y===0){je=console.log,Pe=console.info,De=console.warn,Fe=console.error,Le=console.group,Ue=console.groupCollapsed,Ve=console.groupEnd;var e={configurable:!0,enumerable:!0,value:We,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}Y++}}function Gt(){{if(Y--,Y===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:F({},e,{value:je}),info:F({},e,{value:Pe}),warn:F({},e,{value:De}),error:F({},e,{value:Fe}),group:F({},e,{value:Le}),groupCollapsed:F({},e,{value:Ue}),groupEnd:F({},e,{value:Ve})})}Y<0&&S("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var le=P.ReactCurrentDispatcher,ue;function $(e,n,o){{if(ue===void 0)try{throw Error()}catch(y){var c=y.stack.trim().match(/\n( *(at )?)/);ue=c&&c[1]||""}return`
2
- `+ue+e}}var ce=!1,q;{var zt=typeof WeakMap=="function"?WeakMap:Map;q=new zt}function Be(e,n){if(!e||ce)return"";{var o=q.get(e);if(o!==void 0)return o}var c;ce=!0;var y=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var b;b=le.current,le.current=null,Ht();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 m=N.stack.split(`
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
3
  `),I=c.stack.split(`
4
- `),A=m.length-1,C=I.length-1;A>=1&&C>=0&&m[A]!==I[C];)C--;for(;A>=1&&C>=0;A--,C--)if(m[A]!==I[C]){if(A!==1||C!==1)do if(A--,C--,C<0||m[A]!==I[C]){var k=`
5
- `+m[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{ce=!1,le.current=b,Gt(),Error.prepareStackTrace=y}var V=e?e.displayName||e.name:"",L=V?$(V):"";return typeof e=="function"&&q.set(e,L),L}function Yt(e,n,o){return Be(e,!1)}function Jt(e){var n=e.prototype;return!!(n&&n.isReactComponent)}function ee(e,n,o){if(e==null)return"";if(typeof e=="function")return Be(e,Jt(e));if(typeof e=="string")return $(e);switch(e){case w:return $("Suspense");case h:return $("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case g:return Yt(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,He={},Ge=P.ReactDebugCurrentFrame;function te(e){if(e){var n=e._owner,o=ee(e.type,e._source,n?n.type:null);Ge.setExtraStackFrame(o)}else Ge.setExtraStackFrame(null)}function Kt(e,n,o,c,y){{var b=Function.call.bind(J);for(var v in e)if(b(e,v)){var m=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}m=e[v](n,v,c,o,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(A){m=A}m&&!(m 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 m),te(null)),m instanceof Error&&!(m.message in He)&&(He[m.message]=!0,te(y),S("Failed %s type: %s",o,m.message),te(null))}}}var Xt=Array.isArray;function fe(e){return Xt(e)}function Zt(e){{var n=typeof Symbol=="function"&&Symbol.toStringTag,o=n&&e[Symbol.toStringTag]||e.constructor.name||"Object";return o}}function Qt(e){try{return ze(e),!1}catch{return!0}}function ze(e){return""+e}function Ye(e){if(Qt(e))return S("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",Zt(e)),ze(e)}var Je=P.ReactCurrentOwner,$t={key:!0,ref:!0,__self:!0,__source:!0},Ke,Xe;function qt(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 er(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 tr(e,n){typeof e.ref=="string"&&Je.current}function rr(e,n){{var o=function(){Ke||(Ke=!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 nr(e,n){{var o=function(){Xe||(Xe=!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 ar=function(e,n,o,c,y,b,v){var m={$$typeof:r,type:e,key:n,ref:o,props:v,_owner:b};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:c}),Object.defineProperty(m,"_source",{configurable:!1,enumerable:!1,writable:!1,value:y}),Object.freeze&&(Object.freeze(m.props),Object.freeze(m)),m};function or(e,n,o,c,y){{var b,v={},m=null,I=null;o!==void 0&&(Ye(o),m=""+o),er(n)&&(Ye(n.key),m=""+n.key),qt(n)&&(I=n.ref,tr(n,y));for(b in n)J.call(n,b)&&!$t.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(m||I){var C=typeof e=="function"?e.displayName||e.name||"Unknown":e;m&&rr(v,C),I&&nr(v,C)}return ar(e,m,I,y,c,Je.current,v)}}var de=P.ReactCurrentOwner,Ze=P.ReactDebugCurrentFrame;function U(e){if(e){var n=e._owner,o=ee(e.type,e._source,n?n.type:null);Ze.setExtraStackFrame(o)}else Ze.setExtraStackFrame(null)}var pe;pe=!1;function ge(e){return typeof e=="object"&&e!==null&&e.$$typeof===r}function Qe(){{if(de.current){var e=D(de.current.type);if(e)return`
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 sr(e){return""}var $e={};function ir(e){{var n=Qe();if(!n){var o=typeof e=="string"?e:e.displayName||e.name;o&&(n=`
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 n}}function qe(e,n){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var o=ir(n);if($e[o])return;$e[o]=!0;var c="";e&&e._owner&&e._owner!==de.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 et(e,n){{if(typeof e!="object")return;if(fe(e))for(var o=0;o<e.length;o++){var c=e[o];ge(c)&&qe(c,n)}else if(ge(e))e._store&&(e._store.validated=!0);else if(e){var y=ie(e);if(typeof y=="function"&&y!==e.entries)for(var b=y.call(e),v;!(v=b.next()).done;)ge(v.value)&&qe(v.value,n)}}}function lr(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);Kt(o,e.props,"prop",c,e)}else if(n.PropTypes!==void 0&&!pe){pe=!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 ur(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 tt={};function rt(e,n,o,c,y,b){{var v=Wt(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 I=sr();I?m+=I:m+=Qe();var A;e===null?A="null":fe(e)?A="array":e!==void 0&&e.$$typeof===r?(A="<"+(D(e.type)||"Unknown")+" />",m=" 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,m)}var C=or(e,n,o,y,b);if(C==null)return C;if(v){var k=n.children;if(k!==void 0)if(c)if(fe(k)){for(var V=0;V<k.length;V++)et(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 et(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(!tt[L+he]){var gr=N.length>0?"{"+N.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} />`,he,L,gr,L),tt[L+he]=!0}}return e===l?ur(C):lr(C),C}}function cr(e,n,o){return rt(e,n,o,!0)}function fr(e,n,o){return rt(e,n,o,!1)}var dr=fr,pr=cr;B.Fragment=l,B.jsx=dr,B.jsxs=pr})()),B}var xe;function dt(){return xe||(xe=1,process.env.NODE_ENV==="production"?Z.exports=ct():Z.exports=ft()),Z.exports}var f=dt();const Se="platform-kit",pt=!1,ne={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Se}]`,...t)}};class gt 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 Se}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 pt}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()}:
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 T={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function ht({mfeName:t}){const{data:r,isLoading:a,error:l}=ve({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:h,label:R,icon:u})=>{const E=h.length>40&&(w.includes("URL")||w.includes("MESSAGE"))?`${h.substring(0,37)}...`:h;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:h,children:w.includes("URL")?f.jsx("a",{href:h,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",Re=p.createContext(null);function mt({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]),h=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(Re.Provider,{value:{notify:i,notifySuccess:x,notifyError:g,notifyWarning:w,notifyInfo:h,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 _t(){const t=p.useContext(Re);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function vt(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 Ae="platform-kit",H={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Ae}]`,...t)},info:(...t)=>{}};function Et(){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 yt(){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 wt(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 Ce(t={}){const r=t.name||Ae,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=nt.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return l.interceptors.request.use(s=>{const d=Et();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"),yt()):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(wt(s))}),l}const G=Ce();async function bt(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 xt(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 St(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 Rt(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 At=z("platform-kit",{prefix:"AUTH"}),Ct=z("platform-kit",{prefix:"API"}),Mt=z("platform-kit",{prefix:"ERROR"}),It=z("platform-kit",{prefix:"INFO"}),Nt={},Tt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function Me(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function Ie(){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 oe(){const t=Nt;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let Q=null,se=!1;function Ne(t){if(se&&Q)return Q;const r=[{source:"window.__MF_NAME__",value:Me()},{source:"sessionStorage.mf-config",value:Ie()},{source:"import.meta.env.VITE_MFE_NAME",value:oe()}];for(const{source:l,value:s}of r)if(s)return Q=s,se=!0,s;if(t)return t;const a="Cannot determine MFE name. Please set one of: window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw Tt.error(a),new Error(a)}function kt(){return Ne()}function Te(){return Me()?"window.__MF_NAME__":Ie()?"sessionStorage.mf-config":oe()?"import.meta.env.VITE_MFE_NAME":null}function Ot(){return Te()!==null}function jt(){Q=null,se=!1}function Pt(){const t=[];return typeof window<"u"&&(window.__MF_NAME__&&t.push("window.__MF_NAME__"),sessionStorage.getItem("mf-config")&&t.push("sessionStorage.mf-config")),oe()&&t.push("import.meta.env.VITE_MFE_NAME"),t}_.ErrorBoundary=gt,_.NotificationProvider=mt,_.VersionInfo=ht,_.api=G,_.apiLogger=Ct,_.authLogger=At,_.createApiClient=Ce,_.createMfLogger=z,_.del=Rt,_.dispatchNotification=vt,_.errorLogger=Mt,_.get=bt,_.getAllMfeNameSources=Pt,_.getAuth=K,_.getMfeName=Ne,_.getMfeNameSource=Te,_.hasMfeName=Ot,_.infoLogger=It,_.post=xt,_.put=St,_.requireMfeName=kt,_.resetMfeNameCache=jt,_.useApi=it,_.useInfoData=ve,_.useNotification=_t,_.usePermissions=ut,_.useShellAuth=_e,_.useV1Config=st,Object.defineProperty(_,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"})}));
@@ -178,5 +178,5 @@ export interface MFENotificationEventDetail {
178
178
  /**
179
179
  * Source of MFE name
180
180
  */
181
- export type MfeNameSource = 'window.__MF_NAME__' | 'sessionStorage.mf-config' | 'import.meta.env.VITE_MFE_NAME' | 'import.meta.env.MFE_NAME';
181
+ export type MfeNameSource = 'props.mfeName' | 'window.__MF_NAME__' | 'sessionStorage.mf-config' | 'import.meta.env.VITE_MFE_NAME' | 'import.meta.env.MFE_NAME';
182
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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"}
@@ -1,7 +1,15 @@
1
1
  import { MfeNameSource } from '../types';
2
+ /**
3
+ * Интерфейс для пропсов с именем MFE
4
+ */
5
+ export interface MfeNameProps {
6
+ mfeName?: string;
7
+ name?: string;
8
+ }
2
9
  /**
3
10
  * Централизованная функция для получения имени микрофронтенда
4
11
  *
12
+ * @param props - пропсы с mfeName или name
5
13
  * @param fallback - fallback имя если не удалось определить
6
14
  * @returns Имя MFE
7
15
  *
@@ -9,25 +17,29 @@ import { MfeNameSource } from '../types';
9
17
  * ```ts
10
18
  * import { getMfeName } from '@ib-dop/platform-kit'
11
19
  *
20
+ * // Из пропсов (приоритет)
21
+ * const mfeName = getMfeName({ mfeName: 'mf-home' })
22
+ *
23
+ * // Без пропсов - использует другие источники
12
24
  * const mfeName = getMfeName()
13
- * console.log('Current MFE:', mfeName) // 'mf-home'
25
+ * const mfeName = getMfeName(undefined, 'fallback-name')
14
26
  * ```
15
27
  */
16
- export declare function getMfeName(fallback?: string): string;
28
+ export declare function getMfeName(props?: MfeNameProps, fallback?: string): string;
17
29
  /**
18
30
  * Получить имя MFE с обязательным параметром
19
31
  *
20
32
  * @throws Error если имя не удалось определить
21
33
  */
22
- export declare function requireMfeName(): string;
34
+ export declare function requireMfeName(props?: MfeNameProps): string;
23
35
  /**
24
36
  * Получить источник имени MFE
25
37
  */
26
- export declare function getMfeNameSource(): MfeNameSource | null;
38
+ export declare function getMfeNameSource(props?: MfeNameProps): MfeNameSource | null;
27
39
  /**
28
40
  * Проверить определено ли имя MFE
29
41
  */
30
- export declare function hasMfeName(): boolean;
42
+ export declare function hasMfeName(props?: MfeNameProps): boolean;
31
43
  /**
32
44
  * Сбросить кэш имени MFE
33
45
  * (полезно для тестов)
@@ -36,5 +48,5 @@ export declare function resetMfeNameCache(): void;
36
48
  /**
37
49
  * Получить все доступные источники имени MFE
38
50
  */
39
- export declare function getAllMfeNameSources(): MfeNameSource[];
51
+ export declare function getAllMfeNameSources(props?: MfeNameProps): MfeNameSource[];
40
52
  //# sourceMappingURL=mfeName.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mfeName.d.ts","sourceRoot":"","sources":["../../src/utils/mfeName.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AA4E7C;;;;;;;;;;;;;GAaG;AACH,wBAAgB,UAAU,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAgCpD;AAED;;;;GAIG;AACH,wBAAgB,cAAc,IAAI,MAAM,CAEvC;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,aAAa,GAAG,IAAI,CAKvD;AAED;;GAEG;AACH,wBAAgB,UAAU,IAAI,OAAO,CAEpC;AAED;;;GAGG;AACH,wBAAgB,iBAAiB,IAAI,IAAI,CAIxC;AAED;;GAEG;AACH,wBAAgB,oBAAoB,IAAI,aAAa,EAAE,CAgBtD"}
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.1",
3
+ "version": "1.0.2",
4
4
  "private": false,
5
5
  "description": "Platform Kit - переиспользуемые хуки и компоненты для MF IngoBank DevOps Platform",
6
6
  "main": "dist/index.js",
@@ -220,6 +220,7 @@ export interface MFENotificationEventDetail {
220
220
  * Source of MFE name
221
221
  */
222
222
  export type MfeNameSource =
223
+ | 'props.mfeName'
223
224
  | 'window.__MF_NAME__'
224
225
  | 'sessionStorage.mf-config'
225
226
  | 'import.meta.env.VITE_MFE_NAME'
@@ -1,10 +1,11 @@
1
1
  /**
2
2
  * getMfeName - Централизованная утилита для получения имени микрофронтенда
3
3
  *
4
- * Паттерны получения MFE имени:
5
- * 1. window.__MF_NAME__ - устанавливается shell при загрузке MF
6
- * 2. sessionStorage.getItem('mf-config') - конфигурация MF
7
- * 3. VITE_MFE_NAME - environment variable (для сборки)
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 (для сборки)
8
9
  */
9
10
 
10
11
  import type { MfeNameSource } from '../types'
@@ -27,6 +28,26 @@ const logger = {
27
28
  },
28
29
  }
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
+
30
51
  /**
31
52
  * Получить имя MFE из window.__MF_NAME__
32
53
  */
@@ -68,7 +89,6 @@ function getFromSessionStorage(): string | null {
68
89
  * Получить имя MFE из environment variables
69
90
  */
70
91
  function getFromEnv(): string | null {
71
- // Vite uses import.meta.env
72
92
  const env = import.meta.env as Record<string, unknown>
73
93
 
74
94
  if (env.VITE_MFE_NAME) return String(env.VITE_MFE_NAME)
@@ -78,7 +98,7 @@ function getFromEnv(): string | null {
78
98
  }
79
99
 
80
100
  /**
81
- * Кэш для имени MFE (чтобы не читать каждый раз)
101
+ * Кэш для имени MFE (для случаев без пропсов)
82
102
  */
83
103
  let cachedMfeName: string | null = null
84
104
  let cacheInitialized = false
@@ -86,6 +106,7 @@ let cacheInitialized = false
86
106
  /**
87
107
  * Централизованная функция для получения имени микрофронтенда
88
108
  *
109
+ * @param props - пропсы с mfeName или name
89
110
  * @param fallback - fallback имя если не удалось определить
90
111
  * @returns Имя MFE
91
112
  *
@@ -93,17 +114,28 @@ let cacheInitialized = false
93
114
  * ```ts
94
115
  * import { getMfeName } from '@ib-dop/platform-kit'
95
116
  *
117
+ * // Из пропсов (приоритет)
118
+ * const mfeName = getMfeName({ mfeName: 'mf-home' })
119
+ *
120
+ * // Без пропсов - использует другие источники
96
121
  * const mfeName = getMfeName()
97
- * console.log('Current MFE:', mfeName) // 'mf-home'
122
+ * const mfeName = getMfeName(undefined, 'fallback-name')
98
123
  * ```
99
124
  */
100
- export function getMfeName(fallback?: string): string {
101
- // Return cached value if available
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)
102
134
  if (cacheInitialized && cachedMfeName) {
103
135
  return cachedMfeName
104
136
  }
105
137
 
106
- // Try all sources in order
138
+ // Приоритет 2-4: Другие источники
107
139
  const sources: { source: MfeNameSource; value: string | null }[] = [
108
140
  { source: 'window.__MF_NAME__', value: getFromWindow() },
109
141
  { source: 'sessionStorage.mf-config', value: getFromSessionStorage() },
@@ -126,7 +158,7 @@ export function getMfeName(fallback?: string): string {
126
158
  }
127
159
 
128
160
  // Throw error - MFE name is required
129
- const errorMsg = 'Cannot determine MFE name. Please set one of: window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME'
161
+ const errorMsg = 'Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME'
130
162
  logger.error(errorMsg)
131
163
  throw new Error(errorMsg)
132
164
  }
@@ -136,14 +168,17 @@ export function getMfeName(fallback?: string): string {
136
168
  *
137
169
  * @throws Error если имя не удалось определить
138
170
  */
139
- export function requireMfeName(): string {
140
- return getMfeName()
171
+ export function requireMfeName(props?: MfeNameProps): string {
172
+ return getMfeName(props)
141
173
  }
142
174
 
143
175
  /**
144
176
  * Получить источник имени MFE
145
177
  */
146
- export function getMfeNameSource(): MfeNameSource | null {
178
+ export function getMfeNameSource(props?: MfeNameProps): MfeNameSource | null {
179
+ // Props имеет высший приоритет
180
+ if (getFromProps(props)) return 'props.mfeName'
181
+
147
182
  if (getFromWindow()) return 'window.__MF_NAME__'
148
183
  if (getFromSessionStorage()) return 'sessionStorage.mf-config'
149
184
  if (getFromEnv()) return 'import.meta.env.VITE_MFE_NAME'
@@ -153,8 +188,8 @@ export function getMfeNameSource(): MfeNameSource | null {
153
188
  /**
154
189
  * Проверить определено ли имя MFE
155
190
  */
156
- export function hasMfeName(): boolean {
157
- return getMfeNameSource() !== null
191
+ export function hasMfeName(props?: MfeNameProps): boolean {
192
+ return getMfeNameSource(props) !== null
158
193
  }
159
194
 
160
195
  /**
@@ -170,9 +205,13 @@ export function resetMfeNameCache(): void {
170
205
  /**
171
206
  * Получить все доступные источники имени MFE
172
207
  */
173
- export function getAllMfeNameSources(): MfeNameSource[] {
208
+ export function getAllMfeNameSources(props?: MfeNameProps): MfeNameSource[] {
174
209
  const sources: MfeNameSource[] = []
175
210
 
211
+ if (getFromProps(props)) {
212
+ sources.push('props.mfeName')
213
+ }
214
+
176
215
  if (typeof window !== 'undefined') {
177
216
  if ((window as unknown as { __MF_NAME__?: string }).__MF_NAME__) {
178
217
  sources.push('window.__MF_NAME__')