@next-bricks/form-platform 0.6.1 → 0.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/dist/bricks.json +6 -6
  2. package/dist/chunks/1889.3b1a8139.js +2 -0
  3. package/dist/chunks/1889.3b1a8139.js.map +1 -0
  4. package/dist/chunks/3171.503ba1ad.js +2 -0
  5. package/dist/chunks/3171.503ba1ad.js.map +1 -0
  6. package/dist/chunks/5399.45552283.js +2 -0
  7. package/dist/chunks/5399.45552283.js.map +1 -0
  8. package/dist/chunks/5552.5e249d7f.js +2 -0
  9. package/dist/chunks/5552.5e249d7f.js.map +1 -0
  10. package/dist/chunks/6046.57f17e71.js +3 -0
  11. package/dist/chunks/{6046.d0b3cfb1.js.LICENSE.txt → 6046.57f17e71.js.LICENSE.txt} +2 -0
  12. package/dist/chunks/6046.57f17e71.js.map +1 -0
  13. package/dist/chunks/6376.5cbfdb2a.js +2 -0
  14. package/dist/chunks/6376.5cbfdb2a.js.map +1 -0
  15. package/dist/chunks/{6941.66e34b74.js → 6941.f45659ab.js} +2 -2
  16. package/dist/chunks/6941.f45659ab.js.map +1 -0
  17. package/dist/chunks/{7895.0c6c8882.js → 7895.b1a401b6.js} +3 -3
  18. package/dist/chunks/7895.b1a401b6.js.map +1 -0
  19. package/dist/chunks/948.be85ace4.js +3 -0
  20. package/dist/chunks/948.be85ace4.js.map +1 -0
  21. package/dist/chunks/eo-user-or-user-group-select.422d8070.js +3 -0
  22. package/dist/chunks/eo-user-or-user-group-select.422d8070.js.map +1 -0
  23. package/dist/chunks/main.13e3e06b.js +2 -0
  24. package/dist/chunks/main.13e3e06b.js.map +1 -0
  25. package/dist/examples.json +3 -3
  26. package/dist/index.fd32ac07.js +2 -0
  27. package/dist/index.fd32ac07.js.map +1 -0
  28. package/dist/manifest.json +111 -111
  29. package/dist-types/cmdb-instance-select/CmdbInstanceSelectInternal.d.ts +2 -2
  30. package/package.json +2 -2
  31. package/dist/chunks/1889.b59510a4.js +0 -2
  32. package/dist/chunks/1889.b59510a4.js.map +0 -1
  33. package/dist/chunks/3171.508feb36.js +0 -2
  34. package/dist/chunks/3171.508feb36.js.map +0 -1
  35. package/dist/chunks/4837.c71e7277.js +0 -2
  36. package/dist/chunks/4837.c71e7277.js.map +0 -1
  37. package/dist/chunks/5399.8264e057.js +0 -2
  38. package/dist/chunks/5399.8264e057.js.map +0 -1
  39. package/dist/chunks/5552.5757fe37.js +0 -2
  40. package/dist/chunks/5552.5757fe37.js.map +0 -1
  41. package/dist/chunks/6046.d0b3cfb1.js +0 -3
  42. package/dist/chunks/6046.d0b3cfb1.js.map +0 -1
  43. package/dist/chunks/6580.ab4ba4d4.js +0 -3
  44. package/dist/chunks/6580.ab4ba4d4.js.map +0 -1
  45. package/dist/chunks/6941.66e34b74.js.map +0 -1
  46. package/dist/chunks/7218.16427ab5.js +0 -2
  47. package/dist/chunks/7218.16427ab5.js.map +0 -1
  48. package/dist/chunks/7895.0c6c8882.js.map +0 -1
  49. package/dist/chunks/948.dec6ad6a.js +0 -3
  50. package/dist/chunks/948.dec6ad6a.js.map +0 -1
  51. package/dist/chunks/eo-user-or-user-group-select.b49b99a5.js +0 -3
  52. package/dist/chunks/eo-user-or-user-group-select.b49b99a5.js.LICENSE.txt +0 -1
  53. package/dist/chunks/eo-user-or-user-group-select.b49b99a5.js.map +0 -1
  54. package/dist/chunks/main.0e8ed5c0.js +0 -2
  55. package/dist/chunks/main.0e8ed5c0.js.map +0 -1
  56. package/dist/index.1c21b41c.js +0 -2
  57. package/dist/index.1c21b41c.js.map +0 -1
  58. /package/dist/chunks/{7895.0c6c8882.js.LICENSE.txt → 7895.b1a401b6.js.LICENSE.txt} +0 -0
  59. /package/dist/chunks/{948.dec6ad6a.js.LICENSE.txt → 948.be85ace4.js.LICENSE.txt} +0 -0
  60. /package/dist/chunks/{6580.ab4ba4d4.js.LICENSE.txt → eo-user-or-user-group-select.422d8070.js.LICENSE.txt} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/6376.5cbfdb2a.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":""}
@@ -1,2 +1,2 @@
1
- "use strict";(globalThis.webpackChunk_next_bricks_form_platform=globalThis.webpackChunk_next_bricks_form_platform||[]).push([[6941],{281:(e,t,a)=>{a.d(t,{A:()=>o});var n=a(6758),r=a.n(n),l=a(935),i=a.n(l)()(r());i.push([e.id,":host{display:block}",""]);const o=i.toString()},1757:(e,t,a)=>{a.d(t,{N:()=>k});var n,r=a(918),l=a(6121),i=a(829),o=a(2740),s=a(870),c=a(981);let d,u,h,p,m,b,v,f,A;const{method:g,property:C}=(0,s.createDecorators)();var S=new WeakMap,E=new WeakMap,y=new WeakMap,I=new WeakMap,_=new WeakMap,w=new WeakMap,N=new WeakMap;class k extends c.ReactNextElement{constructor(){super(...arguments),(0,r.A)(this,S,(d(this),!1)),(0,r.A)(this,E,"normal"),(0,r.A)(this,y,!1),(0,r.A)(this,I,u(this)),(0,r.A)(this,_,(h(this),p(this))),(0,r.A)(this,w,(m(this),b(this))),(0,r.A)(this,N,(v(this),f(this))),A(this)}get _notRender(){return(0,i.A)(S,this)}set _notRender(e){(0,l.A)(S,this,e)}get validate(){return(0,i.A)(E,this)}set validate(e){(0,l.A)(E,this,e)}get bindFormItem(){return(0,i.A)(y,this)}set bindFormItem(e){(0,l.A)(y,this,e)}get isFormItemElement(){return!0}set validateState(e){this.validate=e,this._render()}get validateState(){return this.validate}set notRender(e){this.hidden=e,this._notRender=e,this._render()}get notRender(){return this._notRender}get $bindFormItem(){return this.bindFormItem}set $bindFormItem(e){this.bindFormItem=e,this._render()}get helpBrick(){return(0,i.A)(I,this)}set helpBrick(e){(0,l.A)(I,this,e)}get labelBrick(){return(0,i.A)(_,this)}set labelBrick(e){(0,l.A)(_,this,e)}get labelCol(){return(0,i.A)(w,this)}set labelCol(e){(0,l.A)(w,this,e)}get wrapperCol(){return(0,i.A)(N,this)}set wrapperCol(e){(0,l.A)(N,this,e)}setNotRender(e){this.notRender=e}getFormElement(){let e=this;for(;(e=e.parentNode)&&e&&!e.isFormElement;);return e}}n=k,[u,h,p,m,b,v,f,A,d]=(0,o.A)(n,[],[[C({attribute:!1}),1,"helpBrick"],[C({attribute:!1}),1,"labelBrick"],[C({attribute:!1}),1,"labelCol"],[C({attribute:!1}),1,"wrapperCol"],[g(),2,"setNotRender"],[g(),2,"getFormElement"]],0,void 0,c.ReactNextElement).e},2736:(e,t,a)=>{a.d(t,{v:()=>l});var n=a(563);const r=["formElement","curElement","name","label","current","required","pattern","type","min","max","labelCol","wrapperCol","message","layout","size","trigger","valuePropsName","notRender","helpBrick","labelBrick","needValidate","validator"];function l(e){return(0,n.pick)(e,r)}},5814:(e,t,a)=>{a.d(t,{GW:()=>$});var n=a(9575),r=a(8769),l=a.n(r),i=a(801),o=a(656),s=a(7008),c=a(563),d=a(6305),u=a(4986),h=a(8406),p=a(3373),m=a.n(p),b=a(7177),v=a(6123),f=a(2591),A=a.n(f),g=a(1740),C=a.n(g),S=a(8128),E=a.n(S),y=a(855),I=a.n(y),_=a(3051),w=a.n(_),N=a(3656),k=a.n(N),R=a(9156),x={};x.styleTagTransform=k(),x.setAttributes=I(),x.insert=E().bind(null,"head"),x.domAPI=C(),x.insertStyleElement=w(),A()(R.A,x);const B=R.A&&R.A.locals?R.A.locals:void 0;(0,b.initializeI18n)(v.NS,v.I);const T=e=>"HOST"===e?"hostname":"name",$=l().forwardRef((function(e,t){const{showKeyField:a,fields:p={label:[a?"#showKey":T(e.objectId)],value:"instanceId"},firstRender:f=!0,minimumInputLength:A=0,extraSearchKey:g=[],extraFields:C=[],mode:S,placeholder:E,allowClear:y,pageSize:I=30,isMultiLabel:_=!0,showSearchTip:w,permission:N,ignoreMissingFieldError:k,dropdownMatchSelectWidth:R=!0,blurAfterValueChanged:x,suffix:$,useExternalCmdbApi:M,externalSourceId:j}=e,D=function(e){const t=Array.isArray(e)?e:[e];return(0,c.compact)(t)}(e.instanceQuery);p.value||(p.value="instanceId");const[F,K]=l().useState(),[W,z]=l().useState(),[U,H]=l().useState([]),[P,L]=l().useState([]),[O,G]=l().useState(0),[q,V]=l().useState(!1),J=(0,u.useProvider)("easyops.api.cmdb.topo_center@ProxyPostSearchV3:1.0.1",{cache:!1}),Z=(0,r.useMemo)((()=>({objectId:e.objectId,sourceId:e.externalSourceId})),[e.objectId,j]),Q=()=>{const t=[p.value,...Array.isArray(p.label)?p.label:[p.label],...g,...C];return"USER"===e.objectId&&t.push("user_icon"),t},X=async function(t,a){let n=arguments.length>3?arguments[3]:void 0;if(arguments.length>2&&void 0!==arguments[2]&&arguments[2]||t.length>=A)try{var r;let l=[];if(!e.objectId)return[];V(!0);const i={query:{$and:[{$or:[...Array.isArray(p.label)?p.label.filter((e=>!!e)).map((e=>({[e]:{$like:`%${t}%`}}))):p.label?[{[p.label]:{$like:`%${t}%`}}]:[],...g.map((e=>({[e]:{$like:`%${t}%`}})))]},...a]},...N?{permission:N}:{},fields:Q().filter((e=>!!e)),page:1,page_size:n||I,ignore_missing_field_error:k,sort:e.sort},o=M?await J.query([{...i,...Z}]):await(0,h.y)(e.objectId,i);l=o.list,G(o.total);const s=l.map((t=>({...t,label:Array.isArray(p.label)?p.label.map((e=>e?(0,c.get)(t,e):void 0)):p.label?(0,c.get)(t,p.label):void 0,value:p.value?(0,c.get)(t,p.value):void 0,..."USER"===e.objectId?{user_icon:(0,c.get)(t,"user_icon","defaultIcon")}:{}})));return H(s),null===(r=e.optionsChange)||void 0===r||r.call(e,s),s}catch(e){return(0,d.handleHttpError)(e),[]}finally{V(!1)}return[]};l().useEffect((()=>{!e.objectId||(0,c.isNil)(e.value)||(0,c.isEqual)(e.objectId,W)&&(0,c.isEqual)(e.value,F)||(async t=>{const a=await X("",[{[p.value||"instanceId"]:{$in:(0,c.castArray)(e.value)}},...D],!0,(null===(t=e.value)||void 0===t?void 0:t.length)>=I?e.value.length:I);L(a)})();const t="multiple"!==e.mode||(0,c.trim)(e.value)?e.value:[];K(t),z(e.objectId)}),[e.value,e.objectId]),l().useEffect((()=>{f||K("multiple"===S?[]:"")}),[e.objectId]);const Y=(0,c.debounce)((e=>X(e,D)),500);return l().createElement(i.A,(0,n.A)({ref:t,loading:q,className:"formsCmdbInstSelect",allowClear:y,style:(0,c.defaults)(e.inputBoxStyle,{width:"100%"}),showSearch:!0,filterOption:!1,value:F,mode:S,placeholder:E||b.i18n.t(`${v.NS}:${v.K.BACKGROUND_SEARCH}`),onChange:t=>{let a;if("multiple"===S){const e=new Set(t);a=U.filter((t=>e.has(t.value)));const n=new Set((0,c.difference)(t,a.map((e=>e.value))));a=a.concat(P.filter((e=>n.has(e.value))))}else a=U.find((e=>e.value===t));if(x){const e=document.getElementsByClassName("formsCmdbInstSelect");for(let t=0;t<e.length;t++){var n;null===(n=e[t].getElementsByTagName("input"))||void 0===n||null===(n=n[0])||void 0===n||n.blur()}}K(t),L(a),e.onChange&&e.onChange(t,a)},onSearch:Y,onFocus:async()=>{await X("",D)},disabled:e.disabled,dropdownStyle:{padding:"2px",...e.dropdownStyle},dropdownMatchSelectWidth:R,dropdownRender:e=>l().createElement("div",null,e,w&&O>I&&l().createElement("div",{className:B.moreChoices},"仅显示前",I,"项,更多结果请搜索"))},"parent"===e.popoverPositionType?{getPopupContainer:e=>e.parentElement}:{getPopupContainer:e.getPopupContainer}),U.map(((t,a)=>{var n;const r=(t=>{if(e.labelTemplate)return function(e,t){let a=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return e.replace(/#{([#A-Za-z_$][\w$]*(?:(?:\.[A-Za-z_$][\w$]*)|(?:\[[0-9]+\]))*)}/g,((e,n)=>{const r=(0,c.get)(t,n);return void 0===r?!0===a?e:"":r}))}(e.labelTemplate,t);{const a=t.label;if(Array.isArray(a)){const t=a[0],n=a.slice(1,a.length).join(",");if(Array.isArray(t)&&e.showKeyField){const e=t[0],a=t.slice(1,t.length).join(",");return a&&_?`${e}(${a})`:null!=e?e:""}return n&&_?`${null!=t?t:" - "}(${n})`:null!=t?t:""}return a}})(t);return l().createElement(i.A.Option,{key:a,value:t.value,label:r},l().createElement(o.A,{title:e.showTooltip?r:void 0},l().createElement("div",{className:m()(B.optionDiv)},t.user_icon&&l().createElement("span",null,l().createElement(s.A,{src:t.user_icon,size:24,className:m()(B.avatar,{[B.defaultIcon]:"defaultIcon"===t.user_icon})},"defaultIcon"===t.user_icon&&(null===(n=t.label)||void 0===n?void 0:n.slice(0,2)))),l().createElement("span",{className:m()(B.optionSpan),"data-testid":"option-label"},r),(null==$?void 0:$.useBrick)&&l().createElement("div",{className:B.suffixContainer},l().createElement(u.ReactUseMultipleBricks,{useBrick:$.useBrick,data:t})))))})))}))},6123:(e,t,a)=>{a.d(t,{I:()=>l,K:()=>n,NS:()=>r});let n=function(e){return e.CMDB_INSTANCE_SELECT="CMDB_INSTANCE_SELECT",e.BACKGROUND_SEARCH="BACKGROUND_SEARCH",e}({});const r="bricks/form-platform/eo-cmdb-instance-select",l={en:{CMDB_INSTANCE_SELECT:"CMDB Instance Select",BACKGROUND_SEARCH:"Input keyword to search"},zh:{CMDB_INSTANCE_SELECT:"CMDB 实例选择",BACKGROUND_SEARCH:"输入关键字搜索"}}},9156:(e,t,a)=>{a.d(t,{A:()=>o});var n=a(6758),r=a.n(n),l=a(935),i=a.n(l)()(r());i.push([e.id,".avatar--bjgrCS7c{flex-shrink:0}.avatar--bjgrCS7c.defaultIcon--JzAU3AVW{background-color:#167be0;vertical-align:middle}.moreChoices--NRe_HE2Z{padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#999;font-style:italic}.optionSpan--RfuLmCys{max-width:100%;overflow:hidden;text-overflow:ellipsis}.optionDiv--NwbSvnDQ{display:flex;align-items:center;gap:6px;min-height:100%}.suffixContainer--T6K_eJyX{margin-left:auto}",""]),i.locals={avatar:"avatar--bjgrCS7c",defaultIcon:"defaultIcon--JzAU3AVW",moreChoices:"moreChoices--NRe_HE2Z",optionSpan:"optionSpan--RfuLmCys",optionDiv:"optionDiv--NwbSvnDQ",suffixContainer:"suffixContainer--T6K_eJyX"};const o=i}}]);
2
- //# sourceMappingURL=6941.66e34b74.js.map
1
+ "use strict";(globalThis.webpackChunk_next_bricks_form_platform=globalThis.webpackChunk_next_bricks_form_platform||[]).push([[6941],{281:(e,t,a)=>{a.d(t,{A:()=>o});var n=a(6758),r=a.n(n),l=a(935),i=a.n(l)()(r());i.push([e.id,":host{display:block}",""]);const o=i.toString()},1757:(e,t,a)=>{a.d(t,{N:()=>k});var n,r=a(918),l=a(6121),i=a(829),o=a(2740),s=a(870),c=a(981);let d,u,h,p,m,b,v,f,A;const{method:g,property:C}=(0,s.createDecorators)();var S=new WeakMap,E=new WeakMap,y=new WeakMap,I=new WeakMap,_=new WeakMap,w=new WeakMap,N=new WeakMap;class k extends c.ReactNextElement{constructor(){super(...arguments),(0,r.A)(this,S,(d(this),!1)),(0,r.A)(this,E,"normal"),(0,r.A)(this,y,!1),(0,r.A)(this,I,u(this)),(0,r.A)(this,_,(h(this),p(this))),(0,r.A)(this,w,(m(this),b(this))),(0,r.A)(this,N,(v(this),f(this))),A(this)}get _notRender(){return(0,i.A)(S,this)}set _notRender(e){(0,l.A)(S,this,e)}get validate(){return(0,i.A)(E,this)}set validate(e){(0,l.A)(E,this,e)}get bindFormItem(){return(0,i.A)(y,this)}set bindFormItem(e){(0,l.A)(y,this,e)}get isFormItemElement(){return!0}set validateState(e){this.validate=e,this._render()}get validateState(){return this.validate}set notRender(e){this.hidden=e,this._notRender=e,this._render()}get notRender(){return this._notRender}get $bindFormItem(){return this.bindFormItem}set $bindFormItem(e){this.bindFormItem=e,this._render()}get helpBrick(){return(0,i.A)(I,this)}set helpBrick(e){(0,l.A)(I,this,e)}get labelBrick(){return(0,i.A)(_,this)}set labelBrick(e){(0,l.A)(_,this,e)}get labelCol(){return(0,i.A)(w,this)}set labelCol(e){(0,l.A)(w,this,e)}get wrapperCol(){return(0,i.A)(N,this)}set wrapperCol(e){(0,l.A)(N,this,e)}setNotRender(e){this.notRender=e}getFormElement(){let e=this;for(;(e=e.parentNode)&&e&&!e.isFormElement;);return e}}n=k,[u,h,p,m,b,v,f,A,d]=(0,o.A)(n,[],[[C({attribute:!1}),1,"helpBrick"],[C({attribute:!1}),1,"labelBrick"],[C({attribute:!1}),1,"labelCol"],[C({attribute:!1}),1,"wrapperCol"],[g(),2,"setNotRender"],[g(),2,"getFormElement"]],0,void 0,c.ReactNextElement).e},2736:(e,t,a)=>{a.d(t,{v:()=>l});var n=a(563);const r=["formElement","curElement","name","label","current","required","pattern","type","min","max","labelCol","wrapperCol","message","layout","size","trigger","valuePropsName","notRender","helpBrick","labelBrick","needValidate","validator"];function l(e){return(0,n.pick)(e,r)}},5814:(e,t,a)=>{a.d(t,{GW:()=>$});var n=a(9575),r=a(8769),l=a.n(r),i=a(801),o=a(656),s=a(7008),c=a(563),d=a(6305),u=a(4986),h=a(8406),p=a(3373),m=a.n(p),b=a(7177),v=a(6123),f=a(2591),A=a.n(f),g=a(1740),C=a.n(g),S=a(8128),E=a.n(S),y=a(855),I=a.n(y),_=a(5432),w=a.n(_),N=a(3656),k=a.n(N),R=a(9156),x={};x.styleTagTransform=k(),x.setAttributes=I(),x.insert=E().bind(null,"head"),x.domAPI=C(),x.insertStyleElement=w(),A()(R.A,x);const B=R.A&&R.A.locals?R.A.locals:void 0;(0,b.initializeI18n)(v.NS,v.I);const T=e=>"HOST"===e?"hostname":"name",$=l().forwardRef((function(e,t){const{showKeyField:a,fields:p={label:[a?"#showKey":T(e.objectId)],value:"instanceId"},firstRender:f=!0,minimumInputLength:A=0,extraSearchKey:g=[],extraFields:C=[],mode:S,placeholder:E,allowClear:y,pageSize:I=30,isMultiLabel:_=!0,showSearchTip:w,permission:N,ignoreMissingFieldError:k,dropdownMatchSelectWidth:R=!0,blurAfterValueChanged:x,suffix:$,useExternalCmdbApi:M,externalSourceId:j}=e,D=function(e){const t=Array.isArray(e)?e:[e];return(0,c.compact)(t)}(e.instanceQuery);p.value||(p.value="instanceId");const[F,K]=l().useState(),[W,z]=l().useState(),[U,H]=l().useState([]),[P,L]=l().useState([]),[O,G]=l().useState(0),[q,V]=l().useState(!1),J=(0,u.useProvider)("easyops.api.cmdb.topo_center@ProxyPostSearchV3:1.0.1",{cache:!1}),Z=(0,r.useMemo)((()=>({objectId:e.objectId,sourceId:e.externalSourceId})),[e.objectId,j]),Q=()=>{const t=[p.value,...Array.isArray(p.label)?p.label:[p.label],...g,...C];return"USER"===e.objectId&&t.push("user_icon"),t},X=async function(t,a){let n=arguments.length>3?arguments[3]:void 0;if(arguments.length>2&&void 0!==arguments[2]&&arguments[2]||t.length>=A)try{var r;let l=[];if(!e.objectId)return[];V(!0);const i={query:{$and:[{$or:[...Array.isArray(p.label)?p.label.filter((e=>!!e)).map((e=>({[e]:{$like:`%${t}%`}}))):p.label?[{[p.label]:{$like:`%${t}%`}}]:[],...g.map((e=>({[e]:{$like:`%${t}%`}})))]},...a]},...N?{permission:N}:{},fields:Q().filter((e=>!!e)),page:1,page_size:n||I,ignore_missing_field_error:k,sort:e.sort},o=M?await J.query([{...i,...Z}]):await(0,h.y)(e.objectId,i);l=o.list,G(o.total);const s=l.map((t=>({...t,label:Array.isArray(p.label)?p.label.map((e=>e?(0,c.get)(t,e):void 0)):p.label?(0,c.get)(t,p.label):void 0,value:p.value?(0,c.get)(t,p.value):void 0,..."USER"===e.objectId?{user_icon:(0,c.get)(t,"user_icon","defaultIcon")}:{}})));return H(s),null===(r=e.optionsChange)||void 0===r||r.call(e,s),s}catch(e){return(0,d.handleHttpError)(e),[]}finally{V(!1)}return[]};l().useEffect((()=>{!e.objectId||(0,c.isNil)(e.value)||(0,c.isEqual)(e.objectId,W)&&(0,c.isEqual)(e.value,F)||(async t=>{const a=await X("",[{[p.value||"instanceId"]:{$in:(0,c.castArray)(e.value)}},...D],!0,(null===(t=e.value)||void 0===t?void 0:t.length)>=I?e.value.length:I);L(a)})();const t="multiple"!==e.mode||(0,c.trim)(e.value)?e.value:[];K(t),z(e.objectId)}),[e.value,e.objectId]),l().useEffect((()=>{f||K("multiple"===S?[]:"")}),[e.objectId]);const Y=(0,c.debounce)((e=>X(e,D)),500);return l().createElement(i.A,(0,n.A)({ref:t,loading:q,className:"formsCmdbInstSelect",allowClear:y,style:(0,c.defaults)(e.inputBoxStyle,{width:"100%"}),showSearch:!0,filterOption:!1,value:F,mode:S,placeholder:E||b.i18n.t(`${v.NS}:${v.K.BACKGROUND_SEARCH}`),onChange:t=>{let a;if("multiple"===S){const e=new Set(t);a=U.filter((t=>e.has(t.value)));const n=new Set((0,c.difference)(t,a.map((e=>e.value))));a=a.concat(P.filter((e=>n.has(e.value))))}else a=U.find((e=>e.value===t));if(x){const e=document.getElementsByClassName("formsCmdbInstSelect");for(let t=0;t<e.length;t++){var n;null===(n=e[t].getElementsByTagName("input"))||void 0===n||null===(n=n[0])||void 0===n||n.blur()}}K(t),L(a),e.onChange&&e.onChange(t,a)},onSearch:Y,onFocus:async()=>{await X("",D)},disabled:e.disabled,dropdownStyle:{padding:"2px",...e.dropdownStyle},dropdownMatchSelectWidth:R,dropdownRender:e=>l().createElement("div",null,e,w&&O>I&&l().createElement("div",{className:B.moreChoices},"仅显示前",I,"项,更多结果请搜索"))},"parent"===e.popoverPositionType?{getPopupContainer:e=>e.parentElement}:{getPopupContainer:e.getPopupContainer}),U.map(((t,a)=>{var n;const r=(t=>{if(e.labelTemplate)return function(e,t){let a=arguments.length>2&&void 0!==arguments[2]&&arguments[2];return e.replace(/#{([#A-Za-z_$][\w$]*(?:(?:\.[A-Za-z_$][\w$]*)|(?:\[[0-9]+\]))*)}/g,((e,n)=>{const r=(0,c.get)(t,n);return void 0===r?!0===a?e:"":r}))}(e.labelTemplate,t);{const a=t.label;if(Array.isArray(a)){const t=a[0],n=a.slice(1,a.length).join(",");if(Array.isArray(t)&&e.showKeyField){const e=t[0],a=t.slice(1,t.length).join(",");return a&&_?`${e}(${a})`:null!=e?e:""}return n&&_?`${null!=t?t:" - "}(${n})`:null!=t?t:""}return a}})(t);return l().createElement(i.A.Option,{key:a,value:t.value,label:r},l().createElement(o.A,{title:e.showTooltip?r:void 0},l().createElement("div",{className:m()(B.optionDiv)},t.user_icon&&l().createElement("span",null,l().createElement(s.A,{src:t.user_icon,size:24,className:m()(B.avatar,{[B.defaultIcon]:"defaultIcon"===t.user_icon})},"defaultIcon"===t.user_icon&&(null===(n=t.label)||void 0===n?void 0:n.slice(0,2)))),l().createElement("span",{className:m()(B.optionSpan),"data-testid":"option-label"},r),(null==$?void 0:$.useBrick)&&l().createElement("div",{className:B.suffixContainer},l().createElement(u.ReactUseMultipleBricks,{useBrick:$.useBrick,data:t})))))})))}))},6123:(e,t,a)=>{a.d(t,{I:()=>l,K:()=>n,NS:()=>r});let n=function(e){return e.CMDB_INSTANCE_SELECT="CMDB_INSTANCE_SELECT",e.BACKGROUND_SEARCH="BACKGROUND_SEARCH",e}({});const r="bricks/form-platform/eo-cmdb-instance-select",l={en:{CMDB_INSTANCE_SELECT:"CMDB Instance Select",BACKGROUND_SEARCH:"Input keyword to search"},zh:{CMDB_INSTANCE_SELECT:"CMDB 实例选择",BACKGROUND_SEARCH:"输入关键字搜索"}}},9156:(e,t,a)=>{a.d(t,{A:()=>o});var n=a(6758),r=a.n(n),l=a(935),i=a.n(l)()(r());i.push([e.id,".avatar--bjgrCS7c{flex-shrink:0}.avatar--bjgrCS7c.defaultIcon--JzAU3AVW{background-color:#167be0;vertical-align:middle}.moreChoices--NRe_HE2Z{padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#999;font-style:italic}.optionSpan--RfuLmCys{max-width:100%;overflow:hidden;text-overflow:ellipsis}.optionDiv--NwbSvnDQ{display:flex;align-items:center;gap:6px;min-height:100%}.suffixContainer--T6K_eJyX{margin-left:auto}",""]),i.locals={avatar:"avatar--bjgrCS7c",defaultIcon:"defaultIcon--JzAU3AVW",moreChoices:"moreChoices--NRe_HE2Z",optionSpan:"optionSpan--RfuLmCys",optionDiv:"optionDiv--NwbSvnDQ",suffixContainer:"suffixContainer--T6K_eJyX"};const o=i}}]);
2
+ //# sourceMappingURL=6941.f45659ab.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunks/6941.f45659ab.js","mappings":"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","sources":["webpack:///./src/cmdb-instance-select/styles.shadow.css","webpack:///../../src/FormItemElement.tsx","webpack:///../../src/pickFormItemProps.ts","webpack:///./src/cmdb-instance-select/CmdbInstanceSelect.module.css?39dd","webpack:///./src/cmdb-instance-select/CmdbInstanceSelectInternal.tsx","webpack:///./src/cmdb-instance-select/i18n.ts","webpack:///./src/cmdb-instance-select/CmdbInstanceSelect.module.css"],"sourcesContent":["// 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}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n","import { createDecorators } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport type { AbstractForm, ColProps } from \"./Form.js\";\nimport { UseBrickConfOrRenderFunction } from \"@next-core/react-runtime\";\n\nconst { method, property } = createDecorators();\n\nexport abstract class FormItemElementBase extends ReactNextElement {\n private accessor _notRender = false;\n private accessor validate = \"normal\";\n private accessor bindFormItem = false;\n\n get isFormItemElement(): true {\n return true;\n }\n\n set validateState(value: string) {\n this.validate = value;\n this._render();\n }\n get validateState() {\n return this.validate;\n }\n\n /**\n * 控制该表单项是否隐藏\n * @default false\n * @group ui\n */\n set notRender(value: boolean) {\n this.hidden = value;\n this._notRender = value;\n this._render();\n }\n get notRender(): boolean {\n return this._notRender;\n }\n\n get $bindFormItem() {\n return this.bindFormItem;\n }\n set $bindFormItem(value: boolean) {\n this.bindFormItem = value;\n this._render();\n }\n\n @property({\n attribute: false,\n })\n accessor helpBrick:\n | {\n useBrick: UseBrickConfOrRenderFunction;\n }\n | undefined;\n\n @property({\n attribute: false,\n })\n accessor labelBrick:\n | {\n useBrick: UseBrickConfOrRenderFunction;\n }\n | undefined;\n\n @property({\n attribute: false,\n })\n accessor labelCol: ColProps | undefined;\n\n @property({\n attribute: false,\n })\n accessor wrapperCol: ColProps | undefined;\n\n @method()\n setNotRender(value: boolean) {\n this.notRender = value;\n }\n\n @method()\n getFormElement(): AbstractForm | null {\n // eslint-disable-next-line @typescript-eslint/no-this-alias\n let element: AbstractForm | null = this as unknown as AbstractForm;\n while ((element = element.parentNode as AbstractForm | null)) {\n if (!element || element.isFormElement) {\n break;\n }\n }\n return element as AbstractForm | null;\n }\n}\n","// istanbul ignore file\nimport { pick } from \"lodash\";\nimport type { FormItemProps } from \"./interfaces\";\n\nconst FORM_ITEM_PROP_NAMES = [\n \"formElement\",\n \"curElement\",\n \"name\",\n \"label\",\n \"current\",\n \"required\",\n \"pattern\",\n \"type\",\n \"min\",\n \"max\",\n \"labelCol\",\n \"wrapperCol\",\n \"message\",\n \"layout\",\n \"size\",\n \"trigger\",\n \"valuePropsName\",\n \"notRender\",\n \"helpBrick\",\n \"labelBrick\",\n \"needValidate\",\n \"validator\",\n] as const;\n\nexport function pickFormItemProps<T extends FormItemProps>(\n props: T\n): FormItemProps {\n return pick(props, FORM_ITEM_PROP_NAMES);\n}\n\n/* ====== Type checks ====== */\ntype Equal<X, Y> =\n (<T>() => T extends X ? 1 : 2) extends <T>() => T extends Y ? 1 : 2\n ? true\n : false;\ntype Expect<T extends true> = T;\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\ntype cases = [\n Expect<Equal<keyof FormItemProps, (typeof FORM_ITEM_PROP_NAMES)[number]>>,\n];\n","\n import API from \"!../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js\";\n import domAPI from \"!../../../../node_modules/style-loader/dist/runtime/styleDomAPI.js\";\n import insertFn from \"!../../../../node_modules/style-loader/dist/runtime/insertBySelector.js\";\n import setAttributes from \"!../../../../node_modules/style-loader/dist/runtime/setAttributesWithoutAttributes.js\";\n import insertStyleElement from \"!../../../../node_modules/style-loader/dist/runtime/insertStyleElement.js\";\n import styleTagTransformFn from \"!../../../../node_modules/style-loader/dist/runtime/styleTagTransform.js\";\n import content, * as namedExport from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./CmdbInstanceSelect.module.css\";\n \n \n\nvar options = {};\n\noptions.styleTagTransform = styleTagTransformFn;\noptions.setAttributes = setAttributes;\noptions.insert = insertFn.bind(null, \"head\");\noptions.domAPI = domAPI;\noptions.insertStyleElement = insertStyleElement;\n\nvar update = API(content, options);\n\n\n\nexport * from \"!!../../../../node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!../../../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./CmdbInstanceSelect.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import React, { useMemo } from \"react\";\nimport { Select, Avatar, Tooltip } from \"antd\";\nimport { SelectValue } from \"antd/lib/select\";\nimport {\n debounce,\n get,\n compact,\n castArray,\n defaults,\n isEqual,\n difference,\n isNil,\n trim,\n} from \"lodash\";\n\nimport { handleHttpError } from \"@next-core/runtime\";\nimport { ReactUseMultipleBricks, useProvider } from \"@next-core/react-runtime\";\nimport { UseBrickConfOrRenderFunction } from \"@next-core/react-runtime\";\nimport { InstanceApi_postSearchV3 } from \"@next-api-sdk/cmdb-sdk\";\nimport classNames from \"classnames\";\n\nimport { i18n, initializeI18n } from \"@next-core/i18n\";\nimport { K, NS, locales } from \"./i18n.js\";\n\nimport style from \"./CmdbInstanceSelect.module.css\";\n\ninitializeI18n(NS, locales);\n\n// 从 @shared/cmdb-utils 迁移过来的工具函数\nexport const getInstanceNameKey = (objectId: string | number) =>\n objectId === \"HOST\" ? \"hostname\" : \"name\";\n\nexport function parseTemplate(\n template: string,\n data: Record<string, any>,\n skipUndefined = false\n) {\n return template.replace(\n /#{([#A-Za-z_$][\\w$]*(?:(?:\\.[A-Za-z_$][\\w$]*)|(?:\\[[0-9]+\\]))*)}/g,\n (match: string, key: string) => {\n const value = get(data, key);\n\n return value === undefined\n ? skipUndefined === true\n ? match\n : \"\"\n : value;\n }\n );\n}\n\nexport interface CmdbInstanceSelectProps {\n /** 模型对象 ID,必填,指定要查询的模型 */\n objectId: string;\n /** 选择模式,支持 \"default\"(单选)、\"multiple\"(多选)、\"tags\"(标签模式) */\n mode?: string;\n /** 每页加载的实例数量,默认值通常为 20 */\n pageSize?: number;\n /** 实例查询条件,支持 CMDB 查询语法(如 { name: { $like: \"%test%\" } }) */\n instanceQuery?: any;\n /** 输入框占位文本,如\"请选择\"或\"请输入搜索关键词\" */\n placeholder?: string;\n /** 自定义字段配置,用于指定显示哪些字段以及如何显示 */\n fields?: Partial<ComplexOption<string>>;\n /** 是否为首次渲染,用于控制初始化行为 */\n firstRender?: boolean;\n /** 最少输入字符数才触发搜索,设置为 0 表示无限制 */\n minimumInputLength?: number;\n /** 当前选中值,单选时为字符串或数字,多选时为数组 */\n value?: any;\n /** 值变更回调函数,参数为新选中的值和对应的选项对象 */\n onChange?: (value: string, option?: ComplexOption) => void;\n /** 选项列表变更回调,当选项数据加载完成时触发 */\n optionsChange?: (options: ComplexOption[]) => void;\n /** 是否显示清除按钮 */\n allowClear?: boolean;\n /** 输入框自定义样式 */\n inputBoxStyle?: React.CSSProperties;\n /** 额外的搜索字段 ID 数组,用于在多个字段中搜索关键词 */\n extraSearchKey?: string[];\n /** 额外要查询的字段 ID 数组,用于在返回数据中包含更多字段 */\n extraFields?: string[];\n /** 弹出层定位类型,\"default\" 为相对于触发元素,\"parent\" 为相对于父容器 */\n popoverPositionType?: \"default\" | \"parent\";\n /** 是否启用多标签显示模式 */\n isMultiLabel?: boolean;\n /** 是否显示搜索提示文本 */\n showSearchTip?: boolean;\n /** 显示标签的模板字符串(如 \"{{name}} ({{ip}})\"),使用 {{fieldId}} 占位符 */\n labelTemplate?: string;\n /** 是否禁用选择器 */\n disabled?: boolean;\n /** 权限控制数组,可包含 \"read\"、\"update\"、\"operate\" 等权限值 */\n permission?: Array<\"read\" | \"update\" | \"operate\">;\n /** 是否在选项文本超长时显示 Tooltip */\n showTooltip?: boolean;\n /** 是否忽略字段缺失错误(当查询的字段在模型中不存在时不报错) */\n ignoreMissingFieldError?: boolean;\n /** 是否显示关键字段(通常是 instanceId) */\n showKeyField?: boolean;\n /** 下拉菜单宽度是否跟随选择框宽度 */\n dropdownMatchSelectWidth?: boolean;\n /** 下拉菜单自定义样式 */\n dropdownStyle?: React.CSSProperties;\n /** 值变化后是否自动失焦(关闭下拉菜单) */\n blurAfterValueChanged?: boolean;\n /** 排序配置数组,如 [{ name: 1 }] 表示按 name 字段升序排序 */\n sort?: Array<Record<string, number | string>>;\n /** 后缀自定义构件配置,用于在选择器后面添加自定义元素 */\n suffix?: {\n useBrick: UseBrickConfOrRenderFunction;\n };\n /** 是否使用构件可见性控制 */\n useBrickVisible?: boolean;\n /** 是否使用外部 CMDB API */\n useExternalCmdbApi?: boolean;\n /** 外部数据源 ID */\n externalSourceId?: string;\n /** 自定义弹出层容器 */\n getPopupContainer?: (node: HTMLElement) => HTMLElement;\n}\n\nexport interface ComplexOption<T = string | number> {\n label: string[] | string;\n value: T;\n user_icon?: string; // objectId为USER的时候显示用户头像\n}\n\nexport function formatUserQuery(instanceQuery: any): any[] {\n const arr = Array.isArray(instanceQuery) ? instanceQuery : [instanceQuery];\n\n return compact(arr);\n}\n\n/**\n * CMDB 实例下拉选择器组件\n *\n * 基于 Ant Design Select 的 CMDB 实例选择器,支持搜索、分页加载、\n * 单选和多选模式。自动调用 CMDB API 获取实例列表。\n *\n * 主要特性:\n * - 支持关键词搜索(搜索防抖 300ms)\n * - 支持分页加载(滚动到底部自动加载下一页)\n * - 支持单选和多选模式\n * - 支持自定义查询条件(instanceQuery)\n * - 支持自定义显示字段(labelTemplate)\n * - USER 模型特殊处理(显示用户头像)\n * - 支持权限控制(permission)\n * - 支持外部 CMDB 数据源\n * - 支持自定义后缀内容\n */\nexport const CmdbInstanceSelect = React.forwardRef(function CmdbInstanceSelect(\n props: CmdbInstanceSelectProps,\n ref: any\n): React.ReactElement {\n const {\n showKeyField,\n // 默认显示 label 为模型的 name/hostname, value 为 instanceId\n // 当showKeyField时,实例展示是用showKey里的数据展示\n fields = {\n label: [showKeyField ? \"#showKey\" : getInstanceNameKey(props.objectId)],\n value: \"instanceId\",\n },\n firstRender = true,\n minimumInputLength = 0,\n extraSearchKey = [],\n extraFields = [],\n mode,\n placeholder,\n allowClear,\n pageSize = 30,\n isMultiLabel = true,\n showSearchTip,\n permission,\n ignoreMissingFieldError,\n dropdownMatchSelectWidth = true,\n blurAfterValueChanged,\n suffix,\n useExternalCmdbApi,\n externalSourceId,\n } = props;\n const userQuery = formatUserQuery(props.instanceQuery);\n //istanbul ignore else\n if (!fields.value) {\n fields.value = \"instanceId\";\n }\n\n const [value, setValue] = React.useState<unknown>();\n const [objectId, setObjectId] = React.useState<string>();\n const [options, setOptions] = React.useState<ComplexOption[]>([]);\n const [selectedOptions, setSelectedOptions] = React.useState<ComplexOption[]>(\n []\n );\n const [total, setTotal] = React.useState(0);\n const [loading, setLoading] = React.useState(false);\n\n // 用于外部调用的接口, 当useExternalCmdbApi为true,才调用这些接口\n const externalPostSearchV3 = useProvider(\n \"easyops.api.cmdb.topo_center@ProxyPostSearchV3:1.0.1\",\n { cache: false }\n );\n\n // useExternalCmdbApi为true,外部接口参数\n const externalRequestParams = useMemo(() => {\n return {\n objectId: props.objectId,\n sourceId: props.externalSourceId,\n };\n }, [props.objectId, externalSourceId]);\n const computeFields = () => {\n const result = [\n fields.value,\n ...(Array.isArray(fields.label) ? fields.label : [fields.label]),\n ...extraSearchKey,\n ...extraFields,\n ];\n\n if (props.objectId === \"USER\") {\n result.push(\"user_icon\");\n }\n return result;\n };\n\n const handleChange = (newValue: any): void => {\n let selected: any | any[];\n if (mode === \"multiple\") {\n const valueSet = new Set(newValue);\n selected = options.filter((item) => valueSet.has(item.value));\n const oldValueSet = new Set(\n difference(\n newValue,\n (selected as any[]).map((item) => item.value)\n )\n );\n selected = selected.concat(\n selectedOptions.filter((item) => oldValueSet.has(item.value))\n );\n } else {\n selected = options.find((item) => item.value === newValue);\n }\n\n if (blurAfterValueChanged) {\n const selectNodes = document.getElementsByClassName(\n \"formsCmdbInstSelect\"\n );\n for (let i = 0; i < selectNodes.length; i++) {\n selectNodes[i].getElementsByTagName(\"input\")?.[0]?.blur();\n }\n }\n setValue(newValue);\n setSelectedOptions(selected);\n props.onChange && props.onChange(newValue, selected);\n };\n //istanbul ignore else\n const handleSearch = async (\n q: string,\n extraQuery: any,\n forceSearch = false,\n pageSizeQuery?: number\n ): Promise<ComplexOption[]> => {\n if (forceSearch || q.length >= minimumInputLength) {\n try {\n let list = [];\n if (!props.objectId) {\n return [];\n }\n setLoading(true);\n const fieldsQuery = Array.isArray(fields.label)\n ? fields.label\n .filter((label) => !!label)\n .map((label) => ({ [label]: { $like: `%${q}%` } }))\n : fields.label\n ? [{ [fields.label]: { $like: `%${q}%` } }]\n : [];\n const paramQuery = {\n query: {\n $and: [\n {\n $or: [\n ...fieldsQuery,\n ...extraSearchKey.map((key) => ({\n [key]: { $like: `%${q}%` },\n })),\n ],\n },\n\n ...extraQuery,\n ],\n },\n ...(permission ? { permission } : {}),\n fields: computeFields().filter((f): f is string => !!f),\n page: 1,\n page_size: pageSizeQuery || pageSize,\n ignore_missing_field_error: ignoreMissingFieldError,\n sort: props.sort,\n };\n const data = useExternalCmdbApi\n ? await externalPostSearchV3.query([\n {\n ...paramQuery,\n ...externalRequestParams,\n },\n ])\n : await InstanceApi_postSearchV3(props.objectId, paramQuery);\n\n list = data.list;\n setTotal(data.total);\n // 根据用户设置路径显示特定的 label 和 value\n const option = list.map((item: any) => ({\n ...item,\n label: Array.isArray(fields.label)\n ? fields.label.map((label) =>\n label ? get(item, label) : undefined\n )\n : fields.label\n ? get(item, fields.label)\n : undefined,\n value: fields.value ? get(item, fields.value) : undefined,\n ...(props.objectId === \"USER\"\n ? {\n user_icon: get(item, \"user_icon\", \"defaultIcon\"),\n }\n : {}),\n }));\n setOptions(option);\n props.optionsChange?.(option);\n return option;\n } catch (e) {\n handleHttpError(e);\n return [];\n } finally {\n setLoading(false);\n }\n }\n return [];\n };\n const fetchInstanceData = async (): Promise<void> => {\n await handleSearch(\"\", userQuery);\n };\n const getLabelOptions = (op: any) => {\n if (props.labelTemplate) {\n return parseTemplate(props.labelTemplate, op);\n } else {\n const label = op.label;\n if (Array.isArray(label)) {\n const firstKey = label[0];\n const resKey = label.slice(1, label.length).join(\",\");\n if (Array.isArray(firstKey) && props.showKeyField) {\n const subFirstKey = firstKey[0];\n const subResKey = firstKey.slice(1, firstKey.length).join(\",\");\n return subResKey && isMultiLabel\n ? `${subFirstKey}(${subResKey})`\n : (subFirstKey ?? \"\");\n }\n return resKey && isMultiLabel\n ? `${firstKey ?? \" - \"}(${resKey})`\n : (firstKey ?? \"\");\n } else {\n return label;\n }\n }\n };\n\n React.useEffect(() => {\n // 初始化时通过用户的 value 得出首次 label 的值\n // 由于value的不确定性,可能存在首次查询的值不唯一,初始化时也添加instanceQuery\n if (\n props.objectId &&\n !isNil(props.value) &&\n (!isEqual(props.objectId, objectId) || !isEqual(props.value, value))\n ) {\n (async () => {\n const option = await handleSearch(\n \"\",\n [\n {\n [fields.value || \"instanceId\"]: {\n $in: castArray(props.value),\n },\n },\n\n ...userQuery,\n ],\n true,\n props.value?.length >= pageSize ? props.value.length : pageSize\n );\n setSelectedOptions(option);\n })();\n }\n const _value =\n props.mode === \"multiple\" && !trim(props.value) ? [] : props.value;\n setValue(_value);\n setObjectId(props.objectId);\n }, [props.value, props.objectId]);\n\n React.useEffect(() => {\n if (!firstRender) {\n const resetVal: [] | \"\" = mode === \"multiple\" ? [] : \"\";\n setValue(resetVal);\n }\n }, [props.objectId]);\n //istanbul ignore else\n const debounceSearch = debounce(\n (q: string) => handleSearch(q, userQuery),\n 500\n );\n\n return (\n <Select\n ref={ref}\n loading={loading}\n className=\"formsCmdbInstSelect\"\n allowClear={allowClear}\n style={defaults(props.inputBoxStyle, { width: \"100%\" })}\n showSearch\n filterOption={false}\n value={value as SelectValue}\n mode={mode as \"multiple\" | \"tags\"}\n placeholder={placeholder || i18n.t(`${NS}:${K.BACKGROUND_SEARCH}`)}\n onChange={handleChange}\n onSearch={debounceSearch}\n onFocus={fetchInstanceData}\n disabled={props.disabled}\n dropdownStyle={{ padding: \"2px\", ...props.dropdownStyle }}\n dropdownMatchSelectWidth={dropdownMatchSelectWidth}\n dropdownRender={(menu) => {\n return (\n <div>\n {menu}\n {showSearchTip && total > pageSize && (\n <div className={style.moreChoices}>\n 仅显示前{pageSize}项,更多结果请搜索\n </div>\n )}\n </div>\n );\n }}\n {...(props.popoverPositionType === \"parent\"\n ? { getPopupContainer: (triggerNode) => triggerNode.parentElement }\n : { getPopupContainer: props.getPopupContainer })}\n >\n {options.map((op, index) => {\n const optionLabel = getLabelOptions(op);\n return (\n <Select.Option key={index} value={op.value} label={optionLabel}>\n <Tooltip title={props.showTooltip ? optionLabel : undefined}>\n <div className={classNames(style.optionDiv)}>\n {op.user_icon && (\n <span>\n <Avatar\n src={op.user_icon}\n size={24}\n className={classNames(style.avatar, {\n [style.defaultIcon]: op.user_icon === \"defaultIcon\",\n })}\n >\n {op.user_icon === \"defaultIcon\" && op.label?.slice(0, 2)}\n </Avatar>\n </span>\n )}\n <span\n className={classNames(style.optionSpan)}\n data-testid=\"option-label\"\n >\n {optionLabel}\n </span>\n {suffix?.useBrick && (\n <div className={style.suffixContainer}>\n <ReactUseMultipleBricks\n useBrick={suffix.useBrick}\n data={op}\n />\n </div>\n )}\n </div>\n </Tooltip>\n </Select.Option>\n );\n })}\n </Select>\n );\n});\n","export enum K {\n CMDB_INSTANCE_SELECT = \"CMDB_INSTANCE_SELECT\",\n BACKGROUND_SEARCH = \"BACKGROUND_SEARCH\",\n}\n\nconst en: Locale = {\n CMDB_INSTANCE_SELECT: \"CMDB Instance Select\",\n BACKGROUND_SEARCH: \"Input keyword to search\",\n};\n\nconst zh: Locale = {\n CMDB_INSTANCE_SELECT: \"CMDB 实例选择\",\n BACKGROUND_SEARCH: \"输入关键字搜索\",\n};\n\nexport const NS = \"bricks/form-platform/eo-cmdb-instance-select\";\n\nexport const locales = { en, zh };\n\ntype Locale = { [key in K]: string };\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, `.avatar--bjgrCS7c{flex-shrink:0}.avatar--bjgrCS7c.defaultIcon--JzAU3AVW{background-color:#167be0;vertical-align:middle}.moreChoices--NRe_HE2Z{padding:3px 20px;clear:both;font-weight:400;line-height:1.42857143;color:#999;font-style:italic}.optionSpan--RfuLmCys{max-width:100%;overflow:hidden;text-overflow:ellipsis}.optionDiv--NwbSvnDQ{display:flex;align-items:center;gap:6px;min-height:100%}.suffixContainer--T6K_eJyX{margin-left:auto}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"avatar\": `avatar--bjgrCS7c`,\n\t\"defaultIcon\": `defaultIcon--JzAU3AVW`,\n\t\"moreChoices\": `moreChoices--NRe_HE2Z`,\n\t\"optionSpan\": `optionSpan--RfuLmCys`,\n\t\"optionDiv\": `optionDiv--NwbSvnDQ`,\n\t\"suffixContainer\": `suffixContainer--T6K_eJyX`\n};\nexport default ___CSS_LOADER_EXPORT___;\n"],"names":["___CSS_LOADER_EXPORT___","push","module","id","toString","method","property","createDecorators","_A","WeakMap","_B","_C","_D","_E","_F","_G","FormItemElementBase","ReactNextElement","constructor","arguments","_classPrivateFieldInitSpec","_initProto","_init_helpBrick","_init_extra_helpBrick","_init_labelBrick","_init_extra_labelBrick","_init_labelCol","_init_extra_labelCol","_init_wrapperCol","_init_extra_wrapperCol","_notRender","_classPrivateFieldGet","v","_classPrivateFieldSet","validate","bindFormItem","isFormItemElement","validateState","value","this","_render","notRender","hidden","$bindFormItem","helpBrick","labelBrick","labelCol","wrapperCol","setNotRender","getFormElement","element","parentNode","isFormElement","_FormItemElementBase","_applyDecs","attribute","e","FORM_ITEM_PROP_NAMES","pickFormItemProps","props","pick","options","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","undefined","initializeI18n","NS","locales","getInstanceNameKey","objectId","CmdbInstanceSelect","React","ref","showKeyField","fields","label","firstRender","minimumInputLength","extraSearchKey","extraFields","mode","placeholder","allowClear","pageSize","isMultiLabel","showSearchTip","permission","ignoreMissingFieldError","dropdownMatchSelectWidth","blurAfterValueChanged","suffix","useExternalCmdbApi","externalSourceId","userQuery","instanceQuery","arr","Array","isArray","compact","formatUserQuery","setValue","setObjectId","setOptions","selectedOptions","setSelectedOptions","total","setTotal","loading","setLoading","externalPostSearchV3","useProvider","cache","externalRequestParams","useMemo","sourceId","computeFields","result","handleSearch","async","q","extraQuery","pageSizeQuery","length","_props$optionsChange","list","paramQuery","query","$and","$or","filter","map","$like","key","f","page","page_size","ignore_missing_field_error","sort","data","InstanceApi_postSearchV3","option","item","get","user_icon","optionsChange","call","handleHttpError","isNil","isEqual","$in","castArray","_props$value","_value","trim","debounceSearch","debounce","Select","_extends","className","style","defaults","inputBoxStyle","width","showSearch","filterOption","i18n","t","K","BACKGROUND_SEARCH","onChange","newValue","selected","valueSet","Set","has","oldValueSet","difference","concat","find","selectNodes","document","getElementsByClassName","i","_selectNodes$i$getEle","getElementsByTagName","blur","onSearch","onFocus","disabled","dropdownStyle","padding","dropdownRender","menu","moreChoices","popoverPositionType","getPopupContainer","triggerNode","parentElement","op","index","_op$label","optionLabel","labelTemplate","template","skipUndefined","replace","match","parseTemplate","firstKey","resKey","slice","join","subFirstKey","subResKey","getLabelOptions","Option","Tooltip","title","showTooltip","classNames","optionDiv","Avatar","src","size","avatar","defaultIcon","optionSpan","useBrick","suffixContainer","ReactUseMultipleBricks","en","CMDB_INSTANCE_SELECT","zh"],"sourceRoot":""}