botframework-webchat-api 4.13.0 → 4.15.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.yml +4 -100
- package/.prettierrc.yml +1 -1
- package/lib/StyleOptions.d.ts +270 -15
- package/lib/StyleOptions.d.ts.map +1 -1
- package/lib/defaultStyleOptions.d.ts +4 -0
- package/lib/defaultStyleOptions.d.ts.map +1 -0
- package/lib/defaultStyleOptions.js +73 -16
- package/lib/hooks/Composer.d.ts +71 -0
- package/lib/hooks/Composer.d.ts.map +1 -0
- package/lib/hooks/Composer.js +122 -90
- package/lib/hooks/index.d.ts +74 -0
- package/lib/hooks/index.d.ts.map +1 -0
- package/lib/hooks/index.js +89 -1
- package/lib/hooks/internal/ErrorBox.js +2 -2
- package/lib/hooks/internal/Tracker.d.ts +4 -0
- package/lib/hooks/internal/Tracker.d.ts.map +1 -0
- package/lib/hooks/internal/WebChatAPIContext.d.ts +81 -0
- package/lib/hooks/internal/WebChatAPIContext.d.ts.map +1 -0
- package/lib/hooks/internal/WebChatAPIContext.js +2 -4
- package/lib/hooks/internal/useCreateActivityRendererInternal.d.ts +4 -0
- package/lib/hooks/internal/useCreateActivityRendererInternal.d.ts.map +1 -0
- package/lib/hooks/internal/useCreateActivityRendererInternal.js +1 -1
- package/lib/hooks/internal/useDebugDeps.js +11 -5
- package/lib/hooks/internal/useDownscaleImageToDataURL.js +1 -1
- package/lib/hooks/internal/useErrorBoxClass.js +1 -1
- package/lib/hooks/internal/useForceRender.js +2 -2
- package/lib/hooks/internal/useLocalizedStrings.js +1 -1
- package/lib/hooks/internal/usePrevious.d.ts +2 -0
- package/lib/hooks/internal/usePrevious.d.ts.map +1 -0
- package/lib/hooks/internal/usePrevious.js +17 -0
- package/lib/hooks/internal/useReadTelemetryDimensions.js +2 -2
- package/lib/hooks/internal/useTimePassed.js +2 -2
- package/lib/hooks/internal/useTracker.js +2 -2
- package/lib/hooks/internal/useValueRef.d.ts +3 -0
- package/lib/hooks/internal/useValueRef.d.ts.map +1 -0
- package/lib/hooks/internal/useValueRef.js +24 -0
- package/lib/hooks/middleware/UserlandBoundary.js +4 -4
- package/lib/hooks/middleware/applyMiddleware.js +6 -6
- package/lib/hooks/middleware/concatMiddleware.d.ts +6 -0
- package/lib/hooks/middleware/concatMiddleware.d.ts.map +1 -0
- package/lib/hooks/middleware/concatMiddleware.js +3 -3
- package/lib/hooks/middleware/createDefaultCardActionMiddleware.d.ts +3 -0
- package/lib/hooks/middleware/createDefaultCardActionMiddleware.d.ts.map +1 -0
- package/lib/hooks/middleware/createDefaultCardActionMiddleware.js +6 -8
- package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.d.ts +5 -0
- package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.d.ts.map +1 -0
- package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.js +1 -1
- package/lib/hooks/useActiveTyping.d.ts +6 -0
- package/lib/hooks/useActiveTyping.d.ts.map +1 -0
- package/lib/hooks/useActiveTyping.js +4 -4
- package/lib/hooks/useActivities.d.ts +3 -0
- package/lib/hooks/useActivities.d.ts.map +1 -0
- package/lib/hooks/useActivities.js +1 -1
- package/lib/hooks/useActivityKeys.d.ts +3 -0
- package/lib/hooks/useActivityKeys.d.ts.map +1 -0
- package/lib/hooks/useActivityKeys.js +14 -0
- package/lib/hooks/useActivityKeysByRead.d.ts +3 -0
- package/lib/hooks/useActivityKeysByRead.d.ts.map +1 -0
- package/lib/hooks/useActivityKeysByRead.js +14 -0
- package/lib/hooks/useAvatarForBot.d.ts +5 -0
- package/lib/hooks/useAvatarForBot.d.ts.map +1 -0
- package/lib/hooks/useAvatarForBot.js +2 -2
- package/lib/hooks/useAvatarForUser.d.ts +5 -0
- package/lib/hooks/useAvatarForUser.d.ts.map +1 -0
- package/lib/hooks/useAvatarForUser.js +2 -2
- package/lib/hooks/useByteFormatter.d.ts +2 -0
- package/lib/hooks/useByteFormatter.d.ts.map +1 -0
- package/lib/hooks/useByteFormatter.js +2 -2
- package/lib/hooks/useConnectivityStatus.d.ts +2 -0
- package/lib/hooks/useConnectivityStatus.d.ts.map +1 -0
- package/lib/hooks/useConnectivityStatus.js +1 -1
- package/lib/hooks/useCreateActivityRenderer.d.ts +3 -0
- package/lib/hooks/useCreateActivityRenderer.d.ts.map +1 -0
- package/lib/hooks/useCreateActivityRenderer.js +1 -2
- package/lib/hooks/useCreateActivityStatusRenderer.d.ts +9 -0
- package/lib/hooks/useCreateActivityStatusRenderer.d.ts.map +1 -0
- package/lib/hooks/useCreateActivityStatusRenderer.js +6 -4
- package/lib/hooks/useCreateAvatarRenderer.d.ts +6 -0
- package/lib/hooks/useCreateAvatarRenderer.d.ts.map +1 -0
- package/lib/hooks/useCreateAvatarRenderer.js +2 -2
- package/lib/hooks/useCreateScrollToEndButtonRenderer.d.ts +3 -0
- package/lib/hooks/useCreateScrollToEndButtonRenderer.d.ts.map +1 -0
- package/lib/hooks/useCreateScrollToEndButtonRenderer.js +15 -0
- package/lib/hooks/useDateFormatter.d.ts +2 -0
- package/lib/hooks/useDateFormatter.d.ts.map +1 -0
- package/lib/hooks/useDateFormatter.js +2 -2
- package/lib/hooks/useDebouncedNotifications.d.ts +13 -0
- package/lib/hooks/useDebouncedNotifications.d.ts.map +1 -0
- package/lib/hooks/useDebouncedNotifications.js +7 -7
- package/lib/hooks/useDictateInterims.d.ts +2 -0
- package/lib/hooks/useDictateInterims.d.ts.map +1 -0
- package/lib/hooks/useDictateInterims.js +1 -1
- package/lib/hooks/useDictateState.d.ts +2 -0
- package/lib/hooks/useDictateState.d.ts.map +1 -0
- package/lib/hooks/useDictateState.js +1 -1
- package/lib/hooks/useDirection.d.ts +2 -0
- package/lib/hooks/useDirection.d.ts.map +1 -0
- package/lib/hooks/useDirection.js +2 -2
- package/lib/hooks/useDisabled.d.ts +2 -0
- package/lib/hooks/useDisabled.d.ts.map +1 -0
- package/lib/hooks/useDisabled.js +1 -1
- package/lib/hooks/useDismissNotification.d.ts +2 -0
- package/lib/hooks/useDismissNotification.d.ts.map +1 -0
- package/lib/hooks/useDismissNotification.js +1 -1
- package/lib/hooks/useEmitTypingIndicator.d.ts +2 -0
- package/lib/hooks/useEmitTypingIndicator.d.ts.map +1 -0
- package/lib/hooks/useEmitTypingIndicator.js +1 -1
- package/lib/hooks/useGetActivityByKey.d.ts +3 -0
- package/lib/hooks/useGetActivityByKey.d.ts.map +1 -0
- package/lib/hooks/useGetActivityByKey.js +14 -0
- package/lib/hooks/useGetHasAcknowledgedByActivityKey.d.ts +3 -0
- package/lib/hooks/useGetHasAcknowledgedByActivityKey.d.ts.map +1 -0
- package/lib/hooks/useGetHasAcknowledgedByActivityKey.js +14 -0
- package/lib/hooks/useGetKeyByActivity.d.ts +3 -0
- package/lib/hooks/useGetKeyByActivity.d.ts.map +1 -0
- package/lib/hooks/useGetKeyByActivity.js +14 -0
- package/lib/hooks/useGetKeyByActivityId.d.ts +3 -0
- package/lib/hooks/useGetKeyByActivityId.d.ts.map +1 -0
- package/lib/hooks/useGetKeyByActivityId.js +14 -0
- package/lib/hooks/useGetSendTimeoutForActivity.d.ts +5 -0
- package/lib/hooks/useGetSendTimeoutForActivity.d.ts.map +1 -0
- package/lib/hooks/useGetSendTimeoutForActivity.js +2 -2
- package/lib/hooks/useGrammars.d.ts +2 -0
- package/lib/hooks/useGrammars.d.ts.map +1 -0
- package/lib/hooks/useGrammars.js +1 -1
- package/lib/hooks/useGroupActivities.d.ts +8 -0
- package/lib/hooks/useGroupActivities.d.ts.map +1 -0
- package/lib/hooks/useGroupActivities.js +1 -1
- package/lib/hooks/useGroupTimestamp.d.ts +2 -0
- package/lib/hooks/useGroupTimestamp.d.ts.map +1 -0
- package/lib/hooks/useGroupTimestamp.js +2 -2
- package/lib/hooks/useLanguage.d.ts +2 -0
- package/lib/hooks/useLanguage.d.ts.map +1 -0
- package/lib/hooks/useLanguage.js +1 -1
- package/lib/hooks/useLastAcknowledgedActivityKey.d.ts +3 -0
- package/lib/hooks/useLastAcknowledgedActivityKey.d.ts.map +1 -0
- package/lib/hooks/useLastAcknowledgedActivityKey.js +14 -0
- package/lib/hooks/useLastReadActivityKey.d.ts +3 -0
- package/lib/hooks/useLastReadActivityKey.d.ts.map +1 -0
- package/lib/hooks/useLastReadActivityKey.js +14 -0
- package/lib/hooks/useLastTypingAt.d.ts +5 -0
- package/lib/hooks/useLastTypingAt.d.ts.map +1 -0
- package/lib/hooks/useLastTypingAt.js +2 -1
- package/lib/hooks/useLocalize.d.ts +3 -0
- package/lib/hooks/useLocalize.d.ts.map +1 -0
- package/lib/hooks/useLocalize.js +5 -2
- package/lib/hooks/useLocalizeDate.d.ts +3 -0
- package/lib/hooks/useLocalizeDate.d.ts.map +1 -0
- package/lib/hooks/useLocalizeDate.js +3 -2
- package/lib/hooks/useLocalizer.d.ts +13 -0
- package/lib/hooks/useLocalizer.d.ts.map +1 -0
- package/lib/hooks/useLocalizer.js +16 -6
- package/lib/hooks/useMarkActivityAsSpoken.d.ts +3 -0
- package/lib/hooks/useMarkActivityAsSpoken.d.ts.map +1 -0
- package/lib/hooks/useMarkActivityAsSpoken.js +1 -1
- package/lib/hooks/useMarkActivityKeyAsRead.d.ts +3 -0
- package/lib/hooks/useMarkActivityKeyAsRead.d.ts.map +1 -0
- package/lib/hooks/useMarkActivityKeyAsRead.js +14 -0
- package/lib/hooks/useMarkAllAsAcknowledged.d.ts +3 -0
- package/lib/hooks/useMarkAllAsAcknowledged.d.ts.map +1 -0
- package/lib/hooks/useMarkAllAsAcknowledged.js +14 -0
- package/lib/hooks/useNotifications.d.ts +3 -0
- package/lib/hooks/useNotifications.d.ts.map +1 -0
- package/lib/hooks/useNotifications.js +1 -1
- package/lib/hooks/usePerformCardAction.d.ts +3 -0
- package/lib/hooks/usePerformCardAction.d.ts.map +1 -0
- package/lib/hooks/usePerformCardAction.js +1 -1
- package/lib/hooks/usePostActivity.d.ts +4 -0
- package/lib/hooks/usePostActivity.d.ts.map +1 -0
- package/lib/hooks/usePostActivity.js +1 -1
- package/lib/hooks/useReferenceGrammarID.d.ts +2 -0
- package/lib/hooks/useReferenceGrammarID.d.ts.map +1 -0
- package/lib/hooks/useReferenceGrammarID.js +1 -1
- package/lib/hooks/useRelativeTimeFormatter.d.ts +2 -0
- package/lib/hooks/useRelativeTimeFormatter.d.ts.map +1 -0
- package/lib/hooks/useRelativeTimeFormatter.js +2 -2
- package/lib/hooks/useRenderActivity.js +2 -1
- package/lib/hooks/useRenderActivityStatus.js +2 -1
- package/lib/hooks/useRenderAttachment.js +1 -1
- package/lib/hooks/useRenderAvatar.js +2 -1
- package/lib/hooks/useRenderToast.d.ts +3 -0
- package/lib/hooks/useRenderToast.d.ts.map +1 -0
- package/lib/hooks/useRenderToast.js +1 -1
- package/lib/hooks/useRenderTypingIndicator.d.ts +3 -0
- package/lib/hooks/useRenderTypingIndicator.d.ts.map +1 -0
- package/lib/hooks/useRenderTypingIndicator.js +1 -1
- package/lib/hooks/useSendBoxValue.d.ts +2 -0
- package/lib/hooks/useSendBoxValue.d.ts.map +1 -0
- package/lib/hooks/useSendBoxValue.js +1 -1
- package/lib/hooks/useSendEvent.d.ts +2 -0
- package/lib/hooks/useSendEvent.d.ts.map +1 -0
- package/lib/hooks/useSendEvent.js +1 -1
- package/lib/hooks/useSendFiles.d.ts +2 -0
- package/lib/hooks/useSendFiles.d.ts.map +1 -0
- package/lib/hooks/useSendFiles.js +1 -1
- package/lib/hooks/useSendMessage.d.ts +4 -0
- package/lib/hooks/useSendMessage.d.ts.map +1 -0
- package/lib/hooks/useSendMessage.js +1 -1
- package/lib/hooks/useSendMessageBack.d.ts +2 -0
- package/lib/hooks/useSendMessageBack.d.ts.map +1 -0
- package/lib/hooks/useSendMessageBack.js +1 -1
- package/lib/hooks/useSendPostBack.d.ts +2 -0
- package/lib/hooks/useSendPostBack.d.ts.map +1 -0
- package/lib/hooks/useSendPostBack.js +1 -1
- package/lib/hooks/useSendTimeoutForActivity.d.ts +4 -0
- package/lib/hooks/useSendTimeoutForActivity.d.ts.map +1 -0
- package/lib/hooks/useSendTimeoutForActivity.js +2 -1
- package/lib/hooks/useSendTypingIndicator.d.ts +2 -0
- package/lib/hooks/useSendTypingIndicator.d.ts.map +1 -0
- package/lib/hooks/useSendTypingIndicator.js +1 -1
- package/lib/hooks/useSetNotification.d.ts +3 -0
- package/lib/hooks/useSetNotification.d.ts.map +1 -0
- package/lib/hooks/useSetNotification.js +1 -1
- package/lib/hooks/useShouldSpeakIncomingActivity.d.ts +2 -0
- package/lib/hooks/useShouldSpeakIncomingActivity.d.ts.map +1 -0
- package/lib/hooks/useShouldSpeakIncomingActivity.js +1 -1
- package/lib/hooks/useStartDictate.d.ts +2 -0
- package/lib/hooks/useStartDictate.d.ts.map +1 -0
- package/lib/hooks/useStartDictate.js +1 -1
- package/lib/hooks/useStopDictate.d.ts +2 -0
- package/lib/hooks/useStopDictate.d.ts.map +1 -0
- package/lib/hooks/useStopDictate.js +1 -1
- package/lib/hooks/useStyleOptions.d.ts +3 -0
- package/lib/hooks/useStyleOptions.d.ts.map +1 -0
- package/lib/hooks/useStyleOptions.js +1 -1
- package/lib/hooks/useSubmitSendBox.d.ts +4 -0
- package/lib/hooks/useSubmitSendBox.d.ts.map +1 -0
- package/lib/hooks/useSubmitSendBox.js +8 -5
- package/lib/hooks/useSuggestedActions.d.ts +6 -0
- package/lib/hooks/useSuggestedActions.d.ts.map +1 -0
- package/lib/hooks/useSuggestedActions.js +1 -1
- package/lib/hooks/useTimeoutForSend.d.ts +3 -0
- package/lib/hooks/useTimeoutForSend.d.ts.map +1 -0
- package/lib/hooks/useTimeoutForSend.js +2 -2
- package/lib/hooks/useTrackDimension.d.ts +2 -0
- package/lib/hooks/useTrackDimension.d.ts.map +1 -0
- package/lib/hooks/useTrackDimension.js +1 -1
- package/lib/hooks/useTrackEvent.d.ts +10 -0
- package/lib/hooks/useTrackEvent.d.ts.map +1 -0
- package/lib/hooks/useTrackEvent.js +1 -1
- package/lib/hooks/useTrackException.d.ts +2 -0
- package/lib/hooks/useTrackException.d.ts.map +1 -0
- package/lib/hooks/useTrackException.js +2 -2
- package/lib/hooks/useTrackTiming.d.ts +2 -0
- package/lib/hooks/useTrackTiming.d.ts.map +1 -0
- package/lib/hooks/useTrackTiming.js +1 -1
- package/lib/hooks/useUserID.d.ts +2 -0
- package/lib/hooks/useUserID.d.ts.map +1 -0
- package/lib/hooks/useUserID.js +1 -1
- package/lib/hooks/useUsername.d.ts +2 -0
- package/lib/hooks/useUsername.d.ts.map +1 -0
- package/lib/hooks/useUsername.js +1 -1
- package/lib/hooks/useVoiceSelector.d.ts +2 -0
- package/lib/hooks/useVoiceSelector.d.ts.map +1 -0
- package/lib/hooks/useVoiceSelector.js +1 -1
- package/lib/hooks/utils/ErrorBoundary.js +4 -4
- package/lib/hooks/utils/observableToPromise.d.ts +3 -0
- package/lib/hooks/utils/observableToPromise.d.ts.map +1 -0
- package/lib/hooks/utils/observableToPromise.js +1 -1
- package/lib/index.d.ts +20 -4
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +10 -10
- package/lib/localization/Localize.d.ts +10 -0
- package/lib/localization/Localize.d.ts.map +1 -0
- package/lib/localization/Localize.js +18 -12
- package/lib/localization/ar-SA.json +24 -4
- package/lib/localization/bg-BG.json +24 -4
- package/lib/localization/ca-ES.json +24 -4
- package/lib/localization/cs-CZ.json +24 -4
- package/lib/localization/da-DK.json +24 -4
- package/lib/localization/de-DE.json +24 -4
- package/lib/localization/el-GR.json +24 -4
- package/lib/localization/en-US.json +30 -7
- package/lib/localization/es-ES.json +24 -4
- package/lib/localization/et-EE.json +24 -4
- package/lib/localization/eu-ES.json +24 -4
- package/lib/localization/fi-FI.json +24 -4
- package/lib/localization/fr-FR.json +24 -4
- package/lib/localization/getAllLocalizedStrings.d.ts +6 -0
- package/lib/localization/getAllLocalizedStrings.d.ts.map +1 -0
- package/lib/localization/getAllLocalizedStrings.js +1 -1
- package/lib/localization/getLocaleString.d.ts +2 -0
- package/lib/localization/getLocaleString.d.ts.map +1 -0
- package/lib/localization/getLocaleString.js +3 -3
- package/lib/localization/getRTLList.d.ts +2 -0
- package/lib/localization/getRTLList.d.ts.map +1 -0
- package/lib/localization/getRTLList.js +1 -1
- package/lib/localization/gl-ES.json +24 -4
- package/lib/localization/he-IL.json +24 -4
- package/lib/localization/hi-IN.json +24 -4
- package/lib/localization/hr-HR.json +24 -4
- package/lib/localization/hu-HU.json +24 -4
- package/lib/localization/id-ID.json +24 -4
- package/lib/localization/it-IT.json +24 -4
- package/lib/localization/ja-JP.json +24 -4
- package/lib/localization/kk-KZ.json +24 -4
- package/lib/localization/ko-KR.json +24 -4
- package/lib/localization/lt-LT.json +24 -4
- package/lib/localization/lv-LV.json +24 -4
- package/lib/localization/mergeLocalizedStrings.d.ts +7 -0
- package/lib/localization/mergeLocalizedStrings.d.ts.map +1 -0
- package/lib/localization/mergeLocalizedStrings.js +14 -7
- package/lib/localization/ms-MY.json +24 -4
- package/lib/localization/nb-NO.json +24 -4
- package/lib/localization/nl-NL.json +24 -4
- package/lib/localization/pl-PL.json +24 -4
- package/lib/localization/pt-BR.json +24 -4
- package/lib/localization/pt-PT.json +24 -4
- package/lib/localization/ro-RO.json +24 -4
- package/lib/localization/ru-RU.json +24 -4
- package/lib/localization/sk-SK.json +24 -4
- package/lib/localization/sl-SI.json +24 -4
- package/lib/localization/sr-Cyrl-CS.json +24 -4
- package/lib/localization/sr-Latn-CS.json +24 -4
- package/lib/localization/sv-SE.json +24 -4
- package/lib/localization/th-TH.json +24 -4
- package/lib/localization/tr-TR.json +24 -4
- package/lib/localization/uk-UA.json +24 -4
- package/lib/localization/vi-VN.json +24 -4
- package/lib/localization/yue.json +27 -7
- package/lib/localization/zh-CN.json +24 -4
- package/lib/localization/zh-HK.json +24 -4
- package/lib/localization/zh-TW.json +24 -4
- package/lib/normalizeStyleOptions.d.ts +3 -0
- package/lib/normalizeStyleOptions.d.ts.map +1 -0
- package/lib/normalizeStyleOptions.js +85 -5
- package/lib/patchStyleOptionsFromDeprecatedProps.js +1 -2
- package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.d.ts +5 -0
- package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.js +184 -0
- package/lib/providers/ActivityAcknowledgement/private/Context.d.ts +13 -0
- package/lib/providers/ActivityAcknowledgement/private/Context.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/private/Context.js +13 -0
- package/lib/providers/ActivityAcknowledgement/private/types.d.ts +6 -0
- package/lib/providers/ActivityAcknowledgement/private/types.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/private/types.js +2 -0
- package/lib/providers/ActivityAcknowledgement/private/useContext.d.ts +3 -0
- package/lib/providers/ActivityAcknowledgement/private/useContext.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/private/useContext.js +24 -0
- package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.d.ts +5 -0
- package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.js +18 -0
- package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.d.ts +2 -0
- package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.js +15 -0
- package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.d.ts +2 -0
- package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.js +15 -0
- package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.d.ts +2 -0
- package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.js +15 -0
- package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.d.ts +2 -0
- package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.js +15 -0
- package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.d.ts +2 -0
- package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.d.ts.map +1 -0
- package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.js +15 -0
- package/lib/providers/ActivityKeyer/ActivityKeyerComposer.d.ts +18 -0
- package/lib/providers/ActivityKeyer/ActivityKeyerComposer.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/ActivityKeyerComposer.js +153 -0
- package/lib/providers/ActivityKeyer/private/Context.d.ts +12 -0
- package/lib/providers/ActivityKeyer/private/Context.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/private/Context.js +13 -0
- package/lib/providers/ActivityKeyer/private/getActivityId.d.ts +3 -0
- package/lib/providers/ActivityKeyer/private/getActivityId.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/private/getActivityId.js +11 -0
- package/lib/providers/ActivityKeyer/private/getClientActivityId.d.ts +3 -0
- package/lib/providers/ActivityKeyer/private/getClientActivityId.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/private/getClientActivityId.js +13 -0
- package/lib/providers/ActivityKeyer/private/uniqueId.d.ts +2 -0
- package/lib/providers/ActivityKeyer/private/uniqueId.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/private/uniqueId.js +18 -0
- package/lib/providers/ActivityKeyer/private/useContext.d.ts +3 -0
- package/lib/providers/ActivityKeyer/private/useContext.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/private/useContext.js +24 -0
- package/lib/providers/ActivityKeyer/useActivityKeys.d.ts +2 -0
- package/lib/providers/ActivityKeyer/useActivityKeys.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/useActivityKeys.js +15 -0
- package/lib/providers/ActivityKeyer/useGetActivityByKey.d.ts +3 -0
- package/lib/providers/ActivityKeyer/useGetActivityByKey.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/useGetActivityByKey.js +15 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivity.d.ts +3 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivity.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivity.js +15 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivityId.d.ts +2 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivityId.d.ts.map +1 -0
- package/lib/providers/ActivityKeyer/useGetKeyByActivityId.js +15 -0
- package/lib/tsconfig.json +3 -1
- package/lib/types/ActivityMiddleware.d.ts +25 -0
- package/lib/types/ActivityMiddleware.d.ts.map +1 -0
- package/lib/types/ActivityMiddleware.js +2 -0
- package/lib/types/ActivityStatusMiddleware.d.ts +18 -0
- package/lib/types/ActivityStatusMiddleware.d.ts.map +1 -0
- package/lib/types/ActivityStatusMiddleware.js +2 -0
- package/lib/types/AttachmentForScreenReaderMiddleware.d.ts +14 -0
- package/lib/types/AttachmentForScreenReaderMiddleware.d.ts.map +1 -0
- package/lib/types/AttachmentForScreenReaderMiddleware.js +2 -0
- package/lib/types/AttachmentMiddleware.d.ts +12 -0
- package/lib/types/AttachmentMiddleware.d.ts.map +1 -0
- package/lib/types/AttachmentMiddleware.js +2 -0
- package/lib/types/AvatarMiddleware.d.ts +15 -0
- package/lib/types/AvatarMiddleware.d.ts.map +1 -0
- package/lib/types/AvatarMiddleware.js +2 -0
- package/lib/types/CardActionMiddleware.d.ts +19 -0
- package/lib/types/CardActionMiddleware.d.ts.map +1 -0
- package/lib/types/CardActionMiddleware.js +2 -0
- package/lib/types/ComponentMiddleware.d.ts +31 -0
- package/lib/types/ComponentMiddleware.d.ts.map +1 -0
- package/lib/types/ComponentMiddleware.js +2 -0
- package/lib/types/FunctionMiddleware.d.ts +6 -0
- package/lib/types/FunctionMiddleware.d.ts.map +1 -0
- package/lib/types/FunctionMiddleware.js +2 -0
- package/lib/types/GroupActivitiesMiddleware.d.ts +22 -0
- package/lib/types/GroupActivitiesMiddleware.d.ts.map +1 -0
- package/lib/types/GroupActivitiesMiddleware.js +2 -0
- package/lib/types/LocalizedStrings.d.ts +5 -0
- package/lib/types/LocalizedStrings.d.ts.map +1 -0
- package/lib/types/LocalizedStrings.js +2 -0
- package/lib/types/Notification.d.ts +10 -0
- package/lib/types/Notification.d.ts.map +1 -0
- package/lib/types/Notification.js +2 -0
- package/lib/types/PrecompiledGlobalize.d.ts +13 -0
- package/lib/types/PrecompiledGlobalize.d.ts.map +1 -0
- package/lib/types/PrecompiledGlobalize.js +2 -0
- package/lib/types/ScrollToEndButtonMiddleware.d.ts +30 -0
- package/lib/types/ScrollToEndButtonMiddleware.d.ts.map +1 -0
- package/lib/types/ScrollToEndButtonMiddleware.js +2 -0
- package/lib/types/SendState.d.ts +3 -0
- package/lib/types/SendState.d.ts.map +1 -0
- package/lib/types/SendState.js +2 -0
- package/lib/types/TelemetryMeasurementEvent.d.ts +31 -0
- package/lib/types/TelemetryMeasurementEvent.d.ts.map +1 -0
- package/lib/types/TelemetryMeasurementEvent.js +2 -0
- package/lib/types/ToastMiddleware.d.ts +11 -0
- package/lib/types/ToastMiddleware.d.ts.map +1 -0
- package/lib/types/ToastMiddleware.js +2 -0
- package/lib/types/Typing.d.ts +8 -0
- package/lib/types/Typing.d.ts.map +1 -0
- package/lib/types/Typing.js +2 -0
- package/lib/types/TypingIndicatorMiddleware.d.ts +17 -0
- package/lib/types/TypingIndicatorMiddleware.d.ts.map +1 -0
- package/lib/types/TypingIndicatorMiddleware.js +2 -0
- package/lib/types/WebSpeechPonyfill.d.ts +18 -0
- package/lib/types/WebSpeechPonyfill.d.ts.map +1 -0
- package/lib/types/WebSpeechPonyfill.js +2 -0
- package/lib/types/WebSpeechPonyfillFactory.d.ts +6 -0
- package/lib/types/WebSpeechPonyfillFactory.d.ts.map +1 -0
- package/lib/types/WebSpeechPonyfillFactory.js +2 -0
- package/lib/utils/createCustomEvent.d.ts +4 -0
- package/lib/utils/createCustomEvent.d.ts.map +1 -0
- package/lib/utils/createCustomEvent.js +9 -3
- package/lib/utils/findLastIndex.d.ts +2 -0
- package/lib/utils/findLastIndex.d.ts.map +1 -0
- package/lib/utils/findLastIndex.js +32 -0
- package/lib/utils/findMin.d.ts +7 -0
- package/lib/utils/findMin.d.ts.map +1 -0
- package/lib/utils/findMin.js +3 -3
- package/lib/utils/isObject.js +1 -1
- package/lib/utils/mapMap.d.ts +6 -0
- package/lib/utils/mapMap.d.ts.map +1 -0
- package/lib/utils/mapMap.js +10 -3
- package/lib/utils/normalizeLanguage.d.ts +2 -0
- package/lib/utils/normalizeLanguage.d.ts.map +1 -0
- package/lib/utils/normalizeLanguage.js +1 -1
- package/lib/utils/randomId.d.ts +2 -0
- package/lib/utils/randomId.d.ts.map +1 -0
- package/lib/utils/randomId.js +1 -1
- package/lib/utils/warnOnce.js +17 -0
- package/package.json +25 -32
- package/scripts/createPrecompiledGlobalize.mjs +44 -0
- package/src/StyleOptions.ts +332 -15
- package/src/defaultStyleOptions.ts +75 -15
- package/src/hooks/Composer.tsx +224 -145
- package/src/hooks/{index.js → index.ts} +22 -0
- package/src/hooks/internal/WebChatAPIContext.ts +68 -3
- package/src/hooks/internal/useCreateActivityRendererInternal.ts +46 -0
- package/src/hooks/internal/useDebugDeps.js +9 -2
- package/src/hooks/internal/usePrevious.ts +11 -0
- package/src/hooks/internal/useValueRef.ts +21 -0
- package/src/hooks/middleware/applyMiddleware.js +2 -3
- package/src/hooks/middleware/concatMiddleware.spec.js +4 -6
- package/src/hooks/middleware/concatMiddleware.ts +27 -0
- package/src/hooks/middleware/createDefaultCardActionMiddleware.ts +42 -0
- package/src/hooks/middleware/{createDefaultGroupActivitiesMiddleware.js → createDefaultGroupActivitiesMiddleware.ts} +20 -12
- package/src/hooks/{useActiveTyping.js → useActiveTyping.ts} +13 -9
- package/src/hooks/useActivities.ts +7 -0
- package/src/hooks/useActivityKeys.ts +3 -0
- package/src/hooks/useActivityKeysByRead.ts +3 -0
- package/src/hooks/{useAvatarForBot.js → useAvatarForBot.ts} +1 -1
- package/src/hooks/{useAvatarForUser.js → useAvatarForUser.ts} +1 -1
- package/src/hooks/{useByteFormatter.js → useByteFormatter.ts} +1 -1
- package/src/hooks/{useConnectivityStatus.js → useConnectivityStatus.ts} +1 -1
- package/src/hooks/{useCreateActivityRenderer.js → useCreateActivityRenderer.ts} +2 -3
- package/src/hooks/{useCreateActivityStatusRenderer.js → useCreateActivityStatusRenderer.tsx} +27 -11
- package/src/hooks/useCreateAvatarRenderer.ts +39 -0
- package/src/hooks/useCreateScrollToEndButtonRenderer.ts +6 -0
- package/src/hooks/useDateFormatter.ts +14 -0
- package/src/hooks/useDebouncedNotifications.spec.js +2 -0
- package/src/hooks/{useDebouncedNotifications.js → useDebouncedNotifications.ts} +10 -2
- package/src/hooks/{useDictateInterims.js → useDictateInterims.ts} +1 -1
- package/src/hooks/{useDictateState.js → useDictateState.ts} +1 -1
- package/src/hooks/{useDirection.js → useDirection.ts} +1 -1
- package/src/hooks/{useDisabled.js → useDisabled.ts} +1 -1
- package/src/hooks/{useDismissNotification.js → useDismissNotification.ts} +1 -1
- package/src/hooks/{useEmitTypingIndicator.js → useEmitTypingIndicator.ts} +1 -1
- package/src/hooks/useGetActivityByKey.ts +3 -0
- package/src/hooks/useGetHasAcknowledgedByActivityKey.ts +3 -0
- package/src/hooks/useGetKeyByActivity.ts +3 -0
- package/src/hooks/useGetKeyByActivityId.ts +3 -0
- package/src/hooks/useGetSendTimeoutForActivity.ts +20 -0
- package/src/hooks/{useGrammars.js → useGrammars.ts} +1 -1
- package/src/hooks/useGroupActivities.ts +10 -0
- package/src/hooks/{useGroupTimestamp.js → useGroupTimestamp.ts} +1 -1
- package/src/hooks/{useLanguage.js → useLanguage.ts} +1 -1
- package/src/hooks/useLastAcknowledgedActivityKey.ts +3 -0
- package/src/hooks/useLastReadActivityKey.ts +3 -0
- package/src/hooks/{useLastTypingAt.js → useLastTypingAt.ts} +2 -1
- package/src/hooks/{useLocalize.js → useLocalize.ts} +3 -1
- package/src/hooks/{useLocalizeDate.js → useLocalizeDate.ts} +2 -1
- package/src/hooks/{useLocalizer.js → useLocalizer.ts} +24 -6
- package/src/hooks/{useMarkActivityAsSpoken.js → useMarkActivityAsSpoken.ts} +2 -1
- package/src/hooks/useMarkActivityKeyAsRead.ts +3 -0
- package/src/hooks/useMarkAllAsAcknowledged.ts +3 -0
- package/src/hooks/{useNotifications.js → useNotifications.ts} +2 -1
- package/src/hooks/usePerformCardAction.ts +6 -0
- package/src/hooks/usePostActivity.ts +8 -0
- package/src/hooks/{useReferenceGrammarID.js → useReferenceGrammarID.ts} +1 -1
- package/src/hooks/{useRelativeTimeFormatter.js → useRelativeTimeFormatter.ts} +1 -1
- package/src/hooks/useRenderActivity.js +12 -10
- package/src/hooks/useRenderActivityStatus.js +1 -0
- package/src/hooks/useRenderAvatar.js +1 -0
- package/src/hooks/{useRenderToast.js → useRenderToast.ts} +2 -1
- package/src/hooks/useRenderTypingIndicator.ts +6 -0
- package/src/hooks/{useSendBoxValue.js → useSendBoxValue.ts} +1 -1
- package/src/hooks/{useSendEvent.js → useSendEvent.ts} +1 -1
- package/src/hooks/{useSendFiles.js → useSendFiles.ts} +1 -1
- package/src/hooks/useSendMessage.ts +9 -0
- package/src/hooks/{useSendMessageBack.js → useSendMessageBack.ts} +1 -1
- package/src/hooks/{useSendPostBack.js → useSendPostBack.ts} +1 -1
- package/src/hooks/{useSendTimeoutForActivity.js → useSendTimeoutForActivity.ts} +4 -1
- package/src/hooks/{useSendTypingIndicator.js → useSendTypingIndicator.ts} +1 -1
- package/src/hooks/useSetNotification.ts +6 -0
- package/src/hooks/{useShouldSpeakIncomingActivity.js → useShouldSpeakIncomingActivity.ts} +1 -1
- package/src/hooks/{useStartDictate.js → useStartDictate.ts} +1 -1
- package/src/hooks/{useStopDictate.js → useStopDictate.ts} +1 -1
- package/src/hooks/useStyleOptions.ts +6 -0
- package/src/hooks/{useSubmitSendBox.js → useSubmitSendBox.ts} +3 -6
- package/src/hooks/{useSuggestedActions.js → useSuggestedActions.ts} +5 -1
- package/src/hooks/useTimeoutForSend.ts +9 -0
- package/src/hooks/{useTrackDimension.js → useTrackDimension.ts} +1 -1
- package/src/hooks/{useTrackEvent.js → useTrackEvent.ts} +10 -2
- package/src/hooks/{useTrackException.js → useTrackException.ts} +1 -1
- package/src/hooks/{useTrackTiming.js → useTrackTiming.ts} +4 -1
- package/src/hooks/{useUserID.js → useUserID.ts} +1 -1
- package/src/hooks/{useUsername.js → useUsername.ts} +1 -1
- package/src/hooks/{useVoiceSelector.js → useVoiceSelector.ts} +4 -1
- package/src/hooks/utils/{observableToPromise.js → observableToPromise.ts} +5 -3
- package/src/index.ts +51 -0
- package/src/localization/Localize.spec.js +2 -0
- package/src/localization/{Localize.js → Localize.ts} +15 -8
- package/src/localization/ar-SA.json +24 -4
- package/src/localization/bg-BG.json +24 -4
- package/src/localization/ca-ES.json +24 -4
- package/src/localization/cs-CZ.json +24 -4
- package/src/localization/da-DK.json +24 -4
- package/src/localization/de-DE.json +24 -4
- package/src/localization/el-GR.json +24 -4
- package/src/localization/en-US.json +30 -7
- package/src/localization/es-ES.json +24 -4
- package/src/localization/et-EE.json +24 -4
- package/src/localization/eu-ES.json +24 -4
- package/src/localization/fi-FI.json +24 -4
- package/src/localization/fr-FR.json +24 -4
- package/src/localization/getAllLocalizedStrings.spec.js +3 -1
- package/src/localization/{getAllLocalizedStrings.js → getAllLocalizedStrings.ts} +2 -1
- package/src/localization/getLocaleString.spec.js +4 -2
- package/src/localization/{getLocaleString.js → getLocaleString.ts} +2 -2
- package/src/localization/{getRTLList.js → getRTLList.ts} +1 -1
- package/src/localization/gl-ES.json +24 -4
- package/src/localization/he-IL.json +24 -4
- package/src/localization/hi-IN.json +24 -4
- package/src/localization/hr-HR.json +24 -4
- package/src/localization/hu-HU.json +24 -4
- package/src/localization/id-ID.json +24 -4
- package/src/localization/it-IT.json +24 -4
- package/src/localization/ja-JP.json +24 -4
- package/src/localization/kk-KZ.json +24 -4
- package/src/localization/ko-KR.json +24 -4
- package/src/localization/lt-LT.json +24 -4
- package/src/localization/lv-LV.json +24 -4
- package/src/localization/mergeLocalizedStrings.ts +20 -0
- package/src/localization/ms-MY.json +24 -4
- package/src/localization/nb-NO.json +24 -4
- package/src/localization/nl-NL.json +24 -4
- package/src/localization/pl-PL.json +24 -4
- package/src/localization/pt-BR.json +24 -4
- package/src/localization/pt-PT.json +24 -4
- package/src/localization/ro-RO.json +24 -4
- package/src/localization/ru-RU.json +24 -4
- package/src/localization/sk-SK.json +24 -4
- package/src/localization/sl-SI.json +24 -4
- package/src/localization/sr-Cyrl-CS.json +24 -4
- package/src/localization/sr-Latn-CS.json +24 -4
- package/src/localization/sv-SE.json +24 -4
- package/src/localization/th-TH.json +24 -4
- package/src/localization/tr-TR.json +24 -4
- package/src/localization/uk-UA.json +24 -4
- package/src/localization/vi-VN.json +24 -4
- package/src/localization/yue.json +27 -7
- package/src/localization/zh-CN.json +24 -4
- package/src/localization/zh-HK.json +24 -4
- package/src/localization/zh-TW.json +24 -4
- package/src/normalizeStyleOptions.ts +113 -2
- package/src/patchStyleOptionsFromDeprecatedProps.js +0 -2
- package/src/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.tsx +180 -0
- package/src/providers/ActivityAcknowledgement/private/Context.ts +18 -0
- package/src/providers/ActivityAcknowledgement/private/types.ts +6 -0
- package/src/providers/ActivityAcknowledgement/private/useContext.ts +19 -0
- package/src/providers/ActivityAcknowledgement/useActivityKeysByRead.tsx +8 -0
- package/src/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.ts +5 -0
- package/src/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.ts +5 -0
- package/src/providers/ActivityAcknowledgement/useLastReadActivityKey.ts +5 -0
- package/src/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.ts +5 -0
- package/src/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.ts +5 -0
- package/src/providers/ActivityKeyer/ActivityKeyerComposer.tsx +151 -0
- package/src/providers/ActivityKeyer/private/Context.ts +14 -0
- package/src/providers/ActivityKeyer/private/getActivityId.ts +5 -0
- package/src/providers/ActivityKeyer/private/getClientActivityId.ts +5 -0
- package/src/providers/ActivityKeyer/private/uniqueId.ts +8 -0
- package/src/providers/ActivityKeyer/private/useContext.ts +15 -0
- package/src/providers/ActivityKeyer/useActivityKeys.ts +5 -0
- package/src/providers/ActivityKeyer/useGetActivityByKey.ts +7 -0
- package/src/providers/ActivityKeyer/useGetKeyByActivity.ts +7 -0
- package/src/providers/ActivityKeyer/useGetKeyByActivityId.ts +5 -0
- package/src/tsconfig.json +3 -1
- package/src/types/ActivityMiddleware.ts +38 -0
- package/src/types/ActivityStatusMiddleware.ts +28 -0
- package/src/types/AttachmentForScreenReaderMiddleware.ts +24 -0
- package/src/types/AttachmentMiddleware.ts +16 -0
- package/src/types/AvatarMiddleware.ts +20 -0
- package/src/types/CardActionMiddleware.ts +21 -0
- package/src/types/ComponentMiddleware.ts +42 -0
- package/src/types/FunctionMiddleware.ts +13 -0
- package/src/types/GroupActivitiesMiddleware.ts +24 -0
- package/src/types/LocalizedStrings.ts +5 -0
- package/src/types/Notification.ts +10 -0
- package/src/types/PrecompiledGlobalize.ts +9 -0
- package/src/types/ScrollToEndButtonMiddleware.ts +34 -0
- package/src/types/SendState.ts +3 -0
- package/src/types/TelemetryMeasurementEvent.ts +44 -0
- package/src/types/ToastMiddleware.ts +16 -0
- package/src/types/Typing.ts +8 -0
- package/src/types/TypingIndicatorMiddleware.ts +18 -0
- package/src/types/WebSpeechPonyfill.ts +24 -0
- package/src/types/WebSpeechPonyfillFactory.ts +5 -0
- package/src/utils/createCustomEvent.ts +28 -0
- package/src/utils/findLastIndex.spec.js +31 -0
- package/src/utils/findLastIndex.ts +11 -0
- package/src/utils/findMin.spec.js +2 -0
- package/src/utils/{findMin.js → findMin.ts} +3 -3
- package/src/utils/mapMap.spec.js +2 -0
- package/src/utils/mapMap.ts +16 -0
- package/src/utils/{normalizeLanguage.js → normalizeLanguage.ts} +1 -1
- package/src/utils/{randomId.js → randomId.ts} +1 -1
- package/src/utils/warnOnce.ts +10 -0
- package/.eslintignore +0 -9
- package/lib/hooks/utils/singleToArray.js +0 -11
- package/scripts/createPrecompiledGlobalize.js +0 -41
- package/src/hooks/internal/useCreateActivityRendererInternal.js +0 -41
- package/src/hooks/middleware/concatMiddleware.js +0 -19
- package/src/hooks/middleware/createDefaultCardActionMiddleware.js +0 -36
- package/src/hooks/useActivities.js +0 -5
- package/src/hooks/useCreateAvatarRenderer.js +0 -32
- package/src/hooks/useDateFormatter.js +0 -13
- package/src/hooks/useGetSendTimeoutForActivity.js +0 -18
- package/src/hooks/useGroupActivities.js +0 -5
- package/src/hooks/usePerformCardAction.js +0 -5
- package/src/hooks/usePostActivity.js +0 -5
- package/src/hooks/useRenderTypingIndicator.js +0 -5
- package/src/hooks/useSendMessage.js +0 -5
- package/src/hooks/useSetNotification.js +0 -5
- package/src/hooks/useStyleOptions.js +0 -5
- package/src/hooks/useTimeoutForSend.js +0 -7
- package/src/hooks/utils/singleToArray.js +0 -3
- package/src/index.js +0 -10
- package/src/index.tsx +0 -10
- package/src/localization/mergeLocalizedStrings.js +0 -10
- package/src/utils/createCustomEvent.js +0 -17
- package/src/utils/mapMap.js +0 -7
|
@@ -1,8 +1,73 @@
|
|
|
1
1
|
import { createContext } from 'react';
|
|
2
|
+
import { DirectLineActivity, DirectLineJSBotConnection } from 'botframework-webchat-core';
|
|
2
3
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
}
|
|
4
|
+
import { AttachmentForScreenReaderComponentFactory } from '../../types/AttachmentForScreenReaderMiddleware';
|
|
5
|
+
import { AvatarComponentFactory } from '../../types/AvatarMiddleware';
|
|
6
|
+
import { GroupActivities } from '../../types/GroupActivitiesMiddleware';
|
|
7
|
+
import { LegacyActivityRenderer } from '../../types/ActivityMiddleware';
|
|
8
|
+
import { Observable } from 'redux';
|
|
9
|
+
import { PerformCardAction } from '../../types/CardActionMiddleware';
|
|
10
|
+
import { RenderActivityStatus } from '../../types/ActivityStatusMiddleware';
|
|
11
|
+
import { RenderAttachment } from '../../types/AttachmentMiddleware';
|
|
12
|
+
import { RenderToast } from '../../types/ToastMiddleware';
|
|
13
|
+
import { ScrollToEndButtonComponentFactory } from '../../types/ScrollToEndButtonMiddleware';
|
|
14
|
+
import { StrictStyleOptions } from '../../StyleOptions';
|
|
15
|
+
import LocalizedStrings from '../../types/LocalizedStrings';
|
|
16
|
+
import PrecompiledGlobalize from '../../types/PrecompiledGlobalize';
|
|
17
|
+
import TelemetryMeasurementEvent from '../../types/TelemetryMeasurementEvent';
|
|
18
|
+
|
|
19
|
+
type WebChatAPIContext = {
|
|
20
|
+
activityRenderer?: LegacyActivityRenderer;
|
|
21
|
+
activityStatusRenderer?: RenderActivityStatus;
|
|
22
|
+
attachmentForScreenReaderRenderer?: AttachmentForScreenReaderComponentFactory;
|
|
23
|
+
attachmentRenderer?: RenderAttachment;
|
|
24
|
+
avatarRenderer?: AvatarComponentFactory;
|
|
25
|
+
clearSuggestedActions?: () => void;
|
|
26
|
+
dir?: string;
|
|
27
|
+
directLine?: DirectLineJSBotConnection;
|
|
28
|
+
disabled?: boolean;
|
|
29
|
+
dismissNotification?: (id: string) => void;
|
|
30
|
+
downscaleImageToDataURL?: (blob: Blob, maxWidth: number, maxHeight: number, type: string, quality: number) => string;
|
|
31
|
+
emitTypingIndicator?: () => void;
|
|
32
|
+
grammars?: any;
|
|
33
|
+
groupActivities?: GroupActivities;
|
|
34
|
+
internalErrorBoxClass?: React.Component | Function;
|
|
35
|
+
language?: string;
|
|
36
|
+
localizedGlobalizeState?: PrecompiledGlobalize[];
|
|
37
|
+
localizedStrings?: { [language: string]: LocalizedStrings };
|
|
38
|
+
markActivity?: ({ id: string }, name: string, value?: any) => void;
|
|
39
|
+
onCardAction?: PerformCardAction;
|
|
40
|
+
onTelemetry?: (event: TelemetryMeasurementEvent) => void;
|
|
41
|
+
postActivity?: (activity: DirectLineActivity) => Observable<string>;
|
|
42
|
+
renderMarkdown?: (markdown: string, { markdownRespectCRLF: boolean }, { externalLinkAlt: string }) => string;
|
|
43
|
+
scrollToEndButtonRenderer?: ScrollToEndButtonComponentFactory;
|
|
44
|
+
selectVoice?: (voices: typeof window.SpeechSynthesisVoice[], activity: DirectLineActivity) => void;
|
|
45
|
+
sendEvent?: (name: string, value: any) => void;
|
|
46
|
+
sendFiles?: (files: File[]) => void;
|
|
47
|
+
sendMessage?: (text: string, method?: string, { channelData }?: { channelData?: any }) => void;
|
|
48
|
+
sendMessageBack?: (value: any, text?: string, displayText?: string) => void;
|
|
49
|
+
sendPostBack?: (value?: any) => void;
|
|
50
|
+
sendTypingIndicator?: boolean;
|
|
51
|
+
setDictateInterims?: (interims: string[]) => void;
|
|
52
|
+
setDictateState?: (dictateState: number) => void;
|
|
53
|
+
setNotification?: (notification: Notification) => void;
|
|
54
|
+
setSendBox?: (value: string) => void;
|
|
55
|
+
setSendTimeout?: (timeout: number) => void;
|
|
56
|
+
startDictate?: () => void;
|
|
57
|
+
startSpeakingActivity?: () => void;
|
|
58
|
+
stopDictate?: () => void;
|
|
59
|
+
stopSpeakingActivity?: () => void;
|
|
60
|
+
styleOptions?: StrictStyleOptions;
|
|
61
|
+
submitSendBox?: (method?: string, { channelData }?: { channelData: any }) => void;
|
|
62
|
+
telemetryDimensionsRef?: React.Ref<any>;
|
|
63
|
+
toastRenderer?: RenderToast;
|
|
64
|
+
trackDimension?: (name: string, data: any) => void;
|
|
65
|
+
typingIndicatorRenderer?: any; // TODO
|
|
66
|
+
userID?: string;
|
|
67
|
+
username?: string;
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
const context = createContext<WebChatAPIContext>(undefined);
|
|
6
71
|
|
|
7
72
|
context.displayName = 'WebChatAPIContext';
|
|
8
73
|
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { isValidElement, useMemo } from 'react';
|
|
2
|
+
|
|
3
|
+
import { ActivityComponentFactory } from '../../types/ActivityMiddleware';
|
|
4
|
+
import { RenderAttachment } from '../../types/AttachmentMiddleware';
|
|
5
|
+
import useRenderAttachment from '../useRenderAttachment';
|
|
6
|
+
import useWebChatAPIContext from './useWebChatAPIContext';
|
|
7
|
+
|
|
8
|
+
export default function useCreateActivityRendererInternal(
|
|
9
|
+
renderAttachmentOverride?: RenderAttachment
|
|
10
|
+
): ActivityComponentFactory {
|
|
11
|
+
const { activityRenderer: createActivityRenderer } = useWebChatAPIContext();
|
|
12
|
+
const defaultRenderAttachment = useRenderAttachment();
|
|
13
|
+
|
|
14
|
+
const renderAttachment: RenderAttachment = renderAttachmentOverride || defaultRenderAttachment;
|
|
15
|
+
|
|
16
|
+
return useMemo(
|
|
17
|
+
() =>
|
|
18
|
+
(...createActivityRendererOptions) => {
|
|
19
|
+
const renderActivity = createActivityRenderer(...createActivityRendererOptions);
|
|
20
|
+
|
|
21
|
+
if (!renderActivity) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
return renderActivityOptions => {
|
|
26
|
+
if (isValidElement(renderActivity)) {
|
|
27
|
+
return renderActivity;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const activityElement = renderActivity(
|
|
31
|
+
(...renderAttachmentArgs) => renderAttachment(...renderAttachmentArgs),
|
|
32
|
+
renderActivityOptions
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
// "activityElement" cannot be false. If the middleware want to hide the "activityElement", it should return "false" when we call createActivityRenderer().
|
|
36
|
+
activityElement ||
|
|
37
|
+
console.warn(
|
|
38
|
+
'botframework-webchat: To hide an activity, the activity renderer should return false. It should not return a function that will return false when called.'
|
|
39
|
+
);
|
|
40
|
+
|
|
41
|
+
return activityElement;
|
|
42
|
+
};
|
|
43
|
+
},
|
|
44
|
+
[createActivityRenderer, renderAttachment]
|
|
45
|
+
);
|
|
46
|
+
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
/* eslint no-console: "off" */
|
|
2
2
|
|
|
3
|
+
import { isForbiddenPropertyNames } from 'botframework-webchat-core';
|
|
3
4
|
import { useRef } from 'react';
|
|
4
5
|
|
|
5
6
|
export default function useDebugDeps(depsMap, name) {
|
|
@@ -7,13 +8,19 @@ export default function useDebugDeps(depsMap, name) {
|
|
|
7
8
|
|
|
8
9
|
const { current: lastDepsMap } = lastDepsMapRef;
|
|
9
10
|
const keys = new Set([...Object.keys(depsMap), ...Object.keys(lastDepsMap)]);
|
|
10
|
-
const keysChanged = Array.from(keys).filter(
|
|
11
|
+
const keysChanged = Array.from(keys).filter(
|
|
12
|
+
// Mitigation through denylisting.
|
|
13
|
+
// eslint-disable-next-line security/detect-object-injection
|
|
14
|
+
key => !isForbiddenPropertyNames(key) && !Object.is(depsMap[key], lastDepsMap[key])
|
|
15
|
+
);
|
|
11
16
|
|
|
12
17
|
if (keysChanged.length) {
|
|
13
18
|
console.groupCollapsed(`Changes found in ${name}`);
|
|
14
19
|
|
|
15
20
|
keysChanged.forEach(key => {
|
|
16
|
-
|
|
21
|
+
// Mitigation through denylisting.
|
|
22
|
+
// eslint-disable-next-line security/detect-object-injection
|
|
23
|
+
isForbiddenPropertyNames(key) || console.log(key, { from: lastDepsMap[key], to: depsMap[key] });
|
|
17
24
|
});
|
|
18
25
|
|
|
19
26
|
console.groupEnd();
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { RefObject, useMemo, useRef } from 'react';
|
|
2
|
+
|
|
3
|
+
export default function useValueRef<T>(value: T): RefObject<T> {
|
|
4
|
+
const ref = useRef<T>();
|
|
5
|
+
const readOnlyRef = useMemo(
|
|
6
|
+
() =>
|
|
7
|
+
Object.create(
|
|
8
|
+
{},
|
|
9
|
+
{
|
|
10
|
+
current: {
|
|
11
|
+
get: () => ref.current
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
),
|
|
15
|
+
[]
|
|
16
|
+
);
|
|
17
|
+
|
|
18
|
+
ref.current = value;
|
|
19
|
+
|
|
20
|
+
return readOnlyRef;
|
|
21
|
+
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import React, { isValidElement } from 'react';
|
|
2
|
-
|
|
3
|
-
import concatMiddleware from './concatMiddleware';
|
|
4
2
|
import ErrorBox from '../internal/ErrorBox';
|
|
3
|
+
import concatMiddleware from './concatMiddleware';
|
|
5
4
|
import UserlandBoundary from './UserlandBoundary';
|
|
6
5
|
|
|
7
6
|
export default function applyMiddleware(type, ...middleware) {
|
|
@@ -35,7 +34,7 @@ export function forLegacyRenderer(type, ...middleware) {
|
|
|
35
34
|
*
|
|
36
35
|
* @param {string} type Required. String equivalent of type of container to be rendered.
|
|
37
36
|
* @param { strict = false } - Used to enforce new middleware format which cooperates with new activity grouping.
|
|
38
|
-
* @see See {@link https://github.com/microsoft/BotFramework-WebChat/blob/
|
|
37
|
+
* @see See {@link https://github.com/microsoft/BotFramework-WebChat/blob/main/CHANGELOG.md#4100---2020-08-18} and {@link https://github.com/microsoft/BotFramework-WebChat/pull/3365} for middleware breaking changes.
|
|
39
38
|
* @param {middleware[]} middleware list of middleware to be applied.
|
|
40
39
|
* 'createRendererArgs' is "what to render"; for example, an activity.
|
|
41
40
|
* @returns Returns a function if there is a renderer *committed* to render OR returns false if nothing should be rendered.
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
/* eslint no-magic-numbers: "off" */
|
|
2
|
+
|
|
1
3
|
import concatMiddleware from './concatMiddleware';
|
|
2
4
|
|
|
3
5
|
describe('two middleware concatenated and ran', () => {
|
|
@@ -26,9 +28,7 @@ describe('two middleware concatenated and ran', () => {
|
|
|
26
28
|
});
|
|
27
29
|
|
|
28
30
|
test('by a single upstream middleware', () => {
|
|
29
|
-
const combine = () => next => value =>
|
|
30
|
-
return next(value) + next(value + 1);
|
|
31
|
-
};
|
|
31
|
+
const combine = () => next => value => next(value) + next(value + 1);
|
|
32
32
|
|
|
33
33
|
const middleware = concatMiddleware(combine, oddMultiplyByTen, evenMultiplyByHundred);
|
|
34
34
|
const work = middleware()(value => value);
|
|
@@ -38,9 +38,7 @@ describe('two middleware concatenated and ran', () => {
|
|
|
38
38
|
});
|
|
39
39
|
|
|
40
40
|
test('one middleware ran twice by a single upstream middleware', () => {
|
|
41
|
-
const combine = () => next => value =>
|
|
42
|
-
return next(value) + next(value + 1);
|
|
43
|
-
};
|
|
41
|
+
const combine = () => next => value => next(value) + next(value + 1);
|
|
44
42
|
|
|
45
43
|
const oddMultiplyByTenAndEvenMultiplyByHundred = () => () => value => {
|
|
46
44
|
if (value % 2) {
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
type Work<T> = (...args: any[]) => T;
|
|
2
|
+
type Enhancer<T> = (next: Work<T>) => Work<T>;
|
|
3
|
+
type Middleware<Setup, Result> = (setup: Setup) => Enhancer<Result>;
|
|
4
|
+
|
|
5
|
+
export default function concatMiddleware<Setup, Result>(
|
|
6
|
+
...middleware: Middleware<Setup, Result>[]
|
|
7
|
+
): Middleware<Setup, Result> {
|
|
8
|
+
return setupArgs => {
|
|
9
|
+
const setup = middleware.reduce(
|
|
10
|
+
(setup, middleware) => (middleware ? [...setup, middleware(setupArgs)] : setup),
|
|
11
|
+
[]
|
|
12
|
+
);
|
|
13
|
+
|
|
14
|
+
return last => {
|
|
15
|
+
const stack = setup.slice();
|
|
16
|
+
const work =
|
|
17
|
+
(index: number) =>
|
|
18
|
+
(...runArgs) => {
|
|
19
|
+
const next = stack[+index];
|
|
20
|
+
|
|
21
|
+
return (next ? next(work(index + 1)) : last)(...runArgs);
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
return work(0);
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { sendMessage, sendMessageBack, sendPostBack } from 'botframework-webchat-core';
|
|
2
|
+
|
|
3
|
+
import CardActionMiddleware from '../../types/CardActionMiddleware';
|
|
4
|
+
|
|
5
|
+
export default function createDefaultCardActionMiddleware(): CardActionMiddleware {
|
|
6
|
+
return ({ dispatch }) =>
|
|
7
|
+
next =>
|
|
8
|
+
(...args) => {
|
|
9
|
+
const [
|
|
10
|
+
{
|
|
11
|
+
cardAction,
|
|
12
|
+
cardAction: { value }
|
|
13
|
+
}
|
|
14
|
+
] = args;
|
|
15
|
+
|
|
16
|
+
// We cannot use destructured "type" here because TypeScript don't recognize "messageBack" is "MessageBackCardAction".
|
|
17
|
+
switch (cardAction.type) {
|
|
18
|
+
case 'imBack':
|
|
19
|
+
if (typeof value === 'string') {
|
|
20
|
+
// TODO: [P4] Instead of calling dispatch, we should move to dispatchers instead for completeness
|
|
21
|
+
dispatch(sendMessage(value, 'imBack'));
|
|
22
|
+
} else {
|
|
23
|
+
throw new Error('cannot send "imBack" with a non-string value');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
break;
|
|
27
|
+
|
|
28
|
+
case 'messageBack':
|
|
29
|
+
dispatch(sendMessageBack(value, cardAction.text, cardAction.displayText));
|
|
30
|
+
|
|
31
|
+
break;
|
|
32
|
+
|
|
33
|
+
case 'postBack':
|
|
34
|
+
dispatch(sendPostBack(value));
|
|
35
|
+
|
|
36
|
+
break;
|
|
37
|
+
|
|
38
|
+
default:
|
|
39
|
+
return next(...args);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
}
|
|
@@ -1,13 +1,15 @@
|
|
|
1
|
-
import { Constants } from 'botframework-webchat-core';
|
|
1
|
+
import { Constants, DirectLineActivity } from 'botframework-webchat-core';
|
|
2
|
+
|
|
3
|
+
import GroupActivitiesMiddleware from '../../types/GroupActivitiesMiddleware';
|
|
2
4
|
|
|
3
5
|
const {
|
|
4
6
|
ActivityClientState: { SENT }
|
|
5
7
|
} = Constants;
|
|
6
8
|
|
|
7
|
-
function bin(items, grouping) {
|
|
8
|
-
let lastBin;
|
|
9
|
-
const bins = [];
|
|
10
|
-
let lastItem;
|
|
9
|
+
function bin<T>(items: T[], grouping: (last: T, current: T) => boolean): T[][] {
|
|
10
|
+
let lastBin: T[];
|
|
11
|
+
const bins: T[][] = [];
|
|
12
|
+
let lastItem: T;
|
|
11
13
|
|
|
12
14
|
items.forEach(item => {
|
|
13
15
|
if (lastItem && grouping(lastItem, item)) {
|
|
@@ -23,11 +25,15 @@ function bin(items, grouping) {
|
|
|
23
25
|
return bins;
|
|
24
26
|
}
|
|
25
27
|
|
|
26
|
-
function sending(activity) {
|
|
28
|
+
function sending(activity: DirectLineActivity): boolean {
|
|
27
29
|
return activity.from.role === 'user' && activity.channelData && activity.channelData.state !== SENT;
|
|
28
30
|
}
|
|
29
31
|
|
|
30
|
-
function shouldGroupTimestamp(
|
|
32
|
+
function shouldGroupTimestamp(
|
|
33
|
+
activityX: DirectLineActivity,
|
|
34
|
+
activityY: DirectLineActivity,
|
|
35
|
+
groupTimestamp: boolean | number
|
|
36
|
+
): boolean {
|
|
31
37
|
if (groupTimestamp === false) {
|
|
32
38
|
// Hide timestamp for all activities.
|
|
33
39
|
return true;
|
|
@@ -47,9 +53,11 @@ function shouldGroupTimestamp(activityX, activityY, groupTimestamp) {
|
|
|
47
53
|
return false;
|
|
48
54
|
}
|
|
49
55
|
|
|
50
|
-
export default function createDefaultGroupActivityMiddleware({ groupTimestamp }) {
|
|
51
|
-
return () =>
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
56
|
+
export default function createDefaultGroupActivityMiddleware({ groupTimestamp }): GroupActivitiesMiddleware {
|
|
57
|
+
return () =>
|
|
58
|
+
() =>
|
|
59
|
+
({ activities }) => ({
|
|
60
|
+
sender: bin(activities, (x, y) => x.from.role === y.from.role),
|
|
61
|
+
status: bin(activities, (x, y) => shouldGroupTimestamp(x, y, groupTimestamp))
|
|
62
|
+
});
|
|
55
63
|
}
|
|
@@ -1,29 +1,33 @@
|
|
|
1
1
|
import { useEffect } from 'react';
|
|
2
2
|
|
|
3
3
|
import { useSelector } from './internal/WebChatReduxContext';
|
|
4
|
+
import Typing from '../types/Typing';
|
|
4
5
|
import useForceRender from './internal/useForceRender';
|
|
5
6
|
import useStyleOptions from './useStyleOptions';
|
|
6
7
|
|
|
7
|
-
function useActiveTyping(expireAfter) {
|
|
8
|
+
function useActiveTyping(expireAfter?: number): [{ [userId: string]: Typing }] {
|
|
8
9
|
const now = Date.now();
|
|
9
10
|
|
|
10
11
|
const [{ typingAnimationDuration }] = useStyleOptions();
|
|
11
12
|
const forceRender = useForceRender();
|
|
12
|
-
const typing = useSelector(({ typing }) => typing);
|
|
13
|
+
const typing: { [userId: string]: { at: number; name: string; role: string } } = useSelector(({ typing }) => typing);
|
|
13
14
|
|
|
14
15
|
if (typeof expireAfter !== 'number') {
|
|
15
16
|
expireAfter = typingAnimationDuration;
|
|
16
17
|
}
|
|
17
18
|
|
|
18
|
-
const activeTyping = Object.entries(typing).reduce(
|
|
19
|
-
|
|
19
|
+
const activeTyping: { [userId: string]: Typing } = Object.entries(typing).reduce(
|
|
20
|
+
(activeTyping, [id, { at, name, role }]) => {
|
|
21
|
+
const until = at + expireAfter;
|
|
20
22
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
23
|
+
if (until > now) {
|
|
24
|
+
return { ...activeTyping, [id]: { at, expireAt: until, name, role } };
|
|
25
|
+
}
|
|
24
26
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
+
return activeTyping;
|
|
28
|
+
},
|
|
29
|
+
{}
|
|
30
|
+
);
|
|
27
31
|
|
|
28
32
|
const earliestExpireAt = Math.min(...Object.values(activeTyping).map(({ expireAt }) => expireAt));
|
|
29
33
|
const timeToRender = earliestExpireAt && earliestExpireAt - now;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import useStyleOptions from './useStyleOptions';
|
|
2
2
|
|
|
3
|
-
export default function useAvatarForBot() {
|
|
3
|
+
export default function useAvatarForBot(): [{ image: string; initials: string }] {
|
|
4
4
|
const [{ botAvatarImage: image, botAvatarInitials: initials }] = useStyleOptions();
|
|
5
5
|
|
|
6
6
|
return [
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import useStyleOptions from './useStyleOptions';
|
|
2
2
|
|
|
3
|
-
export default function useAvatarForUser() {
|
|
3
|
+
export default function useAvatarForUser(): [{ image: string; initials: string }] {
|
|
4
4
|
const [{ userAvatarImage: image, userAvatarInitials: initials }] = useStyleOptions();
|
|
5
5
|
|
|
6
6
|
return [
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { ActivityComponentFactory } from '../types/ActivityMiddleware';
|
|
3
2
|
import useCreateActivityRendererInternal from './internal/useCreateActivityRendererInternal';
|
|
4
3
|
|
|
5
4
|
// The newer useCreateActivityRenderer() hook does not support override renderAttachment().
|
|
6
5
|
// Only the deprecated useRenderActivity() hook support overriding renderAttachment().
|
|
7
|
-
export default function useCreateActivityRenderer() {
|
|
6
|
+
export default function useCreateActivityRenderer(): ActivityComponentFactory {
|
|
8
7
|
return useCreateActivityRendererInternal();
|
|
9
8
|
}
|
package/src/hooks/{useCreateActivityStatusRenderer.js → useCreateActivityStatusRenderer.tsx}
RENAMED
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
/* eslint react/prop-types: "off"*/
|
|
1
|
+
/* eslint react/prop-types: "off" */
|
|
2
|
+
/* eslint react/require-default-props: "off" */
|
|
2
3
|
|
|
3
|
-
import { Constants } from 'botframework-webchat-core';
|
|
4
|
-
import React, { useMemo } from 'react';
|
|
4
|
+
import { Constants, DirectLineActivity } from 'botframework-webchat-core';
|
|
5
|
+
import React, { ReactNode, useMemo } from 'react';
|
|
5
6
|
|
|
7
|
+
import SendState from '../types/SendState';
|
|
6
8
|
import useGetSendTimeoutForActivity from './useGetSendTimeoutForActivity';
|
|
7
9
|
import useTimePassed from './internal/useTimePassed';
|
|
8
10
|
import useWebChatAPIContext from './internal/useWebChatAPIContext';
|
|
@@ -20,6 +22,14 @@ const ActivityStatusContainer = ({ activity, hideTimestamp, nextVisibleActivity
|
|
|
20
22
|
const {
|
|
21
23
|
channelData: { clientTimestamp = 0, state } = {},
|
|
22
24
|
from: { role }
|
|
25
|
+
}: {
|
|
26
|
+
channelData: {
|
|
27
|
+
clientTimestamp?: number;
|
|
28
|
+
state?: SendState;
|
|
29
|
+
};
|
|
30
|
+
from: {
|
|
31
|
+
role: string;
|
|
32
|
+
};
|
|
23
33
|
} = activity;
|
|
24
34
|
|
|
25
35
|
const activitySent = state !== SENDING && state !== SEND_FAILED;
|
|
@@ -43,15 +53,21 @@ const ActivityStatusContainer = ({ activity, hideTimestamp, nextVisibleActivity
|
|
|
43
53
|
);
|
|
44
54
|
};
|
|
45
55
|
|
|
46
|
-
export default function useCreateActivityStatusRenderer() {
|
|
56
|
+
export default function useCreateActivityStatusRenderer(): (renderOptions: {
|
|
57
|
+
activity: DirectLineActivity;
|
|
58
|
+
nextVisibleActivity: DirectLineActivity;
|
|
59
|
+
}) => (props: { hideTimestamp?: boolean }) => ReactNode {
|
|
47
60
|
return useMemo(
|
|
48
|
-
() =>
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
61
|
+
() =>
|
|
62
|
+
({ activity, nextVisibleActivity }: { activity: DirectLineActivity; nextVisibleActivity: DirectLineActivity }) =>
|
|
63
|
+
({ hideTimestamp }: { hideTimestamp?: boolean } = {}) =>
|
|
64
|
+
(
|
|
65
|
+
<ActivityStatusContainer
|
|
66
|
+
activity={activity}
|
|
67
|
+
hideTimestamp={hideTimestamp}
|
|
68
|
+
nextVisibleActivity={nextVisibleActivity}
|
|
69
|
+
/>
|
|
70
|
+
),
|
|
55
71
|
[]
|
|
56
72
|
);
|
|
57
73
|
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { DirectLineActivity } from 'botframework-webchat-core';
|
|
2
|
+
import { useMemo } from 'react';
|
|
3
|
+
|
|
4
|
+
import { AvatarComponentFactory } from '../types/AvatarMiddleware';
|
|
5
|
+
import useStyleOptions from './useStyleOptions';
|
|
6
|
+
import useWebChatAPIContext from './internal/useWebChatAPIContext';
|
|
7
|
+
|
|
8
|
+
export default function useCreateAvatarRenderer(): ({
|
|
9
|
+
activity
|
|
10
|
+
}: {
|
|
11
|
+
activity: DirectLineActivity;
|
|
12
|
+
}) => AvatarComponentFactory {
|
|
13
|
+
const [styleOptions] = useStyleOptions();
|
|
14
|
+
const { avatarRenderer } = useWebChatAPIContext();
|
|
15
|
+
|
|
16
|
+
return useMemo(
|
|
17
|
+
() =>
|
|
18
|
+
({ activity }) => {
|
|
19
|
+
const { from: { role } = {} }: { from?: { role?: string } } = activity;
|
|
20
|
+
|
|
21
|
+
const result = avatarRenderer({
|
|
22
|
+
activity,
|
|
23
|
+
fromUser: role === 'user',
|
|
24
|
+
styleOptions
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
if (result !== false && typeof result !== 'function') {
|
|
28
|
+
console.warn(
|
|
29
|
+
'botframework-webchat: avatarMiddleware should return a function to render the avatar, or return false if avatar should be hidden. Please refer to HOOKS.md for details.'
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
return () => result;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return result;
|
|
36
|
+
},
|
|
37
|
+
[avatarRenderer, styleOptions]
|
|
38
|
+
);
|
|
39
|
+
}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ScrollToEndButtonComponentFactory } from '../types/ScrollToEndButtonMiddleware';
|
|
2
|
+
import useWebChatAPIContext from './internal/useWebChatAPIContext';
|
|
3
|
+
|
|
4
|
+
export default function useCreateScrollToEndButtonRenderer(): ScrollToEndButtonComponentFactory {
|
|
5
|
+
return useWebChatAPIContext().scrollToEndButtonRenderer;
|
|
6
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
|
|
3
|
+
import useLocalizedGlobalize from './internal/useLocalizedGlobalize';
|
|
4
|
+
|
|
5
|
+
export default function useDateFormatter(): (date: number | Date) => string {
|
|
6
|
+
const [globalize] = useLocalizedGlobalize();
|
|
7
|
+
|
|
8
|
+
const formatDate = useMemo(
|
|
9
|
+
() => date => globalize.dateFormatter({ skeleton: 'MMMMdhm' })(new Date(date)),
|
|
10
|
+
[globalize]
|
|
11
|
+
);
|
|
12
|
+
|
|
13
|
+
return formatDate;
|
|
14
|
+
}
|
|
@@ -2,12 +2,20 @@ import { useRef } from 'react';
|
|
|
2
2
|
import updateIn from 'simple-update-in';
|
|
3
3
|
|
|
4
4
|
import findMin from '../utils/findMin';
|
|
5
|
+
import Notification from '../types/Notification';
|
|
5
6
|
import useForceRender from './internal/useForceRender';
|
|
6
7
|
import useNotifications from './useNotifications';
|
|
7
8
|
import useStyleOptions from './useStyleOptions';
|
|
8
9
|
import useTimer from './internal/useTimer';
|
|
9
10
|
|
|
10
|
-
|
|
11
|
+
type DebouncedNotification = Notification & {
|
|
12
|
+
outOfDate: boolean;
|
|
13
|
+
updateNotBefore: number;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
type DebouncedNotifications = { [id: string]: DebouncedNotification };
|
|
17
|
+
|
|
18
|
+
function getEarliestUpdateNotBefore(notificationMap: DebouncedNotifications) {
|
|
11
19
|
return findMin(
|
|
12
20
|
Object.values(notificationMap)
|
|
13
21
|
.filter(({ outOfDate }) => outOfDate)
|
|
@@ -15,7 +23,7 @@ function getEarliestUpdateNotBefore(notificationMap) {
|
|
|
15
23
|
);
|
|
16
24
|
}
|
|
17
25
|
|
|
18
|
-
function useDebouncedNotifications() {
|
|
26
|
+
function useDebouncedNotifications(): [DebouncedNotifications] {
|
|
19
27
|
const now = Date.now();
|
|
20
28
|
|
|
21
29
|
const [{ notificationDebounceTimeout }] = useStyleOptions();
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useSelector } from './internal/WebChatReduxContext';
|
|
2
2
|
import useWebChatAPIContext from './internal/useWebChatAPIContext';
|
|
3
3
|
|
|
4
|
-
export default function useDictateInterims() {
|
|
4
|
+
export default function useDictateInterims(): [string[], (interims: string[]) => void] {
|
|
5
5
|
return [useSelector(({ dictateInterims }) => dictateInterims) || [], useWebChatAPIContext().setDictateInterims];
|
|
6
6
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { useSelector } from './internal/WebChatReduxContext';
|
|
2
2
|
|
|
3
3
|
// TODO: [P3] We should update this code to use core/src/selectors/dictateState.js
|
|
4
|
-
export default function useDictateState() {
|
|
4
|
+
export default function useDictateState(): [number] {
|
|
5
5
|
return [useSelector(({ dictateState }) => dictateState)];
|
|
6
6
|
}
|