@liveblocks/react-ui 2.14.0 → 2.15.0-debug1

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