n8n-editor-ui 1.97.1 → 1.98.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/dist/assets/{AnimatedSpinner-15ZZp0OO.js → AnimatedSpinner-BiugD1ff.js} +1 -1
  2. package/dist/assets/{AnnotationTagsDropdown.ee.vue_vue_type_script_setup_true_lang-CrF4ktlo.js → AnnotationTagsDropdown.ee.vue_vue_type_script_setup_true_lang-BChDakRF.js} +1 -1
  3. package/dist/assets/{AuthView-64US-Z-m.js → AuthView-D3YwZZ3s.js} +2 -2
  4. package/dist/assets/{CanvasChatSwitch-CaiSjHFG.css → AuthView-jgkkdJYL.css} +29 -90
  5. package/dist/assets/{ChangePasswordView-Y_vO8rQ4.js → ChangePasswordView-CItQkQJg.js} +3 -3
  6. package/dist/assets/CollectionParameter-Bm8EojJq.js +4 -0
  7. package/dist/assets/{CredentialsView-B90NtMag.js → CredentialsView-DyMOfI6f.js} +7 -7
  8. package/dist/assets/DemoFooter-Dy9DQTdo.js +22 -0
  9. package/dist/assets/{ErrorView-B5-OZKdh.js → ErrorView-BC6y15Eg.js} +1 -1
  10. package/dist/assets/{EvaluationsRootView-6cGJTYGC.js → EvaluationsRootView-BbnDfLFy.js} +25 -18
  11. package/dist/assets/{EvaluationsView-DkIkcLrr.js → EvaluationsView-Qz7rd_By.js} +3 -3
  12. package/dist/assets/{ExecutionsTime--_6xBkkx.css → ExecutionsTime-BDLkVZem.css} +25 -17
  13. package/dist/assets/{ExecutionsTime.vue_vue_type_script_setup_true_lang-hCFNZKpq.js → ExecutionsTime.vue_vue_type_script_setup_true_lang-mrrUdf3t.js} +52 -15
  14. package/dist/assets/{ExecutionsView-cA-SzEOo.js → ExecutionsView-AgniDaEH.js} +8 -8
  15. package/dist/assets/{FileSaver.min-Bv-Q_h7m.js → FileSaver.min-BUciI8xL.js} +1 -1
  16. package/dist/assets/{FixedCollectionParameter-CgLfAVkQ.css → FixedCollectionParameter-DjlaZyUQ.css} +18 -18
  17. package/dist/assets/{FixedCollectionParameter-3cfdvUwK.js → FixedCollectionParameter-NPVvBV3e.js} +2 -2
  18. package/dist/assets/{ForgotMyPasswordView-Cv7uhij6.js → ForgotMyPasswordView-BKsk9OLH.js} +3 -3
  19. package/dist/assets/{InsightsChartAverageRuntime-Cr7taDDn.js → InsightsChartAverageRuntime-Dg7z0rOa.js} +4 -4
  20. package/dist/assets/{InsightsChartFailed-Cm5FrmfQ.js → InsightsChartFailed-i4tYyVRH.js} +4 -4
  21. package/dist/assets/{InsightsChartFailureRate-Ci-cBou0.js → InsightsChartFailureRate-BcWGne0C.js} +4 -4
  22. package/dist/assets/{InsightsChartTimeSaved-CMBBA9I4.js → InsightsChartTimeSaved-DugTjxnw.js} +4 -4
  23. package/dist/assets/{InsightsChartTotal-Dxn2bjBB.js → InsightsChartTotal-DTB7kNLU.js} +4 -4
  24. package/dist/assets/{InsightsDashboard-BvqZMhnh.js → InsightsDashboard-By8MKK7g.js} +10 -10
  25. package/dist/assets/{InsightsPaywall-4Vl-4bws.js → InsightsPaywall-BX7wpP8k.js} +1 -1
  26. package/dist/assets/{InsightsSummary-CTzqNpAf.js → InsightsSummary-DBfE_9FW.js} +1 -1
  27. package/dist/assets/{InsightsTableWorkflows-DgCECSSh.js → InsightsTableWorkflows-Dqy8IF2I.js} +2 -2
  28. package/dist/assets/{Logo-B8GIjJ79.js → Logo-BT-1ZjZS.js} +1 -1
  29. package/dist/assets/{LogsPanel-CsNXIuce.js → LogsPanel-CvLCi2ll.js} +4862 -4640
  30. package/dist/assets/{LogsPanel-D7j-yJQx.css → LogsPanel-nh_D5duX.css} +913 -907
  31. package/dist/assets/{MainHeader-CGwvFs2B.css → MainHeader-BRl77CT3.css} +27 -26
  32. package/dist/assets/{MainHeader-B2RGao3U.js → MainHeader-DptCjd0U.js} +84 -94
  33. package/dist/assets/{MainSidebar-E0ePOcg-.js → MainSidebar-BdESTvVI.js} +32 -20
  34. package/dist/assets/{NodeCreation-B6jElzI2.js → NodeCreation-CNH2xciY.js} +3 -3
  35. package/dist/assets/{NodeCreator-Bd2BI_OU.js → NodeCreator-Bgs-It2X.js} +20 -5
  36. package/dist/assets/{NodeDetailsView-BLMLHNQw.js → NodeDetailsView-DQ4I8u72.js} +628 -2203
  37. package/dist/assets/{NodeDetailsView-6JHPI3t-.css → NodeDetailsView-DWA1ZgwG.css} +349 -1000
  38. package/dist/assets/{NodeView-BdvXMmMp.css → NodeView-Duifly4c.css} +1274 -32
  39. package/dist/assets/{NodeView-C4qNUqxt.js → NodeView-i5dNh-Et.js} +2817 -548
  40. package/dist/assets/{ProjectCardBadge-be4FNX6y.js → ProjectCardBadge-CpBBeiGZ.js} +1 -1
  41. package/dist/assets/{ProjectHeader-CsHp0dpi.js → ProjectHeader-CK7zlcmF.js} +2 -2
  42. package/dist/assets/{ProjectSettings-BgunHp-2.css → ProjectSettings-8tvaQJye.css} +9 -10
  43. package/dist/assets/{ProjectSettings-t5UigWKy.js → ProjectSettings-B8_C-09-.js} +9 -9
  44. package/dist/assets/{PushConnectionTracker.vue_vue_type_script_setup_true_lang-Dpfsxn-o.js → PushConnectionTracker.vue_vue_type_script_setup_true_lang-XrUyHArT.js} +1 -1
  45. package/dist/assets/{ResourcesListLayout-DLThke_K.js → ResourcesListLayout-BRxlSl_6.js} +2 -2
  46. package/dist/assets/{RunData-XsmLcFYS.css → RunData-B5_okvCv.css} +205 -205
  47. package/dist/assets/{RunData-u5uBr_cv.js → RunData-D6YmSB6p.js} +1085 -1632
  48. package/dist/assets/{RunDataJson-CeZYY8D_.js → RunDataJson-BtfKusCo.js} +6 -6
  49. package/dist/assets/{RunDataJsonActions-BRAsiSnM.js → RunDataJsonActions-CglQIRT9.js} +1 -1
  50. package/dist/assets/{RunDataParsedAiContent-C1lte0Et.js → RunDataParsedAiContent-DPcEKWtn.js} +4 -4
  51. package/dist/assets/{RunDataSearch-BP_FSk35.js → RunDataSearch-CIKPqFBd.js} +1 -1
  52. package/dist/assets/{RunDataTable-CQghTfxP.js → RunDataTable-jsoKHQg5.js} +2 -2
  53. package/dist/assets/{SamlOnboarding-CWTnplHM.js → SamlOnboarding-DmXYxVe5.js} +3 -3
  54. package/dist/assets/{SettingsApiView-BskWDsE-.js → SettingsApiView-Bv94CWU3.js} +1 -1
  55. package/dist/assets/{SettingsCommunityNodesView-JUjLtmC0.js → SettingsCommunityNodesView-CI8V-SCE.js} +4 -4
  56. package/dist/assets/{SettingsExternalSecrets-BOJ40YuL.js → SettingsExternalSecrets-HCqXt9HG.js} +1 -1
  57. package/dist/assets/{SettingsLdapView-CT-V5pbv.js → SettingsLdapView-B3yMhNoR.js} +1 -1
  58. package/dist/assets/{SettingsLogStreamingView-_G1aTzAD.js → SettingsLogStreamingView-CyDcg7pK.js} +1 -1
  59. package/dist/assets/{SettingsPersonalView-CwV8ImYG.css → SettingsPersonalView-Bt8bL5tJ.css} +19 -15
  60. package/dist/assets/{SettingsPersonalView-BzzZLVh4.js → SettingsPersonalView-Cjb8Yd0L.js} +58 -10
  61. package/dist/assets/{SettingsSourceControl-Bte_2m43.js → SettingsSourceControl-B4lNTCoc.js} +2 -2
  62. package/dist/assets/{SettingsSso-Di8rSq_x.js → SettingsSso-CTy78phb.js} +1 -1
  63. package/dist/assets/{SettingsUsageAndPlan-CwaYHjbQ.js → SettingsUsageAndPlan-CfHv2SML.js} +1 -1
  64. package/dist/assets/{SettingsUsersView-DQbemH_k.js → SettingsUsersView-D4szdW0Y.js} +1 -1
  65. package/dist/assets/{SettingsView-DhqdV7_S.js → SettingsView-BCs3728S.js} +1 -1
  66. package/dist/assets/{SetupView-BOZr75Am.js → SetupView-PB2fxBCd.js} +3 -3
  67. package/dist/assets/{SetupWorkflowCredentialsButton-DFtZhM9C.js → SetupWorkflowCredentialsButton-DgTQe_yd.js} +1 -1
  68. package/dist/assets/{SetupWorkflowFromTemplateView-CTMDcuGm.js → SetupWorkflowFromTemplateView-7pQX4cNJ.js} +3 -3
  69. package/dist/assets/{SigninView-DY-vQ0LU.js → SigninView-BqgxybCQ.js} +12 -4
  70. package/dist/assets/{SignoutView-B8rfrg6C.js → SignoutView-CTKn8Q77.js} +1 -1
  71. package/dist/assets/{SignupView-BxrYV76w.js → SignupView-D8_otRzJ.js} +3 -3
  72. package/dist/assets/{TemplateDetails-DVQ2nLZj.js → TemplateDetails-H2-eQcx6.js} +1 -1
  73. package/dist/assets/{TemplateList-DPouUB38.js → TemplateList-CRgrPugd.js} +1 -1
  74. package/dist/assets/{TemplatesCollectionView-O7noND46.js → TemplatesCollectionView-CNoC5FGF.js} +5 -5
  75. package/dist/assets/{TemplatesSearchView-Bg5DxRv0.js → TemplatesSearchView-BDiwWkwZ.js} +30 -3
  76. package/dist/assets/{TemplatesView-BnzdRWmO.js → TemplatesView-GnPEf_mW.js} +1 -1
  77. package/dist/assets/{TemplatesWorkflowView-B_6tDGsp.js → TemplatesWorkflowView-7E6jyqpd.js} +5 -5
  78. package/dist/assets/{VariablesView-BrzvF0ZW.css → VariablesView-2BSJPXRB.css} +5 -5
  79. package/dist/assets/{VariablesView-DzrhNxAe.js → VariablesView-6sWI8yGj.js} +5 -5
  80. package/dist/assets/{WorkerView-CC1X8IeJ.js → WorkerView-Mvump-QA.js} +6 -6
  81. package/dist/assets/{WorkflowActivator-C30ojCUO.js → WorkflowActivator-BaxuVQDl.js} +14 -261
  82. package/dist/assets/{WorkflowExecutionsPreview-D7jTJ8GL.css → WorkflowActivator-C0R6Yly0.css} +162 -160
  83. package/dist/assets/{WorkflowExecutionsInfoAccordion-XaZEx8v7.js → WorkflowExecutionsInfoAccordion-DM72fu7i.js} +3 -3
  84. package/dist/assets/{WorkflowExecutionsLandingPage-8aAYw87x.js → WorkflowExecutionsLandingPage-DX4kL6pX.js} +2 -2
  85. package/dist/assets/WorkflowExecutionsPreview-BgpOEXPG.css +711 -0
  86. package/dist/assets/WorkflowExecutionsPreview-C2vE7SHl.js +812 -0
  87. package/dist/assets/{WorkflowExecutionsView-DR67gC3V.js → WorkflowExecutionsView-CTxicDMq.js} +8 -9
  88. package/dist/assets/{WorkflowExecutionsView-CZziPgtr.css → WorkflowExecutionsView-_l8AgWIb.css} +2 -2
  89. package/dist/assets/{WorkflowHistory-eAJEV9yu.js → WorkflowHistory-CD-Fhy8m.js} +18 -18
  90. package/dist/assets/{WorkflowOnboardingView-BjyAt8Oq.js → WorkflowOnboardingView-DWzhpMMj.js} +1 -1
  91. package/dist/assets/{WorkflowPreview-BxWA_Uiv.js → WorkflowPreview-A5nTeLz1.js} +1 -1
  92. package/dist/assets/{WorkflowsView-iKkH1nVB.js → WorkflowsView-DCmyKz3u.js} +46 -50
  93. package/dist/assets/{WorkflowsView-CQvTAWQ0.css → WorkflowsView-meCWhW8Y.css} +21 -20
  94. package/dist/assets/canvas-viI6yjxT.js +5 -0
  95. package/dist/assets/{chartjs.utils-CC0SyVUG.js → chartjs.utils-DVxFoTPh.js} +2 -2
  96. package/dist/assets/{easyAiWorkflowUtils-H7-jyGZy.js → easyAiWorkflowUtils-CWag2afn.js} +1 -1
  97. package/dist/assets/{en-D5Q1-BWp.js → en-BcWgUFsO.js} +17 -4
  98. package/dist/assets/{global-link-actions-zn0GER90.js → global-link-actions-B10zAHg8.js} +1 -1
  99. package/dist/assets/{import-curl-D7BhanPS.js → import-curl-B1dF12h6.js} +1 -1
  100. package/dist/assets/{index-HDYArLT1.js → index--ag0tEQM.js} +58887 -67576
  101. package/dist/assets/{index-B4xpaMaK.css → index-B-xWz5mo.css} +418 -370
  102. package/dist/assets/{index-CAyQE60i.js → index-BNKFpYX3.js} +1 -1
  103. package/dist/assets/pickBy-Bnnxgs5-.js +27 -0
  104. package/dist/assets/{polyfills-J2x06Gdp.js → polyfills-deFGRMT9.js} +0 -44
  105. package/dist/assets/{templateActions-CxINaftd.js → templateActions-CXnj7CA4.js} +1 -1
  106. package/dist/assets/{useBeforeUnload-DkY263Ue.js → useBeforeUnload-CZLqOCP0.js} +1 -1
  107. package/dist/assets/{useExecutionDebugging-BrUGp6HK.js → useExecutionDebugging-CoJa-NM6.js} +1 -1
  108. package/dist/assets/{useExecutionHelpers-Dulw8xCc.js → useExecutionHelpers-97Ddzif0.js} +1 -1
  109. package/dist/assets/{useImportCurlCommand-CjFFwjFi.js → useImportCurlCommand-t6LpQGpC.js} +2 -2
  110. package/dist/assets/{useProjectPages-DGU7KQ6y.js → useProjectPages-C95x1s47.js} +1 -1
  111. package/dist/assets/{usePushConnection-4FO744xJ.js → usePushConnection-C1qgSYjB.js} +22 -23
  112. package/dist/assets/{useWorkflowActivate-CUShgia-.js → useWorkflowActivate-E5Lz7Bjd.js} +4 -3
  113. package/dist/index.html +3 -3
  114. package/package.json +1 -1
  115. package/tsconfig.json +9 -1
  116. package/vite.config.mts +10 -2
  117. package/dist/assets/AuthView-D4i2WDPk.css +0 -408
  118. package/dist/assets/CanvasChatSwitch-D1N7Xp_1.js +0 -275
  119. package/dist/assets/CollectionParameter-DOqrZmRA.js +0 -4
  120. package/dist/assets/DemoFooter-DpmRLCPd.js +0 -23
  121. package/dist/assets/RunDataAi-D9VLFXIf.css +0 -443
  122. package/dist/assets/RunDataAi-DZzXTVdi.js +0 -466
  123. package/dist/assets/WorkflowActivator-CL2wacc7.css +0 -1084
  124. package/dist/assets/WorkflowExecutionsPreview-CpAsFXP1.js +0 -683
  125. package/dist/assets/canvas-BzAUJmlt.js +0 -24
  126. package/dist/assets/pickBy-2p7dSPXv.js +0 -16
  127. package/dist/assets/useWorkflowSaving-oozcXWTy.js +0 -66
@@ -1,466 +0,0 @@
1
- import { p as parseAiContent, l as _sfc_main$3, n as getConsumedTokens, o as ViewSubExecution, f as formatTokenUsageCount, _ as _sfc_main$5, q as createAiData, r as getTreeNodeData, s as getReferencedData } from "./RunData-u5uBr_cv.js";
2
- import { d as defineComponent, r as ref, q as computed, by as NodeConnectionTypes, i as createElementBlock, g as openBlock, n as normalizeClass, k as createBaseVNode, e as createBlock, f as createCommentVNode, j as createVNode, m as unref, fz as FontAwesomeIcon, t as toDisplayString, fA as capitalize, bM as N8nRadioButtons, _ as _export_sfc, bz as useNodeTypesStore, Q as useWorkflowsStore, h as resolveComponent, bH as _sfc_main$4, w as withCtx, l as createTextVNode, c as useI18n, F as Fragment, D as renderList, X as watch, fB as ElTree, B as normalizeStyle } from "./index-HDYArLT1.js";
3
- import RunDataAi$1 from "./RunDataParsedAiContent-C1lte0Et.js";
4
- const _sfc_main$2 = /* @__PURE__ */ defineComponent({
5
- __name: "AiRunContentBlock",
6
- props: {
7
- runData: {},
8
- error: {}
9
- },
10
- setup(__props) {
11
- const props = __props;
12
- const isExpanded = ref(getInitialExpandedState());
13
- const renderType = ref("rendered");
14
- const parsedRun = computed(() => parseAiContent(props.runData.data ?? [], props.runData.type));
15
- const contentParsed = computed(
16
- () => parsedRun.value.some((item) => item.parsedContent?.parsed === true)
17
- );
18
- function getInitialExpandedState() {
19
- const collapsedTypes = {
20
- input: [
21
- NodeConnectionTypes.AiDocument,
22
- NodeConnectionTypes.AiTextSplitter
23
- ],
24
- output: [
25
- NodeConnectionTypes.AiDocument,
26
- NodeConnectionTypes.AiEmbedding,
27
- NodeConnectionTypes.AiTextSplitter,
28
- NodeConnectionTypes.AiVectorStore
29
- ]
30
- };
31
- return !collapsedTypes[props.runData.inOut].includes(props.runData.type);
32
- }
33
- function onBlockHeaderClick() {
34
- isExpanded.value = !isExpanded.value;
35
- }
36
- function onRenderTypeChange(value) {
37
- renderType.value = value;
38
- }
39
- return (_ctx, _cache) => {
40
- const _component_NodeErrorView = _sfc_main$3;
41
- return openBlock(), createElementBlock("div", {
42
- class: normalizeClass(_ctx.$style.block)
43
- }, [
44
- createBaseVNode("header", {
45
- class: normalizeClass(_ctx.$style.blockHeader),
46
- onClick: onBlockHeaderClick
47
- }, [
48
- createBaseVNode("button", {
49
- class: normalizeClass(_ctx.$style.blockToggle)
50
- }, [
51
- createVNode(unref(FontAwesomeIcon), {
52
- icon: isExpanded.value ? "angle-down" : "angle-right",
53
- size: "lg"
54
- }, null, 8, ["icon"])
55
- ], 2),
56
- createBaseVNode("p", {
57
- class: normalizeClass(_ctx.$style.blockTitle)
58
- }, toDisplayString(unref(capitalize)(_ctx.runData.inOut)), 3),
59
- contentParsed.value && !_ctx.error && isExpanded.value ? (openBlock(), createBlock(unref(N8nRadioButtons), {
60
- key: 0,
61
- size: "small",
62
- "model-value": renderType.value,
63
- class: normalizeClass(_ctx.$style.rawSwitch),
64
- options: [
65
- { label: "Rendered", value: "rendered" },
66
- { label: "JSON", value: "json" }
67
- ],
68
- "onUpdate:modelValue": onRenderTypeChange
69
- }, null, 8, ["model-value", "class"])) : createCommentVNode("", true)
70
- ], 2),
71
- createBaseVNode("main", {
72
- class: normalizeClass({
73
- [_ctx.$style.blockContent]: true,
74
- [_ctx.$style.blockContentExpanded]: isExpanded.value
75
- })
76
- }, [
77
- _ctx.error ? (openBlock(), createBlock(_component_NodeErrorView, {
78
- key: 0,
79
- error: _ctx.error,
80
- class: normalizeClass(_ctx.$style.error),
81
- "show-details": ""
82
- }, null, 8, ["error", "class"])) : (openBlock(), createBlock(RunDataAi$1, {
83
- key: 1,
84
- data: _ctx.runData.data,
85
- type: _ctx.runData.type,
86
- content: parsedRun.value,
87
- "render-type": renderType.value
88
- }, null, 8, ["data", "type", "content", "render-type"]))
89
- ], 2)
90
- ], 2);
91
- };
92
- }
93
- });
94
- const block = "_block_wafm4_123";
95
- const blockContent = "_blockContent_wafm4_130";
96
- const blockContentExpanded = "_blockContentExpanded_wafm4_134";
97
- const rawSwitch = "_rawSwitch_wafm4_138";
98
- const blockHeader = "_blockHeader_wafm4_148";
99
- const blockTitle = "_blockTitle_wafm4_161";
100
- const blockToggle = "_blockToggle_wafm4_168";
101
- const error = "_error_wafm4_176";
102
- const style0$2 = {
103
- block,
104
- blockContent,
105
- blockContentExpanded,
106
- rawSwitch,
107
- blockHeader,
108
- blockTitle,
109
- blockToggle,
110
- error
111
- };
112
- const cssModules$2 = {
113
- "$style": style0$2
114
- };
115
- const AiRunContentBlock = /* @__PURE__ */ _export_sfc(_sfc_main$2, [["__cssModules", cssModules$2]]);
116
- const _hoisted_1$1 = { key: 0 };
117
- const _hoisted_2$1 = { key: 1 };
118
- const _hoisted_3$1 = { key: 2 };
119
- const _sfc_main$1 = /* @__PURE__ */ defineComponent({
120
- __name: "RunDataAiContent",
121
- props: {
122
- inputData: {},
123
- contentIndex: {}
124
- },
125
- setup(__props) {
126
- const props = __props;
127
- const nodeTypesStore = useNodeTypesStore();
128
- const workflowsStore = useWorkflowsStore();
129
- const i18n = useI18n();
130
- const consumedTokensSum = computed(() => {
131
- return getConsumedTokens(outputRun.value);
132
- });
133
- function extractRunMeta(run) {
134
- const uiNode = workflowsStore.getNodeByName(props.inputData.node);
135
- const nodeType = nodeTypesStore.getNodeType(uiNode?.type ?? "");
136
- const runMeta2 = {
137
- startTimeMs: run.metadata.startTime,
138
- executionTimeMs: run.metadata.executionTime,
139
- node: nodeType,
140
- type: run.inOut,
141
- connectionType: run.type,
142
- subExecution: run.metadata?.subExecution
143
- };
144
- return runMeta2;
145
- }
146
- const outputRun = computed(() => {
147
- return props.inputData.data.find((r) => r.inOut === "output");
148
- });
149
- const runMeta = computed(() => {
150
- if (outputRun.value === void 0) {
151
- return;
152
- }
153
- return extractRunMeta(outputRun.value);
154
- });
155
- const executionRunData = computed(() => {
156
- return workflowsStore.getWorkflowExecution?.data?.resultData?.runData;
157
- });
158
- const outputError = computed(() => {
159
- return executionRunData.value?.[props.inputData.node]?.[props.inputData.runIndex]?.error;
160
- });
161
- return (_ctx, _cache) => {
162
- const _component_n8n_tooltip = resolveComponent("n8n-tooltip");
163
- const _component_n8n_info_tip = resolveComponent("n8n-info-tip");
164
- return openBlock(), createElementBlock("div", {
165
- class: normalizeClass(_ctx.$style.container)
166
- }, [
167
- createBaseVNode("header", {
168
- class: normalizeClass(_ctx.$style.header)
169
- }, [
170
- runMeta.value?.node ? (openBlock(), createBlock(_sfc_main$4, {
171
- key: 0,
172
- class: normalizeClass(_ctx.$style.nodeIcon),
173
- "node-type": runMeta.value.node,
174
- size: 20
175
- }, null, 8, ["class", "node-type"])) : createCommentVNode("", true),
176
- createBaseVNode("div", {
177
- class: normalizeClass(_ctx.$style.headerWrap)
178
- }, [
179
- createBaseVNode("p", {
180
- class: normalizeClass(_ctx.$style.title)
181
- }, toDisplayString(_ctx.inputData.node), 3),
182
- createBaseVNode("ul", {
183
- class: normalizeClass(_ctx.$style.meta)
184
- }, [
185
- runMeta.value?.startTimeMs ? (openBlock(), createElementBlock("li", _hoisted_1$1, toDisplayString(runMeta.value?.executionTimeMs) + "ms", 1)) : createCommentVNode("", true),
186
- runMeta.value?.startTimeMs ? (openBlock(), createElementBlock("li", _hoisted_2$1, [
187
- createVNode(_component_n8n_tooltip, null, {
188
- content: withCtx(() => [
189
- createTextVNode(toDisplayString(new Date(runMeta.value?.startTimeMs).toLocaleString()), 1)
190
- ]),
191
- default: withCtx(() => [
192
- createTextVNode(" " + toDisplayString(unref(i18n).baseText("runData.aiContentBlock.startedAt", {
193
- interpolate: {
194
- startTime: new Date(runMeta.value?.startTimeMs).toLocaleTimeString()
195
- }
196
- })), 1)
197
- ]),
198
- _: 1
199
- })
200
- ])) : createCommentVNode("", true),
201
- runMeta.value ? (openBlock(), createElementBlock("li", _hoisted_3$1, [
202
- createVNode(ViewSubExecution, {
203
- "task-metadata": runMeta.value,
204
- "display-mode": "ai",
205
- inline: true
206
- }, null, 8, ["task-metadata"])
207
- ])) : createCommentVNode("", true),
208
- (consumedTokensSum.value?.totalTokens ?? 0) > 0 ? (openBlock(), createElementBlock("li", {
209
- key: 3,
210
- class: normalizeClass(_ctx.$style.tokensUsage)
211
- }, [
212
- createTextVNode(toDisplayString(unref(i18n).baseText("runData.aiContentBlock.tokens", {
213
- interpolate: {
214
- count: unref(formatTokenUsageCount)(consumedTokensSum.value, "total")
215
- }
216
- })) + " ", 1),
217
- createVNode(_component_n8n_info_tip, {
218
- type: "tooltip",
219
- theme: "info-light",
220
- "tooltip-placement": "right"
221
- }, {
222
- default: withCtx(() => [
223
- createVNode(_sfc_main$5, { "consumed-tokens": consumedTokensSum.value }, null, 8, ["consumed-tokens"])
224
- ]),
225
- _: 1
226
- })
227
- ], 2)) : createCommentVNode("", true)
228
- ], 2)
229
- ], 2)
230
- ], 2),
231
- (openBlock(true), createElementBlock(Fragment, null, renderList(props.inputData.data, (run, index) => {
232
- return openBlock(), createElementBlock("main", {
233
- key: index,
234
- class: normalizeClass(_ctx.$style.content)
235
- }, [
236
- createVNode(AiRunContentBlock, {
237
- "run-data": run,
238
- error: run.inOut === "output" ? outputError.value : void 0
239
- }, null, 8, ["run-data", "error"])
240
- ], 2);
241
- }), 128))
242
- ], 2);
243
- };
244
- }
245
- });
246
- const container$1 = "_container_dypaw_2";
247
- const nodeIcon$1 = "_nodeIcon_dypaw_5";
248
- const header = "_header_dypaw_8";
249
- const headerWrap = "_headerWrap_dypaw_14";
250
- const title$1 = "_title_dypaw_18";
251
- const meta = "_meta_dypaw_25";
252
- const tokensUsage = "_tokensUsage_dypaw_41";
253
- const style0$1 = {
254
- container: container$1,
255
- nodeIcon: nodeIcon$1,
256
- header,
257
- headerWrap,
258
- title: title$1,
259
- meta,
260
- tokensUsage
261
- };
262
- const cssModules$1 = {
263
- "$style": style0$1
264
- };
265
- const RunDataAiContent = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["__cssModules", cssModules$1]]);
266
- const _hoisted_1 = ["data-tree-depth"];
267
- const _hoisted_2 = ["onClick"];
268
- const _hoisted_3 = ["textContent"];
269
- const _sfc_main = /* @__PURE__ */ defineComponent({
270
- __name: "RunDataAi",
271
- props: {
272
- node: {},
273
- runIndex: { default: 0 },
274
- slim: { type: Boolean },
275
- workflow: {}
276
- },
277
- setup(__props) {
278
- const props = __props;
279
- const workflowsStore = useWorkflowsStore();
280
- const nodeTypesStore = useNodeTypesStore();
281
- const selectedRun = ref([]);
282
- const i18n = useI18n();
283
- function isTreeNodeSelected(node) {
284
- return selectedRun.value.some((run) => run.node === node.node && run.runIndex === node.runIndex);
285
- }
286
- function toggleTreeItem(node) {
287
- node.expanded = !node.expanded;
288
- }
289
- function onItemClick(data) {
290
- const matchingRun = aiData.value?.find(
291
- (run) => run.node === data.node && run.runIndex === data.runIndex
292
- );
293
- if (!matchingRun) {
294
- selectedRun.value = [];
295
- return;
296
- }
297
- const selectedNodeRun = workflowsStore.getWorkflowResultDataByNodeName(data.node)?.[data.runIndex];
298
- if (!selectedNodeRun) {
299
- return;
300
- }
301
- selectedRun.value = [
302
- {
303
- node: data.node,
304
- runIndex: data.runIndex,
305
- data: getReferencedData(selectedNodeRun, true)
306
- }
307
- ];
308
- }
309
- function getNodeType(nodeName) {
310
- const node = workflowsStore.getNodeByName(nodeName);
311
- if (!node) {
312
- return null;
313
- }
314
- const nodeType = nodeTypesStore.getNodeType(node?.type);
315
- return nodeType;
316
- }
317
- function selectFirst() {
318
- if (executionTree.value.length && executionTree.value[0].children.length) {
319
- onItemClick(executionTree.value[0].children[0]);
320
- }
321
- }
322
- const aiData = computed(
323
- () => createAiData(props.node.name, props.workflow, workflowsStore.getWorkflowResultDataByNodeName)
324
- );
325
- const executionTree = computed(
326
- () => getTreeNodeData(props.node.name, props.workflow, aiData.value)
327
- );
328
- watch(() => props.runIndex, selectFirst, { immediate: true });
329
- return (_ctx, _cache) => {
330
- const _component_font_awesome_icon = resolveComponent("font-awesome-icon");
331
- const _component_n8n_tooltip = resolveComponent("n8n-tooltip");
332
- const _component_n8n_text = resolveComponent("n8n-text");
333
- return openBlock(), createElementBlock("div", {
334
- class: normalizeClass(_ctx.$style.container)
335
- }, [
336
- aiData.value.length > 0 ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
337
- createBaseVNode("div", {
338
- class: normalizeClass({ [_ctx.$style.tree]: true, [_ctx.$style.slim]: _ctx.slim })
339
- }, [
340
- createVNode(unref(ElTree), {
341
- data: executionTree.value,
342
- props: { label: "node" },
343
- "default-expand-all": "",
344
- indent: 12,
345
- "expand-on-click-node": false,
346
- "data-test-id": "lm-chat-logs-tree",
347
- onNodeClick: onItemClick
348
- }, {
349
- default: withCtx(({ node, data }) => [
350
- createBaseVNode("div", {
351
- class: normalizeClass({
352
- [_ctx.$style.treeNode]: true,
353
- [_ctx.$style.isSelected]: isTreeNodeSelected(data)
354
- }),
355
- "data-tree-depth": data.depth,
356
- style: normalizeStyle({ "--item-depth": data.depth })
357
- }, [
358
- data.children.length ? (openBlock(), createElementBlock("button", {
359
- key: 0,
360
- class: normalizeClass(_ctx.$style.treeToggle),
361
- onClick: ($event) => toggleTreeItem(node)
362
- }, [
363
- createVNode(_component_font_awesome_icon, {
364
- icon: node.expanded ? "angle-down" : "angle-right"
365
- }, null, 8, ["icon"])
366
- ], 10, _hoisted_2)) : createCommentVNode("", true),
367
- createVNode(_component_n8n_tooltip, {
368
- disabled: !_ctx.slim,
369
- placement: "right"
370
- }, {
371
- content: withCtx(() => [
372
- createTextVNode(toDisplayString(node.label), 1)
373
- ]),
374
- default: withCtx(() => [
375
- createBaseVNode("span", {
376
- class: normalizeClass(_ctx.$style.leafLabel)
377
- }, [
378
- createVNode(_sfc_main$4, {
379
- "node-type": getNodeType(data.node),
380
- size: 17,
381
- class: normalizeClass(_ctx.$style.nodeIcon)
382
- }, null, 8, ["node-type", "class"]),
383
- !_ctx.slim ? (openBlock(), createElementBlock("span", {
384
- key: 0,
385
- textContent: toDisplayString(node.label)
386
- }, null, 8, _hoisted_3)) : createCommentVNode("", true)
387
- ], 2)
388
- ]),
389
- _: 2
390
- }, 1032, ["disabled"])
391
- ], 14, _hoisted_1)
392
- ]),
393
- _: 1
394
- }, 8, ["data"])
395
- ], 2),
396
- createBaseVNode("div", {
397
- class: normalizeClass(_ctx.$style.runData)
398
- }, [
399
- selectedRun.value.length === 0 ? (openBlock(), createElementBlock("div", {
400
- key: 0,
401
- class: normalizeClass(_ctx.$style.empty)
402
- }, [
403
- createVNode(_component_n8n_text, { size: "large" }, {
404
- default: withCtx(() => [
405
- createTextVNode(toDisplayString(unref(i18n).baseText("ndv.output.ai.empty", {
406
- interpolate: {
407
- node: props.node.name
408
- }
409
- })), 1)
410
- ]),
411
- _: 1
412
- })
413
- ], 2)) : createCommentVNode("", true),
414
- (openBlock(true), createElementBlock(Fragment, null, renderList(selectedRun.value, (data, index) => {
415
- return openBlock(), createElementBlock("div", {
416
- key: `${data.node}__${data.runIndex}__index`,
417
- "data-test-id": "lm-chat-logs-entry"
418
- }, [
419
- createVNode(RunDataAiContent, {
420
- "input-data": data,
421
- "content-index": index
422
- }, null, 8, ["input-data", "content-index"])
423
- ]);
424
- }), 128))
425
- ], 2)
426
- ], 64)) : (openBlock(), createElementBlock("div", {
427
- key: 1,
428
- class: normalizeClass(_ctx.$style.noData)
429
- }, toDisplayString(unref(i18n).baseText("ndv.output.ai.waiting")), 3))
430
- ], 2);
431
- };
432
- }
433
- });
434
- const treeToggle = "_treeToggle_1qaq4_123";
435
- const leafLabel = "_leafLabel_1qaq4_131";
436
- const noData = "_noData_1qaq4_137";
437
- const empty = "_empty_1qaq4_145";
438
- const title = "_title_1qaq4_149";
439
- const tree = "_tree_1qaq4_123";
440
- const slim = "_slim_1qaq4_161";
441
- const runData = "_runData_1qaq4_165";
442
- const container = "_container_1qaq4_171";
443
- const nodeIcon = "_nodeIcon_1qaq4_198";
444
- const isSelected = "_isSelected_1qaq4_204";
445
- const treeNode = "_treeNode_1qaq4_208";
446
- const style0 = {
447
- treeToggle,
448
- leafLabel,
449
- noData,
450
- empty,
451
- title,
452
- tree,
453
- slim,
454
- runData,
455
- container,
456
- nodeIcon,
457
- isSelected,
458
- treeNode
459
- };
460
- const cssModules = {
461
- "$style": style0
462
- };
463
- const RunDataAi = /* @__PURE__ */ _export_sfc(_sfc_main, [["__cssModules", cssModules]]);
464
- export {
465
- RunDataAi as R
466
- };