@ibdop/platform-kit 1.0.0 → 1.0.1
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.cjs.js +10 -10
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.es.js +631 -561
- package/dist/index.umd.js +9 -9
- package/dist/types/index.d.ts +4 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/utils/index.d.ts +6 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/mfeName.d.ts +40 -0
- package/dist/utils/mfeName.d.ts.map +1 -0
- package/package.json +1 -1
- package/src/index.ts +3 -0
- package/src/types/index.ts +11 -0
- package/src/utils/index.ts +16 -0
- package/src/utils/mfeName.ts +189 -0
package/dist/index.umd.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
(function(
|
|
2
|
-
`+
|
|
3
|
-
`),
|
|
4
|
-
`),
|
|
5
|
-
`+m[
|
|
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(`
|
|
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`
|
|
6
6
|
|
|
7
|
-
Check the render method of \``+e+"`."}return""}}function
|
|
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=`
|
|
8
8
|
|
|
9
|
-
Check the top-level render call using <`+o+">.")}return
|
|
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:
|
|
10
10
|
let props = %s;
|
|
11
11
|
<%s {...props} />
|
|
12
12
|
React keys must be passed directly to JSX without using spread:
|
|
13
13
|
let props = %s;
|
|
14
|
-
<%s key={someKey} {...props} />`,
|
|
14
|
+
<%s key={someKey} {...props} />`,he,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()}:
|
|
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}=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"})}));
|
package/dist/types/index.d.ts
CHANGED
|
@@ -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 = '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 @@
|
|
|
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,40 @@
|
|
|
1
|
+
import { MfeNameSource } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Централизованная функция для получения имени микрофронтенда
|
|
4
|
+
*
|
|
5
|
+
* @param fallback - fallback имя если не удалось определить
|
|
6
|
+
* @returns Имя MFE
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```ts
|
|
10
|
+
* import { getMfeName } from '@ib-dop/platform-kit'
|
|
11
|
+
*
|
|
12
|
+
* const mfeName = getMfeName()
|
|
13
|
+
* console.log('Current MFE:', mfeName) // 'mf-home'
|
|
14
|
+
* ```
|
|
15
|
+
*/
|
|
16
|
+
export declare function getMfeName(fallback?: string): string;
|
|
17
|
+
/**
|
|
18
|
+
* Получить имя MFE с обязательным параметром
|
|
19
|
+
*
|
|
20
|
+
* @throws Error если имя не удалось определить
|
|
21
|
+
*/
|
|
22
|
+
export declare function requireMfeName(): string;
|
|
23
|
+
/**
|
|
24
|
+
* Получить источник имени MFE
|
|
25
|
+
*/
|
|
26
|
+
export declare function getMfeNameSource(): MfeNameSource | null;
|
|
27
|
+
/**
|
|
28
|
+
* Проверить определено ли имя MFE
|
|
29
|
+
*/
|
|
30
|
+
export declare function hasMfeName(): boolean;
|
|
31
|
+
/**
|
|
32
|
+
* Сбросить кэш имени MFE
|
|
33
|
+
* (полезно для тестов)
|
|
34
|
+
*/
|
|
35
|
+
export declare function resetMfeNameCache(): void;
|
|
36
|
+
/**
|
|
37
|
+
* Получить все доступные источники имени MFE
|
|
38
|
+
*/
|
|
39
|
+
export declare function getAllMfeNameSources(): MfeNameSource[];
|
|
40
|
+
//# sourceMappingURL=mfeName.d.ts.map
|
|
@@ -0,0 +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"}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
package/src/types/index.ts
CHANGED
|
@@ -213,3 +213,14 @@ 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
|
+
| 'window.__MF_NAME__'
|
|
224
|
+
| 'sessionStorage.mf-config'
|
|
225
|
+
| 'import.meta.env.VITE_MFE_NAME'
|
|
226
|
+
| 'import.meta.env.MFE_NAME'
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* getMfeName - Централизованная утилита для получения имени микрофронтенда
|
|
3
|
+
*
|
|
4
|
+
* Паттерны получения MFE имени:
|
|
5
|
+
* 1. window.__MF_NAME__ - устанавливается shell при загрузке MF
|
|
6
|
+
* 2. sessionStorage.getItem('mf-config') - конфигурация MF
|
|
7
|
+
* 3. VITE_MFE_NAME - environment variable (для сборки)
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import type { MfeNameSource } from '../types'
|
|
11
|
+
|
|
12
|
+
// Development mode flag
|
|
13
|
+
const isDev = import.meta.env?.DEV === true || import.meta.env?.MODE === 'development'
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* Logger
|
|
17
|
+
*/
|
|
18
|
+
const logger = {
|
|
19
|
+
log: (...args: unknown[]) => {
|
|
20
|
+
if (isDev) console.log('[getMfeName]', ...args)
|
|
21
|
+
},
|
|
22
|
+
warn: (...args: unknown[]) => {
|
|
23
|
+
if (isDev) console.warn('[getMfeName]', ...args)
|
|
24
|
+
},
|
|
25
|
+
error: (...args: unknown[]) => {
|
|
26
|
+
console.error('[getMfeName]', ...args)
|
|
27
|
+
},
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Получить имя MFE из window.__MF_NAME__
|
|
32
|
+
*/
|
|
33
|
+
function getFromWindow(): string | null {
|
|
34
|
+
if (typeof window === 'undefined') return null
|
|
35
|
+
|
|
36
|
+
const win = window as unknown as { __MF_NAME__?: string }
|
|
37
|
+
if (win.__MF_NAME__) {
|
|
38
|
+
return win.__MF_NAME__
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
return null
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Получить имя MFE из sessionStorage mf-config
|
|
46
|
+
*/
|
|
47
|
+
function getFromSessionStorage(): string | null {
|
|
48
|
+
if (typeof window === 'undefined') return null
|
|
49
|
+
|
|
50
|
+
try {
|
|
51
|
+
const configStr = sessionStorage.getItem('mf-config')
|
|
52
|
+
if (configStr) {
|
|
53
|
+
const config = JSON.parse(configStr)
|
|
54
|
+
|
|
55
|
+
// Try multiple paths for MFE name
|
|
56
|
+
if (config.mfeName) return config.mfeName
|
|
57
|
+
if (config.name) return config.name
|
|
58
|
+
if (config.appName) return config.appName
|
|
59
|
+
}
|
|
60
|
+
} catch (error) {
|
|
61
|
+
logger.warn('Failed to parse mf-config:', error)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return null
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Получить имя MFE из environment variables
|
|
69
|
+
*/
|
|
70
|
+
function getFromEnv(): string | null {
|
|
71
|
+
// Vite uses import.meta.env
|
|
72
|
+
const env = import.meta.env as Record<string, unknown>
|
|
73
|
+
|
|
74
|
+
if (env.VITE_MFE_NAME) return String(env.VITE_MFE_NAME)
|
|
75
|
+
if (env.MFE_NAME) return String(env.MFE_NAME)
|
|
76
|
+
|
|
77
|
+
return null
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Кэш для имени MFE (чтобы не читать каждый раз)
|
|
82
|
+
*/
|
|
83
|
+
let cachedMfeName: string | null = null
|
|
84
|
+
let cacheInitialized = false
|
|
85
|
+
|
|
86
|
+
/**
|
|
87
|
+
* Централизованная функция для получения имени микрофронтенда
|
|
88
|
+
*
|
|
89
|
+
* @param fallback - fallback имя если не удалось определить
|
|
90
|
+
* @returns Имя MFE
|
|
91
|
+
*
|
|
92
|
+
* @example
|
|
93
|
+
* ```ts
|
|
94
|
+
* import { getMfeName } from '@ib-dop/platform-kit'
|
|
95
|
+
*
|
|
96
|
+
* const mfeName = getMfeName()
|
|
97
|
+
* console.log('Current MFE:', mfeName) // 'mf-home'
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export function getMfeName(fallback?: string): string {
|
|
101
|
+
// Return cached value if available
|
|
102
|
+
if (cacheInitialized && cachedMfeName) {
|
|
103
|
+
return cachedMfeName
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
// Try all sources in order
|
|
107
|
+
const sources: { source: MfeNameSource; value: string | null }[] = [
|
|
108
|
+
{ source: 'window.__MF_NAME__', value: getFromWindow() },
|
|
109
|
+
{ source: 'sessionStorage.mf-config', value: getFromSessionStorage() },
|
|
110
|
+
{ source: 'import.meta.env.VITE_MFE_NAME', value: getFromEnv() },
|
|
111
|
+
]
|
|
112
|
+
|
|
113
|
+
for (const { source, value } of sources) {
|
|
114
|
+
if (value) {
|
|
115
|
+
cachedMfeName = value
|
|
116
|
+
cacheInitialized = true
|
|
117
|
+
logger.log(`Found MFE name from ${source}:`, value)
|
|
118
|
+
return value
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
// No source provided a name
|
|
123
|
+
if (fallback) {
|
|
124
|
+
logger.warn('Could not determine MFE name, using fallback:', fallback)
|
|
125
|
+
return fallback
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
// 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'
|
|
130
|
+
logger.error(errorMsg)
|
|
131
|
+
throw new Error(errorMsg)
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Получить имя MFE с обязательным параметром
|
|
136
|
+
*
|
|
137
|
+
* @throws Error если имя не удалось определить
|
|
138
|
+
*/
|
|
139
|
+
export function requireMfeName(): string {
|
|
140
|
+
return getMfeName()
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
/**
|
|
144
|
+
* Получить источник имени MFE
|
|
145
|
+
*/
|
|
146
|
+
export function getMfeNameSource(): MfeNameSource | null {
|
|
147
|
+
if (getFromWindow()) return 'window.__MF_NAME__'
|
|
148
|
+
if (getFromSessionStorage()) return 'sessionStorage.mf-config'
|
|
149
|
+
if (getFromEnv()) return 'import.meta.env.VITE_MFE_NAME'
|
|
150
|
+
return null
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Проверить определено ли имя MFE
|
|
155
|
+
*/
|
|
156
|
+
export function hasMfeName(): boolean {
|
|
157
|
+
return getMfeNameSource() !== null
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
/**
|
|
161
|
+
* Сбросить кэш имени MFE
|
|
162
|
+
* (полезно для тестов)
|
|
163
|
+
*/
|
|
164
|
+
export function resetMfeNameCache(): void {
|
|
165
|
+
cachedMfeName = null
|
|
166
|
+
cacheInitialized = false
|
|
167
|
+
logger.log('MFE name cache reset')
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
/**
|
|
171
|
+
* Получить все доступные источники имени MFE
|
|
172
|
+
*/
|
|
173
|
+
export function getAllMfeNameSources(): MfeNameSource[] {
|
|
174
|
+
const sources: MfeNameSource[] = []
|
|
175
|
+
|
|
176
|
+
if (typeof window !== 'undefined') {
|
|
177
|
+
if ((window as unknown as { __MF_NAME__?: string }).__MF_NAME__) {
|
|
178
|
+
sources.push('window.__MF_NAME__')
|
|
179
|
+
}
|
|
180
|
+
if (sessionStorage.getItem('mf-config')) {
|
|
181
|
+
sources.push('sessionStorage.mf-config')
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
if (getFromEnv()) {
|
|
185
|
+
sources.push('import.meta.env.VITE_MFE_NAME')
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
return sources
|
|
189
|
+
}
|