@next-bricks/presentational 1.21.9 → 1.21.11

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 (107) hide show
  1. package/dist/bricks.json +1 -1
  2. package/dist/chunks/1614.5ce43617.js +2 -0
  3. package/dist/chunks/1614.5ce43617.js.map +1 -0
  4. package/dist/chunks/{1889.4559a6f7.js → 1889.01e1c38a.js} +2 -2
  5. package/dist/chunks/{1889.4559a6f7.js.map → 1889.01e1c38a.js.map} +1 -1
  6. package/dist/chunks/3171.7708784b.js +2 -0
  7. package/dist/chunks/3171.7708784b.js.map +1 -0
  8. package/dist/chunks/5399.2ab60504.js +2 -0
  9. package/dist/chunks/5399.2ab60504.js.map +1 -0
  10. package/dist/chunks/5552.f77213dd.js +2 -0
  11. package/dist/chunks/5552.f77213dd.js.map +1 -0
  12. package/dist/chunks/7116.05a51bac.js +2 -0
  13. package/dist/chunks/7116.05a51bac.js.map +1 -0
  14. package/dist/chunks/7455.0f5298ce.js +3 -0
  15. package/dist/chunks/7455.0f5298ce.js.LICENSE.txt +11 -0
  16. package/dist/chunks/7455.0f5298ce.js.map +1 -0
  17. package/dist/chunks/948.b8effe9f.js +3 -0
  18. package/dist/chunks/948.b8effe9f.js.map +1 -0
  19. package/dist/chunks/code-wrapper.40655769.js.map +1 -1
  20. package/dist/chunks/{eo-card-item.fbff6f7e.js → eo-card-item.f56c41e5.js} +3 -3
  21. package/dist/chunks/eo-card-item.f56c41e5.js.map +1 -0
  22. package/dist/chunks/eo-carousel-text.d8e8c2c9.js.map +1 -1
  23. package/dist/chunks/{eo-code-block.7efe5647.js → eo-code-block.a7162247.js} +2 -2
  24. package/dist/chunks/eo-code-block.a7162247.js.map +1 -0
  25. package/dist/chunks/eo-code-display.ffd79558.js.map +1 -1
  26. package/dist/chunks/eo-current-time.7cbef918.js.map +1 -1
  27. package/dist/chunks/{eo-descriptions.b8320ca9.js → eo-descriptions.1ab98c43.js} +3 -3
  28. package/dist/chunks/{eo-descriptions.b8320ca9.js.map → eo-descriptions.1ab98c43.js.map} +1 -1
  29. package/dist/chunks/eo-humanize-time.2397ce6e.js.map +1 -1
  30. package/dist/chunks/{eo-info-card-item.0d15cb28.js → eo-info-card-item.e6403b4d.js} +3 -3
  31. package/dist/chunks/eo-info-card-item.e6403b4d.js.map +1 -0
  32. package/dist/chunks/{eo-loading-step.834e0aa3.js → eo-loading-step.259d7985.js} +3 -3
  33. package/dist/chunks/{eo-loading-step.834e0aa3.js.map → eo-loading-step.259d7985.js.map} +1 -1
  34. package/dist/chunks/eo-pagination.16fd816a.js.map +1 -1
  35. package/dist/chunks/eo-statistics-card.410b5416.js.map +1 -1
  36. package/dist/chunks/{main.7a4b0b01.js → main.519bfa38.js} +2 -2
  37. package/dist/chunks/main.519bfa38.js.map +1 -0
  38. package/dist/examples.json +13 -13
  39. package/dist/{index.db5144bf.js → index.71ea98e1.js} +2 -2
  40. package/dist/index.71ea98e1.js.map +1 -0
  41. package/dist/manifest.json +49 -39
  42. package/dist/types.json +2 -2
  43. package/dist-types/card-item/index.d.ts +8 -4
  44. package/dist-types/carousel-text/index.d.ts +1 -1
  45. package/dist-types/code-block/index.d.ts +12 -3
  46. package/dist-types/code-display/index.d.ts +0 -1
  47. package/dist-types/code-wrapper/index.d.ts +7 -2
  48. package/dist-types/current-time/index.d.ts +1 -1
  49. package/dist-types/descriptions/index.d.ts +4 -3
  50. package/dist-types/humanize-time/index.d.ts +8 -8
  51. package/dist-types/info-card-item/index.d.ts +10 -9
  52. package/dist-types/loading-step/index.d.ts +8 -8
  53. package/dist-types/pagination/index.d.ts +7 -0
  54. package/dist-types/statistics-card/index.d.ts +2 -2
  55. package/docs/eo-alert.md +65 -1
  56. package/docs/eo-alert.react.md +127 -0
  57. package/docs/eo-card-item.md +179 -210
  58. package/docs/eo-card-item.react.md +578 -0
  59. package/docs/eo-carousel-text.md +49 -2
  60. package/docs/eo-carousel-text.react.md +62 -0
  61. package/docs/eo-code-block.md +135 -4
  62. package/docs/eo-code-block.react.md +146 -0
  63. package/docs/eo-code-display.md +97 -1
  64. package/docs/eo-code-display.react.md +116 -0
  65. package/docs/eo-code-wrapper.md +108 -0
  66. package/docs/eo-code-wrapper.react.md +100 -0
  67. package/docs/eo-current-time.md +40 -1
  68. package/docs/eo-current-time.react.md +53 -0
  69. package/docs/eo-descriptions.md +74 -4
  70. package/docs/eo-descriptions.react.md +329 -0
  71. package/docs/eo-divider.md +105 -17
  72. package/docs/eo-divider.react.md +129 -0
  73. package/docs/eo-humanize-time.md +89 -42
  74. package/docs/eo-humanize-time.react.md +109 -0
  75. package/docs/eo-info-card-item.md +129 -183
  76. package/docs/eo-info-card-item.react.md +188 -0
  77. package/docs/eo-loading-step.md +96 -1
  78. package/docs/eo-loading-step.react.md +102 -0
  79. package/docs/eo-pagination.md +74 -1
  80. package/docs/eo-pagination.react.md +93 -0
  81. package/docs/eo-statistics-card.md +175 -456
  82. package/docs/eo-statistics-card.react.md +376 -0
  83. package/package.json +2 -2
  84. package/dist/chunks/3171.3bb3ff80.js +0 -2
  85. package/dist/chunks/3171.3bb3ff80.js.map +0 -1
  86. package/dist/chunks/4837.3ae6253e.js +0 -2
  87. package/dist/chunks/4837.3ae6253e.js.map +0 -1
  88. package/dist/chunks/5045.b0f85f6b.js +0 -2
  89. package/dist/chunks/5045.b0f85f6b.js.map +0 -1
  90. package/dist/chunks/5399.23640b2d.js +0 -2
  91. package/dist/chunks/5399.23640b2d.js.map +0 -1
  92. package/dist/chunks/5552.5d29c532.js +0 -2
  93. package/dist/chunks/5552.5d29c532.js.map +0 -1
  94. package/dist/chunks/7218.4acefe69.js +0 -2
  95. package/dist/chunks/7218.4acefe69.js.map +0 -1
  96. package/dist/chunks/948.817a1ef0.js +0 -3
  97. package/dist/chunks/948.817a1ef0.js.map +0 -1
  98. package/dist/chunks/eo-card-item.fbff6f7e.js.map +0 -1
  99. package/dist/chunks/eo-code-block.7efe5647.js.map +0 -1
  100. package/dist/chunks/eo-info-card-item.0d15cb28.js.map +0 -1
  101. package/dist/chunks/main.7a4b0b01.js.map +0 -1
  102. package/dist/index.db5144bf.js.map +0 -1
  103. /package/dist/chunks/{948.817a1ef0.js.LICENSE.txt → 948.b8effe9f.js.LICENSE.txt} +0 -0
  104. /package/dist/chunks/{eo-card-item.fbff6f7e.js.LICENSE.txt → eo-card-item.f56c41e5.js.LICENSE.txt} +0 -0
  105. /package/dist/chunks/{eo-descriptions.b8320ca9.js.LICENSE.txt → eo-descriptions.1ab98c43.js.LICENSE.txt} +0 -0
  106. /package/dist/chunks/{eo-info-card-item.0d15cb28.js.LICENSE.txt → eo-info-card-item.e6403b4d.js.LICENSE.txt} +0 -0
  107. /package/dist/chunks/{eo-loading-step.834e0aa3.js.LICENSE.txt → eo-loading-step.259d7985.js.LICENSE.txt} +0 -0
package/dist/bricks.json CHANGED
@@ -92,5 +92,5 @@
92
92
  "basic.copy-to-clipboard"
93
93
  ]
94
94
  },
95
- "filePath": "bricks/presentational/dist/index.db5144bf.js"
95
+ "filePath": "bricks/presentational/dist/index.71ea98e1.js"
96
96
  }
@@ -0,0 +1,2 @@
1
+ "use strict";(globalThis.webpackChunk_next_bricks_presentational=globalThis.webpackChunk_next_bricks_presentational||[]).push([[1614],{16376:(e,t,r)=>{r.r(t),r.d(t,{ReactUseBrick:()=>c,ReactUseMultipleBricks:()=>a,asyncWrapBrick:()=>w,useAuth:()=>O,useCheckPermissions:()=>P,useControlledState:()=>F,useCurrentApp:()=>d,useCurrentTheme:()=>i,useFeatureFlags:()=>L,useHistory:()=>A,useLazyWrapBrick:()=>E,useLocation:()=>j,useMessage:()=>N,useNavConfig:()=>k,useParams:()=>B,usePathParams:()=>_,useProvider:()=>h,useRecentApps:()=>l,useRouteRender:()=>f,useSearchParams:()=>R,useSystemInfo:()=>M});var n=r(18769),s=r(36305);let u=function(e){let{useBrick:t,data:r,errorBoundary:u,refCallback:c,ignoredCallback:a}=e;const[o,i]=(0,n.useState)(null),l=(0,n.useRef)(),[d,f]=(0,n.useState)(),g=(0,n.useRef)(0),m=(0,n.useMemo)((()=>{var e;return null===(e=s.__secret_internals.getRenderId)||void 0===e?void 0:e.call(s.__secret_internals)}),[]);(0,n.useEffect)((()=>{let e=!1;return async function(){try{const n=await s.__secret_internals.renderUseBrick(t,r,u);if(e)return;i(n),f(++g.current)}catch(n){!e&&function(e){var t;const r=null===(t=s.__secret_internals.getRenderId)||void 0===t?void 0:t.call(s.__secret_internals);return!e||!r||e===r}(m)&&(console.error("Render useBrick failed:",t,"with data:",r),(0,s.handleHttpError)(n))}}(),()=>{e=!0}}),[r,t,m,u]);const y=(0,n.useCallback)((e=>{e?l.current=s.__secret_internals.mountUseBrick(o,e):(s.__secret_internals.unmountUseBrick(o,l.current),l.current=void 0),null==c||c(e)}),[c,o]);if(!o)return null;const{tagName:p}=o;if(null===p)return null==a||a(),null;const h=p;return n.createElement(h,{key:d,ref:y})},c=function(e){let{useBrick:t,data:r,errorBoundary:s,refCallback:c,ignoredCallback:a}=e;if("function"==typeof t){const e=t;return n.createElement(n.Fragment,null,e(r))}return n.createElement(u,{useBrick:t,data:r,errorBoundary:s,refCallback:c,ignoredCallback:a})},a=function(e){let{useBrick:t,data:r,errorBoundary:s}=e;return"function"==typeof t?n.createElement(n.Fragment,null,t(r)):Array.isArray(t)?n.createElement(n.Fragment,null,t.map(((e,t)=>n.createElement(c,{key:t,useBrick:e,data:r,errorBoundary:s})))):n.createElement(c,{useBrick:t,data:r,errorBoundary:s})};const o=(0,s.getV2RuntimeFromDll)();if(o){const{SingleBrickAsComponentFactory:e,BrickAsComponentFactory:t}=o;e&&t&&(c=e(n),a=t(n))}function i(){const[e,t]=(0,n.useState)(s.getCurrentTheme);return(0,n.useEffect)((()=>{const e=e=>{t(e.detail)};return window.addEventListener("theme.change",e),()=>{window.removeEventListener("theme.change",e)}}),[]),e}function l(){const[e,t]=n.useState((()=>(0,s.getRuntime)().getRecentApps()));return n.useEffect((()=>{const e=e=>{t(e.detail)};return window.addEventListener("app.change",e),()=>window.removeEventListener("app.change",e)}),[]),e}function d(){return l().currentApp}function f(){const[e,t]=n.useState(null);return n.useEffect((()=>{const e=e=>{t(e.detail)};return window.addEventListener("route.render",e),()=>window.removeEventListener("route.render",e)}),[]),e}const g={provider:"",customOptions:{onError:()=>{},transform:(e,t)=>t,data:void 0,loading:!1,suspense:!1,cache:!0},dependencies:void 0},m=Object.entries(g).reduce(((e,t)=>{let[r,n]=t;return"[object Object]"===Object.prototype.toString.call(n)?{...e,...n}:{...e,[r]:n}}),{});var y=r(20563);const p=new Map;function h(){const{provider:e,customOptions:t,dependencies:r,requestInit:u}=function(e,t,r){const s=(0,n.useMemo)((()=>"string"==typeof e?e:g.provider),[e,t]),u=(0,n.useMemo)((()=>{let r={};return(0,y.isObject)(e)?r=e:(0,y.isObject)(t)&&(r=t),{...m,...r}}),[e,t]),c=(0,n.useMemo)((()=>{const e=[...Object.keys(g),...Object.keys(g.customOptions)],{args:t=null,...r}=Object.keys(u).reduce(((t,r)=>(e.includes(r)||(t[r]=u[r]),t)),{});return{options:{...r},args:t}}),[u]),a=(0,n.useMemo)((()=>Array.isArray(t)?t:Array.isArray(r)?r:m.dependencies),[t,r]),o=u.loading||Array.isArray(a);return{provider:s,customOptions:(0,n.useMemo)((()=>({...Object.keys(g.customOptions).reduce(((e,t)=>(e[t]=u[t],e)),{}),loading:o})),[u]),requestInit:c,dependencies:a}}(...arguments),{onError:c,transform:a,suspense:o,cache:i,...l}=t,[d,f]=(0,n.useState)(l.loading),h=(0,n.useRef)("pending"),v=(0,n.useRef)(),w=(0,n.useRef)(!1),k=(0,n.useRef)(),E=(0,n.useRef)(),_=(0,n.useRef)(l.data),b=(0,n.useReducer)((()=>({})),[])[1],R=(0,n.useCallback)((async(e,t)=>{try{k.current=void 0,o||f(!0);const r=await async function(e,t,r){let n;const u=function(e){const t=e=>Object.keys(e).sort().map((t=>({[t]:e[t]})));for(var r=arguments.length,n=new Array(r>1?r-1:0),s=1;s<r;s++)n[s-1]=arguments[s];try{const r="object"!=typeof(u=n)||null===u||Array.isArray(u)?n.map((e=>function(e){return"string"==typeof e}(e)?e:t(e))):t(n);return JSON.stringify({provider:e,args:r})}catch(t){return JSON.stringify({provider:e,args:n})}var u}(e,...r);return!t&&p.has(u)&&p.delete(u),p.has(u)?n=p.get(u):(n=(0,s.fetchByProvider)(e,r,{cache:t?"default":"reload"}),t&&p.set(u,n)),n}(e,i,t);E.current=r,_.current=a(_.current,r)}catch(e){k.current=e,_.current=void 0}return o||f(!1),k.current&&c(k.current),_.current}),[e,t,r,u,o,a,l.data,c,i]),B=(0,n.useCallback)((async(t,r)=>{let n=e,s=[];return(0,y.isString)(t)&&(n=t),(0,y.isObject)(t)?s=t:(0,y.isObject)(r)&&(s=r),o?(async()=>(v.current=R(n,s).then((e=>(h.current="success",e)),(e=>(h.current="error",e.current=e,e))),b(),await v.current))():R(n,s)}),[R]),S=(0,n.useMemo)((()=>Object.defineProperties({query:B},{loading:{get:()=>d},data:{get:()=>_.current},error:{get:()=>k.current}})),[B]);if((0,n.useEffect)((()=>(w.current=!0,Array.isArray(r)&&e&&S.query(e,u.args),()=>w.current=!1)),r),o&&v.current)switch(h.current){case"pending":throw v.current;case"error":throw k.current}return Object.assign([S,E.current,d,k.current],{request:S,...S,response:E.current,data:_.current,loading:d,error:k.current})}var v=r(30981);async function w(e,t){return await s.__secret_internals.loadBricks([e]),(0,v.wrapBrick)(e,t)}function k(){const[e,t]=(0,n.useState)((()=>(0,s.getRuntime)().getNavConfig()));return(0,n.useEffect)((()=>{const e=e=>{t(e.detail)};return window.addEventListener("navConfig.change",e),()=>window.removeEventListener("navConfig.change",e)}),[]),e}function E(e,t){return(0,n.useMemo)((()=>null!=e?(0,n.lazy)((async()=>({default:await w(e,t)}))):null),[e,t])}function _(){const[e,t]=n.useState((()=>b()));return n.useEffect((()=>{const e=()=>{t(b())};return window.addEventListener("page.load",e),()=>window.removeEventListener("page.load",e)}),[]),e}function b(){try{var e,t;const r=s.__secret_internals.getLegalRuntimeValue();return null!==(e=null==r||null===(t=r.match)||void 0===t?void 0:t.params)&&void 0!==e?e:{}}catch(e){return{}}}function R(){const[e,t]=n.useState((()=>new URLSearchParams((0,s.getHistory)().location.search)));return n.useEffect((()=>(0,s.getHistory)().listen((e=>{t(new URLSearchParams(e.search))}))),[]),e}function B(){const[e,t]=n.useState((()=>S((0,s.getHistory)().location.search)));return n.useEffect((()=>(0,s.getHistory)().listen((e=>{t(S(e.search))}))),[]),e}function S(e){const t={};return new URLSearchParams(e).forEach(((e,r)=>{t[r]=e})),t}function A(){return(0,s.getHistory)()}var C=r(69113);function O(){return n.useMemo((()=>C.auth.getAuth()),[])}function j(){const[e,t]=n.useState((()=>(0,s.getHistory)().location));return n.useEffect((()=>(0,s.getHistory)().listen((e=>{t(e)}))),[]),e}function L(){return n.useMemo((()=>(0,s.getRuntime)().getFeatureFlags()),[])}function M(){return n.useMemo((()=>({...C.auth.getAuth(),...(0,s.getPageInfo)(),settings:{brand:(0,s.getRuntime)().getBrandSettings()}})),[])}function P(){for(var e=arguments.length,t=new Array(e),r=0;r<e;r++)t[r]=arguments[r];return n.useMemo((()=>C.checkPermissions.checkPermissions(...t)),[JSON.stringify(t)])}function F(e,t){let r=arguments.length>2&&void 0!==arguments[2]&&arguments[2];const[s,u]=n.useState(void 0!==e?e:t),c=void 0!==e;let a;return n.useEffect((()=>{c&&u(r?t=>(0,y.isEqual)(t,e)?t:e:e)}),[c,e,r]),a=c?r&&(0,y.isEqual)(s,e)?s:e:s,[a,u]}function N(){return n.useMemo((()=>({success:e=>{s.Notification.show({type:"success",message:e})},error:e=>{s.Notification.show({type:"error",message:e})},info:e=>{s.Notification.show({type:"info",message:e})},warn:e=>{s.Notification.show({type:"warn",message:e})}})),[])}}}]);
2
+ //# sourceMappingURL=1614.5ce43617.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/1614.5ce43617.js","mappings":"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","sources":["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","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useProvider/useProviderArgsDefaults.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useProvider/fetch.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useProvider/useProvider.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useProvider/useProviderArgs.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/asyncWrapBrick.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useNavConfig.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useLazyWrapBrick.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/usePathParams.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useSearchParams.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useParams.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useHistory.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useAuth.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useLocation.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useFeatureFlags.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useSystemInfo.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useCheckPermissions.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useControlledState.js","webpack:///../../node_modules/@next-core/react-runtime/dist/esm/useMessage.js"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useRef, useState } from \"react\";\nimport { __secret_internals, handleHttpError, getV2RuntimeFromDll } from \"@next-core/runtime\";\n\n/**\n * useBrick 的 render 函数类型。\n *\n * @example\n *\n * ```tsx\n * const columns = [\n * {\n * key: \"status\",\n * useBrick: (data) => <WrappedEoTag textContent={data.cellData} />\n * }\n * ];\n * ```\n */\n\n/**\n * 单个 useBrick 配置,支持配置对象或 render 函数。\n */\n\n/**\n * useBrick 配置,支持配置对象、配置对象数组或 render 函数。\n */\n\n// Note: always synchronize code in LegacyUseBrick:\n// `bricks/v2-adapter/src/data-providers/legacy-brick-kit/getLegacyUseBrick.ts`\nlet ReactUseBrickInternal = function ReactUseBrickInternal(_ref) {\n let {\n useBrick,\n data,\n errorBoundary,\n refCallback,\n ignoredCallback\n } = _ref;\n const [renderResult, setRenderResult] = useState(null);\n const mountResult = useRef();\n const [renderKey, setRenderKey] = useState();\n const IdCounterRef = useRef(0);\n const 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 let ignore = false;\n async function init() {\n try {\n const newRender = await __secret_internals.renderUseBrick(useBrick, data, errorBoundary);\n if (ignore) {\n return;\n }\n setRenderResult(newRender);\n setRenderKey(getUniqueId(IdCounterRef));\n } catch (error) {\n if (!ignore && 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 init();\n return () => {\n ignore = true;\n };\n }, [data, useBrick, initialRenderId, errorBoundary]);\n const _refCallback = useCallback(element => {\n if (element) {\n mountResult.current = __secret_internals.mountUseBrick(renderResult, element);\n } else {\n __secret_internals.unmountUseBrick(renderResult, mountResult.current);\n mountResult.current = undefined;\n }\n refCallback === null || refCallback === void 0 || refCallback(element);\n }, [refCallback, renderResult]);\n if (!renderResult) {\n // Fallback when loading/\n return null;\n // return <span>🌀 Loading...</span>;\n }\n const {\n tagName\n } = renderResult;\n if (tagName === null) {\n ignoredCallback === null || ignoredCallback === void 0 || ignoredCallback();\n return null;\n }\n const WebComponent = tagName;\n return /*#__PURE__*/React.createElement(WebComponent, {\n key: renderKey,\n ref: _refCallback\n });\n};\nlet ReactUseBrick = function ReactUseBrick(_ref2) {\n let {\n useBrick,\n data,\n errorBoundary,\n refCallback,\n ignoredCallback\n } = _ref2;\n // 如果 useBrick 是 render 函数,直接调用返回\n if (typeof useBrick === \"function\") {\n const renderFn = useBrick;\n return /*#__PURE__*/React.createElement(React.Fragment, null, renderFn(data));\n }\n\n // 否则使用原有的配置对象渲染逻辑\n return /*#__PURE__*/React.createElement(ReactUseBrickInternal, {\n useBrick: useBrick,\n data: data,\n errorBoundary: errorBoundary,\n refCallback: refCallback,\n ignoredCallback: ignoredCallback\n });\n};\nfunction getUniqueId(ref) {\n return ++ref.current;\n}\nfunction isTheSameRender(initialRenderId) {\n var _secret_internals$ge2;\n const 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}\nlet ReactUseMultipleBricks = function ReactUseMultipleBricks(_ref3) {\n let {\n useBrick,\n data,\n errorBoundary\n } = _ref3;\n // 如果 useBrick 是 render 函数,直接调用返回\n if (typeof useBrick === \"function\") {\n return /*#__PURE__*/React.createElement(React.Fragment, null, useBrick(data));\n }\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 errorBoundary: errorBoundary\n })));\n }\n return /*#__PURE__*/React.createElement(ReactUseBrick, {\n useBrick: useBrick,\n data: data,\n errorBoundary: errorBoundary\n });\n};\n\n// Make v3 bricks compatible with Brick Next v2.\n// istanbul ignore next\nconst v2Kit = getV2RuntimeFromDll();\n// istanbul ignore next\nif (v2Kit) {\n const {\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 const [currentTheme, setCurrentTheme] = useState(getCurrentTheme);\n useEffect(() => {\n const 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 const [recentApps, setRecentApps] = React.useState(() => getRuntime().getRecentApps());\n React.useEffect(() => {\n const 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 const [routeRender, setRouteRender] = React.useState(null);\n React.useEffect(() => {\n const 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","export const useProviderArgsDefaults = {\n provider: \"\",\n customOptions: {\n onError: () => {\n /* Do nothing.. */\n },\n transform: (oldData, newData) => newData,\n data: undefined,\n loading: false,\n suspense: false,\n cache: true\n },\n dependencies: undefined\n};\nexport default Object.entries(useProviderArgsDefaults).reduce((acc, _ref) => {\n let [key, value] = _ref;\n if (Object.prototype.toString.call(value) === \"[object Object]\") return {\n ...acc,\n ...value\n };\n return {\n ...acc,\n [key]: value\n };\n}, {});\n//# sourceMappingURL=useProviderArgsDefaults.js.map","import { fetchByProvider } from \"@next-core/runtime\";\nconst cacheMap = new Map();\nfunction isObj(v) {\n return typeof v === \"object\" && v !== null && !Array.isArray(v);\n}\nfunction isString(v) {\n return typeof v === \"string\";\n}\nfunction buildSortedCacheKey(provider) {\n const sortObj = obj => Object.keys(obj).sort().map(k => ({\n [k]: obj[k]\n }));\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n try {\n const sortedArgs = isObj(args) ? sortObj(args) : args.map(arg => isString(arg) ? arg : sortObj(arg));\n return JSON.stringify({\n provider,\n args: sortedArgs\n });\n } catch (e) {\n return JSON.stringify({\n provider,\n args\n });\n }\n}\nexport default async function fetch(provider, cache, args) {\n let promise;\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n const cacheKey = buildSortedCacheKey(provider, ...args);\n !cache && cacheMap.has(cacheKey) && cacheMap.delete(cacheKey);\n if (cacheMap.has(cacheKey)) {\n promise = cacheMap.get(cacheKey);\n } else {\n promise = (() => {\n return fetchByProvider(provider, args, {\n cache: cache ? \"default\" : \"reload\"\n });\n })();\n cache && cacheMap.set(cacheKey, promise);\n }\n return promise;\n}\n//# sourceMappingURL=fetch.js.map","import { useCallback, useEffect, useMemo, useReducer, useRef, useState } from \"react\";\nimport useProviderArgs from \"./useProviderArgs.js\";\nimport { isObject, isString } from \"lodash\";\nimport fetch from \"./fetch.js\";\nexport function useProvider() {\n const {\n provider,\n customOptions,\n dependencies,\n requestInit\n } = useProviderArgs(...arguments);\n const {\n onError,\n transform,\n suspense,\n cache,\n ...defaults\n } = customOptions;\n const [loading, setLoading] = useState(defaults.loading);\n const suspenseStatus = useRef(\"pending\");\n const suspender = useRef();\n const mounted = useRef(false);\n const error = useRef();\n const response = useRef();\n const data = useRef(defaults.data);\n const forceUpdate = useReducer(() => ({}), [])[1];\n const doFetch = useCallback(async (provider, providerArgs) => {\n try {\n error.current = undefined;\n if (!suspense) setLoading(true);\n const newRes = await fetch(provider, cache, providerArgs);\n response.current = newRes;\n data.current = transform(data.current, newRes);\n } catch (e) {\n error.current = e;\n data.current = undefined;\n }\n if (!suspense) setLoading(false);\n if (error.current) onError(error.current);\n return data.current;\n }, [provider, customOptions, dependencies, requestInit, suspense, transform, defaults.data, onError, cache]);\n const makeFetch = useCallback(async (providerOrBody, args) => {\n let providerStr = provider;\n let providerArgs = [];\n if (isString(providerOrBody)) {\n providerStr = providerOrBody;\n }\n if (isObject(providerOrBody)) {\n providerArgs = providerOrBody;\n } else if (isObject(args)) {\n providerArgs = args;\n }\n if (suspense) {\n return (async () => {\n suspender.current = doFetch(providerStr, providerArgs).then(newData => {\n suspenseStatus.current = \"success\";\n return newData;\n }, error => {\n /* istanbul ignore next */\n suspenseStatus.current = \"error\";\n error.current = error;\n return error;\n });\n forceUpdate();\n return await suspender.current;\n })();\n }\n return doFetch(providerStr, providerArgs);\n }, [doFetch]);\n const request = useMemo(() => Object.defineProperties({\n query: makeFetch\n }, {\n loading: {\n get() {\n return loading;\n }\n },\n data: {\n get() {\n return data.current;\n }\n },\n error: {\n get() {\n return error.current;\n }\n }\n }), [makeFetch]);\n\n // onMount/onUpdate\n useEffect(() => {\n mounted.current = true;\n if (Array.isArray(dependencies) && provider) {\n request.query(provider, requestInit.args);\n }\n return () => mounted.current = false;\n }, dependencies);\n if (suspense && suspender.current) {\n switch (suspenseStatus.current) {\n case \"pending\":\n throw suspender.current;\n /* istanbul ignore next */\n case \"error\":\n throw error.current;\n }\n }\n return Object.assign([request, response.current, loading, error.current], {\n request,\n ...request,\n response: response.current,\n data: data.current,\n loading,\n error: error.current\n });\n}\n//# sourceMappingURL=useProvider.js.map","import { useMemo } from \"react\";\nimport defaults, { useProviderArgsDefaults } from \"./useProviderArgsDefaults.js\";\nimport { isObject } from \"lodash\";\nexport default function useProviderArgs(providerOrParamsOrGlobalOptions, globalOptionsOrDeps, deps) {\n const provider = useMemo(() => {\n if (typeof providerOrParamsOrGlobalOptions === \"string\") {\n return providerOrParamsOrGlobalOptions;\n }\n return useProviderArgsDefaults.provider;\n }, [providerOrParamsOrGlobalOptions, globalOptionsOrDeps]);\n const options = useMemo(() => {\n let localOptions = {};\n if (isObject(providerOrParamsOrGlobalOptions)) {\n localOptions = providerOrParamsOrGlobalOptions;\n } else if (isObject(globalOptionsOrDeps)) {\n localOptions = globalOptionsOrDeps;\n }\n return {\n ...defaults,\n ...localOptions\n };\n }, [providerOrParamsOrGlobalOptions, globalOptionsOrDeps]);\n const requestInit = useMemo(() => {\n const customOptionKeys = [...Object.keys(useProviderArgsDefaults), ...Object.keys(useProviderArgsDefaults.customOptions)];\n const {\n args = null,\n ...restOptions\n } = Object.keys(options).reduce((acc, key) => {\n if (!customOptionKeys.includes(key)) acc[key] = options[key];\n return acc;\n }, {});\n return {\n options: {\n ...restOptions\n },\n args\n };\n }, [options]);\n const dependencies = useMemo(() => {\n if (Array.isArray(globalOptionsOrDeps)) return globalOptionsOrDeps;\n if (Array.isArray(deps)) return deps;\n return defaults.dependencies;\n }, [globalOptionsOrDeps, deps]);\n const loading = options.loading || Array.isArray(dependencies);\n const customOptions = useMemo(() => {\n const customOptionKeys = Object.keys(useProviderArgsDefaults.customOptions);\n const customOptions = customOptionKeys.reduce((opts, key) => {\n opts[key] = options[key];\n return opts;\n }, {});\n return {\n ...customOptions,\n loading\n };\n }, [options]);\n return {\n provider,\n customOptions,\n requestInit,\n dependencies\n };\n}\n//# sourceMappingURL=useProviderArgs.js.map","import { __secret_internals } from \"@next-core/runtime\";\nimport { wrapBrick } from \"@next-core/react-element\";\n\n/**\n * 使用异步加载的方式包装一个构件,可用于按条件渲染的构件依赖。\n *\n * 例如提供复杂弹层内容的按钮构件,其内容需要使用到一些大型构件,那么这些依赖可以使用 asyncWrapBrick,\n * 这样只有在需要时才会加载这些依赖的构件。\n */\n\n/**\n * 使用异步加载的方式包装一个构件,可用于按条件渲染的构件依赖。\n *\n * 例如提供复杂弹层内容的按钮构件,其内容需要使用到一些大型构件,那么这些依赖可以使用 asyncWrapBrick,\n * 这样只有在需要时才会加载这些依赖的构件。\n */\n\nexport async function asyncWrapBrick(brickName, eventsMapping) {\n await __secret_internals.loadBricks([brickName]);\n return wrapBrick(brickName, eventsMapping);\n}\n//# sourceMappingURL=asyncWrapBrick.js.map","import { useEffect, useState } from \"react\";\nimport { getRuntime } from \"@next-core/runtime\";\nexport function useNavConfig() {\n const [navConfig, setNavConfig] = useState(() => getRuntime().getNavConfig());\n useEffect(() => {\n const listener = event => {\n setNavConfig(event.detail);\n };\n window.addEventListener(\"navConfig.change\", listener);\n return () => window.removeEventListener(\"navConfig.change\", listener);\n }, []);\n return navConfig;\n}\n//# sourceMappingURL=useNavConfig.js.map","import { lazy, useMemo } from \"react\";\nimport { asyncWrapBrick } from \"./asyncWrapBrick.js\";\n\n/**\n * 使用 `React.lazy` 包装一个异步加载的构件。\n *\n * ```jsx\n * const DepComponent = useLazyWrapBrick(\"async-dep\");\n * return (\n * <Suspense fallback=\"Loading...\">\n * <DepComponent {...props} />\n * </Suspense>\n * );\n * ```\n */\n\n/**\n * 使用 `React.lazy` 包装一个异步加载的构件。\n *\n * ```jsx\n * const DepComponent = useLazyWrapBrick(\"async-dep\");\n * return (\n * <Suspense fallback=\"Loading...\">\n * <DepComponent {...props} />\n * </Suspense>\n * );\n * ```\n */\n\n/**\n * 使用 `React.lazy` 包装一个异步加载的构件。\n *\n * ```jsx\n * const DepComponent = useLazyWrapBrick(\"async-dep\");\n * return (\n * <Suspense fallback=\"Loading...\">\n * <DepComponent {...props} />\n * </Suspense>\n * );\n * ```\n */\n\n/**\n * 使用 `React.lazy` 包装一个异步加载的构件。\n *\n * ```jsx\n * const DepComponent = useLazyWrapBrick(\"async-dep\");\n * return (\n * <Suspense fallback=\"Loading...\">\n * <DepComponent {...props} />\n * </Suspense>\n * );\n * ```\n */\n\nexport function useLazyWrapBrick(brickName, eventsMapping) {\n return useMemo(() => {\n if (brickName != null) {\n return /*#__PURE__*/lazy(async () => ({\n default: await asyncWrapBrick(brickName, eventsMapping)\n }));\n }\n return null;\n }, [brickName, eventsMapping]);\n}\n//# sourceMappingURL=useLazyWrapBrick.js.map","import React from \"react\";\nimport { __secret_internals } from \"@next-core/runtime\";\n\n/**\n * 获取当前路由路径参数的 React hooks。\n *\n * **注意**: 此 hook 依赖于运行时上下文中的路由匹配信息。\n * 如果在非路由上下文中使用,将返回空对象。\n *\n * 此 hook 监听 `page.load` 事件以确保在路由匹配完成后更新路径参数。\n * 直接监听 history 变化无法获取正确的参数,因为路由匹配是异步的。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const pathParams = usePathParams();\n * return <div>User ID: {pathParams.userId}</div>;\n * }\n * ```\n *\n * @returns 当前路由的路径参数对象。\n */\nexport function usePathParams() {\n const [pathParams, setPathParams] = React.useState(() => extractPathParams());\n React.useEffect(() => {\n const listener = () => {\n setPathParams(extractPathParams());\n };\n\n // 监听 page.load 事件,此时路由匹配已完成,match 信息已更新\n window.addEventListener(\"page.load\", listener);\n return () => window.removeEventListener(\"page.load\", listener);\n }, []);\n return pathParams;\n}\n\n/**\n * 从运行时上下文中提取路径参数。\n *\n * @internal\n */\nfunction extractPathParams() {\n try {\n var _runtimeValue$match$p, _runtimeValue$match;\n // 使用 __secret_internals 获取当前运行时值\n const runtimeValue = __secret_internals.getLegalRuntimeValue();\n return (_runtimeValue$match$p = runtimeValue === null || runtimeValue === void 0 || (_runtimeValue$match = runtimeValue.match) === null || _runtimeValue$match === void 0 ? void 0 : _runtimeValue$match.params) !== null && _runtimeValue$match$p !== void 0 ? _runtimeValue$match$p : {};\n } catch (_error) {\n // 如果运行时上下文不可用,返回空对象\n return {};\n }\n}\n//# sourceMappingURL=usePathParams.js.map","import React from \"react\";\nimport { getHistory } from \"@next-core/runtime\";\n\n/**\n * 获取当前 URL 查询参数的 React hooks。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const searchParams = useSearchParams();\n * return <div>Search query: {searchParams.get('q')}</div>;\n * }\n * ```\n *\n * @returns 当前 URL 的查询参数 URLSearchParams 对象。\n */\nexport function useSearchParams() {\n const [searchParams, setSearchParams] = React.useState(() => new URLSearchParams(getHistory().location.search));\n React.useEffect(() => {\n const unlisten = getHistory().listen(location => {\n setSearchParams(new URLSearchParams(location.search));\n });\n return unlisten;\n }, []);\n return searchParams;\n}\n//# sourceMappingURL=useSearchParams.js.map","import React from \"react\";\nimport { getHistory } from \"@next-core/runtime\";\n\n/**\n * 获取 URL query 参数的 React hooks,返回普通对象。\n *\n * 与 `useSearchParams` 不同,此 hook 返回一个普通的键值对象,\n * 而不是 URLSearchParams 实例,使用更方便。\n *\n * **注意**:\n * - 重复的参数只会保留最后一个值\n * - 所有值都是字符串类型\n * - 参数值会自动进行 URL 解码\n *\n * @example\n *\n * ```tsx\n * // URL: /page?id=123&name=test\n * function MyReactComponent() {\n * const params = useParams();\n * return <div>ID: {params.id}, Name: {params.name}</div>;\n * }\n * ```\n *\n * @returns URL query 参数对象。\n */\nexport function useParams() {\n const [params, setParams] = React.useState(() => extractParams(getHistory().location.search));\n React.useEffect(() => {\n const unlisten = getHistory().listen(location => {\n setParams(extractParams(location.search));\n });\n return unlisten;\n }, []);\n return params;\n}\n\n/**\n * 从 query string 中提取参数对象。\n *\n * @internal\n */\nfunction extractParams(search) {\n const params = {};\n const urlSearchParams = new URLSearchParams(search);\n urlSearchParams.forEach((value, key) => {\n params[key] = value;\n });\n return params;\n}\n//# sourceMappingURL=useParams.js.map","import { getHistory } from \"@next-core/runtime\";\n\n/**\n * 获取 history 对象的 React hooks。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const history = useHistory();\n * const handleClick = () => {\n * history.push('/new-page');\n * };\n * return <button onClick={handleClick}>Navigate</button>;\n * }\n * ```\n *\n * @returns history 对象,用于路由导航。\n */\nexport function useHistory() {\n return getHistory();\n}\n//# sourceMappingURL=useHistory.js.map","import React from \"react\";\nimport { auth } from \"@next-core/easyops-runtime\";\n/**\n * 获取用户认证信息的 React hooks。\n *\n * **注意**: 使用 useMemo 确保返回的认证信息对象引用稳定,\n * 避免不必要的组件重渲染。认证信息在会话期间保持不变。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const authInfo = useAuth();\n * return <div>Username: {authInfo.username}</div>;\n * }\n * ```\n *\n * @returns 当前用户的认证信息对象。\n */\nexport function useAuth() {\n return React.useMemo(() => auth.getAuth(), []);\n}\n//# sourceMappingURL=useAuth.js.map","import React from \"react\";\nimport { getHistory } from \"@next-core/runtime\";\n\n/**\n * 获取当前路由 location 对象的 React hooks。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const location = useLocation();\n * return <div>Current path: {location.pathname}</div>;\n * }\n * ```\n *\n * @returns 当前路由的 location 对象。\n */\nexport function useLocation() {\n const [location, setLocation] = React.useState(() => getHistory().location);\n React.useEffect(() => {\n const unlisten = getHistory().listen(newLocation => {\n setLocation(newLocation);\n });\n return unlisten;\n }, []);\n return location;\n}\n//# sourceMappingURL=useLocation.js.map","import React from \"react\";\nimport { getRuntime } from \"@next-core/runtime\";\n/**\n * 获取特性开关配置的 React hooks。\n *\n * 特性开关用于控制功能的启用或禁用,可以在全局设置或应用级别配置。\n * 使用 useMemo 确保返回的对象引用稳定,避免不必要的组件重渲染。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const flags = useFeatureFlags();\n *\n * if (flags[\"my-new-feature\"]) {\n * return <NewFeature />;\n * }\n *\n * return <OldFeature />;\n * }\n * ```\n *\n * @example\n *\n * ```tsx\n * // 检查特定功能是否启用\n * function FeatureToggle() {\n * const flags = useFeatureFlags();\n * const isEnabled = flags[\"experimental-mode\"] ?? false;\n *\n * return (\n * <div>\n * Experimental Mode: {isEnabled ? \"ON\" : \"OFF\"}\n * </div>\n * );\n * }\n * ```\n *\n * @returns 特性开关配置对象,键为特性名称,值为布尔值。\n */\nexport function useFeatureFlags() {\n return React.useMemo(() => getRuntime().getFeatureFlags(), []);\n}\n//# sourceMappingURL=useFeatureFlags.js.map","import React from \"react\";\nimport { getRuntime, getPageInfo } from \"@next-core/runtime\";\nimport { auth } from \"@next-core/easyops-runtime\";\n\n/**\n * 系统信息接口,包含认证信息、页面信息和品牌设置。\n */\n\n/**\n * 获取系统信息的 React hooks。\n *\n * 系统信息包括:\n * - 用户认证信息(username, userInstanceId, org 等)\n * - 页面信息(isInIframe, isInIframeOfNext 等)\n * - 品牌设置(base_title 等)\n *\n * **注意**: 使用 useMemo 确保返回的对象引用稳定,\n * 避免不必要的组件重渲染。系统信息在会话期间保持稳定。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const sys = useSystemInfo();\n *\n * return (\n * <div>\n * <p>User: {sys.username}</p>\n * <p>Org: {sys.org}</p>\n * <p>In iframe: {sys.isInIframe ? \"Yes\" : \"No\"}</p>\n * <p>Brand: {sys.settings.brand.base_title}</p>\n * </div>\n * );\n * }\n * ```\n *\n * @example\n *\n * ```tsx\n * // 检查是否在 iframe 中\n * function IframeDetector() {\n * const sys = useSystemInfo();\n *\n * if (sys.isInIframe) {\n * return <div>Running in iframe mode</div>;\n * }\n *\n * return <div>Running in standalone mode</div>;\n * }\n * ```\n *\n * @returns 系统信息对象。\n */\nexport function useSystemInfo() {\n return React.useMemo(() => {\n const authInfo = auth.getAuth();\n const pageInfo = getPageInfo();\n const brandSettings = getRuntime().getBrandSettings();\n return {\n ...authInfo,\n ...pageInfo,\n settings: {\n brand: brandSettings\n }\n };\n }, []);\n}\n//# sourceMappingURL=useSystemInfo.js.map","import React from \"react\";\nimport { checkPermissions } from \"@next-core/easyops-runtime\";\n\n/**\n * 检查用户权限的 React hooks。\n *\n * 此 hook 用于检查当前登录用户是否拥有指定的权限操作。\n * 权限必须在 storyboard 配置的 `permissionsPreCheck` 中预先声明,\n * 否则会返回 false 并在控制台输出错误。\n *\n * **工作原理:**\n * - 权限会在路由渲染时自动预检查(通过 `preCheckPermissions`)\n * - 此 hook 查询已缓存的权限结果(同步操作)\n * - 管理员用户始终返回 true\n * - 未登录用户始终返回 false\n *\n * **注意事项:**\n * 1. 权限必须在 `permissionsPreCheck` 中声明\n * 2. 所有传入的 actions 都必须有权限才返回 true\n * 3. 权限检查结果会被缓存,避免重复计算\n *\n * @param actions - 需要检查的权限操作列表\n * @returns 是否拥有所有指定的权限\n *\n * @example\n *\n * ```tsx\n * // 检查单个权限\n * function DeleteButton() {\n * const canDelete = useCheckPermissions(\"my-app:user.delete\");\n *\n * if (!canDelete) {\n * return null;\n * }\n *\n * return <button onClick={handleDelete}>Delete</button>;\n * }\n * ```\n *\n * @example\n *\n * ```tsx\n * // 检查多个权限(需要全部拥有)\n * function AdminPanel() {\n * const hasAccess = useCheckPermissions(\n * \"my-app:admin.read\",\n * \"my-app:admin.write\"\n * );\n *\n * if (!hasAccess) {\n * return <div>Access Denied</div>;\n * }\n *\n * return <div>Admin Panel Content</div>;\n * }\n * ```\n *\n * @example\n *\n * ```tsx\n * // 在 storyboard 中配置权限预检查\n * // routes.yaml\n * routes:\n * - path: /users\n * permissionsPreCheck:\n * - \"my-app:user.read\"\n * - \"my-app:user.delete\"\n * bricks:\n * - brick: \"my-brick\"\n * ```\n */\nexport function useCheckPermissions() {\n for (var _len = arguments.length, actions = new Array(_len), _key = 0; _key < _len; _key++) {\n actions[_key] = arguments[_key];\n }\n // 使用 useMemo 缓存权限检查结果\n // 因为权限在会话期间是稳定的,只依赖于 actions 列表\n return React.useMemo(() => checkPermissions.checkPermissions(...actions),\n // 序列化 actions 作为依赖,避免数组引用变化导致重新计算\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [JSON.stringify(actions)]);\n}\n//# sourceMappingURL=useCheckPermissions.js.map","import React from \"react\";\nimport { isEqual } from \"lodash\";\n\n/**\n * 受控/非受控混合模式的通用 Hook。\n *\n * 此 hook 允许组件既支持受控模式(由父组件通过 props 控制状态),\n * 也支持非受控模式(组件自己管理内部状态)。\n *\n * **工作原理:**\n * - 当 `propValue !== undefined` 时,组件处于**受控模式**,状态跟随 prop 更新\n * - 当 `propValue === undefined` 时,组件处于**非受控模式**,使用内部状态\n * - 支持深度比较选项,避免复杂对象引用变化导致的不必要更新\n *\n * **使用场景:**\n * 1. 表单组件需要支持受控和非受控两种模式\n * 2. 组件状态可能由父组件控制,也可能自己管理\n * 3. 复杂对象状态需要避免不必要的重新渲染\n *\n * @template T - 状态值的类型\n * @param propValue - 来自 props 的值(undefined 表示非受控模式)\n * @param defaultValue - 默认值(props 为 undefined 时使用)\n * @param deepCompare - 是否使用深度比较(用于复杂对象,默认 false)\n * @returns 返回 [当前值, 设置值的函数],类似 useState\n *\n * @example\n *\n * ```tsx\n * // 简单值(字符串、数字)\n * function MyComponent({ deployed }: { deployed?: string }) {\n * const [value, setValue] = useControlledState(deployed, 'host');\n *\n * return (\n * <select value={value} onChange={(e) => setValue(e.target.value)}>\n * <option value=\"host\">Host</option>\n * <option value=\"container\">Container</option>\n * </select>\n * );\n * }\n *\n * // 使用方式 1:受控模式\n * <MyComponent deployed=\"container\" />\n *\n * // 使用方式 2:非受控模式\n * <MyComponent />\n * ```\n *\n * @example\n *\n * ```tsx\n * // 复杂对象(启用深度比较)\n * interface Config {\n * host: string;\n * port: number;\n * }\n *\n * function ConfigEditor({ config }: { config?: Config }) {\n * const [value, setValue] = useControlledState<Config | null>(\n * config,\n * null,\n * true // 启用深度比较\n * );\n *\n * return <div>{JSON.stringify(value)}</div>;\n * }\n * ```\n *\n * @example\n *\n * ```tsx\n * // 与 onChange 回调结合\n * function Input({\n * value,\n * defaultValue = '',\n * onChange\n * }: {\n * value?: string;\n * defaultValue?: string;\n * onChange?: (val: string) => void;\n * }) {\n * const [internalValue, setInternalValue] = useControlledState(\n * value,\n * defaultValue\n * );\n *\n * const handleChange = (newValue: string) => {\n * setInternalValue(newValue);\n * onChange?.(newValue);\n * };\n *\n * return (\n * <input\n * value={internalValue}\n * onChange={(e) => handleChange(e.target.value)}\n * />\n * );\n * }\n * ```\n */\nexport function useControlledState(propValue, defaultValue) {\n let deepCompare = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;\n // 初始化内部状态\n // 如果 propValue 不是 undefined,使用 propValue;否则使用 defaultValue\n const [internalValue, setInternalValue] = React.useState(propValue !== undefined ? propValue : defaultValue);\n const isControlled = propValue !== undefined;\n\n // 在受控模式下同步 propValue 到 internalValue\n React.useEffect(() => {\n if (isControlled) {\n if (deepCompare) {\n // 深度比较模式:只有值真正变化时才更新\n setInternalValue(prev => isEqual(prev, propValue) ? prev : propValue);\n } else {\n // 浅比较模式:直接更新(React 会自动优化相同值)\n setInternalValue(propValue);\n }\n }\n // 注意:当 propValue 变为 undefined 时,不更新 internalValue\n // 这样可以保持最后一次的值,实现从受控切换到非受控的平滑过渡\n }, [isControlled, propValue, deepCompare]);\n\n // 计算最终返回的值\n let value;\n if (isControlled) {\n if (deepCompare) {\n // 深度比较模式:如果内容相同,返回 internalValue 保持引用稳定\n // 否则返回 propValue\n value = isEqual(internalValue, propValue) ? internalValue : propValue;\n } else {\n // 浅比较模式:直接返回 propValue,确保受控模式下值始终同步\n value = propValue;\n }\n } else {\n // 非受控模式:返回 internalValue\n value = internalValue;\n }\n return [value, setInternalValue];\n}\n//# sourceMappingURL=useControlledState.js.map","import React from \"react\";\nimport { Notification } from \"@next-core/runtime\";\n/**\n * 获取 message 对象的 React hooks,用于显示通知消息。\n *\n * **注意**: 使用 useMemo 确保返回的 message 对象引用稳定,\n * 避免不必要的组件重渲染。这在对象被用于依赖数组或传递给记忆化组件时尤为重要。\n *\n * @example\n *\n * ```tsx\n * function MyReactComponent() {\n * const message = useMessage();\n * const handleSuccess = () => {\n * message.success(\"操作成功!\");\n * };\n * const handleError = () => {\n * message.error(\"操作失败!\");\n * };\n * return (\n * <div>\n * <button onClick={handleSuccess}>成功</button>\n * <button onClick={handleError}>失败</button>\n * </div>\n * );\n * }\n * ```\n *\n * @returns message 对象,包含 success、error、info、warn 四个方法。\n */\nexport function useMessage() {\n return React.useMemo(() => ({\n success: message => {\n Notification.show({\n type: \"success\",\n message\n });\n },\n error: message => {\n Notification.show({\n type: \"error\",\n message\n });\n },\n info: message => {\n Notification.show({\n type: \"info\",\n message\n });\n },\n warn: message => {\n Notification.show({\n type: \"warn\",\n message\n });\n }\n }), []);\n}\n//# sourceMappingURL=useMessage.js.map"],"names":["ReactUseBrickInternal","_ref","useBrick","data","errorBoundary","refCallback","ignoredCallback","renderResult","setRenderResult","useState","mountResult","useRef","renderKey","setRenderKey","IdCounterRef","initialRenderId","useMemo","_secret_internals$ge","__secret_internals","getRenderId","call","useEffect","ignore","async","newRender","renderUseBrick","current","error","_secret_internals$ge2","newRenderId","isTheSameRender","console","handleHttpError","init","_refCallback","useCallback","element","mountUseBrick","unmountUseBrick","undefined","tagName","WebComponent","key","ref","ReactUseBrick","_ref2","renderFn","ReactUseMultipleBricks","_ref3","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","useProviderArgsDefaults","provider","customOptions","onError","transform","oldData","newData","loading","suspense","cache","dependencies","Object","entries","reduce","acc","value","prototype","toString","cacheMap","Map","useProvider","requestInit","providerOrParamsOrGlobalOptions","globalOptionsOrDeps","deps","options","localOptions","isObject","customOptionKeys","keys","args","restOptions","includes","opts","useProviderArgs","arguments","defaults","setLoading","suspenseStatus","suspender","mounted","response","forceUpdate","useReducer","doFetch","providerArgs","newRes","promise","cacheKey","sortObj","obj","sort","k","_len","length","_key","sortedArgs","v","arg","isString","JSON","stringify","e","buildSortedCacheKey","has","delete","get","fetchByProvider","set","fetch","makeFetch","providerOrBody","providerStr","then","request","defineProperties","query","assign","asyncWrapBrick","brickName","eventsMapping","loadBricks","wrapBrick","useNavConfig","navConfig","setNavConfig","getNavConfig","useLazyWrapBrick","lazy","default","usePathParams","pathParams","setPathParams","extractPathParams","_runtimeValue$match$p","_runtimeValue$match","runtimeValue","getLegalRuntimeValue","match","params","_error","useSearchParams","searchParams","setSearchParams","URLSearchParams","getHistory","location","search","listen","useParams","setParams","extractParams","forEach","useHistory","useAuth","auth","getAuth","useLocation","setLocation","newLocation","useFeatureFlags","getFeatureFlags","useSystemInfo","getPageInfo","settings","brand","getBrandSettings","useCheckPermissions","actions","checkPermissions","useControlledState","propValue","defaultValue","deepCompare","internalValue","setInternalValue","isControlled","prev","isEqual","useMessage","success","message","Notification","show","type","info","warn"],"sourceRoot":""}