@azure/communication-react 1.31.0-beta.1 → 1.31.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.
Files changed (384) hide show
  1. package/dist/communication-react.d.ts +24 -1373
  2. package/dist/dist-cjs/communication-react/index.js +40378 -174
  3. package/dist/dist-cjs/communication-react/index.js.map +1 -1
  4. package/dist/dist-esm/acs-ui-common/src/common.d.ts +0 -13
  5. package/dist/dist-esm/acs-ui-common/src/common.js.map +1 -1
  6. package/dist/dist-esm/acs-ui-common/src/constants.d.ts +0 -5
  7. package/dist/dist-esm/acs-ui-common/src/constants.js +0 -5
  8. package/dist/dist-esm/acs-ui-common/src/constants.js.map +1 -1
  9. package/dist/dist-esm/acs-ui-common/src/index.d.ts +0 -4
  10. package/dist/dist-esm/acs-ui-common/src/index.js +0 -3
  11. package/dist/dist-esm/acs-ui-common/src/index.js.map +1 -1
  12. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js +1 -1
  13. package/dist/dist-esm/acs-ui-common/src/telemetryVersion.js.map +1 -1
  14. package/dist/dist-esm/calling-component-bindings/src/baseSelectors.js +0 -2
  15. package/dist/dist-esm/calling-component-bindings/src/baseSelectors.js.map +1 -1
  16. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.d.ts +0 -2
  17. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js +0 -6
  18. package/dist/dist-esm/calling-component-bindings/src/handlers/createCommonHandlers.js.map +1 -1
  19. package/dist/dist-esm/calling-component-bindings/src/handlers/createTeamsCallHandlers.js +1 -25
  20. package/dist/dist-esm/calling-component-bindings/src/handlers/createTeamsCallHandlers.js.map +1 -1
  21. package/dist/dist-esm/calling-component-bindings/src/participantListSelector.d.ts +0 -1
  22. package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js +1 -3
  23. package/dist/dist-esm/calling-component-bindings/src/participantListSelector.js.map +1 -1
  24. package/dist/dist-esm/calling-stateful-client/src/CallAgentDeclarativeCommon.js +0 -4
  25. package/dist/dist-esm/calling-stateful-client/src/CallAgentDeclarativeCommon.js.map +1 -1
  26. package/dist/dist-esm/calling-stateful-client/src/CallClientState.d.ts +2 -42
  27. package/dist/dist-esm/calling-stateful-client/src/CallClientState.js.map +1 -1
  28. package/dist/dist-esm/calling-stateful-client/src/CallContext.d.ts +0 -6
  29. package/dist/dist-esm/calling-stateful-client/src/CallContext.js +0 -35
  30. package/dist/dist-esm/calling-stateful-client/src/CallContext.js.map +1 -1
  31. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.d.ts +1 -5
  32. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js +12 -27
  33. package/dist/dist-esm/calling-stateful-client/src/CallSubscriber.js.map +1 -1
  34. package/dist/dist-esm/calling-stateful-client/src/Converter.js +0 -3
  35. package/dist/dist-esm/calling-stateful-client/src/Converter.js.map +1 -1
  36. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.d.ts +0 -1
  37. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.js +1 -7
  38. package/dist/dist-esm/calling-stateful-client/src/RecordingSubscriber.js.map +1 -1
  39. package/dist/dist-esm/calling-stateful-client/src/TeamsCallDeclarative.js +0 -17
  40. package/dist/dist-esm/calling-stateful-client/src/TeamsCallDeclarative.js.map +1 -1
  41. package/dist/dist-esm/calling-stateful-client/src/index-public.d.ts +0 -1
  42. package/dist/dist-esm/calling-stateful-client/src/index-public.js.map +1 -1
  43. package/dist/dist-esm/chat-component-bindings/src/handlers/createHandlers.d.ts +2 -6
  44. package/dist/dist-esm/chat-component-bindings/src/handlers/createHandlers.js +2 -36
  45. package/dist/dist-esm/chat-component-bindings/src/handlers/createHandlers.js.map +1 -1
  46. package/dist/dist-esm/chat-component-bindings/src/hooks/usePropsFor.d.ts +1 -2
  47. package/dist/dist-esm/chat-component-bindings/src/hooks/usePropsFor.js +0 -4
  48. package/dist/dist-esm/chat-component-bindings/src/hooks/usePropsFor.js.map +1 -1
  49. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js +2 -25
  50. package/dist/dist-esm/chat-component-bindings/src/messageThreadSelector.js.map +1 -1
  51. package/dist/dist-esm/chat-component-bindings/src/utils/updateMessagesWithAttached.js +3 -3
  52. package/dist/dist-esm/chat-component-bindings/src/utils/updateMessagesWithAttached.js.map +1 -1
  53. package/dist/dist-esm/chat-stateful-client/src/ChatClientState.d.ts +1 -15
  54. package/dist/dist-esm/chat-stateful-client/src/ChatClientState.js.map +1 -1
  55. package/dist/dist-esm/chat-stateful-client/src/EventSubscriber.js +1 -2
  56. package/dist/dist-esm/chat-stateful-client/src/EventSubscriber.js.map +1 -1
  57. package/dist/dist-esm/chat-stateful-client/src/index.d.ts +0 -1
  58. package/dist/dist-esm/chat-stateful-client/src/index.js.map +1 -1
  59. package/dist/dist-esm/communication-react/src/index.d.ts +0 -21
  60. package/dist/dist-esm/communication-react/src/index.js +0 -3
  61. package/dist/dist-esm/communication-react/src/index.js.map +1 -1
  62. package/dist/dist-esm/react-components/src/components/Attachment/AttachmentDownloadCards.d.ts +0 -2
  63. package/dist/dist-esm/react-components/src/components/Attachment/AttachmentDownloadCards.js +0 -1
  64. package/dist/dist-esm/react-components/src/components/Attachment/AttachmentDownloadCards.js.map +1 -1
  65. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentWrapper.d.ts +1 -13
  66. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentWrapper.js +3 -9
  67. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageComponentWrapper.js.map +1 -1
  68. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageContent.d.ts +0 -11
  69. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageContent.js +2 -32
  70. package/dist/dist-esm/react-components/src/components/ChatMessage/ChatMessageContent.js.map +1 -1
  71. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.d.ts +1 -8
  72. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js +5 -9
  73. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/ChatMessageComponentAsMessageBubble.js.map +1 -1
  74. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.d.ts +1 -2
  75. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js +4 -4
  76. package/dist/dist-esm/react-components/src/components/ChatMessage/MessageComponents/FluentChatMessageComponent.js.map +1 -1
  77. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBox.d.ts +1 -4
  78. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBox.js +6 -31
  79. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBox.js.map +1 -1
  80. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBoxPicker.d.ts +1 -15
  81. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBoxPicker.js +0 -9
  82. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsEditBoxPicker.js.map +1 -1
  83. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponent.d.ts +2 -23
  84. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponent.js +6 -17
  85. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponent.js.map +1 -1
  86. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.d.ts +1 -8
  87. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js +6 -10
  88. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMyMessageComponentAsMessageBubble.js.map +1 -1
  89. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js +5 -5
  90. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/FluentChatMyMessageComponent.js.map +1 -1
  91. package/dist/dist-esm/react-components/src/components/ImageOverlay.js +0 -2
  92. package/dist/dist-esm/react-components/src/components/ImageOverlay.js.map +1 -1
  93. package/dist/dist-esm/react-components/src/components/InputBoxComponent.d.ts +0 -2
  94. package/dist/dist-esm/react-components/src/components/InputBoxComponent.js +0 -15
  95. package/dist/dist-esm/react-components/src/components/InputBoxComponent.js.map +1 -1
  96. package/dist/dist-esm/react-components/src/components/MessageThread.d.ts +5 -81
  97. package/dist/dist-esm/react-components/src/components/MessageThread.js +3 -13
  98. package/dist/dist-esm/react-components/src/components/MessageThread.js.map +1 -1
  99. package/dist/dist-esm/react-components/src/components/ParticipantList.d.ts +0 -15
  100. package/dist/dist-esm/react-components/src/components/ParticipantList.js +3 -12
  101. package/dist/dist-esm/react-components/src/components/ParticipantList.js.map +1 -1
  102. package/dist/dist-esm/react-components/src/components/SendBox.d.ts +1 -51
  103. package/dist/dist-esm/react-components/src/components/SendBox.js +6 -58
  104. package/dist/dist-esm/react-components/src/components/SendBox.js.map +1 -1
  105. package/dist/dist-esm/react-components/src/components/index.d.ts +0 -21
  106. package/dist/dist-esm/react-components/src/components/index.js +0 -8
  107. package/dist/dist-esm/react-components/src/components/index.js.map +1 -1
  108. package/dist/dist-esm/react-components/src/components/styles/AttachmentCard.styles.d.ts +1 -1
  109. package/dist/dist-esm/react-components/src/components/styles/AttachmentCardGroup.styles.d.ts +1 -1
  110. package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.d.ts +3 -3
  111. package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.js +0 -8
  112. package/dist/dist-esm/react-components/src/components/styles/MessageThread.styles.js.map +1 -1
  113. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.d.ts +1 -38
  114. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js +3 -30
  115. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentAsEditBoxUtils.js.map +1 -1
  116. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.d.ts +2 -4
  117. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js +2 -9
  118. package/dist/dist-esm/react-components/src/components/utils/ChatMessageComponentUtils.js.map +1 -1
  119. package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.d.ts +1 -47
  120. package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js +4 -154
  121. package/dist/dist-esm/react-components/src/components/utils/SendBoxUtils.js.map +1 -1
  122. package/dist/dist-esm/react-components/src/components/utils/common.js +0 -2
  123. package/dist/dist-esm/react-components/src/components/utils/common.js.map +1 -1
  124. package/dist/dist-esm/react-components/src/components/utils/getParticipantsWhoHaveReadMessage.d.ts +1 -2
  125. package/dist/dist-esm/react-components/src/components/utils/getParticipantsWhoHaveReadMessage.js.map +1 -1
  126. package/dist/dist-esm/react-components/src/identifiers/IdentifierProvider.d.ts +0 -4
  127. package/dist/dist-esm/react-components/src/identifiers/IdentifierProvider.js +1 -3
  128. package/dist/dist-esm/react-components/src/identifiers/IdentifierProvider.js.map +1 -1
  129. package/dist/dist-esm/react-components/src/index.d.ts +0 -1
  130. package/dist/dist-esm/react-components/src/index.js.map +1 -1
  131. package/dist/dist-esm/react-components/src/localization/LocalizationProvider.d.ts +0 -45
  132. package/dist/dist-esm/react-components/src/localization/LocalizationProvider.js.map +1 -1
  133. package/dist/dist-esm/react-components/src/localization/locales/ja-JP/strings.json +2 -2
  134. package/dist/dist-esm/react-components/src/theming/icons.d.ts +0 -24
  135. package/dist/dist-esm/react-components/src/theming/icons.js +0 -67
  136. package/dist/dist-esm/react-components/src/theming/icons.js.map +1 -1
  137. package/dist/dist-esm/react-components/src/theming/themes.d.ts +0 -6
  138. package/dist/dist-esm/react-components/src/theming/themes.js +0 -9
  139. package/dist/dist-esm/react-components/src/theming/themes.js.map +1 -1
  140. package/dist/dist-esm/react-components/src/types/Attachment.d.ts +0 -13
  141. package/dist/dist-esm/react-components/src/types/Attachment.js.map +1 -1
  142. package/dist/dist-esm/react-components/src/types/ChatMessage.d.ts +1 -20
  143. package/dist/dist-esm/react-components/src/types/ChatMessage.js.map +1 -1
  144. package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.d.ts +0 -59
  145. package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.js +10 -15
  146. package/dist/dist-esm/react-composites/src/composites/CallComposite/CallComposite.js.map +1 -1
  147. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.d.ts +6 -38
  148. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js +1 -12
  149. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/AzureCommunicationCallAdapter.js.map +1 -1
  150. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/index.d.ts +0 -2
  151. package/dist/dist-esm/react-composites/src/composites/CallComposite/adapter/index.js.map +1 -1
  152. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageCameraDropdown.d.ts +0 -2
  153. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageCameraDropdown.js +0 -19
  154. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageCameraDropdown.js.map +1 -1
  155. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageErrorBar.js +2 -10
  156. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageErrorBar.js.map +1 -1
  157. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageMicDropdown.d.ts +0 -2
  158. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageMicDropdown.js +0 -19
  159. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/ConfigurationPageMicDropdown.js.map +1 -1
  160. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/LocalDeviceSettings.d.ts +0 -1
  161. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/LocalDeviceSettings.js +3 -5
  162. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/LocalDeviceSettings.js.map +1 -1
  163. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js +0 -3
  164. package/dist/dist-esm/react-composites/src/composites/CallComposite/hooks/useHandlers.js.map +1 -1
  165. package/dist/dist-esm/react-composites/src/composites/CallComposite/index.d.ts +0 -3
  166. package/dist/dist-esm/react-composites/src/composites/CallComposite/index.js.map +1 -1
  167. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/CallPage.js +2 -2
  168. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/CallPage.js.map +1 -1
  169. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/ConfigurationPage.d.ts +0 -7
  170. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/ConfigurationPage.js +5 -43
  171. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/ConfigurationPage.js.map +1 -1
  172. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/HoldPage.js +2 -2
  173. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/HoldPage.js.map +1 -1
  174. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/LobbyPage.js +2 -2
  175. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/LobbyPage.js.map +1 -1
  176. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/TransferPage.js +2 -2
  177. package/dist/dist-esm/react-composites/src/composites/CallComposite/pages/TransferPage.js.map +1 -1
  178. package/dist/dist-esm/react-composites/src/composites/CallComposite/utils/Utils.d.ts +0 -8
  179. package/dist/dist-esm/react-composites/src/composites/CallComposite/utils/Utils.js +0 -68
  180. package/dist/dist-esm/react-composites/src/composites/CallComposite/utils/Utils.js.map +1 -1
  181. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.d.ts +0 -52
  182. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js +4 -10
  183. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/CallWithChatComposite.js.map +1 -1
  184. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.d.ts +3 -10
  185. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js +2 -20
  186. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/AzureCommunicationCallWithChatAdapter.js.map +1 -1
  187. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.d.ts +2 -16
  188. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatAdapter.js.map +1 -1
  189. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.d.ts +4 -10
  190. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js +2 -14
  191. package/dist/dist-esm/react-composites/src/composites/CallWithChatComposite/adapter/CallWithChatBackedChatAdapter.js.map +1 -1
  192. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.d.ts +0 -27
  193. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js +1 -2
  194. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatComposite.js.map +1 -1
  195. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.d.ts +0 -2
  196. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js +11 -189
  197. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreen.js.map +1 -1
  198. package/dist/dist-esm/react-composites/src/composites/ChatComposite/Strings.d.ts +0 -20
  199. package/dist/dist-esm/react-composites/src/composites/ChatComposite/Strings.js.map +1 -1
  200. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.d.ts +2 -6
  201. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js +0 -36
  202. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/AzureCommunicationChatAdapter.js.map +1 -1
  203. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapter.d.ts +2 -12
  204. package/dist/dist-esm/react-composites/src/composites/ChatComposite/adapter/ChatAdapter.js.map +1 -1
  205. package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js +2 -13
  206. package/dist/dist-esm/react-composites/src/composites/ChatComposite/hooks/useHandlers.js.map +1 -1
  207. package/dist/dist-esm/react-composites/src/composites/ChatComposite/index.d.ts +0 -2
  208. package/dist/dist-esm/react-composites/src/composites/ChatComposite/index.js.map +1 -1
  209. package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.d.ts +0 -4
  210. package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js +0 -4
  211. package/dist/dist-esm/react-composites/src/composites/ChatComposite/selectors/baseSelectors.js.map +1 -1
  212. package/dist/dist-esm/react-composites/src/composites/common/ParticipantContainer.js +1 -2
  213. package/dist/dist-esm/react-composites/src/composites/common/ParticipantContainer.js.map +1 -1
  214. package/dist/dist-esm/react-composites/src/composites/common/SendBoxPicker.d.ts +2 -41
  215. package/dist/dist-esm/react-composites/src/composites/common/SendBoxPicker.js +0 -21
  216. package/dist/dist-esm/react-composites/src/composites/common/SendBoxPicker.js.map +1 -1
  217. package/dist/dist-esm/react-composites/src/composites/common/constants.d.ts +0 -5
  218. package/dist/dist-esm/react-composites/src/composites/common/constants.js +0 -5
  219. package/dist/dist-esm/react-composites/src/composites/common/constants.js.map +1 -1
  220. package/dist/dist-esm/react-composites/src/composites/common/icons.d.ts +1 -26
  221. package/dist/dist-esm/react-composites/src/composites/common/icons.js +0 -2
  222. package/dist/dist-esm/react-composites/src/composites/common/icons.js.map +1 -1
  223. package/dist/dist-esm/react-composites/src/composites/localization/locales/ja-JP/strings.json +1 -1
  224. package/dist/tsdoc-metadata.json +1 -1
  225. package/package.json +5 -5
  226. package/dist/dist-cjs/communication-react/ChatMessageComponentAsRichTextEditBox-DdSFdo_m.js +0 -213
  227. package/dist/dist-cjs/communication-react/ChatMessageComponentAsRichTextEditBox-DdSFdo_m.js.map +0 -1
  228. package/dist/dist-cjs/communication-react/RichTextSendBoxWrapper-C2HrwCVY.js +0 -49
  229. package/dist/dist-cjs/communication-react/RichTextSendBoxWrapper-C2HrwCVY.js.map +0 -1
  230. package/dist/dist-cjs/communication-react/index-CH39vOsT.js +0 -46344
  231. package/dist/dist-cjs/communication-react/index-CH39vOsT.js.map +0 -1
  232. package/dist/dist-esm/acs-ui-common/src/dataConversion.d.ts +0 -6
  233. package/dist/dist-esm/acs-ui-common/src/dataConversion.js +0 -20
  234. package/dist/dist-esm/acs-ui-common/src/dataConversion.js.map +0 -1
  235. package/dist/dist-esm/acs-ui-common/src/removeImageTags.d.ts +0 -7
  236. package/dist/dist-esm/acs-ui-common/src/removeImageTags.js +0 -18
  237. package/dist/dist-esm/acs-ui-common/src/removeImageTags.js.map +0 -1
  238. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.d.ts +0 -17
  239. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.js +0 -33
  240. package/dist/dist-esm/calling-stateful-client/src/LocalRecordingSubscriber.js.map +0 -1
  241. package/dist/dist-esm/chat-component-bindings/src/utils/getImageAttachmentsFromHTMLContent.d.ts +0 -6
  242. package/dist/dist-esm/chat-component-bindings/src/utils/getImageAttachmentsFromHTMLContent.js +0 -20
  243. package/dist/dist-esm/chat-component-bindings/src/utils/getImageAttachmentsFromHTMLContent.js.map +0 -1
  244. package/dist/dist-esm/react-components/src/components/ChatMessage/MentionRenderer.d.ts +0 -10
  245. package/dist/dist-esm/react-components/src/components/ChatMessage/MentionRenderer.js +0 -15
  246. package/dist/dist-esm/react-components/src/components/ChatMessage/MentionRenderer.js.map +0 -1
  247. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsRichTextEditBox.d.ts +0 -24
  248. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsRichTextEditBox.js +0 -203
  249. package/dist/dist-esm/react-components/src/components/ChatMessage/MyMessageComponents/ChatMessageComponentAsRichTextEditBox.js.map +0 -1
  250. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDenied.d.ts +0 -69
  251. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDenied.js +0 -36
  252. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDenied.js.map +0 -1
  253. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDeniedIOS.d.ts +0 -75
  254. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDeniedIOS.js +0 -67
  255. package/dist/dist-esm/react-components/src/components/DevicePermissions/BrowserPermissionDeniedIOS.js.map +0 -1
  256. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissions.d.ts +0 -105
  257. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissions.js +0 -51
  258. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissions.js.map +0 -1
  259. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissionsScaffolding.d.ts +0 -86
  260. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissionsScaffolding.js +0 -40
  261. package/dist/dist-esm/react-components/src/components/DevicePermissions/SitePermissionsScaffolding.js.map +0 -1
  262. package/dist/dist-esm/react-components/src/components/MentionPopover.d.ts +0 -121
  263. package/dist/dist-esm/react-components/src/components/MentionPopover.js +0 -119
  264. package/dist/dist-esm/react-components/src/components/MentionPopover.js.map +0 -1
  265. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/ContextMenuPlugin.d.ts +0 -9
  266. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/ContextMenuPlugin.js +0 -29
  267. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/ContextMenuPlugin.js.map +0 -1
  268. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/CopyPastePlugin.d.ts +0 -30
  269. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/CopyPastePlugin.js +0 -98
  270. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/CopyPastePlugin.js.map +0 -1
  271. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/KeyboardInputPlugin.d.ts +0 -19
  272. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/KeyboardInputPlugin.js +0 -43
  273. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/KeyboardInputPlugin.js.map +0 -1
  274. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/PlaceholderPlugin.d.ts +0 -15
  275. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/PlaceholderPlugin.js +0 -42
  276. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/PlaceholderPlugin.js.map +0 -1
  277. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/RichTextToolbarPlugin.d.ts +0 -24
  278. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/RichTextToolbarPlugin.js +0 -64
  279. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/RichTextToolbarPlugin.js.map +0 -1
  280. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/TableEditContextMenuProvider.d.ts +0 -20
  281. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/TableEditContextMenuProvider.js +0 -45
  282. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/TableEditContextMenuProvider.js.map +0 -1
  283. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UndoRedoPlugin.d.ts +0 -14
  284. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UndoRedoPlugin.js +0 -42
  285. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UndoRedoPlugin.js.map +0 -1
  286. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UpdateContentPlugin.d.ts +0 -30
  287. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UpdateContentPlugin.js +0 -99
  288. package/dist/dist-esm/react-components/src/components/RichTextEditor/Plugins/UpdateContentPlugin.js.map +0 -1
  289. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextEditor.d.ts +0 -59
  290. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextEditor.js +0 -334
  291. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextEditor.js.map +0 -1
  292. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.d.ts +0 -37
  293. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js +0 -78
  294. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextInputBoxComponent.js.map +0 -1
  295. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.d.ts +0 -215
  296. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js +0 -184
  297. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBox.js.map +0 -1
  298. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.d.ts +0 -16
  299. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js +0 -75
  300. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxErrors.js.map +0 -1
  301. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxUtils.d.ts +0 -9
  302. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxUtils.js +0 -16
  303. package/dist/dist-esm/react-components/src/components/RichTextEditor/RichTextSendBoxUtils.js.map +0 -1
  304. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/RichTextToolbar.d.ts +0 -19
  305. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/RichTextToolbar.js +0 -229
  306. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/RichTextToolbar.js.map +0 -1
  307. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTableCommandBarItem.d.ts +0 -7
  308. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTableCommandBarItem.js +0 -51
  309. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTableCommandBarItem.js.map +0 -1
  310. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTablePane.d.ts +0 -15
  311. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTablePane.js +0 -64
  312. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextInsertTablePane.js.map +0 -1
  313. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextToolbarTableIcon.d.ts +0 -6
  314. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextToolbarTableIcon.js +0 -13
  315. package/dist/dist-esm/react-components/src/components/RichTextEditor/Toolbar/Table/RichTextToolbarTableIcon.js.map +0 -1
  316. package/dist/dist-esm/react-components/src/components/SendBoxErrorBar.d.ts +0 -56
  317. package/dist/dist-esm/react-components/src/components/SendBoxErrorBar.js +0 -75
  318. package/dist/dist-esm/react-components/src/components/SendBoxErrorBar.js.map +0 -1
  319. package/dist/dist-esm/react-components/src/components/SendBoxErrors.d.ts +0 -14
  320. package/dist/dist-esm/react-components/src/components/SendBoxErrors.js +0 -18
  321. package/dist/dist-esm/react-components/src/components/SendBoxErrors.js.map +0 -1
  322. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/TextFieldWithMention.d.ts +0 -24
  323. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/TextFieldWithMention.js +0 -550
  324. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/TextFieldWithMention.js.map +0 -1
  325. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/mentionTagUtils.d.ts +0 -152
  326. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/mentionTagUtils.js +0 -819
  327. package/dist/dist-esm/react-components/src/components/TextFieldWithMention/mentionTagUtils.js.map +0 -1
  328. package/dist/dist-esm/react-components/src/components/styles/BrowserPermissionDenied.styles.d.ts +0 -58
  329. package/dist/dist-esm/react-components/src/components/styles/BrowserPermissionDenied.styles.js +0 -144
  330. package/dist/dist-esm/react-components/src/components/styles/BrowserPermissionDenied.styles.js.map +0 -1
  331. package/dist/dist-esm/react-components/src/components/styles/MentionPopover.style.d.ts +0 -26
  332. package/dist/dist-esm/react-components/src/components/styles/MentionPopover.style.js +0 -69
  333. package/dist/dist-esm/react-components/src/components/styles/MentionPopover.style.js.map +0 -1
  334. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.d.ts +0 -82
  335. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.js +0 -328
  336. package/dist/dist-esm/react-components/src/components/styles/RichTextEditor.styles.js.map +0 -1
  337. package/dist/dist-esm/react-components/src/components/styles/RichTextInputBoxComponent.styles.d.ts +0 -21
  338. package/dist/dist-esm/react-components/src/components/styles/RichTextInputBoxComponent.styles.js +0 -38
  339. package/dist/dist-esm/react-components/src/components/styles/RichTextInputBoxComponent.styles.js.map +0 -1
  340. package/dist/dist-esm/react-components/src/components/styles/SitePermissions.styles.d.ts +0 -38
  341. package/dist/dist-esm/react-components/src/components/styles/SitePermissions.styles.js +0 -99
  342. package/dist/dist-esm/react-components/src/components/styles/SitePermissions.styles.js.map +0 -1
  343. package/dist/dist-esm/react-components/src/components/styles/Stack.style.d.ts +0 -5
  344. package/dist/dist-esm/react-components/src/components/styles/Stack.style.js +0 -32
  345. package/dist/dist-esm/react-components/src/components/styles/Stack.style.js.map +0 -1
  346. package/dist/dist-esm/react-components/src/components/utils/RichTextEditorUtils.d.ts +0 -73
  347. package/dist/dist-esm/react-components/src/components/utils/RichTextEditorUtils.js +0 -178
  348. package/dist/dist-esm/react-components/src/components/utils/RichTextEditorUtils.js.map +0 -1
  349. package/dist/dist-esm/react-components/src/components/utils/RichTextTableUtils.d.ts +0 -33
  350. package/dist/dist-esm/react-components/src/components/utils/RichTextTableUtils.js +0 -119
  351. package/dist/dist-esm/react-components/src/components/utils/RichTextTableUtils.js.map +0 -1
  352. package/dist/dist-esm/react-components/src/components/utils/merge.d.ts +0 -7
  353. package/dist/dist-esm/react-components/src/components/utils/merge.js +0 -16
  354. package/dist/dist-esm/react-components/src/components/utils/merge.js.map +0 -1
  355. package/dist/dist-esm/react-components/src/theming/icons.styles.d.ts +0 -6
  356. package/dist/dist-esm/react-components/src/theming/icons.styles.js +0 -25
  357. package/dist/dist-esm/react-components/src/theming/icons.styles.js.map +0 -1
  358. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallReadinessModal.d.ts +0 -46
  359. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallReadinessModal.js +0 -200
  360. package/dist/dist-esm/react-composites/src/composites/CallComposite/components/CallReadinessModal.js.map +0 -1
  361. package/dist/dist-esm/react-composites/src/composites/ChatComposite/AttachmentDownloadErrorBar.d.ts +0 -15
  362. package/dist/dist-esm/react-composites/src/composites/ChatComposite/AttachmentDownloadErrorBar.js +0 -23
  363. package/dist/dist-esm/react-composites/src/composites/ChatComposite/AttachmentDownloadErrorBar.js.map +0 -1
  364. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreenPeoplePane.d.ts +0 -18
  365. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreenPeoplePane.js +0 -18
  366. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ChatScreenPeoplePane.js.map +0 -1
  367. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadReducer.d.ts +0 -49
  368. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadReducer.js +0 -44
  369. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadReducer.js.map +0 -1
  370. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadUtils.d.ts +0 -39
  371. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadUtils.js +0 -267
  372. package/dist/dist-esm/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadUtils.js.map +0 -1
  373. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUpload.d.ts +0 -80
  374. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUpload.js +0 -36
  375. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUpload.js.map +0 -1
  376. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUploadButton.d.ts +0 -38
  377. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUploadButton.js +0 -66
  378. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUploadButton.js.map +0 -1
  379. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/index.d.ts +0 -5
  380. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/index.js +0 -5
  381. package/dist/dist-esm/react-composites/src/composites/ChatComposite/file-sharing/index.js.map +0 -1
  382. package/dist/dist-esm/react-composites/src/composites/common/RichTextSendBoxWrapper.d.ts +0 -10
  383. package/dist/dist-esm/react-composites/src/composites/common/RichTextSendBoxWrapper.js +0 -16
  384. package/dist/dist-esm/react-composites/src/composites/common/RichTextSendBoxWrapper.js.map +0 -1
@@ -1,267 +0,0 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- // Copyright (c) Microsoft Corporation.
11
- // Licensed under the MIT License.
12
- import { _IMAGE_ATTRIBUTE_INLINE_IMAGE_FILE_NAME_KEY } from "../../../../../acs-ui-common/src";
13
- import { AttachmentUploadActionType } from '../file-sharing/AttachmentUpload';
14
- import { _DEFAULT_INLINE_IMAGE_FILE_NAME, SEND_BOX_UPLOADS_KEY_VALUE } from '../../common/constants';
15
- import { nanoid } from 'nanoid';
16
- const MAX_INLINE_IMAGE_UPLOAD_SIZE_MB = 20;
17
- const fetchBlobData = (resource, options) => __awaiter(void 0, void 0, void 0, function* () {
18
- // default timeout is 30 seconds
19
- const { timeout = 30000, abortController } = options;
20
- const id = setTimeout(() => {
21
- abortController.abort();
22
- }, timeout);
23
- const response = yield fetch(resource, Object.assign(Object.assign({}, options), { signal: abortController.signal }));
24
- clearTimeout(id);
25
- return response;
26
- });
27
- /**
28
- * @private
29
- */
30
- export const getInlineImageData = (image) => __awaiter(void 0, void 0, void 0, function* () {
31
- if (image.startsWith('blob') || image.startsWith('http')) {
32
- try {
33
- const res = yield fetchBlobData(image, {
34
- abortController: new AbortController()
35
- });
36
- const blobImage = yield res.blob();
37
- return blobImage;
38
- }
39
- catch (error) {
40
- console.error('Error fetching image data', error);
41
- return;
42
- }
43
- }
44
- return;
45
- });
46
- /**
47
- * @internal
48
- */
49
- export const getEditBoxMessagesInlineImages = (editBoxInlineImageUploads) => {
50
- if (!editBoxInlineImageUploads) {
51
- return;
52
- }
53
- const messagesInlineImagesWithProgress = {};
54
- Object.entries(editBoxInlineImageUploads || {}).map(([messageId, attachmentUploads]) => {
55
- const messageUploads = attachmentUploads.map(upload => {
56
- return upload.metadata;
57
- });
58
- messagesInlineImagesWithProgress[messageId] = messageUploads;
59
- });
60
- return messagesInlineImagesWithProgress;
61
- };
62
- /**
63
- * @internal
64
- */
65
- export const getSendBoxInlineImages = (sendBoxInlineImageUploads) => {
66
- var _a;
67
- if (!sendBoxInlineImageUploads) {
68
- return;
69
- }
70
- return (_a = sendBoxInlineImageUploads[SEND_BOX_UPLOADS_KEY_VALUE]) === null || _a === void 0 ? void 0 : _a.map(upload => upload.metadata);
71
- };
72
- const inlineImageUploadHandler = (uploadTasks, adapter, strings) => __awaiter(void 0, void 0, void 0, function* () {
73
- var _a, _b, _c;
74
- for (const task of uploadTasks) {
75
- const uploadTask = task;
76
- const image = uploadTask.image;
77
- if (!image) {
78
- uploadTask.notifyUploadFailed(strings.uploadImageDataNotProvided);
79
- continue;
80
- }
81
- if (image && image.size > MAX_INLINE_IMAGE_UPLOAD_SIZE_MB * 1024 * 1024) {
82
- uploadTask.notifyUploadFailed(strings.uploadImageIsTooLarge.replace('{maxImageSize}', `${MAX_INLINE_IMAGE_UPLOAD_SIZE_MB}`));
83
- continue;
84
- }
85
- const SUPPORTED_FILES = ['jpg', 'jpeg', 'png', 'gif', 'heic', 'webp'];
86
- const imageExtension = (_b = (_a = task.metadata) === null || _a === void 0 ? void 0 : _a.name.split('.').pop()) !== null && _b !== void 0 ? _b : '';
87
- if (!SUPPORTED_FILES.includes(imageExtension)) {
88
- uploadTask.notifyUploadFailed(strings.uploadImageExtensionIsNotAllowed.replace('{imageExtension}', imageExtension));
89
- continue;
90
- }
91
- try {
92
- const response = yield adapter.uploadImage(image, (_c = task.metadata) === null || _c === void 0 ? void 0 : _c.name);
93
- // Use response id as the image src because we need to keep the original image id as a reference to find the image.
94
- // Also the html content we send to ChatSDK does not need image src,
95
- // it only need the response id to match the uploaded image, url is not needed.
96
- uploadTask.notifyUploadCompleted(task.metadata.id, response.id);
97
- }
98
- catch (error) {
99
- console.error(error);
100
- uploadTask.notifyUploadFailed(strings.uploadImageFailed);
101
- }
102
- }
103
- });
104
- const generateUploadTask = (imageAttributes, fileName, messageId, inlineImageUploadActionHandler) => __awaiter(void 0, void 0, void 0, function* () {
105
- if (!imageAttributes.src) {
106
- console.error('Cannot upload image - Image src is not provided');
107
- return;
108
- }
109
- if (!imageAttributes.id) {
110
- console.error('Cannot upload image - Image id is not provided');
111
- return;
112
- }
113
- const imageData = yield getInlineImageData(imageAttributes.src);
114
- if (!imageData) {
115
- return;
116
- }
117
- const taskId = nanoid();
118
- const uploadTask = {
119
- image: imageData,
120
- taskId,
121
- metadata: {
122
- id: imageAttributes.id,
123
- name: fileName,
124
- url: imageAttributes.src,
125
- progress: 0
126
- },
127
- notifyUploadProgressChanged: (value) => {
128
- inlineImageUploadActionHandler({
129
- type: AttachmentUploadActionType.Progress,
130
- taskId,
131
- progress: value,
132
- messageId
133
- });
134
- },
135
- notifyUploadCompleted: (id, url) => {
136
- inlineImageUploadActionHandler({
137
- type: AttachmentUploadActionType.Completed,
138
- taskId,
139
- id,
140
- url,
141
- messageId
142
- });
143
- },
144
- notifyUploadFailed: (message) => {
145
- inlineImageUploadActionHandler({
146
- type: AttachmentUploadActionType.Failed,
147
- taskId,
148
- message,
149
- messageId
150
- });
151
- // remove the failed upload task when error banner is auto dismissed after 10 seconds
152
- // so the banner won't be shown again on UI re-rendering.
153
- setTimeout(() => {
154
- inlineImageUploadActionHandler({
155
- type: AttachmentUploadActionType.Remove,
156
- id: taskId,
157
- messageId
158
- });
159
- }, 10 * 1000);
160
- }
161
- };
162
- return uploadTask;
163
- });
164
- /**
165
- * @internal
166
- */
167
- export const onInsertInlineImageForEditBox = (imageAttributes, fileName, messageId, adapter, handleEditBoxInlineImageUploadAction, chatCompositeStrings) => __awaiter(void 0, void 0, void 0, function* () {
168
- const uploadTask = yield generateUploadTask(imageAttributes, fileName, messageId, handleEditBoxInlineImageUploadAction);
169
- if (!uploadTask) {
170
- return;
171
- }
172
- handleEditBoxInlineImageUploadAction({
173
- type: AttachmentUploadActionType.Set,
174
- newUploads: [uploadTask],
175
- messageId
176
- });
177
- inlineImageUploadHandler([uploadTask], adapter, chatCompositeStrings);
178
- });
179
- /**
180
- * @internal
181
- */
182
- export const onInsertInlineImageForSendBox = (imageAttributes, fileName, adapter, handleSendBoxInlineImageUploadAction, chatCompositeStrings) => __awaiter(void 0, void 0, void 0, function* () {
183
- const uploadTask = yield generateUploadTask(imageAttributes, fileName, SEND_BOX_UPLOADS_KEY_VALUE, handleSendBoxInlineImageUploadAction);
184
- if (!uploadTask) {
185
- return;
186
- }
187
- handleSendBoxInlineImageUploadAction({
188
- type: AttachmentUploadActionType.Set,
189
- newUploads: [uploadTask],
190
- messageId: SEND_BOX_UPLOADS_KEY_VALUE
191
- });
192
- inlineImageUploadHandler([uploadTask], adapter, chatCompositeStrings);
193
- });
194
- /**
195
- * @internal
196
- */
197
- export const cancelInlineImageUpload = (imageAttributes, imageUploads, messageId, inlineImageUploadActionHandler, adapter) => {
198
- var _a;
199
- if (!imageAttributes.id) {
200
- console.error('Cannot cancel image upload - Image id is not provided');
201
- return;
202
- }
203
- if (!imageUploads || !imageUploads[messageId]) {
204
- deleteExistingInlineImageForEditBox(imageAttributes.id, messageId, adapter);
205
- return;
206
- }
207
- const imageUpload = (_a = imageUploads[messageId]) === null || _a === void 0 ? void 0 : _a.find(upload => upload.metadata.id === imageAttributes.id);
208
- if (!imageUpload || !(imageUpload === null || imageUpload === void 0 ? void 0 : imageUpload.metadata.id)) {
209
- deleteExistingInlineImageForEditBox(imageAttributes.id, messageId, adapter);
210
- return;
211
- }
212
- inlineImageUploadActionHandler({
213
- type: AttachmentUploadActionType.Remove,
214
- id: imageUpload === null || imageUpload === void 0 ? void 0 : imageUpload.metadata.id,
215
- messageId
216
- });
217
- if ((imageUpload === null || imageUpload === void 0 ? void 0 : imageUpload.metadata.progress) === 1 && (imageUpload === null || imageUpload === void 0 ? void 0 : imageUpload.metadata.url)) {
218
- // The image id that we got back from the ChatSDK response is stored in the image src attribute,
219
- // while the metadata id is the internal image id that we assigned to the image when it was pasted in.
220
- deleteInlineImageFromServer(imageUpload === null || imageUpload === void 0 ? void 0 : imageUpload.metadata.url, adapter);
221
- }
222
- };
223
- const deleteInlineImageFromServer = (imageId, adapter) => {
224
- try {
225
- adapter.deleteImage(imageId);
226
- }
227
- catch (error) {
228
- console.error(error);
229
- }
230
- }; // This function is used to delete the inline image that existed before editing starts
231
- const deleteExistingInlineImageForEditBox = (imageId, messageId, adapter) => {
232
- if (messageId !== SEND_BOX_UPLOADS_KEY_VALUE) {
233
- deleteInlineImageFromServer(imageId, adapter);
234
- }
235
- };
236
- /**
237
- * @internal
238
- */
239
- export const updateContentStringWithUploadedInlineImages = (content, imageUploads, messageId = SEND_BOX_UPLOADS_KEY_VALUE) => {
240
- if (!imageUploads || !imageUploads[messageId]) {
241
- return content;
242
- }
243
- const messageUploads = imageUploads[messageId];
244
- const document = new DOMParser().parseFromString(content !== null && content !== void 0 ? content : '', 'text/html');
245
- document.querySelectorAll('img').forEach(img => {
246
- var _a;
247
- const uploadInlineImage = messageUploads === null || messageUploads === void 0 ? void 0 : messageUploads.find(upload => !upload.metadata.error && upload.metadata.progress === 1 && upload.metadata.id === img.id);
248
- if (uploadInlineImage) {
249
- // ChatSDK uses the respond id provided by the upload response. We store the response id in the image src attribute previously.
250
- img.id = (_a = uploadInlineImage.metadata.url) !== null && _a !== void 0 ? _a : img.id;
251
- img.src = '';
252
- }
253
- });
254
- content = document.body.innerHTML;
255
- return content;
256
- };
257
- /**
258
- * @internal
259
- */
260
- export const getImageFileNameFromAttributes = (imageAttributes) => {
261
- const fileName = imageAttributes[_IMAGE_ATTRIBUTE_INLINE_IMAGE_FILE_NAME_KEY];
262
- if (!fileName || fileName === '' || fileName === 'undefined' || fileName === 'null') {
263
- return _DEFAULT_INLINE_IMAGE_FILE_NAME;
264
- }
265
- return fileName;
266
- };
267
- //# sourceMappingURL=ImageUploadUtils.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"ImageUploadUtils.js","sourceRoot":"","sources":["../../../../../../../preprocess-dist/react-composites/src/composites/ChatComposite/ImageUpload/ImageUploadUtils.tsx"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { AttachmentMetadataInProgress, _IMAGE_ATTRIBUTE_INLINE_IMAGE_FILE_NAME_KEY } from '@internal/acs-ui-common';\nimport { AttachmentUpload, AttachmentUploadActionType, AttachmentUploadTask } from '../file-sharing/AttachmentUpload';\nimport { _DEFAULT_INLINE_IMAGE_FILE_NAME, SEND_BOX_UPLOADS_KEY_VALUE } from '../../common/constants';\nimport { ChatAdapter } from '../adapter/ChatAdapter';\nimport { Dispatch } from 'react';\nimport { ImageActions } from './ImageUploadReducer';\nimport { nanoid } from 'nanoid';\nimport { ChatCompositeStrings } from '../Strings';\nconst MAX_INLINE_IMAGE_UPLOAD_SIZE_MB = 20;\nconst fetchBlobData = async (resource: string | URL | Request, options: {\n timeout?: number;\n headers?: Headers;\n abortController: AbortController;\n}): Promise<Response> => {\n // default timeout is 30 seconds\n const {\n timeout = 30000,\n abortController\n } = options;\n const id = setTimeout(() => {\n abortController.abort();\n }, timeout);\n const response = await fetch(resource, {\n ...options,\n signal: abortController.signal\n });\n clearTimeout(id);\n return response;\n};\n/**\n * @private\n */\nexport const getInlineImageData = async (image: string): Promise<Blob | undefined> => {\n if (image.startsWith('blob') || image.startsWith('http')) {\n try {\n const res = await fetchBlobData(image, {\n abortController: new AbortController()\n });\n const blobImage = await res.blob();\n return blobImage;\n } catch (error) {\n console.error('Error fetching image data', error);\n return;\n }\n }\n return;\n};\n/**\n * @internal\n */\nexport const getEditBoxMessagesInlineImages = (editBoxInlineImageUploads: Record<string, AttachmentUpload[]> | undefined): Record<string, AttachmentMetadataInProgress[]> | undefined => {\n if (!editBoxInlineImageUploads) {\n return;\n }\n const messagesInlineImagesWithProgress: Record<string, AttachmentMetadataInProgress[]> = {};\n Object.entries(editBoxInlineImageUploads || {}).map(([messageId, attachmentUploads]) => {\n const messageUploads = attachmentUploads.map(upload => {\n return upload.metadata;\n });\n messagesInlineImagesWithProgress[messageId] = messageUploads;\n });\n return messagesInlineImagesWithProgress;\n};\n/**\n * @internal\n */\nexport const getSendBoxInlineImages = (sendBoxInlineImageUploads: Record<string, AttachmentUpload[]> | undefined): AttachmentMetadataInProgress[] | undefined => {\n if (!sendBoxInlineImageUploads) {\n return;\n }\n return sendBoxInlineImageUploads[SEND_BOX_UPLOADS_KEY_VALUE]?.map(upload => upload.metadata);\n};\nconst inlineImageUploadHandler = async (uploadTasks: AttachmentUpload[], adapter: ChatAdapter, strings: ChatCompositeStrings): Promise<void> => {\n for (const task of uploadTasks) {\n const uploadTask = task as AttachmentUploadTask;\n const image: Blob | undefined = uploadTask.image;\n if (!image) {\n uploadTask.notifyUploadFailed(strings.uploadImageDataNotProvided);\n continue;\n }\n if (image && image.size > MAX_INLINE_IMAGE_UPLOAD_SIZE_MB * 1024 * 1024) {\n uploadTask.notifyUploadFailed(strings.uploadImageIsTooLarge.replace('{maxImageSize}', `${MAX_INLINE_IMAGE_UPLOAD_SIZE_MB}`));\n continue;\n }\n const SUPPORTED_FILES: Array<string> = ['jpg', 'jpeg', 'png', 'gif', 'heic', 'webp'];\n const imageExtension = task.metadata?.name.split('.').pop() ?? '';\n if (!SUPPORTED_FILES.includes(imageExtension)) {\n uploadTask.notifyUploadFailed(strings.uploadImageExtensionIsNotAllowed.replace('{imageExtension}', imageExtension));\n continue;\n }\n try {\n const response = await adapter.uploadImage(image, task.metadata?.name);\n // Use response id as the image src because we need to keep the original image id as a reference to find the image.\n // Also the html content we send to ChatSDK does not need image src,\n // it only need the response id to match the uploaded image, url is not needed.\n uploadTask.notifyUploadCompleted(task.metadata.id, response.id);\n } catch (error) {\n console.error(error);\n uploadTask.notifyUploadFailed(strings.uploadImageFailed);\n }\n }\n};\nconst generateUploadTask = async (imageAttributes: Record<string, string>, fileName: string, messageId: string, inlineImageUploadActionHandler: Dispatch<ImageActions>): Promise<AttachmentUpload | undefined> => {\n if (!imageAttributes.src) {\n console.error('Cannot upload image - Image src is not provided');\n return;\n }\n if (!imageAttributes.id) {\n console.error('Cannot upload image - Image id is not provided');\n return;\n }\n const imageData = await getInlineImageData(imageAttributes.src);\n if (!imageData) {\n return;\n }\n const taskId = nanoid();\n const uploadTask: AttachmentUpload = {\n image: imageData,\n taskId,\n metadata: {\n id: imageAttributes.id,\n name: fileName,\n url: imageAttributes.src,\n progress: 0\n },\n notifyUploadProgressChanged: (value: number) => {\n inlineImageUploadActionHandler({\n type: AttachmentUploadActionType.Progress,\n taskId,\n progress: value,\n messageId\n });\n },\n notifyUploadCompleted: (id: string, url: string) => {\n inlineImageUploadActionHandler({\n type: AttachmentUploadActionType.Completed,\n taskId,\n id,\n url,\n messageId\n });\n },\n notifyUploadFailed: (message: string) => {\n inlineImageUploadActionHandler({\n type: AttachmentUploadActionType.Failed,\n taskId,\n message,\n messageId\n });\n // remove the failed upload task when error banner is auto dismissed after 10 seconds\n // so the banner won't be shown again on UI re-rendering.\n setTimeout(() => {\n inlineImageUploadActionHandler({\n type: AttachmentUploadActionType.Remove,\n id: taskId,\n messageId\n });\n }, 10 * 1000);\n }\n };\n return uploadTask;\n};\n/**\n * @internal\n */\nexport const onInsertInlineImageForEditBox = async (imageAttributes: Record<string, string>, fileName: string, messageId: string, adapter: ChatAdapter, handleEditBoxInlineImageUploadAction: Dispatch<ImageActions>, chatCompositeStrings: ChatCompositeStrings): Promise<void> => {\n const uploadTask: AttachmentUpload | undefined = await generateUploadTask(imageAttributes, fileName, messageId, handleEditBoxInlineImageUploadAction);\n if (!uploadTask) {\n return;\n }\n handleEditBoxInlineImageUploadAction({\n type: AttachmentUploadActionType.Set,\n newUploads: [uploadTask],\n messageId\n });\n inlineImageUploadHandler([uploadTask], adapter, chatCompositeStrings);\n};\n/**\n * @internal\n */\nexport const onInsertInlineImageForSendBox = async (imageAttributes: Record<string, string>, fileName: string, adapter: ChatAdapter, handleSendBoxInlineImageUploadAction: Dispatch<ImageActions>, chatCompositeStrings: ChatCompositeStrings): Promise<void> => {\n const uploadTask: AttachmentUpload | undefined = await generateUploadTask(imageAttributes, fileName, SEND_BOX_UPLOADS_KEY_VALUE, handleSendBoxInlineImageUploadAction);\n if (!uploadTask) {\n return;\n }\n handleSendBoxInlineImageUploadAction({\n type: AttachmentUploadActionType.Set,\n newUploads: [uploadTask],\n messageId: SEND_BOX_UPLOADS_KEY_VALUE\n });\n inlineImageUploadHandler([uploadTask], adapter, chatCompositeStrings);\n};\n/**\n * @internal\n */\nexport const cancelInlineImageUpload = (imageAttributes: Record<string, string>, imageUploads: Record<string, AttachmentUpload[]> | undefined, messageId: string, inlineImageUploadActionHandler: Dispatch<ImageActions>, adapter: ChatAdapter): void => {\n if (!imageAttributes.id) {\n console.error('Cannot cancel image upload - Image id is not provided');\n return;\n }\n if (!imageUploads || !imageUploads[messageId]) {\n deleteExistingInlineImageForEditBox(imageAttributes.id, messageId, adapter);\n return;\n }\n const imageUpload = imageUploads[messageId]?.find(upload => upload.metadata.id === imageAttributes.id);\n if (!imageUpload || !imageUpload?.metadata.id) {\n deleteExistingInlineImageForEditBox(imageAttributes.id, messageId, adapter);\n return;\n }\n inlineImageUploadActionHandler({\n type: AttachmentUploadActionType.Remove,\n id: imageUpload?.metadata.id,\n messageId\n });\n if (imageUpload?.metadata.progress === 1 && imageUpload?.metadata.url) {\n // The image id that we got back from the ChatSDK response is stored in the image src attribute,\n // while the metadata id is the internal image id that we assigned to the image when it was pasted in.\n deleteInlineImageFromServer(imageUpload?.metadata.url, adapter);\n }\n};\nconst deleteInlineImageFromServer = (imageId: string, adapter: ChatAdapter): void => {\n try {\n adapter.deleteImage(imageId);\n } catch (error) {\n console.error(error);\n }\n}; // This function is used to delete the inline image that existed before editing starts\nconst deleteExistingInlineImageForEditBox = (imageId: string, messageId: string, adapter: ChatAdapter): void => {\n if (messageId !== SEND_BOX_UPLOADS_KEY_VALUE) {\n deleteInlineImageFromServer(imageId, adapter);\n }\n};\n/**\n * @internal\n */\nexport const updateContentStringWithUploadedInlineImages = (content: string, imageUploads: Record<string, AttachmentUpload[]> | undefined, messageId: string = SEND_BOX_UPLOADS_KEY_VALUE): string => {\n if (!imageUploads || !imageUploads[messageId]) {\n return content;\n }\n const messageUploads = imageUploads[messageId];\n const document = new DOMParser().parseFromString(content ?? '', 'text/html');\n document.querySelectorAll('img').forEach(img => {\n const uploadInlineImage = messageUploads?.find(upload => !upload.metadata.error && upload.metadata.progress === 1 && upload.metadata.id === img.id);\n if (uploadInlineImage) {\n // ChatSDK uses the respond id provided by the upload response. We store the response id in the image src attribute previously.\n img.id = uploadInlineImage.metadata.url ?? img.id;\n img.src = '';\n }\n });\n content = document.body.innerHTML;\n return content;\n};\n/**\n * @internal\n */\nexport const getImageFileNameFromAttributes = (imageAttributes: Record<string, string>): string => {\n const fileName = imageAttributes[_IMAGE_ATTRIBUTE_INLINE_IMAGE_FILE_NAME_KEY];\n if (!fileName || fileName === '' || fileName === 'undefined' || fileName === 'null') {\n return _DEFAULT_INLINE_IMAGE_FILE_NAME;\n }\n return fileName;\n};"]}
@@ -1,80 +0,0 @@
1
- import { AttachmentUploadTask, AttachmentSelectionHandler, AttachmentActionHandler } from "../../../../../react-components/src";
2
- import { AttachmentMetadata, AttachmentMetadataInProgress, AttachmentProgressError } from "../../../../../acs-ui-common/src";
3
- /**
4
- * @internal
5
- */
6
- export interface AttachmentUpload extends AttachmentUploadTask {
7
- metadata: AttachmentMetadataInProgress;
8
- }
9
- /**
10
- * @private
11
- */
12
- export declare enum AttachmentUploadActionType {
13
- Set = "set",
14
- Progress = "progress",
15
- Completed = "completed",
16
- Failed = "failed",
17
- Remove = "remove",
18
- Clear = "clear"
19
- }
20
- /**
21
- * @private
22
- */
23
- export interface Action {
24
- type: AttachmentUploadActionType;
25
- }
26
- /**
27
- * @private
28
- */
29
- interface SetAction extends Action {
30
- type: AttachmentUploadActionType.Set;
31
- newUploads: AttachmentUpload[];
32
- }
33
- /**
34
- * @private
35
- */
36
- export interface ProgressAction extends Action {
37
- type: AttachmentUploadActionType.Progress;
38
- taskId: string;
39
- progress: number;
40
- }
41
- /**
42
- * @private
43
- */
44
- export interface CompleteAction extends Action {
45
- type: AttachmentUploadActionType.Completed;
46
- taskId: string;
47
- id: string;
48
- url: string;
49
- }
50
- /**
51
- * @private
52
- */
53
- export interface FailedAction extends Action {
54
- type: AttachmentUploadActionType.Failed;
55
- taskId: string;
56
- message: string;
57
- }
58
- /**
59
- * @private
60
- */
61
- export interface RemoveAction extends Action {
62
- type: AttachmentUploadActionType.Remove;
63
- id: string;
64
- }
65
- /**
66
- * @private
67
- */
68
- export interface ClearAction extends Action {
69
- type: AttachmentUploadActionType.Clear;
70
- }
71
- /**
72
- * @private
73
- */
74
- type Actions = SetAction | ProgressAction | CompleteAction | FailedAction | RemoveAction | ClearAction;
75
- /**
76
- * @internal
77
- */
78
- export declare const AttachmentUploadReducer: (state: AttachmentUpload[], action: Actions) => AttachmentUpload[];
79
- export type { AttachmentMetadata, AttachmentSelectionHandler, AttachmentActionHandler, AttachmentUploadTask, AttachmentProgressError };
80
- //# sourceMappingURL=AttachmentUpload.d.ts.map
@@ -1,36 +0,0 @@
1
- /**
2
- * @private
3
- */
4
- export var AttachmentUploadActionType;
5
- (function (AttachmentUploadActionType) {
6
- AttachmentUploadActionType["Set"] = "set";
7
- AttachmentUploadActionType["Progress"] = "progress";
8
- AttachmentUploadActionType["Completed"] = "completed";
9
- AttachmentUploadActionType["Failed"] = "failed";
10
- AttachmentUploadActionType["Remove"] = "remove";
11
- AttachmentUploadActionType["Clear"] = "clear";
12
- })(AttachmentUploadActionType || (AttachmentUploadActionType = {}));
13
- /**
14
- * @internal
15
- */
16
- export const AttachmentUploadReducer = (state, action) => {
17
- switch (action.type) {
18
- case AttachmentUploadActionType.Set:
19
- return state.filter(v => !v.metadata.error).concat(action.newUploads);
20
- case AttachmentUploadActionType.Completed:
21
- return state.map(v => v.taskId === action.taskId ? Object.assign(Object.assign({}, v), { metadata: Object.assign(Object.assign({}, v.metadata), { id: action.id, url: action.url, progress: 1 }) }) : v);
22
- case AttachmentUploadActionType.Failed:
23
- return state.map(v => v.taskId === action.taskId ? Object.assign(Object.assign({}, v), { metadata: Object.assign(Object.assign({}, v.metadata), { error: {
24
- message: action.message
25
- } }) }) : v);
26
- case AttachmentUploadActionType.Remove:
27
- return state.filter(v => !v.metadata.error).filter(v => v.metadata.id !== action.id);
28
- case AttachmentUploadActionType.Progress:
29
- return state.map(v => v.taskId === action.taskId ? Object.assign(Object.assign({}, v), { metadata: Object.assign(Object.assign({}, v.metadata), { progress: action.progress }) }) : v);
30
- case AttachmentUploadActionType.Clear:
31
- return [];
32
- default:
33
- return state;
34
- }
35
- };
36
- //# sourceMappingURL=AttachmentUpload.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"AttachmentUpload.js","sourceRoot":"","sources":["../../../../../../../preprocess-dist/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUpload.ts"],"names":[],"mappings":"AAWA;;GAEG;AACH,MAAM,CAAN,IAAY,0BAOX;AAPD,WAAY,0BAA0B;IACpC,yCAAW,CAAA;IACX,mDAAqB,CAAA;IACrB,qDAAuB,CAAA;IACvB,+CAAiB,CAAA;IACjB,+CAAiB,CAAA;IACjB,6CAAe,CAAA;AACjB,CAAC,EAPW,0BAA0B,KAA1B,0BAA0B,QAOrC;AAwDD;;GAEG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,KAAyB,EAAE,MAAe,EAAsB,EAAE;IACxG,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;QACpB,KAAK,0BAA0B,CAAC,GAAG;YACjC,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACxE,KAAK,0BAA0B,CAAC,SAAS;YACvC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,iCAC7C,CAAC,KACJ,QAAQ,kCACH,CAAC,CAAC,QAAQ,KACb,EAAE,EAAE,MAAM,CAAC,EAAE,EACb,GAAG,EAAE,MAAM,CAAC,GAAG,EACf,QAAQ,EAAE,CAAC,OAEb,CAAC,CAAC,CAAC,CAAC,CAAC;QACT,KAAK,0BAA0B,CAAC,MAAM;YACpC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,iCAC7C,CAAC,KACJ,QAAQ,kCACH,CAAC,CAAC,QAAQ,KACb,KAAK,EAAE;wBACL,OAAO,EAAE,MAAM,CAAC,OAAO;qBACxB,OAEH,CAAC,CAAC,CAAC,CAAC,CAAC;QACT,KAAK,0BAA0B,CAAC,MAAM;YACpC,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,KAAK,MAAM,CAAC,EAAE,CAAC,CAAC;QACvF,KAAK,0BAA0B,CAAC,QAAQ;YACtC,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,iCAC7C,CAAC,KACJ,QAAQ,kCACH,CAAC,CAAC,QAAQ,KACb,QAAQ,EAAE,MAAM,CAAC,QAAQ,OAE3B,CAAC,CAAC,CAAC,CAAC,CAAC;QACT,KAAK,0BAA0B,CAAC,KAAK;YACnC,OAAO,EAAE,CAAC;QACZ;YACE,OAAO,KAAK,CAAC;IACjB,CAAC;AACH,CAAC,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { AttachmentUploadTask, AttachmentSelectionHandler, AttachmentActionHandler } from '@internal/react-components';\nimport { AttachmentMetadata, AttachmentMetadataInProgress, AttachmentProgressError } from '@internal/acs-ui-common';\n/**\n * @internal\n */\nexport interface AttachmentUpload extends AttachmentUploadTask {\n metadata: AttachmentMetadataInProgress;\n}\n\n/**\n * @private\n */\nexport enum AttachmentUploadActionType {\n Set = 'set',\n Progress = 'progress',\n Completed = 'completed',\n Failed = 'failed',\n Remove = 'remove',\n Clear = 'clear',\n}\n/**\n * @private\n */\nexport interface Action {\n type: AttachmentUploadActionType;\n}\n/**\n * @private\n */\ninterface SetAction extends Action {\n type: AttachmentUploadActionType.Set;\n newUploads: AttachmentUpload[];\n}\n/**\n * @private\n */\nexport interface ProgressAction extends Action {\n type: AttachmentUploadActionType.Progress;\n taskId: string;\n progress: number;\n}\n/**\n * @private\n */\nexport interface CompleteAction extends Action {\n type: AttachmentUploadActionType.Completed;\n taskId: string;\n id: string;\n url: string;\n}\n/**\n * @private\n */\nexport interface FailedAction extends Action {\n type: AttachmentUploadActionType.Failed;\n taskId: string;\n message: string;\n}\n/**\n * @private\n */\nexport interface RemoveAction extends Action {\n type: AttachmentUploadActionType.Remove;\n id: string;\n}\n/**\n * @private\n */\nexport interface ClearAction extends Action {\n type: AttachmentUploadActionType.Clear;\n}\n/**\n * @private\n */\ntype Actions = SetAction | ProgressAction | CompleteAction | FailedAction | RemoveAction | ClearAction;\n/**\n * @internal\n */\nexport const AttachmentUploadReducer = (state: AttachmentUpload[], action: Actions): AttachmentUpload[] => {\n switch (action.type) {\n case AttachmentUploadActionType.Set:\n return state.filter(v => !v.metadata.error).concat(action.newUploads);\n case AttachmentUploadActionType.Completed:\n return state.map(v => v.taskId === action.taskId ? {\n ...v,\n metadata: {\n ...v.metadata,\n id: action.id,\n url: action.url,\n progress: 1\n }\n } : v);\n case AttachmentUploadActionType.Failed:\n return state.map(v => v.taskId === action.taskId ? {\n ...v,\n metadata: {\n ...v.metadata,\n error: {\n message: action.message\n }\n }\n } : v);\n case AttachmentUploadActionType.Remove:\n return state.filter(v => !v.metadata.error).filter(v => v.metadata.id !== action.id);\n case AttachmentUploadActionType.Progress:\n return state.map(v => v.taskId === action.taskId ? {\n ...v,\n metadata: {\n ...v.metadata,\n progress: action.progress\n }\n } : v);\n case AttachmentUploadActionType.Clear:\n return [];\n default:\n return state;\n }\n};\nexport type { AttachmentMetadata, AttachmentSelectionHandler, AttachmentActionHandler, AttachmentUploadTask, AttachmentProgressError };"]}
@@ -1,38 +0,0 @@
1
- /// <reference types="react" />
2
- /**
3
- * Props for {@link AttachmentUploadButton} component.
4
- * @internal
5
- */
6
- export interface AttachmentUploadButtonProps {
7
- /**
8
- * A list of strings containing the comma separated list of supported media (aka. mime) types.
9
- * i.e. ['image/*', 'video/*', 'audio/*']
10
- * Default value is `['*']`, meaning all media types are supported.
11
- * Similar to the `accept` attribute of the `<input type="file" />` element.
12
- */
13
- supportedMediaTypes?: string[];
14
- /**
15
- * Disable multiple files to be selected if set to `true`.
16
- * Default value is `false`, meaning multiple files can be selected.
17
- * Similar to the `multiple` attribute of the `<input type="file" />` element.
18
- */
19
- disableMultipleUploads?: boolean;
20
- /**
21
- * onChange handler for the attachment upload button.
22
- * Similar to the `onChange` attribute of the `<input type="file" />` element.
23
- * Called every time files are selected through the attachment upload button with a {@link FileList}
24
- * of selected files.
25
- */
26
- onChange?: (files: FileList | null) => void;
27
- }
28
- /**
29
- * @internal
30
- */
31
- export declare const AttachmentUploadButton: (props: AttachmentUploadButtonProps) => JSX.Element;
32
- /**
33
- * A wrapper to return {@link AttachmentUploadButton} component conditionally.
34
- * It will return `<></>` for stable builds.
35
- * @internal
36
- */
37
- export declare const AttachmentUploadButtonWrapper: (props: Pick<AttachmentUploadButtonProps, 'supportedMediaTypes' | 'disableMultipleUploads' | 'onChange'>) => JSX.Element;
38
- //# sourceMappingURL=AttachmentUploadButton.d.ts.map
@@ -1,66 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import { IconButton, mergeStyles, Stack, TooltipHost, useTheme } from '@fluentui/react';
4
- import React from 'react';
5
- import { ChatCompositeIcon } from '../../common/icons';
6
- import { useLocale } from '../../localization';
7
- /**
8
- * @internal
9
- */
10
- export const AttachmentUploadButton = (props) => {
11
- const inputRef = React.useRef(null);
12
- const theme = useTheme();
13
- // default supportedMediaTypes is ['*'], meaning all media types are supported.
14
- // default disableMultipleUploads is false, meaning multiple files can be selected.
15
- const { supportedMediaTypes = ['*'], disableMultipleUploads = false, onChange } = props;
16
- const attachmentUploadButtonClassName = mergeStyles({
17
- width: '1.5rem',
18
- height: '1.5rem',
19
- cursor: 'pointer',
20
- padding: '0.15rem',
21
- ':hover': {
22
- backgroundColor: theme.palette.neutralLighter
23
- }
24
- });
25
- const iconButtonClassName = mergeStyles({
26
- color: 'unset',
27
- width: '1.5rem',
28
- height: '1.5rem',
29
- ':hover': {
30
- color: 'unset',
31
- background: 'transparent'
32
- }
33
- });
34
- return React.createElement(React.Fragment, null,
35
- React.createElement(Stack, { verticalAlign: "center", horizontalAlign: "center", className: attachmentUploadButtonClassName, onClick: () => {
36
- var _a;
37
- (_a = inputRef.current) === null || _a === void 0 ? void 0 : _a.click();
38
- } },
39
- React.createElement(TooltipHost, { content: uploadAttachmentButtonStringTrampoline(), "data-ui-id": "chat-composite-message-tooltip" },
40
- React.createElement(IconButton, { className: iconButtonClassName, ariaLabel: uploadAttachmentButtonStringTrampoline(), autoFocus: false },
41
- React.createElement(SendBoxAttachFileIconTrampoline, null)))),
42
- React.createElement("input", { "data-testid": "attachment-upload-button", ref: inputRef, autoFocus: false, hidden: true, multiple: !disableMultipleUploads, accept: supportedMediaTypes.join(','), type: "file", onClick: e => {
43
- // To ensure that `onChange` is fired even if the same file is picked again.
44
- e.currentTarget.value = '';
45
- }, onChange: e => {
46
- onChange === null || onChange === void 0 ? void 0 : onChange(e.currentTarget.files);
47
- } }));
48
- };
49
- const SendBoxAttachFileIconTrampoline = () => {
50
- return React.createElement(ChatCompositeIcon, { iconName: "SendBoxAttachFile" });
51
- // Return _some_ available icon, as the real icon is beta-only.
52
- return React.createElement(ChatCompositeIcon, { iconName: "EditBoxCancel" });
53
- };
54
- /**
55
- * A wrapper to return {@link AttachmentUploadButton} component conditionally.
56
- * It will return `<></>` for stable builds.
57
- * @internal
58
- */
59
- export const AttachmentUploadButtonWrapper = (props) => {
60
- return React.createElement(React.Fragment, null, React.createElement(AttachmentUploadButton, Object.assign({}, props)));
61
- };
62
- const uploadAttachmentButtonStringTrampoline = () => {
63
- return useLocale().strings.chat.uploadAttachment;
64
- return '';
65
- };
66
- //# sourceMappingURL=AttachmentUploadButton.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"AttachmentUploadButton.js","sourceRoot":"","sources":["../../../../../../../preprocess-dist/react-composites/src/composites/ChatComposite/file-sharing/AttachmentUploadButton.tsx"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACxF,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AA2B/C;;GAEG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,KAAkC,EAAe,EAAE;IACxF,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAmB,IAAI,CAAC,CAAC;IACtD,MAAM,KAAK,GAAG,QAAQ,EAAE,CAAC;IACzB,+EAA+E;IAC/E,mFAAmF;IACnF,MAAM,EACJ,mBAAmB,GAAG,CAAC,GAAG,CAAC,EAC3B,sBAAsB,GAAG,KAAK,EAC9B,QAAQ,EACT,GAAG,KAAK,CAAC;IACV,MAAM,+BAA+B,GAAG,WAAW,CAAC;QAClD,KAAK,EAAE,QAAQ;QACf,MAAM,EAAE,QAAQ;QAChB,MAAM,EAAE,SAAS;QACjB,OAAO,EAAE,SAAS;QAClB,QAAQ,EAAE;YACR,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,cAAc;SAC9C;KACF,CAAC,CAAC;IACH,MAAM,mBAAmB,GAAG,WAAW,CAAC;QACtC,KAAK,EAAE,OAAO;QACd,KAAK,EAAE,QAAQ;QACf,MAAM,EAAE,QAAQ;QAChB,QAAQ,EAAE;YACR,KAAK,EAAE,OAAO;YACd,UAAU,EAAE,aAAa;SAC1B;KACF,CAAC,CAAC;IACH,OAAO;QACH,oBAAC,KAAK,IAAC,aAAa,EAAC,QAAQ,EAAC,eAAe,EAAC,QAAQ,EAAC,SAAS,EAAE,+BAA+B,EAAE,OAAO,EAAE,GAAG,EAAE;;gBACjH,MAAA,QAAQ,CAAC,OAAO,0CAAE,KAAK,EAAE,CAAC;YAC5B,CAAC;YACG,oBAAC,WAAW,IAAC,OAAO,EAAE,sCAAsC,EAAE,gBAAa,gCAAgC;gBACzG,oBAAC,UAAU,IAAC,SAAS,EAAE,mBAAmB,EAAE,SAAS,EAAE,sCAAsC,EAAE,EAAE,SAAS,EAAE,KAAK;oBAC/G,oBAAC,+BAA+B,OAAG,CACxB,CACD,CACR;QACR,8CAAmB,0BAA0B,EAAC,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,QAAC,QAAQ,EAAE,CAAC,sBAAsB,EAAE,MAAM,EAAE,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAC,MAAM,EAAC,OAAO,EAAE,CAAC,CAAC,EAAE;gBACzL,4EAA4E;gBAC5E,CAAC,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;YAC7B,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE;gBACf,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACpC,CAAC,GAAI,CACF,CAAC;AACR,CAAC,CAAC;AACF,MAAM,+BAA+B,GAAG,GAAgB,EAAE;IACxD,OAAO,oBAAC,iBAAiB,IAAC,QAAQ,EAAC,mBAAmB,GAAG,CAAC;IAC1D,+DAA+D;IAC/D,OAAO,oBAAC,iBAAiB,IAAC,QAAQ,EAAC,eAAe,GAAG,CAAC;AACxD,CAAC,CAAC;AACF;;;;GAIG;AACH,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAAC,KAAuG,EAAe,EAAE;IACpK,OAAO,0CACF,oBAAC,sBAAsB,oBAAK,KAAK,EAAI,CACrC,CAAC;AACR,CAAC,CAAC;AACF,MAAM,sCAAsC,GAAG,GAAW,EAAE;IAC1D,OAAO,SAAS,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,gBAAgB,CAAC;IACjD,OAAO,EAAE,CAAC;AACZ,CAAC,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport { IconButton, mergeStyles, Stack, TooltipHost, useTheme } from '@fluentui/react';\nimport React from 'react';\nimport { ChatCompositeIcon } from '../../common/icons';\nimport { useLocale } from '../../localization';\n/**\n * Props for {@link AttachmentUploadButton} component.\n * @internal\n */\nexport interface AttachmentUploadButtonProps {\n /**\n * A list of strings containing the comma separated list of supported media (aka. mime) types.\n * i.e. ['image/*', 'video/*', 'audio/*']\n * Default value is `['*']`, meaning all media types are supported.\n * Similar to the `accept` attribute of the `<input type=\"file\" />` element.\n */\n supportedMediaTypes?: string[];\n /**\n * Disable multiple files to be selected if set to `true`.\n * Default value is `false`, meaning multiple files can be selected.\n * Similar to the `multiple` attribute of the `<input type=\"file\" />` element.\n */\n disableMultipleUploads?: boolean;\n /**\n * onChange handler for the attachment upload button.\n * Similar to the `onChange` attribute of the `<input type=\"file\" />` element.\n * Called every time files are selected through the attachment upload button with a {@link FileList}\n * of selected files.\n */\n onChange?: (files: FileList | null) => void;\n}\n/**\n * @internal\n */\nexport const AttachmentUploadButton = (props: AttachmentUploadButtonProps): JSX.Element => {\n const inputRef = React.useRef<HTMLInputElement>(null);\n const theme = useTheme();\n // default supportedMediaTypes is ['*'], meaning all media types are supported.\n // default disableMultipleUploads is false, meaning multiple files can be selected.\n const {\n supportedMediaTypes = ['*'],\n disableMultipleUploads = false,\n onChange\n } = props;\n const attachmentUploadButtonClassName = mergeStyles({\n width: '1.5rem',\n height: '1.5rem',\n cursor: 'pointer',\n padding: '0.15rem',\n ':hover': {\n backgroundColor: theme.palette.neutralLighter\n }\n });\n const iconButtonClassName = mergeStyles({\n color: 'unset',\n width: '1.5rem',\n height: '1.5rem',\n ':hover': {\n color: 'unset',\n background: 'transparent'\n }\n });\n return <>\n <Stack verticalAlign=\"center\" horizontalAlign=\"center\" className={attachmentUploadButtonClassName} onClick={() => {\n inputRef.current?.click();\n }}>\n <TooltipHost content={uploadAttachmentButtonStringTrampoline()} data-ui-id=\"chat-composite-message-tooltip\">\n <IconButton className={iconButtonClassName} ariaLabel={uploadAttachmentButtonStringTrampoline()} autoFocus={false}>\n <SendBoxAttachFileIconTrampoline />\n </IconButton>\n </TooltipHost>\n </Stack>\n <input data-testid=\"attachment-upload-button\" ref={inputRef} autoFocus={false} hidden multiple={!disableMultipleUploads} accept={supportedMediaTypes.join(',')} type=\"file\" onClick={e => {\n // To ensure that `onChange` is fired even if the same file is picked again.\n e.currentTarget.value = '';\n }} onChange={e => {\n onChange?.(e.currentTarget.files);\n }} />\n </>;\n};\nconst SendBoxAttachFileIconTrampoline = (): JSX.Element => {\n return <ChatCompositeIcon iconName=\"SendBoxAttachFile\" />;\n // Return _some_ available icon, as the real icon is beta-only.\n return <ChatCompositeIcon iconName=\"EditBoxCancel\" />;\n};\n/**\n * A wrapper to return {@link AttachmentUploadButton} component conditionally.\n * It will return `<></>` for stable builds.\n * @internal\n */\nexport const AttachmentUploadButtonWrapper = (props: Pick<AttachmentUploadButtonProps, 'supportedMediaTypes' | 'disableMultipleUploads' | 'onChange'>): JSX.Element => {\n return <>\n {<AttachmentUploadButton {...props} />}\n </>;\n};\nconst uploadAttachmentButtonStringTrampoline = (): string => {\n return useLocale().strings.chat.uploadAttachment;\n return '';\n};"]}
@@ -1,5 +0,0 @@
1
- export * from './AttachmentUpload';
2
- export * from './AttachmentUploadButton';
3
- export type { AttachmentOptions, AttachmentUploadTask, AttachmentUploadOptions, AttachmentRemovalHandler, AttachmentMetadataWrapper, AttachmentSelectionHandler, AttachmentActionHandler } from "../../../../../react-components/src";
4
- export type { AttachmentDownloadOptions } from "../../../../../react-components/src";
5
- //# sourceMappingURL=index.d.ts.map
@@ -1,5 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- export * from './AttachmentUpload';
4
- export * from './AttachmentUploadButton';
5
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../preprocess-dist/react-composites/src/composites/ChatComposite/file-sharing/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport * from './AttachmentUpload';\nexport * from './AttachmentUploadButton';\nexport type { AttachmentOptions, AttachmentUploadTask, AttachmentUploadOptions, AttachmentRemovalHandler, AttachmentMetadataWrapper, AttachmentSelectionHandler, AttachmentActionHandler } from '@internal/react-components';\nexport type { AttachmentDownloadOptions } from '@internal/react-components';"]}
@@ -1,10 +0,0 @@
1
- /// <reference types="react" />
2
- import { RichTextSendBoxProps } from "../../../../react-components/src";
3
- /**
4
- * @private
5
- *
6
- * Wrapper for RichTextSendBox component to allow us to use usePropsFor with richTextSendBox
7
- * before lazyLoading is done
8
- */
9
- export declare const RichTextSendBoxWrapper: (props: RichTextSendBoxProps) => JSX.Element;
10
- //# sourceMappingURL=RichTextSendBoxWrapper.d.ts.map
@@ -1,16 +0,0 @@
1
- // Copyright (c) Microsoft Corporation.
2
- // Licensed under the MIT License.
3
- import React from 'react';
4
- import { usePropsFor } from '../ChatComposite/hooks/usePropsFor';
5
- import { RichTextSendBox } from "../../../../react-components/src";
6
- /**
7
- * @private
8
- *
9
- * Wrapper for RichTextSendBox component to allow us to use usePropsFor with richTextSendBox
10
- * before lazyLoading is done
11
- */
12
- export const RichTextSendBoxWrapper = (props) => {
13
- const richTextSendBoxProps = usePropsFor(RichTextSendBox);
14
- return React.createElement(RichTextSendBox, Object.assign({}, richTextSendBoxProps, props));
15
- };
16
- //# sourceMappingURL=RichTextSendBoxWrapper.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RichTextSendBoxWrapper.js","sourceRoot":"","sources":["../../../../../../preprocess-dist/react-composites/src/composites/common/RichTextSendBoxWrapper.tsx"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAClC,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AACjE,OAAO,EAAE,eAAe,EAAwB,yCAAmC;AACnF;;;;;GAKG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,KAA2B,EAAe,EAAE;IACjF,MAAM,oBAAoB,GAAG,WAAW,CAAC,eAAe,CAAC,CAAC;IAC1D,OAAO,oBAAC,eAAe,oBAAK,oBAAoB,EAAM,KAAK,EAAI,CAAC;AAClE,CAAC,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\nimport React from 'react';\nimport { usePropsFor } from '../ChatComposite/hooks/usePropsFor';\nimport { RichTextSendBox, RichTextSendBoxProps } from '@internal/react-components';\n/**\n * @private\n *\n * Wrapper for RichTextSendBox component to allow us to use usePropsFor with richTextSendBox\n * before lazyLoading is done\n */\nexport const RichTextSendBoxWrapper = (props: RichTextSendBoxProps): JSX.Element => {\n const richTextSendBoxProps = usePropsFor(RichTextSendBox);\n return <RichTextSendBox {...richTextSendBoxProps} {...props} />;\n};"]}