@liveblocks/react-ui 2.14.0 → 2.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.
Files changed (272) hide show
  1. package/dist/_private/index.d.mts +24 -22
  2. package/dist/_private/index.d.ts +24 -22
  3. package/dist/_private/index.js +1 -0
  4. package/dist/_private/index.js.map +1 -1
  5. package/dist/_private/index.mjs +1 -0
  6. package/dist/_private/index.mjs.map +1 -1
  7. package/dist/components/Comment.js +358 -256
  8. package/dist/components/Comment.js.map +1 -1
  9. package/dist/components/Comment.mjs +334 -232
  10. package/dist/components/Comment.mjs.map +1 -1
  11. package/dist/components/Composer.js +308 -225
  12. package/dist/components/Composer.js.map +1 -1
  13. package/dist/components/Composer.mjs +288 -206
  14. package/dist/components/Composer.mjs.map +1 -1
  15. package/dist/components/HistoryVersionSummary.js +28 -32
  16. package/dist/components/HistoryVersionSummary.js.map +1 -1
  17. package/dist/components/HistoryVersionSummary.mjs +27 -31
  18. package/dist/components/HistoryVersionSummary.mjs.map +1 -1
  19. package/dist/components/HistoryVersionSummaryList.js +11 -9
  20. package/dist/components/HistoryVersionSummaryList.js.map +1 -1
  21. package/dist/components/HistoryVersionSummaryList.mjs +10 -8
  22. package/dist/components/HistoryVersionSummaryList.mjs.map +1 -1
  23. package/dist/components/InboxNotification.js +202 -143
  24. package/dist/components/InboxNotification.js.map +1 -1
  25. package/dist/components/InboxNotification.mjs +180 -121
  26. package/dist/components/InboxNotification.mjs.map +1 -1
  27. package/dist/components/InboxNotificationList.js +19 -14
  28. package/dist/components/InboxNotificationList.js.map +1 -1
  29. package/dist/components/InboxNotificationList.mjs +17 -12
  30. package/dist/components/InboxNotificationList.mjs.map +1 -1
  31. package/dist/components/Thread.js +104 -86
  32. package/dist/components/Thread.js.map +1 -1
  33. package/dist/components/Thread.mjs +93 -75
  34. package/dist/components/Thread.mjs.map +1 -1
  35. package/dist/components/internal/Attachment.js +161 -113
  36. package/dist/components/internal/Attachment.js.map +1 -1
  37. package/dist/components/internal/Attachment.mjs +150 -102
  38. package/dist/components/internal/Attachment.mjs.map +1 -1
  39. package/dist/components/internal/Attribution.js +15 -13
  40. package/dist/components/internal/Attribution.js.map +1 -1
  41. package/dist/components/internal/Attribution.mjs +15 -13
  42. package/dist/components/internal/Attribution.mjs.map +1 -1
  43. package/dist/components/internal/Avatar.js +27 -20
  44. package/dist/components/internal/Avatar.js.map +1 -1
  45. package/dist/components/internal/Avatar.mjs +23 -16
  46. package/dist/components/internal/Avatar.mjs.map +1 -1
  47. package/dist/components/internal/Button.js +5 -4
  48. package/dist/components/internal/Button.js.map +1 -1
  49. package/dist/components/internal/Button.mjs +4 -3
  50. package/dist/components/internal/Button.mjs.map +1 -1
  51. package/dist/components/internal/Dropdown.js +27 -19
  52. package/dist/components/internal/Dropdown.js.map +1 -1
  53. package/dist/components/internal/Dropdown.mjs +26 -18
  54. package/dist/components/internal/Dropdown.mjs.map +1 -1
  55. package/dist/components/internal/Emoji.js +4 -3
  56. package/dist/components/internal/Emoji.js.map +1 -1
  57. package/dist/components/internal/Emoji.mjs +3 -2
  58. package/dist/components/internal/Emoji.mjs.map +1 -1
  59. package/dist/components/internal/EmojiPicker.js +96 -72
  60. package/dist/components/internal/EmojiPicker.js.map +1 -1
  61. package/dist/components/internal/EmojiPicker.mjs +90 -66
  62. package/dist/components/internal/EmojiPicker.mjs.map +1 -1
  63. package/dist/components/internal/Icon.js +5 -4
  64. package/dist/components/internal/Icon.js.map +1 -1
  65. package/dist/components/internal/Icon.mjs +5 -4
  66. package/dist/components/internal/Icon.mjs.map +1 -1
  67. package/dist/components/internal/InboxNotificationThread.js +53 -38
  68. package/dist/components/internal/InboxNotificationThread.js.map +1 -1
  69. package/dist/components/internal/InboxNotificationThread.mjs +53 -38
  70. package/dist/components/internal/InboxNotificationThread.mjs.map +1 -1
  71. package/dist/components/internal/List.js +8 -6
  72. package/dist/components/internal/List.js.map +1 -1
  73. package/dist/components/internal/List.mjs +6 -4
  74. package/dist/components/internal/List.mjs.map +1 -1
  75. package/dist/components/internal/Room.js +8 -6
  76. package/dist/components/internal/Room.js.map +1 -1
  77. package/dist/components/internal/Room.mjs +7 -5
  78. package/dist/components/internal/Room.mjs.map +1 -1
  79. package/dist/components/internal/Tooltip.js +49 -33
  80. package/dist/components/internal/Tooltip.js.map +1 -1
  81. package/dist/components/internal/Tooltip.mjs +46 -30
  82. package/dist/components/internal/Tooltip.mjs.map +1 -1
  83. package/dist/components/internal/User.js +8 -6
  84. package/dist/components/internal/User.js.map +1 -1
  85. package/dist/components/internal/User.mjs +7 -5
  86. package/dist/components/internal/User.mjs.map +1 -1
  87. package/dist/components.js +12 -29
  88. package/dist/components.js.map +1 -1
  89. package/dist/components.mjs +6 -5
  90. package/dist/components.mjs.map +1 -1
  91. package/dist/config.js +16 -12
  92. package/dist/config.js.map +1 -1
  93. package/dist/config.mjs +13 -9
  94. package/dist/config.mjs.map +1 -1
  95. package/dist/icons/ArrowDown.js +7 -6
  96. package/dist/icons/ArrowDown.js.map +1 -1
  97. package/dist/icons/ArrowDown.mjs +7 -6
  98. package/dist/icons/ArrowDown.mjs.map +1 -1
  99. package/dist/icons/ArrowUp.js +7 -6
  100. package/dist/icons/ArrowUp.js.map +1 -1
  101. package/dist/icons/ArrowUp.mjs +7 -6
  102. package/dist/icons/ArrowUp.mjs.map +1 -1
  103. package/dist/icons/Attachment.js +7 -6
  104. package/dist/icons/Attachment.js.map +1 -1
  105. package/dist/icons/Attachment.mjs +7 -6
  106. package/dist/icons/Attachment.mjs.map +1 -1
  107. package/dist/icons/Bold.js +7 -6
  108. package/dist/icons/Bold.js.map +1 -1
  109. package/dist/icons/Bold.mjs +7 -6
  110. package/dist/icons/Bold.mjs.map +1 -1
  111. package/dist/icons/Check.js +7 -6
  112. package/dist/icons/Check.js.map +1 -1
  113. package/dist/icons/Check.mjs +7 -6
  114. package/dist/icons/Check.mjs.map +1 -1
  115. package/dist/icons/Code.js +7 -6
  116. package/dist/icons/Code.js.map +1 -1
  117. package/dist/icons/Code.mjs +7 -6
  118. package/dist/icons/Code.mjs.map +1 -1
  119. package/dist/icons/Cross.js +12 -8
  120. package/dist/icons/Cross.js.map +1 -1
  121. package/dist/icons/Cross.mjs +12 -8
  122. package/dist/icons/Cross.mjs.map +1 -1
  123. package/dist/icons/Delete.js +7 -6
  124. package/dist/icons/Delete.js.map +1 -1
  125. package/dist/icons/Delete.mjs +7 -6
  126. package/dist/icons/Delete.mjs.map +1 -1
  127. package/dist/icons/Edit.js +7 -6
  128. package/dist/icons/Edit.js.map +1 -1
  129. package/dist/icons/Edit.mjs +7 -6
  130. package/dist/icons/Edit.mjs.map +1 -1
  131. package/dist/icons/Ellipsis.js +21 -16
  132. package/dist/icons/Ellipsis.js.map +1 -1
  133. package/dist/icons/Ellipsis.mjs +21 -16
  134. package/dist/icons/Ellipsis.mjs.map +1 -1
  135. package/dist/icons/Emoji.js +25 -18
  136. package/dist/icons/Emoji.js.map +1 -1
  137. package/dist/icons/Emoji.mjs +25 -18
  138. package/dist/icons/Emoji.mjs.map +1 -1
  139. package/dist/icons/EmojiAdd.js +28 -20
  140. package/dist/icons/EmojiAdd.js.map +1 -1
  141. package/dist/icons/EmojiAdd.mjs +28 -20
  142. package/dist/icons/EmojiAdd.mjs.map +1 -1
  143. package/dist/icons/Italic.js +7 -6
  144. package/dist/icons/Italic.js.map +1 -1
  145. package/dist/icons/Italic.mjs +7 -6
  146. package/dist/icons/Italic.mjs.map +1 -1
  147. package/dist/icons/Mention.js +12 -8
  148. package/dist/icons/Mention.js.map +1 -1
  149. package/dist/icons/Mention.mjs +12 -8
  150. package/dist/icons/Mention.mjs.map +1 -1
  151. package/dist/icons/Resolve.js +14 -10
  152. package/dist/icons/Resolve.js.map +1 -1
  153. package/dist/icons/Resolve.mjs +14 -10
  154. package/dist/icons/Resolve.mjs.map +1 -1
  155. package/dist/icons/Resolved.js +16 -12
  156. package/dist/icons/Resolved.js.map +1 -1
  157. package/dist/icons/Resolved.mjs +16 -12
  158. package/dist/icons/Resolved.mjs.map +1 -1
  159. package/dist/icons/Restore.js +12 -8
  160. package/dist/icons/Restore.js.map +1 -1
  161. package/dist/icons/Restore.mjs +12 -8
  162. package/dist/icons/Restore.mjs.map +1 -1
  163. package/dist/icons/Search.js +7 -6
  164. package/dist/icons/Search.js.map +1 -1
  165. package/dist/icons/Search.mjs +7 -6
  166. package/dist/icons/Search.mjs.map +1 -1
  167. package/dist/icons/Send.js +7 -6
  168. package/dist/icons/Send.js.map +1 -1
  169. package/dist/icons/Send.mjs +7 -6
  170. package/dist/icons/Send.mjs.map +1 -1
  171. package/dist/icons/Spinner.js +8 -7
  172. package/dist/icons/Spinner.js.map +1 -1
  173. package/dist/icons/Spinner.mjs +8 -7
  174. package/dist/icons/Spinner.mjs.map +1 -1
  175. package/dist/icons/Strikethrough.js +7 -6
  176. package/dist/icons/Strikethrough.js.map +1 -1
  177. package/dist/icons/Strikethrough.mjs +7 -6
  178. package/dist/icons/Strikethrough.mjs.map +1 -1
  179. package/dist/icons/Warning.js +14 -10
  180. package/dist/icons/Warning.js.map +1 -1
  181. package/dist/icons/Warning.mjs +14 -10
  182. package/dist/icons/Warning.mjs.map +1 -1
  183. package/dist/icons/index.js +42 -0
  184. package/dist/icons/index.js.map +1 -0
  185. package/dist/icons/index.mjs +19 -0
  186. package/dist/icons/index.mjs.map +1 -0
  187. package/dist/index.d.mts +14 -12
  188. package/dist/index.d.ts +14 -12
  189. package/dist/overrides.js +65 -36
  190. package/dist/overrides.js.map +1 -1
  191. package/dist/overrides.mjs +59 -12
  192. package/dist/overrides.mjs.map +1 -1
  193. package/dist/primitives/Comment/index.js +75 -66
  194. package/dist/primitives/Comment/index.js.map +1 -1
  195. package/dist/primitives/Comment/index.mjs +71 -62
  196. package/dist/primitives/Comment/index.mjs.map +1 -1
  197. package/dist/primitives/Composer/contexts.js +11 -11
  198. package/dist/primitives/Composer/index.js +343 -284
  199. package/dist/primitives/Composer/index.js.map +1 -1
  200. package/dist/primitives/Composer/index.mjs +262 -203
  201. package/dist/primitives/Composer/index.mjs.map +1 -1
  202. package/dist/primitives/Composer/utils.js +20 -21
  203. package/dist/primitives/Composer/utils.js.map +1 -1
  204. package/dist/primitives/Composer/utils.mjs +4 -5
  205. package/dist/primitives/Composer/utils.mjs.map +1 -1
  206. package/dist/primitives/EmojiPicker/contexts.js +3 -3
  207. package/dist/primitives/EmojiPicker/index.js +160 -142
  208. package/dist/primitives/EmojiPicker/index.js.map +1 -1
  209. package/dist/primitives/EmojiPicker/index.mjs +122 -104
  210. package/dist/primitives/EmojiPicker/index.mjs.map +1 -1
  211. package/dist/primitives/FileSize.js +9 -7
  212. package/dist/primitives/FileSize.js.map +1 -1
  213. package/dist/primitives/FileSize.mjs +7 -5
  214. package/dist/primitives/FileSize.mjs.map +1 -1
  215. package/dist/primitives/Timestamp.js +12 -10
  216. package/dist/primitives/Timestamp.js.map +1 -1
  217. package/dist/primitives/Timestamp.mjs +7 -5
  218. package/dist/primitives/Timestamp.mjs.map +1 -1
  219. package/dist/primitives/index.d.mts +24 -23
  220. package/dist/primitives/index.d.ts +24 -23
  221. package/dist/primitives/internal/Emoji.js +7 -5
  222. package/dist/primitives/internal/Emoji.js.map +1 -1
  223. package/dist/primitives/internal/Emoji.mjs +6 -4
  224. package/dist/primitives/internal/Emoji.mjs.map +1 -1
  225. package/dist/shared.js +2 -7
  226. package/dist/shared.js.map +1 -1
  227. package/dist/shared.mjs +2 -7
  228. package/dist/shared.mjs.map +1 -1
  229. package/dist/slate/plugins/auto-links.mjs +1 -1
  230. package/dist/slate/plugins/custom-links.mjs +1 -1
  231. package/dist/slate/plugins/mentions.mjs +1 -1
  232. package/dist/utils/Persist.js +19 -18
  233. package/dist/utils/Persist.js.map +1 -1
  234. package/dist/utils/Persist.mjs +7 -6
  235. package/dist/utils/Persist.mjs.map +1 -1
  236. package/dist/utils/Portal.js +5 -4
  237. package/dist/utils/Portal.js.map +1 -1
  238. package/dist/utils/Portal.mjs +4 -3
  239. package/dist/utils/Portal.mjs.map +1 -1
  240. package/dist/utils/use-controllable-state.js +5 -5
  241. package/dist/utils/use-index.js +7 -7
  242. package/dist/utils/use-initial.js +2 -2
  243. package/dist/utils/use-interval.js +4 -4
  244. package/dist/utils/use-latest.js +3 -3
  245. package/dist/utils/use-observable.js +2 -2
  246. package/dist/utils/use-refs.js +2 -2
  247. package/dist/utils/use-rerender.js +2 -2
  248. package/dist/utils/use-visible.js +24 -2
  249. package/dist/utils/use-visible.js.map +1 -1
  250. package/dist/utils/use-visible.mjs +23 -2
  251. package/dist/utils/use-visible.mjs.map +1 -1
  252. package/dist/utils/use-window-focus.js +2 -2
  253. package/dist/utils/use-window-focus.js.map +1 -1
  254. package/dist/utils/use-window-focus.mjs +1 -1
  255. package/dist/utils/use-window-focus.mjs.map +1 -1
  256. package/dist/version.js +2 -2
  257. package/dist/version.js.map +1 -1
  258. package/dist/version.mjs +2 -2
  259. package/dist/version.mjs.map +1 -1
  260. package/package.json +10 -25
  261. package/dist/utils/use-id.js +0 -29
  262. package/dist/utils/use-id.js.map +0 -1
  263. package/dist/utils/use-id.mjs +0 -27
  264. package/dist/utils/use-id.mjs.map +0 -1
  265. package/dist/utils/use-layout-effect.js +0 -8
  266. package/dist/utils/use-layout-effect.js.map +0 -1
  267. package/dist/utils/use-layout-effect.mjs +0 -6
  268. package/dist/utils/use-layout-effect.mjs.map +0 -1
  269. package/dist/utils/use-transition.js +0 -16
  270. package/dist/utils/use-transition.js.map +0 -1
  271. package/dist/utils/use-transition.mjs +0 -14
  272. package/dist/utils/use-transition.mjs.map +0 -1
@@ -1,9 +1,7 @@
1
- 'use client';
2
- import { kInternal, Permission } from '@liveblocks/core';
3
- import { useClient } from '@liveblocks/react';
4
- import { useRoomOrNull, useCreateRoomThread, useCreateRoomComment, useEditRoomComment, useRoomPermissions } from '@liveblocks/react/_private';
5
- import React__default, { createContext, forwardRef, useRef, useCallback, useMemo } from 'react';
6
- import { useSyncExternalStore } from 'use-sync-external-store/shim/index.js';
1
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
+ import { Permission } from '@liveblocks/core';
3
+ import { useRoomOrNull, useCreateRoomThread, useCreateRoomComment, useEditRoomComment, useResolveMentionSuggestions, useRoomPermissions } from '@liveblocks/react/_private';
4
+ import { useCallback, useMemo, useLayoutEffect, createContext, forwardRef, useRef, useSyncExternalStore } from 'react';
7
5
  import { useLiveblocksUIConfig } from '../config.mjs';
8
6
  import { FLOATING_ELEMENT_SIDE_OFFSET } from '../constants.mjs';
9
7
  import { AttachmentIcon } from '../icons/Attachment.mjs';
@@ -15,23 +13,23 @@ import { MentionIcon } from '../icons/Mention.mjs';
15
13
  import { SendIcon } from '../icons/Send.mjs';
16
14
  import { StrikethroughIcon } from '../icons/Strikethrough.mjs';
17
15
  import { useOverrides } from '../overrides.mjs';
18
- import { Form as ComposerForm, Editor as ComposerEditor, Submit as ComposerSubmit, AttachFiles as ComposerAttachFiles, MarkToggle as ComposerMarkToggle, FloatingToolbar as ComposerFloatingToolbar$1, Mention as ComposerMention$1, Suggestions as ComposerSuggestions, SuggestionsList as ComposerSuggestionsList, SuggestionsListItem as ComposerSuggestionsListItem, Link as ComposerLink$1 } from '../primitives/Composer/index.mjs';
19
- import { useComposer, useComposerAttachmentsContext, useComposerEditorContext } from '../primitives/Composer/contexts.mjs';
16
+ import { AttachFiles as ComposerAttachFiles, Mention as ComposerMention$1, Suggestions as ComposerSuggestions, SuggestionsList as ComposerSuggestionsList, SuggestionsListItem as ComposerSuggestionsListItem, MarkToggle as ComposerMarkToggle, FloatingToolbar as ComposerFloatingToolbar$1, Link as ComposerLink$1, Editor as ComposerEditor, Submit as ComposerSubmit, Form as ComposerForm } from '../primitives/Composer/index.mjs';
17
+ import { useComposer, useComposerEditorContext, useComposerAttachmentsContext } from '../primitives/Composer/contexts.mjs';
20
18
  import { useComposerAttachmentsDropArea } from '../primitives/Composer/utils.mjs';
21
19
  import { MENTION_CHARACTER } from '../slate/plugins/mentions.mjs';
22
20
  import { classNames } from '../utils/class-names.mjs';
23
21
  import { useControllableState } from '../utils/use-controllable-state.mjs';
24
- import { useLayoutEffect } from '../utils/use-layout-effect.mjs';
25
22
  import { FileAttachment } from './internal/Attachment.mjs';
26
23
  import { Attribution } from './internal/Attribution.mjs';
27
24
  import { Avatar } from './internal/Avatar.mjs';
28
25
  import { Button } from './internal/Button.mjs';
29
26
  import { EmojiPicker } from './internal/EmojiPicker.mjs';
30
- import { ShortcutTooltipKey, ShortcutTooltip, Tooltip } from './internal/Tooltip.mjs';
27
+ import { Tooltip, ShortcutTooltip, ShortcutTooltipKey } from './internal/Tooltip.mjs';
31
28
  import { User } from './internal/User.mjs';
32
- import { TooltipProvider } from '@radix-ui/react-tooltip';
33
29
  import { PopoverTrigger } from '@radix-ui/react-popover';
30
+ import { TooltipProvider } from '@radix-ui/react-tooltip';
34
31
 
32
+ "use client";
35
33
  function ComposerInsertMentionEditorAction({
36
34
  label,
37
35
  tooltipLabel,
@@ -53,17 +51,19 @@ function ComposerInsertMentionEditorAction({
53
51
  },
54
52
  [createMention, onClick]
55
53
  );
56
- return /* @__PURE__ */ React__default.createElement(Tooltip, {
57
- content: tooltipLabel ?? label
58
- }, /* @__PURE__ */ React__default.createElement(Button, {
59
- className: classNames("lb-composer-editor-action", className),
60
- onPointerDown: preventDefault,
61
- onClick: handleClick,
62
- "aria-label": label,
63
- ...props
64
- }, /* @__PURE__ */ React__default.createElement(MentionIcon, {
65
- className: "lb-button-icon"
66
- })));
54
+ return /* @__PURE__ */ jsx(Tooltip, {
55
+ content: tooltipLabel ?? label,
56
+ children: /* @__PURE__ */ jsx(Button, {
57
+ className: classNames("lb-composer-editor-action", className),
58
+ onPointerDown: preventDefault,
59
+ onClick: handleClick,
60
+ "aria-label": label,
61
+ ...props,
62
+ children: /* @__PURE__ */ jsx(MentionIcon, {
63
+ className: "lb-button-icon"
64
+ })
65
+ })
66
+ });
67
67
  }
68
68
  function ComposerInsertEmojiEditorAction({
69
69
  label,
@@ -79,22 +79,26 @@ function ComposerInsertEmojiEditorAction({
79
79
  const stopPropagation = useCallback((event) => {
80
80
  event.stopPropagation();
81
81
  }, []);
82
- return /* @__PURE__ */ React__default.createElement(EmojiPicker, {
82
+ return /* @__PURE__ */ jsx(EmojiPicker, {
83
83
  onEmojiSelect: insertText,
84
- onOpenChange: onPickerOpenChange
85
- }, /* @__PURE__ */ React__default.createElement(Tooltip, {
86
- content: tooltipLabel ?? label
87
- }, /* @__PURE__ */ React__default.createElement(PopoverTrigger, {
88
- asChild: true
89
- }, /* @__PURE__ */ React__default.createElement(Button, {
90
- className: classNames("lb-composer-editor-action", className),
91
- onPointerDown: preventDefault,
92
- onClick: stopPropagation,
93
- "aria-label": label,
94
- ...props
95
- }, /* @__PURE__ */ React__default.createElement(EmojiIcon, {
96
- className: "lb-button-icon"
97
- })))));
84
+ onOpenChange: onPickerOpenChange,
85
+ children: /* @__PURE__ */ jsx(Tooltip, {
86
+ content: tooltipLabel ?? label,
87
+ children: /* @__PURE__ */ jsx(PopoverTrigger, {
88
+ asChild: true,
89
+ children: /* @__PURE__ */ jsx(Button, {
90
+ className: classNames("lb-composer-editor-action", className),
91
+ onPointerDown: preventDefault,
92
+ onClick: stopPropagation,
93
+ "aria-label": label,
94
+ ...props,
95
+ children: /* @__PURE__ */ jsx(EmojiIcon, {
96
+ className: "lb-button-icon"
97
+ })
98
+ })
99
+ })
100
+ })
101
+ });
98
102
  }
99
103
  function ComposerAttachFilesEditorAction({
100
104
  label,
@@ -108,105 +112,153 @@ function ComposerAttachFilesEditorAction({
108
112
  const stopPropagation = useCallback((event) => {
109
113
  event.stopPropagation();
110
114
  }, []);
111
- return /* @__PURE__ */ React__default.createElement(Tooltip, {
112
- content: tooltipLabel ?? label
113
- }, /* @__PURE__ */ React__default.createElement(ComposerAttachFiles, {
114
- asChild: true
115
- }, /* @__PURE__ */ React__default.createElement(Button, {
116
- className: classNames("lb-composer-editor-action", className),
117
- onPointerDown: preventDefault,
118
- onClick: stopPropagation,
119
- "aria-label": label,
120
- ...props
121
- }, /* @__PURE__ */ React__default.createElement(AttachmentIcon, {
122
- className: "lb-button-icon"
123
- }))));
115
+ return /* @__PURE__ */ jsx(Tooltip, {
116
+ content: tooltipLabel ?? label,
117
+ children: /* @__PURE__ */ jsx(ComposerAttachFiles, {
118
+ asChild: true,
119
+ children: /* @__PURE__ */ jsx(Button, {
120
+ className: classNames("lb-composer-editor-action", className),
121
+ onPointerDown: preventDefault,
122
+ onClick: stopPropagation,
123
+ "aria-label": label,
124
+ ...props,
125
+ children: /* @__PURE__ */ jsx(AttachmentIcon, {
126
+ className: "lb-button-icon"
127
+ })
128
+ })
129
+ })
130
+ });
124
131
  }
125
132
  function ComposerMention({ userId }) {
126
- return /* @__PURE__ */ React__default.createElement(ComposerMention$1, {
127
- className: "lb-composer-mention"
128
- }, MENTION_CHARACTER, /* @__PURE__ */ React__default.createElement(User, {
129
- userId
130
- }));
133
+ return /* @__PURE__ */ jsxs(ComposerMention$1, {
134
+ className: "lb-composer-mention",
135
+ children: [
136
+ MENTION_CHARACTER,
137
+ /* @__PURE__ */ jsx(User, {
138
+ userId
139
+ })
140
+ ]
141
+ });
131
142
  }
132
143
  function ComposerMentionSuggestions({
133
144
  userIds
134
145
  }) {
135
- return userIds.length > 0 ? /* @__PURE__ */ React__default.createElement(ComposerSuggestions, {
136
- className: "lb-root lb-portal lb-elevation lb-composer-suggestions lb-composer-mention-suggestions"
137
- }, /* @__PURE__ */ React__default.createElement(ComposerSuggestionsList, {
138
- className: "lb-composer-suggestions-list lb-composer-mention-suggestions-list"
139
- }, userIds.map((userId) => /* @__PURE__ */ React__default.createElement(ComposerSuggestionsListItem, {
140
- key: userId,
141
- className: "lb-composer-suggestions-list-item lb-composer-mention-suggestion",
142
- value: userId
143
- }, /* @__PURE__ */ React__default.createElement(Avatar, {
144
- userId,
145
- className: "lb-composer-mention-suggestion-avatar"
146
- }), /* @__PURE__ */ React__default.createElement(User, {
147
- userId,
148
- className: "lb-composer-mention-suggestion-user"
149
- }))))) : null;
146
+ return userIds.length > 0 ? /* @__PURE__ */ jsx(ComposerSuggestions, {
147
+ className: "lb-root lb-portal lb-elevation lb-composer-suggestions lb-composer-mention-suggestions",
148
+ children: /* @__PURE__ */ jsx(ComposerSuggestionsList, {
149
+ className: "lb-composer-suggestions-list lb-composer-mention-suggestions-list",
150
+ children: userIds.map((userId) => /* @__PURE__ */ jsxs(ComposerSuggestionsListItem, {
151
+ className: "lb-composer-suggestions-list-item lb-composer-mention-suggestion",
152
+ value: userId,
153
+ children: [
154
+ /* @__PURE__ */ jsx(Avatar, {
155
+ userId,
156
+ className: "lb-composer-mention-suggestion-avatar"
157
+ }),
158
+ /* @__PURE__ */ jsx(User, {
159
+ userId,
160
+ className: "lb-composer-mention-suggestion-user"
161
+ })
162
+ ]
163
+ }, userId))
164
+ })
165
+ }) : null;
150
166
  }
151
167
  function MarkToggle({ mark, shortcut, children, ...props }) {
152
168
  const $ = useOverrides();
153
169
  const label = useMemo(() => {
154
170
  return $.COMPOSER_TOGGLE_MARK(mark);
155
171
  }, [$, mark]);
156
- return /* @__PURE__ */ React__default.createElement(ShortcutTooltip, {
172
+ return /* @__PURE__ */ jsx(ShortcutTooltip, {
157
173
  content: label,
158
174
  shortcut,
159
- sideOffset: FLOATING_ELEMENT_SIDE_OFFSET + 2
160
- }, /* @__PURE__ */ React__default.createElement(ComposerMarkToggle, {
161
- mark,
162
- asChild: true,
163
- ...props
164
- }, /* @__PURE__ */ React__default.createElement(Button, {
165
- "aria-label": label,
166
- variant: "toggle"
167
- }, children)));
175
+ sideOffset: FLOATING_ELEMENT_SIDE_OFFSET + 2,
176
+ children: /* @__PURE__ */ jsx(ComposerMarkToggle, {
177
+ mark,
178
+ asChild: true,
179
+ ...props,
180
+ children: /* @__PURE__ */ jsx(Button, {
181
+ "aria-label": label,
182
+ variant: "toggle",
183
+ children
184
+ })
185
+ })
186
+ });
168
187
  }
169
188
  const markToggles = {
170
- bold: () => /* @__PURE__ */ React__default.createElement(MarkToggle, {
189
+ bold: () => /* @__PURE__ */ jsx(MarkToggle, {
171
190
  mark: "bold",
172
- shortcut: /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
173
- name: "mod"
174
- }), /* @__PURE__ */ React__default.createElement("span", null, "B"))
175
- }, /* @__PURE__ */ React__default.createElement(BoldIcon, null)),
176
- italic: () => /* @__PURE__ */ React__default.createElement(MarkToggle, {
191
+ shortcut: /* @__PURE__ */ jsxs(Fragment, {
192
+ children: [
193
+ /* @__PURE__ */ jsx(ShortcutTooltipKey, {
194
+ name: "mod"
195
+ }),
196
+ /* @__PURE__ */ jsx("span", {
197
+ children: "B"
198
+ })
199
+ ]
200
+ }),
201
+ children: /* @__PURE__ */ jsx(BoldIcon, {})
202
+ }),
203
+ italic: () => /* @__PURE__ */ jsx(MarkToggle, {
177
204
  mark: "italic",
178
- shortcut: /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
179
- name: "mod"
180
- }), /* @__PURE__ */ React__default.createElement("span", null, "I"))
181
- }, /* @__PURE__ */ React__default.createElement(ItalicIcon, null)),
182
- strikethrough: () => /* @__PURE__ */ React__default.createElement(MarkToggle, {
205
+ shortcut: /* @__PURE__ */ jsxs(Fragment, {
206
+ children: [
207
+ /* @__PURE__ */ jsx(ShortcutTooltipKey, {
208
+ name: "mod"
209
+ }),
210
+ /* @__PURE__ */ jsx("span", {
211
+ children: "I"
212
+ })
213
+ ]
214
+ }),
215
+ children: /* @__PURE__ */ jsx(ItalicIcon, {})
216
+ }),
217
+ strikethrough: () => /* @__PURE__ */ jsx(MarkToggle, {
183
218
  mark: "strikethrough",
184
- shortcut: /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
185
- name: "mod"
186
- }), /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
187
- name: "shift"
188
- }), /* @__PURE__ */ React__default.createElement("span", null, "S"))
189
- }, /* @__PURE__ */ React__default.createElement(StrikethroughIcon, null)),
190
- code: () => /* @__PURE__ */ React__default.createElement(MarkToggle, {
219
+ shortcut: /* @__PURE__ */ jsxs(Fragment, {
220
+ children: [
221
+ /* @__PURE__ */ jsx(ShortcutTooltipKey, {
222
+ name: "mod"
223
+ }),
224
+ /* @__PURE__ */ jsx(ShortcutTooltipKey, {
225
+ name: "shift"
226
+ }),
227
+ /* @__PURE__ */ jsx("span", {
228
+ children: "S"
229
+ })
230
+ ]
231
+ }),
232
+ children: /* @__PURE__ */ jsx(StrikethroughIcon, {})
233
+ }),
234
+ code: () => /* @__PURE__ */ jsx(MarkToggle, {
191
235
  mark: "code",
192
- shortcut: /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
193
- name: "mod"
194
- }), /* @__PURE__ */ React__default.createElement("span", null, "E"))
195
- }, /* @__PURE__ */ React__default.createElement(CodeIcon, null))
236
+ shortcut: /* @__PURE__ */ jsxs(Fragment, {
237
+ children: [
238
+ /* @__PURE__ */ jsx(ShortcutTooltipKey, {
239
+ name: "mod"
240
+ }),
241
+ /* @__PURE__ */ jsx("span", {
242
+ children: "E"
243
+ })
244
+ ]
245
+ }),
246
+ children: /* @__PURE__ */ jsx(CodeIcon, {})
247
+ })
196
248
  };
197
- const markTogglesList = Object.entries(markToggles).map(([mark, Toggle]) => /* @__PURE__ */ React__default.createElement(Toggle, {
198
- key: mark
199
- }));
249
+ const markTogglesList = Object.entries(markToggles).map(([mark, Toggle]) => /* @__PURE__ */ jsx(Toggle, {}, mark));
200
250
  function ComposerFloatingToolbar() {
201
- return /* @__PURE__ */ React__default.createElement(ComposerFloatingToolbar$1, {
202
- className: "lb-root lb-portal lb-elevation lb-composer-floating-toolbar"
203
- }, markTogglesList);
251
+ return /* @__PURE__ */ jsx(ComposerFloatingToolbar$1, {
252
+ className: "lb-root lb-portal lb-elevation lb-composer-floating-toolbar",
253
+ children: markTogglesList
254
+ });
204
255
  }
205
256
  function ComposerLink({ href, children }) {
206
- return /* @__PURE__ */ React__default.createElement(ComposerLink$1, {
257
+ return /* @__PURE__ */ jsx(ComposerLink$1, {
207
258
  href,
208
- className: "lb-composer-link"
209
- }, children);
259
+ className: "lb-composer-link",
260
+ children
261
+ });
210
262
  }
211
263
  function ComposerFileAttachment({
212
264
  attachment,
@@ -219,7 +271,7 @@ function ComposerFileAttachment({
219
271
  const handleDeleteClick = useCallback(() => {
220
272
  removeAttachment(attachment.id);
221
273
  }, [attachment.id, removeAttachment]);
222
- return /* @__PURE__ */ React__default.createElement(FileAttachment, {
274
+ return /* @__PURE__ */ jsx(FileAttachment, {
223
275
  className: classNames("lb-composer-attachment", className),
224
276
  ...props,
225
277
  attachment,
@@ -238,18 +290,19 @@ function ComposerAttachments({
238
290
  if (attachments.length === 0) {
239
291
  return null;
240
292
  }
241
- return /* @__PURE__ */ React__default.createElement("div", {
293
+ return /* @__PURE__ */ jsx("div", {
242
294
  className: classNames("lb-composer-attachments", className),
243
- ...props
244
- }, /* @__PURE__ */ React__default.createElement("div", {
245
- className: "lb-attachments"
246
- }, attachments.map((attachment) => {
247
- return /* @__PURE__ */ React__default.createElement(ComposerFileAttachment, {
248
- key: attachment.id,
249
- attachment,
250
- overrides
251
- });
252
- })));
295
+ ...props,
296
+ children: /* @__PURE__ */ jsx("div", {
297
+ className: "lb-attachments",
298
+ children: attachments.map((attachment) => {
299
+ return /* @__PURE__ */ jsx(ComposerFileAttachment, {
300
+ attachment,
301
+ overrides
302
+ }, attachment.id);
303
+ })
304
+ })
305
+ });
253
306
  }
254
307
  const editorRequiredComponents = {
255
308
  Mention: ComposerMention,
@@ -292,56 +345,83 @@ function ComposerEditorContainer({
292
345
  const stopPropagation = useCallback((event) => {
293
346
  event.stopPropagation();
294
347
  }, []);
295
- return /* @__PURE__ */ React__default.createElement("div", {
348
+ return /* @__PURE__ */ jsxs("div", {
296
349
  className: "lb-composer-editor-container",
297
- ...dropAreaProps
298
- }, /* @__PURE__ */ React__default.createElement(ComposerEditor, {
299
- className: "lb-composer-editor",
300
- onClick: onEditorClick,
301
- placeholder: $.COMPOSER_PLACEHOLDER,
302
- defaultValue,
303
- autoFocus,
304
- components,
305
- disabled,
306
- dir: $.dir
307
- }), showAttachments && /* @__PURE__ */ React__default.createElement(ComposerAttachments, {
308
- overrides
309
- }), (!isCollapsed || isDraggingOver) && /* @__PURE__ */ React__default.createElement("div", {
310
- className: "lb-composer-footer"
311
- }, /* @__PURE__ */ React__default.createElement("div", {
312
- className: "lb-composer-editor-actions"
313
- }, hasResolveMentionSuggestions && /* @__PURE__ */ React__default.createElement(ComposerInsertMentionEditorAction, {
314
- label: $.COMPOSER_INSERT_MENTION,
315
- disabled
316
- }), /* @__PURE__ */ React__default.createElement(ComposerInsertEmojiEditorAction, {
317
- label: $.COMPOSER_INSERT_EMOJI,
318
- onPickerOpenChange: onEmojiPickerOpenChange,
319
- disabled
320
- }), showAttachments && /* @__PURE__ */ React__default.createElement(ComposerAttachFilesEditorAction, {
321
- label: $.COMPOSER_ATTACH_FILES,
322
- disabled
323
- })), showAttribution && /* @__PURE__ */ React__default.createElement(Attribution, null), /* @__PURE__ */ React__default.createElement("div", {
324
- className: "lb-composer-actions"
325
- }, actions ?? /* @__PURE__ */ React__default.createElement(React__default.Fragment, null, /* @__PURE__ */ React__default.createElement(ShortcutTooltip, {
326
- content: $.COMPOSER_SEND,
327
- shortcut: /* @__PURE__ */ React__default.createElement(ShortcutTooltipKey, {
328
- name: "enter"
329
- })
330
- }, /* @__PURE__ */ React__default.createElement(ComposerSubmit, {
331
- asChild: true
332
- }, /* @__PURE__ */ React__default.createElement(Button, {
333
- onPointerDown: preventDefault,
334
- onClick: stopPropagation,
335
- className: "lb-composer-action",
336
- variant: "primary",
337
- "aria-label": $.COMPOSER_SEND
338
- }, /* @__PURE__ */ React__default.createElement(SendIcon, null))))))), showAttachments && isDraggingOver && /* @__PURE__ */ React__default.createElement("div", {
339
- className: "lb-composer-attachments-drop-area"
340
- }, /* @__PURE__ */ React__default.createElement("div", {
341
- className: "lb-composer-attachments-drop-area-label"
342
- }, /* @__PURE__ */ React__default.createElement(AttachmentIcon, null), $.COMPOSER_ATTACH_FILES)));
350
+ ...dropAreaProps,
351
+ children: [
352
+ /* @__PURE__ */ jsx(ComposerEditor, {
353
+ className: "lb-composer-editor",
354
+ onClick: onEditorClick,
355
+ placeholder: $.COMPOSER_PLACEHOLDER,
356
+ defaultValue,
357
+ autoFocus,
358
+ components,
359
+ disabled,
360
+ dir: $.dir
361
+ }),
362
+ showAttachments && /* @__PURE__ */ jsx(ComposerAttachments, {
363
+ overrides
364
+ }),
365
+ (!isCollapsed || isDraggingOver) && /* @__PURE__ */ jsxs("div", {
366
+ className: "lb-composer-footer",
367
+ children: [
368
+ /* @__PURE__ */ jsxs("div", {
369
+ className: "lb-composer-editor-actions",
370
+ children: [
371
+ hasResolveMentionSuggestions && /* @__PURE__ */ jsx(ComposerInsertMentionEditorAction, {
372
+ label: $.COMPOSER_INSERT_MENTION,
373
+ disabled
374
+ }),
375
+ /* @__PURE__ */ jsx(ComposerInsertEmojiEditorAction, {
376
+ label: $.COMPOSER_INSERT_EMOJI,
377
+ onPickerOpenChange: onEmojiPickerOpenChange,
378
+ disabled
379
+ }),
380
+ showAttachments && /* @__PURE__ */ jsx(ComposerAttachFilesEditorAction, {
381
+ label: $.COMPOSER_ATTACH_FILES,
382
+ disabled
383
+ })
384
+ ]
385
+ }),
386
+ showAttribution && /* @__PURE__ */ jsx(Attribution, {}),
387
+ /* @__PURE__ */ jsx("div", {
388
+ className: "lb-composer-actions",
389
+ children: actions ?? /* @__PURE__ */ jsx(Fragment, {
390
+ children: /* @__PURE__ */ jsx(ShortcutTooltip, {
391
+ content: $.COMPOSER_SEND,
392
+ shortcut: /* @__PURE__ */ jsx(ShortcutTooltipKey, {
393
+ name: "enter"
394
+ }),
395
+ children: /* @__PURE__ */ jsx(ComposerSubmit, {
396
+ asChild: true,
397
+ children: /* @__PURE__ */ jsx(Button, {
398
+ onPointerDown: preventDefault,
399
+ onClick: stopPropagation,
400
+ className: "lb-composer-action",
401
+ variant: "primary",
402
+ "aria-label": $.COMPOSER_SEND,
403
+ children: /* @__PURE__ */ jsx(SendIcon, {})
404
+ })
405
+ })
406
+ })
407
+ })
408
+ })
409
+ ]
410
+ }),
411
+ showAttachments && isDraggingOver && /* @__PURE__ */ jsx("div", {
412
+ className: "lb-composer-attachments-drop-area",
413
+ children: /* @__PURE__ */ jsxs("div", {
414
+ className: "lb-composer-attachments-drop-area-label",
415
+ children: [
416
+ /* @__PURE__ */ jsx(AttachmentIcon, {}),
417
+ $.COMPOSER_ATTACH_FILES
418
+ ]
419
+ })
420
+ })
421
+ ]
422
+ });
343
423
  }
344
- createContext(null);
424
+ const ComposerRoomIdContext = createContext(null);
345
425
  const Composer = forwardRef(
346
426
  ({
347
427
  threadId,
@@ -366,7 +446,6 @@ const Composer = forwardRef(
366
446
  roomId: _roomId,
367
447
  ...props
368
448
  }, forwardedRef) => {
369
- const client = useClient();
370
449
  const room = useRoomOrNull();
371
450
  const roomId = _roomId !== void 0 ? _roomId : room?.id;
372
451
  if (roomId === void 0) {
@@ -378,7 +457,7 @@ const Composer = forwardRef(
378
457
  const createComment = useCreateRoomComment(roomId);
379
458
  const editComment = useEditRoomComment(roomId);
380
459
  const { preventUnsavedComposerChanges } = useLiveblocksUIConfig();
381
- const hasResolveMentionSuggestions = client[kInternal].resolveMentionSuggestions !== void 0;
460
+ const hasResolveMentionSuggestions = useResolveMentionSuggestions() !== void 0;
382
461
  const isEmptyRef = useRef(true);
383
462
  const isEmojiPickerOpenRef = useRef(false);
384
463
  const $ = useOverrides(overrides);
@@ -483,40 +562,43 @@ const Composer = forwardRef(
483
562
  threadId
484
563
  ]
485
564
  );
486
- return /* @__PURE__ */ React__default.createElement(TooltipProvider, null, /* @__PURE__ */ React__default.createElement(ComposerForm, {
487
- onComposerSubmit: handleCommentSubmit,
488
- className: classNames(
489
- "lb-root lb-composer lb-composer-form",
490
- className
491
- ),
492
- dir: $.dir,
493
- ...props,
494
- ref: forwardedRef,
495
- "data-collapsed": isCollapsed ? "" : void 0,
496
- onFocus: handleFocus,
497
- onBlur: handleBlur,
498
- disabled: disabled || !canComment,
499
- defaultAttachments,
500
- pasteFilesAsAttachments: showAttachments,
501
- preventUnsavedChanges: preventUnsavedComposerChanges,
502
- roomId
503
- }, /* @__PURE__ */ React__default.createElement(ComposerEditorContainer, {
504
- defaultValue,
505
- actions,
506
- overrides,
507
- isCollapsed,
508
- showAttachments,
509
- showAttribution,
510
- showFormattingControls,
511
- hasResolveMentionSuggestions,
512
- onEmptyChange: setEmptyRef,
513
- onEmojiPickerOpenChange: setEmojiPickerOpenRef,
514
- onEditorClick: handleEditorClick,
515
- autoFocus,
516
- disabled
517
- })));
565
+ return /* @__PURE__ */ jsx(TooltipProvider, {
566
+ children: /* @__PURE__ */ jsx(ComposerForm, {
567
+ onComposerSubmit: handleCommentSubmit,
568
+ className: classNames(
569
+ "lb-root lb-composer lb-composer-form",
570
+ className
571
+ ),
572
+ dir: $.dir,
573
+ ...props,
574
+ ref: forwardedRef,
575
+ "data-collapsed": isCollapsed ? "" : void 0,
576
+ onFocus: handleFocus,
577
+ onBlur: handleBlur,
578
+ disabled: disabled || !canComment,
579
+ defaultAttachments,
580
+ pasteFilesAsAttachments: showAttachments,
581
+ preventUnsavedChanges: preventUnsavedComposerChanges,
582
+ roomId,
583
+ children: /* @__PURE__ */ jsx(ComposerEditorContainer, {
584
+ defaultValue,
585
+ actions,
586
+ overrides,
587
+ isCollapsed,
588
+ showAttachments,
589
+ showAttribution,
590
+ showFormattingControls,
591
+ hasResolveMentionSuggestions,
592
+ onEmptyChange: setEmptyRef,
593
+ onEmojiPickerOpenChange: setEmojiPickerOpenRef,
594
+ onEditorClick: handleEditorClick,
595
+ autoFocus,
596
+ disabled
597
+ })
598
+ })
599
+ });
518
600
  }
519
601
  );
520
602
 
521
- export { Composer };
603
+ export { Composer, ComposerRoomIdContext };
522
604
  //# sourceMappingURL=Composer.mjs.map