n8n-editor-ui 1.117.1 → 1.118.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.build/cache-marker +1 -1
- package/.build/node-popularity.json +1824 -1824
- package/dist/assets/{AddDataTableModal-DVYo94d8.js → AddDataTableModal-zxWuqmjd.js} +14 -14
- package/dist/assets/{AnnotationTagsDropdown.ee-Cft-NxsO.js → AnnotationTagsDropdown.ee-eHW-3UoT.js} +3 -3
- package/dist/assets/{AuthView-bZFeQ0Sz.js → AuthView-ChkAJQce.js} +6 -6
- package/dist/assets/{Canvas-Bbx0exl8.css → Canvas-Bn6gWZ4a.css} +16 -155
- package/dist/assets/{Canvas-BYFVQSac.js → Canvas-C6GNMexh.js} +32 -34
- package/dist/assets/{ChangePasswordView-BywB2rzP.js → ChangePasswordView-Nm079kBG.js} +12 -12
- package/dist/assets/{ChatSidebar-v-XKvOxu.js → ChatSidebar-F_DQiqTc.js} +20 -19
- package/dist/assets/{ChatView-09XG3Dk0.js → ChatView-Bpfv5CaB.js} +382 -320
- package/dist/assets/{ChatView-Bevy5QGn.css → ChatView-tcBlz_g5.css} +176 -159
- package/dist/assets/CollectionParameter-bg5wO6z0.js +58 -0
- package/dist/assets/{CommunityNodeUpdateInfo-B4-BJ9C-.js → CommunityNodeUpdateInfo-vlTmL7RM.js} +9 -9
- package/dist/assets/{CopyInput-mq9nEw97.js → CopyInput-DC5_nXn2.js} +4 -4
- package/dist/assets/{CredentialIcon-OH0fpAxA.js → CredentialIcon-BcBcgIsH.js} +2 -2
- package/dist/assets/{CredentialsView-aOkMypi5.js → CredentialsView-BPSVyrpG.js} +34 -34
- package/dist/assets/{DataTableActions-_gs21hnV.js → DataTableActions-Cx76tjWJ.js} +7 -7
- package/dist/assets/{DataTableDetailsView-BYu4P-Hr.js → DataTableDetailsView-BGWJ7DaO.js} +20 -20
- package/dist/assets/{DataTableView-CvtkTBPj.js → DataTableView-DAaraaIS.js} +31 -31
- package/dist/assets/DemoFooter-Dxf2cm1O.js +71 -0
- package/dist/assets/{Draggable-CkbgujMO.js → Draggable-BQvrISN2.js} +1 -1
- package/dist/assets/{EmptySharedSectionActionBox-BOeowsQZ.js → EmptySharedSectionActionBox-Chhv6WKy.js} +4 -4
- package/dist/assets/{EnterpriseEdition.ee-CzoWraCB.js → EnterpriseEdition.ee-CS9batXq.js} +1 -1
- package/dist/assets/{EntityNotFound-B0SV29iE.js → EntityNotFound-CKlXW1IL.js} +4 -4
- package/dist/assets/{EntityUnAuthorised-CoZWCXH5.js → EntityUnAuthorised-DB0HgLOM.js} +4 -4
- package/dist/assets/{ErrorView-UEtEPk4G.js → ErrorView-BcG-b8ZO.js} +6 -6
- package/dist/assets/{EvaluationsRootView-C9Lxo7p1.js → EvaluationsRootView-p42ZUoIa.js} +23 -23
- package/dist/assets/{EvaluationsView-CyinuOCh.js → EvaluationsView-BEMEtmQ-.js} +17 -17
- package/dist/assets/{ExecutionsTime-Bu0AvifI.js → ExecutionsTime-DnWwIkdL.js} +9 -9
- package/dist/assets/{ExecutionsView-D6fcLPJa.js → ExecutionsView-BvXMj9Vu.js} +35 -35
- package/dist/assets/{ExternalSecretsProviderConnectionSwitch.ee-Db08XlKQ.js → ExternalSecretsProviderConnectionSwitch.ee-DsoWhFxH.js} +4 -4
- package/dist/assets/{FixedCollectionParameter-DhxxT9l5.css → FixedCollectionParameter-BkEju_IA.css} +18 -18
- package/dist/assets/{FixedCollectionParameter-xxCJtwbW.js → FixedCollectionParameter-CiWWNV7x.js} +50 -49
- package/dist/assets/{ForgotMyPasswordView-INpmT79L.js → ForgotMyPasswordView-DyxwrSiM.js} +12 -12
- package/dist/assets/{InsightsChartAverageRuntime-CXzgnKsT.js → InsightsChartAverageRuntime-B9_qwMgO.js} +11 -9
- package/dist/assets/{InsightsChartFailed-BEfI2q3j.js → InsightsChartFailed-D8rDUthj.js} +10 -8
- package/dist/assets/{InsightsChartFailureRate-8hM7KF7W.js → InsightsChartFailureRate-D7MEDAWL.js} +11 -9
- package/dist/assets/{InsightsChartTimeSaved-CTwHgk_9.js → InsightsChartTimeSaved-BjEX9cpj.js} +11 -9
- package/dist/assets/{InsightsChartTotal-Gpt1PbtN.js → InsightsChartTotal-f6iwgPv4.js} +10 -8
- package/dist/assets/InsightsDashboard-Bx8KpVtA.js +474 -0
- package/dist/assets/{InsightsDashboard-DtYvNa8r.css → InsightsDashboard-CXRybzGm.css} +43 -14
- package/dist/assets/{InsightsPaywall-nCZwKXbw.js → InsightsPaywall-ChwaaAze.js} +13 -13
- package/dist/assets/{InsightsSummary-GdLBEqo5.js → InsightsSummary-B_Sl6ewi.js} +12 -11
- package/dist/assets/{InsightsTableWorkflows-B_bn_DTB.js → InsightsTableWorkflows-B6X6oYiV.js} +13 -13
- package/dist/assets/{ItemsRenderer-CpfjRROV.js → ItemsRenderer-CBKvYrWq.js} +8 -8
- package/dist/assets/{KeyboardShortcutTooltip-BdbqKcZA.js → KeyboardShortcutTooltip-CXKgjDIT.js} +1 -1
- package/dist/assets/{LogsPanel-0ka1r_T5.js → LogsPanel-C9ihuzgY.js} +21 -21
- package/dist/assets/LogsPanel-CblMd42Q.js +58 -0
- package/dist/assets/{MainHeader-CjncWNC2.js → MainHeader-CmU7j5GG.js} +49 -48
- package/dist/assets/{MainSidebar-DozJE7kh.css → MainSidebar-BqoiqeXY.css} +1 -1
- package/dist/assets/{MainSidebar-CI0aaeYj.js → MainSidebar-BxPyEMiS.js} +39 -41
- package/dist/assets/{MainSidebarUserArea-CcC1zpT9.js → MainSidebarUserArea-ByBQ0UAN.js} +5 -5
- package/dist/assets/{Modal-ykm6-05k.js → Modal-3SRv9esg.js} +5 -5
- package/dist/assets/{ModalDrawer-Dm48n_ZC.js → ModalDrawer-D09_H3WU.js} +6 -6
- package/dist/assets/{NDVEmptyState-B3G-aOnE.js → NDVEmptyState-CFiiknri.js} +1 -1
- package/dist/assets/{NodeCreation-DS6o5PZd.js → NodeCreation-u6TbXLrA.js} +45 -44
- package/dist/assets/{NodeCreator-DPBBmzY0.js → NodeCreator-BXGYbkZf.js} +28 -28
- package/dist/assets/{NodeDetailsView-C-Yctp8n.js → NodeDetailsView-ZROQTwH7.js} +65 -64
- package/dist/assets/{NodeDetailsViewV2-hfBepMQ_.js → NodeDetailsViewV2-FP7sM1NB.js} +66 -65
- package/dist/assets/{NodeIcon-DWZobr7N.js → NodeIcon-DbpKADJJ.js} +2 -2
- package/dist/assets/{NodeSettings-CbSfTD_z.css → NodeSettings-B50suDD9.css} +37 -37
- package/dist/assets/{NodeSettings-hOuqwBgl.js → NodeSettings-C7FfbVQv.js} +21 -21
- package/dist/assets/{NodeView-COxmTGmq.js → NodeView-DJ75lhF1.js} +73 -69
- package/dist/assets/{ParameterInputList-Brizqu8u.css → ParameterInputList-aGPYvt18.css} +23 -23
- package/dist/assets/{ParameterInputList-8NsJMTSZ.js → ParameterInputList-gPv74p0o.js} +51 -1418
- package/dist/assets/{PrebuiltAgentTemplatesView-DIEMhkhf.js → PrebuiltAgentTemplatesView-CPHRp9d1.js} +15 -15
- package/dist/assets/{ProjectBreadcrumb-Kpp4zO_E.js → ProjectBreadcrumb-HQc8Y6pX.js} +4 -4
- package/dist/assets/{ProjectCardBadge-Cg0eNODx.js → ProjectCardBadge-DhvyVuW1.js} +5 -5
- package/dist/assets/{ProjectHeader-Cis2-cvI.js → ProjectHeader-CVo15mE_.js} +11 -13
- package/dist/assets/{ProjectIcon-Zi9nHDAv.js → ProjectIcon-Doey-RQc.js} +1 -1
- package/dist/assets/{ProjectRoleView-ulnXe6y-.js → ProjectRoleView-CcTSQCDB.js} +13 -13
- package/dist/assets/{ProjectRolesView-CisxHCmE.js → ProjectRolesView-B1bJiMcv.js} +16 -16
- package/dist/assets/{ProjectSettings-C_5TOZR6.js → ProjectSettings-CkiVn4IE.js} +24 -24
- package/dist/assets/{ProjectSharing-DQIvkzbR.js → ProjectSharing-BEoNZXWQ.js} +18 -12
- package/dist/assets/{ProjectSharing-BbWB7xaB.css → ProjectSharing-DsD3YT5P.css} +9 -6
- package/dist/assets/{ProjectVariables-BhrQh1fU.js → ProjectVariables-XgLTDYWe.js} +33 -33
- package/dist/assets/{PushConnectionTracker-DjwHo6zH.js → PushConnectionTracker-B8U5jb2a.js} +3 -3
- package/dist/assets/{ResourcesListLayout-BXR1TD2S.js → ResourcesListLayout-Dsx1VsiN.js} +10 -10
- package/dist/assets/{RunDataHtml-DCZENNJ3.js → RunDataHtml-DCb1Egc3.js} +1 -1
- package/dist/assets/{RunDataJson-B7Qi0Fwb.js → RunDataJson-DE42Mwzq.js} +14 -14
- package/dist/assets/{RunDataJsonActions-Cf4AhBbU.js → RunDataJsonActions-BTkggY4p.js} +12 -12
- package/dist/assets/{RunDataParsedAiContent-Yuc6X4cv.js → RunDataParsedAiContent-KxWt3HUI.js} +8 -8
- package/dist/assets/RunDataParsedAiContent-wJyf5Rsy.js +25 -0
- package/dist/assets/{RunDataSearch-_Nxwf9LZ.js → RunDataSearch-CBirDE7f.js} +7 -7
- package/dist/assets/{RunDataTable-BDVC2VC6.js → RunDataTable-DYt1Fkzz.js} +14 -14
- package/dist/assets/{SamlOnboarding-CSfUs6QI.js → SamlOnboarding-Cpwf2P16.js} +12 -12
- package/dist/assets/{SaveButton-BuPg71pa.js → SaveButton-C2Gkwcd6.js} +6 -5
- package/dist/assets/{SelectedItemsInfo-BlKBaWS2.js → SelectedItemsInfo-BO9w2ntq.js} +2 -2
- package/dist/assets/{SettingsApiView-CFQr7adI.js → SettingsApiView-RqjYRzOu.js} +17 -17
- package/dist/assets/{SettingsCommunityNodesView-ChN1DOwy.js → SettingsCommunityNodesView-CrY_Cdll.js} +33 -32
- package/dist/assets/{SettingsExternalSecrets-CA6AF0fh.js → SettingsExternalSecrets-D4NwV7eZ.js} +15 -15
- package/dist/assets/{SettingsLdapView-xJBgTuPV.js → SettingsLdapView-DK1CISMa.js} +18 -18
- package/dist/assets/{SettingsLogStreamingView-CCGZ93oT.js → SettingsLogStreamingView-CKd4kHKk.js} +17 -17
- package/dist/assets/{SettingsMCPView-DUq-jTbA.js → SettingsMCPView-BBsH7xGg.js} +35 -35
- package/dist/assets/{SettingsPersonalView-CdXnkcL4.js → SettingsPersonalView-BuRaIsdm.js} +13 -13
- package/dist/assets/{SettingsProvisioningView-B_XNMwQH.js → SettingsProvisioningView-SzLNb4Qo.js} +10 -10
- package/dist/assets/{SettingsSourceControl-9dFG3DD_.js → SettingsSourceControl-B7hg6-GG.js} +17 -17
- package/dist/assets/{SettingsSso-BTZb-Xfy.js → SettingsSso-BxCxR3wV.js} +18 -18
- package/dist/assets/{SettingsUsageAndPlan-pgv4h6gH.js → SettingsUsageAndPlan-DFJos9P4.js} +16 -16
- package/dist/assets/{SettingsUsersView-D_BEWhH-.js → SettingsUsersView-DyEDhF0q.js} +18 -18
- package/dist/assets/{SettingsView-DuEsKUBw.js → SettingsView-Do6kHuex.js} +8 -8
- package/dist/assets/{SetupTemplateFormStep-t8XAe-h6.js → SetupTemplateFormStep-BC6Gv9Yn.js} +6 -6
- package/dist/assets/{SetupView-DRQtANl_.js → SetupView-B5VLMQdy.js} +12 -12
- package/dist/assets/{SetupWorkflowCredentialsButton-Bo0xTtQX.js → SetupWorkflowCredentialsButton-Sj0qCAav.js} +9 -9
- package/dist/assets/{SetupWorkflowFromTemplateView-KJNwWECU.js → SetupWorkflowFromTemplateView-yiqZFDT5.js} +18 -18
- package/dist/assets/{SigninView-D-KjF9x2.js → SigninView-B4TcSDoQ.js} +13 -13
- package/dist/assets/{SignoutView-C2zIR9h2.js → SignoutView-33NqF1r1.js} +9 -9
- package/dist/assets/{SignupView-BrIIgYwe.js → SignupView-C9yQZPU6.js} +12 -12
- package/dist/assets/{TagsDropdown-FI9N3wWY.js → TagsDropdown-CBK5Jbvx.js} +5 -5
- package/dist/assets/{TemplateDetails-BD9LzeJP.js → TemplateDetails-_9SG9Ptr.js} +7 -7
- package/dist/assets/{TemplateList-DYDGVNm6.js → TemplateList-DciGHvZb.js} +5 -5
- package/dist/assets/{TemplatesCollectionView-7Em6x0H2.js → TemplatesCollectionView--u6YfGq2.js} +20 -20
- package/dist/assets/{TemplatesSearchView-B5r7fChO.js → TemplatesSearchView-DdLKh1uT.js} +18 -18
- package/dist/assets/{TemplatesView-Q6pyswdm.js → TemplatesView-FCDPW2Yq.js} +3 -3
- package/dist/assets/{TemplatesWorkflowView-iWPKDJXq.js → TemplatesWorkflowView-CzE7VNEW.js} +22 -22
- package/dist/assets/{TestRunDetailView-DuetwU4N.js → TestRunDetailView-BePevBGV.js} +15 -15
- package/dist/assets/{TimeAgo-DEyMdv_4.js → TimeAgo-BbJFpIo5.js} +2 -2
- package/dist/assets/{TriggerPanel-CCOwZTzP.js → TriggerPanel-Bo5r6zd1.js} +18 -18
- package/dist/assets/{TriggerPanel-BRJZvqDX.css → TriggerPanel-D5WejHyJ.css} +4 -4
- package/dist/assets/{VariablesUsageBadge-zKwYrza9.js → VariablesUsageBadge-egc5OixT.js} +4 -4
- package/dist/assets/{VariablesView-DmwLct-0.js → VariablesView-oHNpwfBn.js} +25 -25
- package/dist/assets/{VirtualSchema-CGj7t6bD.js → VirtualSchema-7sIAPeE0.js} +74 -49
- package/dist/assets/{VirtualSchema-DSZB6gKx.css → VirtualSchema-CSh2c6Ec.css} +42 -46
- package/dist/assets/VirtualSchema-_6DLXPlB.js +43 -0
- package/dist/assets/{VueMarkdown-D7xE_eXp.js → VueMarkdown-70GnkI0W.js} +1 -1
- package/dist/assets/{WorkerView-BwDWY13b.js → WorkerView-D8am2TKI.js} +38 -37
- package/dist/assets/{WorkflowActivator-BPu-5jGT.js → WorkflowActivator-CbrL5beg.js} +8 -8
- package/dist/assets/{WorkflowExecutionsInfoAccordion-ChPTNNr6.js → WorkflowExecutionsInfoAccordion-Cb62PR2q.js} +7 -7
- package/dist/assets/{WorkflowExecutionsLandingPage-BkvLesWr.js → WorkflowExecutionsLandingPage-DbwtOrCN.js} +18 -18
- package/dist/assets/{WorkflowExecutionsPreview-Wxwu0ypU.js → WorkflowExecutionsPreview-BS7_jcuB.js} +22 -22
- package/dist/assets/{WorkflowExecutionsView-C-YCZ8ag.js → WorkflowExecutionsView-DYDAaUZI.js} +34 -34
- package/dist/assets/{WorkflowHistory-DwPW_uDM.js → WorkflowHistory-BwpkfMMS.js} +16 -16
- package/dist/assets/{WorkflowOnboardingView-BmRX_2z1.js → WorkflowOnboardingView-aMUbBMqV.js} +8 -8
- package/dist/assets/{WorkflowPreview-CdK31o_p.js → WorkflowPreview-B48ruNsM.js} +5 -5
- package/dist/assets/{WorkflowTagsDropdown-DHncNdSD.js → WorkflowTagsDropdown-D2XbYd5V.js} +3 -3
- package/dist/assets/{WorkflowsView-GQkhZx2C.js → WorkflowsView-DiNDMl-G.js} +49 -49
- package/dist/assets/{_MapCache-CaP4mhI9.js → _MapCache-BGBKpT5S.js} +7 -2
- package/dist/assets/{apiKeys.store-B-gq_pnY.js → apiKeys.store-BVgdNKhA.js} +1 -1
- package/dist/assets/{assistant.store-CaKAjqDa.js → assistant.store-Bifc8qm3.js} +8 -6
- package/dist/assets/{auth.eventBus-C4nOf_EB.js → auth.eventBus-CUpasXbj.js} +1 -1
- package/dist/assets/{chartjs.utils-CQGs2abL.js → chartjs.utils-DrHDj0Lr.js} +3 -3
- package/dist/assets/{chatPanel.store-D7Rip84v.js → chatPanel.store-CGEgwWy1.js} +4 -4
- package/dist/assets/{cloudPlan.store-DVjbdiNL.js → cloudPlan.store-BJqRknNR.js} +2 -2
- package/dist/assets/{col-DdVTHF55.js → col-b1w4xo57.js} +3 -3
- package/dist/assets/{constants-yBDcqULv.js → constants-CO7BXe8z.js} +509 -515
- package/dist/assets/{constants-BlMVf5I9.js → constants-DlQs6Cav.js} +2 -1
- package/dist/assets/{core-QrkR8HgP.js → core-CGHB7oTc.js} +1 -1
- package/dist/assets/{dataTable.store-CqCrYCu5.js → dataTable.store-ttcUlJRw.js} +2 -2
- package/dist/assets/{date-picker-DBrcn5hn.js → date-picker-YLC0sjSf.js} +3 -3
- package/dist/assets/{dateFormatter-DFjVBgCR.js → dateFormatter-jkly8a5N.js} +1 -1
- package/dist/assets/{dialog-BA_5sIqy.js → dialog-B1U4ND70.js} +4 -4
- package/dist/assets/{dist-DQo7s2CD.js → dist-BCqe3G7U.js} +1 -1
- package/dist/assets/{es-C9hyaXz6.js → es-BO7MlKL2.js} +1 -1
- package/dist/assets/{evaluation.constants-BLZ8xr4X.js → evaluation.constants-Bk1c697W.js} +3 -3
- package/dist/assets/{executions.store-CQlrw6PV.js → executions.store-BK5GLhI-.js} +1 -1
- package/dist/assets/{externalSecrets.ee.store-BMH2q7Z9.js → externalSecrets.ee.store-DyO5hFK8.js} +2 -2
- package/dist/assets/{focusPanel.store-CSnLUdy8.js → focusPanel.store-Cakdvw91.js} +4 -4
- package/dist/assets/{folders.store-BcQ6Wp6V.js → folders.store-Cbs7HYLv.js} +2 -2
- package/dist/assets/{icon-bktrs2EQ.js → icon-C8yfF1LY.js} +1 -1
- package/dist/assets/{index-BN8cyC66.js → index-BLT1lCJl.js} +126 -106
- package/dist/assets/{index-DmWYvsgC.css → index-D9KM9gTZ.css} +24 -0
- package/dist/assets/{insights.constants-BkI0n967.js → insights.constants-DK2g3nnD.js} +1 -11
- package/dist/assets/{insights.store-RACppv9v.js → insights.store-m7dTgwU4.js} +5 -5
- package/dist/assets/{insights.utils-BwI_ySXw.js → insights.utils-7zZgNSKk.js} +12 -3
- package/dist/assets/{isEmpty-Bi_tkWnE.css → isEmpty-B-mcFJ04.css} +2 -2
- package/dist/assets/{isEmpty-CNCxvZuH.js → isEmpty-Dh4aNe51.js} +186 -83
- package/dist/assets/{languageModules-ByRkY5Ff.js → languageModules-B8UNBljm.js} +1 -1
- package/dist/assets/{logStreaming.store-B7UWuvIf.js → logStreaming.store-CkZizwRc.js} +1 -1
- package/dist/assets/{mcp.store-BysD0rVp.js → mcp.store-C8vagCPq.js} +2 -2
- package/dist/assets/{merge-BONzxfgw.js → merge-Db6rb1_m.js} +1 -1
- package/dist/assets/{nodeCreator.store-DH0zzXjr.js → nodeCreator.store-DKWP5T3f.js} +1832 -1832
- package/dist/assets/{nodeIcon-iL6AFnZi.js → nodeIcon-BAM1uNdC.js} +1 -1
- package/dist/assets/{nodeTransforms-BvfzWeb1.js → nodeTransforms-smKGxdJz.js} +2 -2
- package/dist/assets/{npsSurvey.store-B7_iNEDS.js → npsSurvey.store-D44ME1MU.js} +2 -2
- package/dist/assets/{orderBy-DnR31tty.js → orderBy-B8m2WvN5.js} +2 -2
- package/dist/assets/{overlay-CVAnTAPu.js → overlay-DeoWJ8oB.js} +2 -2
- package/dist/assets/{personalizedTemplatesV3.store-1DMQ5zuk.js → personalizedTemplatesV3.store-xAoq0hdB.js} +4 -4
- package/dist/assets/{pickBy-Du5IQGBK.js → pickBy-CsEPk_gZ.js} +3 -3
- package/dist/assets/{radio-D_JpEmub.js → radio-j4rSUoao.js} +3 -3
- package/dist/assets/{readyToRunWorkflows.store-CeAHy3Gw.js → readyToRunWorkflows.store-0tf5VDt7.js} +5 -5
- package/dist/assets/{readyToRunWorkflowsV2.store-L-gWAPRw.js → readyToRunWorkflowsV2.store-VvLyAD65.js} +8 -8
- package/dist/assets/retry-sDkwzrPY.js +23 -0
- package/dist/assets/{roles.store-NBXjdv6j.js → roles.store-ZwchRX8D.js} +2 -2
- package/dist/assets/{router-ZZpLYMBs.js → router-jJtZZKZh.js} +83 -82
- package/dist/assets/{schemaPreview.store-H_WmE5oY.js → schemaPreview.store--hX2TXb-.js} +2 -2
- package/dist/assets/{semver-DsJndgBW.js → semver-CqxA3iSr.js} +1 -1
- package/dist/assets/sourceControl.eventBus-B10rpVhp.js +3 -0
- package/dist/assets/{src-B3UiHJ-Q.css → src-C5a_PFvg.css} +322 -14
- package/dist/assets/{src-Dc6OvOR1.js → src-Cl0xZtCE.js} +6733 -826
- package/dist/assets/{sso.store-DrkAY9s8.js → sso.store-CUl7u_8B.js} +1 -1
- package/dist/assets/{table-0nn2Z9ZZ.js → table-B9oFv7WW.js} +3 -3
- package/dist/assets/{templateActions-jovoofZV.js → templateActions-0m3shEBq.js} +4 -4
- package/dist/assets/{templateTransforms-0i4sTnCn.js → templateTransforms-DAKKzDnq.js} +1 -1
- package/dist/assets/{templates.store-CPIqYFhQ.js → templates.store-DTZvTwkj.js} +3 -3
- package/dist/assets/{truncate-Zm7rqMgr.js → truncate-Dc79aML5.js} +1 -1
- package/dist/assets/{uniqBy-aD1YpiVl.js → uniqBy-BPM3FjgB.js} +1 -1
- package/dist/assets/{usage.store-j2Tik6Qj.js → usage.store-D55n_Sb8.js} +1 -1
- package/dist/assets/{useActions-DDl1M_ZA.js → useActions-CLFMsePu.js} +5 -5
- package/dist/assets/{useBeforeUnload-DF2JzJ4n.js → useBeforeUnload-BpdETqAC.js} +3 -3
- package/dist/assets/{useBugReporting-DgGaOS2n.js → useBugReporting-CtqZQ5ol.js} +9 -9
- package/dist/assets/{useCanvasOperations-D-rGx92q.js → useCanvasOperations-CArZAi8X.js} +14 -13
- package/dist/assets/{useChatHubSidebarState-CVPEM_x0.js → useChatHubSidebarState-B3pC_PWc.js} +27 -42
- package/dist/assets/{useClipboard-Bo6m_x4c.js → useClipboard-Ds1DthAm.js} +2 -2
- package/dist/assets/{useCommandBar-DpShriS8.js → useCommandBar-O5fVoTOU.js} +22 -22
- package/dist/assets/{useDebounce-BDOVCaxX.js → useDebounce-BRhQZVIC.js} +2 -2
- package/dist/assets/{useExecutionData-BIXnhI3s.js → useExecutionData-Dx2GMasN.js} +1 -1
- package/dist/assets/{useExecutionDebugging-u1qtWSuI.js → useExecutionDebugging-CQ0k4sDj.js} +7 -7
- package/dist/assets/{useExecutionHelpers-BGFecxse.js → useExecutionHelpers-Bjt-batF.js} +5 -5
- package/dist/assets/{useExternalHooks-zp0_PYje.js → useExternalHooks-DA3PzQce.js} +1 -1
- package/dist/assets/{useImportCurlCommand-ysDdbl5s.js → useImportCurlCommand-DlQ_fBtE.js} +20 -11
- package/dist/assets/{useKeybindings-C5aXNA-j.js → useKeybindings-CeZJtKID.js} +4 -4
- package/dist/assets/{useLogsTreeExpand-BpGJulE7.js → useLogsTreeExpand-jGcbObcQ.js} +12 -11
- package/dist/assets/{useMcp-B8mELqLq.js → useMcp-dgK39Qex.js} +3 -3
- package/dist/assets/{useMessage-D7zRrqdb.js → useMessage-BRYWi-M_.js} +5 -5
- package/dist/assets/{usePageRedirectionHelper-UBkr_KXQ.js → usePageRedirectionHelper-CHYQYVQk.js} +4 -4
- package/dist/assets/{usePinnedData-CyQ835zq.js → usePinnedData-wr8coWIe.js} +5 -5
- package/dist/assets/{useProjectPages-C-a7fzXH.js → useProjectPages-4anfp-hs.js} +2 -2
- package/dist/assets/{usePushConnection-B4lJil99.js → usePushConnection-BZ4Nfuk_.js} +11 -11
- package/dist/assets/{useRecentResources-9wPy7Jgo.js → useRecentResources-BONr7qgn.js} +7 -7
- package/dist/assets/{useRunWorkflow-C2eWaykT.js → useRunWorkflow-B0NRhnNX.js} +10 -31
- package/dist/assets/{useTelemetry-DMMCGp2b.js → useTelemetry-C-PPHLYt.js} +53 -22
- package/dist/assets/{useTelemetryContext-2dWn5z4h.js → useTelemetryContext-dbQiFzDe.js} +1 -1
- package/dist/assets/{useToast-C1ZpPbXg.js → useToast-DT24R-_J.js} +6 -6
- package/dist/assets/{useWorkflowActivate-CRGuGg0o.js → useWorkflowActivate-BN-oa5MP.js} +8 -8
- package/dist/assets/{useWorkflowSaving-hxklBko-.js → useWorkflowSaving-YMreJCAo.js} +9 -9
- package/dist/assets/{useWorkflowsCache-DtVpUl61.js → useWorkflowsCache-5wmMXakz.js} +1 -1
- package/dist/assets/{versions.store-BiGAlubj.js → versions.store-DKb-5qaR.js} +3 -3
- package/dist/assets/{vue-json-pretty-BlSK1oxV.js → vue-json-pretty-DiH9ZFoW.js} +1 -1
- package/dist/index.html +110 -108
- package/package.json +1 -1
- package/dist/assets/CollectionParameter-BD-RnHFm.js +0 -57
- package/dist/assets/DemoFooter-D25S1bju.js +0 -70
- package/dist/assets/InsightsDashboard-BzJVdpel.js +0 -348
- package/dist/assets/LogsPanel-BNpZ4w7p.js +0 -57
- package/dist/assets/RunDataParsedAiContent-GHYLhA2G.js +0 -25
- package/dist/assets/VirtualSchema-DCSy5rll.js +0 -42
- /package/dist/assets/{AnimatedSpinner-vlvkUC5d.js → AnimatedSpinner-DRB4A7Dx.js} +0 -0
- /package/dist/assets/{FileSaver.min-D8bnhVIu.js → FileSaver.min-CR_3Le5x.js} +0 -0
- /package/dist/assets/{PageViewLayout-CKhCcgRz.js → PageViewLayout-CCwb27rd.js} +0 -0
- /package/dist/assets/{RunDataHtml-BJNWCJaI.js → RunDataHtml-DOQ0pkg3.js} +0 -0
- /package/dist/assets/{TextWithHighlights-4Fm26J2a.js → TextWithHighlights-B8mQwCVK.js} +0 -0
- /package/dist/assets/{buttons.esm-jQ2As9fr.js → buttons.esm-CnepylvE.js} +0 -0
- /package/dist/assets/{chart-C2tFerhP.js → chart-inxSB4fp.js} +0 -0
- /package/dist/assets/{core-DfWDGJ3H.js → core-BfCr8skN.js} +0 -0
- /package/dist/assets/{exports-9spWG404.js → exports-RJH1xso1.js} +0 -0
- /package/dist/assets/{smartDecimal-Bi50OE4b.js → smartDecimal-BitNC0jz.js} +0 -0
- /package/dist/assets/{sortByProperty-qz-1s69w.js → sortByProperty-CUhVU03p.js} +0 -0
- /package/dist/assets/{vue-GniKVX87.js → vue-B27A1Apg.js} +0 -0
- /package/dist/assets/{xml-BZFrCZxf.js → xml-CcxXd9zY.js} +0 -0
|
@@ -1,132 +1,32 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/es-
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/es-BO7MlKL2.js","assets/core-BfCr8skN.js","assets/chunk-6z4oVpB-.js","assets/languageModules-B8UNBljm.js","assets/xml-CcxXd9zY.js"])))=>i.map(i=>d[i]);
|
|
2
2
|
import { o as __toESM } from "./chunk-6z4oVpB-.js";
|
|
3
3
|
import { C as computed, D as createElementBlock, E as createCommentVNode, G as nextTick, Gt as unref, It as ref, M as createVNode, P as defineComponent, Sn as toDisplayString, T as createBlock, Z as onMounted, _ as Fragment, _n as normalizeClass, _t as watch, bt as withCtx, et as openBlock, h as withModifiers, it as renderList, j as createTextVNode, mt as useTemplateRef, q as onBeforeMount, w as createBaseVNode, yn as normalizeStyle } from "./vue.runtime.esm-bundler-DDuXT-9r.js";
|
|
4
|
-
import { I as useSpeechRecognition, L as useSpeechSynthesis, M as useMediaQuery, P as useScroll, gt as useI18n, j as useLocalStorage } from "./_MapCache-
|
|
5
|
-
import {
|
|
4
|
+
import { I as useSpeechRecognition, L as useSpeechSynthesis, M as useMediaQuery, P as useScroll, g as onClickOutside, gt as useI18n, j as useLocalStorage } from "./_MapCache-BGBKpT5S.js";
|
|
5
|
+
import { Ct as N8nIconButton_default, Fn as N8nText_default, G as N8nOption_default, In as N8nButton_default, Nn as N8nHeading_default, Rn as N8nIcon_default, W as N8nSelect_default, bt as N8nInput_default, gt as require_markdown_it_link_attributes, ht as N8nTooltip_default, i as N8nScrollArea_default, k as N8nNavigationDropdown_default } from "./src-Cl0xZtCE.js";
|
|
6
6
|
import "./en-BYTsM8fR.js";
|
|
7
7
|
import { t as __vitePreload } from "./preload-helper-CR0ecmWK.js";
|
|
8
8
|
import { t as __plugin_vue_export_helper_default } from "./_plugin-vue_export-helper-BwBpWJRZ.js";
|
|
9
|
-
import { b as useRouter, x as createEventBus, y as useRoute } from "./truncate-
|
|
10
|
-
import "./icon-
|
|
11
|
-
import "./overlay-
|
|
9
|
+
import { b as useRouter, x as createEventBus, y as useRoute } from "./truncate-Dc79aML5.js";
|
|
10
|
+
import "./icon-C8yfF1LY.js";
|
|
11
|
+
import "./overlay-DeoWJ8oB.js";
|
|
12
12
|
import "./empty-BuGRxzl4.js";
|
|
13
|
-
import "./dialog-
|
|
14
|
-
import { Ht as useCredentialsStore, Li as useUIStore, ir as useUsersStore, kn as useDocumentTitle, yc as v4_default
|
|
15
|
-
import { t as useToast } from "./useToast-
|
|
13
|
+
import "./dialog-B1U4ND70.js";
|
|
14
|
+
import { Ht as useCredentialsStore, Li as useUIStore, ir as useUsersStore, kn as useDocumentTitle, yc as v4_default } from "./useTelemetry-C-PPHLYt.js";
|
|
15
|
+
import { t as useToast } from "./useToast-DT24R-_J.js";
|
|
16
16
|
import "./sanitize-html-BuXr7o4T.js";
|
|
17
17
|
import "./path-browserify-DsmB_HMK.js";
|
|
18
|
-
import {
|
|
19
|
-
import "./merge-
|
|
18
|
+
import { Go as LOCAL_STORAGE_CHAT_HUB_CREDENTIALS, Ko as LOCAL_STORAGE_CHAT_HUB_SELECTED_MODEL, Lr as nullType, Rr as recordType, cr as PROVIDER_CREDENTIAL_TYPE_MAP, lr as chatHubConversationModelSchema, ur as chatHubProviderSchema, zr as stringType } from "./constants-CO7BXe8z.js";
|
|
19
|
+
import "./merge-Db6rb1_m.js";
|
|
20
20
|
import "./dateformat-D7TIhVd4.js";
|
|
21
|
-
import "./useDebounce-
|
|
22
|
-
import "./useExternalHooks-
|
|
23
|
-
import
|
|
24
|
-
import { t as
|
|
25
|
-
import { t as
|
|
26
|
-
import {
|
|
27
|
-
import { t as
|
|
28
|
-
import { n as useChatStore, r as findOneFromModelsResponse, t as useChatHubSidebarState } from "./useChatHubSidebarState-
|
|
29
|
-
|
|
30
|
-
__name: "CredentialSelectorModal",
|
|
31
|
-
props: {
|
|
32
|
-
provider: {},
|
|
33
|
-
initialValue: {}
|
|
34
|
-
},
|
|
35
|
-
emits: ["select", "createNew"],
|
|
36
|
-
setup(__props, { emit: __emit }) {
|
|
37
|
-
const props = __props;
|
|
38
|
-
const emit = __emit;
|
|
39
|
-
const credentialsStore = useCredentialsStore();
|
|
40
|
-
const modalBus = ref(createEventBus());
|
|
41
|
-
const selectedCredentialId = ref(props.initialValue);
|
|
42
|
-
const availableCredentials = computed(() => {
|
|
43
|
-
return credentialsStore.getCredentialsByType(PROVIDER_CREDENTIAL_TYPE_MAP[props.provider]);
|
|
44
|
-
});
|
|
45
|
-
function onCredentialSelect(credentialId) {
|
|
46
|
-
selectedCredentialId.value = credentialId;
|
|
47
|
-
}
|
|
48
|
-
function onConfirm() {
|
|
49
|
-
if (selectedCredentialId.value) {
|
|
50
|
-
emit("select", props.provider, selectedCredentialId.value);
|
|
51
|
-
modalBus.value.emit("close");
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
function onCreateNew() {
|
|
55
|
-
emit("createNew", props.provider);
|
|
56
|
-
modalBus.value.emit("close");
|
|
57
|
-
}
|
|
58
|
-
function onCancel() {
|
|
59
|
-
modalBus.value.emit("close");
|
|
60
|
-
}
|
|
61
|
-
return (_ctx, _cache) => {
|
|
62
|
-
return openBlock(), createBlock(Modal_default, {
|
|
63
|
-
name: "chatCredentialSelector",
|
|
64
|
-
"event-bus": modalBus.value,
|
|
65
|
-
width: "50%",
|
|
66
|
-
center: true,
|
|
67
|
-
"max-width": "460px",
|
|
68
|
-
"min-height": "250px"
|
|
69
|
-
}, {
|
|
70
|
-
header: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.header) }, [createVNode(CredentialIcon_default, {
|
|
71
|
-
"credential-type-name": unref(PROVIDER_CREDENTIAL_TYPE_MAP)[_ctx.provider],
|
|
72
|
-
size: 24,
|
|
73
|
-
class: normalizeClass(_ctx.$style.icon)
|
|
74
|
-
}, null, 8, ["credential-type-name", "class"]), createBaseVNode("h2", { class: normalizeClass(_ctx.$style.title) }, "Select " + toDisplayString(unref(providerDisplayNames)[_ctx.provider]) + " Credential", 3)], 2)]),
|
|
75
|
-
content: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.content) }, [createVNode(unref(N8nText_default), {
|
|
76
|
-
size: "small",
|
|
77
|
-
color: "text-base"
|
|
78
|
-
}, {
|
|
79
|
-
default: withCtx(() => _cache[0] || (_cache[0] = [createTextVNode(" Choose an existing credential or create a new one ")])),
|
|
80
|
-
_: 1
|
|
81
|
-
}), createVNode(unref(N8nSelect_default), {
|
|
82
|
-
"model-value": selectedCredentialId.value,
|
|
83
|
-
size: "large",
|
|
84
|
-
placeholder: "Select credential...",
|
|
85
|
-
"onUpdate:modelValue": onCredentialSelect
|
|
86
|
-
}, {
|
|
87
|
-
default: withCtx(() => [(openBlock(true), createElementBlock(Fragment, null, renderList(availableCredentials.value, (credential) => {
|
|
88
|
-
return openBlock(), createBlock(unref(N8nOption_default), {
|
|
89
|
-
key: credential.id,
|
|
90
|
-
value: credential.id,
|
|
91
|
-
label: credential.name
|
|
92
|
-
}, null, 8, ["value", "label"]);
|
|
93
|
-
}), 128))]),
|
|
94
|
-
_: 1
|
|
95
|
-
}, 8, ["model-value"])], 2)]),
|
|
96
|
-
footer: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.footer) }, [createVNode(unref(N8nButton_default), {
|
|
97
|
-
type: "secondary",
|
|
98
|
-
onClick: onCreateNew
|
|
99
|
-
}, {
|
|
100
|
-
default: withCtx(() => _cache[1] || (_cache[1] = [createTextVNode(" Create New ")])),
|
|
101
|
-
_: 1
|
|
102
|
-
}), createBaseVNode("div", { class: normalizeClass(_ctx.$style.footerRight) }, [createVNode(unref(N8nButton_default), {
|
|
103
|
-
type: "tertiary",
|
|
104
|
-
onClick: onCancel
|
|
105
|
-
}, {
|
|
106
|
-
default: withCtx(() => _cache[2] || (_cache[2] = [createTextVNode(" Cancel ")])),
|
|
107
|
-
_: 1
|
|
108
|
-
}), createVNode(unref(N8nButton_default), {
|
|
109
|
-
type: "primary",
|
|
110
|
-
disabled: !selectedCredentialId.value,
|
|
111
|
-
onClick: onConfirm
|
|
112
|
-
}, {
|
|
113
|
-
default: withCtx(() => _cache[3] || (_cache[3] = [createTextVNode(" Select ")])),
|
|
114
|
-
_: 1
|
|
115
|
-
}, 8, ["disabled"])], 2)], 2)]),
|
|
116
|
-
_: 1
|
|
117
|
-
}, 8, ["event-bus"]);
|
|
118
|
-
};
|
|
119
|
-
}
|
|
120
|
-
});
|
|
121
|
-
var CredentialSelectorModal_vue_vue_type_style_index_0_lang_module_default = {
|
|
122
|
-
title: "_title_1hes0_123",
|
|
123
|
-
content: "_content_1hes0_129",
|
|
124
|
-
footer: "_footer_1hes0_136",
|
|
125
|
-
footerRight: "_footerRight_1hes0_143",
|
|
126
|
-
header: "_header_1hes0_148",
|
|
127
|
-
icon: "_icon_1hes0_154"
|
|
128
|
-
};
|
|
129
|
-
var CredentialSelectorModal_default = /* @__PURE__ */ __plugin_vue_export_helper_default(CredentialSelectorModal_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": CredentialSelectorModal_vue_vue_type_style_index_0_lang_module_default }]]);
|
|
21
|
+
import "./useDebounce-BRhQZVIC.js";
|
|
22
|
+
import "./useExternalHooks-DA3PzQce.js";
|
|
23
|
+
import "./retry-sDkwzrPY.js";
|
|
24
|
+
import { t as useClipboard } from "./useClipboard-Ds1DthAm.js";
|
|
25
|
+
import { t as Modal_default } from "./Modal-3SRv9esg.js";
|
|
26
|
+
import { t as CredentialIcon_default } from "./CredentialIcon-BcBcgIsH.js";
|
|
27
|
+
import { a as providerDisplayNames, i as MOBILE_MEDIA_QUERY, r as CHAT_VIEW, t as CHAT_CONVERSATION_VIEW } from "./constants-DlQs6Cav.js";
|
|
28
|
+
import { n as useChatStore, r as findOneFromModelsResponse, t as useChatHubSidebarState } from "./useChatHubSidebarState-B3pC_PWc.js";
|
|
29
|
+
import { t as VueMarkdown_default } from "./VueMarkdown-70GnkI0W.js";
|
|
130
30
|
var ModelSelector_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
131
31
|
__name: "ModelSelector",
|
|
132
32
|
props: {
|
|
@@ -135,55 +35,66 @@ var ModelSelector_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
|
|
|
135
35
|
credentialsName: {}
|
|
136
36
|
},
|
|
137
37
|
emits: ["change", "configure"],
|
|
138
|
-
setup(__props, { emit: __emit }) {
|
|
38
|
+
setup(__props, { expose: __expose, emit: __emit }) {
|
|
139
39
|
const props = __props;
|
|
140
40
|
const emit = __emit;
|
|
141
|
-
const
|
|
41
|
+
const dropdownRef = useTemplateRef("dropdownRef");
|
|
42
|
+
const menu = computed(() => chatHubProviderSchema.options.filter((provider) => provider !== "n8n").map((provider) => {
|
|
142
43
|
const models = props.models?.[provider].models ?? [];
|
|
143
44
|
const error = props.models?.[provider].error;
|
|
144
|
-
const modelOptions = models.length > 0 ? models.map((model) =>
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
45
|
+
const modelOptions = models.length > 0 ? models.map((model) => {
|
|
46
|
+
return {
|
|
47
|
+
id: `${provider}::${model.provider === "n8n" ? model.workflowId : model.model}`,
|
|
48
|
+
title: model.name,
|
|
49
|
+
disabled: false
|
|
50
|
+
};
|
|
51
|
+
}) : error ? [{
|
|
149
52
|
id: `${provider}::error`,
|
|
53
|
+
value: null,
|
|
150
54
|
disabled: true,
|
|
151
55
|
title: error
|
|
152
56
|
}] : [];
|
|
57
|
+
const submenu = modelOptions.concat([...provider !== "n8n" && modelOptions.length > 0 ? [{
|
|
58
|
+
isDivider: true,
|
|
59
|
+
id: "divider"
|
|
60
|
+
}] : []]);
|
|
61
|
+
if (provider !== "n8n") submenu.push({
|
|
62
|
+
id: `${provider}::configure`,
|
|
63
|
+
icon: "settings",
|
|
64
|
+
title: "Configure credentials...",
|
|
65
|
+
disabled: false
|
|
66
|
+
});
|
|
153
67
|
return {
|
|
154
68
|
id: provider,
|
|
69
|
+
hidden: true,
|
|
155
70
|
title: providerDisplayNames[provider],
|
|
156
|
-
submenu
|
|
157
|
-
isDivider: true,
|
|
158
|
-
id: "divider"
|
|
159
|
-
}] : [], {
|
|
160
|
-
id: `${provider}::configure`,
|
|
161
|
-
icon: "settings",
|
|
162
|
-
title: "Configure credentials...",
|
|
163
|
-
disabled: false
|
|
164
|
-
}])
|
|
71
|
+
submenu
|
|
165
72
|
};
|
|
166
73
|
}));
|
|
167
74
|
const selectedLabel = computed(() => {
|
|
168
75
|
if (!props.selectedModel) return "Select model";
|
|
169
|
-
return props.selectedModel.
|
|
76
|
+
return props.selectedModel.name;
|
|
170
77
|
});
|
|
171
78
|
function onSelect(id) {
|
|
172
|
-
const [provider,
|
|
79
|
+
const [provider, identifier] = id.split("::");
|
|
173
80
|
const parsedProvider = chatHubProviderSchema.safeParse(provider).data;
|
|
174
81
|
if (!parsedProvider) return;
|
|
175
|
-
if (
|
|
82
|
+
if (identifier === "configure" && parsedProvider !== "n8n") {
|
|
176
83
|
emit("configure", parsedProvider);
|
|
177
84
|
return;
|
|
178
85
|
}
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
86
|
+
const model = parsedProvider === "n8n" ? null : identifier;
|
|
87
|
+
const workflowId = parsedProvider === "n8n" ? identifier : null;
|
|
88
|
+
const selected$1 = props.models?.[parsedProvider].models.find((m) => m.provider === "n8n" ? m.workflowId === workflowId : m.model === model);
|
|
89
|
+
if (!selected$1) return;
|
|
90
|
+
emit("change", selected$1);
|
|
184
91
|
}
|
|
92
|
+
onClickOutside(computed(() => dropdownRef.value?.$el), () => dropdownRef.value?.close());
|
|
93
|
+
__expose({ open: () => dropdownRef.value?.open() });
|
|
185
94
|
return (_ctx, _cache) => {
|
|
186
95
|
return openBlock(), createBlock(unref(N8nNavigationDropdown_default), {
|
|
96
|
+
ref_key: "dropdownRef",
|
|
97
|
+
ref: dropdownRef,
|
|
187
98
|
menu: menu.value,
|
|
188
99
|
onSelect
|
|
189
100
|
}, {
|
|
@@ -199,7 +110,7 @@ var ModelSelector_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */
|
|
|
199
110
|
text: ""
|
|
200
111
|
}, {
|
|
201
112
|
default: withCtx(() => [
|
|
202
|
-
_ctx.selectedModel ? (openBlock(), createBlock(CredentialIcon_default, {
|
|
113
|
+
_ctx.selectedModel && _ctx.selectedModel.provider in unref(PROVIDER_CREDENTIAL_TYPE_MAP) ? (openBlock(), createBlock(CredentialIcon_default, {
|
|
203
114
|
key: 0,
|
|
204
115
|
"credential-type-name": unref(PROVIDER_CREDENTIAL_TYPE_MAP)[_ctx.selectedModel.provider],
|
|
205
116
|
size: _ctx.credentialsName ? 20 : 16,
|
|
@@ -244,30 +155,20 @@ var ChatConversationHeader_vue_vue_type_script_setup_true_lang_default = /* @__P
|
|
|
244
155
|
},
|
|
245
156
|
emits: [
|
|
246
157
|
"selectModel",
|
|
247
|
-
"
|
|
158
|
+
"setCredentials",
|
|
248
159
|
"renameConversation"
|
|
249
160
|
],
|
|
250
|
-
setup(__props, { emit: __emit }) {
|
|
161
|
+
setup(__props, { expose: __expose, emit: __emit }) {
|
|
251
162
|
const emit = __emit;
|
|
252
163
|
const sidebar = useChatHubSidebarState();
|
|
253
164
|
const chatStore = useChatStore();
|
|
254
|
-
const uiStore = useUIStore();
|
|
255
165
|
const credentialsStore = useCredentialsStore();
|
|
256
166
|
const router = useRouter();
|
|
257
|
-
const
|
|
167
|
+
const modelSelectorRef = useTemplateRef("modelSelectorRef");
|
|
258
168
|
const credentialsName = computed(() => __props.selectedModel ? credentialsStore.getCredentialById(__props.credentials[__props.selectedModel.provider] ?? "")?.name : void 0);
|
|
259
169
|
function onModelChange(selection) {
|
|
260
170
|
emit("selectModel", selection);
|
|
261
171
|
}
|
|
262
|
-
function onConfigure(provider) {
|
|
263
|
-
const credentialType = PROVIDER_CREDENTIAL_TYPE_MAP[provider];
|
|
264
|
-
if (credentialsStore.getCredentialsByType(credentialType).length === 0) {
|
|
265
|
-
uiStore.openNewCredential(credentialType);
|
|
266
|
-
return;
|
|
267
|
-
}
|
|
268
|
-
credentialSelectorProvider.value = provider;
|
|
269
|
-
uiStore.openModal("chatCredentialSelector");
|
|
270
|
-
}
|
|
271
172
|
function onNewChat() {
|
|
272
173
|
sidebar.toggleOpen(false);
|
|
273
174
|
router.push({
|
|
@@ -275,12 +176,7 @@ var ChatConversationHeader_vue_vue_type_script_setup_true_lang_default = /* @__P
|
|
|
275
176
|
force: true
|
|
276
177
|
});
|
|
277
178
|
}
|
|
278
|
-
|
|
279
|
-
emit("selectCredentials", provider, credentialsId);
|
|
280
|
-
}
|
|
281
|
-
function onCreateNewCredential(provider) {
|
|
282
|
-
uiStore.openNewCredential(PROVIDER_CREDENTIAL_TYPE_MAP[provider]);
|
|
283
|
-
}
|
|
179
|
+
__expose({ openModelSelector: () => modelSelectorRef.value?.open() });
|
|
284
180
|
return (_ctx, _cache) => {
|
|
285
181
|
return openBlock(), createElementBlock("div", { class: normalizeClass(_ctx.$style.component) }, [
|
|
286
182
|
!unref(sidebar).isStatic.value ? (openBlock(), createBlock(unref(N8nIconButton_default), {
|
|
@@ -302,23 +198,18 @@ var ChatConversationHeader_vue_vue_type_script_setup_true_lang_default = /* @__P
|
|
|
302
198
|
onClick: onNewChat
|
|
303
199
|
}, null, 8, ["class"])) : createCommentVNode("", true),
|
|
304
200
|
createVNode(ModelSelector_default, {
|
|
201
|
+
ref_key: "modelSelectorRef",
|
|
202
|
+
ref: modelSelectorRef,
|
|
305
203
|
models: unref(chatStore).models ?? null,
|
|
306
204
|
"selected-model": _ctx.selectedModel,
|
|
307
205
|
"credentials-name": credentialsName.value,
|
|
308
206
|
onChange: onModelChange,
|
|
309
|
-
onConfigure
|
|
207
|
+
onConfigure: _cache[1] || (_cache[1] = ($event) => emit("setCredentials", $event))
|
|
310
208
|
}, null, 8, [
|
|
311
209
|
"models",
|
|
312
210
|
"selected-model",
|
|
313
211
|
"credentials-name"
|
|
314
|
-
])
|
|
315
|
-
credentialSelectorProvider.value ? (openBlock(), createBlock(CredentialSelectorModal_default, {
|
|
316
|
-
key: credentialSelectorProvider.value,
|
|
317
|
-
provider: credentialSelectorProvider.value,
|
|
318
|
-
"initial-value": _ctx.credentials[credentialSelectorProvider.value] ?? null,
|
|
319
|
-
onSelect: onCredentialSelected,
|
|
320
|
-
onCreateNew: onCreateNewCredential
|
|
321
|
-
}, null, 8, ["provider", "initial-value"])) : createCommentVNode("", true)
|
|
212
|
+
])
|
|
322
213
|
], 2);
|
|
323
214
|
};
|
|
324
215
|
}
|
|
@@ -495,7 +386,7 @@ function useChatHubMarkdownOptions() {
|
|
|
495
386
|
try {
|
|
496
387
|
asyncImport = {
|
|
497
388
|
status: "inProgress",
|
|
498
|
-
promise: Promise.all([__vitePreload(() => import("./es-
|
|
389
|
+
promise: Promise.all([__vitePreload(() => import("./es-BO7MlKL2.js"), __vite__mapDeps([0,1,2])), __vitePreload(() => import("./languageModules-B8UNBljm.js"), __vite__mapDeps([3,4]))])
|
|
499
390
|
};
|
|
500
391
|
const [hljs, languages] = await asyncImport.promise;
|
|
501
392
|
asyncImport = { status: "done" };
|
|
@@ -541,7 +432,7 @@ var ChatMessage_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ de
|
|
|
541
432
|
volume: 1
|
|
542
433
|
});
|
|
543
434
|
const credentialTypeName = computed(() => {
|
|
544
|
-
if (__props.message.type !== "ai" || !__props.message.provider) return null;
|
|
435
|
+
if (__props.message.type !== "ai" || !__props.message.provider || __props.message.provider === "n8n") return null;
|
|
545
436
|
return PROVIDER_CREDENTIAL_TYPE_MAP[__props.message.provider] ?? null;
|
|
546
437
|
});
|
|
547
438
|
async function handleCopy() {
|
|
@@ -559,7 +450,7 @@ var ChatMessage_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ de
|
|
|
559
450
|
emit("cancelEdit");
|
|
560
451
|
}
|
|
561
452
|
function handleConfirmEdit() {
|
|
562
|
-
if (
|
|
453
|
+
if (!editedText.value.trim()) return;
|
|
563
454
|
emit("update", {
|
|
564
455
|
...__props.message,
|
|
565
456
|
content: editedText.value
|
|
@@ -707,11 +598,16 @@ var ChatMessage_default = /* @__PURE__ */ __plugin_vue_export_helper_default(Cha
|
|
|
707
598
|
var ChatPrompt_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
708
599
|
__name: "ChatPrompt",
|
|
709
600
|
props: {
|
|
710
|
-
|
|
711
|
-
|
|
712
|
-
|
|
601
|
+
isResponding: { type: Boolean },
|
|
602
|
+
selectedModel: {},
|
|
603
|
+
isMissingCredentials: { type: Boolean }
|
|
713
604
|
},
|
|
714
|
-
emits: [
|
|
605
|
+
emits: [
|
|
606
|
+
"submit",
|
|
607
|
+
"stop",
|
|
608
|
+
"selectModel",
|
|
609
|
+
"setCredentials"
|
|
610
|
+
],
|
|
715
611
|
setup(__props, { expose: __expose, emit: __emit }) {
|
|
716
612
|
const emit = __emit;
|
|
717
613
|
const inputRef = useTemplateRef("inputRef");
|
|
@@ -722,9 +618,13 @@ var ChatPrompt_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ def
|
|
|
722
618
|
interimResults: true,
|
|
723
619
|
lang: navigator.language
|
|
724
620
|
});
|
|
725
|
-
|
|
621
|
+
const placeholder = computed(() => {
|
|
622
|
+
if (!__props.selectedModel) return "Select a model";
|
|
623
|
+
return `Message ${__props.selectedModel.name}`;
|
|
624
|
+
});
|
|
726
625
|
function onMic() {
|
|
727
|
-
speechInput.isListening.value
|
|
626
|
+
if (speechInput.isListening.value) speechInput.stop();
|
|
627
|
+
else speechInput.start();
|
|
728
628
|
}
|
|
729
629
|
function onStop() {
|
|
730
630
|
emit("stop");
|
|
@@ -767,42 +667,62 @@ var ChatPrompt_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ def
|
|
|
767
667
|
return openBlock(), createElementBlock("form", {
|
|
768
668
|
class: normalizeClass(_ctx.$style.prompt),
|
|
769
669
|
onSubmit: withModifiers(handleSubmitForm, ["prevent"])
|
|
770
|
-
}, [createBaseVNode("div", { class: normalizeClass(_ctx.$style.inputWrap) }, [
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
|
|
799
|
-
|
|
800
|
-
|
|
670
|
+
}, [createBaseVNode("div", { class: normalizeClass(_ctx.$style.inputWrap) }, [
|
|
671
|
+
!_ctx.selectedModel ? (openBlock(), createBlock(unref(N8nText_default), {
|
|
672
|
+
key: 0,
|
|
673
|
+
class: normalizeClass(_ctx.$style.callout)
|
|
674
|
+
}, {
|
|
675
|
+
default: withCtx(() => [
|
|
676
|
+
_cache[3] || (_cache[3] = createTextVNode(" Please ")),
|
|
677
|
+
createBaseVNode("a", {
|
|
678
|
+
href: "",
|
|
679
|
+
onClick: _cache[0] || (_cache[0] = withModifiers(($event) => emit("selectModel"), ["prevent"]))
|
|
680
|
+
}, "select a model"),
|
|
681
|
+
_cache[4] || (_cache[4] = createTextVNode(" to start a conversation "))
|
|
682
|
+
]),
|
|
683
|
+
_: 1
|
|
684
|
+
}, 8, ["class"])) : _ctx.isMissingCredentials ? (openBlock(), createBlock(unref(N8nText_default), {
|
|
685
|
+
key: 1,
|
|
686
|
+
class: normalizeClass(_ctx.$style.callout)
|
|
687
|
+
}, {
|
|
688
|
+
default: withCtx(() => [
|
|
689
|
+
_cache[5] || (_cache[5] = createTextVNode(" Please ")),
|
|
690
|
+
createBaseVNode("a", {
|
|
691
|
+
href: "",
|
|
692
|
+
onClick: _cache[1] || (_cache[1] = withModifiers(($event) => emit("setCredentials", _ctx.selectedModel.provider), ["prevent"]))
|
|
693
|
+
}, " set credentials "),
|
|
694
|
+
createTextVNode(" for " + toDisplayString(unref(providerDisplayNames)[_ctx.selectedModel.provider]) + " to start a conversation ", 1)
|
|
695
|
+
]),
|
|
696
|
+
_: 1
|
|
697
|
+
}, 8, ["class"])) : createCommentVNode("", true),
|
|
698
|
+
createVNode(unref(N8nInput_default), {
|
|
699
|
+
ref_key: "inputRef",
|
|
700
|
+
ref: inputRef,
|
|
701
|
+
modelValue: message$1.value,
|
|
702
|
+
"onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => message$1.value = $event),
|
|
703
|
+
class: normalizeClass(_ctx.$style.input),
|
|
704
|
+
type: "textarea",
|
|
705
|
+
placeholder: placeholder.value,
|
|
706
|
+
autocomplete: "off",
|
|
707
|
+
autosize: {
|
|
708
|
+
minRows: 1,
|
|
709
|
+
maxRows: 6
|
|
710
|
+
},
|
|
711
|
+
autofocus: "",
|
|
712
|
+
disabled: _ctx.isMissingCredentials || !_ctx.selectedModel,
|
|
713
|
+
onKeydown: handleKeydownTextarea
|
|
714
|
+
}, null, 8, [
|
|
715
|
+
"modelValue",
|
|
716
|
+
"class",
|
|
717
|
+
"placeholder",
|
|
718
|
+
"disabled"
|
|
719
|
+
]),
|
|
720
|
+
createBaseVNode("div", { class: normalizeClass(_ctx.$style.actions) }, [unref(speechInput).isSupported ? (openBlock(), createBlock(unref(N8nIconButton_default), {
|
|
801
721
|
key: 0,
|
|
802
722
|
"native-type": "button",
|
|
803
723
|
title: unref(speechInput).isListening.value ? "Stop recording" : "Voice input",
|
|
804
724
|
type: "secondary",
|
|
805
|
-
disabled: _ctx.
|
|
725
|
+
disabled: _ctx.isMissingCredentials || !_ctx.selectedModel || _ctx.isResponding,
|
|
806
726
|
icon: unref(speechInput).isListening.value ? "square" : "mic",
|
|
807
727
|
class: normalizeClass({ [_ctx.$style.recording]: unref(speechInput).isListening.value }),
|
|
808
728
|
"icon-size": "large",
|
|
@@ -812,11 +732,10 @@ var ChatPrompt_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ def
|
|
|
812
732
|
"disabled",
|
|
813
733
|
"icon",
|
|
814
734
|
"class"
|
|
815
|
-
])) : createCommentVNode("", true),
|
|
816
|
-
!_ctx.isResponding ? (openBlock(), createBlock(unref(N8nIconButton_default), {
|
|
735
|
+
])) : createCommentVNode("", true), !_ctx.isResponding ? (openBlock(), createBlock(unref(N8nIconButton_default), {
|
|
817
736
|
key: 1,
|
|
818
737
|
"native-type": "submit",
|
|
819
|
-
disabled: _ctx.
|
|
738
|
+
disabled: _ctx.isMissingCredentials || !_ctx.selectedModel || !message$1.value.trim(),
|
|
820
739
|
title: "Send",
|
|
821
740
|
icon: "arrow-up",
|
|
822
741
|
"icon-size": "large"
|
|
@@ -827,18 +746,19 @@ var ChatPrompt_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ def
|
|
|
827
746
|
icon: "square",
|
|
828
747
|
"icon-size": "large",
|
|
829
748
|
onClick: onStop
|
|
830
|
-
}))
|
|
831
|
-
], 2)],
|
|
749
|
+
}))], 2)
|
|
750
|
+
], 2)], 34);
|
|
832
751
|
};
|
|
833
752
|
}
|
|
834
753
|
});
|
|
835
754
|
var ChatPrompt_vue_vue_type_style_index_0_lang_module_default = {
|
|
836
|
-
prompt: "
|
|
837
|
-
inputWrap: "
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
755
|
+
prompt: "_prompt_l0yq4_123",
|
|
756
|
+
inputWrap: "_inputWrap_l0yq4_128",
|
|
757
|
+
callout: "_callout_l0yq4_136",
|
|
758
|
+
input: "_input_l0yq4_128",
|
|
759
|
+
actions: "_actions_l0yq4_164",
|
|
760
|
+
recording: "_recording_l0yq4_177",
|
|
761
|
+
chatHubPromptRecordingPulse: "_chatHubPromptRecordingPulse_l0yq4_1"
|
|
842
762
|
};
|
|
843
763
|
var ChatPrompt_default = /* @__PURE__ */ __plugin_vue_export_helper_default(ChatPrompt_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": ChatPrompt_vue_vue_type_style_index_0_lang_module_default }]]);
|
|
844
764
|
var ChatStarter_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
@@ -846,21 +766,16 @@ var ChatStarter_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ de
|
|
|
846
766
|
props: { isMobileDevice: { type: Boolean } },
|
|
847
767
|
setup(__props) {
|
|
848
768
|
const userStore = useUsersStore();
|
|
849
|
-
const settingsStore = useSettingsStore();
|
|
850
769
|
const greetings = computed(() => `Hello, ${userStore.currentUser?.firstName ?? userStore.currentUser?.fullName ?? "User"}!`);
|
|
851
770
|
return (_ctx, _cache) => {
|
|
852
|
-
return openBlock(), createElementBlock("div", { class: normalizeClass([_ctx.$style.starter, { [_ctx.$style.isMobileDevice]: _ctx.isMobileDevice }]) }, [createVNode(
|
|
853
|
-
size: "large",
|
|
854
|
-
collapsed: "",
|
|
855
|
-
"release-channel": unref(settingsStore).settings.releaseChannel
|
|
856
|
-
}, null, 8, ["release-channel"]), createBaseVNode("div", { class: normalizeClass(_ctx.$style.header) }, [createVNode(unref(N8nHeading_default), {
|
|
771
|
+
return openBlock(), createElementBlock("div", { class: normalizeClass([_ctx.$style.starter, { [_ctx.$style.isMobileDevice]: _ctx.isMobileDevice }]) }, [createVNode(unref(N8nHeading_default), {
|
|
857
772
|
tag: "h2",
|
|
858
773
|
bold: "",
|
|
859
774
|
size: "xlarge"
|
|
860
775
|
}, {
|
|
861
776
|
default: withCtx(() => [createTextVNode(toDisplayString(greetings.value), 1)]),
|
|
862
777
|
_: 1
|
|
863
|
-
})], 2)
|
|
778
|
+
})], 2);
|
|
864
779
|
};
|
|
865
780
|
}
|
|
866
781
|
});
|
|
@@ -872,6 +787,107 @@ var ChatStarter_vue_vue_type_style_index_0_lang_module_default = {
|
|
|
872
787
|
};
|
|
873
788
|
var ChatStarter_default = /* @__PURE__ */ __plugin_vue_export_helper_default(ChatStarter_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": ChatStarter_vue_vue_type_style_index_0_lang_module_default }]]);
|
|
874
789
|
const credentialsMapSchema = recordType(chatHubProviderSchema, stringType().or(nullType()));
|
|
790
|
+
var CredentialSelectorModal_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
791
|
+
__name: "CredentialSelectorModal",
|
|
792
|
+
props: {
|
|
793
|
+
provider: {},
|
|
794
|
+
initialValue: {}
|
|
795
|
+
},
|
|
796
|
+
emits: ["select", "createNew"],
|
|
797
|
+
setup(__props, { emit: __emit }) {
|
|
798
|
+
const props = __props;
|
|
799
|
+
const emit = __emit;
|
|
800
|
+
const credentialsStore = useCredentialsStore();
|
|
801
|
+
const modalBus = ref(createEventBus());
|
|
802
|
+
const selectedCredentialId = ref(props.initialValue);
|
|
803
|
+
const availableCredentials = computed(() => {
|
|
804
|
+
return credentialsStore.getCredentialsByType(PROVIDER_CREDENTIAL_TYPE_MAP[props.provider]);
|
|
805
|
+
});
|
|
806
|
+
function onCredentialSelect(credentialId) {
|
|
807
|
+
selectedCredentialId.value = credentialId;
|
|
808
|
+
}
|
|
809
|
+
function onConfirm() {
|
|
810
|
+
if (selectedCredentialId.value) {
|
|
811
|
+
emit("select", props.provider, selectedCredentialId.value);
|
|
812
|
+
modalBus.value.emit("close");
|
|
813
|
+
}
|
|
814
|
+
}
|
|
815
|
+
function onCreateNew() {
|
|
816
|
+
emit("createNew", props.provider);
|
|
817
|
+
modalBus.value.emit("close");
|
|
818
|
+
}
|
|
819
|
+
function onCancel() {
|
|
820
|
+
modalBus.value.emit("close");
|
|
821
|
+
}
|
|
822
|
+
return (_ctx, _cache) => {
|
|
823
|
+
return openBlock(), createBlock(Modal_default, {
|
|
824
|
+
name: "chatCredentialSelector",
|
|
825
|
+
"event-bus": modalBus.value,
|
|
826
|
+
width: "50%",
|
|
827
|
+
center: true,
|
|
828
|
+
"max-width": "460px",
|
|
829
|
+
"min-height": "250px"
|
|
830
|
+
}, {
|
|
831
|
+
header: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.header) }, [createVNode(CredentialIcon_default, {
|
|
832
|
+
"credential-type-name": unref(PROVIDER_CREDENTIAL_TYPE_MAP)[_ctx.provider],
|
|
833
|
+
size: 24,
|
|
834
|
+
class: normalizeClass(_ctx.$style.icon)
|
|
835
|
+
}, null, 8, ["credential-type-name", "class"]), createBaseVNode("h2", { class: normalizeClass(_ctx.$style.title) }, "Select " + toDisplayString(unref(providerDisplayNames)[_ctx.provider]) + " Credential", 3)], 2)]),
|
|
836
|
+
content: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.content) }, [createVNode(unref(N8nText_default), {
|
|
837
|
+
size: "small",
|
|
838
|
+
color: "text-base"
|
|
839
|
+
}, {
|
|
840
|
+
default: withCtx(() => _cache[0] || (_cache[0] = [createTextVNode(" Choose an existing credential or create a new one ")])),
|
|
841
|
+
_: 1
|
|
842
|
+
}), createVNode(unref(N8nSelect_default), {
|
|
843
|
+
"model-value": selectedCredentialId.value,
|
|
844
|
+
size: "large",
|
|
845
|
+
placeholder: "Select credential...",
|
|
846
|
+
"onUpdate:modelValue": onCredentialSelect
|
|
847
|
+
}, {
|
|
848
|
+
default: withCtx(() => [(openBlock(true), createElementBlock(Fragment, null, renderList(availableCredentials.value, (credential) => {
|
|
849
|
+
return openBlock(), createBlock(unref(N8nOption_default), {
|
|
850
|
+
key: credential.id,
|
|
851
|
+
value: credential.id,
|
|
852
|
+
label: credential.name
|
|
853
|
+
}, null, 8, ["value", "label"]);
|
|
854
|
+
}), 128))]),
|
|
855
|
+
_: 1
|
|
856
|
+
}, 8, ["model-value"])], 2)]),
|
|
857
|
+
footer: withCtx(() => [createBaseVNode("div", { class: normalizeClass(_ctx.$style.footer) }, [createVNode(unref(N8nButton_default), {
|
|
858
|
+
type: "secondary",
|
|
859
|
+
onClick: onCreateNew
|
|
860
|
+
}, {
|
|
861
|
+
default: withCtx(() => _cache[1] || (_cache[1] = [createTextVNode(" Create New ")])),
|
|
862
|
+
_: 1
|
|
863
|
+
}), createBaseVNode("div", { class: normalizeClass(_ctx.$style.footerRight) }, [createVNode(unref(N8nButton_default), {
|
|
864
|
+
type: "tertiary",
|
|
865
|
+
onClick: onCancel
|
|
866
|
+
}, {
|
|
867
|
+
default: withCtx(() => _cache[2] || (_cache[2] = [createTextVNode(" Cancel ")])),
|
|
868
|
+
_: 1
|
|
869
|
+
}), createVNode(unref(N8nButton_default), {
|
|
870
|
+
type: "primary",
|
|
871
|
+
disabled: !selectedCredentialId.value,
|
|
872
|
+
onClick: onConfirm
|
|
873
|
+
}, {
|
|
874
|
+
default: withCtx(() => _cache[3] || (_cache[3] = [createTextVNode(" Select ")])),
|
|
875
|
+
_: 1
|
|
876
|
+
}, 8, ["disabled"])], 2)], 2)]),
|
|
877
|
+
_: 1
|
|
878
|
+
}, 8, ["event-bus"]);
|
|
879
|
+
};
|
|
880
|
+
}
|
|
881
|
+
});
|
|
882
|
+
var CredentialSelectorModal_vue_vue_type_style_index_0_lang_module_default = {
|
|
883
|
+
title: "_title_1hes0_123",
|
|
884
|
+
content: "_content_1hes0_129",
|
|
885
|
+
footer: "_footer_1hes0_136",
|
|
886
|
+
footerRight: "_footerRight_1hes0_143",
|
|
887
|
+
header: "_header_1hes0_148",
|
|
888
|
+
icon: "_icon_1hes0_154"
|
|
889
|
+
};
|
|
890
|
+
var CredentialSelectorModal_default = /* @__PURE__ */ __plugin_vue_export_helper_default(CredentialSelectorModal_vue_vue_type_script_setup_true_lang_default, [["__cssModules", { "$style": CredentialSelectorModal_vue_vue_type_style_index_0_lang_module_default }]]);
|
|
875
891
|
var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
876
892
|
__name: "ChatView",
|
|
877
893
|
setup(__props) {
|
|
@@ -883,6 +899,8 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
883
899
|
const toast = useToast();
|
|
884
900
|
const isMobileDevice$1 = useMediaQuery(MOBILE_MEDIA_QUERY);
|
|
885
901
|
const documentTitle = useDocumentTitle();
|
|
902
|
+
const uiStore = useUIStore();
|
|
903
|
+
const headerRef = useTemplateRef("headerRef");
|
|
886
904
|
const inputRef = useTemplateRef("inputRef");
|
|
887
905
|
const sessionId = computed(() => typeof route.params.id === "string" ? route.params.id : v4_default());
|
|
888
906
|
const isNewSession = computed(() => sessionId.value !== route.params.id);
|
|
@@ -923,6 +941,7 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
923
941
|
}
|
|
924
942
|
});
|
|
925
943
|
const autoSelectCredentials = computed(() => Object.fromEntries(chatHubProviderSchema.options.map((provider) => {
|
|
944
|
+
if (provider === "n8n") return [provider, null];
|
|
926
945
|
return [provider, credentialsStore.getCredentialsByType(PROVIDER_CREDENTIAL_TYPE_MAP[provider]).toSorted((a, b) => +new Date(b.createdAt) - +new Date(a.createdAt))[0]?.id ?? null];
|
|
927
946
|
})));
|
|
928
947
|
const mergedCredentials = computed(() => ({
|
|
@@ -931,12 +950,24 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
931
950
|
}));
|
|
932
951
|
const chatMessages = computed(() => chatStore.getActiveMessages(sessionId.value));
|
|
933
952
|
const isNewChat$1 = computed(() => route.name === CHAT_VIEW);
|
|
934
|
-
const
|
|
935
|
-
|
|
936
|
-
|
|
953
|
+
const credentialsId = computed(() => selectedModel.value ? mergedCredentials.value[selectedModel.value.provider] : void 0);
|
|
954
|
+
const modelRequiresCredentials = computed(() => {
|
|
955
|
+
if (!selectedModel.value) return false;
|
|
956
|
+
return selectedModel.value?.provider !== "n8n";
|
|
957
|
+
});
|
|
958
|
+
const isMissingSelectedCredential = computed(() => {
|
|
959
|
+
if (!selectedModel.value) return false;
|
|
960
|
+
if (!modelRequiresCredentials.value) return false;
|
|
961
|
+
return !credentialsId.value;
|
|
937
962
|
});
|
|
938
963
|
const editingMessageId = ref();
|
|
939
964
|
const didSubmitInCurrentSession = ref(false);
|
|
965
|
+
const initialization = ref({
|
|
966
|
+
credentialsFetched: false,
|
|
967
|
+
modelsFetched: false
|
|
968
|
+
});
|
|
969
|
+
const credentialSelectorProvider = ref(null);
|
|
970
|
+
const isInitialized = computed(() => initialization.value.credentialsFetched && initialization.value.modelsFetched);
|
|
940
971
|
function scrollToBottom(smooth) {
|
|
941
972
|
scrollContainerRef.value?.scrollTo({
|
|
942
973
|
top: scrollableRef.value?.scrollHeight,
|
|
@@ -961,6 +992,7 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
961
992
|
watch(mergedCredentials, async (credentials) => {
|
|
962
993
|
const models = await chatStore.fetchChatModels(credentials);
|
|
963
994
|
if (selectedModel.value === null) selectedModel.value = findOneFromModelsResponse(models) ?? null;
|
|
995
|
+
initialization.value.modelsFetched = true;
|
|
964
996
|
}, { immediate: true });
|
|
965
997
|
watch([sessionId, isNewSession], async ([id, isNew]) => {
|
|
966
998
|
didSubmitInCurrentSession.value = false;
|
|
@@ -977,15 +1009,17 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
977
1009
|
}, { immediate: true });
|
|
978
1010
|
onMounted(async () => {
|
|
979
1011
|
await Promise.all([credentialsStore.fetchCredentialTypes(false), credentialsStore.fetchAllCredentials()]);
|
|
1012
|
+
initialization.value.credentialsFetched = true;
|
|
980
1013
|
});
|
|
981
1014
|
function onSubmit(message$1) {
|
|
982
|
-
if (!message$1.trim() || chatStore.isResponding) return;
|
|
983
|
-
const credentialsId = selectedModel.value ? mergedCredentials.value[selectedModel.value.provider] : void 0;
|
|
1015
|
+
if (!message$1.trim() || chatStore.isResponding || !selectedModel.value || isMissingSelectedCredential.value) return;
|
|
984
1016
|
didSubmitInCurrentSession.value = true;
|
|
985
|
-
|
|
986
|
-
|
|
1017
|
+
const credentials = {};
|
|
1018
|
+
if (selectedModel.value.provider !== "n8n" && credentialsId.value) Object.assign(credentials, { [PROVIDER_CREDENTIAL_TYPE_MAP[selectedModel.value.provider]]: {
|
|
1019
|
+
id: credentialsId.value,
|
|
987
1020
|
name: ""
|
|
988
|
-
} }
|
|
1021
|
+
} });
|
|
1022
|
+
chatStore.sendMessage(sessionId.value, message$1, selectedModel.value, credentials);
|
|
989
1023
|
inputRef.value?.setText("");
|
|
990
1024
|
if (isNewSession.value) router.push({
|
|
991
1025
|
name: CHAT_CONVERSATION_VIEW,
|
|
@@ -1002,111 +1036,139 @@ var ChatView_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defin
|
|
|
1002
1036
|
editingMessageId.value = void 0;
|
|
1003
1037
|
}
|
|
1004
1038
|
function handleEditMessage(message$1) {
|
|
1005
|
-
if (chatStore.isResponding || message$1.type
|
|
1006
|
-
const
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
chatStore.editMessage(sessionId.value, mesasgeToEdit, message$1.content, selectedModel.value, { [PROVIDER_CREDENTIAL_TYPE_MAP[selectedModel.value.provider]]: {
|
|
1010
|
-
id: credentialsId,
|
|
1039
|
+
if (chatStore.isResponding || !["human", "ai"].includes(message$1.type) || !selectedModel.value || !credentialsId.value) return;
|
|
1040
|
+
const messageToEdit = message$1.revisionOfMessageId ?? message$1.id;
|
|
1041
|
+
chatStore.editMessage(sessionId.value, messageToEdit, message$1.content, selectedModel.value, selectedModel.value.provider === "n8n" ? {} : { [PROVIDER_CREDENTIAL_TYPE_MAP[selectedModel.value.provider]]: {
|
|
1042
|
+
id: credentialsId.value,
|
|
1011
1043
|
name: ""
|
|
1012
1044
|
} });
|
|
1013
1045
|
editingMessageId.value = void 0;
|
|
1014
1046
|
}
|
|
1015
1047
|
function handleRegenerateMessage(message$1) {
|
|
1016
|
-
if (chatStore.isResponding || message$1.type !== "ai" || !selectedModel.value) return;
|
|
1017
|
-
const credentialsId = mergedCredentials.value[selectedModel.value.provider];
|
|
1018
|
-
if (!credentialsId) return;
|
|
1048
|
+
if (chatStore.isResponding || message$1.type !== "ai" || !selectedModel.value || !credentialsId.value) return;
|
|
1019
1049
|
const messageToRetry = message$1.retryOfMessageId ?? message$1.id;
|
|
1020
|
-
chatStore.regenerateMessage(sessionId.value, messageToRetry, selectedModel.value, { [PROVIDER_CREDENTIAL_TYPE_MAP[selectedModel.value.provider]]: {
|
|
1021
|
-
id: credentialsId,
|
|
1050
|
+
chatStore.regenerateMessage(sessionId.value, messageToRetry, selectedModel.value, selectedModel.value.provider === "n8n" ? {} : { [PROVIDER_CREDENTIAL_TYPE_MAP[selectedModel.value.provider]]: {
|
|
1051
|
+
id: credentialsId.value,
|
|
1022
1052
|
name: ""
|
|
1023
1053
|
} });
|
|
1024
1054
|
}
|
|
1025
1055
|
function handleSelectModel(selection) {
|
|
1026
1056
|
selectedModel.value = selection;
|
|
1027
1057
|
}
|
|
1028
|
-
function handleSelectCredentials(provider,
|
|
1058
|
+
function handleSelectCredentials(provider, id) {
|
|
1029
1059
|
selectedCredentials.value = {
|
|
1030
1060
|
...selectedCredentials.value,
|
|
1031
|
-
[provider]:
|
|
1061
|
+
[provider]: id
|
|
1032
1062
|
};
|
|
1033
1063
|
}
|
|
1034
1064
|
function handleSwitchAlternative(messageId) {
|
|
1035
1065
|
chatStore.switchAlternative(sessionId.value, messageId);
|
|
1036
1066
|
}
|
|
1067
|
+
function handleConfigureCredentials(provider) {
|
|
1068
|
+
const credentialType = PROVIDER_CREDENTIAL_TYPE_MAP[provider];
|
|
1069
|
+
if (credentialsStore.getCredentialsByType(credentialType).length === 0) {
|
|
1070
|
+
uiStore.openNewCredential(credentialType);
|
|
1071
|
+
return;
|
|
1072
|
+
}
|
|
1073
|
+
credentialSelectorProvider.value = provider;
|
|
1074
|
+
uiStore.openModal("chatCredentialSelector");
|
|
1075
|
+
}
|
|
1076
|
+
function handleConfigureModel() {
|
|
1077
|
+
headerRef.value?.openModelSelector();
|
|
1078
|
+
}
|
|
1079
|
+
function handleCreateNewCredential(provider) {
|
|
1080
|
+
uiStore.openNewCredential(PROVIDER_CREDENTIAL_TYPE_MAP[provider]);
|
|
1081
|
+
}
|
|
1037
1082
|
return (_ctx, _cache) => {
|
|
1038
1083
|
return openBlock(), createElementBlock("div", { class: normalizeClass([_ctx.$style.component, {
|
|
1039
1084
|
[_ctx.$style.isNewChat]: isNewChat$1.value,
|
|
1040
1085
|
[_ctx.$style.isMobileDevice]: unref(isMobileDevice$1)
|
|
1041
|
-
}]) }, [
|
|
1042
|
-
|
|
1043
|
-
credentials: mergedCredentials.value,
|
|
1044
|
-
onSelectModel: handleSelectModel,
|
|
1045
|
-
onSelectCredentials: handleSelectCredentials
|
|
1046
|
-
}, null, 8, ["selected-model", "credentials"]), createVNode(unref(N8nScrollArea_default), {
|
|
1047
|
-
type: "scroll",
|
|
1048
|
-
"enable-vertical-scroll": true,
|
|
1049
|
-
"enable-horizontal-scroll": false,
|
|
1050
|
-
"as-child": "",
|
|
1051
|
-
class: normalizeClass(_ctx.$style.scrollArea)
|
|
1052
|
-
}, {
|
|
1053
|
-
default: withCtx(() => [createBaseVNode("div", {
|
|
1054
|
-
class: normalizeClass(_ctx.$style.scrollable),
|
|
1055
|
-
ref: "scrollable"
|
|
1056
|
-
}, [isNewChat$1.value ? (openBlock(), createBlock(ChatStarter_default, {
|
|
1086
|
+
}]) }, [
|
|
1087
|
+
isInitialized.value ? (openBlock(), createBlock(ChatConversationHeader_default, {
|
|
1057
1088
|
key: 0,
|
|
1058
|
-
|
|
1059
|
-
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1063
|
-
|
|
1064
|
-
|
|
1065
|
-
|
|
1066
|
-
|
|
1067
|
-
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1089
|
+
ref_key: "headerRef",
|
|
1090
|
+
ref: headerRef,
|
|
1091
|
+
"selected-model": unref(selectedModel),
|
|
1092
|
+
credentials: mergedCredentials.value,
|
|
1093
|
+
onSelectModel: handleSelectModel,
|
|
1094
|
+
onSetCredentials: handleConfigureCredentials
|
|
1095
|
+
}, null, 8, ["selected-model", "credentials"])) : createCommentVNode("", true),
|
|
1096
|
+
credentialSelectorProvider.value && credentialSelectorProvider.value !== "n8n" ? (openBlock(), createBlock(CredentialSelectorModal_default, {
|
|
1097
|
+
key: credentialSelectorProvider.value,
|
|
1098
|
+
provider: credentialSelectorProvider.value,
|
|
1099
|
+
"initial-value": mergedCredentials.value[credentialSelectorProvider.value] ?? null,
|
|
1100
|
+
onSelect: handleSelectCredentials,
|
|
1101
|
+
onCreateNew: handleCreateNewCredential
|
|
1102
|
+
}, null, 8, ["provider", "initial-value"])) : createCommentVNode("", true),
|
|
1103
|
+
isInitialized.value ? (openBlock(), createBlock(unref(N8nScrollArea_default), {
|
|
1104
|
+
key: 2,
|
|
1105
|
+
type: "scroll",
|
|
1106
|
+
"enable-vertical-scroll": true,
|
|
1107
|
+
"enable-horizontal-scroll": false,
|
|
1108
|
+
"as-child": "",
|
|
1109
|
+
class: normalizeClass(_ctx.$style.scrollArea)
|
|
1110
|
+
}, {
|
|
1111
|
+
default: withCtx(() => [createBaseVNode("div", {
|
|
1112
|
+
class: normalizeClass(_ctx.$style.scrollable),
|
|
1113
|
+
ref: "scrollable"
|
|
1114
|
+
}, [isNewChat$1.value ? (openBlock(), createBlock(ChatStarter_default, {
|
|
1115
|
+
key: 0,
|
|
1116
|
+
class: normalizeClass(_ctx.$style.starter),
|
|
1117
|
+
"is-mobile-device": unref(isMobileDevice$1)
|
|
1118
|
+
}, null, 8, ["class", "is-mobile-device"])) : (openBlock(), createElementBlock("div", {
|
|
1119
|
+
key: 1,
|
|
1120
|
+
role: "log",
|
|
1121
|
+
"aria-live": "polite",
|
|
1122
|
+
class: normalizeClass(_ctx.$style.messageList)
|
|
1123
|
+
}, [(openBlock(true), createElementBlock(Fragment, null, renderList(chatMessages.value, (message$1, index) => {
|
|
1124
|
+
return openBlock(), createBlock(ChatMessage_default, {
|
|
1125
|
+
key: message$1.id,
|
|
1126
|
+
message: message$1,
|
|
1127
|
+
compact: unref(isMobileDevice$1),
|
|
1128
|
+
"is-editing": editingMessageId.value === message$1.id,
|
|
1129
|
+
"is-streaming": unref(chatStore).streamingMessageId === message$1.id,
|
|
1130
|
+
"min-height": didSubmitInCurrentSession.value && message$1.type === "ai" && index === chatMessages.value.length - 1 && scrollContainerRef.value ? scrollContainerRef.value.offsetHeight - 30 - 200 : void 0,
|
|
1131
|
+
onStartEdit: ($event) => handleStartEditMessage(message$1.id),
|
|
1132
|
+
onCancelEdit: handleCancelEditMessage,
|
|
1133
|
+
onRegenerate: handleRegenerateMessage,
|
|
1134
|
+
onUpdate: handleEditMessage,
|
|
1135
|
+
onSwitchAlternative: handleSwitchAlternative
|
|
1136
|
+
}, null, 8, [
|
|
1137
|
+
"message",
|
|
1138
|
+
"compact",
|
|
1139
|
+
"is-editing",
|
|
1140
|
+
"is-streaming",
|
|
1141
|
+
"min-height",
|
|
1142
|
+
"onStartEdit"
|
|
1143
|
+
]);
|
|
1144
|
+
}), 128))], 2)), createBaseVNode("div", { class: normalizeClass(_ctx.$style.promptContainer) }, [!unref(arrivedState).bottom && !isNewChat$1.value ? (openBlock(), createBlock(unref(N8nIconButton_default), {
|
|
1145
|
+
key: 0,
|
|
1146
|
+
type: "secondary",
|
|
1147
|
+
icon: "arrow-down",
|
|
1148
|
+
class: normalizeClass(_ctx.$style.scrollToBottomButton),
|
|
1149
|
+
title: "Scroll to bottom",
|
|
1150
|
+
onClick: _cache[0] || (_cache[0] = ($event) => scrollToBottom(true))
|
|
1151
|
+
}, null, 8, ["class"])) : createCommentVNode("", true), isInitialized.value ? (openBlock(), createBlock(ChatPrompt_default, {
|
|
1152
|
+
key: 1,
|
|
1153
|
+
ref_key: "inputRef",
|
|
1154
|
+
ref: inputRef,
|
|
1155
|
+
class: normalizeClass(_ctx.$style.prompt),
|
|
1156
|
+
"is-responding": unref(chatStore).isResponding,
|
|
1157
|
+
"selected-model": unref(selectedModel),
|
|
1158
|
+
"is-missing-credentials": isMissingSelectedCredential.value,
|
|
1159
|
+
onSubmit,
|
|
1160
|
+
onStop,
|
|
1161
|
+
onSelectModel: handleConfigureModel,
|
|
1162
|
+
onSetCredentials: handleConfigureCredentials
|
|
1078
1163
|
}, null, 8, [
|
|
1079
|
-
"
|
|
1080
|
-
"
|
|
1081
|
-
"
|
|
1082
|
-
"is-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
key: 0,
|
|
1088
|
-
type: "secondary",
|
|
1089
|
-
icon: "arrow-down",
|
|
1090
|
-
class: normalizeClass(_ctx.$style.scrollToBottomButton),
|
|
1091
|
-
title: "Scroll to bottom",
|
|
1092
|
-
onClick: _cache[0] || (_cache[0] = ($event) => scrollToBottom(true))
|
|
1093
|
-
}, null, 8, ["class"])) : createCommentVNode("", true), createVNode(ChatPrompt_default, {
|
|
1094
|
-
ref_key: "inputRef",
|
|
1095
|
-
ref: inputRef,
|
|
1096
|
-
class: normalizeClass(_ctx.$style.prompt),
|
|
1097
|
-
placeholder: inputPlaceholder.value,
|
|
1098
|
-
"is-responding": unref(chatStore).isResponding,
|
|
1099
|
-
disabled: unref(chatStore).isResponding,
|
|
1100
|
-
onSubmit,
|
|
1101
|
-
onStop
|
|
1102
|
-
}, null, 8, [
|
|
1103
|
-
"class",
|
|
1104
|
-
"placeholder",
|
|
1105
|
-
"is-responding",
|
|
1106
|
-
"disabled"
|
|
1107
|
-
])], 2)], 2)]),
|
|
1108
|
-
_: 1
|
|
1109
|
-
}, 8, ["class"])], 2);
|
|
1164
|
+
"class",
|
|
1165
|
+
"is-responding",
|
|
1166
|
+
"selected-model",
|
|
1167
|
+
"is-missing-credentials"
|
|
1168
|
+
])) : createCommentVNode("", true)], 2)], 2)]),
|
|
1169
|
+
_: 1
|
|
1170
|
+
}, 8, ["class"])) : createCommentVNode("", true)
|
|
1171
|
+
], 2);
|
|
1110
1172
|
};
|
|
1111
1173
|
}
|
|
1112
1174
|
});
|