@next-bricks/nav 0.5.7 → 0.7.0

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.
Files changed (83) hide show
  1. package/dist/bricks.json +22 -3
  2. package/dist/chunks/2167.0233006f.js +3 -0
  3. package/dist/chunks/{2167.b20aa2c9.js.map → 2167.0233006f.js.map} +1 -1
  4. package/dist/chunks/2544.bc748e96.js +3 -0
  5. package/dist/chunks/2544.bc748e96.js.map +1 -0
  6. package/dist/chunks/3646.c04f7c04.js +2 -0
  7. package/dist/chunks/3646.c04f7c04.js.map +1 -0
  8. package/dist/chunks/5381.0a41a7b8.js +2 -0
  9. package/dist/chunks/5381.0a41a7b8.js.map +1 -0
  10. package/dist/chunks/6051.2ad62d04.js +2 -0
  11. package/dist/chunks/6051.2ad62d04.js.map +1 -0
  12. package/dist/chunks/6482.6f246a7f.js +2 -0
  13. package/dist/chunks/6482.6f246a7f.js.map +1 -0
  14. package/dist/chunks/6660.294b8fc3.js +2 -0
  15. package/dist/chunks/6660.294b8fc3.js.map +1 -0
  16. package/dist/chunks/7067.dd6597ad.js +2 -0
  17. package/dist/chunks/{7067.0cebc199.js.map → 7067.dd6597ad.js.map} +1 -1
  18. package/dist/chunks/7746.6dc70441.js +2 -0
  19. package/dist/chunks/7746.6dc70441.js.map +1 -0
  20. package/dist/chunks/8498.5cb1636e.js +2 -0
  21. package/dist/chunks/{8498.a733d4eb.js.map → 8498.5cb1636e.js.map} +1 -1
  22. package/dist/chunks/9102.e9d4952e.js +3 -0
  23. package/dist/chunks/9102.e9d4952e.js.map +1 -0
  24. package/dist/chunks/easyops-navbar-alerts.c0bec48c.js +2 -0
  25. package/dist/chunks/easyops-navbar-alerts.c0bec48c.js.map +1 -0
  26. package/dist/chunks/eo-launchpad-button-v2.bbcc0d9b.js +2 -0
  27. package/dist/chunks/eo-launchpad-button-v2.bbcc0d9b.js.map +1 -0
  28. package/dist/chunks/eo-launchpad-button.eeced6ea.js +2 -0
  29. package/dist/chunks/eo-launchpad-button.eeced6ea.js.map +1 -0
  30. package/dist/chunks/eo-launchpad-quick-access.95d696a2.js +3 -0
  31. package/dist/chunks/eo-launchpad-quick-access.95d696a2.js.LICENSE.txt +7 -0
  32. package/dist/chunks/eo-launchpad-quick-access.95d696a2.js.map +1 -0
  33. package/dist/chunks/eo-nav-menu.c83e8b62.js +3 -0
  34. package/dist/chunks/{eo-nav-menu.b0de8f24.js.map → eo-nav-menu.c83e8b62.js.map} +1 -1
  35. package/dist/chunks/eo-search-launchpad.37cb188d.js +3 -0
  36. package/dist/chunks/eo-search-launchpad.37cb188d.js.LICENSE.txt +7 -0
  37. package/dist/chunks/eo-search-launchpad.37cb188d.js.map +1 -0
  38. package/dist/chunks/main.97e31edb.js +2 -0
  39. package/dist/chunks/main.97e31edb.js.map +1 -0
  40. package/dist/examples.json +3 -0
  41. package/dist/index.c4271aea.js +2 -0
  42. package/dist/index.c4271aea.js.map +1 -0
  43. package/dist/manifest.json +27 -0
  44. package/dist/types.json +15 -0
  45. package/dist-types/bootstrap.d.ts +3 -0
  46. package/dist-types/easyops-navbar-alerts/index.d.ts +14 -0
  47. package/dist-types/easyops-navbar-alerts/index.spec.d.ts +1 -0
  48. package/dist-types/launchpad-quick-access/index.d.ts +10 -0
  49. package/dist-types/launchpad-quick-access/index.spec.d.ts +1 -0
  50. package/dist-types/search-launchpad/index.d.ts +12 -0
  51. package/dist-types/search-launchpad/index.spec.d.ts +1 -0
  52. package/docs/eo-search-launchpad.md +9 -0
  53. package/package.json +2 -2
  54. package/dist/chunks/2167.b20aa2c9.js +0 -3
  55. package/dist/chunks/4443.d435144a.js +0 -2
  56. package/dist/chunks/4443.d435144a.js.map +0 -1
  57. package/dist/chunks/6051.f18558a3.js +0 -2
  58. package/dist/chunks/6051.f18558a3.js.map +0 -1
  59. package/dist/chunks/6482.f89e901b.js +0 -2
  60. package/dist/chunks/6482.f89e901b.js.map +0 -1
  61. package/dist/chunks/7067.0cebc199.js +0 -2
  62. package/dist/chunks/7746.626d61c6.js +0 -2
  63. package/dist/chunks/7746.626d61c6.js.map +0 -1
  64. package/dist/chunks/8142.a92cf697.js +0 -2
  65. package/dist/chunks/8142.a92cf697.js.map +0 -1
  66. package/dist/chunks/8498.a733d4eb.js +0 -2
  67. package/dist/chunks/9102.b12adfa9.js +0 -3
  68. package/dist/chunks/9102.b12adfa9.js.map +0 -1
  69. package/dist/chunks/9816.8cea5f76.js +0 -3
  70. package/dist/chunks/9816.8cea5f76.js.map +0 -1
  71. package/dist/chunks/eo-launchpad-button-v2.5f256b20.js +0 -2
  72. package/dist/chunks/eo-launchpad-button-v2.5f256b20.js.map +0 -1
  73. package/dist/chunks/eo-launchpad-button.8103d9bc.js +0 -2
  74. package/dist/chunks/eo-launchpad-button.8103d9bc.js.map +0 -1
  75. package/dist/chunks/eo-nav-menu.b0de8f24.js +0 -3
  76. package/dist/chunks/main.ef0911c7.js +0 -2
  77. package/dist/chunks/main.ef0911c7.js.map +0 -1
  78. package/dist/index.3cfe8e65.js +0 -2
  79. package/dist/index.3cfe8e65.js.map +0 -1
  80. /package/dist/chunks/{2167.b20aa2c9.js.LICENSE.txt → 2167.0233006f.js.LICENSE.txt} +0 -0
  81. /package/dist/chunks/{9816.8cea5f76.js.LICENSE.txt → 2544.bc748e96.js.LICENSE.txt} +0 -0
  82. /package/dist/chunks/{9102.b12adfa9.js.LICENSE.txt → 9102.e9d4952e.js.LICENSE.txt} +0 -0
  83. /package/dist/chunks/{eo-nav-menu.b0de8f24.js.LICENSE.txt → eo-nav-menu.c83e8b62.js.LICENSE.txt} +0 -0
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[3646],{3646:(e,t,n)=>{n.r(t);var a,r,i,o,l,c,s,m,u,d=n(4795),p=n(3395),h=n(381),g=n(687),v=n(2604),b=n(7896),x=n(8657),f=n.n(x),k=n(5366),y=n(7217),w=n(4511),E=n(9800),N=n(3808),Z=n(7993),C=(n(9234),n(2779)),T=n.n(C),S=n(1880),R=n(9705),D=n(2598),z=n(8462),I=n(8101),{defineElement:M,property:K}=(0,k.createDecorators)(),V=(0,w.wrapBrick)("eo-menu-item"),A=(0,w.wrapBrick)("eo-popover",{onVisibleChange:"visible.change",beforeVisibleChange:"before.visible.change"});function F(e){var{item:t}=e;return(0,N.cl)(t,e.topData)?f().createElement(q,(0,b.Z)({},e,{item:t})):(0,N.ty)(t)?f().createElement(G,(0,b.Z)({},e,{item:t})):f().createElement(B,(0,b.Z)({},e,{item:t}))}function B(e){var{item:t,index:n,hidden:a,showTooltip:r,selectedKey:i=[]}=e;return f().createElement(V,{"data-index":n,className:a?"overflow-menu-item":"",key:t.key,title:r?t.text:"",active:!!t.key&&i.includes(t.key)},(0,N.nC)(t,{width:"100%"}))}var L,_=e=>{var t,n=null!==(t=u)&&void 0!==t?t:u=window.innerWidth-document.body.clientWidth;document.body.style.paddingRight=e.detail?n+"px":"",document.body.style.overflow=e.detail?"hidden":"",document.body.style.touchAction=e.detail?"none":""};function q(e){var t,{index:n,hidden:a,item:r,topData:i,showTooltip:o,selectedKey:l=[],overflow:c}=e;return(null===(t=r.items)||void 0===t?void 0:t.length)>0?f().createElement(A,{"data-index":n,className:T()("popover",{subprime:!i,"overflow-menu-item":a}),trigger:"hover",placement:i?"bottom-start":"right-start",distance:0,anchorDisplay:"block",strategy:"fixed"},f().createElement(V,{className:"sub-menu-item-label",key:r.key,slot:"anchor",title:o?r.title:""},(0,N.cx)(r,!i)),f().createElement("div",{className:T()("sub-menu-wrapper",{"overflow-menu-wrapper":c})},r.items.map((e=>f().createElement(f().Fragment,{key:e.key},f().createElement(F,{item:e,selectedKey:l,showTooltip:o})))))):null}function G(e){var t,{item:n,showTooltip:a,selectedKey:r=[]}=e;return(null===(t=n.items)||void 0===t?void 0:t.length)>0?"category"===n.childLayout?f().createElement(P,{item:n,selectedKey:r,showTooltip:a,placement:"right-start",anchorDisplay:"block"}):"siteMap"===n.childLayout?f().createElement(W,{item:n,selectedKey:r,showTooltip:a,placement:"right-start",anchorDisplay:"block",topData:!1}):f().createElement(f().Fragment,null,f().createElement("div",{className:"group-label"},n.title),f().createElement("div",{className:"group-wrapper"},n.items.map((e=>f().createElement(f().Fragment,{key:e.key},f().createElement(F,{item:e,showTooltip:a,selectedKey:r})))))):null}function P(e){var t,{index:n,hidden:a,item:r,selectedKey:i=[],showTooltip:o,placement:l="bottom-start",anchorDisplay:c}=e;return(null===(t=r.items)||void 0===t?void 0:t.length)>0?f().createElement(A,{"data-index":n,className:T()("three-level-menu-popover","popover",{"overflow-menu-item":a}),trigger:"hover",placement:l,distance:0,key:r.key,strategy:"fixed",anchorDisplay:c,beforeVisibleChange:_},f().createElement(V,{className:"sub-menu-item-label",key:r.key,slot:"anchor",title:o?r.title:""},(0,N.cx)(r)),f().createElement("div",{className:"sub-menu-wrapper"},f().createElement(S.m,{menuItem:r,selectedKey:i}))):null}function W(e){var t,{index:n,hidden:a,item:r,selectedKey:i=[],showTooltip:o,placement:l="bottom-start",anchorDisplay:c,topData:s}=e,[m,u]=(0,x.useState)();return(null===(t=r.items)||void 0===t?void 0:t.length)>0?f().createElement(A,{"data-index":n,className:T()("popover",{"overflow-menu-item":a}),trigger:"hover",placement:l,distance:0,key:r.key,strategy:"fixed",anchorDisplay:c,beforeVisibleChange:e=>{u(e.detail),_(e)}},f().createElement(V,{className:"sub-menu-item-label",key:r.key,slot:"anchor",title:o?r.title:""},(0,N.cx)(r)),f().createElement("div",{className:T()("sub-menu-sit-map-wrapper",{"in-group-site-map":!s}),onClick:e=>e.stopPropagation()},f().createElement(R.hX,{menuGroup:r,selectedKey:i,visible:m}))):null}r=M("eo-nav-menu",{styleTexts:[D.Z,z.Z,I.Z,E.Z]}),i=K({attribute:!1}),l=K({type:Boolean});var j=new WeakMap,U=new WeakMap;class Q extends w.ReactNextElement{constructor(){super(...arguments),(0,p.Z)(this,j,{writable:!0,value:(s(this),o(this))}),(0,p.Z)(this,U,{writable:!0,value:c(this)})}get menu(){return(0,g.Z)(this,j)}set menu(e){(0,h.Z)(this,j,e)}get showTooltip(){return(0,g.Z)(this,U)}set showTooltip(e){(0,h.Z)(this,U,e)}render(){return f().createElement(H,{menu:this.menu,showTooltip:this.showTooltip})}}function H(e){var t,n,{menu:a,showTooltip:r}=e,i=(0,y.getHistory)(),o=(0,x.useRef)(null),[l,c]=(0,x.useState)(i.location),[s,m]=(0,x.useState)(Number.MAX_SAFE_INTEGER),{pathname:u,search:p}=l,[h,g]=(0,x.useState)([]),v=function(){var e=(0,d.Z)((function*(){var e,{selectedKeys:t}=(0,Z.OZ)(null!==(e=null==a?void 0:a.menuItems)&&void 0!==e?e:[],u,p,"");g(t)}));return function(){return e.apply(this,arguments)}}();(0,x.useEffect)((()=>{var e=i.listen((e=>{c(e)}));return v(),e}),[]),(0,x.useEffect)((()=>{if(o.current){var e=new ResizeObserver((()=>{if(o.current){var e,{width:t}=null!==(e=o.current.getClientRects()[0])&&void 0!==e?e:{},n=o.current.childNodes;if(n.length&&t){for(var a=t,r=n.length,i=0;i<n.length;i++){var{width:l,height:c}=n[i].getClientRects()[0];if(!c&&a-40<0){r=i-1;break}if((a=a-l-(i>0?8:0))<0){r=i;break}}m(r<0?0:r)}}}));return e.observe(o.current),()=>{e.disconnect()}}}),[]);var b=(0,x.useMemo)((()=>({type:"subMenu",title:"···",items:null==a?void 0:a.menuItems.slice(s,a.menuItems.length)})),[null==a?void 0:a.menuItems,s]);return f().createElement("div",{ref:o,className:"nav-menu-wrapper"},null==a?void 0:a.menuItems.map(((e,t)=>{var n,a=s<=t;return f().createElement(f().Fragment,{key:e.key},(0,N.cl)(e,!0)&&"category"===e.childLayout&&null!==(n=e.items)&&void 0!==n&&n.length?f().createElement(P,{index:t,hidden:a,item:e,showTooltip:r,selectedKey:h}):"group"===e.type&&"siteMap"===e.childLayout?f().createElement(W,{index:t,hidden:a,item:e,showTooltip:r,selectedKey:h,topData:!0}):f().createElement(F,{index:t,hidden:a,item:e,showTooltip:r,selectedKey:h,topData:!0}))})),f().createElement(F,{hidden:s>(null!==(t=null==a||null===(n=a.menuItems)||void 0===n?void 0:n.length)&&void 0!==t?t:0),item:b,showTooltip:r,selectedKey:h,overflow:!0,topData:!0}))}m=Q,({e:[o,c,s],c:[L,a]}=(0,v.Z)(m,[[i,1,"menu"],[l,1,"showTooltip"]],[r],0,void 0,w.ReactNextElement)),a();var O,X,$,J=n(8470),Y=n(9701),ee=n(4497),te=n(2152);(0,Y.initializeReactI18n)(ee.NS,ee.k);var ne,{defineElement:ae}=(0,k.createDecorators)();X=ae("eo-launchpad-button",{styleTexts:[te.Z]});class re extends w.ReactNextElement{render(){return f().createElement(J.L,null)}}$=re,[ne,O]=(0,v.Z)($,[],[X],0,void 0,w.ReactNextElement).c,O();var ie,oe,le,ce=n(7004),se=n(7370),me=n(4758),ue=n(6976),de=n(2892),pe=n(2085),he=n(3697),ge=n(3132);function ve(e){var{active:t}=e,n=(0,x.useRef)(null),a=(0,x.useCallback)((()=>{var e;null===(e=n.current)||void 0===e||e.focus()}),[]),{loading:r,q:i,setQ:o,menuGroups:l,favorites:c,loadingFavorites:s,recentVisits:m,pushRecentVisit:u,toggleStar:d,isStarred:p}=(0,pe.m1)(t),h=!!i,g=(0,x.useCallback)((e=>{o(e.target.value)}),[o]),v=(0,x.useCallback)((()=>{o("")}),[o]);return f().createElement("div",{className:T()("launchpad",{active:t})},f().createElement(ge.Z.Provider,{value:{searching:h,loadingFavorites:s,pushRecentVisit:u,toggleStar:d,isStarred:p}},f().createElement("div",{className:"sidebar"},f().createElement("div",{className:"quick-nav"},f().createElement("div",{className:"quick-nav-label"},"快捷访问"),f().createElement("ul",{className:"sidebar-menu"},c.map(((e,t)=>f().createElement(he.L,{key:t,item:e})))))),f().createElement("div",{className:T()("content",{loading:r})},f().createElement(be,{loading:r}),f().createElement("div",{className:"search-box",onClick:a},f().createElement(de.V3,{lib:"fa",icon:"magnifying-glass",className:"search-icon"}),f().createElement("input",{ref:n,placeholder:"通过关键字搜索",value:i,onChange:g,className:"search-input"}),f().createElement(de.V3,{lib:"antd",theme:"filled",icon:"close-circle",className:T()("search-clear",{searching:h}),onClick:v})),f().createElement("div",{className:T()({empty:0===m.length})},f().createElement("div",{className:"recent-visits-label"},"最近访问"),f().createElement("ul",{className:"recent-visits"},m.map(((e,t)=>f().createElement("li",{key:t},f().createElement(de.kk,(0,b.Z)({onClick:()=>u(e)},"app"===e.type?{url:e.url}:{href:e.url,target:"_blank"}),f().createElement("span",null,e.name))))))),f().createElement("ul",{className:"menu-groups"},l.map((e=>f().createElement(he.k,{key:e.name,name:e.name,items:e.items})))))))}function be(e){var{loading:t}=e;return t&&f().createElement("div",{className:"spinner"},f().createElement(de.V3,{lib:"fa",icon:"spinner",spinning:!0}))}var xe,{defineElement:fe}=(0,k.createDecorators)(),ke=(0,ce.unwrapProvider)("basic.lock-body-scroll");oe=fe("eo-launchpad-button-v2",{styleTexts:[ue.Z]});class ye extends w.ReactNextElement{disconnectedCallback(){super.disconnectedCallback(),ke(this,!1)}render(){return f().createElement(we,{host:this})}}function we(e){var{host:t}=e,[n,a]=(0,x.useState)(!1),[r,i]=(0,x.useState)(!1),o=()=>{i((e=>!e))};return(0,x.useEffect)((()=>(0,y.getHistory)().listen((()=>{i(!1)}))),[]),(0,x.useEffect)((()=>{r&&!n&&a(!0)}),[r,n]),(0,x.useEffect)((()=>(se.Z.filter=function(){return!0},(0,se.Z)("alt+l",(e=>{e.preventDefault(),i((e=>!e))})),(0,se.Z)("esc",(()=>{i(!1)})),()=>{se.Z.unbind("alt+l"),se.Z.unbind("esc")})),[]),(0,x.useEffect)((()=>{ke(t,r)}),[r,t]),(0,x.useEffect)((()=>{pe.yp.schedulePrefetch(),pe.sK.schedulePrefetch()}),[]),f().createElement(f().Fragment,null,f().createElement("a",{role:"button",className:T()("launchpad-button",{active:r}),onClick:o},f().createElement(me.Z,null)),f().createElement("div",{className:T()("mask",{active:r}),onClick:o}),n&&f().createElement(ve,{active:r}))}le=ye,[xe,ie]=(0,v.Z)(le,[],[oe],0,void 0,w.ReactNextElement).c,ie();var Ee=n(1815),Ne=n(5178),Ze=(0,w.wrapBrick)("eo-icon"),Ce=(0,w.wrapBrick)("eo-link"),Te=(0,w.wrapBrick)("eo-dropdown-actions",{onActionClick:"action.click",onVisibleChange:"visible.change"});function Se(e){var{data:t,actions:n,onActionClick:a}=e,{name:r,items:i}=t,[o,l]=(0,x.useState)(!1),c=(0,x.useMemo)((()=>null==n?void 0:n.filter((e=>(0,y.checkIfByTransform)(e,{type:"group"})))),[n]),s=(0,x.useCallback)((e=>{null==a||a({data:t,action:e.detail})}),[t,a]);return f().createElement("li",{className:T()("menu-group",{empty:0===i.length})},f().createElement("div",{className:"menu-group-label-wrapper"},f().createElement("span",{className:"menu-group-label"},r),f().createElement(Te,{actions:c,onVisibleChange:e=>{l(e.detail)},onActionClick:s},f().createElement(Ze,{lib:"fa",icon:"gear",className:T()("menu-config",{active:o})}))),f().createElement("ul",{className:"menu"},i.map((e=>"dir"===e.type?f().createElement(De,{key:e.instanceId,data:e,actions:n,onActionClick:a}):f().createElement(Re,{key:"".concat(e.type,"-").concat(e.id),data:e})))))}function Re(e){var t,{data:n}=e;return f().createElement("li",{className:"menu-item"},f().createElement(Ce,null,f().createElement(Ze,(0,b.Z)({className:"menu-icon",lib:"easyops",icon:"micro-app-center"},null!==(t=n.menuIcon)&&void 0!==t&&t.lib&&n.menuIcon.icon?(0,Ne.pick)(n.menuIcon,["lib","icon","theme","category","prefix"]):null)),f().createElement("span",{className:"menu-item-label"},n.name)))}function De(e){var{data:t,actions:n,onActionClick:a}=e,{name:r,items:i}=t,[o,l]=(0,x.useState)(!1),[c,s]=(0,x.useState)(!1),m=(0,x.useMemo)((()=>null==n?void 0:n.filter((e=>(0,y.checkIfByTransform)(e,{type:"dir"})))),[n]),u=(0,x.useCallback)((()=>{s((e=>!e))}),[]),d=(0,x.useCallback)((e=>{null==a||a({data:t,action:e.detail})}),[t,a]);return f().createElement("li",{className:T()("menu-item folder",{empty:0===i.length})},f().createElement("div",{className:"menu-folder-label-wrapper"},f().createElement(Ce,{onClick:u},f().createElement(Ze,{lib:"fa",prefix:"far",icon:"folder-open",className:"menu-icon"}),f().createElement("span",{className:"menu-item-label"},r),f().createElement(Ze,{lib:"antd",icon:c?"up":"down",className:"menu-item-toggle"})),f().createElement(Te,{actions:m,onVisibleChange:e=>{l(e.detail)},onActionClick:d},f().createElement(Ze,{lib:"fa",icon:"gear",className:T()("menu-config",{active:o})}))),f().createElement("ul",{className:T()("sub-menu",{expanded:c})},i.map((e=>f().createElement(Re,{key:e.instanceId,data:e})))))}(0,ce.unwrapProvider)("basic.show-dialog");var ze,Ie,Me,Ke,Ve,Ae,Fe,Be,Le,_e,qe,Ge,Pe,We=n(9534),{defineElement:je,property:Ue,event:Qe}=(0,k.createDecorators)();Ie=je("nav.launchpad-config",{styleTexts:[We.Z]}),Me=Ue({attribute:!1}),Ve=Ue({attribute:!1}),Fe=Qe({type:"action.click"});var He=new WeakMap,Oe=new WeakMap,Xe=new WeakMap,$e=new WeakMap,Je=new WeakMap;class Ye extends w.ReactNextElement{constructor(){super(...arguments),(0,p.Z)(this,$e,{get:tt,set:et}),(0,p.Z)(this,He,{writable:!0,value:(qe(this),Ke(this))}),(0,p.Z)(this,Oe,{writable:!0,value:Ae(this)}),(0,p.Z)(this,Xe,{writable:!0,value:Be(this)}),(0,p.Z)(this,Je,{writable:!0,value:e=>{(0,g.Z)(this,$e).emit(e)}})}get menuGroups(){return(0,g.Z)(this,He)}set menuGroups(e){(0,h.Z)(this,He,e)}get actions(){return(0,g.Z)(this,Oe)}set actions(e){(0,h.Z)(this,Oe,e)}render(){return f().createElement(nt,{menuGroups:this.menuGroups,actions:this.actions,onActionClick:(0,g.Z)(this,Je)})}}function et(e){_e(this,e)}function tt(){return Le(this)}function nt(e){var{menuGroups:t,actions:n,onActionClick:a}=e;return f().createElement("ul",{className:"menu-groups"},null==t?void 0:t.map((e=>f().createElement(Se,{key:e.instanceId,data:e,actions:n,onActionClick:a}))))}Ge=Ye,({e:[Ke,Ae,Be,Le,_e,qe],c:[Pe,ze]}=(0,v.Z)(Ge,[[Me,1,"menuGroups"],[Ve,1,"actions"],[Fe,1,"actionClickEvent",e=>(0,g.Z)(e,Xe),(e,t)=>(0,h.Z)(e,Xe,t)]],[Ie],0,(e=>Je.has((0,Ee.Z)(e))),w.ReactNextElement)),ze();var at,rt,it,ot,lt=n(1150),ct=n(1229),st=n(2890),mt=n(5239),ut=n.n(mt),dt=n(7128),pt=(0,w.wrapBrick)("eo-icon"),ht=(0,w.wrapBrick)("eo-link"),{defineElement:gt,property:vt}=(0,k.createDecorators)();rt=gt("nav.easyops-navbar-alerts",{styleTexts:[dt.Z]});class bt extends w.ReactNextElement{render(){return f().createElement(ft,null)}}it=bt,[ot,at]=(0,v.Z)(it,[],[rt],0,void 0,w.ReactNextElement).c,at();var xt=new st.o(localStorage);function ft(){var[e,t]=(0,x.useState)(null),[n,a]=(0,x.useState)(null),r=(0,lt.useCurrentApp)(),i=(0,x.useMemo)((()=>{var e=ct.auth.getAuth();return"license:".concat(e.org)}),[]);(0,x.useEffect)((()=>{var e,n,a=ct.auth.getAuth(),r=null===(e=a.license)||void 0===e?void 0:e.validDaysLeft;r&&r<=15&&a.isAdmin&&(!(n=xt.getItem(i))||ut()().unix()>n)&&t(r)}),[i]),(0,x.useEffect)((()=>{var e=e=>{var t=e.detail.renderTime,{loadTime:n,loadInfoPage:i}=(0,y.getRuntime)().getMiscSettings();null!=r&&r.isBuildPush&&n>0&&t>n&&a({renderTime:yt(t),suggestTime:yt(n),suggestUrl:i})};return window.addEventListener("route.render",e),()=>{window.removeEventListener("route.render",e)}}),[r]);var o=(0,x.useCallback)((()=>{xt.setItem(i,ut()().unix()+86400),t(null)}),[i]);return f().createElement(f().Fragment,null,n&&f().createElement(kt,{text:"您的页面存在性能问题, 当前页面渲染时间 ".concat(n.renderTime," 秒, 规定阈值为: ").concat(n.suggestTime," 秒, 您已超过。请您针对该页面进行性能优化!"),type:"warning",link:n.suggestUrl?{label:"建议解决思路",url:n.suggestUrl}:void 0}),null!==e&&f().createElement(kt,{text:"离 License 过期还有 ".concat(e," 天"),type:"info",closable:!0,onClose:o}))}function kt(e){var{text:t,type:n,closable:a,link:r,onClose:i}=e;return f().createElement("div",{className:"alert ".concat(n)},f().createElement("span",{className:"text"},t),r&&f().createElement(ht,{className:"link",href:r.url,target:"_blank"},r.label),a&&f().createElement(pt,{lib:"antd",icon:"close",className:"icon",role:"button",onClick:i}))}function yt(e){return Math.floor(100*e)/1e5}var wt,Et,Nt,Zt,Ct=n(2252),{defineElement:Tt,property:St}=(0,k.createDecorators)();Et=Tt("eo-launchpad-quick-access",{styleTexts:[Ct.Z]});class Rt extends w.ReactNextElement{render(){return f().createElement(Dt,null)}}function Dt(){var{favorites:e,loadingFavorites:t,pushRecentVisit:n,toggleStar:a,isStarred:r}=(0,pe.m1)(!0);return f().createElement(ge.Z.Provider,{value:{searching:!1,loadingFavorites:t,pushRecentVisit:n,toggleStar:a,isStarred:r}},f().createElement("ul",{className:"quick-access-list"},e.map(((e,t)=>f().createElement(he.L,{key:t,item:e})))))}Nt=Rt,[Zt,wt]=(0,v.Z)(Nt,[],[Et],0,void 0,w.ReactNextElement).c,wt();var zt,It,Mt,Kt,Vt=n(2222),At=(0,w.wrapBrick)("eo-icon"),{defineElement:Ft,property:Bt}=(0,k.createDecorators)();It=Ft("eo-search-launchpad",{styleTexts:[Vt.Z]});class Lt extends w.ReactNextElement{render(){return f().createElement(_t,null)}}function _t(){var e=(0,x.useRef)(null),t=(0,x.useCallback)((()=>{var t;null===(t=e.current)||void 0===t||t.focus()}),[]),[n,a]=(0,x.useState)(!1),{loading:r,q:i,setQ:o,menuGroups:l,loadingFavorites:c,pushRecentVisit:s,toggleStar:m,isStarred:u}=(0,pe.m1)(n),d=!!i,p=(0,x.useCallback)((e=>{o(e.target.value)}),[o]),h=(0,x.useCallback)((()=>{o("")}),[o]);return f().createElement(ge.Z.Provider,{value:{searching:d,loadingFavorites:c,pushRecentVisit:s,toggleStar:m,isStarred:u}},f().createElement("div",{className:"container"},f().createElement("div",{className:"search-box",onClick:t},f().createElement(At,{lib:"fa",icon:"magnifying-glass",className:"search-icon"}),f().createElement("input",{ref:e,placeholder:"搜索产品/微应用",value:i,onChange:p,className:"search-input",onFocus:()=>a(!0),onBlur:()=>a(!1)}),f().createElement(At,{lib:"antd",theme:"filled",icon:"close-circle",className:T()("search-clear",{searching:d}),onClick:h,onMouseDown:e=>e.preventDefault()})),f().createElement("div",{className:T()("dropdown",{"dropdown-active":n}),onMouseDown:e=>e.preventDefault()},f().createElement("div",{className:T()("dropdown-content",{loading:r})},f().createElement(qt,{loading:r}),f().createElement("ul",{className:"menu-groups"},l.map((e=>f().createElement(he.k,{key:e.name,name:e.name,items:e.items}))))))))}function qt(e){var{loading:t}=e;return t&&f().createElement("div",{className:"spinner"},f().createElement(At,{lib:"fa",icon:"spinner",spinning:!0}))}Mt=Lt,[Kt,zt]=(0,v.Z)(Mt,[],[It],0,void 0,w.ReactNextElement).c,zt()},7128:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(9601),r=n.n(a),i=n(2609),o=n.n(i)()(r());o.push([e.id,":host{display:block}:host([hidden]){display:none}.alert{height:32px;padding:0 20px;display:flex;justify-content:center;align-items:center}.text{color:var(--antd-text-color);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon{margin-left:20px;cursor:pointer;color:#8c8c8c}.info{background-color:var(--color-info-bg)}.warning{background-color:var(--color-warning-bg)}",""]);const l=o.toString()},6976:(e,t,n)=>{n.d(t,{Z:()=>d});var a=n(9601),r=n.n(a),i=n(2609),o=n.n(i),l=n(8991),c=n.n(l),s=new URL(n(2754),n.b),m=o()(r()),u=c()(s);m.push([e.id,`:host{display:inline-block;width:32px;height:32px;--local-sidebar-menu-item-active-bg:rgba(0,0,0,0.04);--local-background:#fff;--local-menu-icon-color:#8c8c8c;--local-max-height:calc(100vh - var(--app-bar-height) - 10px)}:host([hidden]){display:none}:host-context(html[data-theme="dark"]),\n:host-context(html[data-theme="dark-v2"]){--local-sidebar-menu-item-active-bg:rgba(255,255,255,0.04);--local-background:#26262a;--local-menu-icon-color:rgba(255,255,255,0.45)}.launchpad-button{width:100%;height:100%;display:flex;justify-content:center;align-items:center;color:#999;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:3px}.launchpad-button:hover,\n.launchpad-button.active{background-color:var(--color-fill-bg-base-1)}.launchpad-button.active{color:var(--color-brand)}.mask{position:fixed;top:0;bottom:0;left:0;right:0;z-index:1;display:none}.mask.active{display:block}.launchpad{display:none;position:absolute;margin-top:4px;z-index:1;width:1110px;max-width:calc(100vw - 100px);max-height:var(--local-max-height);min-height:50vh;min-height:min(500px,var(--local-max-height));background-color:var(--local-background);border:1px solid var(--color-text-divider-line);border-radius:6px;box-shadow:var(--fullscreen-overlay-shadow)}.launchpad.active{display:flex}.sidebar{width:190px;padding:20px 0 24px;display:flex;flex-direction:column;background:var(--color-fill-bg-base-3);min-width:0;background-image:url(${u});background-size:205px 205px;background-repeat:no-repeat;background-position:left 52px bottom 27px}.quick-nav-label,\n.menu-group-label,\n.menu-item-label,\n.recent-visits span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-menu,\n.menu-groups,\n.menu,\n.sub-menu,\n.recent-visits{list-style:none;margin:0;padding:0}.sidebar-menu,\n.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.sidebar-menu-item > eo-link,\n.menu-item > eo-link,\n.recent-visits eo-link{display:block;min-width:0}.sidebar-menu-item > eo-link::part(link),\n.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.sidebar-menu-item{padding:0 12px 0 16px;justify-content:space-between}.sidebar-menu-icon{color:var(--left-sidebar-item-collapsed-icon-color)}.quick-nav{overflow-y:auto;flex:1}.quick-nav-label{color:var(--color-header-text);font-weight:500;margin-bottom:14px;padding:0 16px}.content{flex:1;padding:20px 24px 24px;min-width:0;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.search-box{border-bottom:1px solid var(--color-text-divider-line);display:flex;gap:8px;align-items:center;padding:10px 0;margin-top:-10px;cursor:text}.search-icon{color:var(--color-auxiliary-text)}.search-input{padding:0;margin:0;border:none;outline:none;color:inherit;background-color:transparent;font-size:14px;line-height:22px;flex:1;min-width:0}.search-input::placeholder{color:var(--color-disabled-text);opacity:1}.search-clear{display:none;color:var(--color-secondary-text);cursor:pointer}.search-clear.searching{display:inline-block}.search-clear:hover{color:var(--color-auxiliary-text)}.menu-groups,\n.recent-visits{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.menu-groups{display:grid;grid-gap:32px 8px;gap:32px 8px}.menu-group{padding-right:12px;color:var(--color-header-text)}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text);margin-bottom:14px}.sidebar-menu-item,\n.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-icon{color:var(--local-menu-icon-color)}.menu-item.active,\n.menu-item.active .menu-icon{color:var(--color-brand-active)}.sub-menu:not(.expanded){display:none}.sub-menu{margin-top:14px;margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item-remove,\n.menu-item-star{cursor:pointer}.menu-item-remove,\n.menu-item-star,\n.menu-item-toggle{color:var(--color-secondary-text)}.sidebar-menu-item:not(:hover) .menu-item-remove{display:none}.menu-item-remove:hover{color:var(--color-normal-text)}.menu-item-remove:active{color:var(--color-strong-text)}.menu-item-star{display:none}.can-star.starred > .menu-item-star,\n.can-star:hover > .menu-item-star{display:inline-block}.can-star:not(.starred) > .menu-item-star{color:var(--color-secondary-text)}.starred > .menu-item-star{color:var(--palette-yellow-6)}.recent-visits-label{margin-bottom:12px;font-size:var(--card-title-font-size);color:var(--color-header-text);font-weight:500}.recent-visits{display:grid;grid-gap:8px;gap:8px}.recent-visits eo-link::part(link){background-color:var(--color-fill-bg-base-1);border-radius:3px;color:var(--color-header-text);display:flex;align-items:center;height:24px;padding:0 8px}.sidebar-menu-item > eo-link:hover::part(link),\n.sidebar-menu-item > eo-link:hover .sidebar-menu-icon,\n.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-item > eo-link:hover .menu-item-toggle,\n.recent-visits eo-link:hover::part(link){color:var(--color-brand-hover)}.spinner{display:flex;justify-content:center;align-items:center;color:var(--theme-doderblue-color);flex:1;font-size:30px}.empty,\n.loading > :not(.spinner){display:none}@supports not (inset: 0){.search-box,\n .sidebar-menu,\n .menu,\n .sub-menu,\n .sidebar-menu-item,\n .menu-item:not(.folder),\n .sidebar-menu-item > eo-link::part(link),\n .menu-item > eo-link::part(link){gap:0}.content{display:grid;grid-auto-flow:row}.content:not(.loading){height:-webkit-min-content;height:-moz-min-content;height:min-content}.sidebar-menu > :not(:first-child),\n .menu > :not(:first-child),\n .sub-menu > :not(:first-child){margin-top:14px}.search-icon,\n .sidebar-menu-icon,\n .menu-icon{margin-right:8px}.search-clear,\n .menu-item-star,\n .menu-item-toggle{margin-left:8px}}`,""]);const d=m.toString()},9534:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(9601),r=n.n(a),i=n(2609),o=n.n(i)()(r());o.push([e.id,":host{display:block;--local-menu-icon-color:#8c8c8c}:host([hidden]){display:none;--local-menu-icon-color:rgba(255,255,255,0.45)}ul{list-style:none;margin:0;padding:0}.menu-groups{display:grid;grid-gap:32px 16px;gap:32px 16px;grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.sidebar-menu,\n.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.menu-folder-label-wrapper > eo-link,\n.menu-item > eo-link{display:block}.menu-folder-label-wrapper > eo-link::part(link),\n.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.menu-group-label-wrapper,\n.menu-folder-label-wrapper,\n.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-group-label-wrapper{gap:3px}.menu-group:not(.empty) .menu-group-label-wrapper{margin-bottom:14px}.menu-group-label,\n.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text)}.menu-icon{color:var(--local-menu-icon-color)}.menu-folder-label-wrapper > eo-link,\n.menu-item > eo-link{max-width:100%;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;min-width:0}.sub-menu:not(.expanded){display:none}.sub-menu{margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item:not(.empty) .sub-menu{margin-top:14px}.menu-item-toggle{color:var(--color-secondary-text)}.menu-config{visibility:hidden;color:var(--color-brand);cursor:pointer;display:flex;justify-content:center;align-items:center;width:24px;height:24px}.menu-config.active,\n.menu-group-label-wrapper:hover .menu-config,\n.menu-folder-label-wrapper:hover .menu-config{visibility:visible}.menu-folder-label-wrapper > eo-dropdown-actions{margin:-3px 0}.menu-config:hover,\n.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-folder-label-wrapper > eo-link:hover::part(link),\n.menu-folder-label-wrapper > eo-link:hover .menu-icon,\n.menu-folder-label-wrapper > eo-link:hover .menu-item-toggle{color:var(--color-brand-hover)}",""]);const l=o.toString()},2252:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(9601),r=n.n(a),i=n(2609),o=n.n(i)()(r());o.push([e.id,":host{display:block}:host([hidden]){display:none}.quick-access-list{display:grid;grid-gap:14px;gap:14px;grid-template-columns:repeat(2,1fr);list-style:none;margin:0;padding:0}.sidebar-menu-item{display:flex;align-items:center;justify-content:space-between;overflow:hidden}.sidebar-menu-item > eo-link{display:block;min-width:0}.sidebar-menu-item > eo-link::part(link){display:flex;align-items:center;height:20px;gap:8px;color:var(--color-header-text)}.sidebar-menu-icon{color:var(--left-sidebar-item-collapsed-icon-color)}.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-item-remove{color:var(--color-secondary-text);cursor:pointer}.sidebar-menu-item:not(:hover) .menu-item-remove{display:none}.menu-item-remove:hover{color:var(--color-normal-text)}.menu-item-remove:active{color:var(--color-strong-text)}.sidebar-menu-item > eo-link:hover::part(link),\n.sidebar-menu-item > eo-link:hover .sidebar-menu-icon{color:var(--color-brand-hover)}@supports not (inset: 0){.sidebar-menu-item,\n .sidebar-menu-item > eo-link::part(link){gap:0}.sidebar-menu-icon{margin-right:8px}}",""]);const l=o.toString()},2222:(e,t,n)=>{n.d(t,{Z:()=>l});var a=n(9601),r=n.n(a),i=n(2609),o=n.n(i)()(r());o.push([e.id,':host{display:block;--local-menu-icon-color:#8c8c8c}:host([hidden]){display:none}:host-context(html[data-theme="dark"]),\n:host-context(html[data-theme="dark-v2"]){--local-menu-icon-color:rgba(255,255,255,0.45)}.container{position:relative}.dropdown{margin-top:5px;position:absolute;top:100%;left:0px;width:100%;z-index:1050;padding:20px 24px 24px;overflow:hidden;box-sizing:border-box;background-color:var(--antd-select-dropdown-bg);border-radius:4px;box-shadow:var(--antd-box-shadow-base);display:none}.dropdown-active{display:block}.search-box{border-bottom:1px solid var(--color-text-divider-line);display:flex;gap:8px;align-items:center;padding:10px 0;cursor:text}.search-icon{color:var(--color-auxiliary-text)}.search-input{padding:0;margin:0;border:none;outline:none;color:inherit;background-color:transparent;font-size:14px;line-height:22px;flex:1;min-width:0}.search-input::placeholder{color:var(--color-disabled-text);opacity:1}.search-clear{display:none;color:var(--color-secondary-text);cursor:pointer}.search-clear.searching{display:inline-block}.search-clear:hover{color:var(--color-auxiliary-text)}.dropdown-content{min-width:0;display:flex;flex-direction:column;gap:24px;max-height:260px;overflow-y:auto}.spinner{display:flex;justify-content:center;align-items:center;color:var(--theme-doderblue-color);flex:1;font-size:30px}.loading > :not(.spinner){display:none}.menu-group-label,\n.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-groups,\n.menu,\n.sub-menu{list-style:none;margin:0;padding:0}.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.menu-item > eo-link{display:block;min-width:0}.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.menu-groups{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.menu-groups{display:grid;grid-gap:32px 8px;gap:32px 8px}.menu-group{padding-right:12px;color:var(--color-header-text)}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text);margin-bottom:14px}.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-icon{color:var(--local-menu-icon-color)}.menu-item.active,\n.menu-item.active .menu-icon{color:var(--color-brand-active)}.sub-menu:not(.expanded){display:none}.sub-menu{margin-top:14px;margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item-star{cursor:pointer}.menu-item-star,\n.menu-item-toggle{color:var(--color-secondary-text)}.menu-item-star{display:none}.can-star.starred > .menu-item-star,\n.can-star:hover > .menu-item-star{display:inline-block}.can-star:not(.starred) > .menu-item-star{color:var(--color-secondary-text)}.starred > .menu-item-star{color:var(--palette-yellow-6)}.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-item > eo-link:hover .menu-item-toggle{color:var(--color-brand-hover)}@supports not (inset: 0){.search-box,\n .menu,\n .sub-menu,\n .menu-item:not(.folder),\n .menu-item > eo-link::part(link){gap:0}.dropdown-content{display:grid;grid-auto-flow:row}.dropdown-content:not(.loading){height:-webkit-min-content;height:-moz-min-content;height:min-content}.menu > :not(:first-child),\n .sub-menu > :not(:first-child){margin-top:14px}.search-icon,\n .menu-icon{margin-right:8px}.search-clear,\n .menu-item-star,\n .menu-item-toggle{margin-left:8px}}',""]);const l=o.toString()},8991:e=>{e.exports=function(e,t){return t||(t={}),e?(e=String(e.__esModule?e.default:e),/^['"].*['"]$/.test(e)&&(e=e.slice(1,-1)),t.hash&&(e+=t.hash),/["'() \t\n]|(%20)/.test(e)||t.needQuotes?'"'.concat(e.replace(/"/g,'\\"').replace(/\n/g,"\\n"),'"'):e):e}},2754:(e,t,n)=>{e.exports=n.p+"images/9879d37a.png"}}]);
2
+ //# sourceMappingURL=3646.c04f7c04.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/3646.c04f7c04.js","mappings":"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","sources":["webpack:///./src/nav-menu/index.tsx","webpack:///./src/launchpad/index.tsx","webpack:///./src/launchpad-button-v2/Launchpad.tsx","webpack:///./src/launchpad-button-v2/index.tsx","webpack:///./src/launchpad-config/wrapped-bricks.ts","webpack:///./src/launchpad-config/MenuGroup.tsx","webpack:///./src/launchpad-config/index.tsx","webpack:///./src/easyops-navbar-alerts/index.tsx","webpack:///./src/launchpad-quick-access/index.tsx","webpack:///./src/search-launchpad/index.tsx","webpack:///./src/easyops-navbar-alerts/styles.shadow.css","webpack:///./src/launchpad-button-v2/styles.shadow.css","webpack:///./src/launchpad-config/styles.shadow.css","webpack:///./src/launchpad-quick-access/styles.shadow.css","webpack:///./src/search-launchpad/styles.shadow.css","webpack:///../../node_modules/css-loader/dist/runtime/getUrl.js"],"sourcesContent":["import React, {\n CSSProperties,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { getHistory } from \"@next-core/runtime\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport type { GeneralIconProps } from \"@next-bricks/icons/general-icon\";\nimport styleText from \"./nav-menu.shadow.css\";\nimport { LocationDescriptor, UnregisterCallback } from \"history\";\nimport type { SidebarMenu } from \"@next-bricks/basic/menu\";\nimport type {\n MenuItem as MenuItemComponent,\n MenuComponentProps,\n} from \"@next-bricks/basic/menu-item\";\nimport {\n isSimple,\n isSubMenu,\n isGroup,\n renderLinkCom,\n renderSpanCom,\n} from \"./utils.js\";\nimport { initMenuItemAndMatchCurrentPathKeys } from \"@next-shared/general/menu\";\nimport type {\n SidebarMenuGroup,\n SidebarMenuItem,\n SidebarMenuSimpleItem,\n} from \"@next-shared/general/types\";\nimport type {\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping,\n Placement,\n} from \"@next-bricks/basic/popover\";\nimport \"@next-core/theme\";\nimport classnames from \"classnames\";\nimport { ThreeLevelMenuPopoverContent } from \"./ThreeLevelMenuPopoverContent.js\";\nimport { SiteMapItem } from \"./site-map/SiteMapItem.js\";\nimport SiteMapStyleText from \"../nav-menu/site-map/SiteMapItem.shadow.css\";\nimport ItemTagStyleText from \"../nav-menu/site-map/ItemTag.shadow.css\";\nimport GroupItemStyleText from \"../nav-menu/site-map/GroupItem.shadow.css\";\n\nconst { defineElement, property } = createDecorators();\n\nconst WrappedMenuItem = wrapBrick<MenuItemComponent, MenuComponentProps>(\n \"eo-menu-item\"\n);\nconst WrappedPopover = wrapBrick<\n Popover,\n PopoverProps,\n PopoverEvents,\n PopoverEventsMapping\n>(\"eo-popover\", {\n onVisibleChange: \"visible.change\",\n beforeVisibleChange: \"before.visible.change\",\n});\n\nconst GAP_WIDTH = 8;\n\ninterface NavMenuProps {\n menu?: SidebarMenu;\n showTooltip?: boolean;\n}\n\ninterface MenuItemComProps {\n index?: number;\n hidden?: boolean;\n item: SidebarMenuItem;\n topData?: boolean;\n selectedKey?: string[];\n showTooltip?: boolean;\n overflow?: boolean;\n}\ninterface SimpleMenuItemComProps extends MenuItemComProps {\n item: SidebarMenuSimpleItem;\n}\ninterface MenuGroupComProps extends MenuItemComProps {\n item: SidebarMenuGroup;\n}\nfunction RenderMenuItemCom(props: MenuItemComProps) {\n const { item } = props;\n return isSubMenu(item as SidebarMenuGroup, props.topData) ? (\n <SubMenuItemCom {...props} item={item as SidebarMenuGroup}></SubMenuItemCom>\n ) : isGroup(item) ? (\n <GroupMenuItemCom {...props} item={item as SidebarMenuGroup} />\n ) : (\n <SimpleMenuItemCom\n {...props}\n item={item as SidebarMenuSimpleItem}\n ></SimpleMenuItemCom>\n );\n}\nfunction SimpleMenuItemCom(props: SimpleMenuItemComProps) {\n const { item, index, hidden, showTooltip, selectedKey = [] } = props;\n return (\n <WrappedMenuItem\n data-index={index}\n className={hidden ? \"overflow-menu-item\" : \"\"}\n key={item.key}\n title={showTooltip ? item.text : \"\"}\n active={item.key ? selectedKey.includes(item.key) : false}\n >\n {renderLinkCom(item, { width: \"100%\" })}\n </WrappedMenuItem>\n );\n}\n\nlet scrollWidth: number;\n// istanbul ignore next;\nconst handlePopupVisibleChange = (event: CustomEvent<boolean>) => {\n // 当用户设置滚动条一直显示时,来回切换 overflow: hidden 会导致滚动条显示或隐藏\n // 造成页面宽度变化而导致的抖动的问题\n const paddingRight =\n scrollWidth ??\n (scrollWidth = window.innerWidth - document.body.clientWidth);\n\n document.body.style.paddingRight = event.detail ? paddingRight + \"px\" : \"\";\n document.body.style.overflow = event.detail ? \"hidden\" : \"\";\n document.body.style.touchAction = event.detail ? \"none\" : \"\";\n};\n\nfunction SubMenuItemCom({\n index,\n hidden,\n item,\n topData,\n showTooltip,\n selectedKey = [],\n overflow,\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n data-index={index}\n className={classnames(\"popover\", {\n subprime: !topData,\n \"overflow-menu-item\": hidden,\n })}\n trigger=\"hover\"\n placement={topData ? \"bottom-start\" : \"right-start\"}\n distance={0}\n anchorDisplay=\"block\"\n strategy=\"fixed\"\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item, !topData)}\n </WrappedMenuItem>\n <div\n className={classnames(\"sub-menu-wrapper\", {\n \"overflow-menu-wrapper\": overflow,\n })}\n >\n {item.items.map((innerItem) => (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n selectedKey={selectedKey}\n showTooltip={showTooltip}\n />\n </React.Fragment>\n ))}\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction GroupMenuItemCom({\n item,\n showTooltip,\n selectedKey = [],\n}: MenuGroupComProps) {\n return item.items?.length > 0 ? (\n item.childLayout === \"category\" ? (\n <ThreeLevelMenuCom\n item={item}\n selectedKey={selectedKey}\n showTooltip={showTooltip}\n placement=\"right-start\"\n anchorDisplay=\"block\"\n />\n ) : (item as SidebarMenuGroup).childLayout === \"siteMap\" ? (\n <SitMapMenCom\n item={item}\n selectedKey={selectedKey}\n showTooltip={showTooltip}\n placement=\"right-start\"\n anchorDisplay=\"block\"\n topData={false}\n />\n ) : (\n <>\n <div className=\"group-label\">{item.title}</div>\n <div className=\"group-wrapper\">\n {item.items.map((innerItem) => {\n return (\n <React.Fragment key={innerItem.key}>\n <RenderMenuItemCom\n item={innerItem}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n </React.Fragment>\n );\n })}\n </div>\n </>\n )\n ) : null;\n}\n\nfunction ThreeLevelMenuCom({\n index,\n hidden,\n item,\n selectedKey = [],\n showTooltip,\n placement = \"bottom-start\",\n anchorDisplay,\n}: {\n index?: number;\n hidden?: boolean;\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n placement?: Placement;\n anchorDisplay?: CSSProperties[\"display\"];\n}) {\n return item.items?.length > 0 ? (\n <WrappedPopover\n data-index={index}\n className={classnames(\"three-level-menu-popover\", \"popover\", {\n \"overflow-menu-item\": hidden,\n })}\n trigger={\"hover\"}\n placement={placement}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n anchorDisplay={anchorDisplay}\n beforeVisibleChange={handlePopupVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div className=\"sub-menu-wrapper\">\n <ThreeLevelMenuPopoverContent\n menuItem={item}\n selectedKey={selectedKey}\n ></ThreeLevelMenuPopoverContent>\n </div>\n </WrappedPopover>\n ) : null;\n}\n\nfunction SitMapMenCom({\n index,\n hidden,\n item,\n selectedKey = [],\n showTooltip,\n placement = \"bottom-start\",\n anchorDisplay,\n topData,\n}: {\n index?: number;\n hidden?: boolean;\n item: SidebarMenuGroup;\n selectedKey?: string[];\n showTooltip?: boolean;\n placement?: Placement;\n anchorDisplay?: CSSProperties[\"display\"];\n topData?: boolean;\n}) {\n const [visible, setVisible] = useState<boolean>();\n\n const handleVisibleChange = (event: CustomEvent<boolean>): void => {\n setVisible(event.detail);\n handlePopupVisibleChange(event);\n };\n\n return item.items?.length > 0 ? (\n <WrappedPopover\n data-index={index}\n className={classnames(\"popover\", {\n \"overflow-menu-item\": hidden,\n })}\n trigger={\"hover\"}\n placement={placement}\n distance={0}\n key={item.key}\n strategy=\"fixed\"\n anchorDisplay={anchorDisplay}\n beforeVisibleChange={handleVisibleChange}\n >\n <WrappedMenuItem\n className=\"sub-menu-item-label\"\n key={item.key}\n slot=\"anchor\"\n title={showTooltip ? item.title : \"\"}\n >\n {renderSpanCom(item)}\n </WrappedMenuItem>\n <div\n className={classnames(\"sub-menu-sit-map-wrapper\", {\n \"in-group-site-map\": !topData,\n })}\n onClick={(e) => e.stopPropagation()}\n >\n <SiteMapItem\n menuGroup={item}\n selectedKey={selectedKey}\n visible={visible}\n />\n </div>\n </WrappedPopover>\n ) : null;\n}\n\n/**\n * 菜单构件\n * @author sailor\n * @category navigation\n */\n@defineElement(\"eo-nav-menu\", {\n styleTexts: [\n SiteMapStyleText,\n ItemTagStyleText,\n GroupItemStyleText,\n styleText,\n ],\n})\nclass NavMenu extends ReactNextElement {\n /**\n * 菜单项\n */\n @property({\n attribute: false,\n })\n accessor menu: SidebarMenu | undefined;\n\n /**\n * 是否显示 tooltip\n */\n @property({\n type: Boolean,\n })\n accessor showTooltip: boolean | undefined;\n\n render() {\n return <NavMenuComponent menu={this.menu} showTooltip={this.showTooltip} />;\n }\n}\n\nfunction NavMenuComponent(props: NavMenuProps) {\n const { menu, showTooltip } = props;\n\n const history = getHistory();\n const navMenuWrapperRef = useRef<HTMLDivElement>(null);\n const [location, setLocation] = useState(history.location);\n const [overflowIndex, setOverflowIndex] = useState<number>(\n Number.MAX_SAFE_INTEGER\n );\n const { pathname, search } = location;\n\n const [selectedKey, setSelectedKey] = useState<string[]>([]);\n\n const setSelected = async (): Promise<void> => {\n const { selectedKeys } = initMenuItemAndMatchCurrentPathKeys(\n menu?.menuItems ?? [],\n pathname,\n search,\n \"\"\n );\n setSelectedKey(selectedKeys);\n };\n\n useEffect(() => {\n const unListen: UnregisterCallback = history.listen((location) => {\n setLocation(location);\n });\n setSelected();\n return unListen;\n }, []);\n\n useEffect(() => {\n if (navMenuWrapperRef.current) {\n const resizeObserver = new ResizeObserver(() => {\n if (navMenuWrapperRef.current) {\n const { width } = navMenuWrapperRef.current.getClientRects()[0] ?? {};\n const childNodes = navMenuWrapperRef.current.childNodes;\n\n if (childNodes.length && width) {\n let wrapperWidth = width;\n let overflowIndex = childNodes.length;\n\n for (let i = 0; i < childNodes.length; i++) {\n const { width: childWidth, height: childHeight } = (\n childNodes[i] as HTMLElement\n ).getClientRects()[0];\n\n if (!childHeight && wrapperWidth - 40 < 0) {\n overflowIndex = i - 1;\n break;\n }\n\n wrapperWidth =\n wrapperWidth - childWidth - (i > 0 ? GAP_WIDTH : 0);\n if (wrapperWidth < 0) {\n overflowIndex = i;\n break;\n }\n }\n\n setOverflowIndex(overflowIndex < 0 ? 0 : overflowIndex);\n }\n }\n });\n resizeObserver.observe(navMenuWrapperRef.current);\n\n return () => {\n resizeObserver.disconnect();\n };\n }\n }, []);\n\n const overflowMenu = useMemo(\n (): SidebarMenuItem => ({\n type: \"subMenu\",\n title: \"···\",\n items: menu?.menuItems.slice(\n overflowIndex,\n menu.menuItems.length\n ) as SidebarMenuItem[],\n }),\n [menu?.menuItems, overflowIndex]\n );\n\n return (\n <div ref={navMenuWrapperRef} className=\"nav-menu-wrapper\">\n {menu?.menuItems.map((item, index) => {\n const isHidden = overflowIndex <= index;\n return (\n <React.Fragment key={item.key}>\n {isSubMenu(item as SidebarMenuGroup, true) &&\n (item as SidebarMenuGroup).childLayout === \"category\" &&\n (item as SidebarMenuGroup).items?.length ? (\n <ThreeLevelMenuCom\n index={index}\n hidden={isHidden}\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n />\n ) : (item as SidebarMenuGroup).type === \"group\" &&\n (item as SidebarMenuGroup).childLayout === \"siteMap\" ? (\n <SitMapMenCom\n index={index}\n hidden={isHidden}\n item={item as SidebarMenuGroup}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n topData={true}\n />\n ) : (\n <RenderMenuItemCom\n index={index}\n hidden={isHidden}\n item={item}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n topData={true}\n />\n )}\n </React.Fragment>\n );\n })}\n <RenderMenuItemCom\n hidden={overflowIndex > (menu?.menuItems?.length ?? 0)}\n item={overflowMenu}\n showTooltip={showTooltip}\n selectedKey={selectedKey}\n overflow={true}\n topData={true}\n />\n </div>\n );\n}\n\nexport { NavMenu };\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { LaunchpadButton as LaunchpadButtonComponent } from \"./LaunchpadButton/LaunchpadButton.js\";\nimport { initializeReactI18n } from \"@next-core/i18n/react\";\nimport \"@next-core/theme\";\nimport { NS, locales } from \"./i18n.js\";\nimport styleText from \"./LaunchpadButton/LaunchpadButton.shadow.css\";\n\ninitializeReactI18n(NS, locales);\n\nconst { defineElement } = createDecorators();\n\n/**\n * Launchpad 按钮构件\n * @author sailor\n */\n@defineElement(\"eo-launchpad-button\", {\n styleTexts: [styleText],\n})\nclass LaunchpadButton extends ReactNextElement {\n render() {\n return <LaunchpadButtonComponent />;\n }\n}\n\nexport { LaunchpadButton };\n","import React, { useCallback, useRef } from \"react\";\nimport classNames from \"classnames\";\nimport { WrappedIcon, WrappedLink } from \"./wrapped-bricks\";\nimport { useLaunchpadInfo } from \"./useLaunchpadInfo.js\";\nimport { MenuGroup, SidebarMenuItem } from \"./MenuGroup.js\";\nimport { LaunchpadsContext } from \"./LaunchpadContext.js\";\nimport { SidebarMenuItemData } from \"./interfaces\";\n\nexport function Launchpad({ active }: { active?: boolean }) {\n const searchInputRef = useRef<HTMLInputElement>(null);\n const handleClickSearchBox = useCallback(() => {\n searchInputRef.current?.focus();\n }, []);\n\n const {\n loading,\n q,\n setQ,\n menuGroups,\n favorites,\n loadingFavorites,\n recentVisits,\n pushRecentVisit,\n toggleStar,\n isStarred,\n } = useLaunchpadInfo(active);\n const searching = !!q;\n\n const handleSearch = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setQ(e.target.value);\n },\n [setQ]\n );\n\n const clearSearch = useCallback(() => {\n setQ(\"\");\n }, [setQ]);\n\n return (\n <div className={classNames(\"launchpad\", { active })}>\n <LaunchpadsContext.Provider\n value={{\n searching,\n loadingFavorites,\n pushRecentVisit,\n toggleStar,\n isStarred,\n }}\n >\n <div className=\"sidebar\">\n <div className=\"quick-nav\">\n <div className=\"quick-nav-label\">快捷访问</div>\n {/* <Loading loading={loading || loadingFavorites} /> */}\n <ul className=\"sidebar-menu\">\n {favorites.map((item, index) => (\n <SidebarMenuItem\n key={index}\n item={item as SidebarMenuItemData}\n />\n ))}\n </ul>\n </div>\n </div>\n <div className={classNames(\"content\", { loading })}>\n <Loading loading={loading} />\n <div className=\"search-box\" onClick={handleClickSearchBox}>\n <WrappedIcon\n lib=\"fa\"\n icon=\"magnifying-glass\"\n className=\"search-icon\"\n />\n <input\n ref={searchInputRef}\n placeholder=\"通过关键字搜索\"\n value={q}\n onChange={handleSearch}\n className=\"search-input\"\n />\n <WrappedIcon\n lib=\"antd\"\n theme=\"filled\"\n icon=\"close-circle\"\n className={classNames(\"search-clear\", { searching })}\n onClick={clearSearch}\n />\n </div>\n <div className={classNames({ empty: recentVisits.length === 0 })}>\n <div className=\"recent-visits-label\">最近访问</div>\n <ul className=\"recent-visits\">\n {recentVisits.map((item, index) => (\n <li key={index}>\n <WrappedLink\n onClick={() => pushRecentVisit(item)}\n {...(item.type === \"app\"\n ? {\n url: item.url,\n }\n : {\n href: item.url,\n target: \"_blank\",\n })}\n >\n <span>{item.name}</span>\n </WrappedLink>\n </li>\n ))}\n </ul>\n </div>\n <ul className=\"menu-groups\">\n {menuGroups.map((group) => (\n <MenuGroup\n key={group.name}\n name={group.name}\n items={group.items}\n />\n ))}\n </ul>\n </div>\n </LaunchpadsContext.Provider>\n </div>\n );\n}\n\nfunction Loading({ loading }: { loading: boolean }) {\n return (\n loading && (\n <div className=\"spinner\">\n <WrappedIcon lib=\"fa\" icon=\"spinner\" spinning />\n </div>\n )\n );\n}\n","import React, { useEffect, useState } from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport \"@next-core/theme\";\nimport { getHistory } from \"@next-core/runtime\";\nimport type { lockBodyScroll as _lockBodyScroll } from \"@next-bricks/basic/data-providers/lock-body-scroll/lock-body-scroll\";\n// import { useTranslation, initializeReactI18n } from \"@next-core/i18n/react\";\nimport hotkeys from \"hotkeys-js\";\nimport classNames from \"classnames\";\n// import { K, NS, locales } from \"./i18n.js\";\nimport LaunchpadSvg from \"../images/launchpad.svg\";\nimport styleText from \"./styles.shadow.css\";\nimport { Launchpad } from \"./Launchpad\";\nimport { deferredFavorites, deferredLaunchpadInfo } from \"./useLaunchpadInfo\";\n\n// initializeReactI18n(NS, locales);\n\nconst { defineElement } = createDecorators();\n\nconst lockBodyScroll = unwrapProvider<typeof _lockBodyScroll>(\n \"basic.lock-body-scroll\"\n);\n\n/**\n * 构件 `eo-launchpad-button-v2`\n */\nexport\n@defineElement(\"eo-launchpad-button-v2\", {\n styleTexts: [styleText],\n})\nclass EoLaunchpadButtonV2 extends ReactNextElement {\n disconnectedCallback(): void {\n super.disconnectedCallback();\n lockBodyScroll(this, false);\n }\n\n render() {\n return <EoLaunchpadButtonV2Component host={this} />;\n }\n}\n\nexport function EoLaunchpadButtonV2Component({ host }: { host: HTMLElement }) {\n const [initialized, setInitialized] = useState(false);\n const [active, setActive] = useState(false);\n const toggleLaunchpad = (): void => {\n setActive((previous) => !previous);\n };\n\n useEffect(() => {\n // 当切换页面时,关闭 Launchpad。\n const unlisten = getHistory().listen(() => {\n setActive(false);\n });\n return unlisten;\n }, []);\n\n useEffect(() => {\n // 打开一次 launchpad 后,保留 DOM。\n if (active && !initialized) {\n setInitialized(true);\n }\n }, [active, initialized]);\n\n // istanbul ignore next\n useEffect(() => {\n hotkeys.filter = function () {\n return true;\n };\n\n // 快捷打开/关闭 Launchpad\n hotkeys(\"alt+l\", (event) => {\n event.preventDefault();\n setActive((previous) => !previous);\n });\n\n // 按 Esc 关闭 Launchpad\n hotkeys(\"esc\", () => {\n setActive(false);\n });\n\n return () => {\n hotkeys.unbind(\"alt+l\");\n hotkeys.unbind(\"esc\");\n };\n }, []);\n\n useEffect(() => {\n lockBodyScroll(host, active);\n }, [active, host]);\n\n useEffect(() => {\n deferredLaunchpadInfo.schedulePrefetch();\n deferredFavorites.schedulePrefetch();\n }, []);\n\n return (\n <>\n <a\n role=\"button\"\n className={classNames(\"launchpad-button\", { active })}\n onClick={toggleLaunchpad}\n >\n <LaunchpadSvg />\n </a>\n <div\n className={classNames(\"mask\", { active })}\n onClick={toggleLaunchpad}\n ></div>\n {initialized && <Launchpad active={active} />}\n </>\n );\n}\n","import { wrapBrick } from \"@next-core/react-element\";\nimport { unwrapProvider } from \"@next-core/utils/general\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport type {\n EoDropdownActions,\n DropdownActionsProps,\n DropdownActionsEvents,\n DropdownActionsEventsMapping,\n} from \"@next-bricks/basic/dropdown-actions\";\nimport type { showDialog as _showDialog } from \"@next-bricks/basic/data-providers/show-dialog/show-dialog\";\n\nexport const WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nexport const WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\nexport const WrappedDropdownActions = wrapBrick<\n EoDropdownActions,\n DropdownActionsProps,\n DropdownActionsEvents,\n DropdownActionsEventsMapping\n>(\"eo-dropdown-actions\", {\n onActionClick: \"action.click\",\n onVisibleChange: \"visible.change\",\n});\n\n// Use `unwrapProvider` to get the original function of a provider\nexport const showDialog =\n unwrapProvider<typeof _showDialog>(\"basic.show-dialog\");\n","import React, { useCallback, useMemo, useState } from \"react\";\nimport { pick } from \"lodash\";\nimport classNames from \"classnames\";\nimport { checkIfByTransform } from \"@next-core/runtime\";\nimport type { SimpleAction } from \"@next-bricks/basic/dropdown-actions\";\nimport {\n WrappedDropdownActions,\n WrappedIcon,\n WrappedLink,\n} from \"./wrapped-bricks\";\nimport type {\n ConfigMenuGroup,\n ConfigMenuItemDir,\n ConfigMenuItemNormal,\n MenuAction,\n MenuActionEventDetail,\n} from \"./interfaces\";\n\nexport interface MenuGroupProps {\n data: ConfigMenuGroup;\n actions?: MenuAction[];\n onActionClick?: (detail: MenuActionEventDetail) => void;\n}\n\nexport function MenuGroup({ data, actions, onActionClick }: MenuGroupProps) {\n const { name, items } = data;\n const [dropdownActive, setDropdownActive] = useState(false);\n\n const filteredActions = useMemo(\n () =>\n actions?.filter((item) => checkIfByTransform(item, { type: \"group\" })),\n [actions]\n );\n\n const handleActionClick = useCallback(\n (event: CustomEvent<SimpleAction>) => {\n onActionClick?.({\n data,\n action: event.detail,\n });\n },\n [data, onActionClick]\n );\n\n return (\n <li className={classNames(\"menu-group\", { empty: items.length === 0 })}>\n <div className=\"menu-group-label-wrapper\">\n <span className=\"menu-group-label\">{name}</span>\n <WrappedDropdownActions\n actions={filteredActions}\n onVisibleChange={(event) => {\n setDropdownActive(event.detail);\n }}\n onActionClick={handleActionClick}\n >\n <WrappedIcon\n lib=\"fa\"\n icon=\"gear\"\n className={classNames(\"menu-config\", { active: dropdownActive })}\n />\n </WrappedDropdownActions>\n </div>\n <ul className=\"menu\">\n {items.map((item) =>\n item.type === \"dir\" ? (\n <MenuItemFolder\n key={item.instanceId}\n data={item}\n actions={actions}\n onActionClick={onActionClick}\n />\n ) : (\n <MenuItem key={`${item.type}-${item.id}`} data={item} />\n )\n )}\n </ul>\n </li>\n );\n}\n\nexport interface MenuItemProps {\n data: ConfigMenuItemNormal;\n}\n\nexport function MenuItem({ data }: MenuItemProps) {\n return (\n <li className=\"menu-item\">\n <WrappedLink>\n <WrappedIcon\n className={`menu-icon`}\n lib=\"easyops\"\n icon=\"micro-app-center\"\n {...(data.menuIcon?.lib && data.menuIcon.icon\n ? (pick(data.menuIcon, [\n \"lib\",\n \"icon\",\n \"theme\",\n \"category\",\n \"prefix\",\n ]) as any)\n : null)}\n />\n <span className=\"menu-item-label\">{data.name}</span>\n </WrappedLink>\n </li>\n );\n}\n\nexport interface MenuItemFolderProps {\n data: ConfigMenuItemDir;\n actions?: MenuAction[];\n onActionClick?: (detail: MenuActionEventDetail) => void;\n}\n\nfunction MenuItemFolder({ data, actions, onActionClick }: MenuItemFolderProps) {\n const { name, items } = data;\n const [dropdownActive, setDropdownActive] = useState(false);\n const [expanded, setExpanded] = useState(false);\n\n const filteredActions = useMemo(\n () => actions?.filter((item) => checkIfByTransform(item, { type: \"dir\" })),\n [actions]\n );\n\n const toggle = useCallback(() => {\n setExpanded((previous) => !previous);\n }, []);\n\n const handleActionClick = useCallback(\n (event: CustomEvent<SimpleAction>) => {\n onActionClick?.({\n data,\n action: event.detail,\n });\n },\n [data, onActionClick]\n );\n\n return (\n <li\n className={classNames(\"menu-item folder\", { empty: items.length === 0 })}\n >\n <div className=\"menu-folder-label-wrapper\">\n <WrappedLink onClick={toggle}>\n <WrappedIcon\n lib=\"fa\"\n prefix=\"far\"\n icon=\"folder-open\"\n className=\"menu-icon\"\n />\n <span className=\"menu-item-label\">{name}</span>\n <WrappedIcon\n lib=\"antd\"\n icon={expanded ? \"up\" : \"down\"}\n className=\"menu-item-toggle\"\n />\n </WrappedLink>\n <WrappedDropdownActions\n actions={filteredActions}\n onVisibleChange={(event) => {\n setDropdownActive(event.detail);\n }}\n onActionClick={handleActionClick}\n >\n <WrappedIcon\n lib=\"fa\"\n icon=\"gear\"\n className={classNames(\"menu-config\", { active: dropdownActive })}\n />\n </WrappedDropdownActions>\n </div>\n <ul className={classNames(\"sub-menu\", { expanded })}>\n {items.map((item) => (\n <MenuItem key={item.instanceId} data={item} />\n ))}\n </ul>\n </li>\n );\n}\n","import React from \"react\";\nimport { EventEmitter, createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport type {\n ConfigMenuGroup,\n MenuAction,\n MenuActionEventDetail,\n} from \"./interfaces\";\nimport { MenuGroup } from \"./MenuGroup\";\nimport styleText from \"./styles.shadow.css\";\n\nconst { defineElement, property, event } = createDecorators();\n\n/**\n * 构件 `nav.launchpad-config`\n */\nexport\n@defineElement(\"nav.launchpad-config\", {\n styleTexts: [styleText],\n})\nclass LaunchpadConfig extends ReactNextElement implements LaunchpadConfigProps {\n @property({ attribute: false })\n accessor menuGroups: ConfigMenuGroup[] | undefined;\n\n @property({ attribute: false })\n accessor actions: MenuAction[] | undefined;\n\n @event({ type: \"action.click\" })\n accessor #actionClickEvent!: EventEmitter<MenuActionEventDetail>;\n\n #onActionClick = (detail: MenuActionEventDetail) => {\n this.#actionClickEvent.emit(detail);\n };\n\n render() {\n return (\n <LaunchpadConfigComponent\n menuGroups={this.menuGroups}\n actions={this.actions}\n onActionClick={this.#onActionClick}\n />\n );\n }\n}\n\nexport interface LaunchpadConfigProps {\n menuGroups?: ConfigMenuGroup[];\n actions?: MenuAction[];\n onActionClick?: (detail: MenuActionEventDetail) => void;\n}\n\nexport function LaunchpadConfigComponent({\n menuGroups,\n actions,\n onActionClick,\n}: LaunchpadConfigProps) {\n return (\n <ul className=\"menu-groups\">\n {menuGroups?.map((group) => (\n <MenuGroup\n key={group.instanceId}\n data={group}\n actions={actions}\n onActionClick={onActionClick}\n />\n ))}\n </ul>\n );\n}\n","import React, { useCallback, useEffect, useMemo, useState } from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport { getRuntime } from \"@next-core/runtime\";\nimport { useCurrentApp } from \"@next-core/react-runtime\";\nimport { auth } from \"@next-core/easyops-runtime\";\nimport \"@next-core/theme\";\nimport { JsonStorage } from \"@next-shared/general/JsonStorage\";\nimport moment from \"moment\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { Link, LinkProps } from \"@next-bricks/basic/link\";\nimport styleText from \"./styles.shadow.css\";\n\nexport const WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\nexport const WrappedLink = wrapBrick<Link, LinkProps>(\"eo-link\");\n\nconst { defineElement, property } = createDecorators();\n\n/**\n * 构件 `nav.easyops-navbar-alerts`\n */\nexport\n@defineElement(\"nav.easyops-navbar-alerts\", {\n styleTexts: [styleText],\n})\nclass EasyopsNavbarAlerts extends ReactNextElement {\n render() {\n return <EasyopsNavbarAlertsComponent />;\n }\n}\n\ninterface SlowRenderInfo {\n renderTime: number;\n suggestTime: number;\n suggestUrl?: string;\n}\n\nconst storage = new JsonStorage(localStorage);\n\nexport function EasyopsNavbarAlertsComponent() {\n const [licenseDaysLeft, setLicenseDaysLeft] = useState<number | null>(null);\n const [slowRender, setSlowRender] = useState<SlowRenderInfo | null>(null);\n const currentApp = useCurrentApp();\n const licenseDismissedKey = useMemo(() => {\n const authInfo = auth.getAuth();\n return `license:${authInfo.org}`;\n }, []);\n\n useEffect(() => {\n const authInfo = auth.getAuth();\n const validDaysLeft = authInfo.license?.validDaysLeft;\n let dismissExpireAt: number;\n if (\n validDaysLeft &&\n validDaysLeft <= 15 &&\n authInfo.isAdmin &&\n ((dismissExpireAt = storage.getItem(licenseDismissedKey)),\n !dismissExpireAt || moment().unix() > dismissExpireAt)\n ) {\n setLicenseDaysLeft(validDaysLeft);\n }\n }, [licenseDismissedKey]);\n\n useEffect(() => {\n const handelRouteRender = (e: Event): void => {\n const renderTime = (e as CustomEvent<{ renderTime: number }>).detail\n .renderTime;\n const { loadTime, loadInfoPage } = getRuntime().getMiscSettings() as {\n loadTime: number;\n loadInfoPage?: string;\n };\n if (currentApp?.isBuildPush && loadTime > 0 && renderTime > loadTime) {\n setSlowRender({\n renderTime: millisecondToSecond(renderTime),\n suggestTime: millisecondToSecond(loadTime),\n suggestUrl: loadInfoPage,\n });\n }\n };\n window.addEventListener(\"route.render\", handelRouteRender);\n return () => {\n window.removeEventListener(\"route.render\", handelRouteRender);\n };\n }, [currentApp]);\n\n const handleLicenseAlertDismiss = useCallback(() => {\n // 一天内不再显示。\n storage.setItem(licenseDismissedKey, moment().unix() + 86400);\n setLicenseDaysLeft(null);\n }, [licenseDismissedKey]);\n\n return (\n <>\n {slowRender && (\n <Alert\n text={`您的页面存在性能问题, 当前页面渲染时间 ${slowRender.renderTime} 秒, 规定阈值为: ${slowRender.suggestTime} 秒, 您已超过。请您针对该页面进行性能优化!`}\n type=\"warning\"\n link={\n slowRender.suggestUrl\n ? {\n label: \"建议解决思路\",\n url: slowRender.suggestUrl,\n }\n : undefined\n }\n />\n )}\n {licenseDaysLeft !== null && (\n <Alert\n text={`离 License 过期还有 ${licenseDaysLeft} 天`}\n type=\"info\"\n closable\n onClose={handleLicenseAlertDismiss}\n />\n )}\n </>\n );\n}\n\ninterface AlertProps {\n text: string;\n type: \"info\" | \"warning\";\n closable?: boolean;\n link?: {\n label: string;\n url: string;\n };\n onClose?: () => void;\n}\n\nfunction Alert({ text, type, closable, link, onClose }: AlertProps) {\n return (\n <div className={`alert ${type}`}>\n <span className=\"text\">{text}</span>\n {link && (\n <WrappedLink className=\"link\" href={link.url} target=\"_blank\">\n {link.label}\n </WrappedLink>\n )}\n {closable && (\n <WrappedIcon\n lib=\"antd\"\n icon=\"close\"\n className=\"icon\"\n role=\"button\"\n onClick={onClose}\n />\n )}\n </div>\n );\n}\n\nfunction millisecondToSecond(millisecond: number) {\n return Math.floor(millisecond * 100) / 1e5;\n}\n","import React from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport { useLaunchpadInfo } from \"../launchpad-button-v2/useLaunchpadInfo\";\nimport { LaunchpadsContext } from \"../launchpad-button-v2/LaunchpadContext\";\nimport { SidebarMenuItem } from \"../launchpad-button-v2/MenuGroup\";\nimport { SidebarMenuItemData } from \"../launchpad-button-v2/interfaces\";\n\nconst { defineElement, property } = createDecorators();\n\n/**\n * 快捷访问\n */\nexport\n@defineElement(\"eo-launchpad-quick-access\", {\n styleTexts: [styleText],\n})\nclass EoLaunchpadQuickAccess extends ReactNextElement {\n render() {\n return <EoLaunchpadQuickAccessComponent />;\n }\n}\n\nexport function EoLaunchpadQuickAccessComponent() {\n const {\n favorites,\n loadingFavorites,\n pushRecentVisit,\n toggleStar,\n isStarred,\n } = useLaunchpadInfo(true);\n\n return (\n <LaunchpadsContext.Provider\n value={{\n searching: false,\n loadingFavorites,\n pushRecentVisit,\n toggleStar,\n isStarred,\n }}\n >\n <ul className=\"quick-access-list\">\n {favorites.map((item, index) => (\n <SidebarMenuItem key={index} item={item as SidebarMenuItemData} />\n ))}\n </ul>\n </LaunchpadsContext.Provider>\n );\n}\n","import React, { useCallback, useRef, useState } from \"react\";\nimport { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport \"@next-core/theme\";\nimport styleText from \"./styles.shadow.css\";\nimport classNames from \"classnames\";\nimport { LaunchpadsContext } from \"../launchpad-button-v2/LaunchpadContext\";\nimport { useLaunchpadInfo } from \"../launchpad-button-v2/useLaunchpadInfo\";\nimport { MenuGroup } from \"../launchpad-button-v2/MenuGroup\";\nimport { GeneralIcon, GeneralIconProps } from \"@next-bricks/icons/general-icon\";\n\nexport const WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nconst { defineElement, property } = createDecorators();\n\n/**\n * launchpad 搜索\n */\nexport\n@defineElement(\"eo-search-launchpad\", {\n styleTexts: [styleText],\n})\nclass EoSearchLaunchpad extends ReactNextElement {\n render() {\n return <EoSearchLaunchpadComponent />;\n }\n}\n\nexport function EoSearchLaunchpadComponent() {\n const searchInputRef = useRef<HTMLInputElement>(null);\n const handleClickSearchBox = useCallback(() => {\n searchInputRef.current?.focus();\n }, []);\n\n const [active, setActive] = useState(false);\n\n const {\n loading,\n q,\n setQ,\n menuGroups,\n loadingFavorites,\n pushRecentVisit,\n toggleStar,\n isStarred,\n } = useLaunchpadInfo(active);\n const searching = !!q;\n\n const handleSearch = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n setQ(e.target.value);\n },\n [setQ]\n );\n\n const clearSearch = useCallback(() => {\n setQ(\"\");\n }, [setQ]);\n\n return (\n <LaunchpadsContext.Provider\n value={{\n searching,\n loadingFavorites,\n pushRecentVisit,\n toggleStar,\n isStarred,\n }}\n >\n <div className=\"container\">\n <div className=\"search-box\" onClick={handleClickSearchBox}>\n <WrappedIcon\n lib=\"fa\"\n icon=\"magnifying-glass\"\n className=\"search-icon\"\n />\n <input\n ref={searchInputRef}\n placeholder=\"搜索产品/微应用\"\n value={q}\n onChange={handleSearch}\n className=\"search-input\"\n onFocus={() => setActive(true)}\n onBlur={() => setActive(false)}\n />\n <WrappedIcon\n lib=\"antd\"\n theme=\"filled\"\n icon=\"close-circle\"\n className={classNames(\"search-clear\", { searching })}\n onClick={clearSearch}\n onMouseDown={(e) => e.preventDefault()}\n />\n </div>\n <div\n className={classNames(\"dropdown\", { \"dropdown-active\": active })}\n onMouseDown={(e) => e.preventDefault()}\n >\n <div className={classNames(\"dropdown-content\", { loading })}>\n <Loading loading={loading} />\n <ul className=\"menu-groups\">\n {menuGroups.map((group) => (\n <MenuGroup\n key={group.name}\n name={group.name}\n items={group.items}\n />\n ))}\n </ul>\n </div>\n </div>\n </div>\n </LaunchpadsContext.Provider>\n );\n}\n\nfunction Loading({ loading }: { loading: boolean }) {\n return (\n loading && (\n <div className=\"spinner\">\n <WrappedIcon lib=\"fa\" icon=\"spinner\" spinning />\n </div>\n )\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}.alert{height:32px;padding:0 20px;display:flex;justify-content:center;align-items:center}.text{color:var(--antd-text-color);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon{margin-left:20px;cursor:pointer;color:#8c8c8c}.info{background-color:var(--color-info-bg)}.warning{background-color:var(--color-warning-bg)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../images/launchpad-sidebar.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:inline-block;width:32px;height:32px;--local-sidebar-menu-item-active-bg:rgba(0,0,0,0.04);--local-background:#fff;--local-menu-icon-color:#8c8c8c;--local-max-height:calc(100vh - var(--app-bar-height) - 10px)}:host([hidden]){display:none}:host-context(html[data-theme=\"dark\"]),\n:host-context(html[data-theme=\"dark-v2\"]){--local-sidebar-menu-item-active-bg:rgba(255,255,255,0.04);--local-background:#26262a;--local-menu-icon-color:rgba(255,255,255,0.45)}.launchpad-button{width:100%;height:100%;display:flex;justify-content:center;align-items:center;color:#999;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;border-radius:3px}.launchpad-button:hover,\n.launchpad-button.active{background-color:var(--color-fill-bg-base-1)}.launchpad-button.active{color:var(--color-brand)}.mask{position:fixed;top:0;bottom:0;left:0;right:0;z-index:1;display:none}.mask.active{display:block}.launchpad{display:none;position:absolute;margin-top:4px;z-index:1;width:1110px;max-width:calc(100vw - 100px);max-height:var(--local-max-height);min-height:50vh;min-height:min(500px,var(--local-max-height));background-color:var(--local-background);border:1px solid var(--color-text-divider-line);border-radius:6px;box-shadow:var(--fullscreen-overlay-shadow)}.launchpad.active{display:flex}.sidebar{width:190px;padding:20px 0 24px;display:flex;flex-direction:column;background:var(--color-fill-bg-base-3);min-width:0;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:205px 205px;background-repeat:no-repeat;background-position:left 52px bottom 27px}.quick-nav-label,\n.menu-group-label,\n.menu-item-label,\n.recent-visits span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-menu,\n.menu-groups,\n.menu,\n.sub-menu,\n.recent-visits{list-style:none;margin:0;padding:0}.sidebar-menu,\n.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.sidebar-menu-item > eo-link,\n.menu-item > eo-link,\n.recent-visits eo-link{display:block;min-width:0}.sidebar-menu-item > eo-link::part(link),\n.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.sidebar-menu-item{padding:0 12px 0 16px;justify-content:space-between}.sidebar-menu-icon{color:var(--left-sidebar-item-collapsed-icon-color)}.quick-nav{overflow-y:auto;flex:1}.quick-nav-label{color:var(--color-header-text);font-weight:500;margin-bottom:14px;padding:0 16px}.content{flex:1;padding:20px 24px 24px;min-width:0;overflow-y:auto;display:flex;flex-direction:column;gap:24px}.search-box{border-bottom:1px solid var(--color-text-divider-line);display:flex;gap:8px;align-items:center;padding:10px 0;margin-top:-10px;cursor:text}.search-icon{color:var(--color-auxiliary-text)}.search-input{padding:0;margin:0;border:none;outline:none;color:inherit;background-color:transparent;font-size:14px;line-height:22px;flex:1;min-width:0}.search-input::placeholder{color:var(--color-disabled-text);opacity:1}.search-clear{display:none;color:var(--color-secondary-text);cursor:pointer}.search-clear.searching{display:inline-block}.search-clear:hover{color:var(--color-auxiliary-text)}.menu-groups,\n.recent-visits{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.menu-groups{display:grid;grid-gap:32px 8px;gap:32px 8px}.menu-group{padding-right:12px;color:var(--color-header-text)}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text);margin-bottom:14px}.sidebar-menu-item,\n.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-icon{color:var(--local-menu-icon-color)}.menu-item.active,\n.menu-item.active .menu-icon{color:var(--color-brand-active)}.sub-menu:not(.expanded){display:none}.sub-menu{margin-top:14px;margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item-remove,\n.menu-item-star{cursor:pointer}.menu-item-remove,\n.menu-item-star,\n.menu-item-toggle{color:var(--color-secondary-text)}.sidebar-menu-item:not(:hover) .menu-item-remove{display:none}.menu-item-remove:hover{color:var(--color-normal-text)}.menu-item-remove:active{color:var(--color-strong-text)}.menu-item-star{display:none}.can-star.starred > .menu-item-star,\n.can-star:hover > .menu-item-star{display:inline-block}.can-star:not(.starred) > .menu-item-star{color:var(--color-secondary-text)}.starred > .menu-item-star{color:var(--palette-yellow-6)}.recent-visits-label{margin-bottom:12px;font-size:var(--card-title-font-size);color:var(--color-header-text);font-weight:500}.recent-visits{display:grid;grid-gap:8px;gap:8px}.recent-visits eo-link::part(link){background-color:var(--color-fill-bg-base-1);border-radius:3px;color:var(--color-header-text);display:flex;align-items:center;height:24px;padding:0 8px}.sidebar-menu-item > eo-link:hover::part(link),\n.sidebar-menu-item > eo-link:hover .sidebar-menu-icon,\n.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-item > eo-link:hover .menu-item-toggle,\n.recent-visits eo-link:hover::part(link){color:var(--color-brand-hover)}.spinner{display:flex;justify-content:center;align-items:center;color:var(--theme-doderblue-color);flex:1;font-size:30px}.empty,\n.loading > :not(.spinner){display:none}@supports not (inset: 0){.search-box,\n .sidebar-menu,\n .menu,\n .sub-menu,\n .sidebar-menu-item,\n .menu-item:not(.folder),\n .sidebar-menu-item > eo-link::part(link),\n .menu-item > eo-link::part(link){gap:0}.content{display:grid;grid-auto-flow:row}.content:not(.loading){height:-webkit-min-content;height:-moz-min-content;height:min-content}.sidebar-menu > :not(:first-child),\n .menu > :not(:first-child),\n .sub-menu > :not(:first-child){margin-top:14px}.search-icon,\n .sidebar-menu-icon,\n .menu-icon{margin-right:8px}.search-clear,\n .menu-item-star,\n .menu-item-toggle{margin-left:8px}}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;--local-menu-icon-color:#8c8c8c}:host([hidden]){display:none;--local-menu-icon-color:rgba(255,255,255,0.45)}ul{list-style:none;margin:0;padding:0}.menu-groups{display:grid;grid-gap:32px 16px;gap:32px 16px;grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.sidebar-menu,\n.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.menu-folder-label-wrapper > eo-link,\n.menu-item > eo-link{display:block}.menu-folder-label-wrapper > eo-link::part(link),\n.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.menu-group-label-wrapper,\n.menu-folder-label-wrapper,\n.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-group-label-wrapper{gap:3px}.menu-group:not(.empty) .menu-group-label-wrapper{margin-bottom:14px}.menu-group-label,\n.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text)}.menu-icon{color:var(--local-menu-icon-color)}.menu-folder-label-wrapper > eo-link,\n.menu-item > eo-link{max-width:100%;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;min-width:0}.sub-menu:not(.expanded){display:none}.sub-menu{margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item:not(.empty) .sub-menu{margin-top:14px}.menu-item-toggle{color:var(--color-secondary-text)}.menu-config{visibility:hidden;color:var(--color-brand);cursor:pointer;display:flex;justify-content:center;align-items:center;width:24px;height:24px}.menu-config.active,\n.menu-group-label-wrapper:hover .menu-config,\n.menu-folder-label-wrapper:hover .menu-config{visibility:visible}.menu-folder-label-wrapper > eo-dropdown-actions{margin:-3px 0}.menu-config:hover,\n.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-folder-label-wrapper > eo-link:hover::part(link),\n.menu-folder-label-wrapper > eo-link:hover .menu-icon,\n.menu-folder-label-wrapper > eo-link:hover .menu-item-toggle{color:var(--color-brand-hover)}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}.quick-access-list{display:grid;grid-gap:14px;gap:14px;grid-template-columns:repeat(2,1fr);list-style:none;margin:0;padding:0}.sidebar-menu-item{display:flex;align-items:center;justify-content:space-between;overflow:hidden}.sidebar-menu-item > eo-link{display:block;min-width:0}.sidebar-menu-item > eo-link::part(link){display:flex;align-items:center;height:20px;gap:8px;color:var(--color-header-text)}.sidebar-menu-icon{color:var(--left-sidebar-item-collapsed-icon-color)}.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-item-remove{color:var(--color-secondary-text);cursor:pointer}.sidebar-menu-item:not(:hover) .menu-item-remove{display:none}.menu-item-remove:hover{color:var(--color-normal-text)}.menu-item-remove:active{color:var(--color-strong-text)}.sidebar-menu-item > eo-link:hover::part(link),\n.sidebar-menu-item > eo-link:hover .sidebar-menu-icon{color:var(--color-brand-hover)}@supports not (inset: 0){.sidebar-menu-item,\n .sidebar-menu-item > eo-link::part(link){gap:0}.sidebar-menu-icon{margin-right:8px}}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block;--local-menu-icon-color:#8c8c8c}:host([hidden]){display:none}:host-context(html[data-theme=\"dark\"]),\n:host-context(html[data-theme=\"dark-v2\"]){--local-menu-icon-color:rgba(255,255,255,0.45)}.container{position:relative}.dropdown{margin-top:5px;position:absolute;top:100%;left:0px;width:100%;z-index:1050;padding:20px 24px 24px;overflow:hidden;box-sizing:border-box;background-color:var(--antd-select-dropdown-bg);border-radius:4px;box-shadow:var(--antd-box-shadow-base);display:none}.dropdown-active{display:block}.search-box{border-bottom:1px solid var(--color-text-divider-line);display:flex;gap:8px;align-items:center;padding:10px 0;cursor:text}.search-icon{color:var(--color-auxiliary-text)}.search-input{padding:0;margin:0;border:none;outline:none;color:inherit;background-color:transparent;font-size:14px;line-height:22px;flex:1;min-width:0}.search-input::placeholder{color:var(--color-disabled-text);opacity:1}.search-clear{display:none;color:var(--color-secondary-text);cursor:pointer}.search-clear.searching{display:inline-block}.search-clear:hover{color:var(--color-auxiliary-text)}.dropdown-content{min-width:0;display:flex;flex-direction:column;gap:24px;max-height:260px;overflow-y:auto}.spinner{display:flex;justify-content:center;align-items:center;color:var(--theme-doderblue-color);flex:1;font-size:30px}.loading > :not(.spinner){display:none}.menu-group-label,\n.menu-item-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-groups,\n.menu,\n.sub-menu{list-style:none;margin:0;padding:0}.menu,\n.sub-menu{display:flex;flex-direction:column;gap:14px}.menu-item > eo-link{display:block;min-width:0}.menu-item > eo-link::part(link){height:20px;display:flex;align-items:center;gap:8px;color:var(--color-header-text)}.menu-groups{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}.menu-groups{display:grid;grid-gap:32px 8px;gap:32px 8px}.menu-group{padding-right:12px;color:var(--color-header-text)}.menu-group-label{font-size:var(--card-title-font-size);font-weight:500;color:var(--color-header-text);margin-bottom:14px}.menu-item:not(.folder){display:flex;gap:8px;align-items:center}.menu-icon{color:var(--local-menu-icon-color)}.menu-item.active,\n.menu-item.active .menu-icon{color:var(--color-brand-active)}.sub-menu:not(.expanded){display:none}.sub-menu{margin-top:14px;margin-left:8px;border-left:1px solid var(--color-text-divider-line);padding-left:15px}.menu-item-star{cursor:pointer}.menu-item-star,\n.menu-item-toggle{color:var(--color-secondary-text)}.menu-item-star{display:none}.can-star.starred > .menu-item-star,\n.can-star:hover > .menu-item-star{display:inline-block}.can-star:not(.starred) > .menu-item-star{color:var(--color-secondary-text)}.starred > .menu-item-star{color:var(--palette-yellow-6)}.menu-item > eo-link:hover::part(link),\n.menu-item > eo-link:hover .menu-icon,\n.menu-item > eo-link:hover .menu-item-toggle{color:var(--color-brand-hover)}@supports not (inset: 0){.search-box,\n .menu,\n .sub-menu,\n .menu-item:not(.folder),\n .menu-item > eo-link::part(link){gap:0}.dropdown-content{display:grid;grid-auto-flow:row}.dropdown-content:not(.loading){height:-webkit-min-content;height:-moz-min-content;height:min-content}.menu > :not(:first-child),\n .sub-menu > :not(:first-child){margin-top:14px}.search-icon,\n .menu-icon{margin-right:8px}.search-clear,\n .menu-item-star,\n .menu-item-toggle{margin-left:8px}}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","\"use strict\";\n\nmodule.exports = function (url, options) {\n if (!options) {\n options = {};\n }\n if (!url) {\n return url;\n }\n url = String(url.__esModule ? url.default : url);\n\n // If url is already wrapped in quotes, remove them\n if (/^['\"].*['\"]$/.test(url)) {\n url = url.slice(1, -1);\n }\n if (options.hash) {\n url += options.hash;\n }\n\n // Should url be wrapped?\n // See https://drafts.csswg.org/css-values-3/#urls\n if (/[\"'() \\t\\n]|(%20)/.test(url) || options.needQuotes) {\n return \"\\\"\".concat(url.replace(/\"/g, '\\\\\"').replace(/\\n/g, \"\\\\n\"), \"\\\"\");\n }\n return url;\n};"],"names":["scrollWidth","defineElement","property","createDecorators","WrappedMenuItem","wrapBrick","WrappedPopover","onVisibleChange","beforeVisibleChange","RenderMenuItemCom","props","item","isSubMenu","topData","React","SubMenuItemCom","_extends","isGroup","GroupMenuItemCom","SimpleMenuItemCom","index","hidden","showTooltip","selectedKey","className","key","title","text","active","includes","renderLinkCom","width","_NavMenu","handlePopupVisibleChange","event","_scrollWidth","paddingRight","window","innerWidth","document","body","clientWidth","style","detail","overflow","touchAction","_ref","_item$items","items","length","classnames","subprime","trigger","placement","distance","anchorDisplay","strategy","slot","renderSpanCom","map","innerItem","_ref2","_item$items2","childLayout","ThreeLevelMenuCom","SitMapMenCom","_ref3","_item$items3","ThreeLevelMenuPopoverContent","menuItem","_ref4","_item$items4","visible","setVisible","useState","onClick","e","stopPropagation","SiteMapItem","menuGroup","_dec","styleTexts","SiteMapStyleText","ItemTagStyleText","GroupItemStyleText","styleText","_dec2","attribute","_dec3","type","Boolean","_A","WeakMap","_B","NavMenu","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","writable","value","_initProto","_init_menu","_init_showTooltip","menu","_classPrivateFieldGet","v","_classPrivateFieldSet","render","NavMenuComponent","this","_menu$menuItems$lengt","_menu$menuItems2","history","getHistory","navMenuWrapperRef","useRef","location","setLocation","overflowIndex","setOverflowIndex","Number","MAX_SAFE_INTEGER","pathname","search","setSelectedKey","setSelected","_ref5","_asyncToGenerator","_menu$menuItems","selectedKeys","initMenuItemAndMatchCurrentPathKeys","menuItems","apply","useEffect","unListen","listen","current","resizeObserver","ResizeObserver","_navMenuWrapperRef$cu","getClientRects","childNodes","wrapperWidth","i","childWidth","height","childHeight","observe","disconnect","overflowMenu","useMemo","slice","ref","_items","isHidden","_class","c","_initClass","_applyDecs","initializeReactI18n","NS","locales","_LaunchpadButton","LaunchpadButton","LaunchpadButtonComponent","Launchpad","searchInputRef","handleClickSearchBox","useCallback","_searchInputRef$curre","focus","loading","q","setQ","menuGroups","favorites","loadingFavorites","recentVisits","pushRecentVisit","toggleStar","isStarred","useLaunchpadInfo","searching","handleSearch","target","clearSearch","classNames","LaunchpadsContext","Provider","SidebarMenuItem","Loading","WrappedIcon","lib","icon","placeholder","onChange","theme","empty","WrappedLink","url","href","name","group","MenuGroup","spinning","_EoLaunchpadButtonV","lockBodyScroll","unwrapProvider","EoLaunchpadButtonV2","disconnectedCallback","super","EoLaunchpadButtonV2Component","host","initialized","setInitialized","setActive","toggleLaunchpad","previous","hotkeys","filter","preventDefault","unbind","deferredLaunchpadInfo","schedulePrefetch","deferredFavorites","role","LaunchpadSvg","WrappedDropdownActions","onActionClick","data","actions","dropdownActive","setDropdownActive","filteredActions","checkIfByTransform","handleActionClick","action","MenuItemFolder","instanceId","MenuItem","concat","id","_data$menuIcon","menuIcon","pick","expanded","setExpanded","toggle","prefix","_LaunchpadConfig","_dec4","_C","_actionClickEvent","_onActionClick","LaunchpadConfig","get","_get_actionClickEvent2","set","_set_actionClickEvent2","_init_menuGroups","_init_actions","_init_actionClickEvent","emit","LaunchpadConfigComponent","_set_actionClickEvent","_get_actionClickEvent","o","_","has","_checkInRHS","_EasyopsNavbarAlerts","EasyopsNavbarAlerts","EasyopsNavbarAlertsComponent","storage","JsonStorage","localStorage","licenseDaysLeft","setLicenseDaysLeft","slowRender","setSlowRender","currentApp","useCurrentApp","licenseDismissedKey","authInfo","auth","getAuth","org","_authInfo$license","dismissExpireAt","validDaysLeft","license","isAdmin","getItem","moment","unix","handelRouteRender","renderTime","loadTime","loadInfoPage","getRuntime","getMiscSettings","isBuildPush","millisecondToSecond","suggestTime","suggestUrl","addEventListener","removeEventListener","handleLicenseAlertDismiss","setItem","Alert","link","label","undefined","closable","onClose","millisecond","Math","floor","_EoLaunchpadQuickAcce","EoLaunchpadQuickAccess","EoLaunchpadQuickAccessComponent","_EoSearchLaunchpad","EoSearchLaunchpad","EoSearchLaunchpadComponent","onFocus","onBlur","onMouseDown","___CSS_LOADER_EXPORT___","push","module","toString","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___","exports","options","String","__esModule","default","test","hash","needQuotes","replace"],"sourceRoot":""}
@@ -0,0 +1,2 @@
1
+ "use strict";(self.webpackChunk_next_bricks_nav=self.webpackChunk_next_bricks_nav||[]).push([[5381,6660],{4795:(e,r,t)=>{function n(e,r,t,n,u,a,i){try{var c=e[a](i),s=c.value}catch(e){return void t(e)}c.done?r(s):Promise.resolve(s).then(n,u)}function u(e){return function(){var r=this,t=arguments;return new Promise((function(u,a){var i=e.apply(r,t);function c(e){n(i,u,a,c,s,"next",e)}function s(e){n(i,u,a,c,s,"throw",e)}c(void 0)}))}}t.d(r,{Z:()=>u})},6660:(e,r,t)=>{t.r(r),t.d(r,{ReactUseBrick:()=>i,ReactUseMultipleBricks:()=>c,useCurrentApp:()=>f,useCurrentTheme:()=>d,useRecentApps:()=>v,useRouteRender:()=>_});var n=t(4795),u=t(8657),a=t(7217),i=function(e){var{useBrick:r,data:t}=e,[i,c]=(0,u.useState)(null),s=(0,u.useRef)(),[o,l]=(0,u.useState)(),d=(0,u.useRef)(0),v=(0,u.useMemo)((()=>{var e;return null===(e=a.__secret_internals.getRenderId)||void 0===e?void 0:e.call(a.__secret_internals)}),[]);(0,u.useEffect)((()=>{var e=!1;function u(){return u=(0,n.Z)((function*(){try{var n=yield a.__secret_internals.renderUseBrick(r,t);if(e)return;c(n),l(++d.current)}catch(e){(function(e){var r,t=null===(r=a.__secret_internals.getRenderId)||void 0===r?void 0:r.call(a.__secret_internals);return!e||!t||e===t})(v)&&(console.error("Render useBrick failed:",r,"with data:",t),(0,a.handleHttpError)(e))}})),u.apply(this,arguments)}return function(){u.apply(this,arguments)}(),()=>{e=!0}}),[t,r,v]);var f=(0,u.useCallback)((e=>{e?s.current=a.__secret_internals.mountUseBrick(i,e):(a.__secret_internals.unmountUseBrick(i,s.current),s.current=void 0)}),[i]);if(!i)return null;var{tagName:_}=i;if(null===_)return null;var p=_;return u.createElement(p,{key:o,ref:f})},c=function(e){var{useBrick:r,data:t}=e;return Array.isArray(r)?u.createElement(u.Fragment,null,r.map(((e,r)=>u.createElement(i,{key:r,useBrick:e,data:t})))):u.createElement(i,{useBrick:r,data:t})},s=(0,a.getV2RuntimeFromDll)();if(s){var{SingleBrickAsComponentFactory:o,BrickAsComponentFactory:l}=s;o&&l&&(i=o(u),c=l(u))}function d(){var[e,r]=(0,u.useState)(a.getCurrentTheme);return(0,u.useEffect)((()=>{var e=e=>{r(e.detail)};return window.addEventListener("theme.change",e),()=>{window.removeEventListener("theme.change",e)}}),[]),e}function v(){var[e,r]=u.useState((()=>(0,a.getRuntime)().getRecentApps()));return u.useEffect((()=>{var e=e=>{r(e.detail)};return window.addEventListener("app.change",e),()=>window.removeEventListener("app.change",e)}),[]),e}function f(){return v().currentApp}function _(){var[e,r]=u.useState(null);return u.useEffect((()=>{var e=e=>{r(e.detail)};return window.addEventListener("route.render",e),()=>window.removeEventListener("route.render",e)}),[]),e}}}]);
2
+ //# sourceMappingURL=5381.0a41a7b8.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/5381.0a41a7b8.js","mappings":"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","sources":["webpack:///../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/ReactUseBrick.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useCurrentTheme.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useRecentApps.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useCurrentApp.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useRouteRender.js"],"sourcesContent":["function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\nexport default function _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n _next(undefined);\n });\n };\n}","import _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { __secret_internals, handleHttpError, getV2RuntimeFromDll } from \"@next-core/runtime\";\n// Note: always synchronize code in LegacyUseBrick:\n// `bricks/v2-adapter/src/data-providers/legacy-brick-kit/getLegacyUseBrick.ts`\nvar ReactUseBrick = function ReactUseBrick(_ref) {\n var {\n useBrick,\n data\n } = _ref;\n var [renderResult, setRenderResult] = useState(null);\n var mountResult = useRef();\n var [renderKey, setRenderKey] = useState();\n var IdCounterRef = useRef(0);\n var initialRenderId = useMemo(() => {\n var _secret_internals$ge;\n return (_secret_internals$ge = __secret_internals.getRenderId) === null || _secret_internals$ge === void 0 ? void 0 : _secret_internals$ge.call(__secret_internals);\n }, []);\n useEffect(() => {\n var ignore = false;\n function init() {\n return _init.apply(this, arguments);\n }\n function _init() {\n _init = _asyncToGenerator(function* () {\n try {\n var newRender = yield __secret_internals.renderUseBrick(useBrick, data);\n if (ignore) {\n return;\n }\n setRenderResult(newRender);\n setRenderKey(getUniqueId(IdCounterRef));\n } catch (error) {\n if (isTheSameRender(initialRenderId)) {\n // eslint-disable-next-line no-console\n console.error(\"Render useBrick failed:\", useBrick, \"with data:\", data);\n handleHttpError(error);\n }\n }\n });\n return _init.apply(this, arguments);\n }\n init();\n return () => {\n ignore = true;\n };\n }, [data, useBrick, initialRenderId]);\n var refCallback = useCallback(element => {\n if (element) {\n mountResult.current = __secret_internals.mountUseBrick(\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n renderResult, element);\n } else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n __secret_internals.unmountUseBrick(renderResult, mountResult.current);\n mountResult.current = undefined;\n }\n }, [renderResult]);\n if (!renderResult) {\n // Fallback when loading/\n return null;\n // return <span>🌀 Loading...</span>;\n }\n\n var {\n tagName\n } = renderResult;\n if (tagName === null) {\n return null;\n }\n var WebComponent = tagName;\n return /*#__PURE__*/React.createElement(WebComponent, {\n key: renderKey,\n ref: refCallback\n });\n};\nfunction getUniqueId(ref) {\n return ++ref.current;\n}\nfunction isTheSameRender(initialRenderId) {\n var _secret_internals$ge2;\n var newRenderId = (_secret_internals$ge2 = __secret_internals.getRenderId) === null || _secret_internals$ge2 === void 0 ? void 0 : _secret_internals$ge2.call(__secret_internals);\n return !initialRenderId || !newRenderId || initialRenderId === newRenderId;\n}\nvar ReactUseMultipleBricks = function ReactUseMultipleBricks(_ref2) {\n var {\n useBrick,\n data\n } = _ref2;\n if (Array.isArray(useBrick)) {\n return /*#__PURE__*/React.createElement(React.Fragment, null, useBrick.map((item, index) => /*#__PURE__*/React.createElement(ReactUseBrick, {\n key: index,\n useBrick: item,\n data: data\n })));\n }\n return /*#__PURE__*/React.createElement(ReactUseBrick, {\n useBrick: useBrick,\n data: data\n });\n};\n\n// Make v3 bricks compatible with Brick Next v2.\n// istanbul ignore next\nvar v2Kit = getV2RuntimeFromDll();\n// istanbul ignore next\nif (v2Kit) {\n var {\n SingleBrickAsComponentFactory,\n BrickAsComponentFactory\n } = v2Kit;\n if (SingleBrickAsComponentFactory && BrickAsComponentFactory) {\n ReactUseBrick = SingleBrickAsComponentFactory(React);\n ReactUseMultipleBricks = BrickAsComponentFactory(React);\n }\n}\nexport { ReactUseBrick, ReactUseMultipleBricks };\n//# sourceMappingURL=ReactUseBrick.js.map","import { useEffect, useState } from \"react\";\nimport { getCurrentTheme } from \"@next-core/runtime\";\nexport function useCurrentTheme() {\n var [currentTheme, setCurrentTheme] = useState(getCurrentTheme);\n useEffect(() => {\n var listenToThemeChange = event => {\n setCurrentTheme(event.detail);\n };\n window.addEventListener(\"theme.change\", listenToThemeChange);\n return () => {\n window.removeEventListener(\"theme.change\", listenToThemeChange);\n };\n }, []);\n return currentTheme;\n}\n//# sourceMappingURL=useCurrentTheme.js.map","import React from \"react\";\nimport { getRuntime } from \"@next-core/runtime\";\nexport function useRecentApps() {\n var [recentApps, setRecentApps] = React.useState(() => getRuntime().getRecentApps());\n React.useEffect(() => {\n var listener = event => {\n setRecentApps(event.detail);\n };\n window.addEventListener(\"app.change\", listener);\n return () => window.removeEventListener(\"app.change\", listener);\n }, []);\n return recentApps;\n}\n//# sourceMappingURL=useRecentApps.js.map","import { useRecentApps } from \"./useRecentApps.js\";\n\n/**\n * 获取当前所在微应用信息的 React hooks。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const app = useCurrentApp();\n * return <div>{app.id}</div>;\n * }\n * ```\n *\n * @returns 当前所在微应用的信息。\n */\nexport function useCurrentApp() {\n return useRecentApps().currentApp;\n}\n//# sourceMappingURL=useCurrentApp.js.map","import React from \"react\";\nexport function useRouteRender() {\n var [routeRender, setRouteRender] = React.useState(null);\n React.useEffect(() => {\n var listener = event => {\n setRouteRender(event.detail);\n };\n window.addEventListener(\"route.render\", listener);\n return () => window.removeEventListener(\"route.render\", listener);\n }, []);\n return routeRender;\n}\n//# sourceMappingURL=useRouteRender.js.map"],"names":["asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","_asyncToGenerator","fn","self","this","args","arguments","apply","err","undefined","ReactUseBrick","_ref","useBrick","data","renderResult","setRenderResult","useState","mountResult","useRef","renderKey","setRenderKey","IdCounterRef","initialRenderId","useMemo","_secret_internals$ge","__secret_internals","getRenderId","call","useEffect","ignore","_init","newRender","renderUseBrick","current","_secret_internals$ge2","newRenderId","isTheSameRender","console","handleHttpError","init","refCallback","useCallback","element","mountUseBrick","unmountUseBrick","tagName","WebComponent","ref","ReactUseMultipleBricks","_ref2","Array","isArray","map","item","index","v2Kit","getV2RuntimeFromDll","SingleBrickAsComponentFactory","BrickAsComponentFactory","useCurrentTheme","currentTheme","setCurrentTheme","getCurrentTheme","listenToThemeChange","event","detail","window","addEventListener","removeEventListener","useRecentApps","recentApps","setRecentApps","getRuntime","getRecentApps","listener","useCurrentApp","currentApp","useRouteRender","routeRender","setRouteRender"],"sourceRoot":""}