synapse-react-client 4.0.1 → 4.0.3-b
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/SWC.index.js +1 -1
- package/dist/assets/icons/AwardScroll.d.ts +5 -0
- package/dist/assets/icons/AwardScroll.d.ts.map +1 -0
- package/dist/assets/icons/AwardScroll.js +78 -0
- package/dist/assets/icons/AwardScroll.js.map +1 -0
- package/dist/assets/icons/Baseline.d.ts +5 -0
- package/dist/assets/icons/Baseline.d.ts.map +1 -0
- package/dist/assets/icons/Baseline.js +43 -0
- package/dist/assets/icons/Baseline.js.map +1 -0
- package/dist/assets/icons/Challenge.svg +13 -0
- package/dist/assets/icons/Challenge.svg.js +7 -0
- package/dist/assets/icons/Challenge.svg.js.map +1 -0
- package/dist/assets/icons/ClappingHands.d.ts +5 -0
- package/dist/assets/icons/ClappingHands.d.ts.map +1 -0
- package/dist/assets/icons/ClappingHands.js +106 -0
- package/dist/assets/icons/ClappingHands.js.map +1 -0
- package/dist/assets/icons/DNA_Two.svg +0 -0
- package/dist/assets/icons/Data2.svg +0 -0
- package/dist/assets/icons/HandWithMoney.d.ts +5 -0
- package/dist/assets/icons/HandWithMoney.d.ts.map +1 -0
- package/dist/assets/icons/HandWithMoney.js +15 -0
- package/dist/assets/icons/HandWithMoney.js.map +1 -0
- package/dist/assets/icons/MultiFile.d.ts +5 -0
- package/dist/assets/icons/MultiFile.d.ts.map +1 -0
- package/dist/assets/icons/MultiFile.js +8 -0
- package/dist/assets/icons/MultiFile.js.map +1 -0
- package/dist/assets/icons/MultiFile.svg +4 -0
- package/dist/assets/icons/MultiFile.svg.js +7 -0
- package/dist/assets/icons/MultiFile.svg.js.map +1 -0
- package/dist/assets/icons/OpenBook.d.ts +5 -0
- package/dist/assets/icons/OpenBook.d.ts.map +1 -0
- package/dist/assets/icons/OpenBook.js +99 -0
- package/dist/assets/icons/OpenBook.js.map +1 -0
- package/dist/assets/icons/Podium.d.ts +5 -0
- package/dist/assets/icons/Podium.d.ts.map +1 -0
- package/dist/assets/icons/Podium.js +36 -0
- package/dist/assets/icons/Podium.js.map +1 -0
- package/dist/assets/icons/RosetteRibbon.d.ts +5 -0
- package/dist/assets/icons/RosetteRibbon.d.ts.map +1 -0
- package/dist/assets/icons/RosetteRibbon.js +36 -0
- package/dist/assets/icons/RosetteRibbon.js.map +1 -0
- package/dist/assets/icons/StarTrophy.d.ts +5 -0
- package/dist/assets/icons/StarTrophy.d.ts.map +1 -0
- package/dist/assets/icons/StarTrophy.js +99 -0
- package/dist/assets/icons/StarTrophy.js.map +1 -0
- package/dist/assets/icons/ThreeStars.d.ts +5 -0
- package/dist/assets/icons/ThreeStars.d.ts.map +1 -0
- package/dist/assets/icons/ThreeStars.js +71 -0
- package/dist/assets/icons/ThreeStars.js.map +1 -0
- package/dist/assets/icons/UnpackagableFile.d.ts +5 -0
- package/dist/assets/icons/UnpackagableFile.d.ts.map +1 -0
- package/dist/assets/icons/UnpackagableFile.js +8 -0
- package/dist/assets/icons/UnpackagableFile.js.map +1 -0
- package/dist/assets/icons/UnpackagableFile.svg +4 -0
- package/dist/assets/icons/UnpackagableFile.svg.js +7 -0
- package/dist/assets/icons/UnpackagableFile.svg.js.map +1 -0
- package/dist/assets/mui_components/PackagableFile.d.ts.map +1 -1
- package/dist/assets/mui_components/PackagableFile.js +5 -4
- package/dist/assets/mui_components/PackagableFile.js.map +1 -1
- package/dist/assets/mui_components/PackagableFile.svg +3 -0
- package/dist/assets/mui_components/PackagableFile.svg.js +7 -0
- package/dist/assets/mui_components/PackagableFile.svg.js.map +1 -0
- package/dist/assets/themed_icons/index.d.ts +1 -2
- package/dist/assets/themed_icons/index.d.ts.map +1 -1
- package/dist/assets/themed_icons/index.js +8 -10
- package/dist/assets/themed_icons/index.js.map +1 -1
- package/dist/components/AcknowledgementsPage/AcknowledgementsPage.js +4 -4
- package/dist/components/AcknowledgementsPage/AcknowledgementsPage.js.map +1 -1
- package/dist/components/AddToDownloadListV2.js +10 -10
- package/dist/components/AddToDownloadListV2.js.map +1 -1
- package/dist/components/BasePortalCard/BasePortalCard.css +1 -1
- package/dist/components/BasePortalCard/BasePortalCard.d.ts +1 -2
- package/dist/components/BasePortalCard/BasePortalCard.d.ts.map +1 -1
- package/dist/components/BasePortalCard/BasePortalCard.js +21 -28
- package/dist/components/BasePortalCard/BasePortalCard.js.map +1 -1
- package/dist/components/BasePortalCard/BasePortalCard.module.scss +7 -1
- package/dist/components/BasePortalCard/BasePortalCard.module.scss.js +11 -11
- package/dist/components/BasePortalCard/ColorfulPortalCardWithChips/ColorfulPortalCardWithChips.d.ts.map +1 -1
- package/dist/components/BasePortalCard/ColorfulPortalCardWithChips/ColorfulPortalCardWithChips.js +24 -24
- package/dist/components/BasePortalCard/ColorfulPortalCardWithChips/ColorfulPortalCardWithChips.js.map +1 -1
- package/dist/components/CardContainerLogic/CardContainerLogic.d.ts +5 -1
- package/dist/components/CardContainerLogic/CardContainerLogic.d.ts.map +1 -1
- package/dist/components/CardContainerLogic/CardContainerLogic.js.map +1 -1
- package/dist/components/CardContainerLogic/index.d.ts +1 -1
- package/dist/components/CardContainerLogic/index.d.ts.map +1 -1
- package/dist/components/CardDeck/TableQueryCardDeck.js +12 -9
- package/dist/components/CardDeck/TableQueryCardDeck.js.map +1 -1
- package/dist/components/ChallengeDataDownload/ChallengeDataDownload.js +33 -33
- package/dist/components/ChallengeDataDownload/ChallengeDataDownload.js.map +1 -1
- package/dist/components/ChangePassword/useChangePasswordFormState.js +5 -2
- package/dist/components/ChangePassword/useChangePasswordFormState.js.map +1 -1
- package/dist/components/ComponentCollapse.d.ts +6 -10
- package/dist/components/ComponentCollapse.d.ts.map +1 -1
- package/dist/components/ComponentCollapse.js +31 -35
- package/dist/components/ComponentCollapse.js.map +1 -1
- package/dist/components/CreateOrUpdateAccessRequirementWizard/CreateOrUpdateAccessRequirementWizard.js +12 -9
- package/dist/components/CreateOrUpdateAccessRequirementWizard/CreateOrUpdateAccessRequirementWizard.js.map +1 -1
- package/dist/components/DataGrid/MergeGridWithSourceTableButton.js +8 -3
- package/dist/components/DataGrid/MergeGridWithSourceTableButton.js.map +1 -1
- package/dist/components/DataGrid/SynapseGrid.js +8 -3
- package/dist/components/DataGrid/SynapseGrid.js.map +1 -1
- package/dist/components/DataGrid/components/UploadCsvToGridDialog.js +8 -3
- package/dist/components/DataGrid/components/UploadCsvToGridDialog.js.map +1 -1
- package/dist/components/DirectDownload/DirectDownload.d.ts.map +1 -1
- package/dist/components/DirectDownload/DirectDownload.js +23 -23
- package/dist/components/DirectDownload/DirectDownload.js.map +1 -1
- package/dist/components/DownloadCart/AvailableForDownloadTable.d.ts +6 -2
- package/dist/components/DownloadCart/AvailableForDownloadTable.d.ts.map +1 -1
- package/dist/components/DownloadCart/AvailableForDownloadTable.js +10 -8
- package/dist/components/DownloadCart/AvailableForDownloadTable.js.map +1 -1
- package/dist/components/DownloadCart/CreatePackageV2.css +1 -0
- package/dist/components/DownloadCart/CreatePackageV2.d.ts.map +1 -1
- package/dist/components/DownloadCart/CreatePackageV2.js +50 -46
- package/dist/components/DownloadCart/CreatePackageV2.js.map +1 -1
- package/dist/components/DownloadCart/CreatePackageV2.module.scss +38 -0
- package/dist/components/DownloadCart/CreatePackageV2.module.scss.js +14 -0
- package/dist/components/DownloadCart/CreatePackageV2.module.scss.js.map +1 -0
- package/dist/components/DownloadCart/DownloadCartPage.css +1 -0
- package/dist/components/DownloadCart/DownloadCartPage.d.ts.map +1 -1
- package/dist/components/DownloadCart/DownloadCartPage.js +316 -186
- package/dist/components/DownloadCart/DownloadCartPage.js.map +1 -1
- package/dist/components/DownloadCart/DownloadCartPage.module.scss +217 -0
- package/dist/components/DownloadCart/DownloadCartPage.module.scss.js +48 -0
- package/dist/components/DownloadCart/DownloadCartPage.module.scss.js.map +1 -0
- package/dist/components/DownloadCart/DownloadDetails.js +1 -1
- package/dist/components/DownloadCart/DownloadDetails.js.map +1 -1
- package/dist/components/DownloadCart/DownloadIneligibleForPackagingFilesFromListButton.js +33 -33
- package/dist/components/DownloadCart/DownloadIneligibleForPackagingFilesFromListButton.js.map +1 -1
- package/dist/components/DownloadCart/DownloadListTable.d.ts +4 -1
- package/dist/components/DownloadCart/DownloadListTable.d.ts.map +1 -1
- package/dist/components/DownloadCart/DownloadListTable.js +156 -236
- package/dist/components/DownloadCart/DownloadListTable.js.map +1 -1
- package/dist/components/DownloadCart/ShowDownloadV2.js +5 -5
- package/dist/components/DownloadCart/ShowDownloadV2.js.map +1 -1
- package/dist/components/Ecosystem/EcosystemSkeleton.js +8 -3
- package/dist/components/Ecosystem/EcosystemSkeleton.js.map +1 -1
- package/dist/components/EntityDownloadButton/EntityDownloadButton.d.ts +3 -0
- package/dist/components/EntityDownloadButton/EntityDownloadButton.d.ts.map +1 -1
- package/dist/components/EntityDownloadButton/EntityDownloadButton.js +113 -119
- package/dist/components/EntityDownloadButton/EntityDownloadButton.js.map +1 -1
- package/dist/components/EntityFinder/details/view/table/AddToDownloadListCell.js +3 -3
- package/dist/components/EntityFinder/details/view/table/AddToDownloadListCell.js.map +1 -1
- package/dist/components/FeaturedDataTabs/FacetPlotsCard.js +6 -2
- package/dist/components/FeaturedDataTabs/FacetPlotsCard.js.map +1 -1
- package/dist/components/FeaturedDataTabs/FeaturedDataTabs.js +11 -8
- package/dist/components/FeaturedDataTabs/FeaturedDataTabs.js.map +1 -1
- package/dist/components/FullWidthAlert/FullWidthAlert.d.ts +2 -2
- package/dist/components/FullWidthAlert/FullWidthAlert.js.map +1 -1
- package/dist/components/GenericCard/GenericCard.d.ts +5 -5
- package/dist/components/GenericCard/GenericCard.d.ts.map +1 -1
- package/dist/components/GenericCard/GenericCard.js +117 -103
- package/dist/components/GenericCard/GenericCard.js.map +1 -1
- package/dist/components/GenericCard/LabelMaybeWithIcon.d.ts +10 -0
- package/dist/components/GenericCard/LabelMaybeWithIcon.d.ts.map +1 -0
- package/dist/components/GenericCard/LabelMaybeWithIcon.js +33 -0
- package/dist/components/GenericCard/LabelMaybeWithIcon.js.map +1 -0
- package/dist/components/GenericCard/SynapseCardLabel.d.ts +2 -1
- package/dist/components/GenericCard/SynapseCardLabel.d.ts.map +1 -1
- package/dist/components/GenericCard/SynapseCardLabel.js +86 -81
- package/dist/components/GenericCard/SynapseCardLabel.js.map +1 -1
- package/dist/components/GenericCard/TableRowGenericCard.d.ts +7 -1
- package/dist/components/GenericCard/TableRowGenericCard.d.ts.map +1 -1
- package/dist/components/GenericCard/TableRowGenericCard.js +239 -202
- package/dist/components/GenericCard/TableRowGenericCard.js.map +1 -1
- package/dist/components/HeaderCard.js +17 -13
- package/dist/components/HeaderCard.js.map +1 -1
- package/dist/components/Icon/Icon.js +52 -52
- package/dist/components/Icon/Icon.js.map +1 -1
- package/dist/components/IconSvg/IconSvg.d.ts +1 -1
- package/dist/components/IconSvg/IconSvg.d.ts.map +1 -1
- package/dist/components/IconSvg/IconSvg.js +215 -171
- package/dist/components/IconSvg/IconSvg.js.map +1 -1
- package/dist/components/QueryWrapperPlotNav/QueryWrapperPlotNav.d.ts +1 -0
- package/dist/components/QueryWrapperPlotNav/QueryWrapperPlotNav.d.ts.map +1 -1
- package/dist/components/QueryWrapperPlotNav/QueryWrapperPlotNav.js +103 -102
- package/dist/components/QueryWrapperPlotNav/QueryWrapperPlotNav.js.map +1 -1
- package/dist/components/StorybookComponentWrapper.js +6 -3
- package/dist/components/StorybookComponentWrapper.js.map +1 -1
- package/dist/components/SynapseChat/SynapseChat.d.ts +7 -1
- package/dist/components/SynapseChat/SynapseChat.d.ts.map +1 -1
- package/dist/components/SynapseChat/SynapseChat.js +76 -67
- package/dist/components/SynapseChat/SynapseChat.js.map +1 -1
- package/dist/components/SynapseChat/SynapseChatInteraction.d.ts +2 -1
- package/dist/components/SynapseChat/SynapseChatInteraction.d.ts.map +1 -1
- package/dist/components/SynapseChat/SynapseChatInteraction.js +83 -58
- package/dist/components/SynapseChat/SynapseChatInteraction.js.map +1 -1
- package/dist/components/SynapseChat/SynapseChatMessage.d.ts +1 -0
- package/dist/components/SynapseChat/SynapseChatMessage.d.ts.map +1 -1
- package/dist/components/SynapseChat/SynapseChatMessage.js +16 -15
- package/dist/components/SynapseChat/SynapseChatMessage.js.map +1 -1
- package/dist/components/SynapseChat/SynapsePortalChatDialog.d.ts +12 -0
- package/dist/components/SynapseChat/SynapsePortalChatDialog.d.ts.map +1 -0
- package/dist/components/SynapseChat/SynapsePortalChatDialog.js +30 -0
- package/dist/components/SynapseChat/SynapsePortalChatDialog.js.map +1 -0
- package/dist/components/SynapseChat/extractMessageFromTraceEvent.d.ts.map +1 -1
- package/dist/components/SynapseChat/extractMessageFromTraceEvent.js +22 -16
- package/dist/components/SynapseChat/extractMessageFromTraceEvent.js.map +1 -1
- package/dist/components/SynapseChat/index.d.ts +2 -0
- package/dist/components/SynapseChat/index.d.ts.map +1 -1
- package/dist/components/SynapseChat/index.js +5 -3
- package/dist/components/SynapseChat/index.js.map +1 -1
- package/dist/components/SynapseChat/useChatState.d.ts +1 -1
- package/dist/components/SynapseChat/useChatState.d.ts.map +1 -1
- package/dist/components/SynapseChat/useChatState.js +10 -7
- package/dist/components/SynapseChat/useChatState.js.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseHomepageChatSearch.d.ts.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseHomepageChatSearch.js +30 -32
- package/dist/components/SynapseHomepageV2/SynapseHomepageChatSearch.js.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseHomepageSearch.d.ts.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseHomepageSearch.js +27 -30
- package/dist/components/SynapseHomepageV2/SynapseHomepageSearch.js.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseSearchChips.d.ts.map +1 -1
- package/dist/components/SynapseHomepageV2/SynapseSearchChips.js +14 -17
- package/dist/components/SynapseHomepageV2/SynapseSearchChips.js.map +1 -1
- package/dist/components/SynapseNavDrawer/SynapseNavDrawer.d.ts.map +1 -1
- package/dist/components/SynapseNavDrawer/SynapseNavDrawer.js +114 -115
- package/dist/components/SynapseNavDrawer/SynapseNavDrawer.js.map +1 -1
- package/dist/components/SynapsePortalBanners/SynapsePortalBanners.d.ts.map +1 -1
- package/dist/components/SynapsePortalBanners/SynapsePortalBanners.js +39 -39
- package/dist/components/SynapsePortalBanners/SynapsePortalBanners.js.map +1 -1
- package/dist/components/SynapseSearchPageResults/SearchPagePortalBanners.js +18 -18
- package/dist/components/SynapseSearchPageResults/SearchPagePortalBanners.js.map +1 -1
- package/dist/components/SynapseSearchPageResults/SynapseSearchResultsCard.d.ts.map +1 -1
- package/dist/components/SynapseSearchPageResults/SynapseSearchResultsCard.js +66 -64
- package/dist/components/SynapseSearchPageResults/SynapseSearchResultsCard.js.map +1 -1
- package/dist/components/SynapseTable/RowSelection/RowSelectionControls.js +13 -13
- package/dist/components/SynapseTable/RowSelection/RowSelectionControls.js.map +1 -1
- package/dist/components/SynapseTable/TopLevelControls/TopLevelControlsUtils.js +9 -9
- package/dist/components/SynapseTable/TopLevelControls/TopLevelControlsUtils.js.map +1 -1
- package/dist/components/TextToComponentCollapse.d.ts +16 -0
- package/dist/components/TextToComponentCollapse.d.ts.map +1 -0
- package/dist/components/TextToComponentCollapse.js +29 -0
- package/dist/components/TextToComponentCollapse.js.map +1 -0
- package/dist/components/download_list/AddToDownloadListConfirmationAlert/AddToDownloadListConfirmationAlert.js +8 -3
- package/dist/components/download_list/AddToDownloadListConfirmationAlert/AddToDownloadListConfirmationAlert.js.map +1 -1
- package/dist/components/download_list/DownloadConfirmationUI.d.ts +1 -1
- package/dist/components/download_list/DownloadConfirmationUI.js +22 -22
- package/dist/components/download_list/DownloadConfirmationUI.js.map +1 -1
- package/dist/components/download_list/DownloadConfirmationUtils.js +4 -4
- package/dist/components/download_list/DownloadConfirmationUtils.js.map +1 -1
- package/dist/components/index.js +85 -83
- package/dist/components/index.js.map +1 -1
- package/dist/components/row_renderers/ObservationCard.js +12 -11
- package/dist/components/row_renderers/ObservationCard.js.map +1 -1
- package/dist/components/row_renderers/utils/CardFooter.d.ts +1 -3
- package/dist/components/row_renderers/utils/CardFooter.d.ts.map +1 -1
- package/dist/components/row_renderers/utils/CardFooter.js +31 -45
- package/dist/components/row_renderers/utils/CardFooter.js.map +1 -1
- package/dist/components/table/CsvPreview/CsvPreview.js +8 -3
- package/dist/components/table/CsvPreview/CsvPreview.js.map +1 -1
- package/dist/components/table/CsvPreview/CsvPreviewDialog.js +8 -3
- package/dist/components/table/CsvPreview/CsvPreviewDialog.js.map +1 -1
- package/dist/features/curator/GridPage/GridPage.js +8 -3
- package/dist/features/curator/GridPage/GridPage.js.map +1 -1
- package/dist/features/curator/GridPage/components/GridPageTitle.js +8 -3
- package/dist/features/curator/GridPage/components/GridPageTitle.js.map +1 -1
- package/dist/index.js +137 -135
- package/dist/index.js.map +1 -1
- package/dist/style/abstracts/_functions.scss +0 -0
- package/dist/style/abstracts/_mixins.scss +0 -0
- package/dist/style/abstracts/_variables.scss +0 -0
- package/dist/style/base/_base.scss +0 -0
- package/dist/style/base/_fonts.scss +0 -0
- package/dist/style/base/_helpers.scss +0 -0
- package/dist/style/components/_all.scss +0 -1
- package/dist/style/components/_cards.scss +22 -0
- package/dist/style/components/_download-list-v2.scss +1 -1
- package/dist/style/components/_query-wrapper-plot-nav.scss +13 -0
- package/dist/style/main.css +1 -1
- package/dist/style/main.scss +0 -0
- package/dist/style/vendors/_normalize.scss +0 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/utils/AppUtils/session/ApplicationSessionManager.d.ts.map +1 -1
- package/dist/utils/AppUtils/session/ApplicationSessionManager.js.map +1 -1
- package/dist/utils/context/FullContextProvider.js +9 -9
- package/dist/utils/context/FullContextProvider.js.map +1 -1
- package/dist/utils/context/SynapseContext.d.ts.map +1 -1
- package/dist/utils/context/SynapseContext.js +1 -0
- package/dist/utils/context/SynapseContext.js.map +1 -1
- package/dist/utils/functions/SqlFunctions.d.ts +4 -0
- package/dist/utils/functions/SqlFunctions.d.ts.map +1 -1
- package/dist/utils/functions/SqlFunctions.js +25 -23
- package/dist/utils/functions/SqlFunctions.js.map +1 -1
- package/package.json +25 -24
- package/dist/assets/themed_icons/Challenge.d.ts +0 -3
- package/dist/assets/themed_icons/Challenge.d.ts.map +0 -1
- package/dist/assets/themed_icons/Challenge.js +0 -25
- package/dist/assets/themed_icons/Challenge.js.map +0 -1
- package/dist/style/components/_download-cart-page.scss +0 -204
|
@@ -1,42 +1,56 @@
|
|
|
1
|
-
import { jsxs as
|
|
2
|
-
import { SynapseSpinner as
|
|
3
|
-
import
|
|
4
|
-
import { SmartToyTwoTone as
|
|
5
|
-
import { useTheme as
|
|
6
|
-
import { useRef as
|
|
7
|
-
import { MarkdownSynapse as
|
|
8
|
-
function
|
|
9
|
-
return "reasoningText" in
|
|
1
|
+
import { jsxs as s, Fragment as A, jsx as t } from "react/jsx-runtime";
|
|
2
|
+
import { SynapseSpinner as L } from "../LoadingScreen/LoadingScreen.js";
|
|
3
|
+
import j from "./extractMessageFromTraceEvent.js";
|
|
4
|
+
import { SmartToyTwoTone as B, KeyboardArrowDown as P, KeyboardArrowRight as q } from "@mui/icons-material";
|
|
5
|
+
import { useTheme as F, ListItem as T, ListItemText as z, Box as d, Button as E, Collapse as D, Stack as G, Tooltip as K, Chip as O, Alert as $ } from "@mui/material";
|
|
6
|
+
import { useRef as H, useState as _, useEffect as J, useMemo as x } from "react";
|
|
7
|
+
import { MarkdownSynapse as C } from "../Markdown/MarkdownSynapse.js";
|
|
8
|
+
function N(n) {
|
|
9
|
+
return "reasoningText" in n ? n.reasoningText : "";
|
|
10
10
|
}
|
|
11
|
-
function
|
|
12
|
-
userMessage:
|
|
13
|
-
chatResponseText:
|
|
14
|
-
chatErrorReason:
|
|
15
|
-
chatResponseTrace:
|
|
16
|
-
scrollIntoView:
|
|
11
|
+
function ee({
|
|
12
|
+
userMessage: n,
|
|
13
|
+
chatResponseText: i,
|
|
14
|
+
chatErrorReason: c,
|
|
15
|
+
chatResponseTrace: m,
|
|
16
|
+
scrollIntoView: u = !1,
|
|
17
|
+
onSendChat: f
|
|
17
18
|
}) {
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
}, [
|
|
22
|
-
const
|
|
23
|
-
() => (
|
|
24
|
-
[
|
|
25
|
-
),
|
|
26
|
-
() =>
|
|
27
|
-
[
|
|
28
|
-
),
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
19
|
+
const h = F(), a = H(null), [p, k] = _(!1);
|
|
20
|
+
J(() => {
|
|
21
|
+
u && a.current && a.current.scrollIntoView({ behavior: "smooth" });
|
|
22
|
+
}, [a, u]);
|
|
23
|
+
const g = !i && !c, l = x(
|
|
24
|
+
() => (m ?? []).flatMap((e) => j(e))?.filter((e) => !!e),
|
|
25
|
+
[m]
|
|
26
|
+
), v = l.length > 0, y = x(
|
|
27
|
+
() => l.filter((e) => "reasoningText" in e).at(-1),
|
|
28
|
+
[l]
|
|
29
|
+
), M = y == null ? "Thinking..." : y.reasoningText, I = g ? M : `${p ? "Hide" : "Show"} Trace`, { textContent: w, guidePrompts: b } = x(() => {
|
|
30
|
+
try {
|
|
31
|
+
const o = new DOMParser().parseFromString(i ?? "", "text/html");
|
|
32
|
+
o.querySelectorAll("tool_name, actions").forEach((r) => r.remove());
|
|
33
|
+
const W = Array.from(
|
|
34
|
+
o.querySelectorAll("guideprompt")
|
|
35
|
+
).map((r) => r.textContent?.trim()).filter((r) => !!r);
|
|
36
|
+
o.querySelectorAll("guideprompt").forEach((r) => r.remove());
|
|
37
|
+
const S = o.querySelector("chat");
|
|
38
|
+
return {
|
|
39
|
+
textContent: S ? S.textContent ?? "" : o.body.textContent ?? "",
|
|
40
|
+
guidePrompts: W
|
|
41
|
+
};
|
|
42
|
+
} catch (e) {
|
|
43
|
+
return console.error(e), { textContent: i ?? "", guidePrompts: [] };
|
|
44
|
+
}
|
|
45
|
+
}, [i]);
|
|
46
|
+
return /* @__PURE__ */ s(A, { children: [
|
|
47
|
+
/* @__PURE__ */ t(
|
|
48
|
+
T,
|
|
35
49
|
{
|
|
36
|
-
ref:
|
|
50
|
+
ref: a,
|
|
37
51
|
sx: {
|
|
38
52
|
alignSelf: "flex-end",
|
|
39
|
-
backgroundColor:
|
|
53
|
+
backgroundColor: h.palette.secondary[100],
|
|
40
54
|
borderRadius: "24px",
|
|
41
55
|
maxWidth: "70%",
|
|
42
56
|
display: "block",
|
|
@@ -45,11 +59,11 @@ function N({
|
|
|
45
59
|
wordWrap: "break-word",
|
|
46
60
|
width: "auto"
|
|
47
61
|
},
|
|
48
|
-
children: /* @__PURE__ */
|
|
62
|
+
children: /* @__PURE__ */ t(z, { primary: n })
|
|
49
63
|
}
|
|
50
64
|
),
|
|
51
|
-
/* @__PURE__ */
|
|
52
|
-
|
|
65
|
+
/* @__PURE__ */ s(
|
|
66
|
+
T,
|
|
53
67
|
{
|
|
54
68
|
sx: {
|
|
55
69
|
display: "grid",
|
|
@@ -60,8 +74,8 @@ function N({
|
|
|
60
74
|
p: "0px"
|
|
61
75
|
},
|
|
62
76
|
children: [
|
|
63
|
-
/* @__PURE__ */
|
|
64
|
-
|
|
77
|
+
/* @__PURE__ */ t(
|
|
78
|
+
d,
|
|
65
79
|
{
|
|
66
80
|
sx: {
|
|
67
81
|
p: "3px",
|
|
@@ -72,11 +86,11 @@ function N({
|
|
|
72
86
|
borderWidth: "1px",
|
|
73
87
|
borderColor: "grey.300"
|
|
74
88
|
},
|
|
75
|
-
children: /* @__PURE__ */
|
|
89
|
+
children: /* @__PURE__ */ t(B, { sx: { color: "secondary.main" } })
|
|
76
90
|
}
|
|
77
91
|
),
|
|
78
|
-
/* @__PURE__ */
|
|
79
|
-
|
|
92
|
+
/* @__PURE__ */ s(
|
|
93
|
+
d,
|
|
80
94
|
{
|
|
81
95
|
sx: {
|
|
82
96
|
borderRadius: "10px",
|
|
@@ -85,14 +99,14 @@ function N({
|
|
|
85
99
|
overflow: "auto"
|
|
86
100
|
},
|
|
87
101
|
children: [
|
|
88
|
-
/* @__PURE__ */
|
|
89
|
-
|
|
102
|
+
/* @__PURE__ */ s(
|
|
103
|
+
d,
|
|
90
104
|
{
|
|
91
105
|
component: "aside",
|
|
92
106
|
sx: {
|
|
93
107
|
".markdown": {
|
|
94
108
|
fontStyle: "italic",
|
|
95
|
-
borderLeft: `4px solid ${
|
|
109
|
+
borderLeft: `4px solid ${h.palette.grey[300]}`,
|
|
96
110
|
marginLeft: "4px",
|
|
97
111
|
paddingLeft: "8px",
|
|
98
112
|
mt: 1,
|
|
@@ -100,15 +114,15 @@ function N({
|
|
|
100
114
|
}
|
|
101
115
|
},
|
|
102
116
|
children: [
|
|
103
|
-
/* @__PURE__ */
|
|
104
|
-
|
|
117
|
+
/* @__PURE__ */ t(
|
|
118
|
+
E,
|
|
105
119
|
{
|
|
106
120
|
variant: "outlined",
|
|
107
121
|
size: "small",
|
|
108
|
-
startIcon:
|
|
109
|
-
disabled: !
|
|
122
|
+
startIcon: g ? /* @__PURE__ */ t(L, { size: 14 }) : p ? /* @__PURE__ */ t(P, { sx: { width: "14px" } }) : /* @__PURE__ */ t(q, { sx: { width: "14px" } }),
|
|
123
|
+
disabled: !v,
|
|
110
124
|
onClick: () => {
|
|
111
|
-
|
|
125
|
+
k((e) => !e);
|
|
112
126
|
},
|
|
113
127
|
sx: {
|
|
114
128
|
height: "20px",
|
|
@@ -124,30 +138,41 @@ function N({
|
|
|
124
138
|
pl: 0,
|
|
125
139
|
".MuiButton-startIcon": { mr: 0.5 }
|
|
126
140
|
},
|
|
127
|
-
children: /* @__PURE__ */
|
|
141
|
+
children: /* @__PURE__ */ t(d, { sx: { overflow: "hidden", textOverflow: "ellipsis" }, children: I })
|
|
128
142
|
}
|
|
129
143
|
),
|
|
130
|
-
|
|
131
|
-
|
|
144
|
+
m && /* @__PURE__ */ t(D, { in: p, children: /* @__PURE__ */ t(
|
|
145
|
+
C,
|
|
132
146
|
{
|
|
133
|
-
markdown:
|
|
147
|
+
markdown: l.map(N).filter((e) => e.trim().length > 0).join("<br/><br/>")
|
|
134
148
|
}
|
|
135
149
|
) })
|
|
136
150
|
]
|
|
137
151
|
}
|
|
138
152
|
),
|
|
139
|
-
|
|
153
|
+
w && /* @__PURE__ */ t(C, { markdown: w }),
|
|
154
|
+
f && b.length > 0 && /* @__PURE__ */ t(G, { direction: "row", flexWrap: "wrap", gap: 1, mt: 1, children: b.map((e) => /* @__PURE__ */ t(K, { title: e, children: /* @__PURE__ */ t(
|
|
155
|
+
O,
|
|
156
|
+
{
|
|
157
|
+
label: e,
|
|
158
|
+
variant: "outlined",
|
|
159
|
+
color: "primary",
|
|
160
|
+
clickable: !0,
|
|
161
|
+
onClick: () => f(e),
|
|
162
|
+
sx: { maxWidth: 200 }
|
|
163
|
+
}
|
|
164
|
+
) }, e)) })
|
|
140
165
|
]
|
|
141
166
|
}
|
|
142
167
|
)
|
|
143
168
|
]
|
|
144
169
|
}
|
|
145
170
|
),
|
|
146
|
-
|
|
171
|
+
c && /* @__PURE__ */ t($, { severity: "error", sx: { my: 2 }, children: c })
|
|
147
172
|
] });
|
|
148
173
|
}
|
|
149
174
|
export {
|
|
150
|
-
|
|
151
|
-
|
|
175
|
+
ee as SynapseChatInteraction,
|
|
176
|
+
ee as default
|
|
152
177
|
};
|
|
153
178
|
//# sourceMappingURL=SynapseChatInteraction.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SynapseChatInteraction.js","sources":["../../../src/components/SynapseChat/SynapseChatInteraction.tsx"],"sourcesContent":["import { SynapseSpinner } from '@/components/LoadingScreen/LoadingScreen'\nimport extractMessageFromTraceEvent, {\n TraceMessage,\n} from '@/components/SynapseChat/extractMessageFromTraceEvent'\nimport {\n KeyboardArrowDown,\n KeyboardArrowRight,\n SmartToyTwoTone,\n} from '@mui/icons-material'\nimport {\n Alert,\n Box,\n Button,\n Collapse,\n ListItem,\n ListItemText,\n useTheme,\n} from '@mui/material'\nimport { Color } from '@mui/material/styles'\nimport { TraceEvent } from '@sage-bionetworks/synapse-types'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport MarkdownSynapse from '../Markdown/MarkdownSynapse'\n\nexport type SynapseChatInteractionProps = {\n userMessage: string\n chatResponseText?: string\n chatResponseTrace?: TraceEvent[]\n scrollIntoView?: boolean\n chatErrorReason?: string\n}\n\n// Show tool calls in the trace. Useful for development. We may want to show them to users in the future.\nconst SHOW_TOOL_USE = false\n\nfunction getMarkdownForTraceMessage(traceMessage: TraceMessage): string {\n if ('reasoningText' in traceMessage) {\n return traceMessage.reasoningText\n }\n if (SHOW_TOOL_USE && 'toolName' in traceMessage) {\n return `**Tool Used:** \\`${\n traceMessage.toolName\n }\\`\\n\\n**Tool Input:**\\n\\`\\`\\`json\\n${JSON.stringify(\n traceMessage.toolInput,\n null,\n 2,\n )}\\n\\`\\`\\`\\n`\n }\n return ''\n}\n\nexport function SynapseChatInteraction({\n userMessage,\n chatResponseText,\n chatErrorReason,\n chatResponseTrace,\n scrollIntoView = false,\n}: SynapseChatInteractionProps) {\n const theme = useTheme()\n const ref = useRef<HTMLLIElement | null>(null)\n const [showTrace, setShowTrace] = useState(false)\n useEffect(() => {\n // on mount, scroll into view if instructed\n if (scrollIntoView) {\n if (ref.current) {\n ref.current.scrollIntoView({ behavior: 'smooth' })\n }\n }\n }, [ref])\n\n const isLoading = !chatResponseText && !chatErrorReason\n\n const traceMessages = useMemo(\n () =>\n (chatResponseTrace ?? [])\n .flatMap(traceEvent => extractMessageFromTraceEvent(traceEvent))\n ?.filter(trace => !!trace),\n [chatResponseTrace],\n )\n\n const hasTraceInfo = traceMessages.length > 0\n\n const lastReasoningMessage = useMemo(\n () => traceMessages.filter(trace => 'reasoningText' in trace).at(-1),\n [traceMessages],\n )\n\n const traceButtonLoadingText =\n lastReasoningMessage == null\n ? 'Thinking...'\n : lastReasoningMessage.reasoningText\n\n const traceButtonText = isLoading\n ? traceButtonLoadingText\n : `${showTrace ? 'Hide' : 'Show'} Trace`\n\n const textContent = useMemo(() => {\n const parser = new DOMParser()\n const doc = parser.parseFromString(chatResponseText ?? '', 'text/html')\n const elementsToRemove = doc.querySelectorAll('tool_name')\n elementsToRemove.forEach(element => element.remove())\n return doc.body.textContent ?? ''\n }, [chatResponseText])\n\n return (\n <>\n <ListItem\n ref={ref}\n sx={{\n alignSelf: 'flex-end',\n backgroundColor: (theme.palette.secondary as unknown as Color)[100],\n borderRadius: '24px',\n maxWidth: '70%',\n display: 'block',\n mb: '5px',\n p: '8px 12px',\n wordWrap: 'break-word',\n width: 'auto',\n }}\n >\n <ListItemText primary={userMessage} />\n </ListItem>\n <ListItem\n sx={{\n display: 'grid',\n gridTemplateColumns: '50px auto',\n columnGap: '0px',\n justifyItems: 'center',\n alignItems: 'start',\n p: '0px',\n }}\n >\n <Box\n sx={{\n p: '3px',\n mt: '10px',\n height: '31px',\n borderRadius: '50%',\n borderStyle: 'solid',\n borderWidth: '1px',\n borderColor: 'grey.300',\n }}\n >\n <SmartToyTwoTone sx={{ color: 'secondary.main' }} />\n </Box>\n <Box\n sx={{\n borderRadius: '10px',\n padding: '10px',\n maxWidth: '100%',\n overflow: 'auto',\n }}\n >\n <Box\n component={'aside'}\n sx={{\n '.markdown': {\n fontStyle: 'italic',\n borderLeft: `4px solid ${theme.palette.grey[300]}`,\n marginLeft: '4px',\n paddingLeft: '8px',\n mt: 1,\n mb: 2,\n },\n }}\n >\n <Button\n variant={'outlined'}\n size={'small'}\n startIcon={\n isLoading ? (\n <SynapseSpinner size={14} />\n ) : showTrace ? (\n <KeyboardArrowDown sx={{ width: '14px' }} />\n ) : (\n <KeyboardArrowRight sx={{ width: '14px' }} />\n )\n }\n disabled={!hasTraceInfo}\n onClick={() => {\n setShowTrace(v => !v)\n }}\n sx={{\n height: '20px',\n fontSize: '12px',\n fontWeight: 600,\n mb: 1,\n border: 'none !important',\n color: 'grey.700',\n justifyContent: 'flex-start',\n whiteSpace: 'nowrap',\n maxWidth: '325px',\n textTransform: 'none',\n pl: 0,\n '.MuiButton-startIcon': { mr: 0.5 },\n }}\n >\n <Box sx={{ overflow: 'hidden', textOverflow: 'ellipsis' }}>\n {traceButtonText}\n </Box>\n </Button>\n {chatResponseTrace && (\n <Collapse in={showTrace}>\n <MarkdownSynapse\n markdown={traceMessages\n .map(getMarkdownForTraceMessage)\n .filter(md => md.trim().length > 0)\n .join('<br/><br/>')}\n />\n </Collapse>\n )}\n </Box>\n {textContent && <MarkdownSynapse markdown={textContent} />}\n </Box>\n </ListItem>\n {chatErrorReason && (\n <Alert severity={'error'} sx={{ my: 2 }}>\n {chatErrorReason}\n </Alert>\n )}\n </>\n )\n}\n\nexport default SynapseChatInteraction\n"],"names":["getMarkdownForTraceMessage","traceMessage","SynapseChatInteraction","userMessage","chatResponseText","chatErrorReason","chatResponseTrace","scrollIntoView","theme","useTheme","ref","useRef","showTrace","setShowTrace","useState","useEffect","isLoading","traceMessages","useMemo","traceEvent","extractMessageFromTraceEvent","trace","hasTraceInfo","lastReasoningMessage","traceButtonLoadingText","traceButtonText","textContent","doc","element","jsxs","Fragment","jsx","ListItem","ListItemText","Box","SmartToyTwoTone","Button","SynapseSpinner","KeyboardArrowDown","KeyboardArrowRight","v","Collapse","MarkdownSynapse","md","Alert"],"mappings":";;;;;;;AAkCA,SAASA,EAA2BC,GAAoC;AACtE,SAAI,mBAAmBA,IACdA,EAAa,gBAWf;AACT;AAEO,SAASC,EAAuB;AAAA,EACrC,aAAAC;AAAA,EACA,kBAAAC;AAAA,EACA,iBAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,gBAAAC,IAAiB;AACnB,GAAgC;AAC9B,QAAMC,IAAQC,EAAA,GACRC,IAAMC,EAA6B,IAAI,GACvC,CAACC,GAAWC,CAAY,IAAIC,EAAS,EAAK;AAChD,EAAAC,EAAU,MAAM;AAEd,IAAIR,KACEG,EAAI,WACNA,EAAI,QAAQ,eAAe,EAAE,UAAU,UAAU;AAAA,EAGvD,GAAG,CAACA,CAAG,CAAC;AAER,QAAMM,IAAY,CAACZ,KAAoB,CAACC,GAElCY,IAAgBC;AAAA,IACpB,OACGZ,KAAqB,CAAA,GACnB,QAAQ,CAAAa,MAAcC,EAA6BD,CAAU,CAAC,GAC7D,OAAO,CAAAE,MAAS,CAAC,CAACA,CAAK;AAAA,IAC7B,CAACf,CAAiB;AAAA,EAAA,GAGdgB,IAAeL,EAAc,SAAS,GAEtCM,IAAuBL;AAAA,IAC3B,MAAMD,EAAc,OAAO,CAAAI,MAAS,mBAAmBA,CAAK,EAAE,GAAG,EAAE;AAAA,IACnE,CAACJ,CAAa;AAAA,EAAA,GAGVO,IACJD,KAAwB,OACpB,gBACAA,EAAqB,eAErBE,IAAkBT,IACpBQ,IACA,GAAGZ,IAAY,SAAS,MAAM,UAE5Bc,IAAcR,EAAQ,MAAM;AAEhC,UAAMS,IADS,IAAI,UAAA,EACA,gBAAgBvB,KAAoB,IAAI,WAAW;AAEtE,WADyBuB,EAAI,iBAAiB,WAAW,EACxC,QAAQ,CAAAC,MAAWA,EAAQ,OAAA,CAAQ,GAC7CD,EAAI,KAAK,eAAe;AAAA,EACjC,GAAG,CAACvB,CAAgB,CAAC;AAErB,SACE,gBAAAyB,EAAAC,GAAA,EACE,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,KAAAtB;AAAA,QACA,IAAI;AAAA,UACF,WAAW;AAAA,UACX,iBAAkBF,EAAM,QAAQ,UAA+B,GAAG;AAAA,UAClE,cAAc;AAAA,UACd,UAAU;AAAA,UACV,SAAS;AAAA,UACT,IAAI;AAAA,UACJ,GAAG;AAAA,UACH,UAAU;AAAA,UACV,OAAO;AAAA,QAAA;AAAA,QAGT,UAAA,gBAAAuB,EAACE,GAAA,EAAa,SAAS9B,EAAA,CAAa;AAAA,MAAA;AAAA,IAAA;AAAA,IAEtC,gBAAA0B;AAAA,MAACG;AAAA,MAAA;AAAA,QACC,IAAI;AAAA,UACF,SAAS;AAAA,UACT,qBAAqB;AAAA,UACrB,WAAW;AAAA,UACX,cAAc;AAAA,UACd,YAAY;AAAA,UACZ,GAAG;AAAA,QAAA;AAAA,QAGL,UAAA;AAAA,UAAA,gBAAAD;AAAA,YAACG;AAAA,YAAA;AAAA,cACC,IAAI;AAAA,gBACF,GAAG;AAAA,gBACH,IAAI;AAAA,gBACJ,QAAQ;AAAA,gBACR,cAAc;AAAA,gBACd,aAAa;AAAA,gBACb,aAAa;AAAA,gBACb,aAAa;AAAA,cAAA;AAAA,cAGf,4BAACC,GAAA,EAAgB,IAAI,EAAE,OAAO,mBAAiB,CAAG;AAAA,YAAA;AAAA,UAAA;AAAA,UAEpD,gBAAAN;AAAA,YAACK;AAAA,YAAA;AAAA,cACC,IAAI;AAAA,gBACF,cAAc;AAAA,gBACd,SAAS;AAAA,gBACT,UAAU;AAAA,gBACV,UAAU;AAAA,cAAA;AAAA,cAGZ,UAAA;AAAA,gBAAA,gBAAAL;AAAA,kBAACK;AAAA,kBAAA;AAAA,oBACC,WAAW;AAAA,oBACX,IAAI;AAAA,sBACF,aAAa;AAAA,wBACX,WAAW;AAAA,wBACX,YAAY,aAAa1B,EAAM,QAAQ,KAAK,GAAG,CAAC;AAAA,wBAChD,YAAY;AAAA,wBACZ,aAAa;AAAA,wBACb,IAAI;AAAA,wBACJ,IAAI;AAAA,sBAAA;AAAA,oBACN;AAAA,oBAGF,UAAA;AAAA,sBAAA,gBAAAuB;AAAA,wBAACK;AAAA,wBAAA;AAAA,0BACC,SAAS;AAAA,0BACT,MAAM;AAAA,0BACN,WACEpB,IACE,gBAAAe,EAACM,GAAA,EAAe,MAAM,GAAA,CAAI,IACxBzB,IACF,gBAAAmB,EAACO,GAAA,EAAkB,IAAI,EAAE,OAAO,UAAU,IAE1C,gBAAAP,EAACQ,KAAmB,IAAI,EAAE,OAAO,OAAA,EAAO,CAAG;AAAA,0BAG/C,UAAU,CAACjB;AAAA,0BACX,SAAS,MAAM;AACb,4BAAAT,EAAa,CAAA2B,MAAK,CAACA,CAAC;AAAA,0BACtB;AAAA,0BACA,IAAI;AAAA,4BACF,QAAQ;AAAA,4BACR,UAAU;AAAA,4BACV,YAAY;AAAA,4BACZ,IAAI;AAAA,4BACJ,QAAQ;AAAA,4BACR,OAAO;AAAA,4BACP,gBAAgB;AAAA,4BAChB,YAAY;AAAA,4BACZ,UAAU;AAAA,4BACV,eAAe;AAAA,4BACf,IAAI;AAAA,4BACJ,wBAAwB,EAAE,IAAI,IAAA;AAAA,0BAAI;AAAA,0BAGpC,UAAA,gBAAAT,EAACG,KAAI,IAAI,EAAE,UAAU,UAAU,cAAc,cAC1C,UAAAT,EAAA,CACH;AAAA,wBAAA;AAAA,sBAAA;AAAA,sBAEDnB,KACC,gBAAAyB,EAACU,GAAA,EAAS,IAAI7B,GACZ,UAAA,gBAAAmB;AAAA,wBAACW;AAAA,wBAAA;AAAA,0BACC,UAAUzB,EACP,IAAIjB,CAA0B,EAC9B,OAAO,CAAA2C,MAAMA,EAAG,KAAA,EAAO,SAAS,CAAC,EACjC,KAAK,YAAY;AAAA,wBAAA;AAAA,sBAAA,EACtB,CACF;AAAA,oBAAA;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAGHjB,KAAe,gBAAAK,EAACW,GAAA,EAAgB,UAAUhB,EAAA,CAAa;AAAA,cAAA;AAAA,YAAA;AAAA,UAAA;AAAA,QAC1D;AAAA,MAAA;AAAA,IAAA;AAAA,IAEDrB,KACC,gBAAA0B,EAACa,GAAA,EAAM,UAAU,SAAS,IAAI,EAAE,IAAI,KACjC,UAAAvC,EAAA,CACH;AAAA,EAAA,GAEJ;AAEJ;"}
|
|
1
|
+
{"version":3,"file":"SynapseChatInteraction.js","sources":["../../../src/components/SynapseChat/SynapseChatInteraction.tsx"],"sourcesContent":["import { SynapseSpinner } from '@/components/LoadingScreen/LoadingScreen'\nimport extractMessageFromTraceEvent, {\n TraceMessage,\n} from '@/components/SynapseChat/extractMessageFromTraceEvent'\nimport {\n KeyboardArrowDown,\n KeyboardArrowRight,\n SmartToyTwoTone,\n} from '@mui/icons-material'\nimport {\n Alert,\n Box,\n Button,\n Chip,\n Collapse,\n ListItem,\n ListItemText,\n Stack,\n Tooltip,\n useTheme,\n} from '@mui/material'\nimport { Color } from '@mui/material/styles'\nimport { TraceEvent } from '@sage-bionetworks/synapse-types'\nimport { useEffect, useMemo, useRef, useState } from 'react'\nimport MarkdownSynapse from '../Markdown/MarkdownSynapse'\n\nexport type SynapseChatInteractionProps = {\n userMessage: string\n chatResponseText?: string\n chatResponseTrace?: TraceEvent[]\n scrollIntoView?: boolean\n chatErrorReason?: string\n onSendChat?: (message: string) => void\n}\n\n// Show tool calls in the trace. Useful for development. We may want to show them to users in the future.\nconst SHOW_TOOL_USE = false\n\nfunction getMarkdownForTraceMessage(traceMessage: TraceMessage): string {\n if ('reasoningText' in traceMessage) {\n return traceMessage.reasoningText\n }\n if (SHOW_TOOL_USE && 'toolName' in traceMessage) {\n return `**Tool Used:** \\`${\n traceMessage.toolName\n }\\`\\n\\n**Tool Input:**\\n\\`\\`\\`json\\n${JSON.stringify(\n traceMessage.toolInput,\n null,\n 2,\n )}\\n\\`\\`\\`\\n`\n }\n return ''\n}\n\nexport function SynapseChatInteraction({\n userMessage,\n chatResponseText,\n chatErrorReason,\n chatResponseTrace,\n scrollIntoView = false,\n onSendChat,\n}: SynapseChatInteractionProps) {\n const theme = useTheme()\n const ref = useRef<HTMLLIElement | null>(null)\n const [showTrace, setShowTrace] = useState(false)\n\n useEffect(() => {\n // on mount, scroll into view if instructed\n if (scrollIntoView) {\n if (ref.current) {\n ref.current.scrollIntoView({ behavior: 'smooth' })\n }\n }\n }, [ref, scrollIntoView])\n\n const isLoading = !chatResponseText && !chatErrorReason\n\n const traceMessages = useMemo(\n () =>\n (chatResponseTrace ?? [])\n .flatMap(traceEvent => extractMessageFromTraceEvent(traceEvent))\n ?.filter(trace => !!trace),\n [chatResponseTrace],\n )\n\n const hasTraceInfo = traceMessages.length > 0\n\n const lastReasoningMessage = useMemo(\n () => traceMessages.filter(trace => 'reasoningText' in trace).at(-1),\n [traceMessages],\n )\n\n const traceButtonLoadingText =\n lastReasoningMessage == null\n ? 'Thinking...'\n : lastReasoningMessage.reasoningText\n\n const traceButtonText = isLoading\n ? traceButtonLoadingText\n : `${showTrace ? 'Hide' : 'Show'} Trace`\n\n const { textContent, guidePrompts } = useMemo(() => {\n try {\n const parser = new DOMParser()\n const doc = parser.parseFromString(chatResponseText ?? '', 'text/html')\n\n // Remove tool_name and actions elements (AI XML tags not for display)\n doc\n .querySelectorAll('tool_name, actions')\n .forEach(element => element.remove())\n\n // Extract guideprompts before removing them\n const extractedGuidePrompts = Array.from(\n doc.querySelectorAll('guideprompt'),\n )\n .map(el => el.textContent?.trim())\n .filter((t): t is string => !!t)\n\n // Remove guideprompt elements\n doc.querySelectorAll('guideprompt').forEach(element => element.remove())\n\n // Extract text from <chat> element if present, otherwise use full body text\n const chatElement = doc.querySelector('chat')\n return {\n textContent: chatElement\n ? chatElement.textContent ?? ''\n : doc.body.textContent ?? '',\n guidePrompts: extractedGuidePrompts,\n }\n } catch (e) {\n console.error(e)\n return { textContent: chatResponseText ?? '', guidePrompts: [] }\n }\n }, [chatResponseText])\n\n return (\n <>\n <ListItem\n ref={ref}\n sx={{\n alignSelf: 'flex-end',\n backgroundColor: (theme.palette.secondary as unknown as Color)[100],\n borderRadius: '24px',\n maxWidth: '70%',\n display: 'block',\n mb: '5px',\n p: '8px 12px',\n wordWrap: 'break-word',\n width: 'auto',\n }}\n >\n <ListItemText primary={userMessage} />\n </ListItem>\n <ListItem\n sx={{\n display: 'grid',\n gridTemplateColumns: '50px auto',\n columnGap: '0px',\n justifyItems: 'center',\n alignItems: 'start',\n p: '0px',\n }}\n >\n <Box\n sx={{\n p: '3px',\n mt: '10px',\n height: '31px',\n borderRadius: '50%',\n borderStyle: 'solid',\n borderWidth: '1px',\n borderColor: 'grey.300',\n }}\n >\n <SmartToyTwoTone sx={{ color: 'secondary.main' }} />\n </Box>\n <Box\n sx={{\n borderRadius: '10px',\n padding: '10px',\n maxWidth: '100%',\n overflow: 'auto',\n }}\n >\n <Box\n component={'aside'}\n sx={{\n '.markdown': {\n fontStyle: 'italic',\n borderLeft: `4px solid ${theme.palette.grey[300]}`,\n marginLeft: '4px',\n paddingLeft: '8px',\n mt: 1,\n mb: 2,\n },\n }}\n >\n <Button\n variant={'outlined'}\n size={'small'}\n startIcon={\n isLoading ? (\n <SynapseSpinner size={14} />\n ) : showTrace ? (\n <KeyboardArrowDown sx={{ width: '14px' }} />\n ) : (\n <KeyboardArrowRight sx={{ width: '14px' }} />\n )\n }\n disabled={!hasTraceInfo}\n onClick={() => {\n setShowTrace(v => !v)\n }}\n sx={{\n height: '20px',\n fontSize: '12px',\n fontWeight: 600,\n mb: 1,\n border: 'none !important',\n color: 'grey.700',\n justifyContent: 'flex-start',\n whiteSpace: 'nowrap',\n maxWidth: '325px',\n textTransform: 'none',\n pl: 0,\n '.MuiButton-startIcon': { mr: 0.5 },\n }}\n >\n <Box sx={{ overflow: 'hidden', textOverflow: 'ellipsis' }}>\n {traceButtonText}\n </Box>\n </Button>\n {chatResponseTrace && (\n <Collapse in={showTrace}>\n <MarkdownSynapse\n markdown={traceMessages\n .map(getMarkdownForTraceMessage)\n .filter(md => md.trim().length > 0)\n .join('<br/><br/>')}\n />\n </Collapse>\n )}\n </Box>\n {textContent && <MarkdownSynapse markdown={textContent} />}\n {onSendChat && guidePrompts.length > 0 && (\n <Stack direction=\"row\" flexWrap=\"wrap\" gap={1} mt={1}>\n {guidePrompts.map(prompt => (\n <Tooltip key={prompt} title={prompt}>\n <Chip\n label={prompt}\n variant=\"outlined\"\n color=\"primary\"\n clickable\n onClick={() => onSendChat(prompt)}\n sx={{ maxWidth: 200 }}\n />\n </Tooltip>\n ))}\n </Stack>\n )}\n </Box>\n </ListItem>\n {chatErrorReason && (\n <Alert severity={'error'} sx={{ my: 2 }}>\n {chatErrorReason}\n </Alert>\n )}\n </>\n )\n}\n\nexport default SynapseChatInteraction\n"],"names":["getMarkdownForTraceMessage","traceMessage","SynapseChatInteraction","userMessage","chatResponseText","chatErrorReason","chatResponseTrace","scrollIntoView","onSendChat","theme","useTheme","ref","useRef","showTrace","setShowTrace","useState","useEffect","isLoading","traceMessages","useMemo","traceEvent","extractMessageFromTraceEvent","trace","hasTraceInfo","lastReasoningMessage","traceButtonLoadingText","traceButtonText","textContent","guidePrompts","doc","element","extractedGuidePrompts","el","t","chatElement","jsxs","Fragment","jsx","ListItem","ListItemText","Box","SmartToyTwoTone","Button","SynapseSpinner","KeyboardArrowDown","KeyboardArrowRight","v","Collapse","MarkdownSynapse","md","Stack","Tooltip","prompt","Chip","Alert"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SynapseChatMessage.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/SynapseChatMessage.tsx"],"names":[],"mappings":"AA8CA,KAAK,uBAAuB,GAAG;IAC7B,SAAS,EAAE,MAAM,CAAA;
|
|
1
|
+
{"version":3,"file":"SynapseChatMessage.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/SynapseChatMessage.tsx"],"names":[],"mappings":"AA8CA,KAAK,uBAAuB,GAAG;IAC7B,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;CACvC,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,2CAyBxE"}
|
|
@@ -3,13 +3,13 @@ import { SynapseChatInteraction as h } from "./SynapseChatInteraction.js";
|
|
|
3
3
|
import m from "../../synapse-queries/asynchronous/usePollAsynchronousJob.js";
|
|
4
4
|
import { useGetChatAgentTraceEvents as f } from "../../synapse-queries/chat/useChat.js";
|
|
5
5
|
import { useState as T, useCallback as l, useEffect as E } from "react";
|
|
6
|
-
function
|
|
7
|
-
const [
|
|
8
|
-
|
|
9
|
-
}, []),
|
|
6
|
+
function d(o, s) {
|
|
7
|
+
const [a, e] = T([]), n = l((c) => {
|
|
8
|
+
e((p) => [...p, ...c]);
|
|
9
|
+
}, []), r = a.at(a.length - 1), { data: t } = f(
|
|
10
10
|
{
|
|
11
|
-
jobId:
|
|
12
|
-
newerThanTimestamp:
|
|
11
|
+
jobId: o,
|
|
12
|
+
newerThanTimestamp: r?.timestamp
|
|
13
13
|
},
|
|
14
14
|
{
|
|
15
15
|
enabled: s,
|
|
@@ -20,20 +20,21 @@ function g(n, s) {
|
|
|
20
20
|
}
|
|
21
21
|
);
|
|
22
22
|
return E(() => {
|
|
23
|
-
t && t.page.length > 0 && (
|
|
24
|
-
}, [
|
|
25
|
-
traceEvents:
|
|
23
|
+
t && t.page.length > 0 && (n(t.page), console.debug(t.page));
|
|
24
|
+
}, [n, t]), {
|
|
25
|
+
traceEvents: a
|
|
26
26
|
};
|
|
27
27
|
}
|
|
28
|
-
function I(
|
|
29
|
-
const { chatJobId: s } =
|
|
28
|
+
function I(o) {
|
|
29
|
+
const { chatJobId: s, onSendChat: a } = o, { data: e } = m(s), n = e?.requestBody, r = e?.responseBody, t = e?.errorMessage, c = !!s && (!e?.jobState || e.jobState == "PROCESSING"), { traceEvents: p } = d(s, c);
|
|
30
30
|
return /* @__PURE__ */ u(
|
|
31
31
|
h,
|
|
32
32
|
{
|
|
33
|
-
userMessage:
|
|
34
|
-
chatResponseText:
|
|
35
|
-
chatResponseTrace:
|
|
36
|
-
chatErrorReason:
|
|
33
|
+
userMessage: n?.chatText,
|
|
34
|
+
chatResponseText: r?.responseText,
|
|
35
|
+
chatResponseTrace: p,
|
|
36
|
+
chatErrorReason: t,
|
|
37
|
+
onSendChat: a
|
|
37
38
|
}
|
|
38
39
|
);
|
|
39
40
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SynapseChatMessage.js","sources":["../../../src/components/SynapseChat/SynapseChatMessage.tsx"],"sourcesContent":["import SynapseChatInteraction from '@/components/SynapseChat/SynapseChatInteraction'\nimport usePollAsynchronousJob from '@/synapse-queries/asynchronous/usePollAsynchronousJob'\nimport { useGetChatAgentTraceEvents } from '@/synapse-queries/chat/useChat'\nimport {\n AgentChatRequest,\n AgentChatResponse,\n TraceEvent,\n} from '@sage-bionetworks/synapse-types'\nimport { useCallback, useEffect, useState } from 'react'\n\nfunction useTraceEvent(chatJobId: string, enabled: boolean) {\n const [traceEvents, setTraceEvents] = useState<TraceEvent[]>([])\n\n const appendTraceEvents = useCallback((newEvents: TraceEvent[]) => {\n setTraceEvents(prev => {\n return [...prev, ...newEvents]\n })\n }, [])\n\n const latestTraceEvent = traceEvents.at(traceEvents.length - 1)\n const { data: newTraceEvents } = useGetChatAgentTraceEvents(\n {\n jobId: chatJobId,\n newerThanTimestamp: latestTraceEvent?.timestamp,\n },\n {\n enabled: enabled,\n refetchInterval: 1000, // Re-fetch every second if enabled\n refetchIntervalInBackground: true, // Continue polling even when the tab is not active\n },\n )\n useEffect(() => {\n if (newTraceEvents && newTraceEvents.page.length > 0) {\n appendTraceEvents(newTraceEvents.page)\n\n // send trace events to the console to ease agent debugging\n // if the trace events do not contain the latest event, add the events to the array\n console.debug(newTraceEvents.page)\n }\n }, [appendTraceEvents, newTraceEvents])\n\n return {\n traceEvents,\n }\n}\n\ntype SynapseChatMessageProps = {\n chatJobId: string\n}\n\nexport default function SynapseChatMessage(props: SynapseChatMessageProps) {\n const { chatJobId } = props\n const { data: asyncJobStatus } = usePollAsynchronousJob(chatJobId)\n\n const chatRequest = asyncJobStatus?.requestBody as AgentChatRequest\n const chatResponse = asyncJobStatus?.responseBody as\n | AgentChatResponse\n | undefined\n const chatError = asyncJobStatus?.errorMessage\n\n // enabled if the job has not finished processing\n const enableTrace =\n !!chatJobId &&\n (!asyncJobStatus?.jobState || asyncJobStatus.jobState == 'PROCESSING')\n const { traceEvents } = useTraceEvent(chatJobId, enableTrace)\n\n return (\n <SynapseChatInteraction\n userMessage={chatRequest?.chatText}\n chatResponseText={chatResponse?.responseText}\n chatResponseTrace={traceEvents}\n chatErrorReason={chatError}\n />\n )\n}\n"],"names":["useTraceEvent","chatJobId","enabled","traceEvents","setTraceEvents","useState","appendTraceEvents","useCallback","newEvents","prev","latestTraceEvent","newTraceEvents","useGetChatAgentTraceEvents","useEffect","SynapseChatMessage","props","asyncJobStatus","usePollAsynchronousJob","chatRequest","chatResponse","chatError","enableTrace","jsx","SynapseChatInteraction"],"mappings":";;;;;AAUA,SAASA,EAAcC,GAAmBC,GAAkB;AAC1D,QAAM,CAACC,GAAaC,CAAc,IAAIC,EAAuB,CAAA,CAAE,GAEzDC,IAAoBC,EAAY,CAACC,MAA4B;AACjE,IAAAJ,EAAe,CAAAK,MACN,CAAC,GAAGA,GAAM,GAAGD,CAAS,CAC9B;AAAA,EACH,GAAG,CAAA,CAAE,GAECE,IAAmBP,EAAY,GAAGA,EAAY,SAAS,CAAC,GACxD,EAAE,MAAMQ,EAAA,IAAmBC;AAAA,IAC/B;AAAA,MACE,OAAOX;AAAA,MACP,oBAAoBS,GAAkB;AAAA,IAAA;AAAA,IAExC;AAAA,MACE,SAAAR;AAAA,MACA,iBAAiB;AAAA;AAAA,MACjB,6BAA6B;AAAA;AAAA,IAAA;AAAA,EAC/B;AAEF,SAAAW,EAAU,MAAM;AACd,IAAIF,KAAkBA,EAAe,KAAK,SAAS,MACjDL,EAAkBK,EAAe,IAAI,GAIrC,QAAQ,MAAMA,EAAe,IAAI;AAAA,EAErC,GAAG,CAACL,GAAmBK,CAAc,CAAC,GAE/B;AAAA,IACL,aAAAR;AAAA,EAAA;AAEJ;
|
|
1
|
+
{"version":3,"file":"SynapseChatMessage.js","sources":["../../../src/components/SynapseChat/SynapseChatMessage.tsx"],"sourcesContent":["import SynapseChatInteraction from '@/components/SynapseChat/SynapseChatInteraction'\nimport usePollAsynchronousJob from '@/synapse-queries/asynchronous/usePollAsynchronousJob'\nimport { useGetChatAgentTraceEvents } from '@/synapse-queries/chat/useChat'\nimport {\n AgentChatRequest,\n AgentChatResponse,\n TraceEvent,\n} from '@sage-bionetworks/synapse-types'\nimport { useCallback, useEffect, useState } from 'react'\n\nfunction useTraceEvent(chatJobId: string, enabled: boolean) {\n const [traceEvents, setTraceEvents] = useState<TraceEvent[]>([])\n\n const appendTraceEvents = useCallback((newEvents: TraceEvent[]) => {\n setTraceEvents(prev => {\n return [...prev, ...newEvents]\n })\n }, [])\n\n const latestTraceEvent = traceEvents.at(traceEvents.length - 1)\n const { data: newTraceEvents } = useGetChatAgentTraceEvents(\n {\n jobId: chatJobId,\n newerThanTimestamp: latestTraceEvent?.timestamp,\n },\n {\n enabled: enabled,\n refetchInterval: 1000, // Re-fetch every second if enabled\n refetchIntervalInBackground: true, // Continue polling even when the tab is not active\n },\n )\n useEffect(() => {\n if (newTraceEvents && newTraceEvents.page.length > 0) {\n appendTraceEvents(newTraceEvents.page)\n\n // send trace events to the console to ease agent debugging\n // if the trace events do not contain the latest event, add the events to the array\n console.debug(newTraceEvents.page)\n }\n }, [appendTraceEvents, newTraceEvents])\n\n return {\n traceEvents,\n }\n}\n\ntype SynapseChatMessageProps = {\n chatJobId: string\n onSendChat?: (message: string) => void\n}\n\nexport default function SynapseChatMessage(props: SynapseChatMessageProps) {\n const { chatJobId, onSendChat } = props\n const { data: asyncJobStatus } = usePollAsynchronousJob(chatJobId)\n\n const chatRequest = asyncJobStatus?.requestBody as AgentChatRequest\n const chatResponse = asyncJobStatus?.responseBody as\n | AgentChatResponse\n | undefined\n const chatError = asyncJobStatus?.errorMessage\n\n // enabled if the job has not finished processing\n const enableTrace =\n !!chatJobId &&\n (!asyncJobStatus?.jobState || asyncJobStatus.jobState == 'PROCESSING')\n const { traceEvents } = useTraceEvent(chatJobId, enableTrace)\n\n return (\n <SynapseChatInteraction\n userMessage={chatRequest?.chatText}\n chatResponseText={chatResponse?.responseText}\n chatResponseTrace={traceEvents}\n chatErrorReason={chatError}\n onSendChat={onSendChat}\n />\n )\n}\n"],"names":["useTraceEvent","chatJobId","enabled","traceEvents","setTraceEvents","useState","appendTraceEvents","useCallback","newEvents","prev","latestTraceEvent","newTraceEvents","useGetChatAgentTraceEvents","useEffect","SynapseChatMessage","props","onSendChat","asyncJobStatus","usePollAsynchronousJob","chatRequest","chatResponse","chatError","enableTrace","jsx","SynapseChatInteraction"],"mappings":";;;;;AAUA,SAASA,EAAcC,GAAmBC,GAAkB;AAC1D,QAAM,CAACC,GAAaC,CAAc,IAAIC,EAAuB,CAAA,CAAE,GAEzDC,IAAoBC,EAAY,CAACC,MAA4B;AACjE,IAAAJ,EAAe,CAAAK,MACN,CAAC,GAAGA,GAAM,GAAGD,CAAS,CAC9B;AAAA,EACH,GAAG,CAAA,CAAE,GAECE,IAAmBP,EAAY,GAAGA,EAAY,SAAS,CAAC,GACxD,EAAE,MAAMQ,EAAA,IAAmBC;AAAA,IAC/B;AAAA,MACE,OAAOX;AAAA,MACP,oBAAoBS,GAAkB;AAAA,IAAA;AAAA,IAExC;AAAA,MACE,SAAAR;AAAA,MACA,iBAAiB;AAAA;AAAA,MACjB,6BAA6B;AAAA;AAAA,IAAA;AAAA,EAC/B;AAEF,SAAAW,EAAU,MAAM;AACd,IAAIF,KAAkBA,EAAe,KAAK,SAAS,MACjDL,EAAkBK,EAAe,IAAI,GAIrC,QAAQ,MAAMA,EAAe,IAAI;AAAA,EAErC,GAAG,CAACL,GAAmBK,CAAc,CAAC,GAE/B;AAAA,IACL,aAAAR;AAAA,EAAA;AAEJ;AAOA,SAAwBW,EAAmBC,GAAgC;AACzE,QAAM,EAAE,WAAAd,GAAW,YAAAe,EAAA,IAAeD,GAC5B,EAAE,MAAME,MAAmBC,EAAuBjB,CAAS,GAE3DkB,IAAcF,GAAgB,aAC9BG,IAAeH,GAAgB,cAG/BI,IAAYJ,GAAgB,cAG5BK,IACJ,CAAC,CAACrB,MACD,CAACgB,GAAgB,YAAYA,EAAe,YAAY,eACrD,EAAE,aAAAd,EAAA,IAAgBH,EAAcC,GAAWqB,CAAW;AAE5D,SACE,gBAAAC;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,aAAaL,GAAa;AAAA,MAC1B,kBAAkBC,GAAc;AAAA,MAChC,mBAAmBjB;AAAA,MACnB,iBAAiBkB;AAAA,MACjB,YAAAL;AAAA,IAAA;AAAA,EAAA;AAGN;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { SynapseChatProps } from './SynapseChat';
|
|
2
|
+
export type SynapsePortalChatDialogProps = SynapseChatProps & {
|
|
3
|
+
open: boolean;
|
|
4
|
+
onClose: () => void;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* A dialog that wraps SynapseChat with externally-controlled open/close state.
|
|
8
|
+
* Only shown when the user is logged in and the PORTAL_CHAT feature flag is enabled.
|
|
9
|
+
*/
|
|
10
|
+
export declare function SynapsePortalChatDialog({ open, onClose, ...chatDialogProps }: SynapsePortalChatDialogProps): import("react/jsx-runtime").JSX.Element;
|
|
11
|
+
export default SynapsePortalChatDialog;
|
|
12
|
+
//# sourceMappingURL=SynapsePortalChatDialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SynapsePortalChatDialog.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/SynapsePortalChatDialog.tsx"],"names":[],"mappings":"AACA,OAAoB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAE7D,MAAM,MAAM,4BAA4B,GAAG,gBAAgB,GAAG;IAC5D,IAAI,EAAE,OAAO,CAAA;IACb,OAAO,EAAE,MAAM,IAAI,CAAA;CACpB,CAAA;AAED;;;GAGG;AACH,wBAAgB,uBAAuB,CAAC,EACtC,IAAI,EACJ,OAAO,EACP,GAAG,eAAe,EACnB,EAAE,4BAA4B,2CAc9B;AAED,eAAe,uBAAuB,CAAA"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { jsx as e } from "react/jsx-runtime";
|
|
2
|
+
import r from "../DraggableDialog/DraggableDialog.js";
|
|
3
|
+
import { SynapseChat as i } from "./SynapseChat.js";
|
|
4
|
+
function m({
|
|
5
|
+
open: a,
|
|
6
|
+
onClose: o,
|
|
7
|
+
...t
|
|
8
|
+
}) {
|
|
9
|
+
return /* @__PURE__ */ e(
|
|
10
|
+
r,
|
|
11
|
+
{
|
|
12
|
+
open: a,
|
|
13
|
+
onClose: o,
|
|
14
|
+
title: t.chatbotName || "SynapseChat",
|
|
15
|
+
children: /* @__PURE__ */ e(
|
|
16
|
+
i,
|
|
17
|
+
{
|
|
18
|
+
hideTitle: !0,
|
|
19
|
+
textboxPositionOffset: "16px",
|
|
20
|
+
...t
|
|
21
|
+
}
|
|
22
|
+
)
|
|
23
|
+
}
|
|
24
|
+
);
|
|
25
|
+
}
|
|
26
|
+
export {
|
|
27
|
+
m as SynapsePortalChatDialog,
|
|
28
|
+
m as default
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=SynapsePortalChatDialog.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SynapsePortalChatDialog.js","sources":["../../../src/components/SynapseChat/SynapsePortalChatDialog.tsx"],"sourcesContent":["import DraggableDialog from '../DraggableDialog/DraggableDialog'\nimport SynapseChat, { SynapseChatProps } from './SynapseChat'\n\nexport type SynapsePortalChatDialogProps = SynapseChatProps & {\n open: boolean\n onClose: () => void\n}\n\n/**\n * A dialog that wraps SynapseChat with externally-controlled open/close state.\n * Only shown when the user is logged in and the PORTAL_CHAT feature flag is enabled.\n */\nexport function SynapsePortalChatDialog({\n open,\n onClose,\n ...chatDialogProps\n}: SynapsePortalChatDialogProps) {\n return (\n <DraggableDialog\n open={open}\n onClose={onClose}\n title={chatDialogProps.chatbotName || 'SynapseChat'}\n >\n <SynapseChat\n hideTitle={true}\n textboxPositionOffset=\"16px\"\n {...chatDialogProps}\n />\n </DraggableDialog>\n )\n}\n\nexport default SynapsePortalChatDialog\n"],"names":["SynapsePortalChatDialog","open","onClose","chatDialogProps","jsx","DraggableDialog","SynapseChat"],"mappings":";;;AAYO,SAASA,EAAwB;AAAA,EACtC,MAAAC;AAAA,EACA,SAAAC;AAAA,EACA,GAAGC;AACL,GAAiC;AAC/B,SACE,gBAAAC;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,MAAAJ;AAAA,MACA,SAAAC;AAAA,MACA,OAAOC,EAAgB,eAAe;AAAA,MAEtC,UAAA,gBAAAC;AAAA,QAACE;AAAA,QAAA;AAAA,UACC,WAAW;AAAA,UACX,uBAAsB;AAAA,UACrB,GAAGH;AAAA,QAAA;AAAA,MAAA;AAAA,IACN;AAAA,EAAA;AAGN;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"extractMessageFromTraceEvent.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/extractMessageFromTraceEvent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAA;AAG5D,MAAM,MAAM,YAAY,GACpB;IACE,aAAa,EAAE,MAAM,CAAA;CACtB,GACD;IACE,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAEL,MAAM,CAAC,OAAO,UAAU,4BAA4B,CAClD,KAAK,EAAE,UAAU,GAChB,YAAY,EAAE,GAAG,IAAI,
|
|
1
|
+
{"version":3,"file":"extractMessageFromTraceEvent.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/extractMessageFromTraceEvent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAA;AAG5D,MAAM,MAAM,YAAY,GACpB;IACE,aAAa,EAAE,MAAM,CAAA;CACtB,GACD;IACE,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAEL,MAAM,CAAC,OAAO,UAAU,4BAA4B,CAClD,KAAK,EAAE,UAAU,GAChB,YAAY,EAAE,GAAG,IAAI,CAqCvB"}
|
|
@@ -1,26 +1,32 @@
|
|
|
1
|
-
import { JSONPath as
|
|
2
|
-
function
|
|
3
|
-
const
|
|
4
|
-
|
|
1
|
+
import { JSONPath as o } from "jsonpath-plus";
|
|
2
|
+
function p(n) {
|
|
3
|
+
const s = [];
|
|
4
|
+
let a;
|
|
5
|
+
try {
|
|
6
|
+
a = JSON.parse(n.message);
|
|
7
|
+
} catch (e) {
|
|
8
|
+
return console.error(e), [{ reasoningText: n.message }];
|
|
9
|
+
}
|
|
10
|
+
return o({
|
|
5
11
|
path: "$.output.message.content[*]",
|
|
6
|
-
json:
|
|
7
|
-
}).forEach((
|
|
8
|
-
const
|
|
12
|
+
json: a
|
|
13
|
+
}).forEach((e) => {
|
|
14
|
+
const r = o({
|
|
9
15
|
path: "$.reasoningContent.reasoningText.text",
|
|
10
|
-
json:
|
|
16
|
+
json: e
|
|
11
17
|
});
|
|
12
|
-
|
|
13
|
-
const
|
|
18
|
+
r[0] && s.push({ reasoningText: r[0] });
|
|
19
|
+
const t = o({
|
|
14
20
|
path: "$.toolUse[name,input]",
|
|
15
|
-
json:
|
|
21
|
+
json: e
|
|
16
22
|
});
|
|
17
|
-
|
|
18
|
-
toolName:
|
|
19
|
-
toolInput:
|
|
23
|
+
t.length > 0 && s.push({
|
|
24
|
+
toolName: t[0],
|
|
25
|
+
toolInput: t[1]
|
|
20
26
|
});
|
|
21
|
-
}),
|
|
27
|
+
}), s;
|
|
22
28
|
}
|
|
23
29
|
export {
|
|
24
|
-
|
|
30
|
+
p as default
|
|
25
31
|
};
|
|
26
32
|
//# sourceMappingURL=extractMessageFromTraceEvent.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"extractMessageFromTraceEvent.js","sources":["../../../src/components/SynapseChat/extractMessageFromTraceEvent.ts"],"sourcesContent":["import { TraceEvent } from '@sage-bionetworks/synapse-types'\nimport { JSONPath } from 'jsonpath-plus'\n\nexport type TraceMessage =\n | {\n reasoningText: string\n }\n | {\n toolName: string\n toolInput: string\n }\n\nexport default function extractMessageFromTraceEvent(\n event: TraceEvent,\n): TraceMessage[] | null {\n // WARNING: The message format may change when we change models.\n const messagesToAdd: TraceMessage[] = []\n
|
|
1
|
+
{"version":3,"file":"extractMessageFromTraceEvent.js","sources":["../../../src/components/SynapseChat/extractMessageFromTraceEvent.ts"],"sourcesContent":["import { TraceEvent } from '@sage-bionetworks/synapse-types'\nimport { JSONPath } from 'jsonpath-plus'\n\nexport type TraceMessage =\n | {\n reasoningText: string\n }\n | {\n toolName: string\n toolInput: string\n }\n\nexport default function extractMessageFromTraceEvent(\n event: TraceEvent,\n): TraceMessage[] | null {\n // WARNING: The message format may change when we change models.\n const messagesToAdd: TraceMessage[] = []\n let parsedMessage: object\n try {\n parsedMessage = JSON.parse(event.message) as object\n } catch (e) {\n console.error(e)\n return [{ reasoningText: event.message }]\n }\n\n const messages = JSONPath({\n path: '$.output.message.content[*]',\n json: parsedMessage,\n })\n\n messages.forEach((message: any) => {\n const reasoningMessage = JSONPath({\n path: '$.reasoningContent.reasoningText.text',\n json: message,\n })\n if (reasoningMessage[0]) {\n messagesToAdd.push({ reasoningText: reasoningMessage[0] })\n }\n const toolUseMessage = JSONPath({\n path: '$.toolUse[name,input]',\n json: message,\n })\n\n if (toolUseMessage.length > 0) {\n messagesToAdd.push({\n toolName: toolUseMessage[0],\n toolInput: toolUseMessage[1],\n })\n }\n })\n return messagesToAdd\n}\n"],"names":["extractMessageFromTraceEvent","event","messagesToAdd","parsedMessage","JSONPath","message","reasoningMessage","toolUseMessage"],"mappings":";AAYA,SAAwBA,EACtBC,GACuB;AAEvB,QAAMC,IAAgC,CAAA;AACtC,MAAIC;AACJ,MAAI;AACF,IAAAA,IAAgB,KAAK,MAAMF,EAAM,OAAO;AAAA,EAC1C,SAAS,GAAG;AACV,mBAAQ,MAAM,CAAC,GACR,CAAC,EAAE,eAAeA,EAAM,SAAS;AAAA,EAC1C;AAOA,SALiBG,EAAS;AAAA,IACxB,MAAM;AAAA,IACN,MAAMD;AAAA,EAAA,CACP,EAEQ,QAAQ,CAACE,MAAiB;AACjC,UAAMC,IAAmBF,EAAS;AAAA,MAChC,MAAM;AAAA,MACN,MAAMC;AAAA,IAAA,CACP;AACD,IAAIC,EAAiB,CAAC,KACpBJ,EAAc,KAAK,EAAE,eAAeI,EAAiB,CAAC,GAAG;AAE3D,UAAMC,IAAiBH,EAAS;AAAA,MAC9B,MAAM;AAAA,MACN,MAAMC;AAAA,IAAA,CACP;AAED,IAAIE,EAAe,SAAS,KAC1BL,EAAc,KAAK;AAAA,MACjB,UAAUK,EAAe,CAAC;AAAA,MAC1B,WAAWA,EAAe,CAAC;AAAA,IAAA,CAC5B;AAAA,EAEL,CAAC,GACML;AACT;"}
|
|
@@ -2,4 +2,6 @@ import SynapseChat from './SynapseChat';
|
|
|
2
2
|
import type { SynapseChatProps } from './SynapseChat';
|
|
3
3
|
export { SynapseChat, SynapseChatProps };
|
|
4
4
|
export default SynapseChat;
|
|
5
|
+
export { SynapsePortalChatDialog } from './SynapsePortalChatDialog';
|
|
6
|
+
export type { SynapsePortalChatDialogProps } from './SynapsePortalChatDialog';
|
|
5
7
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/index.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,eAAe,CAAA;AACvC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAA;AACxC,eAAe,WAAW,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/index.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,eAAe,CAAA;AACvC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AACrD,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAA;AACxC,eAAe,WAAW,CAAA;AAE1B,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAA;AACnE,YAAY,EAAE,4BAA4B,EAAE,MAAM,2BAA2B,CAAA"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import { SynapseChat as
|
|
1
|
+
import { SynapseChat as o } from "./SynapseChat.js";
|
|
2
|
+
import { SynapsePortalChatDialog as e } from "./SynapsePortalChatDialog.js";
|
|
2
3
|
export {
|
|
3
|
-
|
|
4
|
-
|
|
4
|
+
o as SynapseChat,
|
|
5
|
+
e as SynapsePortalChatDialog,
|
|
6
|
+
o as default
|
|
5
7
|
};
|
|
6
8
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -4,5 +4,5 @@ export type ChatState = {
|
|
|
4
4
|
pendingMessage: string | null;
|
|
5
5
|
chatJobIds: string[];
|
|
6
6
|
};
|
|
7
|
-
export declare function useChatState(agentSession?: AgentSession): ChatState;
|
|
7
|
+
export declare function useChatState(agentSession?: AgentSession, onChatResponse?: (responseText: string) => void): ChatState;
|
|
8
8
|
//# sourceMappingURL=useChatState.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useChatState.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/useChatState.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,YAAY,EAEb,MAAM,iCAAiC,CAAA;AAGxC,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACnC,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,UAAU,EAAE,MAAM,EAAE,CAAA;CACrB,CAAA;AAED,wBAAgB,YAAY,CAAC,YAAY,CAAC,EAAE,YAAY,
|
|
1
|
+
{"version":3,"file":"useChatState.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseChat/useChatState.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,YAAY,EAEb,MAAM,iCAAiC,CAAA;AAGxC,MAAM,MAAM,SAAS,GAAG;IACtB,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,CAAA;IACnC,cAAc,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,UAAU,EAAE,MAAM,EAAE,CAAA;CACrB,CAAA;AAED,wBAAgB,YAAY,CAC1B,YAAY,CAAC,EAAE,YAAY,EAC3B,cAAc,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,IAAI,GAC9C,SAAS,CAyCX"}
|
|
@@ -1,16 +1,19 @@
|
|
|
1
1
|
import { useSendChatMessageToAgent as i } from "../../synapse-queries/chat/useChat.js";
|
|
2
|
-
import { useState as
|
|
3
|
-
function
|
|
4
|
-
const [s,
|
|
2
|
+
import { useState as c, useCallback as h, useMemo as l } from "react";
|
|
3
|
+
function b(t, r) {
|
|
4
|
+
const [s, u] = c([]), [n, o] = c(null), { mutate: a } = i(
|
|
5
5
|
{
|
|
6
6
|
onMutate: (e) => {
|
|
7
7
|
o(e.chatText);
|
|
8
|
+
},
|
|
9
|
+
onSuccess: (e) => {
|
|
10
|
+
r?.(e.responseText);
|
|
8
11
|
}
|
|
9
12
|
},
|
|
10
13
|
(e) => {
|
|
11
|
-
s.includes(e.jobId) || (o(null),
|
|
14
|
+
s.includes(e.jobId) || (o(null), u(() => [...s, e.jobId]));
|
|
12
15
|
}
|
|
13
|
-
), d =
|
|
16
|
+
), d = h(
|
|
14
17
|
(e) => {
|
|
15
18
|
if (!t?.sessionId)
|
|
16
19
|
throw new Error("No agent session available to send chat message.");
|
|
@@ -22,12 +25,12 @@ function I(t) {
|
|
|
22
25
|
},
|
|
23
26
|
[t?.sessionId, a]
|
|
24
27
|
);
|
|
25
|
-
return
|
|
28
|
+
return l(
|
|
26
29
|
() => ({ sendChat: d, pendingMessage: n, chatJobIds: s }),
|
|
27
30
|
[d, n, s]
|
|
28
31
|
);
|
|
29
32
|
}
|
|
30
33
|
export {
|
|
31
|
-
|
|
34
|
+
b as useChatState
|
|
32
35
|
};
|
|
33
36
|
//# sourceMappingURL=useChatState.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useChatState.js","sources":["../../../src/components/SynapseChat/useChatState.ts"],"sourcesContent":["import { useSendChatMessageToAgent } from '@/synapse-queries/chat/useChat'\nimport {\n AgentChatRequest,\n AgentChatResponse,\n AgentSession,\n AsynchronousJobStatus,\n} from '@sage-bionetworks/synapse-types'\nimport { useCallback, useMemo, useState } from 'react'\n\nexport type ChatState = {\n sendChat: (message: string) => void\n pendingMessage: string | null\n chatJobIds: string[]\n}\n\nexport function useChatState(agentSession?: AgentSession): ChatState {\n const [chatJobIds, setChatJobIds] = useState<string[]>([])\n // Optimistic update state for latest unprocessed message\n const [pendingMessage, setPendingMessage] = useState<string | null>(null)\n\n const { mutate: sendChatMessageToAgent } = useSendChatMessageToAgent(\n {\n onMutate: (newChatMessage: AgentChatRequest) => {\n // set the pending message to the new chat message\n setPendingMessage(newChatMessage.chatText)\n },\n },\n (status: AsynchronousJobStatus<AgentChatRequest, AgentChatResponse>) => {\n if (!chatJobIds.includes(status.jobId)) {\n setPendingMessage(null)\n setChatJobIds(() => [...chatJobIds, status.jobId])\n }\n },\n )\n\n const sendChat = useCallback(\n (message: string) => {\n if (!agentSession?.sessionId) {\n throw new Error('No agent session available to send chat message.')\n }\n sendChatMessageToAgent({\n chatText: message,\n sessionId: agentSession.sessionId,\n enableTrace: true,\n })\n },\n [agentSession?.sessionId, sendChatMessageToAgent],\n )\n\n return useMemo(\n () => ({ sendChat, pendingMessage, chatJobIds }),\n [sendChat, pendingMessage, chatJobIds],\n )\n}\n"],"names":["useChatState","agentSession","chatJobIds","setChatJobIds","useState","pendingMessage","setPendingMessage","sendChatMessageToAgent","useSendChatMessageToAgent","newChatMessage","status","sendChat","useCallback","message","useMemo"],"mappings":";;AAeO,SAASA,
|
|
1
|
+
{"version":3,"file":"useChatState.js","sources":["../../../src/components/SynapseChat/useChatState.ts"],"sourcesContent":["import { useSendChatMessageToAgent } from '@/synapse-queries/chat/useChat'\nimport {\n AgentChatRequest,\n AgentChatResponse,\n AgentSession,\n AsynchronousJobStatus,\n} from '@sage-bionetworks/synapse-types'\nimport { useCallback, useMemo, useState } from 'react'\n\nexport type ChatState = {\n sendChat: (message: string) => void\n pendingMessage: string | null\n chatJobIds: string[]\n}\n\nexport function useChatState(\n agentSession?: AgentSession,\n onChatResponse?: (responseText: string) => void,\n): ChatState {\n const [chatJobIds, setChatJobIds] = useState<string[]>([])\n // Optimistic update state for latest unprocessed message\n const [pendingMessage, setPendingMessage] = useState<string | null>(null)\n\n const { mutate: sendChatMessageToAgent } = useSendChatMessageToAgent(\n {\n onMutate: (newChatMessage: AgentChatRequest) => {\n // set the pending message to the new chat message\n setPendingMessage(newChatMessage.chatText)\n },\n onSuccess: (response: AgentChatResponse) => {\n onChatResponse?.(response.responseText)\n },\n },\n (status: AsynchronousJobStatus<AgentChatRequest, AgentChatResponse>) => {\n if (!chatJobIds.includes(status.jobId)) {\n setPendingMessage(null)\n setChatJobIds(() => [...chatJobIds, status.jobId])\n }\n },\n )\n\n const sendChat = useCallback(\n (message: string) => {\n if (!agentSession?.sessionId) {\n throw new Error('No agent session available to send chat message.')\n }\n sendChatMessageToAgent({\n chatText: message,\n sessionId: agentSession.sessionId,\n enableTrace: true,\n })\n },\n [agentSession?.sessionId, sendChatMessageToAgent],\n )\n\n return useMemo(\n () => ({ sendChat, pendingMessage, chatJobIds }),\n [sendChat, pendingMessage, chatJobIds],\n )\n}\n"],"names":["useChatState","agentSession","onChatResponse","chatJobIds","setChatJobIds","useState","pendingMessage","setPendingMessage","sendChatMessageToAgent","useSendChatMessageToAgent","newChatMessage","response","status","sendChat","useCallback","message","useMemo"],"mappings":";;AAeO,SAASA,EACdC,GACAC,GACW;AACX,QAAM,CAACC,GAAYC,CAAa,IAAIC,EAAmB,CAAA,CAAE,GAEnD,CAACC,GAAgBC,CAAiB,IAAIF,EAAwB,IAAI,GAElE,EAAE,QAAQG,EAAA,IAA2BC;AAAA,IACzC;AAAA,MACE,UAAU,CAACC,MAAqC;AAE9C,QAAAH,EAAkBG,EAAe,QAAQ;AAAA,MAC3C;AAAA,MACA,WAAW,CAACC,MAAgC;AAC1C,QAAAT,IAAiBS,EAAS,YAAY;AAAA,MACxC;AAAA,IAAA;AAAA,IAEF,CAACC,MAAuE;AACtE,MAAKT,EAAW,SAASS,EAAO,KAAK,MACnCL,EAAkB,IAAI,GACtBH,EAAc,MAAM,CAAC,GAAGD,GAAYS,EAAO,KAAK,CAAC;AAAA,IAErD;AAAA,EAAA,GAGIC,IAAWC;AAAA,IACf,CAACC,MAAoB;AACnB,UAAI,CAACd,GAAc;AACjB,cAAM,IAAI,MAAM,kDAAkD;AAEpE,MAAAO,EAAuB;AAAA,QACrB,UAAUO;AAAA,QACV,WAAWd,EAAa;AAAA,QACxB,aAAa;AAAA,MAAA,CACd;AAAA,IACH;AAAA,IACA,CAACA,GAAc,WAAWO,CAAsB;AAAA,EAAA;AAGlD,SAAOQ;AAAA,IACL,OAAO,EAAE,UAAAH,GAAU,gBAAAP,GAAgB,YAAAH;IACnC,CAACU,GAAUP,GAAgBH,CAAU;AAAA,EAAA;AAEzC;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SynapseHomepageChatSearch.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseHomepageV2/SynapseHomepageChatSearch.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"SynapseHomepageChatSearch.d.ts","sourceRoot":"","sources":["../../../src/components/SynapseHomepageV2/SynapseHomepageChatSearch.tsx"],"names":[],"mappings":"AAcA,MAAM,MAAM,8BAA8B,GAAG;IAC3C,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;CAClC,CAAA;AAMD;;;;GAIG;AACH,wBAAgB,yBAAyB,CAAC,EACxC,SAAS,GACV,EAAE,8BAA8B,2CAsFhC"}
|