@envive-ai/react-widgets-v3 0.3.10 → 0.3.11
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/_virtual/rolldown_runtime.cjs +2 -0
- package/dist/debug/GenericSelect.cjs +167 -0
- package/dist/debug/GenericSelect.js +165 -0
- package/dist/debug/MessageContent.cjs +151 -0
- package/dist/debug/MessageContent.js +149 -0
- package/dist/debug/chatEmbed.cjs +95 -0
- package/dist/debug/chatEmbed.js +92 -0
- package/dist/debug/debugBar.cjs +18 -0
- package/dist/debug/debugBar.js +17 -0
- package/dist/debug/reportIssue.cjs +528 -0
- package/dist/debug/reportIssue.js +524 -0
- package/dist/hocs/withBaseWidget/withBaseWidget.d.cts +2 -2
- package/dist/hocs/withBaseWidget/withBaseWidget.d.ts +2 -2
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/CustomerServiceApi.cjs +265 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/DefaultApi.cjs +591 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/InferenceApi.cjs +265 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/ProductsApi.cjs +105 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/SearchApi.cjs +229 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/apis/index.cjs +43 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/index.cjs +39 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AddNoteToLatestConversationRequest.cjs +68 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AddNoteToLatestConversationResponse.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AddToCartAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AnalyticsIdentifyRequest.cjs +86 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AnalyticsTrackEventRequest.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AttachmentRequest.cjs +63 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/AutoForm.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/Context.cjs +89 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ConversationStatus.cjs +63 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CreateConversationRequest.cjs +68 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CreateConversationResponse.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustServiceAttachment.cjs +68 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustServiceConversation.cjs +69 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustServiceConversationMessages.cjs +67 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustServiceCustomer.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustServiceMessage.cjs +85 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/CustomerServiceProvider.cjs +63 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/FormResponseAttributes.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/FormResponseAttributesFormCategory.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/FormSubmittedAttributes.cjs +65 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/FormType.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/FulfillmentDisplayStatus.cjs +84 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/GenerationParams.cjs +74 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/GetConversationMessagesRequest.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/IsBusinessHoursRequest.cjs +54 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/IsBusinessHoursResponse.cjs +59 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/LabelValue.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ManualForm.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRule.cjs +70 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleAction.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleActionAttribute.cjs +58 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleActionType.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleCondition.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleOp.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/MerchRuleStatus.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/NextMessageRequest.cjs +78 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/OrderItemInfo.cjs +78 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/OrderResponseAttributes.cjs +71 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/Organization.cjs +83 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/OrganizationConfig.cjs +82 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/OrganizationConfigResults.cjs +70 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/OrganizationSettings.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PDPAttributes.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PLPAttributeCategory.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PLPAttributes.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PLPAttributesAttributes.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PLPIdAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PLPUrlAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PageVisitAttributes.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/PageVisitCategory.cjs +65 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductRetrievalRequest.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductRetrievalResponse.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductSearchFilterResponseAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductSearchRequest.cjs +71 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductSearchResponse.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductSearchResponseAttributes.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ProductSearchResponseV2.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/QueryTypedAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ReportContent.cjs +59 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ReportSessionRequest.cjs +99 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/Response.cjs +68 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ResponseCategory.cjs +69 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/ResponseProductAttributes.cjs +91 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SearchAttributes.cjs +65 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SearchResponseProduct.cjs +93 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SearchSuggestionsResponse.cjs +58 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SendMessageRequest.cjs +71 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SendMessageResponse.cjs +55 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/StatsigExperiment.cjs +64 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/StatsigFeatureGate.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/Suggestion.cjs +70 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SuggestionCategory.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SuggestionClickedAttributes.cjs +53 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SupportedEventProductCategory.cjs +62 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SupportedEventRequest.cjs +67 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/SupportedEventResponse.cjs +78 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/TurnInfo.cjs +70 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/TurnInfoPrevUserEvent.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingGenericConfig.cjs +52 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingPDPConfig.cjs +65 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingPLPConfig.cjs +61 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingRequest.cjs +65 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingResponse.cjs +73 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingResponseSpecificDetails.cjs +59 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UrlResolvingType.cjs +67 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UserEvent.cjs +69 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UserEventAttributes.cjs +75 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/UserEventCategory.cjs +70 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/V1GetSessionMessages200Response.cjs +67 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/V1SearchExplainGet200Response.cjs +63 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/WidgetString.cjs +60 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/WidgetTextRequest.cjs +73 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/WidgetTextResponse.cjs +66 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/WidgetType.cjs +69 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/models/index.cjs +221 -0
- package/dist/node_modules/@spiffy-ai/commerce-api-client/dist/runtime.cjs +324 -0
- package/dist/node_modules/react-icons/fa/index.cjs +65 -0
- package/dist/node_modules/react-icons/fa/index.js +61 -0
- package/dist/node_modules/react-icons/lib/iconBase.cjs +121 -0
- package/dist/node_modules/react-icons/lib/iconBase.js +119 -0
- package/dist/node_modules/react-icons/lib/iconContext.cjs +17 -0
- package/dist/node_modules/react-icons/lib/iconContext.js +14 -0
- package/dist/packages/icons/dist/IconCloseVariant.cjs +22 -0
- package/dist/packages/icons/dist/IconCloseVariant.js +22 -0
- package/dist/packages/icons/dist/_virtual/rolldown_runtime.cjs +27 -0
- package/dist/packages/icons/dist/_virtual/rolldown_runtime.js +25 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react-jsx-runtime.development.cjs +696 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react-jsx-runtime.development.js +696 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react-jsx-runtime.production.min.cjs +43 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react-jsx-runtime.production.min.js +43 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react.development.cjs +1528 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react.development.js +1528 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react.production.min.cjs +329 -0
- package/dist/packages/icons/dist/node_modules/react/cjs/react.production.min.js +329 -0
- package/dist/packages/icons/dist/node_modules/react/index.cjs +13 -0
- package/dist/packages/icons/dist/node_modules/react/index.js +13 -0
- package/dist/packages/icons/dist/node_modules/react/jsx-runtime.cjs +13 -0
- package/dist/packages/icons/dist/node_modules/react/jsx-runtime.js +13 -0
- package/dist/{widgets → packages/widgets}/dist/SearchResults/SearchResultsWidget.d.ts +2 -2
- package/dist/{widgets → packages/widgets}/dist/SearchZeroState/SearchZeroStateWidget.d.ts +2 -2
- package/dist/{widgets → packages/widgets}/dist/SuggestionBar/SuggestionBar.d.ts +2 -2
- package/dist/widgets/ChatPreviewComparisonWidget/ChatPreviewComparisonWidget.cjs +3 -3
- package/dist/widgets/ChatPreviewComparisonWidget/ChatPreviewComparisonWidget.d.cts +3 -3
- package/dist/widgets/ChatPreviewComparisonWidget/ChatPreviewComparisonWidget.js +3 -3
- package/dist/widgets/ChatPreviewLoadingWidget/ChatPreviewLoadingWidget.d.cts +3 -3
- package/dist/widgets/ChatPreviewLoadingWidget/ChatPreviewLoadingWidget.d.ts +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.cjs +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.d.cts +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.d.ts +3 -3
- package/dist/widgets/ChatPreviewWidget/ChatPreviewWidget.js +3 -3
- package/dist/widgets/FloatingChatWidget/FloatingChatOverlay.cjs +2 -2
- package/dist/widgets/FloatingChatWidget/FloatingChatOverlay.js +1 -1
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.cjs +3 -1
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.d.cts +2 -2
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.d.ts +2 -2
- package/dist/widgets/FloatingChatWidget/FloatingChatWidget.js +3 -1
- package/dist/widgets/FloatingChatWidget/hooks/useFloatingButtonVisibility.cjs +4 -1
- package/dist/widgets/FloatingChatWidget/hooks/useFloatingButtonVisibility.js +5 -2
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.cjs +31 -0
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.d.cts +15 -0
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.d.ts +15 -0
- package/dist/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.js +30 -0
- package/dist/widgets/FullPageSalesAgentWidget/index.cjs +3 -0
- package/dist/widgets/FullPageSalesAgentWidget/index.d.cts +2 -0
- package/dist/widgets/FullPageSalesAgentWidget/index.d.ts +2 -0
- package/dist/widgets/FullPageSalesAgentWidget/index.js +3 -0
- package/dist/widgets/ProductCardWidget/ProductCardWidget.cjs +3 -2
- package/dist/widgets/ProductCardWidget/ProductCardWidget.d.cts +2 -2
- package/dist/widgets/ProductCardWidget/ProductCardWidget.d.ts +2 -2
- package/dist/widgets/ProductCardWidget/ProductCardWidget.js +3 -2
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.cjs +4 -3
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.d.cts +3 -3
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.d.ts +3 -3
- package/dist/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.js +4 -3
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.cjs +28 -4
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.d.cts +2 -2
- package/dist/widgets/PromptCarouselWidget/PromptCarouselWidget.js +29 -5
- package/dist/widgets/SocialProofFlowWidget/SocialProofFlowWidget.d.cts +2 -2
- package/dist/widgets/SocialProofFlowWidget/SocialProofFlowWidget.d.ts +2 -2
- package/dist/widgets/SocialProofWidget/SocialProofWidget.cjs +8 -6
- package/dist/widgets/SocialProofWidget/SocialProofWidget.d.cts +3 -3
- package/dist/widgets/SocialProofWidget/SocialProofWidget.d.ts +3 -3
- package/dist/widgets/SocialProofWidget/SocialProofWidget.js +8 -6
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.cjs +3 -2
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.d.cts +2 -2
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.d.ts +2 -2
- package/dist/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.js +3 -2
- package/dist/widgets/TypingAnimationFlowWidget/TypingAnimationFlowWidget.d.cts +2 -2
- package/dist/widgets/TypingAnimationWidget/TypingAnimationWidget.cjs +3 -2
- package/dist/widgets/TypingAnimationWidget/TypingAnimationWidget.d.cts +3 -3
- package/dist/widgets/TypingAnimationWidget/TypingAnimationWidget.d.ts +3 -3
- package/dist/widgets/TypingAnimationWidget/TypingAnimationWidget.js +3 -2
- package/dist/widgets/dist/SearchResults/SearchResultsWidget.d.cts +2 -2
- package/dist/widgets/dist/SearchZeroState/SearchZeroStateWidget.d.cts +2 -2
- package/dist/widgets/dist/SuggestionBar/SuggestionBar.d.cts +2 -2
- package/dist/widgets/utils/functions.cjs +1 -1
- package/dist/widgets/utils/functions.js +1 -1
- package/dist/widgets-v2/SearchResults/index.d.ts +3 -3
- package/dist/widgets-v2/SearchZeroState/index.d.ts +4 -4
- package/dist/widgets-v2/SuggestionBar/index.d.ts +3 -3
- package/dist/widgets-v2/SuggestionButtonContainer/index.d.ts +2 -2
- package/package.json +5 -1
- package/src/debug/GenericSelect.tsx +236 -0
- package/src/debug/MessageContent.tsx +248 -0
- package/src/debug/chatEmbed.tsx +119 -0
- package/src/debug/debugBar.tsx +13 -0
- package/src/debug/reportIssue.tsx +649 -0
- package/src/hocs/withBaseWidget/__tests__/withBaseWidget.test.tsx +6 -0
- package/src/stories/FullPageSalesAgentWidget.stories.tsx +68 -0
- package/src/stories/SalesAgentTest/SalesAgentTest.tsx +10 -2
- package/src/widgets/FloatingChatWidget/FloatingChatWidget.tsx +2 -0
- package/src/widgets/FloatingChatWidget/hooks/useFloatingButtonVisibility.ts +11 -5
- package/src/widgets/FullPageSalesAgentWidget/FullPageSalesAgentWidget.tsx +46 -0
- package/src/widgets/FullPageSalesAgentWidget/index.ts +1 -0
- package/src/widgets/ProductCardWidget/ProductCardWidget.tsx +5 -1
- package/src/widgets/PromptButtonCarouselWithImageWidget/PromptButtonCarouselWithImageWidget.tsx +6 -1
- package/src/widgets/PromptCarouselWidget/PromptCarouselWidget.tsx +31 -2
- package/src/widgets/SocialProofWidget/SocialProofWidget.tsx +10 -2
- package/src/widgets/TitledPromptCarouselWidget/TitledPromptCarouselWidget.tsx +5 -1
- package/src/widgets/TypingAnimationWidget/TypingAnimationWidget.tsx +5 -1
- /package/dist/{widgets → packages/widgets}/dist/SearchResults/SearchResults.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SearchResults/index.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SearchResults/types.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SearchZeroState/SearchZeroState.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SearchZeroState/index.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SearchZeroState/types.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SuggestionBar/index.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SuggestionBar/types.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SuggestionButtonContainer/SuggestionButtonContainer.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/SuggestionButtonContainer/types.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/config/BaseWidgetConfig.d.ts +0 -0
- /package/dist/{widgets → packages/widgets}/dist/config/WidgetType.d.ts +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@envive-ai/react-widgets-v3",
|
|
3
|
-
"version": "0.3.
|
|
3
|
+
"version": "0.3.11",
|
|
4
4
|
"description": "React widget library v3 for Envive services.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"react",
|
|
@@ -120,6 +120,10 @@
|
|
|
120
120
|
"import": "./dist/widgets/FloatingChatWidget/index.js",
|
|
121
121
|
"require": "./dist/widgets/FloatingChatWidget/index.cjs"
|
|
122
122
|
},
|
|
123
|
+
"./widgets/FullPageSalesAgentWidget": {
|
|
124
|
+
"import": "./dist/widgets/FullPageSalesAgentWidget/index.js",
|
|
125
|
+
"require": "./dist/widgets/FullPageSalesAgentWidget/index.cjs"
|
|
126
|
+
},
|
|
123
127
|
"./widgets/ProductCardWidget": {
|
|
124
128
|
"import": "./dist/widgets/ProductCardWidget/index.js",
|
|
125
129
|
"require": "./dist/widgets/ProductCardWidget/index.cjs"
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import React, { CSSProperties, useRef, useState } from 'react';
|
|
2
|
+
|
|
3
|
+
type SelectType = 'priority';
|
|
4
|
+
|
|
5
|
+
interface CategorySkillItem {
|
|
6
|
+
icon: string;
|
|
7
|
+
label: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
interface ChipItem {
|
|
11
|
+
label: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
type DictionaryItem = CategorySkillItem | ChipItem;
|
|
15
|
+
type Dictionary = Record<string, DictionaryItem>;
|
|
16
|
+
|
|
17
|
+
const dictionaries: Record<SelectType, Dictionary> = {
|
|
18
|
+
priority: {
|
|
19
|
+
p0: { label: 'Urgent' },
|
|
20
|
+
p1: { label: 'High' },
|
|
21
|
+
p2: { label: 'Medium' },
|
|
22
|
+
p3: { label: 'Low' },
|
|
23
|
+
'no priority': { label: 'No Priority' },
|
|
24
|
+
},
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
// Inline styles for Shadow DOM compatibility
|
|
28
|
+
const styles: Record<string, CSSProperties> = {
|
|
29
|
+
button: {
|
|
30
|
+
display: 'flex',
|
|
31
|
+
alignItems: 'center',
|
|
32
|
+
gap: '0.5rem',
|
|
33
|
+
fontSize: '0.75rem',
|
|
34
|
+
backgroundColor: 'transparent',
|
|
35
|
+
padding: '0.375rem 0.75rem',
|
|
36
|
+
borderRadius: '0.375rem',
|
|
37
|
+
cursor: 'pointer',
|
|
38
|
+
outline: 'none',
|
|
39
|
+
border: 'none',
|
|
40
|
+
},
|
|
41
|
+
buttonHover: {
|
|
42
|
+
backgroundColor: '#f9fafb',
|
|
43
|
+
},
|
|
44
|
+
dropdown: {
|
|
45
|
+
position: 'absolute',
|
|
46
|
+
left: '0',
|
|
47
|
+
zIndex: 10,
|
|
48
|
+
marginTop: '4px',
|
|
49
|
+
borderRadius: '8px',
|
|
50
|
+
width: '125px',
|
|
51
|
+
backgroundColor: 'white',
|
|
52
|
+
boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',
|
|
53
|
+
border: '1px solid rgba(0, 0, 0, 0.05)',
|
|
54
|
+
},
|
|
55
|
+
dropdownItem: {
|
|
56
|
+
display: 'flex',
|
|
57
|
+
width: '100%',
|
|
58
|
+
alignItems: 'center',
|
|
59
|
+
padding: '4px 8px',
|
|
60
|
+
fontSize: '12px',
|
|
61
|
+
cursor: 'pointer',
|
|
62
|
+
border: 'none',
|
|
63
|
+
backgroundColor: 'transparent',
|
|
64
|
+
textAlign: 'left',
|
|
65
|
+
},
|
|
66
|
+
dropdownItemHover: {
|
|
67
|
+
backgroundColor: '#EBEEF6',
|
|
68
|
+
},
|
|
69
|
+
container: {
|
|
70
|
+
marginLeft: '-1rem',
|
|
71
|
+
position: 'relative',
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
// Badge style generator function
|
|
76
|
+
const getBadgeStyles = (variant?: string): CSSProperties => {
|
|
77
|
+
let backgroundColor;
|
|
78
|
+
let textColor;
|
|
79
|
+
|
|
80
|
+
switch (variant) {
|
|
81
|
+
case 'p0':
|
|
82
|
+
backgroundColor = '#940F24';
|
|
83
|
+
textColor = '#F9E8EA';
|
|
84
|
+
break;
|
|
85
|
+
case 'p1':
|
|
86
|
+
backgroundColor = '#F9E8EA';
|
|
87
|
+
textColor = '#940F24';
|
|
88
|
+
break;
|
|
89
|
+
case 'p2':
|
|
90
|
+
backgroundColor = '#FEEBCB';
|
|
91
|
+
textColor = '#C05621';
|
|
92
|
+
break;
|
|
93
|
+
case 'p3':
|
|
94
|
+
backgroundColor = '#E6F6F4';
|
|
95
|
+
textColor = '#007F6D';
|
|
96
|
+
break;
|
|
97
|
+
default:
|
|
98
|
+
backgroundColor = '#EBEEF6';
|
|
99
|
+
textColor = '#3C57AA';
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// Using fixed medium size values
|
|
103
|
+
return {
|
|
104
|
+
display: 'inline-flex',
|
|
105
|
+
borderRadius: '4px',
|
|
106
|
+
backgroundColor,
|
|
107
|
+
color: textColor,
|
|
108
|
+
fontSize: '0.875rem',
|
|
109
|
+
paddingLeft: '0.625rem',
|
|
110
|
+
paddingRight: '0.625rem',
|
|
111
|
+
paddingTop: '0.25rem',
|
|
112
|
+
paddingBottom: '0.25rem',
|
|
113
|
+
};
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
interface SelectProps {
|
|
117
|
+
type: SelectType;
|
|
118
|
+
selectedKey: string;
|
|
119
|
+
onSelect?: (key: string) => void;
|
|
120
|
+
buttonStyle?: CSSProperties;
|
|
121
|
+
menuStyle?: CSSProperties;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
export function GenericSelect({
|
|
125
|
+
type,
|
|
126
|
+
selectedKey,
|
|
127
|
+
onSelect,
|
|
128
|
+
buttonStyle = {},
|
|
129
|
+
menuStyle = {},
|
|
130
|
+
}: Readonly<SelectProps>) {
|
|
131
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
132
|
+
const [isHovering, setIsHovering] = useState<string | null>(null);
|
|
133
|
+
const menuRef = useRef<HTMLDivElement>(null);
|
|
134
|
+
const dictionary = dictionaries[type];
|
|
135
|
+
|
|
136
|
+
const renderItem = (key: string, item: DictionaryItem) => {
|
|
137
|
+
const chipItem = item as ChipItem;
|
|
138
|
+
const badgeStyles = getBadgeStyles(key);
|
|
139
|
+
|
|
140
|
+
return <span style={badgeStyles}>{chipItem.label}</span>;
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
// Close menu when clicking outside
|
|
144
|
+
React.useEffect(() => {
|
|
145
|
+
const handleClickOutside = (event: MouseEvent) => {
|
|
146
|
+
// Check if the click target is within our menu ref
|
|
147
|
+
const isOutside = menuRef.current && !menuRef.current.contains(event.target as Node);
|
|
148
|
+
|
|
149
|
+
// Also check the event path (for Shadow DOM compatibility)
|
|
150
|
+
const path = event.composedPath ? event.composedPath() : [];
|
|
151
|
+
const isInPath = menuRef.current && path.includes(menuRef.current);
|
|
152
|
+
|
|
153
|
+
// Only close if truly outside (not in the path)
|
|
154
|
+
if (isOutside && !isInPath) {
|
|
155
|
+
setIsOpen(false);
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
document.addEventListener('mouseup', handleClickOutside, true);
|
|
160
|
+
|
|
161
|
+
return () => {
|
|
162
|
+
document.removeEventListener('mouseup', handleClickOutside, true);
|
|
163
|
+
};
|
|
164
|
+
}, [isOpen]);
|
|
165
|
+
|
|
166
|
+
if (!dictionary) {
|
|
167
|
+
console.error(`Invalid type "${type}".`);
|
|
168
|
+
return null;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
return (
|
|
172
|
+
<div
|
|
173
|
+
style={styles.container}
|
|
174
|
+
ref={menuRef}
|
|
175
|
+
>
|
|
176
|
+
<button
|
|
177
|
+
type="button"
|
|
178
|
+
style={{
|
|
179
|
+
...styles.button,
|
|
180
|
+
...(isHovering === 'button' ? styles.buttonHover : {}),
|
|
181
|
+
...buttonStyle,
|
|
182
|
+
}}
|
|
183
|
+
onClick={() => {
|
|
184
|
+
setIsOpen(!isOpen);
|
|
185
|
+
}}
|
|
186
|
+
onMouseEnter={() => setIsHovering('button')}
|
|
187
|
+
onMouseLeave={() => setIsHovering(null)}
|
|
188
|
+
>
|
|
189
|
+
{dictionary[selectedKey] ? (
|
|
190
|
+
renderItem(selectedKey, dictionary[selectedKey])
|
|
191
|
+
) : (
|
|
192
|
+
<span
|
|
193
|
+
style={{ color: '#6b7280' }}
|
|
194
|
+
>{`Select ${type.charAt(0).toUpperCase() + type.slice(1)}`}</span>
|
|
195
|
+
)}
|
|
196
|
+
</button>
|
|
197
|
+
|
|
198
|
+
{isOpen && (
|
|
199
|
+
<div
|
|
200
|
+
style={{
|
|
201
|
+
...styles.dropdown,
|
|
202
|
+
...menuStyle,
|
|
203
|
+
}}
|
|
204
|
+
>
|
|
205
|
+
<div style={{ padding: '0.25rem 0' }}>
|
|
206
|
+
{Object.entries(dictionary)
|
|
207
|
+
.filter(([key]) => key !== selectedKey)
|
|
208
|
+
.map(([key, item]) => (
|
|
209
|
+
<button
|
|
210
|
+
type="button"
|
|
211
|
+
key={key}
|
|
212
|
+
style={{
|
|
213
|
+
...styles.dropdownItem,
|
|
214
|
+
...(isHovering === key ? styles.dropdownItemHover : {}),
|
|
215
|
+
}}
|
|
216
|
+
onMouseEnter={() => setIsHovering(key)}
|
|
217
|
+
onMouseLeave={() => setIsHovering(null)}
|
|
218
|
+
onClick={e => {
|
|
219
|
+
// Stop event propagation to prevent handleClickOutside from firing
|
|
220
|
+
e.stopPropagation();
|
|
221
|
+
|
|
222
|
+
if (onSelect) {
|
|
223
|
+
onSelect(key);
|
|
224
|
+
}
|
|
225
|
+
setIsOpen(false);
|
|
226
|
+
}}
|
|
227
|
+
>
|
|
228
|
+
{renderItem(key, item)}
|
|
229
|
+
</button>
|
|
230
|
+
))}
|
|
231
|
+
</div>
|
|
232
|
+
</div>
|
|
233
|
+
)}
|
|
234
|
+
</div>
|
|
235
|
+
);
|
|
236
|
+
}
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
import { FaFile, FaLink, FaPaperclip, FaSearch, FaTag } from 'react-icons/fa';
|
|
2
|
+
import { ReviewCard } from '@envive-ai/react-toolkit-v3/ReviewCard';
|
|
3
|
+
import { Message as MessageComponent } from '@envive-ai/react-toolkit-v3/Message';
|
|
4
|
+
import classNames from 'classnames';
|
|
5
|
+
import { Message, MessageType } from '@envive-ai/react-hooks/application/models';
|
|
6
|
+
|
|
7
|
+
const textContentMessageTypes = new Set([
|
|
8
|
+
MessageType.Text,
|
|
9
|
+
MessageType.QueryTyped,
|
|
10
|
+
MessageType.SuggestionClicked,
|
|
11
|
+
MessageType.CXAgentResponse,
|
|
12
|
+
]);
|
|
13
|
+
|
|
14
|
+
const containerClassNames = classNames({
|
|
15
|
+
'envive-tw-flex': true,
|
|
16
|
+
'envive-tw-flex-col': true,
|
|
17
|
+
'envive-tw-gap-1': true,
|
|
18
|
+
});
|
|
19
|
+
|
|
20
|
+
const fontSemiboldClassNames = classNames({
|
|
21
|
+
'envive-tw-font-semibold': true,
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const flexItemsClassNames = classNames({
|
|
25
|
+
'envive-tw-flex': true,
|
|
26
|
+
'envive-tw-items-center': true,
|
|
27
|
+
});
|
|
28
|
+
|
|
29
|
+
const gap1ClassNames = classNames({
|
|
30
|
+
'envive-tw-gap-1': true,
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
const textLinkClassNames = classNames({
|
|
34
|
+
'envive-tw-text-[--spiffy-colors-text-link]': true,
|
|
35
|
+
'envive-tw-underline': true,
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
const textLgClassNames = classNames({
|
|
39
|
+
'envive-tw-text-lg': true,
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
const iconClassNames = classNames({
|
|
43
|
+
'envive-tw-w-3': true,
|
|
44
|
+
'envive-tw-h-3': true,
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
export const MessageContent = ({ message: m }: { message: Message }) => {
|
|
48
|
+
// text messages
|
|
49
|
+
if (textContentMessageTypes.has(m.type)) {
|
|
50
|
+
if (m.type === MessageType.Text) {
|
|
51
|
+
return (
|
|
52
|
+
<MessageComponent
|
|
53
|
+
key={m.id}
|
|
54
|
+
content={m.metadata.content}
|
|
55
|
+
/>
|
|
56
|
+
);
|
|
57
|
+
}
|
|
58
|
+
if (m.type === MessageType.QueryTyped) {
|
|
59
|
+
return (
|
|
60
|
+
<MessageComponent
|
|
61
|
+
key={m.id}
|
|
62
|
+
content={m.metadata.content}
|
|
63
|
+
/>
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
if (m.type === MessageType.SuggestionClicked) {
|
|
67
|
+
return (
|
|
68
|
+
<MessageComponent
|
|
69
|
+
key={m.id}
|
|
70
|
+
content={m.metadata.suggestionContent}
|
|
71
|
+
/>
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
if (m.type === MessageType.CXAgentResponse) {
|
|
75
|
+
return (
|
|
76
|
+
<MessageComponent
|
|
77
|
+
key={m.id}
|
|
78
|
+
content={m.metadata.message}
|
|
79
|
+
/>
|
|
80
|
+
);
|
|
81
|
+
}
|
|
82
|
+
return (
|
|
83
|
+
<MessageComponent
|
|
84
|
+
key={m.id}
|
|
85
|
+
content="unknown"
|
|
86
|
+
/>
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (m.type === MessageType.Product) {
|
|
91
|
+
return (
|
|
92
|
+
<div className={classNames(flexItemsClassNames, gap1ClassNames, 'envive-tw-text-sm')}>
|
|
93
|
+
<FaTag className={iconClassNames} />
|
|
94
|
+
|
|
95
|
+
<a
|
|
96
|
+
href={m.metadata.url}
|
|
97
|
+
target="_blank"
|
|
98
|
+
rel="noopener noreferrer"
|
|
99
|
+
className={textLinkClassNames}
|
|
100
|
+
>
|
|
101
|
+
{m.metadata.title}
|
|
102
|
+
</a>
|
|
103
|
+
</div>
|
|
104
|
+
);
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if (m.type === MessageType.Review) {
|
|
108
|
+
return (
|
|
109
|
+
<ReviewCard
|
|
110
|
+
name={m.metadata?.reviewer ?? ''}
|
|
111
|
+
rating={m.metadata?.stars ?? 0}
|
|
112
|
+
reviewText={m.metadata?.review ?? ''}
|
|
113
|
+
/>
|
|
114
|
+
);
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
if (m.type === MessageType.Separator) {
|
|
118
|
+
return (
|
|
119
|
+
<div className="envive-tw-relative envive-tw-flex envive-tw-w-full envive-tw-items-center envive-tw-p-2">
|
|
120
|
+
<div className="envive-tw-flex-grow envive-tw-border-t envive-tw-border-gray-500" />
|
|
121
|
+
|
|
122
|
+
<span className="envive-tw-flex-shrink envive-tw-px-4 envive-tw-text-sm envive-tw-text-gray-500">
|
|
123
|
+
New Discussion
|
|
124
|
+
</span>
|
|
125
|
+
|
|
126
|
+
<div className="envive-tw-flex-grow envive-tw-border-t envive-tw-border-gray-500" />
|
|
127
|
+
</div>
|
|
128
|
+
);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
if (m.type === MessageType.Page) {
|
|
132
|
+
return (
|
|
133
|
+
<div className={containerClassNames}>
|
|
134
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
135
|
+
<FaFile className={iconClassNames} />
|
|
136
|
+
|
|
137
|
+
<span className={classNames(textLgClassNames, fontSemiboldClassNames)}>
|
|
138
|
+
{m.metadata?.title}
|
|
139
|
+
</span>
|
|
140
|
+
</div>
|
|
141
|
+
|
|
142
|
+
{m.metadata?.url && (
|
|
143
|
+
<div className={classNames(flexItemsClassNames, gap1ClassNames)}>
|
|
144
|
+
<FaLink className={iconClassNames} />
|
|
145
|
+
|
|
146
|
+
<a
|
|
147
|
+
href={m.metadata.url}
|
|
148
|
+
target="_blank"
|
|
149
|
+
rel="noopener noreferrer"
|
|
150
|
+
className={textLinkClassNames}
|
|
151
|
+
>
|
|
152
|
+
{m.metadata.url}
|
|
153
|
+
</a>
|
|
154
|
+
</div>
|
|
155
|
+
)}
|
|
156
|
+
</div>
|
|
157
|
+
);
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
if (m.type === MessageType.Search) {
|
|
161
|
+
return (
|
|
162
|
+
<div className={containerClassNames}>
|
|
163
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
164
|
+
<FaSearch className={iconClassNames} /> Search
|
|
165
|
+
</div>
|
|
166
|
+
|
|
167
|
+
<div>{m.metadata?.searchTerm}</div>
|
|
168
|
+
</div>
|
|
169
|
+
);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
if (m.type === MessageType.Attachment) {
|
|
173
|
+
return (
|
|
174
|
+
<div className={containerClassNames}>
|
|
175
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
176
|
+
<FaPaperclip className={iconClassNames} /> Attachment
|
|
177
|
+
</div>
|
|
178
|
+
|
|
179
|
+
<div>{m.metadata?.message}</div>
|
|
180
|
+
|
|
181
|
+
{m.metadata?.attachment.map(attachment => (
|
|
182
|
+
<div key={attachment.id}>
|
|
183
|
+
<a
|
|
184
|
+
href={attachment.url ?? ''}
|
|
185
|
+
target="_blank"
|
|
186
|
+
rel="noopener noreferrer"
|
|
187
|
+
className={textLinkClassNames}
|
|
188
|
+
>
|
|
189
|
+
{attachment.name}
|
|
190
|
+
</a>
|
|
191
|
+
</div>
|
|
192
|
+
))}
|
|
193
|
+
</div>
|
|
194
|
+
);
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
if (m.type === MessageType.Form) {
|
|
198
|
+
return (
|
|
199
|
+
<div className={containerClassNames}>
|
|
200
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
201
|
+
<FaPaperclip className={iconClassNames} /> Form Request
|
|
202
|
+
</div>
|
|
203
|
+
|
|
204
|
+
<div>{m.metadata?.formType}</div>
|
|
205
|
+
</div>
|
|
206
|
+
);
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
if (m.type === MessageType.ProductSearch) {
|
|
210
|
+
return (
|
|
211
|
+
<div className={containerClassNames}>
|
|
212
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
213
|
+
<FaPaperclip className={iconClassNames} /> Product Search Results
|
|
214
|
+
</div>
|
|
215
|
+
|
|
216
|
+
<div>
|
|
217
|
+
{m.metadata?.generatedQuery} - {m.metadata?.productCount} results
|
|
218
|
+
</div>
|
|
219
|
+
</div>
|
|
220
|
+
);
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
if (m.type === MessageType.ProductSearchFilter) {
|
|
224
|
+
return (
|
|
225
|
+
<div className={containerClassNames}>
|
|
226
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
227
|
+
<FaPaperclip className={iconClassNames} /> Product Search Filter
|
|
228
|
+
</div>
|
|
229
|
+
|
|
230
|
+
<div>Filter: {m.metadata?.filterName}</div>
|
|
231
|
+
</div>
|
|
232
|
+
);
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
if (m.type === MessageType.Order) {
|
|
236
|
+
return (
|
|
237
|
+
<div className={containerClassNames}>
|
|
238
|
+
<div className={classNames(fontSemiboldClassNames, flexItemsClassNames, gap1ClassNames)}>
|
|
239
|
+
<FaPaperclip className={iconClassNames} /> Order Information
|
|
240
|
+
</div>
|
|
241
|
+
|
|
242
|
+
<div>OrderNumber: {m.metadata?.orderNumber}</div>
|
|
243
|
+
</div>
|
|
244
|
+
);
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
throw new Error(`Unsupported message type: ${JSON.stringify(m)}`);
|
|
248
|
+
};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useAtomValue } from 'jotai';
|
|
3
|
+
import classNames from 'classnames';
|
|
4
|
+
import { chatAtom } from '@envive-ai/react-hooks/atoms/chat';
|
|
5
|
+
import { MessageType } from '@envive-ai/react-hooks/application/models';
|
|
6
|
+
import { PromptCarousel, PromptCarouselRows } from '@envive-ai/react-toolkit-v3/PromptCarousel';
|
|
7
|
+
import { MessageContent } from './MessageContent';
|
|
8
|
+
|
|
9
|
+
const containerClassNames = classNames({
|
|
10
|
+
'envive-tw-font-sans': true,
|
|
11
|
+
'envive-tw-text-base': true,
|
|
12
|
+
'envive-tw-leading-6': true,
|
|
13
|
+
'envive-tw-font-normal': true,
|
|
14
|
+
});
|
|
15
|
+
|
|
16
|
+
const messagesContainerClassNames = classNames({
|
|
17
|
+
'envive-tw-flex': true,
|
|
18
|
+
'envive-tw-flex-col': true,
|
|
19
|
+
'envive-tw-gap-4': true,
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
const turnContainerClassNames = classNames({
|
|
23
|
+
'envive-tw-flex': true,
|
|
24
|
+
'envive-tw-flex-col': true,
|
|
25
|
+
'envive-tw-gap-2': true,
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
const messageBodyClassNames = classNames({
|
|
29
|
+
'envive-tw-whitespace-pre-wrap': true,
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
const lastTurnClassNames = classNames({
|
|
33
|
+
'envive-tw-bg-[#FFFFF0]': true,
|
|
34
|
+
'envive-tw-p-2': true,
|
|
35
|
+
'envive-tw-rounded-lg': true,
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
const lastTurnContentClassNames = classNames({
|
|
39
|
+
'envive-tw-flex': true,
|
|
40
|
+
'envive-tw-flex-col': true,
|
|
41
|
+
'envive-tw-gap-2': true,
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
const ChatEmbed = () => {
|
|
45
|
+
const { messages, suggestions } = useAtomValue(chatAtom);
|
|
46
|
+
const lastTurnRef = React.useRef<HTMLDivElement>(null);
|
|
47
|
+
|
|
48
|
+
// Scroll the last turn into view when messages change
|
|
49
|
+
React.useEffect(() => {
|
|
50
|
+
if (lastTurnRef.current && messages.length > 0) {
|
|
51
|
+
lastTurnRef.current.scrollIntoView({ behavior: 'smooth', block: 'nearest' });
|
|
52
|
+
}
|
|
53
|
+
}, [messages]);
|
|
54
|
+
|
|
55
|
+
const answerSuggestions = suggestions.filter(s => s.isAnswer);
|
|
56
|
+
const generalSuggestions = suggestions.filter(s => !s.isAnswer);
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<div className={containerClassNames}>
|
|
60
|
+
<div className={messagesContainerClassNames}>
|
|
61
|
+
{messages.map((turn, turnIdx) => {
|
|
62
|
+
const isLastTurn = turnIdx === messages.length - 1;
|
|
63
|
+
|
|
64
|
+
return (
|
|
65
|
+
<div key={turnIdx}>
|
|
66
|
+
<div className={turnContainerClassNames}>
|
|
67
|
+
{turn
|
|
68
|
+
.filter(m => m.type === MessageType.Separator)
|
|
69
|
+
.map(message => (
|
|
70
|
+
<div key={message.id}>
|
|
71
|
+
<div className={messageBodyClassNames}>
|
|
72
|
+
<MessageContent message={message} />
|
|
73
|
+
</div>
|
|
74
|
+
</div>
|
|
75
|
+
))}
|
|
76
|
+
</div>
|
|
77
|
+
|
|
78
|
+
<div
|
|
79
|
+
ref={isLastTurn ? lastTurnRef : null}
|
|
80
|
+
className={`${turnContainerClassNames} ${isLastTurn ? lastTurnClassNames : ''}`}
|
|
81
|
+
>
|
|
82
|
+
{turn
|
|
83
|
+
.filter(m => m.type !== MessageType.Separator)
|
|
84
|
+
.map(message => (
|
|
85
|
+
<div key={message.id}>
|
|
86
|
+
<div className={messageBodyClassNames}>
|
|
87
|
+
<MessageContent message={message} />
|
|
88
|
+
</div>
|
|
89
|
+
</div>
|
|
90
|
+
))}
|
|
91
|
+
</div>
|
|
92
|
+
</div>
|
|
93
|
+
);
|
|
94
|
+
})}
|
|
95
|
+
</div>
|
|
96
|
+
|
|
97
|
+
{suggestions.length > 0 && (
|
|
98
|
+
<div className={lastTurnClassNames}>
|
|
99
|
+
<div className={lastTurnContentClassNames}>
|
|
100
|
+
<PromptCarousel
|
|
101
|
+
promptButtonTexts={answerSuggestions.map(s => s.content)}
|
|
102
|
+
handleButtonClick={() => {}}
|
|
103
|
+
promptCarouselRows={PromptCarouselRows.ALWAYS_ONE}
|
|
104
|
+
isLoading={false}
|
|
105
|
+
/>
|
|
106
|
+
<PromptCarousel
|
|
107
|
+
promptButtonTexts={generalSuggestions.map(s => s.content)}
|
|
108
|
+
handleButtonClick={() => {}}
|
|
109
|
+
promptCarouselRows={PromptCarouselRows.ALWAYS_ONE}
|
|
110
|
+
isLoading={false}
|
|
111
|
+
/>
|
|
112
|
+
</div>
|
|
113
|
+
</div>
|
|
114
|
+
)}
|
|
115
|
+
</div>
|
|
116
|
+
);
|
|
117
|
+
};
|
|
118
|
+
|
|
119
|
+
export default ChatEmbed;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useSystemSettingsContext } from '@envive-ai/react-hooks/hooks/SystemSettingsContext';
|
|
2
|
+
import { ReportIssue } from './reportIssue';
|
|
3
|
+
|
|
4
|
+
export const DebugBar = () => {
|
|
5
|
+
const { showDebugBar } = useSystemSettingsContext();
|
|
6
|
+
console.log('=== showDebugBar ===', showDebugBar);
|
|
7
|
+
if (!showDebugBar) return null;
|
|
8
|
+
return (
|
|
9
|
+
<div className="envive-tw-flex envive-tw-items-center envive-tw-p-[4px]">
|
|
10
|
+
<ReportIssue />
|
|
11
|
+
</div>
|
|
12
|
+
);
|
|
13
|
+
};
|