@next-bricks/ai-portal 0.1.1 → 0.1.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.
- package/dist/bricks.json +1 -1
- package/dist/chunks/2569.e4658458.js +2 -0
- package/dist/chunks/2569.e4658458.js.map +1 -0
- package/dist/chunks/7039.74886564.js +2 -0
- package/dist/chunks/7039.74886564.js.map +1 -0
- package/dist/chunks/cruise-canvas.9b109fa0.js +2 -0
- package/dist/chunks/cruise-canvas.9b109fa0.js.map +1 -0
- package/dist/chunks/{main.18197352.js → main.b03201e6.js} +2 -2
- package/dist/chunks/{main.18197352.js.map → main.b03201e6.js.map} +1 -1
- package/dist/images/9f5ff403.png +0 -0
- package/dist/{index.0f303e60.js → index.3c536b70.js} +2 -2
- package/dist/{index.0f303e60.js.map → index.3c536b70.js.map} +1 -1
- package/dist-types/cruise-canvas/constants.d.ts +3 -0
- package/dist-types/cruise-canvas/interfaces.d.ts +1 -1
- package/package.json +2 -2
- package/dist/chunks/2569.13ea6d31.js +0 -2
- package/dist/chunks/2569.13ea6d31.js.map +0 -1
- package/dist/chunks/7039.1c9f420a.js +0 -2
- package/dist/chunks/7039.1c9f420a.js.map +0 -1
- package/dist/chunks/cruise-canvas.5203ef3a.js +0 -2
- package/dist/chunks/cruise-canvas.5203ef3a.js.map +0 -1
- package/dist/images/e7d89ec3.png +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/2569.13ea6d31.js","mappings":"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","sources":["webpack:///./src/cruise-canvas/i18n.ts","webpack:///../../../src/utils/calculateAutoSizeStyle.ts","webpack:///../../src/TextareaAutoResize.tsx","webpack:///./src/cruise-canvas/styles.module.css?7c94","webpack:///./src/cruise-canvas/reducers/jobs.ts","webpack:///./src/cruise-canvas/reducers/index.ts","webpack:///./src/cruise-canvas/reducers/task.ts","webpack:///./src/cruise-canvas/reducers/error.ts","webpack:///./src/cruise-canvas/useTaskDetail.ts","webpack:///./src/cruise-canvas/PlanProgress/PlanProgress.module.css?4fe8","webpack:///./src/cruise-canvas/PlanProgress/PlanProgress.tsx","webpack:///./src/cruise-canvas/ZoomBar/ZoomBar.module.css","webpack:///./src/cruise-canvas/NodeRequirement/NodeRequirement.module.css?7927","webpack:///./src/cruise-canvas/NodeRequirement/NodeRequirement.tsx","webpack:///./src/cruise-canvas/PlanProgress/PlanProgress.module.css","webpack:///./src/cruise-canvas/ZoomBar/ZoomBar.module.css?7d53","webpack:///./src/cruise-canvas/ZoomBar/ZoomBar.tsx","webpack:///./src/cruise-canvas/NodeInstruction/NodeInstruction.module.css","webpack:///../../src/rehypePrism.ts","webpack:///../../src/MarkdownComponent.tsx","webpack:///./src/cruise-canvas/cmdb.tsx","webpack:///./src/cruise-canvas/NodeJob/NodeJob.tsx","webpack:///./src/cruise-canvas/bricks.ts","webpack:///./src/cruise-canvas/NodeRequirement/NodeRequirement.module.css","webpack:///./src/cruise-canvas/useAutoCenter.ts","webpack:///./src/cruise-canvas/constants.ts","webpack:///./src/cruise-canvas/NodeInstruction/NodeInstruction.module.css?5e68","webpack:///./src/cruise-canvas/NodeInstruction/NodeInstruction.tsx","webpack:///./src/cruise-canvas/styles.module.css","webpack:///./src/cruise-canvas/NodeEnd/NodeEnd.module.css","webpack:///./src/cruise-canvas/NodeJob/NodeJob.module.css","webpack:///./src/cruise-canvas/useLayout.ts","webpack:///./src/cruise-canvas/NodeStart/NodeStart.module.css?c135","webpack:///./src/cruise-canvas/NodeStart/NodeStart.tsx","webpack:///./src/cruise-canvas/useZoom.ts","webpack:///./src/cruise-canvas/NodeStart/NodeStart.module.css","webpack:///./src/cruise-canvas/NodeEnd/NodeEnd.module.css?bd4b","webpack:///./src/cruise-canvas/NodeEnd/NodeEnd.tsx","webpack:///./src/cruise-canvas/NodeJob/NodeJob.module.css?69ec","webpack:///./src/cruise-canvas/useTaskGraph.ts"],"sourcesContent":["import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n YES = \"YES\",\n NO = \"NO\",\n PLAN_COMPLETED = \"PLAN_COMPLETED\",\n TASK_COMPLETED = \"TASK_COMPLETED\",\n SHARE = \"SHARE\",\n}\n\nconst en: Locale = {\n YES: \"Yes\",\n NO: \"No\",\n PLAN_COMPLETED: \"All jobs done\",\n TASK_COMPLETED: \"Task completed\",\n SHARE: \"Share\",\n};\n\nconst zh: Locale = {\n YES: \"是\",\n NO: \"否\",\n PLAN_COMPLETED: \"所有任务已全部完成\",\n TASK_COMPLETED: \"任务完成\",\n SHARE: \"分享\",\n};\n\nexport const NS = \"bricks/ai-portal/cruise-canvas\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","// istanbul ignore file\nimport type React from \"react\";\n\nconst HIDDEN_TEXTAREA_STYLE = `\n min-height: 0!important;\n max-height: none!important;\n height: 0!important;\n visibility: hidden!important;\n overflow: hidden!important;\n position: absolute!important;\n z-index: -1000!important;\n top: 0!important;\n right: 0!important;\n pointer-events: none!important;\n`;\n\nconst SIZING_STYLE = [\n \"letter-spacing\",\n \"line-height\",\n \"padding-top\",\n \"padding-bottom\",\n \"font-family\",\n \"font-weight\",\n \"font-size\",\n \"font-variant\",\n \"text-rendering\",\n \"text-transform\",\n \"width\",\n \"text-indent\",\n \"padding-left\",\n \"padding-right\",\n \"border-width\",\n \"box-sizing\",\n \"word-break\",\n \"white-space\",\n];\n\nlet hiddenTextarea: HTMLTextAreaElement | undefined;\n\nexport interface AutoSizeOptions {\n minRows?: number | null;\n maxRows?: number | null;\n borderSize?: number;\n paddingSize?: number;\n}\n\n/**\n * 计算 textarea 高度\n * https://github.com/react-component/textarea/blob/1c0026fbe30e5f7dff1fca695b2cf262246381ca/src/calculateNodeHeight.tsx\n */\nexport default function calculateAutoSizeStyle(\n uiTextNode: HTMLTextAreaElement,\n options?: AutoSizeOptions\n): React.CSSProperties {\n const {\n minRows = null,\n maxRows = null,\n borderSize = 2,\n paddingSize = 8,\n } = options ?? {};\n\n if (!hiddenTextarea) {\n hiddenTextarea = document.createElement(\"textarea\");\n hiddenTextarea.setAttribute(\"tab-index\", \"-1\");\n hiddenTextarea.setAttribute(\"aria-hidden\", \"true\");\n document.body.appendChild(hiddenTextarea);\n }\n\n const uiTextNodeStyle = window.getComputedStyle(uiTextNode);\n const sizingStyle = SIZING_STYLE.map(\n (name) => `${name}:${uiTextNodeStyle.getPropertyValue(name)}`\n ).join(\";\");\n\n // equal style\n hiddenTextarea.setAttribute(\n \"style\",\n `${sizingStyle};${HIDDEN_TEXTAREA_STYLE}`\n );\n hiddenTextarea.value = uiTextNode.value || uiTextNode.placeholder || \"\";\n\n let minHeight: number | undefined;\n let maxHeight: number | undefined;\n let overflowY: React.CSSProperties[\"overflowY\"];\n\n let height = hiddenTextarea.scrollHeight + borderSize;\n\n if (minRows !== null || maxRows !== null) {\n const singleRowHeight =\n process.env.NODE_ENV === \"test\"\n ? 22\n : parseFloat(\n window\n .getComputedStyle(hiddenTextarea)\n .getPropertyValue(\"line-height\")\n );\n if (minRows !== null) {\n minHeight = singleRowHeight * minRows + paddingSize + borderSize;\n height = Math.max(minHeight, height);\n }\n if (maxRows !== null) {\n maxHeight = singleRowHeight * maxRows + paddingSize + borderSize;\n if (height <= maxHeight) {\n overflowY = \"hidden\";\n }\n height = Math.min(maxHeight, height);\n }\n }\n\n const style: React.CSSProperties = {\n height,\n overflowY,\n resize: \"none\",\n };\n\n if (minHeight) {\n style.minHeight = minHeight;\n }\n if (maxHeight) {\n style.maxHeight = maxHeight;\n }\n\n return style;\n}\n","import React, {\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from \"react\";\nimport { flushSync } from \"react-dom\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport calculateAutoSizeStyle from \"./utils/calculateAutoSizeStyle.js\";\n\n// istanbul ignore next\nconst modKey = /Mac|iPod|iPhone|iPad/.test(navigator.platform)\n ? \"metaKey\"\n : \"ctrlKey\";\n\nexport interface TextareaAutoResizeProps\n extends React.DetailedHTMLProps<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n HTMLTextAreaElement\n > {\n /** @default true */\n autoResize?: boolean;\n minRows?: number | null;\n maxRows?: number | null;\n /** @default 2 */\n borderSize?: number;\n /** @default 8 */\n paddingSize?: number;\n containerRef?: React.RefObject<HTMLElement>;\n submitWhen?: \"enter-without-shift\" | \"enter-with-mod\";\n}\n\nexport interface TextareaAutoResizeRef {\n focus(): void;\n}\n\nexport const TextareaAutoResize = React.forwardRef<\n TextareaAutoResizeRef,\n TextareaAutoResizeProps\n>(LegacyTextareaAutoResize);\n\nfunction LegacyTextareaAutoResize(\n {\n autoResize: _autoResize,\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n containerRef,\n value: propValue,\n style,\n submitWhen,\n onChange,\n onSubmit,\n onKeyDown,\n onCompositionStart,\n onCompositionEnd,\n ...props\n }: TextareaAutoResizeProps,\n ref: React.ForwardedRef<TextareaAutoResizeRef>\n): React.JSX.Element {\n const autoResize = _autoResize ?? true;\n const [value, setValue] = useState(propValue ?? \"\");\n const textareaRef = useRef<HTMLTextAreaElement>(null);\n const [autoStyle, setAutoStyle] = useState<React.CSSProperties | null>(null);\n\n useImperativeHandle(\n ref,\n () => ({\n focus: () => {\n const textarea = textareaRef.current;\n // istanbul ignore else: defensive check\n if (textarea) {\n const valueLength = textarea.value?.length;\n textarea.focus();\n valueLength && textarea.setSelectionRange(valueLength, valueLength);\n }\n },\n }),\n []\n );\n\n const doAutoResize = useCallback(() => {\n const textarea = textareaRef.current;\n if (textarea && autoResize) {\n const style = calculateAutoSizeStyle(textarea, {\n minRows,\n maxRows,\n borderSize,\n paddingSize,\n });\n // istanbul ignore next\n if (process.env.NODE_ENV === \"test\") {\n setAutoStyle(style);\n } else {\n flushSync(() => {\n setAutoStyle(style);\n });\n }\n }\n }, [autoResize, maxRows, minRows, borderSize, paddingSize]);\n\n const handleInputChange = (\n e: React.ChangeEvent<HTMLTextAreaElement>\n ): void => {\n setValue(e.target.value);\n onChange?.(e);\n };\n\n useEffect(() => {\n setValue(propValue ?? \"\");\n }, [propValue]);\n\n useEffect(() => {\n doAutoResize();\n }, [doAutoResize, value]);\n\n const compositionRef = useRef(false);\n\n const handleCompositionStart = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = true;\n onCompositionStart?.(e);\n },\n [onCompositionStart]\n );\n\n const handleCompositionEnd = useCallback(\n (e: React.CompositionEvent<HTMLTextAreaElement>) => {\n compositionRef.current = false;\n onCompositionEnd?.(e);\n },\n [onCompositionEnd]\n );\n\n const handleKeyDown = useCallback(\n (e: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (compositionRef.current) {\n // Ignore key events during composition\n return;\n }\n\n if (\n e.key === \"Enter\" &&\n (submitWhen === \"enter-without-shift\"\n ? !e.shiftKey\n : submitWhen === \"enter-with-mod\" && e[modKey])\n ) {\n e.preventDefault();\n e.stopPropagation();\n onSubmit?.(e);\n }\n\n onKeyDown?.(e);\n },\n [onKeyDown, onSubmit, submitWhen]\n );\n\n // istanbul ignore next\n useEffect(() => {\n const container = containerRef?.current;\n if (!container || !autoResize) {\n return;\n }\n let previousInlineSize: number | undefined;\n const observer = new ResizeObserver((entries) => {\n for (const entry of entries) {\n if (entry.target === container) {\n // istanbul ignore next: compatibility\n const currentInlineSize = entry.contentBoxSize\n ? entry.contentBoxSize[0]\n ? entry.contentBoxSize[0].inlineSize\n : (entry.contentBoxSize as unknown as ResizeObserverSize)\n .inlineSize\n : entry.contentRect.width;\n if (\n currentInlineSize !== undefined &&\n currentInlineSize !== previousInlineSize\n ) {\n const isInitial = !previousInlineSize;\n previousInlineSize = currentInlineSize;\n if (!isInitial) {\n requestAnimationFrame(doAutoResize);\n }\n }\n }\n }\n });\n observer.observe(container);\n return () => {\n observer.disconnect();\n };\n }, [autoResize, containerRef, doAutoResize]);\n\n return (\n <textarea\n {...props}\n ref={textareaRef}\n value={value}\n style={{\n ...style,\n ...autoStyle,\n }}\n onChange={handleInputChange}\n onCompositionStart={handleCompositionStart}\n onCompositionEnd={handleCompositionEnd}\n onKeyDown={handleKeyDown}\n />\n );\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]!./styles.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]!./styles.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","import type { Reducer } from \"react\";\nimport { isEqual, isMatchWith, pick } from \"lodash\";\nimport type { Job, JobPatch, Message, Part, TextPart } from \"../interfaces\";\nimport type { CruiseCanvasAction } from \"./interfaces\";\n\nexport const jobs: Reducer<Job[], CruiseCanvasAction> = (state, action) => {\n switch (action.type) {\n case \"sse\": {\n const jobsPatch = action.payload.jobs;\n let jobs = action.isInitial ? [] : state;\n\n if (!Array.isArray(jobsPatch) || jobsPatch.length === 0) {\n return jobs;\n }\n\n for (const jobPatch of jobsPatch) {\n // TODO(): remove temp work around.\n // if (!jobPatch.upstream?.length) {\n // delete jobPatch.upstream;\n // }\n // if (!jobPatch.parent) {\n // delete jobPatch.parent;\n // }\n // if (!jobPatch.state) {\n // delete jobPatch.state;\n // }\n // if (!jobPatch.instruction) {\n // delete jobPatch.instruction;\n // }\n\n if ((jobPatch as any).state === \"blocked\") {\n jobPatch.state = \"working\";\n }\n\n const previousJobIndex =\n jobs?.findIndex((job) => job.id === jobPatch.id) ?? -1;\n const { messages: messagesPatch, toolCall } = jobPatch;\n\n if (typeof toolCall?.arguments === \"string\") {\n try {\n jobPatch.toolCall!.arguments = JSON.parse(toolCall.arguments);\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error(\"Failed to parse toolCall arguments\", e);\n jobPatch.toolCall!.arguments = {};\n jobPatch.toolCall!.argumentsParseFailed = true;\n jobPatch.toolCall!.argumentsParseError = e;\n }\n }\n\n if (previousJobIndex === -1) {\n if (Array.isArray(messagesPatch) && messagesPatch.length > 0) {\n jobs = [\n ...jobs,\n {\n ...jobPatch,\n messages: mergeMessages(messagesPatch),\n } as Job,\n ];\n } else {\n jobs = [...jobs, jobPatch as Job];\n }\n } else {\n const previousJob = jobs[previousJobIndex];\n const restMessagesPatch: JobPatch = pick(jobPatch, [\n \"id\",\n \"upstream\",\n \"parent\",\n \"state\",\n \"instruction\",\n \"toolCall\",\n \"isError\",\n \"startTime\",\n \"endTime\",\n ]);\n if (Array.isArray(messagesPatch) && messagesPatch.length > 0) {\n restMessagesPatch.messages = mergeMessages([\n ...(previousJob.messages ?? []),\n ...messagesPatch,\n ]);\n }\n if (!isMatchWith(previousJob, restMessagesPatch, isEqual)) {\n jobs = [\n ...jobs.slice(0, previousJobIndex),\n {\n ...previousJob,\n ...restMessagesPatch,\n },\n ...jobs.slice(previousJobIndex + 1),\n ];\n }\n }\n }\n\n return jobs;\n }\n\n case \"reset\": {\n return state.length === 0 ? state : [];\n }\n }\n\n return state;\n};\n\nfunction mergeMessages(messages: Message[]): Message[] {\n const merged: Message[] = [];\n let previousRole: Message[\"role\"] | undefined;\n for (const message of messages) {\n if (!previousRole || previousRole !== message.role) {\n merged.push({ ...message });\n } else {\n const lastMessage = merged[merged.length - 1];\n lastMessage.parts = [...lastMessage.parts, ...message.parts];\n }\n previousRole = message.role;\n }\n\n for (const message of merged) {\n message.parts = mergeMessageParts(message.parts);\n }\n\n return merged;\n}\n\nfunction mergeMessageParts(parts: Part[]): Part[] {\n const merged: Part[] = [];\n let previousType: Part[\"type\"] | undefined;\n for (const part of parts) {\n if (!previousType || previousType !== part.type || part.type !== \"text\") {\n merged.push({ ...part });\n } else {\n const lastPart = merged[merged.length - 1] as TextPart;\n lastPart.text += part.text;\n }\n previousType = part.type;\n }\n return merged;\n}\n","import { Reducer } from \"react\";\nimport type { CruiseCanvasAction, CruiseCanvasState } from \"./interfaces\";\nimport { jobs } from \"./jobs\";\nimport { task } from \"./task\";\nimport { error } from \"./error\";\n\ntype ReducersMapObject<S, A> = {\n [K in keyof S]: Reducer<S[K], A>;\n};\n\nfunction combineReducers<S, A>(\n reducers: ReducersMapObject<S, A>\n): Reducer<S, A> {\n return ((state, action) =>\n Object.fromEntries(\n Object.entries<Reducer<any, A>>(reducers).map(([key, value]) => [\n key,\n value(state[key as keyof S], action),\n ])\n )) as Reducer<S, A>;\n}\n\nexport const rootReducer = combineReducers<\n CruiseCanvasState,\n CruiseCanvasAction\n>({\n task,\n jobs,\n error,\n});\n","import type { Reducer } from \"react\";\nimport { isEqual, isMatchWith, pick } from \"lodash\";\nimport type { TaskBaseDetail } from \"../interfaces\";\nimport type { CruiseCanvasAction } from \"./interfaces\";\n\nexport const task: Reducer<TaskBaseDetail | null, CruiseCanvasAction> = (\n state,\n action\n) => {\n switch (action.type) {\n case \"sse\": {\n const taskPatch = pick(action.payload, [\n \"id\",\n \"requirement\",\n \"state\",\n \"startTime\",\n \"endTime\",\n \"plan\",\n ]);\n\n // TODO(): remove temp work around.\n // if (!taskPatch.requirement) {\n // delete taskPatch.requirement;\n // }\n // if (!taskPatch.state) {\n // delete taskPatch.state;\n // }\n\n if ((taskPatch as any).state === \"blocked\") {\n taskPatch.state = \"working\";\n }\n\n return (\n action.isInitial\n ? taskPatch\n : state && isMatchWith(state, taskPatch, isEqual)\n ? state\n : { ...state, ...taskPatch }\n ) as TaskBaseDetail;\n }\n\n case \"reset\": {\n return null;\n }\n }\n return state;\n};\n","import type { Reducer } from \"react\";\nimport type { CruiseCanvasAction } from \"./interfaces\";\n\nexport const error: Reducer<string | null, CruiseCanvasAction> = (\n state,\n action\n) => {\n switch (action.type) {\n case \"sse\": {\n const error = action.payload.error;\n return state === null && typeof error === \"string\" ? error : state;\n }\n\n case \"reset\": {\n return null;\n }\n }\n\n return state;\n};\n","// istanbul ignore file\nimport { useEffect, useReducer, useRef, useState } from \"react\";\nimport { isEqual } from \"lodash\";\nimport { HttpResponseError } from \"@next-core/http\";\nimport { createSSEStream } from \"@next-core/utils/general\";\nimport { getBasePath, handleHttpError } from \"@next-core/runtime\";\nimport { rootReducer } from \"./reducers\";\nimport type { Job, StepWithState, TaskPatch } from \"./interfaces\";\n\nexport function useTaskDetail(taskId: string | undefined) {\n const [{ task, jobs, error }, dispatch] = useReducer(\n rootReducer,\n null,\n () => ({\n task: null,\n jobs: [],\n error: null,\n })\n );\n\n const humanInputRef = useRef<(jobId: string, input: string) => void>();\n\n useEffect(() => {\n dispatch({ type: \"reset\" });\n humanInputRef.current = undefined;\n if (!taskId) {\n return;\n }\n\n let ignore = false;\n let requesting = false;\n let ctrl: AbortController | undefined;\n\n const makeRequest = async () => {\n if (requesting) {\n return;\n }\n\n requesting = true;\n ctrl = new AbortController();\n try {\n const request = await createSSEStream<TaskPatch>(\n `${getBasePath()}api/gateway/logic.llm.aiops_service/api/v1/llm/agent/flow/${taskId}`,\n // `/api/mocks/task/get?${new URLSearchParams({ id: taskId })}`\n // `http://localhost:8888/.netlify/functions/task-get?${new URLSearchParams({ id: taskId })}`\n // `https://serverless-mocks.netlify.app/.netlify/functions/task-get?${new URLSearchParams({ id: taskId })}`\n {\n signal: ctrl.signal,\n }\n );\n const stream = await request;\n let isInitial = true;\n for await (const value of stream) {\n if (ignore) {\n requesting = false;\n return;\n }\n\n dispatch({ type: \"sse\", payload: value, isInitial });\n isInitial = false;\n }\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error(\"sse failed\", e);\n handleHttpError(e);\n } finally {\n requesting = false;\n }\n };\n\n humanInputRef.current = async (jobId: string, input: string) => {\n const response = await fetch(\n `${getBasePath()}api/gateway/logic.llm.aiops_service/api/v1/llm/agent/flow/${taskId}/job/${jobId}`,\n // `/api/mocks/task/input`,\n // `http://localhost:8888/.netlify/functions/task-input`,\n // `https://serverless-mocks.netlify.app/.netlify/functions/task-input`,\n {\n method: \"POST\",\n headers: {\n \"Content-Type\": \"application/json\",\n },\n body: JSON.stringify({\n id: taskId,\n jobId: jobId,\n input,\n }),\n }\n );\n if (response.ok) {\n makeRequest();\n } else {\n // eslint-disable-next-line no-console\n console.error(\n \"human input failed\",\n response.status,\n response.statusText\n );\n\n let responseJson;\n try {\n responseJson = await response.json();\n } catch {\n // Do nothing.\n }\n handleHttpError(new HttpResponseError(response, responseJson));\n }\n };\n\n makeRequest();\n\n return () => {\n ignore = true;\n ctrl?.abort();\n };\n }, [taskId]);\n\n const [plan, setPlan] = useState<StepWithState[]>([]);\n\n useEffect(() => {\n setPlan((prev) => {\n const jobMap = new Map<string, Job>();\n const childrenMap = new Map<string, string[]>();\n for (const job of jobs) {\n jobMap.set(job.id, job);\n\n if (job.parent) {\n childrenMap.set(job.parent, [\n ...(childrenMap.get(job.parent) ?? []),\n job.id,\n ]);\n }\n }\n\n // A step is input-required when itself is input-required or any of its descendants is input-required.\n const isInputRequired = (job: Job): boolean => {\n return (\n job.state === \"input-required\" ||\n !!childrenMap.get(job.id)?.some((childId) => {\n const childJob = jobMap.get(childId)!;\n return isInputRequired(childJob);\n })\n );\n };\n\n const plan: StepWithState[] = [];\n for (const step of task?.plan ?? []) {\n const job = jobMap.get(step.id);\n plan.push({\n id: step.id,\n instruction: step.instruction,\n state: job\n ? isInputRequired(job)\n ? \"input-required\"\n : job.state\n : undefined,\n });\n }\n\n return isEqual(prev, plan) ? prev : plan;\n });\n }, [jobs, task?.plan]);\n\n return { task, jobs, plan, error, humanInputRef };\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]!./PlanProgress.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]!./PlanProgress.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React, { useCallback, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\nimport styles from \"./PlanProgress.module.css\";\nimport type { JobState, StepWithState } from \"../interfaces\";\nimport { WrappedIcon } from \"../bricks\";\nimport { K, t } from \"../i18n\";\n\nexport interface PlanProgressProps {\n plan?: StepWithState[];\n}\n\ninterface PlanProgressStat {\n doneCount: number;\n instruction: string;\n state: JobState | undefined;\n}\n\nexport function PlanProgress({ plan }: PlanProgressProps): JSX.Element | null {\n const [expanded, setExpanded] = useState(false);\n\n const { doneCount, state, instruction } = useMemo(() => {\n return (plan ?? []).reduce<PlanProgressStat>(\n (acc, step) => {\n if (step.state === \"completed\") {\n return {\n ...acc,\n state: step.state,\n doneCount: acc.doneCount + 1,\n };\n } else if (\n !acc.instruction ||\n (step.state && step.state !== \"unknown\")\n ) {\n return {\n ...acc,\n state: step.state,\n instruction: step.instruction,\n };\n }\n return acc;\n },\n {\n doneCount: 0,\n state: \"unknown\",\n instruction: \"\",\n }\n );\n }, [plan]);\n\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state);\n }, [state]);\n\n const toggle = useCallback(() => {\n setExpanded((prev) => !prev);\n }, []);\n\n if (!plan?.length) {\n return null;\n }\n\n return (\n <div className={classNames(styles.progress, className)} onClick={toggle}>\n <div className={styles.icon}>\n <WrappedIcon {...icon} />\n </div>\n <span\n className={styles.text}\n title={state === \"completed\" ? \"\" : instruction}\n >\n {state === \"completed\" ? t(K.PLAN_COMPLETED) : instruction}\n </span>\n <span className={styles.stat}>\n {doneCount}/{plan.length}\n </span>\n <WrappedIcon\n className={styles.expand}\n lib=\"antd\"\n theme=\"outlined\"\n icon={expanded ? \"down\" : \"up\"}\n />\n {expanded && (\n <ul className={styles.details} onClick={(e) => e.stopPropagation()}>\n {plan.map((step, index) => (\n <PlanStep\n key={index}\n state={step.state}\n instruction={step.instruction}\n />\n ))}\n </ul>\n )}\n </div>\n );\n}\n\ninterface PlanStepProps {\n state?: JobState;\n instruction: string;\n}\n\nfunction PlanStep({ state, instruction }: PlanStepProps) {\n const { className, icon } = useMemo(() => {\n return getClassNameAndIconProps(state);\n }, [state]);\n\n return (\n <li className={styles.step}>\n <WrappedIcon {...icon} className={classNames(styles.state, className)} />\n <span className={styles.instruction} title={instruction}>\n {instruction}\n </span>\n </li>\n );\n}\n\nfunction getClassNameAndIconProps(state: JobState | undefined) {\n switch (state) {\n case \"completed\":\n return {\n className: styles.completed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"check\",\n },\n };\n case \"submitted\":\n case \"working\":\n return {\n className: styles.working,\n icon: {\n lib: \"antd\",\n theme: \"outlined\",\n icon: \"loading-3-quarters\",\n spinning: true,\n },\n };\n case \"input-required\":\n return {\n className: styles[\"input-required\"],\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-pause\",\n },\n };\n case \"failed\":\n return {\n className: styles.failed,\n icon: {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"xmark\",\n },\n };\n case \"canceled\":\n return {\n className: styles.canceled,\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"circle-stop\",\n },\n };\n default:\n return {\n icon: {\n lib: \"fa\",\n prefix: \"far\",\n icon: \"clock\",\n },\n };\n }\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.zoom-bar--MTw5VGPl{position:absolute;left:20px;bottom:20px;display:flex;align-items:center;padding:4px 6px;-webkit-user-select:none;user-select:none;background:rgba(255,255,255,0.7);box-shadow:0px 3px 14px 0px rgba(0,0,0,0.1),0px 1px 4px 0px rgba(0,0,0,0.06);border-radius:8px;border:1px solid rgba(255,255,255,0.3)}.zoom-bar--MTw5VGPl button{background:transparent;border:none;border-radius:4px;color:#333;width:24px;height:24px;font-size:16px;line-height:16px;display:flex;align-items:center;justify-content:center;cursor:pointer}.zoom-bar--MTw5VGPl button:hover{background:rgba(0,0,0,0.04)}.zoom-bar--MTw5VGPl button:active{background:rgba(0,0,0,0.08)}.divider--S0X2YCDi{background:rgba(0,0,0,0.15);width:1px;height:16px}.zoom-bar--MTw5VGPl > :not(:last-child){margin-right:6px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"zoom-bar\": `zoom-bar--MTw5VGPl`,\n\t\"divider\": `divider--S0X2YCDi`\n};\nexport default ___CSS_LOADER_EXPORT___;\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]!./NodeRequirement.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]!./NodeRequirement.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React, { useMemo } from \"react\";\nimport { wrapBrick } from \"@next-core/react-element\";\nimport { auth } from \"@next-core/easyops-runtime\";\nimport type {\n EoEasyopsAvatar,\n EoEasyopsAvatarProps,\n} from \"@next-bricks/basic/easyops-avatar\";\nimport moment from \"moment\";\nimport styles from \"./NodeRequirement.module.css\";\n\nconst WrappedEasyOpsAvatar = wrapBrick<EoEasyopsAvatar, EoEasyopsAvatarProps>(\n \"eo-easyops-avatar\"\n);\n\nexport interface NodeRequirementProps {\n content?: string;\n startTime?: number;\n loading?: boolean;\n}\n\nexport function NodeRequirement({\n content,\n startTime,\n loading,\n}: NodeRequirementProps): JSX.Element {\n const username = useMemo(() => {\n return auth.getAuth().username;\n }, []);\n\n return (\n <div className={styles[\"node-requirement\"]}>\n <div className={styles.heading}>\n <div className={styles.user}>\n <WrappedEasyOpsAvatar\n nameOrInstanceId={username}\n showName\n size=\"xs\"\n />\n </div>\n <div className={styles.time}>\n {startTime && moment(startTime * 1000).format(\"MM-DD HH:mm\")}\n </div>\n </div>\n <div className={styles.body}>{content}</div>\n {loading && (\n <>\n <svg\n className={styles[\"loading-line\"]}\n viewBox=\"0 0 2 62\"\n width=\"2\"\n height=\"62\"\n >\n <path d=\"M1 0 L1 62\" />\n </svg>\n <div className={styles.loading}>\n <div className={styles.inner} />\n </div>\n </>\n )}\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.progress--62eOnxaf{position:absolute;bottom:20px;left:50%;transform:translate(-50%,0);width:453px;max-width:80%;background:#ffffff;box-shadow:0px 6px 16px 0px rgba(0,0,0,0.08),0px 3px 6px -4px rgba(0,0,0,0.12);border-radius:12px;padding:12px;line-height:24px;cursor:pointer;display:flex;align-items:center}.icon--TMLJniSx{margin-right:6px;width:22px;height:22px;border-radius:22px;display:flex;align-items:center;justify-content:center;background:linear-gradient(222deg,#abaab7 25%,#fff 75%);color:#4e4d56;font-size:12px;text-shadow:0px 1px 1px #fff}.progress--62eOnxaf.completed--ACUTqxl7 .icon--TMLJniSx{background:linear-gradient(222deg,#16c661 25%,#fff 75%);color:#055527}.progress--62eOnxaf.failed--atS7ek2B .icon--TMLJniSx{background:linear-gradient(222deg,#f24c25 25%,#fff 75%);color:#5b1504}.progress--62eOnxaf.working--Z6W16jVj .icon--TMLJniSx{background:linear-gradient(222deg,#3e56ff 25%,#fff 75%);color:#0c165d}.progress--62eOnxaf.input-required--YhWlEgu0 .icon--TMLJniSx{background:linear-gradient(222deg,#12aacc 25%,#fff 75%);color:#0c353e}.progress--62eOnxaf.canceled--imA9nfyy .icon--TMLJniSx{background:linear-gradient(222deg,#fcaa07 25%,#fff 75%);color:#302206}.text--vZYOZzn1,\n.instruction--Z7riLyFL{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0;flex:1}.stat--YsJ88cZz{margin-left:auto;color:#8c8c8c}.expand--gqn8QEnc{margin-left:6px;color:#8c8c8c}.details--rtuqBzKj{position:absolute;left:0;right:0;bottom:4em;background:#fff;border-radius:12px;box-shadow:0px 6px 16px 0px rgba(0,0,0,0.08),0px 3px 6px -4px rgba(0,0,0,0.12);list-style:none;margin:0;padding:12px;cursor:auto}.step--f9i49Db2{display:flex;align-items:center}.step--f9i49Db2:not(:last-child){margin-bottom:8px}.state--TmkD_q3_{margin-right:6px;color:var(--text-color-secondary)}.state--TmkD_q3_.completed--ACUTqxl7{color:var(--color-success)}.state--TmkD_q3_.failed--atS7ek2B{color:var(--color-error)}.state--TmkD_q3_.working--Z6W16jVj{color:var(--color-info)}.state--TmkD_q3_.input-required--YhWlEgu0{color:var(--palette-cyan-7)}.state--TmkD_q3_.canceled--imA9nfyy{color:#fcaa07}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"progress\": `progress--62eOnxaf`,\n\t\"icon\": `icon--TMLJniSx`,\n\t\"completed\": `completed--ACUTqxl7`,\n\t\"failed\": `failed--atS7ek2B`,\n\t\"working\": `working--Z6W16jVj`,\n\t\"input-required\": `input-required--YhWlEgu0`,\n\t\"canceled\": `canceled--imA9nfyy`,\n\t\"text\": `text--vZYOZzn1`,\n\t\"instruction\": `instruction--Z7riLyFL`,\n\t\"stat\": `stat--YsJ88cZz`,\n\t\"expand\": `expand--gqn8QEnc`,\n\t\"details\": `details--rtuqBzKj`,\n\t\"step\": `step--f9i49Db2`,\n\t\"state\": `state--TmkD_q3_`\n};\nexport default ___CSS_LOADER_EXPORT___;\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]!./ZoomBar.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]!./ZoomBar.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React, { useCallback } from \"react\";\nimport styles from \"./ZoomBar.module.css\";\nimport { WrappedIcon } from \"../bricks\";\n\nexport interface ZoomBarProps {\n scale: number;\n onScaleChange?: (scale: number) => void;\n onReCenter?: () => void;\n}\n\nexport function ZoomBar({\n scale,\n onScaleChange,\n onReCenter,\n}: ZoomBarProps): JSX.Element {\n const handleZoomIn = useCallback(() => {\n onScaleChange?.(scale + 0.1);\n }, [onScaleChange, scale]);\n\n const handleZoomOut = useCallback(() => {\n onScaleChange?.(scale - 0.1);\n }, [onScaleChange, scale]);\n\n return (\n <div className={styles[\"zoom-bar\"]}>\n <button onClick={onReCenter}>\n <WrappedIcon lib=\"fa\" prefix=\"fas\" icon=\"expand\" />\n </button>\n <div className={styles.divider}></div>\n <button onClick={handleZoomOut}>\n <WrappedIcon lib=\"antd\" theme=\"outlined\" icon=\"minus-circle\" />\n </button>\n <button onClick={handleZoomIn}>\n <WrappedIcon lib=\"antd\" theme=\"outlined\" icon=\"plus-circle\" />\n </button>\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.node-instruction--Gu7k6RDs{max-width:437px;background:rgba(255,255,255,0.2);box-shadow:0px 4px 10px 0px rgba(54,64,80,0.08);border-radius:9999px;border:1px solid rgba(255,255,255,0.284);padding:6px 16px;color:rgba(0,0,0,0.45)}.text--jsSeLl7B{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading--KdGolqAK > .text--jsSeLl7B{color:transparent;background:linear-gradient(to right,rgba(0,0,0,0.45) 0%,rgba(0,0,0,0.45) 40%,rgba(220,220,220,1) 50%,rgba(0,0,0,0.45) 60%,rgba(0,0,0,0.45) 100%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;animation:shineEffect--Zn2JtRpU 2s infinite linear}@keyframes shineEffect--Zn2JtRpU{0%{background-position:-50% 50%}100%{background-position:-250% 50%}}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"node-instruction\": `node-instruction--Gu7k6RDs`,\n\t\"text\": `text--jsSeLl7B`,\n\t\"loading\": `loading--KdGolqAK`,\n\t\"shineEffect\": `shineEffect--Zn2JtRpU`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import { visit } from \"unist-util-visit\";\nimport { toString } from \"hast-util-to-string\";\nimport { refractor, type RefractorElement } from \"refractor\";\n\n// Reference https://github.com/mapbox/rehype-prism\nexport function rehypePrism() {\n function visitor(\n node: RefractorElement,\n _index: number | undefined,\n parent: RefractorElement | undefined\n ) {\n if (!parent || parent.tagName !== \"pre\" || node.tagName !== \"code\") {\n return;\n }\n\n const lang = getLanguage(node);\n\n if (lang === null) {\n return;\n }\n\n let result;\n try {\n parent.properties.className = (\n (parent.properties.className as string[]) || []\n ).concat(\"language-\" + lang);\n result = refractor.highlight(toString(node), lang);\n } catch {\n return;\n }\n\n node.children = result.children;\n }\n return (tree: RefractorElement) => {\n visit(tree, \"element\", visitor);\n };\n}\n\nfunction getLanguage(node: RefractorElement) {\n const className = (node.properties.className as string[]) || [];\n\n for (const classListItem of className) {\n if (classListItem.slice(0, 9) === \"language-\") {\n return classListItem.slice(9).toLowerCase();\n }\n }\n\n return null;\n}\n","import { useEffect, useState } from \"react\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nimport { unified } from \"unified\";\nimport remarkParse from \"remark-parse\";\nimport remarkToRehype from \"remark-rehype\";\nimport rehypeReact, { Options as RehypeReactOptions } from \"rehype-react\";\nimport { rehypePrism } from \"./rehypePrism.js\";\n\nconst production = { Fragment, jsx, jsxs };\n\nexport interface MarkdownComponentProps {\n content?: string;\n}\n\n// Reference https://github.com/remarkjs/react-remark/blob/39553e5f5c9e9b903bebf261788ff45130668de0/src/index.ts\nexport function MarkdownComponent({ content }: MarkdownComponentProps) {\n const [reactContent, setReactContent] = useState<JSX.Element | null>(null);\n\n useEffect(() => {\n let ignore = false;\n unified()\n .use(remarkParse)\n .use(remarkToRehype)\n .use([rehypePrism])\n .use(rehypeReact, production as RehypeReactOptions)\n .process(content)\n .then((vFile) => {\n if (!ignore) {\n setReactContent(vFile.result);\n }\n })\n .catch((error) => {\n if (!ignore) {\n // eslint-disable-next-line no-console\n console.error(\"Convert markdown failed:\", error);\n setReactContent(null);\n }\n });\n return () => {\n ignore = true;\n };\n }, [content]);\n\n return reactContent;\n}\n","import React from \"react\";\nimport { asyncWrapBrick } from \"@next-core/react-runtime\";\n\ninterface CMDBSelectProps {\n objectId?: string | null;\n fieldId?: string | null;\n objectList?: any[] | null;\n}\n\ninterface CMDBSelectEvents {\n \"cmdb.instance.form.change.v2\": CustomEvent<any[]>;\n}\n\ninterface CMDBSelectEvensMapping {\n onChangeV2: \"cmdb.instance.form.change.v2\";\n}\n\nexport const AsyncWrappedCMDB = React.lazy(async () => ({\n default: await asyncWrapBrick<\n HTMLElement,\n CMDBSelectProps,\n CMDBSelectEvents,\n CMDBSelectEvensMapping\n >(\"cmdb-instances.cmdb-instances-input-form\", {\n onChangeV2: \"cmdb.instance.form.change.v2\",\n }),\n}));\n","// istanbul ignore file: experimental\nimport React, { Suspense, useEffect, useMemo, useRef, useState } from \"react\";\nimport { MarkdownComponent } from \"@next-shared/markdown\";\nimport { TextareaAutoResize } from \"@next-shared/form\";\nimport { CmdbObjectApi_getObjectRef } from \"@next-api-sdk/cmdb-sdk\";\nimport classNames from \"classnames\";\nimport moment from \"moment\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport styles from \"./NodeJob.module.css\";\nimport type { Job } from \"../interfaces\";\nimport { K, t } from \"../i18n.js\";\nimport { AsyncWrappedCMDB } from \"../cmdb.js\";\nimport { WrappedButton, WrappedIcon } from \"../bricks.js\";\n\nexport interface NodeJobProps {\n job: Job;\n state?: string;\n humanInput?: (jobId: string, input: string) => void;\n}\n\nexport function NodeJob({ job, state, humanInput }: NodeJobProps): JSX.Element {\n const askUser = job.toolCall?.name === \"ask_human\";\n const knownAskUser =\n askUser &&\n [\n \"ask_user_more\",\n \"ask_user_confirm\",\n \"ask_user_choose\",\n \"ask_user_select_from_cmdb\",\n ].includes(job.toolCall!.arguments?.command as string);\n\n return (\n <div\n className={classNames(styles[\"node-job\"], {\n [styles.error]: job.isError,\n [styles[\"ask-user\"]]: knownAskUser,\n })}\n >\n <div className={styles.heading}>\n {job.toolCall ? (\n <>\n {askUser ? (\n <WrappedIcon\n className={styles.icon}\n lib=\"fa\"\n prefix=\"fas\"\n icon=\"person-circle-question\"\n />\n ) : (\n <WrappedIcon\n className={styles.icon}\n lib=\"antd\"\n theme=\"outlined\"\n icon=\"tool\"\n />\n )}\n <div className={styles.tool}>{job.toolCall?.name}</div>\n </>\n ) : (\n <>\n <WrappedIcon className={styles.icon} lib=\"easyops\" icon=\"robot\" />\n </>\n )}\n <div className={styles.time}>\n {job.startTime && moment(job.startTime * 1000).format(\"MM-DD HH:mm\")}\n </div>\n </div>\n <div className={styles.body}>\n {knownAskUser ? (\n <>\n <div className={`${styles.message} ${styles[\"role-assistant\"]}`}>\n <MarkdownComponent\n content={job.toolCall!.arguments?.question as string}\n />\n </div>\n {state === \"input-required\" &&\n (job.toolCall!.arguments!.command === \"ask_user_more\" ? (\n <HumanInputComponent jobId={job.id} humanInput={humanInput} />\n ) : job.toolCall!.arguments!.command === \"ask_user_confirm\" ? (\n <HumanConfirmComponent\n jobId={job.id}\n humanInput={humanInput}\n confirmText={job.toolCall!.arguments!.confirm_text as string}\n cancelText={job.toolCall!.arguments!.cancel_text as string}\n />\n ) : job.toolCall!.arguments!.command === \"ask_user_choose\" ? (\n <HumanChooseComponent\n jobId={job.id}\n humanInput={humanInput}\n options={job.toolCall!.arguments!.options as string[]}\n />\n ) : job.toolCall!.arguments!.command ===\n \"ask_user_select_from_cmdb\" ? (\n <HumanSelectFromCmdb\n jobId={job.id}\n humanInput={humanInput}\n objectId={job.toolCall!.arguments!.objectId as string}\n attrId={job.toolCall!.arguments!.attrId as string}\n />\n ) : null)}\n </>\n ) : askUser ? (\n <div className={`${styles.message} ${styles[\"role-assistant\"]}`}>\n Unexpected ask_human command:{\" \"}\n {JSON.stringify(job.toolCall!.arguments?.command ?? null)}\n </div>\n ) : null}\n {job.messages?.map((message, index) => (\n <div\n key={index}\n className={classNames(styles.message, {\n [styles[\"role-user\"]]: message.role === \"tool\" && askUser,\n })}\n >\n {message.parts?.map((part, partIndex) => (\n <React.Fragment key={partIndex}>\n {part.type === \"text\" ? (\n message.role === \"tool\" && askUser ? (\n part.text\n ) : (\n <RefineMarkdownComponent\n content={part.text}\n isToolOutput={\n message.role === \"tool\" && !!job.toolCall && !askUser\n }\n />\n )\n ) : part.type === \"file\" ? (\n <div>{part.file.name}</div>\n ) : (\n <div>{JSON.stringify(part.data)}</div>\n )}\n </React.Fragment>\n ))}\n </div>\n ))}\n </div>\n </div>\n );\n}\n\nfunction HumanInputComponent({\n jobId,\n humanInput,\n}: {\n jobId: string;\n humanInput?: (jobId: string, input: string) => void;\n}): JSX.Element {\n const containerRef = useRef<HTMLDivElement>(null);\n\n return (\n <div /* className=\"node-ask-user-more size-medium\" */ ref={containerRef}>\n {/* <div className=\"message\">\n <MarkdownComponent content={node.content} />\n </div> */}\n <TextareaAutoResize\n className={styles[\"human-input\"]}\n containerRef={containerRef}\n autoResize\n minRows={2}\n paddingSize={14}\n placeholder=\"Type your message here...\"\n submitWhen=\"enter-without-shift\"\n onSubmit={(e) => {\n const input = e.currentTarget.value;\n if (input) {\n humanInput?.(jobId, input);\n }\n }}\n />\n </div>\n );\n}\n\nfunction HumanConfirmComponent({\n jobId,\n humanInput,\n confirmText,\n cancelText,\n}: {\n jobId: string;\n confirmText?: string;\n cancelText?: string;\n humanInput?: (jobId: string, input: string) => void;\n}): JSX.Element {\n return (\n <div style={{ marginTop: \"1em\" }}>\n <WrappedButton\n type=\"primary\"\n onClick={() => {\n humanInput?.(jobId, confirmText || t(K.YES));\n }}\n >\n {confirmText || t(K.YES)}\n </WrappedButton>\n <WrappedButton\n onClick={() => {\n humanInput?.(jobId, cancelText || t(K.NO));\n }}\n style={{ marginLeft: \"0.5em\" }}\n >\n {cancelText || t(K.NO)}\n </WrappedButton>\n </div>\n );\n}\n\nfunction HumanChooseComponent({\n jobId,\n options,\n humanInput,\n}: {\n jobId: string;\n options?: string[];\n humanInput?: (jobId: string, input: string) => void;\n}): JSX.Element {\n return (\n <div\n style={{\n marginTop: \"1em\",\n display: \"flex\",\n flexDirection: \"column\",\n gap: \"0.5em\",\n }}\n >\n {options?.map((option, index) => (\n <WrappedButton\n key={index}\n onClick={() => {\n humanInput?.(jobId, option);\n }}\n >\n {option}\n </WrappedButton>\n ))}\n </div>\n );\n}\n\nfunction HumanSelectFromCmdb({\n jobId,\n objectId,\n attrId,\n humanInput,\n}: {\n jobId: string;\n objectId?: string;\n attrId?: string;\n humanInput?: (jobId: string, input: string) => void;\n}): JSX.Element {\n const [objectList, setObjectList] = useState<any[] | null>(null);\n\n useEffect(() => {\n if (!objectId) {\n return;\n }\n let ignore = false;\n (async () => {\n try {\n const objects = (\n await CmdbObjectApi_getObjectRef({ ref_object: objectId })\n ).data;\n if (!ignore) {\n setObjectList(objects);\n }\n } catch (e) {\n // eslint-disable-next-line no-console\n console.error(\"Fetch object list failed:\", e);\n handleHttpError(e);\n }\n })();\n return () => {\n ignore = true;\n };\n }, [objectId]);\n\n if (!objectId) {\n return (\n <div style={{ marginTop: \"1em\" }}>\n Can not call ask_user_select_from_cmdb without objectId\n </div>\n );\n }\n // if (!objectId || !attrId) {\n // return <div style={{ marginTop: \"1em\" }}>Can not call ask_user_select_from_cmdb without {!objectId ? \"objectId\" : \"attrId\"}</div>;\n // }\n\n const fieldId =\n !attrId || (attrId === \"instanceId\" && objectId === \"HOST\") ? \"ip\" : attrId;\n\n return (\n <div style={{ marginTop: \"1em\" }}>\n <Suspense>\n <AsyncWrappedCMDB\n objectList={objectList}\n objectId={objectId}\n fieldId={fieldId}\n onChangeV2={(e) => {\n humanInput?.(\n jobId,\n e.detail.map((i) => i[fieldId /* ?? \"instanceId\" */]).join(\"\\n\")\n );\n }}\n />\n </Suspense>\n </div>\n );\n}\n\nfunction RefineMarkdownComponent({\n content,\n isToolOutput,\n}: {\n content?: string;\n isToolOutput?: boolean;\n}): JSX.Element {\n const refinedContent = useMemo(() => {\n if (isToolOutput) {\n try {\n const json = JSON.parse(content ?? \"\");\n return `${\"```json\\n\"}${JSON.stringify(json, null, 2)}${\"\\n```\"}`;\n } catch {\n // Do nothing.\n }\n }\n return content;\n }, [content, isToolOutput]);\n\n return <MarkdownComponent content={refinedContent} />;\n}\n","import { wrapBrick } from \"@next-core/react-element\";\nimport type {\n GeneralIcon,\n GeneralIconProps,\n} from \"@next-bricks/icons/general-icon\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\n\nexport const WrappedIcon = wrapBrick<GeneralIcon, GeneralIconProps>(\"eo-icon\");\n\nexport const WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../images/requirement@2x.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.node-requirement--aVjY3LFY{width:453px;background-color:rgba(255,255,255,0.4);background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-position:center bottom;background-size:453px 128px;background-repeat:no-repeat;box-shadow:0px 4px 10px 0px rgba(54,64,80,0.18);border-radius:12px;-webkit-backdrop-filter:blur(28px);backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,0.4);padding:8px;white-space:pre-wrap;position:relative}.heading--F8b1aIJT{display:flex;justify-content:space-between;align-items:center;margin-bottom:11px;font-size:12px}.time--IRwoiblW{color:#8c8c8c}.body--JYv_r9n_{background:#f1f6ff;box-shadow:0px 1px 0px 0px #ffffff;border-radius:9px;padding:15px 10px}.loading-line--xDrsXoxu{position:absolute;bottom:-62px;left:50%;transform:translate(-50%,0)}.loading-line--xDrsXoxu path{fill:none;stroke-width:2px;stroke:rgba(255,255,255,0.6);stroke-dasharray:5,5}.loading--yZvyv4wE{position:absolute;bottom:-74px;left:50%;transform:translate(-50%,0);width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:rgba(69,94,255,0.5);border-radius:24px;animation:loading--yZvyv4wE 1s infinite linear}.inner--voOHXPcc{width:12px;height:12px;background:rgb(69,94,255);border-radius:12px}@keyframes loading--yZvyv4wE{0%{transform:translate(-50%,0) scale(1);opacity:1}100%{transform:translate(-50%,0) scale(1.5);opacity:0}}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"node-requirement\": `node-requirement--aVjY3LFY`,\n\t\"heading\": `heading--F8b1aIJT`,\n\t\"time\": `time--IRwoiblW`,\n\t\"body\": `body--JYv_r9n_`,\n\t\"loading-line\": `loading-line--xDrsXoxu`,\n\t\"loading\": `loading--yZvyv4wE`,\n\t\"inner\": `inner--voOHXPcc`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import { useEffect, useRef, useState, type RefObject } from \"react\";\nimport { ZoomTransform, type ZoomBehavior } from \"d3-zoom\";\nimport { select } from \"d3-selection\";\nimport type { GraphNode } from \"./interfaces\";\nimport { CANVAS_PADDING_BOTTOM } from \"./constants\";\n\nexport interface UseAutoCenterOptions {\n nodes: GraphNode[];\n sizeReady: boolean;\n zoomer: ZoomBehavior<HTMLDivElement, unknown>;\n rootRef: RefObject<HTMLDivElement>;\n}\n\nexport function useAutoCenter({\n nodes,\n sizeReady,\n zoomer,\n rootRef,\n}: UseAutoCenterOptions) {\n const [centered, setCentered] = useState(false);\n const reCenterRef = useRef(false);\n\n // Transform to horizontal center once.\n useEffect(() => {\n const root = rootRef.current;\n if (sizeReady && root && !centered && nodes.length > 0) {\n let left = Infinity;\n let right = -Infinity;\n let top = Infinity;\n let bottom = -Infinity;\n\n for (const node of nodes) {\n const view = node.view!;\n const r = view.x + view.width;\n const b = view.y + view.height;\n if (view.x < left) {\n left = view.x;\n }\n if (r > right) {\n right = r;\n }\n if (view.y < top) {\n top = view.y;\n }\n if (b > bottom) {\n bottom = b;\n }\n }\n\n const x = (root.clientWidth - (right + left)) / 2;\n let y = 30;\n if (reCenterRef.current) {\n const height = bottom - top + CANVAS_PADDING_BOTTOM;\n const diffY = height - root.clientHeight;\n if (diffY > 0) {\n y = -diffY - top;\n } else {\n y = (root.clientHeight - (bottom + top)) / 2;\n }\n }\n\n zoomer.transform(select(root), new ZoomTransform(1, x, y));\n setCentered(true);\n }\n\n reCenterRef.current = false;\n }, [centered, nodes, rootRef, sizeReady, zoomer]);\n\n return { centered, setCentered, reCenterRef };\n}\n","import { JobState } from \"./interfaces.js\";\n\nexport const DEFAULT_SCALE_RANGE_MIN = 0.5;\nexport const DEFAULT_SCALE_RANGE_MAX = 2;\nexport const START_NODE_ID = \"<START>\";\nexport const END_NODE_ID = \"<END>\";\nexport const CANVAS_PADDING_BOTTOM = 96;\n\nexport const DONE_STATES = [\"completed\", \"failed\", \"canceled\"] as JobState[];\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]!./NodeInstruction.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]!./NodeInstruction.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React from \"react\";\nimport classNames from \"classnames\";\nimport styles from \"./NodeInstruction.module.css\";\n\nexport interface NodeInstructionProps {\n content?: string;\n loading?: boolean;\n}\n\nexport function NodeInstruction({\n content,\n loading,\n}: NodeInstructionProps): JSX.Element {\n return (\n <div\n className={classNames(styles[\"node-instruction\"], {\n [styles.loading]: loading,\n })}\n >\n <div className={styles.text} title={content}>\n {content}\n </div>\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"./images/background@2x.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `ai-portal\\\\.cruise-canvas{display:block;position:relative;width:100%;height:100%;overflow:hidden;background-color:rgb(205,206,207);background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:cover;background-repeat:no-repeat;background-position:center;color:#262626;--cruise-canvas-node-border:1px solid gray;--cruise-canvas-node-width-medium:380px;--cruise-canvas-node-width-large:764px;--cruise-canvas-primary-color:#2540ff}.root--z6jdb_BU{width:100%;height:100%;position:relative}.widgets--r6lUPOu2{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;-webkit-user-select:none;user-select:none}.widgets--r6lUPOu2 > *{pointer-events:auto;-webkit-user-select:text;user-select:text}.canvas--u6C26uH_,\n.edges--uNPQGWZg{width:100%;height:100%;position:absolute;transform-origin:0% 0%;-webkit-user-select:none;user-select:none}.node--IBGywwp4{position:absolute;-webkit-user-select:text;user-select:text;cursor:auto}.node--IBGywwp4:not(.ready--pmh440go),\n.canvas--u6C26uH_:not(.ready--pmh440go) > .edges--uNPQGWZg{visibility:hidden}svg.edges--uNPQGWZg{pointer-events:none;overflow:visible}.edge--muRUWYG1{fill:none;stroke-width:2px;stroke:rgba(255,255,255,0.6);stroke-dasharray:5,5}.size-medium--s_5BfbCV,\n.size-large--GFdstz_s{border:var(--cruise-canvas-node-border);border-radius:6px;padding:6px}.size-medium--s_5BfbCV{width:var(--cruise-canvas-node-width-medium)}.size-large--GFdstz_s{width:var(--cruise-canvas-node-width-large)}.node-default--rfA_zOid{border:var(--cruise-canvas-node-border)}.node-default--rfA_zOid > :first-child{margin-top:0}.node-default--rfA_zOid > :last-child{margin-bottom:0}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"root\": `root--z6jdb_BU`,\n\t\"widgets\": `widgets--r6lUPOu2`,\n\t\"canvas\": `canvas--u6C26uH_`,\n\t\"edges\": `edges--uNPQGWZg`,\n\t\"node\": `node--IBGywwp4`,\n\t\"ready\": `ready--pmh440go`,\n\t\"edge\": `edge--muRUWYG1`,\n\t\"size-medium\": `size-medium--s_5BfbCV`,\n\t\"size-large\": `size-large--GFdstz_s`,\n\t\"node-default\": `node-default--rfA_zOid`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../images/end@2x.png\", import.meta.url);\nvar ___CSS_LOADER_URL_IMPORT_1___ = new URL(\"../images/completed@2x.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\nvar ___CSS_LOADER_URL_REPLACEMENT_1___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_1___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.node-end--yzRaOZnC{width:330px;background-color:#fff;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:330px 271px;background-repeat:no-repeat;background-position:center;border:1px solid #e0e5f0;border-radius:12px;display:flex;flex-direction:column;align-items:center;padding:41px 24px 28px}.icon--IVcHjGFO{width:64px;height:64px;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_1___});background-size:59px 49px;background-repeat:no-repeat;background-position:center;margin-bottom:16px}.title--ESn4jaJ9{margin-bottom:8px;font-weight:500;font-size:16px;line-height:24px}.description--aYl8sq6S{margin-bottom:36px;font-size:13px;color:#8c8c8c;line-height:24px}.button--mkIwsPzt{width:120px;height:30px;background:rgba(0,0,0,0.04);border:none;border-radius:15px;text-align:center;cursor:pointer}.button--mkIwsPzt:hover{background:rgba(0,0,0,0.08)}.button--mkIwsPzt:active{background:rgba(0,0,0,0.15)}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"node-end\": `node-end--yzRaOZnC`,\n\t\"icon\": `icon--IVcHjGFO`,\n\t\"title\": `title--ESn4jaJ9`,\n\t\"description\": `description--aYl8sq6S`,\n\t\"button\": `button--mkIwsPzt`\n};\nexport default ___CSS_LOADER_EXPORT___;\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, `.node-job--soTYrcA7{width:330px;background:linear-gradient(180deg,#f5f8ff 0%,#edf0f9 100%);box-shadow:0px 4px 10px 0px rgba(177,149,207,0.4),0px 2px 4px 0px rgba(0,0,0,0.06);border-radius:12px;border:1px solid #ffffff;padding:8px}.error--IwtdD0T6{outline-offset:4px;outline:2px solid var(--color-error)}.heading--GZqrhPqL{display:flex;align-items:center;border-bottom:1px solid #e2e2ec;padding:0 5px 5px;font-size:12px;color:#8c8c8c}.icon--Rb_vveHN{margin-right:6px}.time--eHXSEjt6{margin-left:auto}.body--V34MsV9R{padding:16px 4px 8px;max-height:392px;overflow-y:auto}.message--iVQBlD6k{overflow-wrap:break-word}.message--iVQBlD6k + .message--iVQBlD6k{margin-top:1em}.message--iVQBlD6k p{margin:1em 0}.message--iVQBlD6k > :first-child{margin-top:0}.message--iVQBlD6k > :last-child{margin-bottom:0}.ask-user--lf925zGf .heading--GZqrhPqL{border-bottom:none}.ask-user--lf925zGf .body--V34MsV9R{padding-top:8px}.role-assistant--Y8vd9Oms,\n.role-user--nAW4Hzsu{background:rgba(255,255,255,0.8);border-radius:9px;border:1px solid #ccd1de;padding:6px 16px}.role-user--nAW4Hzsu{white-space:pre-wrap}.human-input--wFc6ovnT{margin-top:1em;display:block;width:100%;padding:0.5em 1em;color:var(--antd-input-color);background:rgba(255,255,255,0.8);box-shadow:0px 1px 0px 0px #ffffff,inset 0px 2px 4px 0px #b3bcf9;box-sizing:border-box;border:1px solid var(--antd-input-border-color);border-radius:9px;font-size:14px;line-height:22px;height:32px}.human-input--wFc6ovnT:not(:disabled):hover{border:1px solid var(--antd-input-hover-border-color)}.human-input--wFc6ovnT:not(:disabled):focus{border:1px solid var(--antd-input-focus-border-color);outline:0;box-shadow:0 0 0 2px rgb(0 113 235/20%)}.human-input--wFc6ovnT::placeholder{color:var(--antd-input-placeholder-color)}.message--iVQBlD6k code[class*=\"language-\"],.message--iVQBlD6k pre[class*=\"language-\"]{background:hsl(230,1%,98%);color:hsl(230,8%,24%);font-family:\"Fira Code\",\"Fira Mono\",Menlo,Consolas,\"DejaVu Sans Mono\",monospace;direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;line-height:1.5;-moz-tab-size:2;tab-size:2;-webkit-hyphens:none;hyphens:none;font-size:13px}.message--iVQBlD6k code[class*=\"language-\"]::selection,.message--iVQBlD6k code[class*=\"language-\"] *::selection,.message--iVQBlD6k pre[class*=\"language-\"] *::selection{background:hsl(230,1%,90%);color:inherit}.message--iVQBlD6k pre[class*=\"language-\"]{padding:1em;margin:0.5em 0;overflow:auto;border-radius:9px}.message--iVQBlD6k :not(pre) > code[class*=\"language-\"]{padding:0.2em 0.3em;border-radius:9px;white-space:normal}.message--iVQBlD6k .token.comment,.message--iVQBlD6k .token.prolog,.message--iVQBlD6k .token.cdata{color:hsl(230,4%,64%)}.message--iVQBlD6k .token.doctype,.message--iVQBlD6k .token.punctuation,.message--iVQBlD6k .token.entity{color:hsl(230,8%,24%)}.message--iVQBlD6k .token.attr-name,.message--iVQBlD6k .token.class-name,.message--iVQBlD6k .token.boolean,.message--iVQBlD6k .token.constant,.message--iVQBlD6k .token.number,.message--iVQBlD6k .token.atrule{color:hsl(35,99%,36%)}.message--iVQBlD6k .token.keyword{color:hsl(301,63%,40%)}.message--iVQBlD6k .token.property,.message--iVQBlD6k .token.tag,.message--iVQBlD6k .token.symbol,.message--iVQBlD6k .token.deleted,.message--iVQBlD6k .token.important{color:hsl(5,74%,59%)}.message--iVQBlD6k .token.selector,.message--iVQBlD6k .token.string,.message--iVQBlD6k .token.char,.message--iVQBlD6k .token.builtin,.message--iVQBlD6k .token.inserted,.message--iVQBlD6k .token.regex,.message--iVQBlD6k .token.attr-value,.message--iVQBlD6k .token.attr-value > .token.punctuation{color:hsl(119,34%,47%)}.message--iVQBlD6k .token.variable,.message--iVQBlD6k .token.operator,.message--iVQBlD6k .token.function{color:hsl(221,87%,60%)}.message--iVQBlD6k .token.url{color:hsl(198,99%,37%)}.message--iVQBlD6k .token.attr-value > .token.punctuation.attr-equals,.message--iVQBlD6k .token.special-attr > .token.attr-value > .token.value.css{color:hsl(230,8%,24%)}.message--iVQBlD6k .language-css .token.selector{color:hsl(5,74%,59%)}.message--iVQBlD6k .language-css .token.property{color:hsl(230,8%,24%)}.message--iVQBlD6k .language-css .token.function,.message--iVQBlD6k .language-css .token.url > .token.function{color:hsl(198,99%,37%)}.message--iVQBlD6k .language-css .token.url > .token.string.url{color:hsl(119,34%,47%)}.message--iVQBlD6k .language-css .token.important,.message--iVQBlD6k .language-css .token.atrule .token.rule{color:hsl(301,63%,40%)}.message--iVQBlD6k .language-javascript .token.operator{color:hsl(301,63%,40%)}.message--iVQBlD6k .language-javascript .token.template-string > .token.interpolation > .token.interpolation-punctuation.punctuation{color:hsl(344,84%,43%)}.message--iVQBlD6k .language-json .token.operator{color:hsl(230,8%,24%)}.message--iVQBlD6k .language-json .token.null.keyword{color:hsl(35,99%,36%)}.message--iVQBlD6k .language-markdown .token.url,.message--iVQBlD6k .language-markdown .token.url > .token.operator,.message--iVQBlD6k .language-markdown .token.url-reference.url > .token.string{color:hsl(230,8%,24%)}.message--iVQBlD6k .language-markdown .token.url > .token.content{color:hsl(221,87%,60%)}.message--iVQBlD6k .language-markdown .token.url > .token.url,.message--iVQBlD6k .language-markdown .token.url-reference.url{color:hsl(198,99%,37%)}.message--iVQBlD6k .language-markdown .token.blockquote.punctuation,.message--iVQBlD6k .language-markdown .token.hr.punctuation{color:hsl(230,4%,64%);font-style:italic}.message--iVQBlD6k .language-markdown .token.code-snippet{color:hsl(119,34%,47%)}.message--iVQBlD6k .language-markdown .token.bold .token.content{color:hsl(35,99%,36%)}.message--iVQBlD6k .language-markdown .token.italic .token.content{color:hsl(301,63%,40%)}.message--iVQBlD6k .language-markdown .token.strike .token.content,.message--iVQBlD6k .language-markdown .token.strike .token.punctuation,.message--iVQBlD6k .language-markdown .token.list.punctuation,.message--iVQBlD6k .language-markdown .token.title.important > .token.punctuation{color:hsl(5,74%,59%)}.message--iVQBlD6k .token.bold{font-weight:bold}.message--iVQBlD6k .token.comment,.message--iVQBlD6k .token.italic{font-style:italic}.message--iVQBlD6k .token.entity{cursor:help}.message--iVQBlD6k .token.namespace{opacity:0.8}.node-job--soTYrcA7 *::-webkit-scrollbar{width:5px;height:5px;background:transparent}.node-job--soTYrcA7 *::-webkit-scrollbar-thumb{background-color:#d8d8d8;border-radius:3px}.node-job--soTYrcA7 *::-webkit-scrollbar-track{background:transparent}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"node-job\": `node-job--soTYrcA7`,\n\t\"error\": `error--IwtdD0T6`,\n\t\"heading\": `heading--GZqrhPqL`,\n\t\"icon\": `icon--Rb_vveHN`,\n\t\"time\": `time--eHXSEjt6`,\n\t\"body\": `body--V34MsV9R`,\n\t\"message\": `message--iVQBlD6k`,\n\t\"ask-user\": `ask-user--lf925zGf`,\n\t\"role-assistant\": `role-assistant--Y8vd9Oms`,\n\t\"role-user\": `role-user--nAW4Hzsu`,\n\t\"human-input\": `human-input--wFc6ovnT`\n};\nexport default ___CSS_LOADER_EXPORT___;\n","import dagre from \"@dagrejs/dagre\";\nimport { useMemo, useRef } from \"react\";\nimport type {\n NodePosition,\n NodeView,\n GraphEdge,\n GraphNode,\n SizeTuple,\n TaskState,\n} from \"./interfaces\";\nimport { END_NODE_ID, START_NODE_ID } from \"./constants\";\n\nexport interface UseLayoutOptions {\n rawNodes: GraphNode[] | undefined;\n rawEdges: GraphEdge[] | undefined;\n sizeMap: Map<string, SizeTuple> | null;\n state?: TaskState;\n}\n\nexport function useLayout({\n rawNodes: _rawNodes,\n rawEdges: _rawEdges,\n sizeMap,\n state,\n}: UseLayoutOptions) {\n const memoizedPositionsRef = useRef<Map<string, NodePosition> | null>(null);\n const completed = state === \"completed\";\n\n const { initialNodes, initialEdges } = useMemo(() => {\n const initialNodes: GraphNode[] = [\n {\n type: \"start\",\n id: START_NODE_ID,\n },\n ];\n const initialEdges: GraphEdge[] = [];\n const finishedNodeIds: string[] = [];\n const rawNodes = _rawNodes ?? [];\n const rawEdges = _rawEdges ?? [];\n\n const hasSource = new Set<string>(rawEdges.map((edge) => edge.target));\n const hasTarget = completed\n ? new Set<string>(rawEdges.map((edge) => edge.source))\n : null;\n\n for (const node of rawNodes) {\n if (!hasSource.has(node.id)) {\n initialEdges.push({\n source: START_NODE_ID,\n target: node.id,\n });\n }\n\n if (completed && !hasTarget!.has(node.id)) {\n finishedNodeIds.push(node.id);\n }\n }\n\n initialNodes.push(...rawNodes);\n initialEdges.push(...rawEdges);\n\n if (finishedNodeIds.length > 0) {\n initialNodes.push({\n id: END_NODE_ID,\n type: \"end\",\n });\n initialEdges.push(\n ...finishedNodeIds.map((id) => ({\n source: id,\n target: END_NODE_ID,\n }))\n );\n }\n\n const memoizedPositions = memoizedPositionsRef.current;\n if (memoizedPositions) {\n for (const node of initialNodes) {\n const view = memoizedPositions.get(node.id);\n if (view) {\n node.view = view as NodeView;\n }\n }\n }\n\n return { initialNodes, initialEdges };\n }, [completed, _rawEdges, _rawNodes]);\n\n const startNodePositionRef = useRef<NodePosition | null>(null);\n\n return useMemo(() => {\n for (const node of initialNodes) {\n if (!sizeMap?.has(node.id)) {\n return { sizeReady: false, nodes: initialNodes, edges: [] };\n }\n }\n\n const graph = new dagre.graphlib.Graph();\n graph.setGraph({\n rankdir: \"TB\",\n nodesep: 50,\n edgesep: 10,\n ranksep: 50,\n });\n // Default to assigning a new object as a label for each new edge.\n graph.setDefaultEdgeLabel(function () {\n return {};\n });\n for (const edge of initialEdges) {\n graph.setEdge(edge.source, edge.target);\n }\n for (const node of initialNodes) {\n const [width, height] = sizeMap!.get(node.id)!;\n graph.setNode(node.id, {\n id: node.id,\n width,\n height,\n });\n }\n dagre.layout(graph);\n\n // Make the start node position unchanged\n let offsets: NodePosition | null = null;\n\n const nodes = initialNodes.map<GraphNode>((node) => {\n const nodeView = graph.node(node.id);\n const x = nodeView.x - nodeView.width / 2;\n const y = nodeView.y - nodeView.height / 2;\n\n if (node.type === \"start\") {\n if (startNodePositionRef.current) {\n offsets = {\n x: startNodePositionRef.current.x - x,\n y: startNodePositionRef.current.y - y,\n };\n } else {\n startNodePositionRef.current = { x, y };\n }\n }\n\n return {\n ...node,\n view: {\n x,\n y,\n width: nodeView.width,\n height: nodeView.height,\n },\n };\n });\n\n if (offsets) {\n for (const node of nodes) {\n Object.assign(node.view!, getPositionWithOffsets(node.view!, offsets));\n }\n }\n\n const memoizedPositions = (memoizedPositionsRef.current ??= new Map());\n for (const node of nodes) {\n const { x, y } = node.view!;\n memoizedPositions.set(node.id, { x, y });\n }\n\n const edges = initialEdges.map((edge) => {\n const source = graph.node(edge.source);\n const sourcePosition = getPositionWithOffsets(source, offsets);\n const target = graph.node(edge.target);\n const targetPosition = getPositionWithOffsets(target, offsets);\n // const turnY =\n // (sourcePosition.y +\n // source.height / 2 +\n // targetPosition.y -\n // target.height / 2) /\n // 2;\n const turnY = targetPosition.y - target.height / 2 - 25;\n const points: NodePosition[] = [\n { x: sourcePosition.x, y: sourcePosition.y + source.height / 2 },\n { x: sourcePosition.x, y: turnY },\n { x: targetPosition.x, y: turnY },\n { x: targetPosition.x, y: targetPosition.y - target.height / 2 },\n ];\n\n return {\n ...edge,\n points,\n };\n });\n\n return {\n sizeReady: true,\n nodes,\n edges,\n };\n }, [initialEdges, initialNodes, sizeMap]);\n}\n\nfunction getPositionWithOffsets<T extends NodePosition>(\n position: T,\n offsets: NodePosition | null\n): NodePosition {\n if (!offsets) {\n return {\n x: position.x,\n y: position.y,\n };\n }\n return {\n x: position.x + offsets.x,\n y: position.y + offsets.y,\n };\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]!./NodeStart.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]!./NodeStart.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React from \"react\";\nimport styles from \"./NodeStart.module.css\";\n\nexport function NodeStart(): JSX.Element {\n return (\n <div className={styles[\"node-start\"]}>\n <div className={styles.icon} />\n </div>\n );\n}\n","// istanbul ignore file: hard to test with d3-zoom\nimport React, { useEffect, useMemo, useRef, useState } from \"react\";\nimport { select } from \"d3-selection\";\nimport { zoom, type ZoomBehavior } from \"d3-zoom\";\nimport type {\n RangeTuple,\n TransformLiteral /* , ActiveTarget */,\n} from \"./interfaces\";\nimport { DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX } from \"./constants\";\n// import type { ActiveTarget } from \"./interfaces\";\nimport jobStyles from \"./NodeJob/NodeJob.module.css\";\n\nexport interface UseZoomOptions {\n rootRef: React.RefObject<HTMLDivElement>;\n zoomable?: boolean;\n scrollable?: boolean;\n pannable?: boolean;\n pannableWithCtrl?: boolean;\n scaleRange?: RangeTuple;\n onSwitchActiveTarget?(target: unknown | null): void;\n}\n\nexport interface UseZoomResult {\n grabbing: boolean;\n transform: TransformLiteral;\n transformRef: React.MutableRefObject<TransformLiteral>;\n scaleRange: RangeTuple;\n zoomer: ZoomBehavior<HTMLDivElement, unknown>;\n}\n\n// istanbul ignore next\nconst isMac = /mac/i.test(\n (\n navigator as Navigator & {\n userAgentData?: {\n platform: string;\n };\n }\n ).userAgentData?.platform ??\n navigator.platform ??\n navigator.userAgent\n);\n\n// istanbul ignore next\nfunction wheelData(event: WheelEvent) {\n // On Windows with normal mouse, deltaY is too big when scroll with ctrlKey pressed,\n // which cause the zooming too fast.\n // While on mac OS, we need to keep default behavior of d3-zoom.\n return (\n -event.deltaY *\n (event.deltaMode === 1 ? 0.05 : event.deltaMode ? 1 : 0.002) *\n (event.ctrlKey && isMac ? 10 : 1)\n );\n}\n\nexport function useZoom({\n rootRef,\n zoomable,\n scrollable,\n pannable,\n pannableWithCtrl,\n scaleRange: _scaleRange,\n onSwitchActiveTarget,\n}: UseZoomOptions): UseZoomResult {\n const [grabbing, setGrabbing] = useState(false);\n const [transform, setTransform] = useState<TransformLiteral>({\n k: 1,\n x: 0,\n y: 0,\n });\n const transformRef = useRef(transform);\n\n const scaleRange = useMemo(\n () =>\n _scaleRange ??\n ([DEFAULT_SCALE_RANGE_MIN, DEFAULT_SCALE_RANGE_MAX] as RangeTuple),\n [_scaleRange]\n );\n\n const zoomer = useMemo(\n () => zoom<HTMLDivElement, unknown>().wheelDelta(wheelData),\n []\n );\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n let moved = false;\n zoomer\n .scaleExtent(zoomable ? scaleRange : [1, 1])\n .on(\"start\", () => {\n moved = false;\n setGrabbing(true);\n })\n .on(\"zoom\", (e: { transform: TransformLiteral }) => {\n moved = true;\n setTransform(e.transform);\n transformRef.current = e.transform;\n })\n .on(\"end\", () => {\n setGrabbing(false);\n if (!moved) {\n onSwitchActiveTarget?.(null);\n }\n })\n .filter(\n (event) =>\n (event.type === \"wheel\" ||\n (pannableWithCtrl ? pannable || event.ctrlKey : !event.ctrlKey)) &&\n !event.button\n );\n }, [\n onSwitchActiveTarget,\n scaleRange,\n zoomable,\n zoomer,\n pannableWithCtrl,\n pannable,\n ]);\n\n useEffect(() => {\n if (pannableWithCtrl) {\n const onContextMenu = (e: MouseEvent) => {\n if (e.ctrlKey) {\n e.preventDefault();\n }\n };\n document.addEventListener(\"contextmenu\", onContextMenu, true);\n return () => {\n document.removeEventListener(\"contextmenu\", onContextMenu, true);\n };\n }\n }, [pannableWithCtrl]);\n\n // istanbul ignore next: d3-zoom currently hard to test\n useEffect(() => {\n const root = rootRef.current;\n if (!root) {\n return;\n }\n\n const rootSelection = select(root);\n\n const unsetZoom = () => {\n rootSelection\n .on(\".zoom\", null)\n .on(\".zoom.custom\", null)\n .on(\"wheel\", null);\n };\n\n if (!(zoomable || scrollable || pannable)) {\n unsetZoom();\n return;\n }\n\n if (zoomable || scrollable) {\n // Do not override default d3 zoom handler.\n // Only handles *panning*\n rootSelection.on(\n \"wheel.zoom.custom\",\n (e: WheelEvent & { wheelDeltaX: number; wheelDeltaY: number }) => {\n // Mac OS trackpad pinch event is emitted as a wheel.zoom and d3.event.ctrlKey set to true\n if (!e.ctrlKey) {\n // Stop immediate propagation for default d3 zoom handler\n e.stopImmediatePropagation();\n if (scrollable) {\n const pre = (e.target as HTMLElement)!.closest(\n 'pre[class*=\"language-\"]'\n );\n if (pre) {\n if (checkScrollableX(pre, e.deltaX)) {\n return;\n }\n }\n\n const node = (e.target as HTMLElement)!.closest(\n `.${jobStyles.body}`\n );\n if (node) {\n if (checkScrollableY(node, e.deltaY)) {\n return;\n }\n }\n\n if (e.cancelable) {\n e.preventDefault();\n zoomer.translateBy(\n rootSelection,\n e.wheelDeltaX / 5,\n e.wheelDeltaY / 5\n );\n }\n }\n }\n // zoomer.scaleBy(rootSelection, Math.pow(2, defaultWheelDelta(e)))\n }\n );\n }\n\n rootSelection\n .call(zoomer)\n .on(\"wheel\", (e: WheelEvent) => {\n e.preventDefault();\n })\n .on(\"dblclick.zoom\", null);\n\n if (!pannable && !pannableWithCtrl) {\n rootSelection.on(\"mousedown.zoom\", null);\n }\n\n if (!pannable) {\n rootSelection\n .on(\"touchstart.zoom\", null)\n .on(\"touchmove.zoom\", null)\n .on(\"touchend.zoom\", null);\n }\n\n return unsetZoom;\n }, [pannableWithCtrl, pannable, rootRef, scrollable, zoomable, zoomer]);\n\n return { grabbing, transform, transformRef, zoomer, scaleRange };\n}\n\n// 检查元素是否还能滚动\nfunction checkScrollableY(element: Element, delta: number) {\n const isScrollingDown = delta > 0;\n // 还能向下滚动 或 还能向上滚动\n if (isScrollingDown) {\n const maxScroll = element.scrollHeight - element.clientHeight;\n return element.scrollTop <= maxScroll - 1;\n }\n return element.scrollTop >= 1;\n}\n\n// 检查元素是否还能滚动\nfunction checkScrollableX(element: Element, delta: number) {\n const isScrollingRight = delta > 0; // Updated variable name for clarity\n // 还能向右滚动 或 还能向左滚动\n if (isScrollingRight) {\n const maxScroll = element.scrollWidth - element.clientWidth; // Changed to scrollWidth and clientWidth\n return element.scrollLeft <= maxScroll - 1; // Changed to scrollLeft\n }\n return element.scrollLeft >= 1;\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/api.js\";\nimport ___CSS_LOADER_GET_URL_IMPORT___ from \"../../../../../node_modules/css-loader/dist/runtime/getUrl.js\";\nvar ___CSS_LOADER_URL_IMPORT_0___ = new URL(\"../images/start@2x.png\", import.meta.url);\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\nvar ___CSS_LOADER_URL_REPLACEMENT_0___ = ___CSS_LOADER_GET_URL_IMPORT___(___CSS_LOADER_URL_IMPORT_0___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `.node-start--Mrh1iP5r{width:65px;height:65px;position:relative;overflow:visible}.icon--NxC4u6Wl{width:75px;height:75px;background-image:url(${___CSS_LOADER_URL_REPLACEMENT_0___});background-size:75px 75px;background-repeat:no-repeat;background-position:center;position:absolute;left:-5px;top:-1px}`, \"\"]);\n// Exports\n___CSS_LOADER_EXPORT___.locals = {\n\t\"node-start\": `node-start--Mrh1iP5r`,\n\t\"icon\": `icon--NxC4u6Wl`\n};\nexport default ___CSS_LOADER_EXPORT___;\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]!./NodeEnd.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]!./NodeEnd.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file: experimental\nimport React from \"react\";\nimport styles from \"./NodeEnd.module.css\";\nimport { K, t } from \"../i18n\";\n\nexport interface NodeEndProps {\n onShare?: () => void;\n}\n\nexport function NodeEnd({ onShare }: NodeEndProps): JSX.Element {\n return (\n <div className={styles[\"node-end\"]}>\n <div className={styles.icon} />\n <div className={styles.title}>{t(K.TASK_COMPLETED)}</div>\n <div className={styles.description}>{t(K.PLAN_COMPLETED)}</div>\n <button className={styles.button} onClick={onShare}>\n {t(K.SHARE)}\n </button>\n </div>\n );\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]!./NodeJob.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]!./NodeJob.module.css\";\n export default content && content.locals ? content.locals : undefined;\n","// istanbul ignore file\nimport { useMemo } from \"react\";\nimport type { Job, GraphEdge, GraphNode, TaskBaseDetail } from \"./interfaces\";\n\nexport function useTaskGraph(\n task: TaskBaseDetail | null | undefined,\n jobs: Job[]\n) {\n return useMemo(() => {\n if (!task) {\n return null;\n }\n\n const nodes: GraphNode[] = [];\n const edges: GraphEdge[] = [];\n\n const requirementNodeId = \"requirement\";\n nodes.push({\n type: \"requirement\",\n id: requirementNodeId,\n content: task.requirement,\n state: jobs.length === 0 ? \"working\" : \"completed\",\n });\n\n const jobMap = new Map<string, Job>();\n const childrenMap = new Map<string, string[]>();\n const downstreamMap = new Map<string, string[]>();\n const upstreamMap = new Map<string, string[]>();\n const rootDownstream: string[] = [];\n const rootChildren: string[] = [];\n\n for (const job of jobs) {\n if (job.parent) {\n let children = childrenMap.get(job.parent);\n if (!children) {\n children = [];\n childrenMap.set(job.parent, children);\n }\n children.push(job.id);\n }\n }\n\n // Setup jobMap and downstreamMap\n for (const job of jobs) {\n jobMap.set(job.id, job);\n\n for (const up of job.upstream ?? []) {\n let downstream = downstreamMap.get(up);\n if (!downstream) {\n downstream = [];\n downstreamMap.set(up, downstream);\n }\n downstream.push(job.id);\n }\n\n if (!job.parent) {\n rootChildren.push(job.id);\n\n if (!job.upstream?.length) {\n rootDownstream.push(job.id);\n }\n }\n }\n\n const alignDownstreamMap = (children: string[]) => {\n for (const rootJobId of children) {\n const subChildren = childrenMap.get(rootJobId);\n const downstream = downstreamMap.get(rootJobId);\n\n if (subChildren) {\n const firstLevelChildren = subChildren.filter((child) => {\n const childJob = jobMap.get(child)!;\n return !childJob.upstream?.length;\n });\n\n const lastLevelChildren = downstream\n ? subChildren.filter((child) => {\n return !downstreamMap.has(child);\n })\n : [];\n\n downstreamMap.set(rootJobId, firstLevelChildren);\n\n for (const child of lastLevelChildren) {\n downstreamMap.set(child, [...downstream!]);\n }\n\n alignDownstreamMap(subChildren);\n }\n }\n };\n\n alignDownstreamMap(rootChildren);\n\n // Setup upstreamMap\n for (const [upstream, downstream] of downstreamMap) {\n for (const target of downstream) {\n let upstreams = upstreamMap.get(target);\n if (!upstreams) {\n upstreams = [];\n upstreamMap.set(target, upstreams);\n }\n upstreams.push(upstream);\n }\n }\n\n // Get BFS order of jobs\n const list: string[] = [];\n const visitedJobs = new Set<string>();\n const queue: string[] = [...rootDownstream];\n while (queue.length > 0) {\n const id = queue.shift()!;\n if (visitedJobs.has(id)) {\n continue;\n }\n visitedJobs.add(id);\n list.push(id);\n const downstream = downstreamMap.get(id);\n if (downstream) {\n queue.push(...downstream);\n }\n }\n\n const jobNodesMap = new Map<string, string[]>([\n [requirementNodeId, [requirementNodeId]],\n ]);\n\n for (const jobId of list) {\n const job = jobMap.get(jobId)!;\n const { messages } = job;\n const hasMessages =\n (Array.isArray(messages) && messages.length > 0) || job.toolCall;\n\n const nodeIds: string[] = [];\n\n if (job.instruction) {\n const instructionNodeId = `instruction:${jobId}`;\n nodes.push({\n type: \"instruction\",\n id: instructionNodeId,\n job,\n state: job.state,\n });\n\n nodeIds.push(instructionNodeId);\n }\n\n if (hasMessages || !job.instruction) {\n const jobNodeId = `job:${job.id}`;\n nodes.push({\n type: \"job\",\n id: jobNodeId,\n job,\n state: job.state,\n });\n nodeIds.push(jobNodeId);\n }\n\n jobNodesMap.set(jobId, nodeIds);\n }\n\n for (const jobId of list) {\n const nodeIds = jobNodesMap.get(jobId)!;\n\n const upstreams = upstreamMap.get(jobId);\n for (const upstream of upstreams ?? [requirementNodeId]) {\n const parentNodeIds = jobNodesMap.get(upstream)!;\n edges.push({\n source: parentNodeIds[parentNodeIds.length - 1],\n target: nodeIds[0],\n });\n }\n\n for (let i = 1; i < nodeIds.length; i++) {\n edges.push({\n source: nodeIds[i - 1],\n target: nodeIds[i],\n });\n }\n }\n\n return {\n nodes,\n edges,\n };\n }, [task, jobs]);\n}\n"],"names":["K","NS","locales","en","YES","NO","PLAN_COMPLETED","TASK_COMPLETED","SHARE","zh","t","i18n","getFixedT","SIZING_STYLE","hiddenTextarea","modKey","test","navigator","platform","TextareaAutoResize","React","LegacyTextareaAutoResize","_ref","ref","autoResize","_autoResize","minRows","maxRows","borderSize","paddingSize","containerRef","value","propValue","style","submitWhen","onChange","onSubmit","onKeyDown","onCompositionStart","onCompositionEnd","props","setValue","useState","textareaRef","useRef","autoStyle","setAutoStyle","useImperativeHandle","focus","textarea","current","_textarea$value","valueLength","length","setSelectionRange","doAutoResize","useCallback","uiTextNode","options","document","createElement","setAttribute","body","appendChild","uiTextNodeStyle","window","getComputedStyle","sizingStyle","map","name","getPropertyValue","join","minHeight","maxHeight","overflowY","placeholder","height","scrollHeight","singleRowHeight","parseFloat","Math","max","min","resize","calculateAutoSizeStyle","flushSync","useEffect","compositionRef","handleCompositionStart","e","handleCompositionEnd","handleKeyDown","key","shiftKey","preventDefault","stopPropagation","container","previousInlineSize","observer","ResizeObserver","entries","entry","target","currentInlineSize","contentBoxSize","inlineSize","contentRect","width","undefined","isInitial","requestAnimationFrame","observe","disconnect","_extends","styleTagTransform","setAttributes","insert","domAPI","insertStyleElement","locals","mergeMessages","messages","merged","previousRole","message","role","lastMessage","parts","push","mergeMessageParts","previousType","part","type","text","rootReducer","reducers","task","state","action","taskPatch","pick","payload","isMatchWith","isEqual","jobs","jobsPatch","Array","isArray","jobPatch","_jobs$findIndex","_jobs","previousJobIndex","findIndex","job","id","messagesPatch","toolCall","arguments","JSON","parse","console","error","argumentsParseFailed","argumentsParseError","previousJob","restMessagesPatch","_previousJob$messages","slice","Object","fromEntries","useTaskDetail","taskId","dispatch","useReducer","humanInputRef","ctrl","ignore","requesting","makeRequest","async","AbortController","request","createSSEStream","getBasePath","signal","stream","handleHttpError","jobId","input","response","fetch","method","headers","stringify","ok","responseJson","status","statusText","json","HttpResponseError","_ctrl","abort","plan","setPlan","prev","jobMap","Map","childrenMap","_childrenMap$get","set","parent","get","isInputRequired","_childrenMap$get2","some","childId","childJob","step","_task$plan","instruction","PlanProgress","expanded","setExpanded","doneCount","useMemo","reduce","acc","className","icon","getClassNameAndIconProps","toggle","classNames","styles","progress","onClick","WrappedIcon","title","stat","expand","lib","theme","details","index","PlanStep","_ref2","completed","prefix","working","spinning","failed","canceled","___CSS_LOADER_EXPORT___","module","WrappedEasyOpsAvatar","wrapBrick","NodeRequirement","content","startTime","loading","username","auth","getAuth","heading","user","nameOrInstanceId","showName","size","time","moment","format","viewBox","d","inner","ZoomBar","scale","onScaleChange","onReCenter","handleZoomIn","handleZoomOut","divider","rehypePrism","visitor","node","_index","tagName","lang","properties","classListItem","toLowerCase","getLanguage","result","concat","refractor","highlight","toString","children","tree","visit","production","Fragment","jsx","jsxs","MarkdownComponent","reactContent","setReactContent","unified","use","remarkParse","remarkToRehype","rehypeReact","process","then","vFile","catch","AsyncWrappedCMDB","default","asyncWrapBrick","onChangeV2","NodeJob","_job$toolCall","_arguments","_job$toolCall2","_arguments2","_arguments$command","_arguments3","_job$messages","humanInput","askUser","knownAskUser","includes","command","isError","tool","question","HumanInputComponent","HumanConfirmComponent","confirmText","confirm_text","cancelText","cancel_text","HumanChooseComponent","HumanSelectFromCmdb","objectId","attrId","_message$parts","partIndex","RefineMarkdownComponent","isToolOutput","file","data","currentTarget","_ref3","marginTop","WrappedButton","marginLeft","_ref4","display","flexDirection","gap","option","_ref5","objectList","setObjectList","objects","CmdbObjectApi_getObjectRef","ref_object","fieldId","Suspense","detail","i","_ref6","refinedContent","___CSS_LOADER_URL_IMPORT_0___","URL","___CSS_LOADER_URL_REPLACEMENT_0___","useAutoCenter","nodes","sizeReady","zoomer","rootRef","centered","setCentered","reCenterRef","root","left","Infinity","right","top","bottom","view","r","x","b","y","clientWidth","diffY","CANVAS_PADDING_BOTTOM","clientHeight","transform","select","ZoomTransform","DEFAULT_SCALE_RANGE_MIN","DEFAULT_SCALE_RANGE_MAX","START_NODE_ID","END_NODE_ID","DONE_STATES","NodeInstruction","___CSS_LOADER_URL_IMPORT_1___","___CSS_LOADER_URL_REPLACEMENT_1___","useLayout","rawNodes","_rawNodes","rawEdges","_rawEdges","sizeMap","memoizedPositionsRef","initialNodes","initialEdges","finishedNodeIds","hasSource","Set","edge","hasTarget","source","has","memoizedPositions","startNodePositionRef","_memoizedPositionsRef","edges","graph","dagre","Graph","setGraph","rankdir","nodesep","edgesep","ranksep","setDefaultEdgeLabel","setEdge","setNode","offsets","nodeView","assign","getPositionWithOffsets","sourcePosition","targetPosition","turnY","points","position","NodeStart","isMac","_userAgentData$platfo","_userAgentData","userAgentData","userAgent","wheelData","event","deltaY","deltaMode","ctrlKey","useZoom","zoomable","scrollable","pannable","pannableWithCtrl","scaleRange","_scaleRange","onSwitchActiveTarget","grabbing","setGrabbing","setTransform","k","transformRef","zoom","wheelDelta","moved","scaleExtent","on","filter","button","onContextMenu","addEventListener","removeEventListener","rootSelection","unsetZoom","stopImmediatePropagation","pre","closest","element","delta","maxScroll","scrollWidth","scrollLeft","checkScrollableX","deltaX","jobStyles","scrollTop","checkScrollableY","cancelable","translateBy","wheelDeltaX","wheelDeltaY","call","NodeEnd","onShare","description","useTaskGraph","requirementNodeId","requirement","downstreamMap","upstreamMap","rootDownstream","rootChildren","up","_job$upstream","upstream","downstream","_job$upstream2","alignDownstreamMap","rootJobId","subChildren","firstLevelChildren","child","_childJob$upstream","lastLevelChildren","upstreams","list","visitedJobs","queue","shift","add","jobNodesMap","hasMessages","nodeIds","instructionNodeId","jobNodeId","parentNodeIds"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[7039],{2277:(e,t,n)=>{var a,s=n(4635),r=n(918),o=n(6902),i=n(5536),l=n(6121),c=n(829),u=n(2740),d=n(8769),h=n.n(d),p=n(6192),m=n(9859),b=n(8974),f=(n(6477),n(3922)),g=n(3373),v=n.n(g),k=n(9126),A=n(7566),E=n(79),x=n(2464),w=n(8231),y=n(6494),_=n(7642),R=n(2773),C=n(9533),N=n(3153),I=n(4999),S=n(7954),W=n(4388),z=n(6938),M=n(5391),H=n(9295),j=n(6854);let L,$,T,O,P,B,D,F,q,Q,U;(0,f.initializeI18n)(E.NS,E.I);const{defineElement:X,property:G,event:J}=(0,p.createDecorators)(),K=(0,d.memo)(oe);let V;var Y=new WeakMap,Z=new WeakMap,ee=new WeakMap,te=new WeakMap,ne=new WeakSet,ae=new WeakMap;class se extends m.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,ne),(0,r.A)(this,Y,$(this)),(0,r.A)(this,Z,(T(this),O(this))),(0,r.A)(this,ee,(P(this),B(this))),(0,r.A)(this,te,(D(this),F(this))),(0,r.A)(this,ae,(U(this),()=>{(0,i.A)(ne,this,q).emit()}))}get taskId(){return(0,c.A)(Y,this)}set taskId(e){(0,l.A)(Y,this,e)}get task(){return(0,c.A)(Z,this)}set task(e){(0,l.A)(Z,this,e)}get jobs(){return(0,c.A)(ee,this)}set jobs(e){(0,l.A)(ee,this,e)}render(){return h().createElement(re,{taskId:this.taskId,jobs:this.jobs,task:this.task,onShare:(0,c.A)(ae,this)})}}function re(e){var t;let{taskId:n,task:a,jobs:s,onShare:r}=e;const o=(0,d.useRef)(null),{task:i,jobs:l,plan:c,error:u,humanInputRef:p}=(0,R.S)(n),m=n?i:a,f=n?l:null!=s?s:[],g=n?c:null==a?void 0:a.plan,k=(0,C.B)(m,f),E=null==k?void 0:k.nodes,S=null==k?void 0:k.edges;(0,d.useEffect)((()=>{u&&(0,b.handleHttpError)(u)}),[u]);const W=(0,d.useCallback)(((e,t)=>{var n;null===(n=p.current)||void 0===n||n.call(p,e,t)}),[p]),[z,M]=(0,d.useState)(null),H=(0,d.useCallback)(((e,t)=>{M((n=>{if(!t){if(!n)return null;const t=new Map(n);return t.delete(e)?t:n}return n?new Map(n).set(e,t):new Map([[e,t]])}))}),[]),{sizeReady:L,nodes:$,edges:T}=(0,_.g)({rawNodes:E,rawEdges:S,state:null==m?void 0:m.state,sizeMap:z}),{grabbing:O,transform:P,transformRef:B,zoomer:D}=(0,w.f)({rootRef:o,zoomable:L,scrollable:L,pannable:L}),{centered:F,setCentered:q,reCenterRef:Q}=(0,y.E)({nodes:$,sizeReady:L,zoomer:D,rootRef:o}),U=!j.QB.includes(null!==(t=null==m?void 0:m.state)&&void 0!==t?t:"working")&&2===$.length,X=(0,d.useMemo)((()=>new Set(T.map((e=>e.source)))),[T]),G=(0,d.useMemo)((()=>{if(!L)return null;const e=[];for(const t of $)X.has(t.id)||e.push(t);return e.length>0?Math.max(...e.map((e=>e.view.y+e.view.height))):null}),[$,X,L]);(0,d.useEffect)((()=>{const e=o.current;if(!e||null===G)return;const{offsetHeight:t}=e,n=B.current,a=G*n.k+n.y,s=t-j.xX-a;s<0&&D.translateBy((0,A.A)(o.current),0,s)}),[G,B,D]);const J=(0,d.useCallback)((()=>{Q.current=!0,q(!1)}),[Q,q]),V=(0,d.useCallback)((e=>{D.scaleTo((0,A.A)(o.current),e)}),[D]);return h().createElement(h().Fragment,null,h().createElement("div",{className:x.A.root,ref:o,style:{cursor:O?"grabbing":"grab"}},h().createElement("div",{className:v()(x.A.canvas,{[x.A.ready]:L&&F}),style:{transform:`translate3d(${P.x}px, ${P.y}px, 0) scale(${P.k})`}},h().createElement("svg",{className:x.A.edges},T.map((e=>h().createElement("path",{className:x.A.edge,key:`${e.source}-${e.target}`,d:e.points.map(((e,t)=>{let{x:n,y:a}=e;return`${0===t?"M":"L"}${n},${a}`})).join(" ")})))),$.map((e=>{var t,n;return h().createElement(K,{key:e.id,id:e.id,type:e.type,content:e.content,job:e.job,state:e.state,startTime:null==m?void 0:m.startTime,taskLoading:U,instructionLoading:"instruction"===e.type&&!X.has(e.id),edges:T,x:null===(t=e.view)||void 0===t?void 0:t.x,y:null===(n=e.view)||void 0===n?void 0:n.y,onResize:H,humanInput:W,onShare:r})})))),h().createElement("div",{className:x.A.widgets},h().createElement(N.r,{plan:g}),h().createElement(I.l,{scale:P.k,onScaleChange:V,onReCenter:J})))}function oe(e){let{id:t,type:n,state:a,job:s,content:r,startTime:o,taskLoading:i,instructionLoading:l,x:c,y:u,onResize:p,humanInput:m,onShare:b}=e;const f=(0,d.useRef)(null);return(0,d.useEffect)((()=>{const e=f.current;if(!e)return;const n=new k.A((()=>{p(t,[e.offsetWidth,e.offsetHeight])}));return n.observe(e),()=>{n.disconnect(),p(t,null)}}),[t,p]),(0,d.useEffect)((()=>{const e=f.current;if(!e)return;const t=e=>{e.stopPropagation()};return e.addEventListener("mousedown",t),()=>{e.removeEventListener("mousedown",t)}}),[]),h().createElement("div",{className:v()(x.A.node,{[x.A.ready]:null!=c&&null!=u}),ref:f,style:{left:c,top:u}},"start"===n?h().createElement(S.H,null):"end"===n?h().createElement(H.s,{onShare:b}):"requirement"===n?h().createElement(W.O,{content:r,startTime:o,loading:i}):"instruction"===n?h().createElement(z.L,{content:s.instruction,loading:l}):"job"===n?h().createElement(M.W,{state:a,job:s,humanInput:m}):h().createElement("div",{className:`${x.A["node-default"]} ${x.A["size-medium"]}`},`Unknown job type: "${n}"`))}a=se,({e:[$,T,O,P,B,D,F,q,Q,U],c:[V,L]}=(0,u.A)(a,[X("ai-portal.cruise-canvas",{shadowOptions:!1})],[[G(),1,"taskId"],[G({attribute:!1}),1,"task"],[G({attribute:!1}),1,"jobs"],[J({type:"share"}),1,"shareEvent",e=>(0,c.A)(te,e),(e,t)=>(0,l.A)(te,e,t)]],0,(e=>ae.has((0,o.A)(e))),m.ReactNextElement)),L();var ie=n(1451);let le=function(e){return e.HOW_CAN_I_HELP="HOW_CAN_I_HELP",e}({});const ce="bricks/ai-portal/chat-box",ue={en:{[le.HOW_CAN_I_HELP]:"How can I help?"},zh:{[le.HOW_CAN_I_HELP]:"有什么可以帮您的?"}},de=f.i18n.getFixedT(null,ce);var he,pe=n(7008);let me,be,fe,ge,ve,ke,Ae;(0,f.initializeI18n)(ce,ue);const Ee=(0,m.wrapBrick)("eo-button"),xe={lib:"fa",prefix:"fas",icon:"arrow-up"},{defineElement:we,property:ye,event:_e}=(0,p.createDecorators)();let Re;var Ce=new WeakMap,Ne=new WeakMap,Ie=new WeakSet,Se=new WeakMap;class We extends m.ReactNextElement{constructor(){super(...arguments),(0,s.A)(this,Ie),(0,r.A)(this,Ce,be(this)),(0,r.A)(this,Ne,(fe(this),ge(this))),(0,r.A)(this,Se,(Ae(this),e=>{(0,i.A)(Ie,this,ve).emit(e)}))}get disabled(){return(0,c.A)(Ce,this)}set disabled(e){(0,l.A)(Ce,this,e)}render(){return h().createElement(ze,{disabled:this.disabled,onSubmit:(0,c.A)(Se,this)})}}function ze(e){let{disabled:t,onSubmit:n}=e;const a=(0,d.useRef)(null),s=(0,d.useRef)(""),r=(0,d.useCallback)((e=>{null==n||n(e.currentTarget.value)}),[n]),o=(0,d.useCallback)((e=>{s.current=e.target.value}),[]),i=(0,d.useCallback)((()=>{null==n||n(s.current)}),[n]);return h().createElement("div",{className:"container",ref:a},h().createElement(ie.e,{containerRef:a,minRows:5,paddingSize:24,autoResize:!0,disabled:t,placeholder:de(le.HOW_CAN_I_HELP),submitWhen:"enter-without-shift",onSubmit:r,onChange:o}),h().createElement(Ee,{className:"btn-send",shape:"circle",icon:xe,disabled:t,onClick:i}))}he=We,({e:[be,fe,ge,ve,ke,Ae],c:[Re,me]}=(0,u.A)(he,[we("ai-portal.chat-box",{styleTexts:[pe.A]})],[[ye({type:Boolean}),1,"disabled"],[_e({type:"message.submit"}),1,"messageSubmit",e=>(0,c.A)(Ne,e),(e,t)=>(0,l.A)(Ne,e,t)]],0,(e=>Se.has((0,o.A)(e))),m.ReactNextElement)),me()},7008:(e,t,n)=>{n.d(t,{A:()=>i});var a=n(6758),s=n.n(a),r=n(935),o=n.n(r)()(s());o.push([e.id,":host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.container{position:relative}textarea{display:block;width:100%;padding:12px 18px;color:var(--antd-input-color);background:var(--antd-input-bg);box-sizing:border-box;border-radius:1em;border:1px solid var(--antd-input-border-color);font-size:14px;line-height:22px;height:32px}textarea:not(:disabled):hover{border:1px solid var(--antd-input-hover-border-color)}textarea:not(:disabled):focus{border:1px solid var(--antd-input-focus-border-color);outline:0;box-shadow:0 0 0 2px rgb(0 113 235/20%)}textarea::placeholder{color:var(--antd-input-placeholder-color)}.btn-send{position:absolute;bottom:1em;right:1em}",""]);const i=o.toString()}}]);
|
|
2
|
-
//# sourceMappingURL=7039.1c9f420a.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/7039.1c9f420a.js","mappings":"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","sources":["webpack:///./src/cruise-canvas/index.tsx","webpack:///./src/chat-box/i18n.ts","webpack:///./src/chat-box/index.tsx","webpack:///./src/chat-box/styles.shadow.css"],"sourcesContent":["// istanbul ignore file: experimental\nimport React, {\n memo,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport { select } from \"d3-selection\";\nimport { NS, locales } from \"./i18n.js\";\nimport styles from \"./styles.module.css\";\nimport { useZoom } from \"./useZoom.js\";\nimport type {\n SizeTuple,\n GraphNode,\n Job,\n RequirementGraphNode,\n JobGraphNode,\n TaskBaseDetail,\n GraphEdge,\n} from \"./interfaces.js\";\nimport { useAutoCenter } from \"./useAutoCenter.js\";\nimport { useLayout } from \"./useLayout.js\";\nimport { useTaskDetail } from \"./useTaskDetail.js\";\nimport { useTaskGraph } from \"./useTaskGraph.js\";\nimport { PlanProgress } from \"./PlanProgress/PlanProgress.js\";\nimport { ZoomBar } from \"./ZoomBar/ZoomBar.js\";\nimport { NodeStart } from \"./NodeStart/NodeStart.js\";\nimport { NodeRequirement } from \"./NodeRequirement/NodeRequirement.js\";\nimport { NodeInstruction } from \"./NodeInstruction/NodeInstruction.js\";\nimport { NodeJob } from \"./NodeJob/NodeJob.js\";\nimport { NodeEnd } from \"./NodeEnd/NodeEnd.js\";\nimport { CANVAS_PADDING_BOTTOM, DONE_STATES } from \"./constants.js\";\n\ninitializeI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst MemoizedNodeComponent = memo(NodeComponent);\n\nexport interface CruiseCanvasProps {\n taskId: string | undefined;\n task: TaskBaseDetail | undefined;\n jobs: Job[] | undefined;\n}\n\n/**\n * 构件 `ai-portal.cruise-canvas`\n */\nexport\n@defineElement(\"ai-portal.cruise-canvas\", {\n // Will wrap v2 bricks which don't support in shadow DOM.\n shadowOptions: false,\n})\nclass CruiseCanvas extends ReactNextElement implements CruiseCanvasProps {\n @property()\n accessor taskId: string | undefined;\n\n @property({ attribute: false })\n accessor task: TaskBaseDetail | undefined;\n\n @property({ attribute: false })\n accessor jobs: Job[] | undefined;\n\n @event({ type: \"share\" })\n accessor #shareEvent!: EventEmitter<void>;\n\n #onShare = () => {\n this.#shareEvent.emit();\n };\n\n render() {\n return (\n <CruiseCanvasComponent\n taskId={this.taskId}\n jobs={this.jobs}\n task={this.task}\n onShare={this.#onShare}\n />\n );\n }\n}\n\nexport interface CruiseCanvasComponentProps extends CruiseCanvasProps {\n onShare?: () => void;\n}\n\nexport function CruiseCanvasComponent({\n taskId,\n task: propTask,\n jobs: propJobs,\n onShare,\n}: CruiseCanvasComponentProps) {\n const rootRef = useRef<HTMLDivElement>(null);\n const {\n task: _task,\n jobs: _jobs,\n plan: _plan,\n error,\n humanInputRef,\n } = useTaskDetail(taskId);\n const task = taskId ? _task : propTask;\n const jobs = taskId ? _jobs : (propJobs ?? []);\n const plan = taskId ? _plan : propTask?.plan;\n const graph = useTaskGraph(task, jobs);\n const rawNodes = graph?.nodes;\n const rawEdges = graph?.edges;\n\n useEffect(() => {\n if (error) {\n handleHttpError(error);\n }\n }, [error]);\n\n const humanInput = useCallback(\n (jobId: string, input: string) => {\n humanInputRef.current?.(jobId, input);\n },\n [humanInputRef]\n );\n\n const [sizeMap, setSizeMap] = useState<Map<string, SizeTuple> | null>(null);\n const handleNodeResize = useCallback((id: string, size: SizeTuple | null) => {\n // Handle resize logic here\n setSizeMap((prev) => {\n if (!size) {\n if (!prev) {\n return null;\n }\n const newMap = new Map(prev);\n const deleted = newMap.delete(id);\n return deleted ? newMap : prev;\n }\n return prev ? new Map(prev).set(id, size) : new Map([[id, size]]);\n });\n }, []);\n\n const { sizeReady, nodes, edges } = useLayout({\n rawNodes,\n rawEdges,\n state: task?.state,\n sizeMap,\n });\n\n const { grabbing, transform, transformRef, zoomer /* , scaleRange */ } =\n useZoom({\n rootRef,\n zoomable: sizeReady,\n scrollable: sizeReady,\n pannable: sizeReady,\n });\n\n const { centered, setCentered, reCenterRef } = useAutoCenter({\n nodes,\n sizeReady,\n zoomer,\n rootRef,\n });\n\n const taskDone = DONE_STATES.includes(task?.state ?? \"working\");\n const taskLoading = !taskDone && nodes.length === 2;\n\n const nonLeafNodes = useMemo(() => {\n return new Set<string>(edges.map((edge) => edge.source));\n }, [edges]);\n\n const bottom = useMemo(() => {\n if (!sizeReady) {\n return null;\n }\n\n const leafNodes: GraphNode[] = [];\n for (const node of nodes) {\n if (!nonLeafNodes.has(node.id)) {\n leafNodes.push(node);\n }\n }\n if (leafNodes.length > 0) {\n const y1 = Math.max(\n ...leafNodes.map((node) => node.view!.y + node.view!.height)\n );\n return y1;\n }\n\n return null;\n }, [nodes, nonLeafNodes, sizeReady]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || bottom === null) {\n return;\n }\n const { offsetHeight } = root;\n const transform = transformRef.current;\n const transformedBottom = bottom * transform.k + transform.y;\n const diffY = offsetHeight - CANVAS_PADDING_BOTTOM - transformedBottom;\n if (diffY < 0) {\n // Make the latest node visible\n zoomer.translateBy(select(rootRef.current!), 0, diffY);\n }\n }, [bottom, transformRef, zoomer]);\n\n const handleReCenter = useCallback(() => {\n reCenterRef.current = true;\n setCentered(false);\n }, [reCenterRef, setCentered]);\n\n const handleScaleChange = useCallback(\n (scale: number) => {\n zoomer.scaleTo(select(rootRef.current!), scale);\n },\n [zoomer]\n );\n\n return (\n <>\n <div\n className={styles.root}\n ref={rootRef}\n style={{\n cursor: grabbing ? \"grabbing\" : \"grab\",\n }}\n >\n <div\n className={classNames(styles.canvas, {\n [styles.ready]: sizeReady && centered,\n })}\n style={{\n transform: `translate3d(${transform.x}px, ${transform.y}px, 0) scale(${transform.k})`,\n }}\n >\n <svg className={styles.edges}>\n {edges.map((edge) => (\n <path\n className={styles.edge}\n key={`${edge.source}-${edge.target}`}\n d={edge\n .points!.map(\n ({ x, y }, i) => `${i === 0 ? \"M\" : \"L\"}${x},${y}`\n )\n .join(\" \")}\n />\n ))}\n </svg>\n {nodes.map((node) => (\n <MemoizedNodeComponent\n key={node.id}\n id={node.id}\n type={node.type}\n content={(node as RequirementGraphNode).content}\n job={(node as JobGraphNode).job}\n state={node.state}\n startTime={task?.startTime}\n taskLoading={taskLoading}\n instructionLoading={\n node.type === \"instruction\" && !nonLeafNodes.has(node.id)\n }\n edges={edges}\n x={node.view?.x}\n y={node.view?.y}\n onResize={handleNodeResize}\n humanInput={humanInput}\n onShare={onShare}\n />\n ))}\n </div>\n </div>\n <div className={styles.widgets}>\n <PlanProgress plan={plan} />\n <ZoomBar\n scale={transform.k}\n onScaleChange={handleScaleChange}\n onReCenter={handleReCenter}\n />\n </div>\n </>\n );\n}\n\ninterface NodeComponentProps {\n id: string;\n type: GraphNode[\"type\"];\n edges: GraphEdge[];\n content?: string;\n job?: Job;\n state?: string;\n startTime?: number;\n taskLoading?: boolean;\n instructionLoading?: boolean;\n x?: number;\n y?: number;\n onResize: (id: string, size: SizeTuple | null) => void;\n humanInput?: (jobId: string, input: string) => void;\n onShare?: () => void;\n}\n\nfunction NodeComponent({\n id,\n type,\n state,\n job,\n content,\n startTime,\n taskLoading,\n instructionLoading,\n x,\n y,\n onResize,\n humanInput,\n onShare,\n}: NodeComponentProps) {\n const nodeRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const observer = new ResizeObserver(() => {\n onResize(id, [element.offsetWidth, element.offsetHeight]);\n });\n observer.observe(element);\n return () => {\n observer.disconnect();\n onResize(id, null);\n };\n }, [id, onResize]);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const handleMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n element.addEventListener(\"mousedown\", handleMouseDown);\n return () => {\n element.removeEventListener(\"mousedown\", handleMouseDown);\n };\n }, []);\n\n return (\n <div\n className={classNames(styles.node, {\n [styles.ready]: x != null && y != null,\n })}\n ref={nodeRef}\n style={{\n left: x,\n top: y,\n }}\n >\n {type === \"start\" ? (\n <NodeStart />\n ) : type === \"end\" ? (\n <NodeEnd onShare={onShare} />\n ) : type === \"requirement\" ? (\n <NodeRequirement\n content={content}\n startTime={startTime}\n loading={taskLoading}\n />\n ) : type === \"instruction\" ? (\n <NodeInstruction\n content={job!.instruction}\n loading={instructionLoading}\n />\n ) : type === \"job\" ? (\n <NodeJob state={state} job={job!} humanInput={humanInput} />\n ) : (\n <div className={`${styles[\"node-default\"]} ${styles[\"size-medium\"]}`}>\n {`Unknown job type: \"${type}\"`}\n </div>\n )}\n </div>\n );\n}\n","import { i18n } from \"@next-core/i18n\";\n\nexport enum K {\n HOW_CAN_I_HELP = \"HOW_CAN_I_HELP\",\n}\n\nconst en: Locale = {\n [K.HOW_CAN_I_HELP]: \"How can I help?\",\n};\n\nconst zh: Locale = {\n [K.HOW_CAN_I_HELP]: \"有什么可以帮您的?\",\n};\n\nexport const NS = \"bricks/ai-portal/chat-box\";\n\nexport const locales = { en, zh };\n\nexport const t = i18n.getFixedT(null, NS);\n\ntype Locale = { [k in K]: string } & {\n [k in K as `${k}_plural`]?: string;\n};\n","import React, { useCallback, useRef } from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement, wrapBrick } from \"@next-core/react-element\";\nimport { TextareaAutoResize } from \"@next-shared/form\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport type { Button, ButtonProps } from \"@next-bricks/basic/button\";\nimport { K, NS, locales, t } from \"./i18n.js\";\nimport styleText from \"./styles.shadow.css\";\n\ninitializeI18n(NS, locales);\n\nconst WrappedButton = wrapBrick<Button, ButtonProps>(\"eo-button\");\n\nconst SEND_ICON: ButtonProps[\"icon\"] = {\n lib: \"fa\",\n prefix: \"fas\",\n icon: \"arrow-up\",\n};\n\nconst { defineElement, property, event } = createDecorators();\n\nexport interface ChatBoxProps {\n disabled?: boolean;\n}\n\n/**\n * 构件 `ai-portal.chat-box`\n */\nexport\n@defineElement(\"ai-portal.chat-box\", {\n styleTexts: [styleText],\n})\nclass ChatBox extends ReactNextElement implements ChatBoxProps {\n @property({ type: Boolean })\n accessor disabled: boolean | undefined;\n\n @event({ type: \"message.submit\" })\n accessor #messageSubmit!: EventEmitter<string>;\n\n #handleMessageSubmit = (value: string) => {\n this.#messageSubmit.emit(value);\n };\n\n render() {\n return (\n <ChatBoxComponent\n disabled={this.disabled}\n onSubmit={this.#handleMessageSubmit}\n />\n );\n }\n}\n\nexport interface ChatBoxComponentProps extends ChatBoxProps {\n // Define react event handlers here.\n onSubmit?: (value: string) => void;\n}\n\nexport function ChatBoxComponent({\n disabled,\n onSubmit,\n}: ChatBoxComponentProps) {\n const containerRef = useRef<HTMLDivElement>(null);\n const valueRef = useRef(\"\");\n\n const handleSubmit = useCallback(\n (e: React.FormEvent<HTMLTextAreaElement>) => {\n onSubmit?.(e.currentTarget.value);\n },\n [onSubmit]\n );\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLTextAreaElement>) => {\n valueRef.current = e.target.value;\n },\n []\n );\n\n const handleSubmitClick = useCallback(() => {\n onSubmit?.(valueRef.current);\n }, [onSubmit]);\n\n return (\n <div className=\"container\" ref={containerRef}>\n <TextareaAutoResize\n containerRef={containerRef}\n minRows={5}\n paddingSize={24}\n autoResize\n disabled={disabled}\n placeholder={t(K.HOW_CAN_I_HELP)}\n submitWhen=\"enter-without-shift\"\n onSubmit={handleSubmit}\n onChange={handleChange}\n />\n <WrappedButton\n className=\"btn-send\"\n shape=\"circle\"\n icon={SEND_ICON}\n disabled={disabled}\n onClick={handleSubmitClick}\n />\n </div>\n );\n}\n","// Imports\nimport ___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/noSourceMaps.js\";\nimport ___CSS_LOADER_API_IMPORT___ from \"../../../../node_modules/css-loader/dist/runtime/api.js\";\nvar ___CSS_LOADER_EXPORT___ = ___CSS_LOADER_API_IMPORT___(___CSS_LOADER_API_NO_SOURCEMAP_IMPORT___);\n// Module\n___CSS_LOADER_EXPORT___.push([module.id, `:host{display:block}:host([hidden]){display:none}*{box-sizing:border-box}.container{position:relative}textarea{display:block;width:100%;padding:12px 18px;color:var(--antd-input-color);background:var(--antd-input-bg);box-sizing:border-box;border-radius:1em;border:1px solid var(--antd-input-border-color);font-size:14px;line-height:22px;height:32px}textarea:not(:disabled):hover{border:1px solid var(--antd-input-hover-border-color)}textarea:not(:disabled):focus{border:1px solid var(--antd-input-focus-border-color);outline:0;box-shadow:0 0 0 2px rgb(0 113 235/20%)}textarea::placeholder{color:var(--antd-input-placeholder-color)}.btn-send{position:absolute;bottom:1em;right:1em}`, \"\"]);\n// Exports\nexport default ___CSS_LOADER_EXPORT___.toString();\n"],"names":["initializeI18n","NS","locales","defineElement","property","event","createDecorators","MemoizedNodeComponent","memo","NodeComponent","_CruiseCanvas","_A","WeakMap","_B","_C","_D","_CruiseCanvas_brand","WeakSet","_onShare","CruiseCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_taskId","_init_extra_taskId","_init_task","_init_extra_task","_init_jobs","_init_extra_jobs","_init_shareEvent","_init_extra_shareEvent","_classPrivateGetter","this","_get_shareEvent","emit","taskId","_classPrivateFieldGet","v","_classPrivateFieldSet","task","jobs","render","React","CruiseCanvasComponent","onShare","_ref","_task$state","propTask","propJobs","rootRef","useRef","_task","_jobs","plan","_plan","error","humanInputRef","useTaskDetail","graph","useTaskGraph","rawNodes","nodes","rawEdges","edges","useEffect","handleHttpError","humanInput","useCallback","jobId","input","_humanInputRef$curren","current","call","sizeMap","setSizeMap","useState","handleNodeResize","id","size","prev","newMap","Map","delete","set","sizeReady","useLayout","state","grabbing","transform","transformRef","zoomer","useZoom","zoomable","scrollable","pannable","centered","setCentered","reCenterRef","useAutoCenter","taskLoading","DONE_STATES","includes","length","nonLeafNodes","useMemo","Set","map","edge","source","bottom","leafNodes","node","has","push","Math","max","view","y","height","root","offsetHeight","transformedBottom","k","diffY","CANVAS_PADDING_BOTTOM","translateBy","select","handleReCenter","handleScaleChange","scale","scaleTo","className","styles","ref","style","cursor","classNames","canvas","ready","x","key","target","d","points","_ref2","i","join","_node$view","_node$view2","type","content","job","startTime","instructionLoading","onResize","widgets","PlanProgress","ZoomBar","onScaleChange","onReCenter","_ref3","nodeRef","element","observer","ResizeObserver","offsetWidth","observe","disconnect","handleMouseDown","e","stopPropagation","addEventListener","removeEventListener","left","top","NodeStart","NodeEnd","NodeRequirement","loading","NodeInstruction","instruction","NodeJob","_CruiseCanvas2","_set_shareEvent","c","_initClass","_applyDecs","shadowOptions","attribute","o","_","_checkInRHS","K","en","HOW_CAN_I_HELP","zh","t","i18n","getFixedT","WrappedButton","wrapBrick","SEND_ICON","lib","prefix","icon","_ChatBox","_ChatBox_brand","_handleMessageSubmit","ChatBox","_init_disabled","_init_extra_disabled","_init_messageSubmit","_init_extra_messageSubmit","value","_get_messageSubmit","disabled","ChatBoxComponent","onSubmit","containerRef","valueRef","handleSubmit","currentTarget","handleChange","handleSubmitClick","TextareaAutoResize","minRows","paddingSize","autoResize","placeholder","submitWhen","onChange","shape","onClick","_ChatBox2","_set_messageSubmit","styleTexts","styleText","Boolean","___CSS_LOADER_EXPORT___","module","toString"],"sourceRoot":""}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";(globalThis.webpackChunk_next_bricks_ai_portal=globalThis.webpackChunk_next_bricks_ai_portal||[]).push([[2267],{6185:(e,t,n)=>{n.r(t),n.d(t,{CruiseCanvas:()=>V,CruiseCanvasComponent:()=>re});var s,a=n(4635),r=n(918),o=n(6902),l=n(5536),i=n(6121),u=n(829),c=n(2740),d=n(8769),m=n.n(d),h=n(6192),p=n(9859),f=n(8974),k=(n(6477),n(3922)),v=n(3373),g=n.n(v),b=n(9126),A=n(7566),E=n(79),w=n(2464),y=n(8231),C=n(6494),j=n(7642),x=n(2773),R=n(9533),M=n(3153),I=n(4999),N=n(7954),S=n(4388),$=n(6938),z=n(5391),L=n(9295),W=n(6854);let _,T,H,B,O,q,D,F,P,Q,U;(0,k.initializeI18n)(E.NS,E.I);const{defineElement:X,property:G,event:J}=(0,h.createDecorators)(),K=(0,d.memo)(oe);let V;var Y=new WeakMap,Z=new WeakMap,ee=new WeakMap,te=new WeakMap,ne=new WeakSet,se=new WeakMap;class ae extends p.ReactNextElement{constructor(){super(...arguments),(0,a.A)(this,ne),(0,r.A)(this,Y,T(this)),(0,r.A)(this,Z,(H(this),B(this))),(0,r.A)(this,ee,(O(this),q(this))),(0,r.A)(this,te,(D(this),F(this))),(0,r.A)(this,se,(U(this),()=>{(0,l.A)(ne,this,P).emit()}))}get taskId(){return(0,u.A)(Y,this)}set taskId(e){(0,i.A)(Y,this,e)}get task(){return(0,u.A)(Z,this)}set task(e){(0,i.A)(Z,this,e)}get jobs(){return(0,u.A)(ee,this)}set jobs(e){(0,i.A)(ee,this,e)}render(){return m().createElement(re,{taskId:this.taskId,jobs:this.jobs,task:this.task,onShare:(0,u.A)(se,this)})}}function re(e){var t;let{taskId:n,task:s,jobs:a,onShare:r}=e;const o=(0,d.useRef)(null),{task:l,jobs:i,plan:u,error:c,humanInputRef:h}=(0,x.S)(n),p=n?l:s,k=n?i:null!=a?a:[],v=n?u:null==s?void 0:s.plan,b=(0,R.B)(p,k),E=null==b?void 0:b.nodes,N=null==b?void 0:b.edges;(0,d.useEffect)((()=>{c&&(0,f.handleHttpError)(c)}),[c]);const S=(0,d.useCallback)(((e,t)=>{var n;null===(n=h.current)||void 0===n||n.call(h,e,t)}),[h]),[$,z]=(0,d.useState)(null),L=(0,d.useCallback)(((e,t)=>{z((n=>{if(!t){if(!n)return null;const t=new Map(n);return t.delete(e)?t:n}return n?new Map(n).set(e,t):new Map([[e,t]])}))}),[]),{sizeReady:_,nodes:T,edges:H}=(0,j.g)({rawNodes:E,rawEdges:N,state:null==p?void 0:p.state,sizeMap:$}),{grabbing:B,transform:O,transformRef:q,zoomer:D}=(0,y.f)({rootRef:o,zoomable:_,scrollable:_,pannable:_}),{centered:F,setCentered:P,reCenterRef:Q}=(0,C.E)({nodes:T,sizeReady:_,zoomer:D,rootRef:o}),U=!W.QB.includes(null!==(t=null==p?void 0:p.state)&&void 0!==t?t:"working")&&2===T.length,X=(0,d.useMemo)((()=>new Set(H.map((e=>e.source)))),[H]),G=(0,d.useMemo)((()=>{if(!_)return null;const e=[];for(const t of T)X.has(t.id)||e.push(t);return e.length>0?Math.max(...e.map((e=>e.view.y+e.view.height))):null}),[T,X,_]);(0,d.useEffect)((()=>{const e=o.current;if(!e||null===G)return;const{offsetHeight:t}=e,n=q.current,s=G*n.k+n.y,a=t-W.xX-s;a<0&&D.translateBy((0,A.A)(o.current),0,a)}),[G,q,D]);const J=(0,d.useCallback)((()=>{Q.current=!0,P(!1)}),[Q,P]),V=(0,d.useCallback)((e=>{D.scaleTo((0,A.A)(o.current),e)}),[D]);return m().createElement(m().Fragment,null,m().createElement("div",{className:w.A.root,ref:o,style:{cursor:B?"grabbing":"grab"}},m().createElement("div",{className:g()(w.A.canvas,{[w.A.ready]:_&&F}),style:{transform:`translate3d(${O.x}px, ${O.y}px, 0) scale(${O.k})`}},m().createElement("svg",{className:w.A.edges},H.map((e=>m().createElement("path",{className:w.A.edge,key:`${e.source}-${e.target}`,d:e.points.map(((e,t)=>{let{x:n,y:s}=e;return`${0===t?"M":"L"}${n},${s}`})).join(" ")})))),T.map((e=>{var t,n;return m().createElement(K,{key:e.id,id:e.id,type:e.type,content:e.content,job:e.job,state:e.state,startTime:null==p?void 0:p.startTime,taskLoading:U,instructionLoading:"instruction"===e.type&&!X.has(e.id),edges:H,x:null===(t=e.view)||void 0===t?void 0:t.x,y:null===(n=e.view)||void 0===n?void 0:n.y,onResize:L,humanInput:S,onShare:r})})))),m().createElement("div",{className:w.A.widgets},m().createElement(M.r,{plan:v}),m().createElement(I.l,{scale:O.k,onScaleChange:V,onReCenter:J})))}function oe(e){let{id:t,type:n,state:s,job:a,content:r,startTime:o,taskLoading:l,instructionLoading:i,x:u,y:c,onResize:h,humanInput:p,onShare:f}=e;const k=(0,d.useRef)(null);return(0,d.useEffect)((()=>{const e=k.current;if(!e)return;const n=new b.A((()=>{h(t,[e.offsetWidth,e.offsetHeight])}));return n.observe(e),()=>{n.disconnect(),h(t,null)}}),[t,h]),(0,d.useEffect)((()=>{const e=k.current;if(!e)return;const t=e=>{e.stopPropagation()};return e.addEventListener("mousedown",t),()=>{e.removeEventListener("mousedown",t)}}),[]),m().createElement("div",{className:g()(w.A.node,{[w.A.ready]:null!=u&&null!=c}),ref:k,style:{left:u,top:c}},"start"===n?m().createElement(N.H,null):"end"===n?m().createElement(L.s,{onShare:f}):"requirement"===n?m().createElement(S.O,{content:r,startTime:o,loading:l}):"instruction"===n?m().createElement($.L,{content:a.instruction,loading:i}):"job"===n?m().createElement(z.W,{state:s,job:a,humanInput:p}):m().createElement("div",{className:`${w.A["node-default"]} ${w.A["size-medium"]}`},`Unknown job type: "${n}"`))}s=ae,({e:[T,H,B,O,q,D,F,P,Q,U],c:[V,_]}=(0,c.A)(s,[X("ai-portal.cruise-canvas",{shadowOptions:!1})],[[G(),1,"taskId"],[G({attribute:!1}),1,"task"],[G({attribute:!1}),1,"jobs"],[J({type:"share"}),1,"shareEvent",e=>(0,u.A)(te,e),(e,t)=>(0,i.A)(te,e,t)]],0,(e=>se.has((0,o.A)(e))),p.ReactNextElement)),_()}}]);
|
|
2
|
-
//# sourceMappingURL=cruise-canvas.5203ef3a.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"chunks/cruise-canvas.5203ef3a.js","mappings":"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","sources":["webpack:///./src/cruise-canvas/index.tsx"],"sourcesContent":["// istanbul ignore file: experimental\nimport React, {\n memo,\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { createDecorators, type EventEmitter } from \"@next-core/element\";\nimport { ReactNextElement } from \"@next-core/react-element\";\nimport { handleHttpError } from \"@next-core/runtime\";\nimport \"@next-core/theme\";\nimport { initializeI18n } from \"@next-core/i18n\";\nimport classNames from \"classnames\";\nimport ResizeObserver from \"resize-observer-polyfill\";\nimport { select } from \"d3-selection\";\nimport { NS, locales } from \"./i18n.js\";\nimport styles from \"./styles.module.css\";\nimport { useZoom } from \"./useZoom.js\";\nimport type {\n SizeTuple,\n GraphNode,\n Job,\n RequirementGraphNode,\n JobGraphNode,\n TaskBaseDetail,\n GraphEdge,\n} from \"./interfaces.js\";\nimport { useAutoCenter } from \"./useAutoCenter.js\";\nimport { useLayout } from \"./useLayout.js\";\nimport { useTaskDetail } from \"./useTaskDetail.js\";\nimport { useTaskGraph } from \"./useTaskGraph.js\";\nimport { PlanProgress } from \"./PlanProgress/PlanProgress.js\";\nimport { ZoomBar } from \"./ZoomBar/ZoomBar.js\";\nimport { NodeStart } from \"./NodeStart/NodeStart.js\";\nimport { NodeRequirement } from \"./NodeRequirement/NodeRequirement.js\";\nimport { NodeInstruction } from \"./NodeInstruction/NodeInstruction.js\";\nimport { NodeJob } from \"./NodeJob/NodeJob.js\";\nimport { NodeEnd } from \"./NodeEnd/NodeEnd.js\";\nimport { CANVAS_PADDING_BOTTOM, DONE_STATES } from \"./constants.js\";\n\ninitializeI18n(NS, locales);\n\nconst { defineElement, property, event } = createDecorators();\n\nconst MemoizedNodeComponent = memo(NodeComponent);\n\nexport interface CruiseCanvasProps {\n taskId: string | undefined;\n task: TaskBaseDetail | undefined;\n jobs: Job[] | undefined;\n}\n\n/**\n * 构件 `ai-portal.cruise-canvas`\n */\nexport\n@defineElement(\"ai-portal.cruise-canvas\", {\n // Will wrap v2 bricks which don't support in shadow DOM.\n shadowOptions: false,\n})\nclass CruiseCanvas extends ReactNextElement implements CruiseCanvasProps {\n @property()\n accessor taskId: string | undefined;\n\n @property({ attribute: false })\n accessor task: TaskBaseDetail | undefined;\n\n @property({ attribute: false })\n accessor jobs: Job[] | undefined;\n\n @event({ type: \"share\" })\n accessor #shareEvent!: EventEmitter<void>;\n\n #onShare = () => {\n this.#shareEvent.emit();\n };\n\n render() {\n return (\n <CruiseCanvasComponent\n taskId={this.taskId}\n jobs={this.jobs}\n task={this.task}\n onShare={this.#onShare}\n />\n );\n }\n}\n\nexport interface CruiseCanvasComponentProps extends CruiseCanvasProps {\n onShare?: () => void;\n}\n\nexport function CruiseCanvasComponent({\n taskId,\n task: propTask,\n jobs: propJobs,\n onShare,\n}: CruiseCanvasComponentProps) {\n const rootRef = useRef<HTMLDivElement>(null);\n const {\n task: _task,\n jobs: _jobs,\n plan: _plan,\n error,\n humanInputRef,\n } = useTaskDetail(taskId);\n const task = taskId ? _task : propTask;\n const jobs = taskId ? _jobs : (propJobs ?? []);\n const plan = taskId ? _plan : propTask?.plan;\n const graph = useTaskGraph(task, jobs);\n const rawNodes = graph?.nodes;\n const rawEdges = graph?.edges;\n\n useEffect(() => {\n if (error) {\n handleHttpError(error);\n }\n }, [error]);\n\n const humanInput = useCallback(\n (jobId: string, input: string) => {\n humanInputRef.current?.(jobId, input);\n },\n [humanInputRef]\n );\n\n const [sizeMap, setSizeMap] = useState<Map<string, SizeTuple> | null>(null);\n const handleNodeResize = useCallback((id: string, size: SizeTuple | null) => {\n // Handle resize logic here\n setSizeMap((prev) => {\n if (!size) {\n if (!prev) {\n return null;\n }\n const newMap = new Map(prev);\n const deleted = newMap.delete(id);\n return deleted ? newMap : prev;\n }\n return prev ? new Map(prev).set(id, size) : new Map([[id, size]]);\n });\n }, []);\n\n const { sizeReady, nodes, edges } = useLayout({\n rawNodes,\n rawEdges,\n state: task?.state,\n sizeMap,\n });\n\n const { grabbing, transform, transformRef, zoomer /* , scaleRange */ } =\n useZoom({\n rootRef,\n zoomable: sizeReady,\n scrollable: sizeReady,\n pannable: sizeReady,\n });\n\n const { centered, setCentered, reCenterRef } = useAutoCenter({\n nodes,\n sizeReady,\n zoomer,\n rootRef,\n });\n\n const taskDone = DONE_STATES.includes(task?.state ?? \"working\");\n const taskLoading = !taskDone && nodes.length === 2;\n\n const nonLeafNodes = useMemo(() => {\n return new Set<string>(edges.map((edge) => edge.source));\n }, [edges]);\n\n const bottom = useMemo(() => {\n if (!sizeReady) {\n return null;\n }\n\n const leafNodes: GraphNode[] = [];\n for (const node of nodes) {\n if (!nonLeafNodes.has(node.id)) {\n leafNodes.push(node);\n }\n }\n if (leafNodes.length > 0) {\n const y1 = Math.max(\n ...leafNodes.map((node) => node.view!.y + node.view!.height)\n );\n return y1;\n }\n\n return null;\n }, [nodes, nonLeafNodes, sizeReady]);\n\n useEffect(() => {\n const root = rootRef.current;\n if (!root || bottom === null) {\n return;\n }\n const { offsetHeight } = root;\n const transform = transformRef.current;\n const transformedBottom = bottom * transform.k + transform.y;\n const diffY = offsetHeight - CANVAS_PADDING_BOTTOM - transformedBottom;\n if (diffY < 0) {\n // Make the latest node visible\n zoomer.translateBy(select(rootRef.current!), 0, diffY);\n }\n }, [bottom, transformRef, zoomer]);\n\n const handleReCenter = useCallback(() => {\n reCenterRef.current = true;\n setCentered(false);\n }, [reCenterRef, setCentered]);\n\n const handleScaleChange = useCallback(\n (scale: number) => {\n zoomer.scaleTo(select(rootRef.current!), scale);\n },\n [zoomer]\n );\n\n return (\n <>\n <div\n className={styles.root}\n ref={rootRef}\n style={{\n cursor: grabbing ? \"grabbing\" : \"grab\",\n }}\n >\n <div\n className={classNames(styles.canvas, {\n [styles.ready]: sizeReady && centered,\n })}\n style={{\n transform: `translate3d(${transform.x}px, ${transform.y}px, 0) scale(${transform.k})`,\n }}\n >\n <svg className={styles.edges}>\n {edges.map((edge) => (\n <path\n className={styles.edge}\n key={`${edge.source}-${edge.target}`}\n d={edge\n .points!.map(\n ({ x, y }, i) => `${i === 0 ? \"M\" : \"L\"}${x},${y}`\n )\n .join(\" \")}\n />\n ))}\n </svg>\n {nodes.map((node) => (\n <MemoizedNodeComponent\n key={node.id}\n id={node.id}\n type={node.type}\n content={(node as RequirementGraphNode).content}\n job={(node as JobGraphNode).job}\n state={node.state}\n startTime={task?.startTime}\n taskLoading={taskLoading}\n instructionLoading={\n node.type === \"instruction\" && !nonLeafNodes.has(node.id)\n }\n edges={edges}\n x={node.view?.x}\n y={node.view?.y}\n onResize={handleNodeResize}\n humanInput={humanInput}\n onShare={onShare}\n />\n ))}\n </div>\n </div>\n <div className={styles.widgets}>\n <PlanProgress plan={plan} />\n <ZoomBar\n scale={transform.k}\n onScaleChange={handleScaleChange}\n onReCenter={handleReCenter}\n />\n </div>\n </>\n );\n}\n\ninterface NodeComponentProps {\n id: string;\n type: GraphNode[\"type\"];\n edges: GraphEdge[];\n content?: string;\n job?: Job;\n state?: string;\n startTime?: number;\n taskLoading?: boolean;\n instructionLoading?: boolean;\n x?: number;\n y?: number;\n onResize: (id: string, size: SizeTuple | null) => void;\n humanInput?: (jobId: string, input: string) => void;\n onShare?: () => void;\n}\n\nfunction NodeComponent({\n id,\n type,\n state,\n job,\n content,\n startTime,\n taskLoading,\n instructionLoading,\n x,\n y,\n onResize,\n humanInput,\n onShare,\n}: NodeComponentProps) {\n const nodeRef = useRef<HTMLDivElement>(null);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const observer = new ResizeObserver(() => {\n onResize(id, [element.offsetWidth, element.offsetHeight]);\n });\n observer.observe(element);\n return () => {\n observer.disconnect();\n onResize(id, null);\n };\n }, [id, onResize]);\n\n useEffect(() => {\n const element = nodeRef.current;\n if (!element) {\n return;\n }\n const handleMouseDown = (e: MouseEvent) => {\n e.stopPropagation();\n };\n element.addEventListener(\"mousedown\", handleMouseDown);\n return () => {\n element.removeEventListener(\"mousedown\", handleMouseDown);\n };\n }, []);\n\n return (\n <div\n className={classNames(styles.node, {\n [styles.ready]: x != null && y != null,\n })}\n ref={nodeRef}\n style={{\n left: x,\n top: y,\n }}\n >\n {type === \"start\" ? (\n <NodeStart />\n ) : type === \"end\" ? (\n <NodeEnd onShare={onShare} />\n ) : type === \"requirement\" ? (\n <NodeRequirement\n content={content}\n startTime={startTime}\n loading={taskLoading}\n />\n ) : type === \"instruction\" ? (\n <NodeInstruction\n content={job!.instruction}\n loading={instructionLoading}\n />\n ) : type === \"job\" ? (\n <NodeJob state={state} job={job!} humanInput={humanInput} />\n ) : (\n <div className={`${styles[\"node-default\"]} ${styles[\"size-medium\"]}`}>\n {`Unknown job type: \"${type}\"`}\n </div>\n )}\n </div>\n );\n}\n"],"names":["initializeI18n","NS","locales","defineElement","property","event","createDecorators","MemoizedNodeComponent","memo","NodeComponent","_CruiseCanvas","_A","WeakMap","_B","_C","_D","_CruiseCanvas_brand","WeakSet","_onShare","CruiseCanvas","ReactNextElement","constructor","arguments","_classPrivateMethodInitSpec","_classPrivateFieldInitSpec","_init_taskId","_init_extra_taskId","_init_task","_init_extra_task","_init_jobs","_init_extra_jobs","_init_shareEvent","_init_extra_shareEvent","_classPrivateGetter","this","_get_shareEvent","emit","taskId","_classPrivateFieldGet","v","_classPrivateFieldSet","task","jobs","render","React","CruiseCanvasComponent","onShare","_ref","_task$state","propTask","propJobs","rootRef","useRef","_task","_jobs","plan","_plan","error","humanInputRef","useTaskDetail","graph","useTaskGraph","rawNodes","nodes","rawEdges","edges","useEffect","handleHttpError","humanInput","useCallback","jobId","input","_humanInputRef$curren","current","call","sizeMap","setSizeMap","useState","handleNodeResize","id","size","prev","newMap","Map","delete","set","sizeReady","useLayout","state","grabbing","transform","transformRef","zoomer","useZoom","zoomable","scrollable","pannable","centered","setCentered","reCenterRef","useAutoCenter","taskLoading","DONE_STATES","includes","length","nonLeafNodes","useMemo","Set","map","edge","source","bottom","leafNodes","node","has","push","Math","max","view","y","height","root","offsetHeight","transformedBottom","k","diffY","CANVAS_PADDING_BOTTOM","translateBy","select","handleReCenter","handleScaleChange","scale","scaleTo","className","styles","ref","style","cursor","classNames","canvas","ready","x","key","target","d","points","_ref2","i","join","_node$view","_node$view2","type","content","job","startTime","instructionLoading","onResize","widgets","PlanProgress","ZoomBar","onScaleChange","onReCenter","_ref3","nodeRef","element","observer","ResizeObserver","offsetWidth","observe","disconnect","handleMouseDown","e","stopPropagation","addEventListener","removeEventListener","left","top","NodeStart","NodeEnd","NodeRequirement","loading","NodeInstruction","instruction","NodeJob","_CruiseCanvas2","_set_shareEvent","c","_initClass","_applyDecs","shadowOptions","attribute","o","_","_checkInRHS"],"sourceRoot":""}
|
package/dist/images/e7d89ec3.png
DELETED
|
Binary file
|