@ibdop/platform-kit 1.0.11 → 1.0.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -0
- package/dist/components/ErrorBoundary.d.ts +0 -0
- package/dist/components/ErrorBoundary.d.ts.map +0 -0
- package/dist/components/Notification.d.ts +0 -0
- package/dist/components/Notification.d.ts.map +0 -0
- package/dist/components/VersionInfo.d.ts +0 -0
- package/dist/components/VersionInfo.d.ts.map +0 -0
- package/dist/components/index.d.ts +0 -0
- package/dist/components/index.d.ts.map +0 -0
- package/dist/hooks/index.d.ts +3 -2
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/useApi.d.ts +22 -8
- package/dist/hooks/useApi.d.ts.map +1 -1
- package/dist/hooks/useFeatures.d.ts +0 -0
- package/dist/hooks/useFeatures.d.ts.map +0 -0
- package/dist/hooks/useInfoData.d.ts +0 -0
- package/dist/hooks/useInfoData.d.ts.map +0 -0
- package/dist/hooks/usePermissions.d.ts +0 -0
- package/dist/hooks/usePermissions.d.ts.map +0 -0
- package/dist/hooks/useShellAuth.d.ts +2 -5
- package/dist/hooks/useShellAuth.d.ts.map +1 -1
- package/dist/hooks/useV1Config.d.ts +0 -0
- package/dist/hooks/useV1Config.d.ts.map +0 -0
- package/dist/index.d.ts +0 -0
- package/dist/index.d.ts.map +0 -0
- package/dist/index.js +10 -10
- package/dist/index.mjs +931 -866
- package/dist/index.umd.js +10 -10
- package/dist/services/api.d.ts +2 -0
- package/dist/services/api.d.ts.map +1 -1
- package/dist/services/index.d.ts +0 -0
- package/dist/services/index.d.ts.map +0 -0
- package/dist/services/logger.d.ts +0 -0
- package/dist/services/logger.d.ts.map +0 -0
- package/dist/types/index.d.ts +0 -23
- package/dist/types/index.d.ts.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/mfeName.d.ts +0 -0
- package/dist/utils/mfeName.d.ts.map +0 -0
- package/dist/utils/shellAuth.d.ts +44 -0
- package/dist/utils/shellAuth.d.ts.map +1 -0
- package/package.json +3 -5
- package/src/components/ErrorBoundary.tsx +0 -0
- package/src/components/Notification.tsx +0 -0
- package/src/components/VersionInfo.tsx +0 -0
- package/src/components/index.ts +0 -0
- package/src/global.d.ts +0 -0
- package/src/hooks/index.ts +3 -2
- package/src/hooks/useApi.ts +114 -47
- package/src/hooks/useFeatures.ts +0 -0
- package/src/hooks/useInfoData.ts +0 -0
- package/src/hooks/usePermissions.ts +0 -0
- package/src/hooks/useShellAuth.ts +6 -26
- package/src/hooks/useV1Config.ts +0 -0
- package/src/index.ts +0 -0
- package/src/services/api.ts +47 -44
- package/src/services/index.ts +0 -0
- package/src/services/logger.ts +0 -0
- package/src/types/index.ts +1 -24
- package/src/utils/index.ts +10 -0
- package/src/utils/mfeName.ts +0 -0
- package/src/utils/shellAuth.ts +107 -0
package/dist/index.umd.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
(function(v,c){typeof exports=="object"&&typeof module<"u"?c(exports,require("react"),require("axios")):typeof define=="function"&&define.amd?define(["exports","react","axios"],c):(v=typeof globalThis<"u"?globalThis:v||self,c(v.PlatformKit={},v.React,v.axios))})(this,(function(v,c,ot){"use strict";const ye={log:(...t)=>{},warn:(...t)=>{}};function $(){if(typeof window>"u")return null;const t=window;if(t.__SHELL_AUTH_INSTANCE__)return t.__SHELL_AUTH_INSTANCE__;const n=window;return n.__SHELL_AUTH__?.authInstance?n.__SHELL_AUTH__.authInstance:null}function z(){const[t,n]=c.useState(null),[a,u]=c.useState(!0),o=c.useRef(0),p=20,s=c.useCallback(()=>$(),[]);c.useEffect(()=>{const w=s();if(w){n(w),u(!1);return}const f=l=>{n(l.detail),u(!1)},_=setInterval(()=>{o.current++;const l=s();l?(ye.log("Auth found via polling, attempts:",o.current),n(l),u(!1),clearInterval(_)):o.current>=p&&(u(!1),clearInterval(_))},500);return window.addEventListener("shell-auth-ready",f),()=>{clearInterval(_),window.removeEventListener("shell-auth-ready",f)}},[s]);const d=t||{user:null,isAuthenticated:!1,isLoading:a,signinRedirect:async()=>{const w=$();w?.signinRedirect?await w.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const w=$();w?.removeUser&&await w.removeUser()}};return ye.log("Auth result:",{isAuthenticated:d.isAuthenticated,isLoading:d.isLoading}),d}const it={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function ct(t){if(t)return t;if(typeof window<"u"){const n=window;if(n.__MF_NAME__)return n.__MF_NAME__}return"unknown-mfe"}function we(t){const[n,a]=c.useState(null),[u,o]=c.useState(!0),[p,s]=c.useState(null),C=c.useCallback(()=>{const w=ct(t?.mfeName).replace("@ib-dop/","");o(!0),s(null),fetch(`/svc/${w}/info.json`).then(f=>{if(!f.ok)throw new Error(`HTTP ${f.status}: ${f.statusText}`);return f.json()}).then(f=>{a(f)}).catch(f=>{it.error("Failed to load info:",f),s(f instanceof Error?f.message:String(f))}).finally(()=>{o(!1)})},[t?.mfeName]);return c.useEffect(()=>{C()},[C]),{data:n,isLoading:u,error:p,refetch:C}}const oe={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},q={authority:"",client_id:"",environment:"development"};function ut(){const[t,n]=c.useState(null),[a,u]=c.useState(!0),[o,p]=c.useState(null);return c.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){p("sessionStorage not available"),n(q),u(!1);return}try{const C=sessionStorage.getItem("config");if(C){const d=JSON.parse(C);n({...q,...d}),p(null),oe.log("Config loaded successfully")}else n(q),p("Config not found in sessionStorage"),oe.warn("Config not found in sessionStorage")}catch(C){oe.error("Error parsing config:",C),n(q),p("Error parsing config")}finally{u(!1)}})()},[]),{data:t,isLoading:a,error:o}}function be(t){if(typeof window>"u")return;const n=window.__MF_NAME__||"unknown",a={...t,mfeName:n,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}function Se(t,n){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||"Произошла неизвестная ошибка."}},u=a[t.type]||a.unknown;be({type:t.type==="network"?"warning":"error",title:u.title,message:n?`${u.message} (${n})`:u.message})}function lt(t,n={}){const{notifyOnError:a=!0,notifyOnSuccess:u=!1,successMessage:o,errorContext:p,onSuccess:s,onError:C}=n,[d,w]=c.useState(null),[f,_]=c.useState(null),[l,E]=c.useState(!1),S=f!==null,N=d!==null&&!l&&!S,R=c.useCallback(async()=>{E(!0),_(null);try{const h=await t();if(h.ok)return w(h.data),u&&o&&be({type:"success",title:"Успешно",message:o}),s?.(h.data),h.data;{const T={message:h.data||"Request failed",status:h.status,type:"client",timestamp:Date.now()};return _(T),a&&Se(T,p),C?.(T),null}}catch(h){const T=h;return _(T),a&&Se(T,p),C?.(T),null}finally{E(!1)}},[t,a,u,o,p,s,C]),x=c.useCallback(()=>{w(null),_(null),E(!1)},[]);return{data:d,error:f,isLoading:l,isError:S,isSuccess:N,execute:R,reset:x}}const ft={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 dt(t={}){const n=z(),a=c.useMemo(()=>({...ft,...t}),[t]),u=c.useMemo(()=>{const p=n.user?.profile?.realm_roles||n.user?.profile?.roles||[];return Array.isArray(p)?p:[p]},[n.user]),o=p=>p.includes("all")?!0:p.some(s=>u.includes(s));return{canView:o(a.canView),canEdit:o(a.canEdit),canDelete:o(a.canDelete),canAdmin:o(a.canAdmin),canViewSensitiveData:o(a.canViewSensitiveData),canExportData:o(a.canExportData),canManageUsers:o(a.canManageUsers)}}function pt(){const t=z(),[n,a]=c.useState([]),[u,o]=c.useState(0),[p,s]=c.useState([]),[C,d]=c.useState(!0),[w,f]=c.useState(null),_=c.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatures] Not authenticated"),d(!1);return}d(!0),f(null);try{const S={"Content-Type":"application/json"},N=t.user?.access_token;N&&(S.Authorization=`Bearer ${N}`);const R=await fetch("/api/features",{headers:S});if(!R.ok)throw new Error(`HTTP ${R.status}: ${R.statusText}`);const x=await R.json();a(x.features||[]),o(x.totalCount||0),s(x.userRoles||[])}catch(S){console.debug("Features fetch error:",S),f(S instanceof Error?S.message:String(S)),a([]),s([])}finally{d(!1)}},[t.isAuthenticated,t.user?.access_token]);c.useEffect(()=>{_()},[_]);const l=c.useCallback(S=>n.find(R=>R.name===S)?.userEnabled??!1,[n]),E=c.useCallback(S=>n.filter(N=>N.mfDependencies?.includes(S)),[n]);return{features:n,totalCount:u,userRoles:p,isLoading:C,error:w,refetch:_,isFeatureEnabled:l,getFeaturesByMf:E}}function ht(){const t=z(),[n,a]=c.useState([]),[u,o]=c.useState([]),[p,s]=c.useState(!1),[C,d]=c.useState(!0),[w,f]=c.useState(null),_=c.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatureAdmin] Not authenticated"),d(!1);return}d(!0),f(null);try{const R={"Content-Type":"application/json"},x=t.user?.access_token;x&&(R.Authorization=`Bearer ${x}`);const h=await fetch("/api/features/admin",{headers:R});if(!h.ok){if(h.status===403){console.warn("[useFeatureAdmin] 403 Forbidden - checking if token has admin role"),s(!1),a([]),o([]),d(!1);return}throw new Error(`HTTP ${h.status}: ${h.statusText}`)}const T=await h.json();a(T.featureToggles||[]),o(T.microfrontends||[]),s(T.isAdmin||!1)}catch(R){console.debug("FeatureAdmin fetch error:",R),a([]),o([]),s(!1)}finally{d(!1)}},[t.isAuthenticated,t.user?.access_token]),l=c.useCallback(async R=>{try{const x={"Content-Type":"application/json"},h=t.user?.access_token;h&&(x.Authorization=`Bearer ${h}`);const T=await fetch("/api/features/admin",{method:"POST",headers:x,body:JSON.stringify(R)});if(!T.ok){const O=await T.json().catch(()=>({}));throw new Error(O.error||`HTTP ${T.status}`)}return await _(),!0}catch(x){return f(x instanceof Error?x.message:String(x)),!1}},[_]),E=c.useCallback(async(R,x)=>{try{const h={"Content-Type":"application/json"},T=t.user?.access_token;T&&(h.Authorization=`Bearer ${T}`);const O=await fetch(`/api/features/admin/${encodeURIComponent(R)}`,{method:"PUT",headers:h,body:JSON.stringify(x)});if(!O.ok){const X=await O.json().catch(()=>({}));throw new Error(X.error||`HTTP ${O.status}`)}return await _(),!0}catch(h){return f(h instanceof Error?h.message:String(h)),!1}},[_]),S=c.useCallback(async(R,x)=>{try{const h={},T=t.user?.access_token;T&&(h.Authorization=`Bearer ${T}`);const O=await fetch(`/api/features/admin/${encodeURIComponent(R)}/toggle?enabled=${x}`,{method:"POST",headers:h});if(!O.ok){const X=await O.json().catch(()=>({}));throw new Error(X.error||`HTTP ${O.status}`)}return await _(),!0}catch(h){return f(h instanceof Error?h.message:String(h)),!1}},[_]),N=c.useCallback(async R=>{try{const x={},h=t.user?.access_token;h&&(x.Authorization=`Bearer ${h}`);const T=await fetch(`/api/features/admin/${encodeURIComponent(R)}`,{method:"DELETE",headers:x});if(!T.ok){const O=await T.json().catch(()=>({}));throw new Error(O.error||`HTTP ${T.status}`)}return await _(),!0}catch(x){return f(x instanceof Error?x.message:String(x)),!1}},[_]);return c.useEffect(()=>{_()},[_]),{features:n,microfrontends:u,isAdmin:p,isLoading:C,error:w,refetch:_,createFeature:l,updateFeature:E,toggleFeature:S,deleteFeature:N}}function gt(){const t=z(),[n,a]=c.useState([]),[u,o]=c.useState(0),[p,s]=c.useState(!0),[C,d]=c.useState(null),w=c.useCallback(async()=>{if(!t.isAuthenticated){s(!1);return}s(!0),d(null);try{const f={"Content-Type":"application/json"},_=t.user?.access_token;_&&(f.Authorization=`Bearer ${_}`);const l=await fetch("/api/features/microfrontends",{headers:f});if(!l.ok)throw new Error(`HTTP ${l.status}: ${l.statusText}`);const E=await l.json();a(E.microfrontends||[]),o(E.totalCount||0)}catch(f){d(f instanceof Error?f.message:String(f))}finally{s(!1)}},[t.isAuthenticated,t.user?.access_token]);return c.useEffect(()=>{w()},[w]),{microfrontends:n,totalCount:u,isLoading:p,error:C,refetch:w}}var ee={exports:{}},W={};var xe;function mt(){if(xe)return W;xe=1;var t=c,n=Symbol.for("react.element"),a=Symbol.for("react.fragment"),u=Object.prototype.hasOwnProperty,o=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function s(C,d,w){var f,_={},l=null,E=null;w!==void 0&&(l=""+w),d.key!==void 0&&(l=""+d.key),d.ref!==void 0&&(E=d.ref);for(f in d)u.call(d,f)&&!p.hasOwnProperty(f)&&(_[f]=d[f]);if(C&&C.defaultProps)for(f in d=C.defaultProps,d)_[f]===void 0&&(_[f]=d[f]);return{$$typeof:n,type:C,key:l,ref:E,props:_,_owner:o.current}}return W.Fragment=a,W.jsx=s,W.jsxs=s,W}var G={};var Ce;function _t(){return Ce||(Ce=1,process.env.NODE_ENV!=="production"&&(function(){var t=c,n=Symbol.for("react.element"),a=Symbol.for("react.portal"),u=Symbol.for("react.fragment"),o=Symbol.for("react.strict_mode"),p=Symbol.for("react.profiler"),s=Symbol.for("react.provider"),C=Symbol.for("react.context"),d=Symbol.for("react.forward_ref"),w=Symbol.for("react.suspense"),f=Symbol.for("react.suspense_list"),_=Symbol.for("react.memo"),l=Symbol.for("react.lazy"),E=Symbol.for("react.offscreen"),S=Symbol.iterator,N="@@iterator";function R(e){if(e===null||typeof e!="object")return null;var r=S&&e[S]||e[N];return typeof r=="function"?r:null}var x=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function h(e){{for(var r=arguments.length,i=new Array(r>1?r-1:0),g=1;g<r;g++)i[g-1]=arguments[g];T("error",e,i)}}function T(e,r,i){{var g=x.ReactDebugCurrentFrame,A=g.getStackAddendum();A!==""&&(r+="%s",i=i.concat([A]));var k=i.map(function(b){return String(b)});k.unshift("Warning: "+r),Function.prototype.apply.call(console[e],console,k)}}var O=!1,X=!1,Ht=!1,zt=!1,Wt=!1,Oe;Oe=Symbol.for("react.module.reference");function Gt(e){return!!(typeof e=="string"||typeof e=="function"||e===u||e===p||Wt||e===o||e===w||e===f||zt||e===E||O||X||Ht||typeof e=="object"&&e!==null&&(e.$$typeof===l||e.$$typeof===_||e.$$typeof===s||e.$$typeof===C||e.$$typeof===d||e.$$typeof===Oe||e.getModuleId!==void 0))}function Yt(e,r,i){var g=e.displayName;if(g)return g;var A=r.displayName||r.name||"";return A!==""?i+"("+A+")":i}function Fe(e){return e.displayName||"Context"}function L(e){if(e==null)return null;if(typeof e.tag=="number"&&h("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case u:return"Fragment";case a:return"Portal";case p:return"Profiler";case o:return"StrictMode";case w:return"Suspense";case f:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case C:var r=e;return Fe(r)+".Consumer";case s:var i=e;return Fe(i._context)+".Provider";case d:return Yt(e,e.render,"ForwardRef");case _:var g=e.displayName||null;return g!==null?g:L(e.type)||"Memo";case l:{var A=e,k=A._payload,b=A._init;try{return L(b(k))}catch{return null}}}return null}var U=Object.assign,Z=0,De,Le,Ue,Ve,Be,He,ze;function We(){}We.__reactDisabledLog=!0;function Jt(){{if(Z===0){De=console.log,Le=console.info,Ue=console.warn,Ve=console.error,Be=console.group,He=console.groupCollapsed,ze=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})}Z++}}function Kt(){{if(Z--,Z===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:U({},e,{value:De}),info:U({},e,{value:Le}),warn:U({},e,{value:Ue}),error:U({},e,{value:Ve}),group:U({},e,{value:Be}),groupCollapsed:U({},e,{value:He}),groupEnd:U({},e,{value:ze})})}Z<0&&h("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var de=x.ReactCurrentDispatcher,pe;function ne(e,r,i){{if(pe===void 0)try{throw Error()}catch(A){var g=A.stack.trim().match(/\n( *(at )?)/);pe=g&&g[1]||""}return`
|
|
2
|
-
`+
|
|
3
|
-
`),
|
|
4
|
-
`),M=
|
|
5
|
-
`+
|
|
1
|
+
(function(h,u){typeof exports=="object"&&typeof module<"u"?u(exports,require("react"),require("axios")):typeof define=="function"&&define.amd?define(["exports","react","axios"],u):(h=typeof globalThis<"u"?globalThis:h||self,u(h.PlatformKit={},h.React,h.axios))})(this,(function(h,u,lt){"use strict";function U(){if(typeof window>"u")return null;const t=window;if(t.__SHELL_AUTH_INSTANCE__)return t.__SHELL_AUTH_INSTANCE__;const n=window;return n.__SHELL_AUTH__?.authInstance?n.__SHELL_AUTH__.authInstance:null}function be(){const t=U();return t?{isAuthenticated:t.isAuthenticated,user:t.user??void 0}:{isAuthenticated:!1}}function ft(){const t=U();return t?.isAuthenticated?t.user?.profile?.access_token??null:null}function dt(){return U()?.isAuthenticated??!1}async function Se(){const t=U();t?.signinRedirect?await t.signinRedirect():typeof window<"u"&&(window.location.href="/")}async function pt(){const t=U();t?.removeUser&&await t.removeUser()}const Ce={log:(...t)=>{},warn:(...t)=>{}};function J(){const[t,n]=u.useState(null),[s,i]=u.useState(!0),o=u.useRef(0),p=20,r=u.useCallback(()=>U(),[]);u.useEffect(()=>{const y=r();if(y){n(y),i(!1);return}const l=d=>{n(d.detail),i(!1)},_=setInterval(()=>{o.current++;const d=r();d?(Ce.log("Auth found via polling, attempts:",o.current),n(d),i(!1),clearInterval(_)):o.current>=p&&(i(!1),clearInterval(_))},500);return window.addEventListener("shell-auth-ready",l),()=>{clearInterval(_),window.removeEventListener("shell-auth-ready",l)}},[r]);const f=t||{user:null,isAuthenticated:!1,isLoading:s,signinRedirect:async()=>{const y=U();y?.signinRedirect?await y.signinRedirect():typeof window<"u"&&(window.location.href="/")},removeUser:async()=>{const y=U();y?.removeUser&&await y.removeUser()}};return Ce.log("Auth result:",{isAuthenticated:f.isAuthenticated,isLoading:f.isLoading}),f}const ht={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useInfoData]",...t)}};function gt(t){if(t)return t;if(typeof window<"u"){const n=window;if(n.__MF_NAME__)return n.__MF_NAME__}return"unknown-mfe"}function xe(t){const[n,s]=u.useState(null),[i,o]=u.useState(!0),[p,r]=u.useState(null),g=u.useCallback(()=>{const y=gt(t?.mfeName).replace("@ib-dop/","");o(!0),r(null),fetch(`/svc/${y}/info.json`).then(l=>{if(!l.ok)throw new Error(`HTTP ${l.status}: ${l.statusText}`);return l.json()}).then(l=>{s(l)}).catch(l=>{ht.error("Failed to load info:",l),r(l instanceof Error?l.message:String(l))}).finally(()=>{o(!1)})},[t?.mfeName]);return u.useEffect(()=>{g()},[g]),{data:n,isLoading:i,error:p,refetch:g}}const ue={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[useV1Config]",...t)}},ee={authority:"",client_id:"",environment:"development"};function mt(){const[t,n]=u.useState(null),[s,i]=u.useState(!0),[o,p]=u.useState(null);return u.useEffect(()=>{(()=>{if(typeof sessionStorage>"u"){p("sessionStorage not available"),n(ee),i(!1);return}try{const g=sessionStorage.getItem("config");if(g){const f=JSON.parse(g);n({...ee,...f}),p(null),ue.log("Config loaded successfully")}else n(ee),p("Config not found in sessionStorage"),ue.warn("Config not found in sessionStorage")}catch(g){ue.error("Error parsing config:",g),n(ee),p("Error parsing config")}finally{i(!1)}})()},[]),{data:t,isLoading:s,error:o}}const Ae="platform-kit",te={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Ae}]`,...t)},info:(...t)=>{}};function _t(t){const n=t.response;let s="unknown";return n?n.status===401?s="unauthorized":n.status===403?s="forbidden":n.status===404?s="not_found":n.status>=500&&(s="server"):s="network",{message:n?.data?.message??t.message??"Unknown error",code:n?.data?.code,status:n?.status,type:s,timestamp:Date.now(),url:t.config?.url}}const vt=3,Et=1e3;function yt(t){return!t||t>=500||t===429}function wt(t){return new Promise(n=>setTimeout(n,t))}function ke(t={}){const n=t.name||Ae,s=t.retries??vt,i=t.retryDelay??Et,o={log:(...r)=>te.log(`[API:${n}]`,...r),warn:(...r)=>te.warn(`[API:${n}]`,...r),error:(...r)=>te.error(`[API:${n}]`,...r),info:(...r)=>te.info(`[API:${n}]`,...r)},p=lt.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return p.interceptors.request.use(r=>{const g=be();if(g?.isAuthenticated){const f=g.user?.access_token||g.user?.profile?.access_token;f&&r.headers?(r.headers.Authorization=`Bearer ${f}`,o.info("Auth token attached")):o.warn("User is authenticated but no token found")}else o.info("User not authenticated - request without token");return o.log(`${r.method?.toUpperCase()} ${r.url}`),r},r=>(o.error("Request interceptor error:",r.message),Promise.reject(r))),p.interceptors.response.use(r=>(o.log(`Response ${r.status}:`,r.config.url),r),async r=>{const g=r.response?.status,f=r.config?.url,y=r.config?._retryCount??0;if(yt(g)&&y<s){const l=r.config;l._retryCount=y+1;const _=i*Math.pow(2,y);return o.warn(`Retrying (${l._retryCount}/${s}) after ${_}ms:`,f),await wt(_),p.request(l)}return g===401?(o.warn("401 Unauthorized - triggering re-auth"),Se()):g===403?o.warn("403 Forbidden - insufficient permissions"):g===404?o.warn("404 Not found:",f):g===429?o.warn("429 Rate limited"):g===500?o.error("500 Server error:",f):r.response?o.warn(`Error ${g}:`,r.message):o.error("Network error - backend may be unavailable:",f),Promise.reject(_t(r))}),p}const V=ke();async function bt(t,n,s=V){const i=await s.get(t,{params:n});return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function St(t,n,s=V){const i=await s.post(t,n);return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function Ct(t,n,s=V){const i=await s.put(t,n);return{data:i.data,status:i.status,ok:i.status>=200&&i.status<300}}async function xt(t,n=V){const s=await n.delete(t);return{data:s.data,status:s.status,ok:s.status>=200&&s.status<300}}function Te(t){if(typeof window>"u")return;const n=window.__MF_NAME__||"unknown",s={...t,mfeName:n,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:s,bubbles:!0}))}function Re(t,n){const s={network:{title:"Нет подключения",message:"Сервер недоступен. Проверьте подключение к интернету."},unauthorized:{title:"Требуется вход",message:"Ваша сессия истекла. Войдите в систему снова."},forbidden:{title:"Доступ запрещён",message:"У вас нет прав для выполнения этого действия."},not_found:{title:"Не найдено",message:"Запрошенный ресурс не найден."},server:{title:"Ошибка сервера",message:"Произошла ошибка на сервере. Попробуйте позже."},client:{title:"Ошибка",message:t.message||"Произошла ошибка при выполнении запроса."},unknown:{title:"Неизвестная ошибка",message:t.message||"Произошла неизвестная ошибка."}},i=s[t.type]||s.unknown;Te({type:t.type==="network"?"warning":"error",title:i.title,message:n?`${i.message} (${n})`:i.message})}function At(t){return t instanceof Error&&t.name==="AbortError"}function K(t,n={}){const{notifyOnError:s=!0,notifyOnSuccess:i=!1,successMessage:o,errorContext:p,onSuccess:r,onError:g}=n,[f,y]=u.useState(null),[l,_]=u.useState(null),[d,b]=u.useState(!1),w=u.useRef(null),N=l!==null,T=f!==null&&!d&&!N;u.useEffect(()=>()=>{w.current&&w.current.abort()},[]);const x=u.useCallback(()=>{w.current&&(w.current.abort(),w.current=null,b(!1))},[]),E=u.useCallback(async()=>{w.current&&w.current.abort(),w.current=new AbortController;const j=w.current.signal;b(!0),_(null);try{const P=await t(j);if(j.aborted)return null;if(P.ok)return y(P.data),i&&o&&Te({type:"success",title:"Успешно",message:o}),r?.(P.data),P.data;{const B={message:P.data||"Request failed",status:P.status,type:"client",timestamp:Date.now()};return _(B),s&&Re(B,p),g?.(B),null}}catch(P){if(At(P))return null;const B=P;return _(B),s&&Re(B,p),g?.(B),null}finally{j.aborted||b(!1),w.current=null}},[t,s,i,o,p,r,g]),R=u.useCallback(()=>{y(null),_(null),b(!1)},[]);return{data:f,error:l,isLoading:d,isError:N,isSuccess:T,execute:E,reset:R,abort:x}}function kt(t,n={}){const{skip:s=!1,headers:i,immediate:o=!0,...p}=n,r=u.useMemo(()=>f=>{const y=i?i():{};return V.get(t,{headers:{"Content-Type":"application/json",...y},signal:f}).then(l=>({data:l.data,status:l.status,ok:l.status>=200&&l.status<300}))},[t,i]),g=K(r,{...p});return u.useEffect(()=>{o&&!s&&g.execute()},[o,s,t]),g}function Tt(t,n,s={}){return K(o=>V.post(t,n,{signal:o}).then(p=>({data:p.data,status:p.status,ok:p.status>=200&&p.status<300})),s)}function Rt(t,n,s={}){return K(o=>V.put(t,n,{signal:o}).then(p=>({data:p.data,status:p.status,ok:p.status>=200&&p.status<300})),s)}function Mt(t,n={}){return K(i=>V.delete(t,{signal:i}).then(o=>({data:o.data,status:o.status,ok:o.status>=200&&o.status<300})),n)}const It={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 Nt(t={}){const n=J(),s=u.useMemo(()=>({...It,...t}),[t]),i=u.useMemo(()=>{const p=n.user?.profile?.realm_roles||n.user?.profile?.roles||[];return Array.isArray(p)?p:[p]},[n.user]),o=p=>p.includes("all")?!0:p.some(r=>i.includes(r));return{canView:o(s.canView),canEdit:o(s.canEdit),canDelete:o(s.canDelete),canAdmin:o(s.canAdmin),canViewSensitiveData:o(s.canViewSensitiveData),canExportData:o(s.canExportData),canManageUsers:o(s.canManageUsers)}}function jt(){const t=J(),[n,s]=u.useState([]),[i,o]=u.useState(0),[p,r]=u.useState([]),[g,f]=u.useState(!0),[y,l]=u.useState(null),_=u.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatures] Not authenticated"),f(!1);return}f(!0),l(null);try{const w={"Content-Type":"application/json"},N=t.user?.access_token;N&&(w.Authorization=`Bearer ${N}`);const T=await fetch("/api/features",{headers:w});if(!T.ok)throw new Error(`HTTP ${T.status}: ${T.statusText}`);const x=await T.json();s(x.features||[]),o(x.totalCount||0),r(x.userRoles||[])}catch(w){console.debug("Features fetch error:",w),l(w instanceof Error?w.message:String(w)),s([]),r([])}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]);u.useEffect(()=>{_()},[_]);const d=u.useCallback(w=>n.find(T=>T.name===w)?.userEnabled??!1,[n]),b=u.useCallback(w=>n.filter(N=>N.mfDependencies?.includes(w)),[n]);return{features:n,totalCount:i,userRoles:p,isLoading:g,error:y,refetch:_,isFeatureEnabled:d,getFeaturesByMf:b}}function Pt(){const t=J(),[n,s]=u.useState([]),[i,o]=u.useState([]),[p,r]=u.useState(!1),[g,f]=u.useState(!0),[y,l]=u.useState(null),_=u.useCallback(async()=>{if(!t.isAuthenticated){console.debug("[useFeatureAdmin] Not authenticated"),f(!1);return}f(!0),l(null);try{const T={"Content-Type":"application/json"},x=t.user?.access_token;x&&(T.Authorization=`Bearer ${x}`);const E=await fetch("/api/features/admin",{headers:T});if(!E.ok){if(E.status===403){console.warn("[useFeatureAdmin] 403 Forbidden - checking if token has admin role"),r(!1),s([]),o([]),f(!1);return}throw new Error(`HTTP ${E.status}: ${E.statusText}`)}const R=await E.json();s(R.featureToggles||[]),o(R.microfrontends||[]),r(R.isAdmin||!1)}catch(T){console.debug("FeatureAdmin fetch error:",T),s([]),o([]),r(!1)}finally{f(!1)}},[t.isAuthenticated,t.user?.access_token]),d=u.useCallback(async T=>{try{const x={"Content-Type":"application/json"},E=t.user?.access_token;E&&(x.Authorization=`Bearer ${E}`);const R=await fetch("/api/features/admin",{method:"POST",headers:x,body:JSON.stringify(T)});if(!R.ok){const j=await R.json().catch(()=>({}));throw new Error(j.error||`HTTP ${R.status}`)}return await _(),!0}catch(x){return l(x instanceof Error?x.message:String(x)),!1}},[_]),b=u.useCallback(async(T,x)=>{try{const E={"Content-Type":"application/json"},R=t.user?.access_token;R&&(E.Authorization=`Bearer ${R}`);const j=await fetch(`/api/features/admin/${encodeURIComponent(T)}`,{method:"PUT",headers:E,body:JSON.stringify(x)});if(!j.ok){const P=await j.json().catch(()=>({}));throw new Error(P.error||`HTTP ${j.status}`)}return await _(),!0}catch(E){return l(E instanceof Error?E.message:String(E)),!1}},[_]),w=u.useCallback(async(T,x)=>{try{const E={},R=t.user?.access_token;R&&(E.Authorization=`Bearer ${R}`);const j=await fetch(`/api/features/admin/${encodeURIComponent(T)}/toggle?enabled=${x}`,{method:"POST",headers:E});if(!j.ok){const P=await j.json().catch(()=>({}));throw new Error(P.error||`HTTP ${j.status}`)}return await _(),!0}catch(E){return l(E instanceof Error?E.message:String(E)),!1}},[_]),N=u.useCallback(async T=>{try{const x={},E=t.user?.access_token;E&&(x.Authorization=`Bearer ${E}`);const R=await fetch(`/api/features/admin/${encodeURIComponent(T)}`,{method:"DELETE",headers:x});if(!R.ok){const j=await R.json().catch(()=>({}));throw new Error(j.error||`HTTP ${R.status}`)}return await _(),!0}catch(x){return l(x instanceof Error?x.message:String(x)),!1}},[_]);return u.useEffect(()=>{_()},[_]),{features:n,microfrontends:i,isAdmin:p,isLoading:g,error:y,refetch:_,createFeature:d,updateFeature:b,toggleFeature:w,deleteFeature:N}}function Ot(){const t=J(),[n,s]=u.useState([]),[i,o]=u.useState(0),[p,r]=u.useState(!0),[g,f]=u.useState(null),y=u.useCallback(async()=>{if(!t.isAuthenticated){r(!1);return}r(!0),f(null);try{const l={"Content-Type":"application/json"},_=t.user?.access_token;_&&(l.Authorization=`Bearer ${_}`);const d=await fetch("/api/features/microfrontends",{headers:l});if(!d.ok)throw new Error(`HTTP ${d.status}: ${d.statusText}`);const b=await d.json();s(b.microfrontends||[]),o(b.totalCount||0)}catch(l){f(l instanceof Error?l.message:String(l))}finally{r(!1)}},[t.isAuthenticated,t.user?.access_token]);return u.useEffect(()=>{y()},[y]),{microfrontends:n,totalCount:i,isLoading:p,error:g,refetch:y}}var ne={exports:{}},X={};var Me;function Ft(){if(Me)return X;Me=1;var t=u,n=Symbol.for("react.element"),s=Symbol.for("react.fragment"),i=Object.prototype.hasOwnProperty,o=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};function r(g,f,y){var l,_={},d=null,b=null;y!==void 0&&(d=""+y),f.key!==void 0&&(d=""+f.key),f.ref!==void 0&&(b=f.ref);for(l in f)i.call(f,l)&&!p.hasOwnProperty(l)&&(_[l]=f[l]);if(g&&g.defaultProps)for(l in f=g.defaultProps,f)_[l]===void 0&&(_[l]=f[l]);return{$$typeof:n,type:g,key:d,ref:b,props:_,_owner:o.current}}return X.Fragment=s,X.jsx=r,X.jsxs=r,X}var Z={};var Ie;function Dt(){return Ie||(Ie=1,process.env.NODE_ENV!=="production"&&(function(){var t=u,n=Symbol.for("react.element"),s=Symbol.for("react.portal"),i=Symbol.for("react.fragment"),o=Symbol.for("react.strict_mode"),p=Symbol.for("react.profiler"),r=Symbol.for("react.provider"),g=Symbol.for("react.context"),f=Symbol.for("react.forward_ref"),y=Symbol.for("react.suspense"),l=Symbol.for("react.suspense_list"),_=Symbol.for("react.memo"),d=Symbol.for("react.lazy"),b=Symbol.for("react.offscreen"),w=Symbol.iterator,N="@@iterator";function T(e){if(e===null||typeof e!="object")return null;var a=w&&e[w]||e[N];return typeof a=="function"?a:null}var x=t.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;function E(e){{for(var a=arguments.length,c=new Array(a>1?a-1:0),m=1;m<a;m++)c[m-1]=arguments[m];R("error",e,c)}}function R(e,a,c){{var m=x.ReactDebugCurrentFrame,A=m.getStackAddendum();A!==""&&(a+="%s",c=c.concat([A]));var k=c.map(function(C){return String(C)});k.unshift("Warning: "+a),Function.prototype.apply.call(console[e],console,k)}}var j=!1,P=!1,B=!1,tn=!1,nn=!1,Ue;Ue=Symbol.for("react.module.reference");function rn(e){return!!(typeof e=="string"||typeof e=="function"||e===i||e===p||nn||e===o||e===y||e===l||tn||e===b||j||P||B||typeof e=="object"&&e!==null&&(e.$$typeof===d||e.$$typeof===_||e.$$typeof===r||e.$$typeof===g||e.$$typeof===f||e.$$typeof===Ue||e.getModuleId!==void 0))}function an(e,a,c){var m=e.displayName;if(m)return m;var A=a.displayName||a.name||"";return A!==""?c+"("+A+")":c}function Ve(e){return e.displayName||"Context"}function W(e){if(e==null)return null;if(typeof e.tag=="number"&&E("Received an unexpected object in getComponentNameFromType(). This is likely a bug in React. Please file an issue."),typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case i:return"Fragment";case s:return"Portal";case p:return"Profiler";case o:return"StrictMode";case y:return"Suspense";case l:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case g:var a=e;return Ve(a)+".Consumer";case r:var c=e;return Ve(c._context)+".Provider";case f:return an(e,e.render,"ForwardRef");case _:var m=e.displayName||null;return m!==null?m:W(e.type)||"Memo";case d:{var A=e,k=A._payload,C=A._init;try{return W(C(k))}catch{return null}}}return null}var z=Object.assign,q=0,Be,We,ze,He,Ge,Ye,Je;function Ke(){}Ke.__reactDisabledLog=!0;function sn(){{if(q===0){Be=console.log,We=console.info,ze=console.warn,He=console.error,Ge=console.group,Ye=console.groupCollapsed,Je=console.groupEnd;var e={configurable:!0,enumerable:!0,value:Ke,writable:!0};Object.defineProperties(console,{info:e,log:e,warn:e,error:e,group:e,groupCollapsed:e,groupEnd:e})}q++}}function on(){{if(q--,q===0){var e={configurable:!0,enumerable:!0,writable:!0};Object.defineProperties(console,{log:z({},e,{value:Be}),info:z({},e,{value:We}),warn:z({},e,{value:ze}),error:z({},e,{value:He}),group:z({},e,{value:Ge}),groupCollapsed:z({},e,{value:Ye}),groupEnd:z({},e,{value:Je})})}q<0&&E("disabledDepth fell below zero. This is a bug in React. Please file an issue.")}}var he=x.ReactCurrentDispatcher,ge;function ae(e,a,c){{if(ge===void 0)try{throw Error()}catch(A){var m=A.stack.trim().match(/\n( *(at )?)/);ge=m&&m[1]||""}return`
|
|
2
|
+
`+ge+e}}var me=!1,se;{var un=typeof WeakMap=="function"?WeakMap:Map;se=new un}function Xe(e,a){if(!e||me)return"";{var c=se.get(e);if(c!==void 0)return c}var m;me=!0;var A=Error.prepareStackTrace;Error.prepareStackTrace=void 0;var k;k=he.current,he.current=null,sn();try{if(a){var C=function(){throw Error()};if(Object.defineProperty(C.prototype,"props",{set:function(){throw Error()}}),typeof Reflect=="object"&&Reflect.construct){try{Reflect.construct(C,[])}catch(F){m=F}Reflect.construct(e,[],C)}else{try{C.call()}catch(F){m=F}e.call(C.prototype)}}else{try{throw Error()}catch(F){m=F}e()}}catch(F){if(F&&m&&typeof F.stack=="string"){for(var S=F.stack.split(`
|
|
3
|
+
`),O=m.stack.split(`
|
|
4
|
+
`),M=S.length-1,I=O.length-1;M>=1&&I>=0&&S[M]!==O[I];)I--;for(;M>=1&&I>=0;M--,I--)if(S[M]!==O[I]){if(M!==1||I!==1)do if(M--,I--,I<0||S[M]!==O[I]){var L=`
|
|
5
|
+
`+S[M].replace(" at new "," at ");return e.displayName&&L.includes("<anonymous>")&&(L=L.replace("<anonymous>",e.displayName)),typeof e=="function"&&se.set(e,L),L}while(M>=1&&I>=0);break}}}finally{me=!1,he.current=k,on(),Error.prepareStackTrace=A}var Y=e?e.displayName||e.name:"",H=Y?ae(Y):"";return typeof e=="function"&&se.set(e,H),H}function cn(e,a,c){return Xe(e,!1)}function ln(e){var a=e.prototype;return!!(a&&a.isReactComponent)}function oe(e,a,c){if(e==null)return"";if(typeof e=="function")return Xe(e,ln(e));if(typeof e=="string")return ae(e);switch(e){case y:return ae("Suspense");case l:return ae("SuspenseList")}if(typeof e=="object")switch(e.$$typeof){case f:return cn(e.render);case _:return oe(e.type,a,c);case d:{var m=e,A=m._payload,k=m._init;try{return oe(k(A),a,c)}catch{}}}return""}var $=Object.prototype.hasOwnProperty,Ze={},Qe=x.ReactDebugCurrentFrame;function ie(e){if(e){var a=e._owner,c=oe(e.type,e._source,a?a.type:null);Qe.setExtraStackFrame(c)}else Qe.setExtraStackFrame(null)}function fn(e,a,c,m,A){{var k=Function.call.bind($);for(var C in e)if(k(e,C)){var S=void 0;try{if(typeof e[C]!="function"){var O=Error((m||"React class")+": "+c+" type `"+C+"` is invalid; it must be a function, usually from the `prop-types` package, but received `"+typeof e[C]+"`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.");throw O.name="Invariant Violation",O}S=e[C](a,C,m,c,null,"SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED")}catch(M){S=M}S&&!(S instanceof Error)&&(ie(A),E("%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).",m||"React class",c,C,typeof S),ie(null)),S instanceof Error&&!(S.message in Ze)&&(Ze[S.message]=!0,ie(A),E("Failed %s type: %s",c,S.message),ie(null))}}}var dn=Array.isArray;function _e(e){return dn(e)}function pn(e){{var a=typeof Symbol=="function"&&Symbol.toStringTag,c=a&&e[Symbol.toStringTag]||e.constructor.name||"Object";return c}}function hn(e){try{return qe(e),!1}catch{return!0}}function qe(e){return""+e}function $e(e){if(hn(e))return E("The provided key is an unsupported type %s. This value must be coerced to a string before before using it here.",pn(e)),qe(e)}var et=x.ReactCurrentOwner,gn={key:!0,ref:!0,__self:!0,__source:!0},tt,nt;function mn(e){if($.call(e,"ref")){var a=Object.getOwnPropertyDescriptor(e,"ref").get;if(a&&a.isReactWarning)return!1}return e.ref!==void 0}function _n(e){if($.call(e,"key")){var a=Object.getOwnPropertyDescriptor(e,"key").get;if(a&&a.isReactWarning)return!1}return e.key!==void 0}function vn(e,a){typeof e.ref=="string"&&et.current}function En(e,a){{var c=function(){tt||(tt=!0,E("%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)",a))};c.isReactWarning=!0,Object.defineProperty(e,"key",{get:c,configurable:!0})}}function yn(e,a){{var c=function(){nt||(nt=!0,E("%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)",a))};c.isReactWarning=!0,Object.defineProperty(e,"ref",{get:c,configurable:!0})}}var wn=function(e,a,c,m,A,k,C){var S={$$typeof:n,type:e,key:a,ref:c,props:C,_owner:k};return S._store={},Object.defineProperty(S._store,"validated",{configurable:!1,enumerable:!1,writable:!0,value:!1}),Object.defineProperty(S,"_self",{configurable:!1,enumerable:!1,writable:!1,value:m}),Object.defineProperty(S,"_source",{configurable:!1,enumerable:!1,writable:!1,value:A}),Object.freeze&&(Object.freeze(S.props),Object.freeze(S)),S};function bn(e,a,c,m,A){{var k,C={},S=null,O=null;c!==void 0&&($e(c),S=""+c),_n(a)&&($e(a.key),S=""+a.key),mn(a)&&(O=a.ref,vn(a,A));for(k in a)$.call(a,k)&&!gn.hasOwnProperty(k)&&(C[k]=a[k]);if(e&&e.defaultProps){var M=e.defaultProps;for(k in M)C[k]===void 0&&(C[k]=M[k])}if(S||O){var I=typeof e=="function"?e.displayName||e.name||"Unknown":e;S&&En(C,I),O&&yn(C,I)}return wn(e,S,O,A,m,et.current,C)}}var ve=x.ReactCurrentOwner,rt=x.ReactDebugCurrentFrame;function G(e){if(e){var a=e._owner,c=oe(e.type,e._source,a?a.type:null);rt.setExtraStackFrame(c)}else rt.setExtraStackFrame(null)}var Ee;Ee=!1;function ye(e){return typeof e=="object"&&e!==null&&e.$$typeof===n}function at(){{if(ve.current){var e=W(ve.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 Sn(e){return""}var st={};function Cn(e){{var a=at();if(!a){var c=typeof e=="string"?e:e.displayName||e.name;c&&(a=`
|
|
8
8
|
|
|
9
|
-
Check the top-level render call using <`+
|
|
9
|
+
Check the top-level render call using <`+c+">.")}return a}}function ot(e,a){{if(!e._store||e._store.validated||e.key!=null)return;e._store.validated=!0;var c=Cn(a);if(st[c])return;st[c]=!0;var m="";e&&e._owner&&e._owner!==ve.current&&(m=" It was passed a child from "+W(e._owner.type)+"."),G(e),E('Each child in a list should have a unique "key" prop.%s%s See https://reactjs.org/link/warning-keys for more information.',c,m),G(null)}}function it(e,a){{if(typeof e!="object")return;if(_e(e))for(var c=0;c<e.length;c++){var m=e[c];ye(m)&&ot(m,a)}else if(ye(e))e._store&&(e._store.validated=!0);else if(e){var A=T(e);if(typeof A=="function"&&A!==e.entries)for(var k=A.call(e),C;!(C=k.next()).done;)ye(C.value)&&ot(C.value,a)}}}function xn(e){{var a=e.type;if(a==null||typeof a=="string")return;var c;if(typeof a=="function")c=a.propTypes;else if(typeof a=="object"&&(a.$$typeof===f||a.$$typeof===_))c=a.propTypes;else return;if(c){var m=W(a);fn(c,e.props,"prop",m,e)}else if(a.PropTypes!==void 0&&!Ee){Ee=!0;var A=W(a);E("Component %s declared `PropTypes` instead of `propTypes`. Did you misspell the property assignment?",A||"Unknown")}typeof a.getDefaultProps=="function"&&!a.getDefaultProps.isReactClassApproved&&E("getDefaultProps is only used on classic React.createClass definitions. Use a static property named `defaultProps` instead.")}}function An(e){{for(var a=Object.keys(e.props),c=0;c<a.length;c++){var m=a[c];if(m!=="children"&&m!=="key"){G(e),E("Invalid prop `%s` supplied to `React.Fragment`. React.Fragment can only have `key` and `children` props.",m),G(null);break}}e.ref!==null&&(G(e),E("Invalid attribute `ref` supplied to `React.Fragment`."),G(null))}}var ut={};function ct(e,a,c,m,A,k){{var C=rn(e);if(!C){var S="";(e===void 0||typeof e=="object"&&e!==null&&Object.keys(e).length===0)&&(S+=" 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 O=Sn();O?S+=O:S+=at();var M;e===null?M="null":_e(e)?M="array":e!==void 0&&e.$$typeof===n?(M="<"+(W(e.type)||"Unknown")+" />",S=" Did you accidentally export a JSX literal instead of a component?"):M=typeof e,E("React.jsx: type is invalid -- expected a string (for built-in components) or a class/function (for composite components) but got: %s.%s",M,S)}var I=bn(e,a,c,A,k);if(I==null)return I;if(C){var L=a.children;if(L!==void 0)if(m)if(_e(L)){for(var Y=0;Y<L.length;Y++)it(L[Y],e);Object.freeze&&Object.freeze(L)}else E("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 it(L,e)}if($.call(a,"key")){var H=W(e),F=Object.keys(a).filter(function(Nn){return Nn!=="key"}),we=F.length>0?"{key: someKey, "+F.join(": ..., ")+": ...}":"{key: someKey}";if(!ut[H+we]){var In=F.length>0?"{"+F.join(": ..., ")+": ...}":"{}";E(`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} />`,we,H,In,H),ut[H+we]=!0}}return e===i?An(I):xn(I),I}}function kn(e,a,c){return ct(e,a,c,!0)}function Tn(e,a,c){return ct(e,a,c,!1)}var Rn=Tn,Mn=kn;Z.Fragment=i,Z.jsx=Rn,Z.jsxs=Mn})()),Z}var Ne;function Lt(){return Ne||(Ne=1,process.env.NODE_ENV==="production"?ne.exports=Ft():ne.exports=Dt()),ne.exports}var v=Lt();const je="platform-kit",Ut=!1,ce={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${je}]`,...t)}};class Vt extends u.Component{hasDispatched=!1;constructor(n){super(n),this.state={hasError:!1}}getMfeName(){if(this.props.mfeName)return this.props.mfeName;if(typeof window<"u"){const n=window;if(n.__MF_NAME__)return n.__MF_NAME__}return je}shouldShowDetails(){if(this.props.showDetails!==void 0)return this.props.showDetails;if(typeof sessionStorage<"u")try{const n=sessionStorage.getItem("config");if(n){const s=JSON.parse(n);if(s.showErrorDetails!==void 0)return s.showErrorDetails}}catch{}return Ut}dispatchError(n,s){if(this.hasDispatched||typeof window>"u")return;this.hasDispatched=!0;const i=this.getMfeName();ce.error("ErrorBoundary caught:",n);try{window.dispatchEvent(new CustomEvent("mfe-error",{detail:{mfeName:i,error:n.message||String(n),stack:n.stack,componentStack:s?.componentStack,timestamp:Date.now()},bubbles:!0}))}catch(o){ce.error("Failed to dispatch mfe-error event:",o)}}static getDerivedStateFromError(n){return{hasError:!0,error:n}}componentDidCatch(n,s){this.dispatchError(n,s),ce.error("Error info:",s.componentStack)}handleCopy=()=>{const n=`Error in ${this.getMfeName()}:
|
|
15
15
|
${this.state.error?.message}
|
|
16
|
-
${this.state.error?.stack}`;typeof navigator<"u"&&navigator.clipboard&&navigator.clipboard.writeText(n).then(()=>{alert("Ошибка скопирована в буфер обмена")}).catch(()=>{prompt("Скопируйте ошибку:",n)})};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 n=this.state.error?.message||"Unknown error",
|
|
16
|
+
${this.state.error?.stack}`;typeof navigator<"u"&&navigator.clipboard&&navigator.clipboard.writeText(n).then(()=>{alert("Ошибка скопирована в буфер обмена")}).catch(()=>{prompt("Скопируйте ошибку:",n)})};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 n=this.state.error?.message||"Unknown error",s=this.state.error?.stack||"",i=this.shouldShowDetails(),o=this.getMfeName();return v.jsxs("div",{style:{padding:"20px",textAlign:"center",color:"#d32f2f",fontFamily:"monospace",background:"#ffebee",border:"1px solid #ef5350",borderRadius:"4px",margin:"10px"},children:[v.jsxs("h2",{style:{fontSize:"16px",margin:"0 0 8px 0"},children:["⚠️ Ошибка в ",o]}),v.jsx("p",{style:{fontSize:"12px",margin:0},children:"Произошла ошибка в микрофронтенде. Сообщение отправлено в shell."}),i&&v.jsxs("details",{style:{whiteSpace:"pre-wrap",textAlign:"left",marginTop:"10px",background:"#fff",padding:"8px",borderRadius:"4px"},children:[v.jsx("summary",{style:{cursor:"pointer",fontWeight:"bold"},children:"Детали ошибки"}),v.jsxs("pre",{style:{fontSize:"11px",overflow:"auto",maxHeight:"150px",margin:"8px 0 0 0",padding:"8px",background:"#f5f5f5",borderRadius:"4px"},children:[n,s&&`
|
|
17
17
|
|
|
18
|
-
${a}`]})]}),m.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[m.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),m.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),m.jsx("button",{onClick:this.handleGoHome,style:{padding:"8px 12px",background:"#1976d2",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🏠 На главную"})]})]})}return this.props.children==null?null:this.props.children}}const F={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function wt({mfeName:t}){const{data:n,isLoading:a,error:u}=we({mfeName:t}),[o,p]=c.useState(!1);if(a)return m.jsxs("span",{className:"text-muted small me-2",children:[m.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(u||!n)return m.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${u||"нет данных"}`,children:[m.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const s=n,C=s.BUILD_VERSION||s.IMAGE_VERSION||s.APP_NAME||"N/A",d=[];return s.APP_NAME&&d.push({key:"APP_NAME",value:s.APP_NAME,label:"Приложение",icon:F.apps}),s.BUILD_VERSION&&d.push({key:"BUILD_VERSION",value:s.BUILD_VERSION,label:"Версия",icon:F.tags}),s.IMAGE_VERSION&&d.push({key:"IMAGE_VERSION",value:s.IMAGE_VERSION,label:"Образ",icon:F.storage}),s.GIT_COMMIT&&d.push({key:"GIT_COMMIT",value:s.GIT_COMMIT,label:"Commit",icon:F.spreadsheet}),s.GIT_BRANCH&&d.push({key:"GIT_BRANCH",value:s.GIT_BRANCH,label:"Ветка",icon:F.spreadsheet}),s.CI_COMMIT_AUTHOR&&d.push({key:"CI_COMMIT_AUTHOR",value:s.CI_COMMIT_AUTHOR,label:"Автор",icon:F.user}),s.CI_COMMIT_TIMESTAMP&&d.push({key:"CI_COMMIT_TIMESTAMP",value:s.CI_COMMIT_TIMESTAMP,label:"Дата",icon:F.clock}),s.CI_JOB_URL&&d.push({key:"CI_JOB_URL",value:s.CI_JOB_URL,label:"CI Job",icon:F.link}),s.CI_PIPELINE_URL&&d.push({key:"CI_PIPELINE_URL",value:s.CI_PIPELINE_URL,label:"Pipeline",icon:F.link}),s.CI_COMMIT_MESSAGE&&(s.CI_COMMIT_MESSAGE.length>60?s.CI_COMMIT_MESSAGE.substring(0,57)+"":s.CI_COMMIT_MESSAGE,d.push({key:"CI_COMMIT_MESSAGE",value:s.CI_COMMIT_MESSAGE,label:"Сообщение",icon:F.code})),m.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[m.jsxs("button",{onClick:()=>p(!o),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[m.jsx("span",{className:"me-1",children:F.info}),m.jsx("span",{className:"text-dark",children:C})]}),o&&m.jsxs("div",{style:{position:"absolute",top:"100%",right:0,zIndex:1e3,minWidth:"300px",background:"white",border:"1px solid #dee2e6",borderRadius:"8px",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",padding:"16px",marginTop:"4px"},children:[m.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[m.jsx("span",{className:"me-2",children:F.apps}),m.jsx("strong",{children:s.APP_NAME||t})]}),m.jsxs("div",{style:{marginBottom:"12px"},children:[m.jsx("span",{className:"text-muted",children:"Версия: "}),m.jsx("strong",{children:C})]}),d.length>0&&m.jsx("div",{style:{fontSize:"13px"},children:d.map(({key:w,value:f,label:_,icon:l})=>{const E=f.length>40&&(w.includes("URL")||w.includes("MESSAGE"))?`${f.substring(0,37)}...`:f;return m.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[m.jsx("span",{className:"me-2",style:{flexShrink:0},children:l}),m.jsxs("div",{style:{flex:1,minWidth:0},children:[m.jsx("div",{className:"small text-muted",children:_}),m.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:f,children:w.includes("URL")?m.jsx("a",{href:f,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:E}):E})]})]},w)})}),d.length===0&&m.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),m.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),m.jsx("button",{onClick:()=>p(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),o&&m.jsx("div",{onClick:()=>p(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const ce="platform-kit",ke=c.createContext(null);function bt({children:t}){const[n,a]=c.useState([]),u=typeof window<"u"&&window.__MF_NAME__||ce,o=c.useCallback((l,E,S,N)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:l,title:E,message:S,mfeName:u,timestamp:Date.now(),duration:N}),[u]),p=c.useCallback(l=>{a(S=>[...S,l].slice(0,5));const E=l.duration||5e3;E>0&&setTimeout(()=>{a(S=>S.filter(N=>N.id!==l.id))},E)},[]),s=c.useCallback(l=>{const E=o(l.type,l.title,l.message,l.duration);p(E),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:E,bubbles:!0}))},[o,p]),C=c.useCallback((l,E="Успешно")=>{s({type:"success",title:E,message:l})},[s]),d=c.useCallback((l,E="Ошибка")=>{s({type:"error",title:E,message:l})},[s]),w=c.useCallback((l,E="Предупреждение")=>{s({type:"warning",title:E,message:l})},[s]),f=c.useCallback((l,E="Информация")=>{s({type:"info",title:E,message:l})},[s]),_=c.useCallback(l=>{a(E=>E.filter(S=>S.id!==l))},[]);return c.useEffect(()=>{if(typeof window>"u")return;const l=E=>{const S=E.detail;if(S&&S.type&&S.title&&S.message){const N={...S,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};p(N)}};return window.addEventListener("mfe-notification",l),()=>{window.removeEventListener("mfe-notification",l)}},[p]),m.jsxs(ke.Provider,{value:{notify:s,notifySuccess:C,notifyError:d,notifyWarning:w,notifyInfo:f,removeNotification:_},children:[t,n.length>0&&m.jsx("div",{style:{position:"fixed",top:"80px",right:"20px",zIndex:9998,maxWidth:"400px",width:"100%",display:"flex",flexDirection:"column",gap:"8px",pointerEvents:"none"},children:n.map(l=>m.jsxs("div",{className:`notification notification-${l.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:l.type==="success"?"#d4edda":l.type==="error"?"#f8d7da":l.type==="warning"?"#fff3cd":"#d1ecf1",color:l.type==="success"?"#155724":l.type==="error"?"#721c24":l.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[m.jsxs("div",{style:{flex:1},children:[m.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:l.title}),m.jsx("p",{style:{margin:0,fontSize:"14px"},children:l.message}),m.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:l.mfeName})]}),m.jsx("button",{onClick:()=>_(l.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},l.id))})]})}function St(){const t=c.useContext(ke);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function xt(t){if(typeof window>"u")return;const n=window.__MF_NAME__||ce,a={...t,mfeName:n,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:a,bubbles:!0}))}const Re="platform-kit",Y={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error(`[${Re}]`,...t)},info:(...t)=>{}};function Ct(){if(typeof window>"u")return{isAuthenticated:!1};const t=window.__SHELL_AUTH_INSTANCE__;if(t)return t;const n=window.__SHELL_AUTH__;return n?.authInstance?n.authInstance:{isAuthenticated:!1}}function At(){if(typeof window>"u")return;const t=window.__SHELL_AUTH_INSTANCE__;t?.signinRedirect?t.signinRedirect().catch(n=>{Y.error("Failed to redirect to login:",n)}):window.location.href="/"}function Tt(t){const n=t.response;let a="unknown";return n?n.status===401?a="unauthorized":n.status===403?a="forbidden":n.status===404?a="not_found":n.status>=500&&(a="server"):a="network",{message:n?.data?.message??t.message??"Unknown error",code:n?.data?.code,status:n?.status,type:a,timestamp:Date.now(),url:t.config?.url}}function Me(t={}){const n=t.name||Re,a={log:(...o)=>Y.log(`[API:${n}]`,...o),warn:(...o)=>Y.warn(`[API:${n}]`,...o),error:(...o)=>Y.error(`[API:${n}]`,...o),info:(...o)=>Y.info(`[API:${n}]`,...o)},u=ot.create({timeout:t.timeout??1e4,baseURL:t.baseURL??"",headers:{"Content-Type":"application/json"}});return u.interceptors.request.use(o=>{const p=Ct();if(p?.isAuthenticated){const s=p.user?.profile?.access_token;s&&o.headers&&(o.headers.Authorization=`Bearer ${s}`,a.info("Auth token attached"))}else a.info("User not authenticated - request without token");return a.log(`${o.method?.toUpperCase()} ${o.url}`),o},o=>(a.error("Request interceptor error:",o.message),Promise.reject(o))),u.interceptors.response.use(o=>(a.log(`Response ${o.status}:`,o.config.url),o),o=>{const p=o.response?.status,s=o.config?.url;return p===401?(a.warn("401 Unauthorized - triggering re-auth"),At()):p===403?a.warn("403 Forbidden - insufficient permissions"):p===404?a.warn("404 Not found:",s):p===429?a.warn("429 Rate limited"):p===500?a.error("500 Server error:",s):o.response?a.warn(`Error ${p}:`,o.message):a.error("Network error - backend may be unavailable:",s),Promise.reject(Tt(o))}),u}const J=Me();async function kt(t,n,a=J){const u=await a.get(t,{params:n});return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function Rt(t,n,a=J){const u=await a.post(t,n);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function Mt(t,n,a=J){const u=await a.put(t,n);return{data:u.data,status:u.status,ok:u.status>=200&&u.status<300}}async function It(t,n=J){const a=await n.delete(t);return{data:a.data,status:a.status,ok:a.status>=200&&a.status<300}}function K(t,n){const a=n?.prefix?`[${n.prefix}]`:`[${t}]`;return{log:(...u)=>{},warn:(...u)=>{},error:(...u)=>{console.error(a,...u)},info:(...u)=>{}}}const Nt=K("platform-kit",{prefix:"AUTH"}),jt=K("platform-kit",{prefix:"API"}),Pt=K("platform-kit",{prefix:"ERROR"}),Ot=K("platform-kit",{prefix:"INFO"}),Ft={},Dt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function ue(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 n=JSON.parse(t);if(n.mfeName)return n.mfeName;if(n.name)return n.name;if(n.appName)return n.appName}}catch{}return null}function le(){const t=Ft;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let te=null,fe=!1;function je(t,n){const a=ue(t);if(a)return a;if(fe&&te)return te;const u=[{source:"window.__MF_NAME__",value:Ie()},{source:"sessionStorage.mf-config",value:Ne()},{source:"import.meta.env.VITE_MFE_NAME",value:le()}];for(const{source:p,value:s}of u)if(s)return te=s,fe=!0,s;if(n)return n;const o="Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw Dt.error(o),new Error(o)}function Lt(t){return je(t)}function Pe(t){return ue(t)?"props.mfeName":Ie()?"window.__MF_NAME__":Ne()?"sessionStorage.mf-config":le()?"import.meta.env.VITE_MFE_NAME":null}function Ut(t){return Pe(t)!==null}function Vt(){te=null,fe=!1}function Bt(t){const n=[];return ue(t)&&n.push("props.mfeName"),typeof window<"u"&&(window.__MF_NAME__&&n.push("window.__MF_NAME__"),sessionStorage.getItem("mf-config")&&n.push("sessionStorage.mf-config")),le()&&n.push("import.meta.env.VITE_MFE_NAME"),n}v.ErrorBoundary=yt,v.NotificationProvider=bt,v.VersionInfo=wt,v.api=J,v.apiLogger=jt,v.authLogger=Nt,v.createApiClient=Me,v.createMfLogger=K,v.del=It,v.dispatchNotification=xt,v.errorLogger=Pt,v.get=kt,v.getAllMfeNameSources=Bt,v.getAuth=$,v.getMfeName=je,v.getMfeNameSource=Pe,v.hasMfeName=Ut,v.infoLogger=Ot,v.post=Rt,v.put=Mt,v.requireMfeName=Lt,v.resetMfeNameCache=Vt,v.useApi=lt,v.useFeatureAdmin=ht,v.useFeatures=pt,v.useInfoData=we,v.useMicrofrontendsFeatures=gt,v.useNotification=St,v.usePermissions=dt,v.useShellAuth=z,v.useV1Config=ut,Object.defineProperty(v,Symbol.toStringTag,{value:"Module"})}));
|
|
18
|
+
${s}`]})]}),v.jsxs("div",{style:{marginTop:"12px",display:"flex",gap:"8px",justifyContent:"center"},children:[v.jsx("button",{onClick:this.handleCopy,style:{padding:"8px 12px",background:"#666",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"📋 Копировать"}),v.jsx("button",{onClick:this.handleRetry,style:{padding:"8px 12px",background:"#d32f2f",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🔄 Обновить"}),v.jsx("button",{onClick:this.handleGoHome,style:{padding:"8px 12px",background:"#1976d2",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"🏠 На главную"})]})]})}return this.props.children==null?null:this.props.children}}const D={info:"ℹ️",code:"💻",link:"🔗",user:"👤",clock:"🕐",apps:"📦",storage:"💾",tags:"🏷️",spreadsheet:"📊"};function Bt({mfeName:t}){const{data:n,isLoading:s,error:i}=xe({mfeName:t}),[o,p]=u.useState(!1);if(s)return v.jsxs("span",{className:"text-muted small me-2",children:[v.jsx("span",{className:"me-1",children:"⏳"}),"Загрузка..."]});if(i||!n)return v.jsxs("span",{className:"text-muted small me-2",title:`Ошибка: ${i||"нет данных"}`,children:[v.jsx("span",{className:"me-1",children:"ℹ️"}),"N/A"]});const r=n,g=r.BUILD_VERSION||r.IMAGE_VERSION||r.APP_NAME||"N/A",f=[];return r.APP_NAME&&f.push({key:"APP_NAME",value:r.APP_NAME,label:"Приложение",icon:D.apps}),r.BUILD_VERSION&&f.push({key:"BUILD_VERSION",value:r.BUILD_VERSION,label:"Версия",icon:D.tags}),r.IMAGE_VERSION&&f.push({key:"IMAGE_VERSION",value:r.IMAGE_VERSION,label:"Образ",icon:D.storage}),r.GIT_COMMIT&&f.push({key:"GIT_COMMIT",value:r.GIT_COMMIT,label:"Commit",icon:D.spreadsheet}),r.GIT_BRANCH&&f.push({key:"GIT_BRANCH",value:r.GIT_BRANCH,label:"Ветка",icon:D.spreadsheet}),r.CI_COMMIT_AUTHOR&&f.push({key:"CI_COMMIT_AUTHOR",value:r.CI_COMMIT_AUTHOR,label:"Автор",icon:D.user}),r.CI_COMMIT_TIMESTAMP&&f.push({key:"CI_COMMIT_TIMESTAMP",value:r.CI_COMMIT_TIMESTAMP,label:"Дата",icon:D.clock}),r.CI_JOB_URL&&f.push({key:"CI_JOB_URL",value:r.CI_JOB_URL,label:"CI Job",icon:D.link}),r.CI_PIPELINE_URL&&f.push({key:"CI_PIPELINE_URL",value:r.CI_PIPELINE_URL,label:"Pipeline",icon:D.link}),r.CI_COMMIT_MESSAGE&&(r.CI_COMMIT_MESSAGE.length>60?r.CI_COMMIT_MESSAGE.substring(0,57)+"":r.CI_COMMIT_MESSAGE,f.push({key:"CI_COMMIT_MESSAGE",value:r.CI_COMMIT_MESSAGE,label:"Сообщение",icon:D.code})),v.jsxs("div",{style:{display:"inline-block",position:"relative"},children:[v.jsxs("button",{onClick:()=>p(!o),style:{background:"transparent",border:"none",cursor:"pointer",padding:"4px 8px",fontSize:"14px",display:"inline-flex",alignItems:"center"},title:"Информация о версии",children:[v.jsx("span",{className:"me-1",children:D.info}),v.jsx("span",{className:"text-dark",children:g})]}),o&&v.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:[v.jsxs("div",{style:{marginBottom:"12px",paddingBottom:"8px",borderBottom:"1px solid #dee2e6",display:"flex",alignItems:"center"},children:[v.jsx("span",{className:"me-2",children:D.apps}),v.jsx("strong",{children:r.APP_NAME||t})]}),v.jsxs("div",{style:{marginBottom:"12px"},children:[v.jsx("span",{className:"text-muted",children:"Версия: "}),v.jsx("strong",{children:g})]}),f.length>0&&v.jsx("div",{style:{fontSize:"13px"},children:f.map(({key:y,value:l,label:_,icon:d})=>{const b=l.length>40&&(y.includes("URL")||y.includes("MESSAGE"))?`${l.substring(0,37)}...`:l;return v.jsxs("div",{style:{marginBottom:"8px",display:"flex",alignItems:"flex-start"},children:[v.jsx("span",{className:"me-2",style:{flexShrink:0},children:d}),v.jsxs("div",{style:{flex:1,minWidth:0},children:[v.jsx("div",{className:"small text-muted",children:_}),v.jsx("div",{className:"font-monospace small text-truncate",style:{maxWidth:"100%"},title:l,children:y.includes("URL")?v.jsx("a",{href:l,target:"_blank",rel:"noopener noreferrer",style:{color:"#007bff"},children:b}):b})]})]},y)})}),f.length===0&&v.jsx("div",{className:"text-center text-muted py-2 small",children:"Нет информации о версии"}),v.jsx("div",{style:{marginTop:"12px",paddingTop:"8px",borderTop:"1px solid #dee2e6",textAlign:"center",fontSize:"12px",color:"#6c757d"},children:"IngoBank DevOps Platform"}),v.jsx("button",{onClick:()=>p(!1),style:{position:"absolute",top:"8px",right:"8px",background:"transparent",border:"none",cursor:"pointer",fontSize:"16px",color:"#6c757d"},children:"×"})]}),o&&v.jsx("div",{onClick:()=>p(!1),style:{position:"fixed",top:0,left:0,right:0,bottom:0,zIndex:999}})]})}const le="platform-kit",Pe=u.createContext(null);function Wt({children:t}){const[n,s]=u.useState([]),i=typeof window<"u"&&window.__MF_NAME__||le,o=u.useCallback((d,b,w,N)=>({id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`,type:d,title:b,message:w,mfeName:i,timestamp:Date.now(),duration:N}),[i]),p=u.useCallback(d=>{s(w=>[...w,d].slice(0,5));const b=d.duration||5e3;b>0&&setTimeout(()=>{s(w=>w.filter(N=>N.id!==d.id))},b)},[]),r=u.useCallback(d=>{const b=o(d.type,d.title,d.message,d.duration);p(b),typeof window<"u"&&window.dispatchEvent(new CustomEvent("mfe-notification",{detail:b,bubbles:!0}))},[o,p]),g=u.useCallback((d,b="Успешно")=>{r({type:"success",title:b,message:d})},[r]),f=u.useCallback((d,b="Ошибка")=>{r({type:"error",title:b,message:d})},[r]),y=u.useCallback((d,b="Предупреждение")=>{r({type:"warning",title:b,message:d})},[r]),l=u.useCallback((d,b="Информация")=>{r({type:"info",title:b,message:d})},[r]),_=u.useCallback(d=>{s(b=>b.filter(w=>w.id!==d))},[]);return u.useEffect(()=>{if(typeof window>"u")return;const d=b=>{const w=b.detail;if(w&&w.type&&w.title&&w.message){const N={...w,id:`${Date.now()}-${Math.random().toString(36).substr(2,9)}`};p(N)}};return window.addEventListener("mfe-notification",d),()=>{window.removeEventListener("mfe-notification",d)}},[p]),v.jsxs(Pe.Provider,{value:{notify:r,notifySuccess:g,notifyError:f,notifyWarning:y,notifyInfo:l,removeNotification:_},children:[t,n.length>0&&v.jsx("div",{style:{position:"fixed",top:"80px",right:"20px",zIndex:9998,maxWidth:"400px",width:"100%",display:"flex",flexDirection:"column",gap:"8px",pointerEvents:"none"},children:n.map(d=>v.jsxs("div",{className:`notification notification-${d.type}`,style:{pointerEvents:"auto",padding:"12px 16px",borderRadius:"8px",background:d.type==="success"?"#d4edda":d.type==="error"?"#f8d7da":d.type==="warning"?"#fff3cd":"#d1ecf1",color:d.type==="success"?"#155724":d.type==="error"?"#721c24":d.type==="warning"?"#856404":"#0c5460",boxShadow:"0 4px 12px rgba(0,0,0,0.15)",display:"flex",alignItems:"flex-start",gap:"12px"},children:[v.jsxs("div",{style:{flex:1},children:[v.jsx("strong",{style:{display:"block",marginBottom:"4px"},children:d.title}),v.jsx("p",{style:{margin:0,fontSize:"14px"},children:d.message}),v.jsx("small",{style:{opacity:.7,fontSize:"12px"},children:d.mfeName})]}),v.jsx("button",{onClick:()=>_(d.id),style:{background:"transparent",border:"none",cursor:"pointer",fontSize:"18px",lineHeight:1,opacity:.5},children:"×"})]},d.id))})]})}function zt(){const t=u.useContext(Pe);return t||{notify:()=>{},notifySuccess:()=>{},notifyError:()=>{},notifyWarning:()=>{},notifyInfo:()=>{},removeNotification:()=>{}}}function Ht(t){if(typeof window>"u")return;const n=window.__MF_NAME__||le,s={...t,mfeName:n,timestamp:Date.now()};window.dispatchEvent(new CustomEvent("mfe-notification",{detail:s,bubbles:!0}))}function Q(t,n){const s=n?.prefix?`[${n.prefix}]`:`[${t}]`;return{log:(...i)=>{},warn:(...i)=>{},error:(...i)=>{console.error(s,...i)},info:(...i)=>{}}}const Gt=Q("platform-kit",{prefix:"AUTH"}),Yt=Q("platform-kit",{prefix:"API"}),Jt=Q("platform-kit",{prefix:"ERROR"}),Kt=Q("platform-kit",{prefix:"INFO"}),Xt={},Zt={log:(...t)=>{},warn:(...t)=>{},error:(...t)=>{console.error("[getMfeName]",...t)}};function fe(t){return t?t.mfeName?t.mfeName:t.name?t.name.replace("@ib-dop/",""):null:null}function Oe(){if(typeof window>"u")return null;const t=window;return t.__MF_NAME__?t.__MF_NAME__:null}function Fe(){if(typeof window>"u")return null;try{const t=sessionStorage.getItem("mf-config");if(t){const n=JSON.parse(t);if(n.mfeName)return n.mfeName;if(n.name)return n.name;if(n.appName)return n.appName}}catch{}return null}function de(){const t=Xt;return t.VITE_MFE_NAME?String(t.VITE_MFE_NAME):t.MFE_NAME?String(t.MFE_NAME):null}let re=null,pe=!1;function De(t,n){const s=fe(t);if(s)return s;if(pe&&re)return re;const i=[{source:"window.__MF_NAME__",value:Oe()},{source:"sessionStorage.mf-config",value:Fe()},{source:"import.meta.env.VITE_MFE_NAME",value:de()}];for(const{source:p,value:r}of i)if(r)return re=r,pe=!0,r;if(n)return n;const o="Cannot determine MFE name. Please pass mfeName in props, set window.__MF_NAME__, sessionStorage.mf-config, or VITE_MFE_NAME";throw Zt.error(o),new Error(o)}function Qt(t){return De(t)}function Le(t){return fe(t)?"props.mfeName":Oe()?"window.__MF_NAME__":Fe()?"sessionStorage.mf-config":de()?"import.meta.env.VITE_MFE_NAME":null}function qt(t){return Le(t)!==null}function $t(){re=null,pe=!1}function en(t){const n=[];return fe(t)&&n.push("props.mfeName"),typeof window<"u"&&(window.__MF_NAME__&&n.push("window.__MF_NAME__"),sessionStorage.getItem("mf-config")&&n.push("sessionStorage.mf-config")),de()&&n.push("import.meta.env.VITE_MFE_NAME"),n}h.ErrorBoundary=Vt,h.NotificationProvider=Wt,h.VersionInfo=Bt,h.api=V,h.apiLogger=Yt,h.authLogger=Gt,h.createApiClient=ke,h.createMfLogger=Q,h.del=xt,h.dispatchNotification=Ht,h.errorLogger=Jt,h.get=bt,h.getAccessToken=ft,h.getAllMfeNameSources=en,h.getAuthState=be,h.getMfeName=De,h.getMfeNameSource=Le,h.getShellAuth=U,h.hasMfeName=qt,h.infoLogger=Kt,h.isAuthenticated=dt,h.logout=pt,h.post=St,h.put=Ct,h.redirectToLogin=Se,h.requireMfeName=Qt,h.resetMfeNameCache=$t,h.useApi=K,h.useDel=Mt,h.useFeatureAdmin=Pt,h.useFeatures=jt,h.useGet=kt,h.useInfoData=xe,h.useMicrofrontendsFeatures=Ot,h.useNotification=zt,h.usePermissions=Nt,h.usePost=Tt,h.usePut=Rt,h.useShellAuth=J,h.useV1Config=mt,Object.defineProperty(h,Symbol.toStringTag,{value:"Module"})}));
|
package/dist/services/api.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/services/api.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAc,EAAE,aAAa,EAA0C,MAAM,OAAO,CAAA;AACpF,OAAO,KAAK,EAAY,WAAW,EAAE,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../src/services/api.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAc,EAAE,aAAa,EAA0C,MAAM,OAAO,CAAA;AACpF,OAAO,KAAK,EAAY,WAAW,EAAE,MAAM,UAAU,CAAA;AASrD;;GAEG;AACH,QAAA,MAAM,MAAM;mBACK,OAAO,EAAE;oBAGR,OAAO,EAAE;qBAGR,OAAO,EAAE;oBAGV,OAAO,EAAE;CAG1B,CAAA;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB;AAED;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAgED;;;;;;;;;;;GAWG;AACH,wBAAgB,eAAe,CAAC,MAAM,GAAE,SAAc,GAAG,aAAa,CA+FrE;AAGD,eAAO,MAAM,GAAG,eAAoB,CAAA;AAEpC;;GAEG;AACH,wBAAsB,GAAG,CAAC,CAAC,EACzB,GAAG,EAAE,MAAM,EACX,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAChC,MAAM,GAAE,aAAmB,GAC1B,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAOzB;AAED;;GAEG;AACH,wBAAsB,IAAI,CAAC,CAAC,EAC1B,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,MAAM,GAAE,aAAmB,GAC1B,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAOzB;AAED;;GAEG;AACH,wBAAsB,GAAG,CAAC,CAAC,EACzB,GAAG,EAAE,MAAM,EACX,IAAI,CAAC,EAAE,OAAO,EACd,MAAM,GAAE,aAAmB,GAC1B,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAOzB;AAED;;GAEG;AACH,wBAAsB,GAAG,CAAC,CAAC,EACzB,GAAG,EAAE,MAAM,EACX,MAAM,GAAE,aAAmB,GAC1B,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAOzB;AAGD,OAAO,EAAE,MAAM,EAAE,CAAA"}
|
package/dist/services/index.d.ts
CHANGED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/dist/types/index.d.ts
CHANGED
|
@@ -56,29 +56,6 @@ export interface ApiResponse<T> {
|
|
|
56
56
|
status: number;
|
|
57
57
|
ok: boolean;
|
|
58
58
|
}
|
|
59
|
-
/**
|
|
60
|
-
* Interface для конфигурации useApi
|
|
61
|
-
*/
|
|
62
|
-
export interface UseApiConfig<T = never> {
|
|
63
|
-
notifyOnError?: boolean;
|
|
64
|
-
notifyOnSuccess?: boolean;
|
|
65
|
-
successMessage?: string;
|
|
66
|
-
errorContext?: string;
|
|
67
|
-
onSuccess?: (data: T) => void;
|
|
68
|
-
onError?: (error: ApiError) => void;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Interface для результата useApi
|
|
72
|
-
*/
|
|
73
|
-
export interface UseApiResult<T> {
|
|
74
|
-
data: T | null;
|
|
75
|
-
error: ApiError | null;
|
|
76
|
-
isLoading: boolean;
|
|
77
|
-
isError: boolean;
|
|
78
|
-
isSuccess: boolean;
|
|
79
|
-
execute: () => Promise<T | null>;
|
|
80
|
-
reset: () => void;
|
|
81
|
-
}
|
|
82
59
|
/**
|
|
83
60
|
* MF Info Data from info.json
|
|
84
61
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAIA;;GAEG;AACH,MAAM,WAAW,gBAAgB;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAA;IACjB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,OAAO,CAAC,EAAE,gBAAgB,CAAA;IAC1B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;CACvB;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,SAAS,GAAG,IAAI,CAAA;IACtB,eAAe,EAAE,OAAO,CAAA;IACxB,SAAS,EAAE,OAAO,CAAA;IAClB,cAAc,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IACnC,UAAU,CAAC,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAChC,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAID;;GAEG;AACH,MAAM,MAAM,YAAY,GACpB,SAAS,GACT,cAAc,GACd,WAAW,GACX,WAAW,GACX,QAAQ,GACR,QAAQ,GACR,SAAS,CAAA;AAEb;;GAEG;AACH,MAAM,WAAW,QAAQ;IACvB,OAAO,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,YAAY,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;IACjB,GAAG,CAAC,EAAE,MAAM,CAAA;CACb;AAED;;GAEG;AACH,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,IAAI,EAAE,CAAC,CAAA;IACP,MAAM,EAAE,MAAM,CAAA;IACd,EAAE,EAAE,OAAO,CAAA;CACZ;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/index.d.ts
CHANGED
|
@@ -4,5 +4,6 @@
|
|
|
4
4
|
* Centralized utilities for microfrontend management
|
|
5
5
|
*/
|
|
6
6
|
export { getMfeName, requireMfeName, getMfeNameSource, hasMfeName, resetMfeNameCache, getAllMfeNameSources, type MfeNameProps, } from './mfeName';
|
|
7
|
+
export { getShellAuth, getAuthState, getAccessToken, isAuthenticated, redirectToLogin, logout, } from './shellAuth';
|
|
7
8
|
export type { MfeNameSource } from '../types';
|
|
8
9
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EACL,UAAU,EACV,cAAc,EACd,gBAAgB,EAChB,UAAU,EACV,iBAAiB,EACjB,oBAAoB,EACpB,KAAK,YAAY,GAClB,MAAM,WAAW,CAAA;AAGlB,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EACL,UAAU,EACV,cAAc,EACd,gBAAgB,EAChB,UAAU,EACV,iBAAiB,EACjB,oBAAoB,EACpB,KAAK,YAAY,GAClB,MAAM,WAAW,CAAA;AAGlB,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,eAAe,EACf,eAAe,EACf,MAAM,GACP,MAAM,aAAa,CAAA;AAGpB,YAAY,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA"}
|
package/dist/utils/mfeName.d.ts
CHANGED
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ShellAuth } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* Получить auth instance из window globals
|
|
4
|
+
*
|
|
5
|
+
* Поддерживает два формата:
|
|
6
|
+
* - window.__SHELL_AUTH_INSTANCE__ (прямой доступ)
|
|
7
|
+
* - window.__SHELL_AUTH__.authInstance (вложенный формат)
|
|
8
|
+
*
|
|
9
|
+
* @returns ShellAuth instance или null
|
|
10
|
+
*/
|
|
11
|
+
export declare function getShellAuth(): ShellAuth | null;
|
|
12
|
+
/**
|
|
13
|
+
* Получить auth state (упрощённый формат для API interceptors)
|
|
14
|
+
*
|
|
15
|
+
* @returns Auth state с isAuthenticated и user
|
|
16
|
+
*/
|
|
17
|
+
export declare function getAuthState(): {
|
|
18
|
+
isAuthenticated: boolean;
|
|
19
|
+
user?: {
|
|
20
|
+
access_token?: string;
|
|
21
|
+
profile?: {
|
|
22
|
+
access_token?: string;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
} | null;
|
|
26
|
+
/**
|
|
27
|
+
* Получить access token из shell auth
|
|
28
|
+
*
|
|
29
|
+
* @returns Access token или null
|
|
30
|
+
*/
|
|
31
|
+
export declare function getAccessToken(): string | null;
|
|
32
|
+
/**
|
|
33
|
+
* Проверить авторизован ли пользователь
|
|
34
|
+
*/
|
|
35
|
+
export declare function isAuthenticated(): boolean;
|
|
36
|
+
/**
|
|
37
|
+
* Инициировать редирект на страницу логина
|
|
38
|
+
*/
|
|
39
|
+
export declare function redirectToLogin(): Promise<void>;
|
|
40
|
+
/**
|
|
41
|
+
* Выход из системы
|
|
42
|
+
*/
|
|
43
|
+
export declare function logout(): Promise<void>;
|
|
44
|
+
//# sourceMappingURL=shellAuth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"shellAuth.d.ts","sourceRoot":"","sources":["../../src/utils/shellAuth.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAEzC;;;;;;;;GAQG;AACH,wBAAgB,YAAY,IAAI,SAAS,GAAG,IAAI,CAgB/C;AAED;;;;GAIG;AACH,wBAAgB,YAAY,IAAI;IAC9B,eAAe,EAAE,OAAO,CAAA;IACxB,IAAI,CAAC,EAAE;QACL,YAAY,CAAC,EAAE,MAAM,CAAA;QACrB,OAAO,CAAC,EAAE;YACR,YAAY,CAAC,EAAE,MAAM,CAAA;SACtB,CAAA;KACF,CAAA;CACF,GAAG,IAAI,CAWP;AAED;;;;GAIG;AACH,wBAAgB,cAAc,IAAI,MAAM,GAAG,IAAI,CAQ9C;AAED;;GAEG;AACH,wBAAgB,eAAe,IAAI,OAAO,CAGzC;AAED;;GAEG;AACH,wBAAsB,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC,CAQrD;AAED;;GAEG;AACH,wBAAsB,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,CAM5C"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ibdop/platform-kit",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.13",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "Platform Kit - переиспользуемые хуки и компоненты для MF IngoBank DevOps Platform",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -45,8 +45,6 @@
|
|
|
45
45
|
"dev": "vite",
|
|
46
46
|
"build": "tsc && vite build",
|
|
47
47
|
"build:types": "tsc --emitDeclarationOnly --declaration --declarationMap",
|
|
48
|
-
"test": "vitest",
|
|
49
|
-
"test:ui": "vitest --ui",
|
|
50
48
|
"lint": "eslint src --ext .ts,.tsx",
|
|
51
49
|
"lint:fix": "eslint src --ext .ts,.tsx --fix",
|
|
52
50
|
"typecheck": "tsc --noEmit"
|
|
@@ -70,8 +68,8 @@
|
|
|
70
68
|
"homepage": "https://git.dev.banksoyuz.ru/devops/platform-kit",
|
|
71
69
|
"devDependencies": {
|
|
72
70
|
"@types/node": "^25.2.3",
|
|
73
|
-
"@types/react": "^
|
|
74
|
-
"@types/react-dom": "^
|
|
71
|
+
"@types/react": "^18.0.0",
|
|
72
|
+
"@types/react-dom": "^18.0.0",
|
|
75
73
|
"@vitejs/plugin-react": "^5.1.4",
|
|
76
74
|
"typescript": "^5.9.3",
|
|
77
75
|
"vite": "^7.3.1",
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/src/components/index.ts
CHANGED
|
File without changes
|
package/src/global.d.ts
CHANGED
|
File without changes
|
package/src/hooks/index.ts
CHANGED
|
@@ -2,13 +2,14 @@
|
|
|
2
2
|
* Hooks barrel export
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
|
-
export { useShellAuth,
|
|
5
|
+
export { useShellAuth, getShellAuth } from './useShellAuth'
|
|
6
6
|
|
|
7
7
|
export { useInfoData } from './useInfoData'
|
|
8
8
|
|
|
9
9
|
export { useV1Config } from './useV1Config'
|
|
10
10
|
|
|
11
|
-
export { useApi } from './useApi'
|
|
11
|
+
export { useApi, useGet, usePost, usePut, useDel } from './useApi'
|
|
12
|
+
export type { UseApiConfig, UseApiResult, UseGetConfig } from './useApi'
|
|
12
13
|
|
|
13
14
|
export { usePermissions } from './usePermissions'
|
|
14
15
|
|