@selfcommunity/react-ui 0.11.0-alpha.6 → 0.11.0-alpha.61

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 (719) hide show
  1. package/lib/cjs/assets/courses/clapping.d.ts +1 -0
  2. package/lib/cjs/assets/courses/clapping.js +4 -0
  3. package/lib/cjs/components/BottomNavigation/BottomNavigation.js +17 -2
  4. package/lib/cjs/components/CategoryAutocomplete/CategoryAutocomplete.d.ts +5 -0
  5. package/lib/cjs/components/CategoryAutocomplete/CategoryAutocomplete.js +9 -11
  6. package/lib/cjs/components/CommentObject/CommentObject.d.ts +5 -0
  7. package/lib/cjs/components/CommentObject/CommentObject.js +2 -2
  8. package/lib/cjs/components/CommentObjectReply/CommentObjectReply.d.ts +24 -2
  9. package/lib/cjs/components/CommentObjectReply/CommentObjectReply.js +17 -4
  10. package/lib/cjs/components/Composer/Content/ContentLesson/ContentLesson.d.ts +38 -0
  11. package/lib/cjs/components/Composer/Content/ContentLesson/ContentLesson.js +67 -0
  12. package/lib/cjs/components/Composer/Content/ContentLesson/index.d.ts +3 -0
  13. package/lib/cjs/components/Composer/Content/ContentLesson/index.js +5 -0
  14. package/lib/cjs/components/Composer/Layer/AudienceLayer/AudienceLayer.js +2 -2
  15. package/lib/cjs/components/Composer/Layer/CategoryLayer/CategoryLayer.d.ts +1 -1
  16. package/lib/cjs/components/Composer/Layer/CategoryLayer/CategoryLayer.js +4 -1
  17. package/lib/cjs/components/ComposerIconButton/ComposerIconButton.d.ts +9 -3
  18. package/lib/cjs/components/ComposerIconButton/ComposerIconButton.js +46 -9
  19. package/lib/cjs/components/Course/Course.d.ts +92 -0
  20. package/lib/cjs/components/Course/Course.js +185 -0
  21. package/lib/cjs/components/Course/CreatePlaceholder.d.ts +39 -0
  22. package/lib/cjs/components/Course/CreatePlaceholder.js +59 -0
  23. package/lib/cjs/components/Course/Skeleton.d.ts +51 -0
  24. package/lib/cjs/components/Course/Skeleton.js +77 -0
  25. package/lib/cjs/components/Course/constants.d.ts +1 -0
  26. package/lib/cjs/components/Course/constants.js +4 -0
  27. package/lib/cjs/components/Course/index.d.ts +4 -0
  28. package/lib/cjs/components/Course/index.js +8 -0
  29. package/lib/cjs/components/CourseCompletedDialog/CourseCompletedDialog.d.ts +9 -0
  30. package/lib/cjs/components/CourseCompletedDialog/CourseCompletedDialog.js +40 -0
  31. package/lib/cjs/components/CourseCompletedDialog/index.d.ts +3 -0
  32. package/lib/cjs/components/CourseCompletedDialog/index.js +5 -0
  33. package/lib/cjs/components/CourseContentMenu/CourseContentMenu.d.ts +25 -0
  34. package/lib/cjs/components/CourseContentMenu/CourseContentMenu.js +47 -0
  35. package/lib/cjs/components/CourseContentMenu/constants.d.ts +1 -0
  36. package/lib/cjs/components/CourseContentMenu/constants.js +4 -0
  37. package/lib/cjs/components/CourseContentMenu/index.d.ts +3 -0
  38. package/lib/cjs/components/CourseContentMenu/index.js +5 -0
  39. package/lib/cjs/components/CourseDashboard/Header/Skeleton.d.ts +1 -0
  40. package/lib/cjs/components/CourseDashboard/Header/Skeleton.js +16 -0
  41. package/lib/cjs/components/CourseDashboard/Header.d.ts +9 -0
  42. package/lib/cjs/components/CourseDashboard/Header.js +44 -0
  43. package/lib/cjs/components/CourseDashboard/Student/ActionButton.d.ts +8 -0
  44. package/lib/cjs/components/CourseDashboard/Student/ActionButton.js +16 -0
  45. package/lib/cjs/components/CourseDashboard/Student/Skeleton.d.ts +1 -0
  46. package/lib/cjs/components/CourseDashboard/Student/Skeleton.js +30 -0
  47. package/lib/cjs/components/CourseDashboard/Student.d.ts +11 -0
  48. package/lib/cjs/components/CourseDashboard/Student.js +203 -0
  49. package/lib/cjs/components/CourseDashboard/Teacher/Comments.d.ts +9 -0
  50. package/lib/cjs/components/CourseDashboard/Teacher/Comments.js +108 -0
  51. package/lib/cjs/components/CourseDashboard/Teacher/Info.d.ts +11 -0
  52. package/lib/cjs/components/CourseDashboard/Teacher/Info.js +19 -0
  53. package/lib/cjs/components/CourseDashboard/Teacher/Skeleton.d.ts +1 -0
  54. package/lib/cjs/components/CourseDashboard/Teacher/Skeleton.js +25 -0
  55. package/lib/cjs/components/CourseDashboard/Teacher/Students.d.ts +10 -0
  56. package/lib/cjs/components/CourseDashboard/Teacher/Students.js +71 -0
  57. package/lib/cjs/components/CourseDashboard/Teacher.d.ts +11 -0
  58. package/lib/cjs/components/CourseDashboard/Teacher.js +62 -0
  59. package/lib/cjs/components/CourseDashboard/constants.d.ts +1 -0
  60. package/lib/cjs/components/CourseDashboard/constants.js +4 -0
  61. package/lib/cjs/components/CourseDashboard/index.d.ts +11 -0
  62. package/lib/cjs/components/CourseDashboard/index.js +11 -0
  63. package/lib/cjs/components/CourseDashboard/types.d.ts +8 -0
  64. package/lib/cjs/components/CourseDashboard/types.js +13 -0
  65. package/lib/cjs/components/CourseForm/CourseForm.d.ts +74 -0
  66. package/lib/cjs/components/CourseForm/CourseForm.js +273 -0
  67. package/lib/cjs/components/CourseForm/Dialog.d.ts +8 -0
  68. package/lib/cjs/components/CourseForm/Dialog.js +19 -0
  69. package/lib/cjs/components/CourseForm/Edit.d.ts +24 -0
  70. package/lib/cjs/components/CourseForm/Edit.js +53 -0
  71. package/lib/cjs/components/CourseForm/Skeleton.d.ts +1 -0
  72. package/lib/cjs/components/CourseForm/Skeleton.js +17 -0
  73. package/lib/cjs/components/CourseForm/UploadCourseCover.d.ts +45 -0
  74. package/lib/cjs/components/CourseForm/UploadCourseCover.js +94 -0
  75. package/lib/cjs/components/CourseForm/constants.d.ts +1 -0
  76. package/lib/cjs/components/CourseForm/constants.js +4 -0
  77. package/lib/cjs/components/CourseForm/index.d.ts +4 -0
  78. package/lib/cjs/components/CourseForm/index.js +8 -0
  79. package/lib/cjs/components/CourseFormDialog/CourseFormDialog.d.ts +48 -0
  80. package/lib/cjs/components/CourseFormDialog/CourseFormDialog.js +67 -0
  81. package/lib/cjs/components/CourseFormDialog/constants.d.ts +1 -0
  82. package/lib/cjs/components/CourseFormDialog/constants.js +4 -0
  83. package/lib/cjs/components/CourseFormDialog/index.d.ts +3 -0
  84. package/lib/cjs/components/CourseFormDialog/index.js +5 -0
  85. package/lib/cjs/components/CourseJoinButton/CourseJoinButton.d.ts +56 -0
  86. package/lib/cjs/components/CourseJoinButton/CourseJoinButton.js +148 -0
  87. package/lib/cjs/components/CourseJoinButton/index.d.ts +3 -0
  88. package/lib/cjs/components/CourseJoinButton/index.js +5 -0
  89. package/lib/cjs/components/CourseParticipantsButton/CourseParticipantsButton.d.ts +53 -0
  90. package/lib/cjs/components/CourseParticipantsButton/CourseParticipantsButton.js +150 -0
  91. package/lib/cjs/components/CourseParticipantsButton/index.d.ts +3 -0
  92. package/lib/cjs/components/CourseParticipantsButton/index.js +5 -0
  93. package/lib/cjs/components/Courses/Courses.d.ts +100 -0
  94. package/lib/cjs/components/Courses/Courses.js +237 -0
  95. package/lib/cjs/components/Courses/Skeleton.d.ts +54 -0
  96. package/lib/cjs/components/Courses/Skeleton.js +45 -0
  97. package/lib/cjs/components/Courses/constants.d.ts +1 -0
  98. package/lib/cjs/components/Courses/constants.js +4 -0
  99. package/lib/cjs/components/Courses/index.d.ts +4 -0
  100. package/lib/cjs/components/Courses/index.js +8 -0
  101. package/lib/cjs/components/Courses/prefetchedCourses.d.ts +81 -0
  102. package/lib/cjs/components/Courses/prefetchedCourses.js +186 -0
  103. package/lib/cjs/components/CreateCourseButton/CreateCourseButton.d.ts +38 -0
  104. package/lib/cjs/components/CreateCourseButton/CreateCourseButton.js +81 -0
  105. package/lib/cjs/components/CreateCourseButton/index.d.ts +3 -0
  106. package/lib/cjs/components/CreateCourseButton/index.js +5 -0
  107. package/lib/cjs/components/CreateEventButton/CreateEventButton.d.ts +1 -1
  108. package/lib/cjs/components/CreateEventButton/CreateEventButton.js +1 -1
  109. package/lib/cjs/components/CreateLiveStreamButton/CreateLiveStreamButton.d.ts +0 -6
  110. package/lib/cjs/components/CreateLiveStreamButton/CreateLiveStreamButton.js +2 -9
  111. package/lib/cjs/components/CreateLiveStreamDialog/CreateLiveStreamDialog.d.ts +10 -4
  112. package/lib/cjs/components/CreateLiveStreamDialog/CreateLiveStreamDialog.js +17 -11
  113. package/lib/cjs/components/CreateLiveStreamDialog/LiveStreamSelector/LiveStreamSelector.js +10 -2
  114. package/lib/cjs/components/EditCourse/Customize.d.ts +9 -0
  115. package/lib/cjs/components/EditCourse/Customize.js +31 -0
  116. package/lib/cjs/components/EditCourse/EditCourse.d.ts +13 -0
  117. package/lib/cjs/components/EditCourse/EditCourse.js +110 -0
  118. package/lib/cjs/components/EditCourse/Lessons/AddButton.d.ts +9 -0
  119. package/lib/cjs/components/EditCourse/Lessons/AddButton.js +29 -0
  120. package/lib/cjs/components/EditCourse/Lessons/ChangeLessonStatus.d.ts +13 -0
  121. package/lib/cjs/components/EditCourse/Lessons/ChangeLessonStatus.js +92 -0
  122. package/lib/cjs/components/EditCourse/Lessons/FieldName.d.ts +15 -0
  123. package/lib/cjs/components/EditCourse/Lessons/FieldName.js +83 -0
  124. package/lib/cjs/components/EditCourse/Lessons/LessonRow.d.ts +15 -0
  125. package/lib/cjs/components/EditCourse/Lessons/LessonRow.js +68 -0
  126. package/lib/cjs/components/EditCourse/Lessons/SectionRow.d.ts +14 -0
  127. package/lib/cjs/components/EditCourse/Lessons/SectionRow.js +158 -0
  128. package/lib/cjs/components/EditCourse/Lessons/Skeleton.d.ts +1 -0
  129. package/lib/cjs/components/EditCourse/Lessons/Skeleton.js +20 -0
  130. package/lib/cjs/components/EditCourse/Lessons.d.ts +11 -0
  131. package/lib/cjs/components/EditCourse/Lessons.js +196 -0
  132. package/lib/cjs/components/EditCourse/MenuRow.d.ts +9 -0
  133. package/lib/cjs/components/EditCourse/MenuRow.js +25 -0
  134. package/lib/cjs/components/EditCourse/Options/Skeleton.d.ts +1 -0
  135. package/lib/cjs/components/EditCourse/Options/Skeleton.js +15 -0
  136. package/lib/cjs/components/EditCourse/Options/SwitchForm.d.ts +11 -0
  137. package/lib/cjs/components/EditCourse/Options/SwitchForm.js +20 -0
  138. package/lib/cjs/components/EditCourse/Options.d.ts +9 -0
  139. package/lib/cjs/components/EditCourse/Options.js +96 -0
  140. package/lib/cjs/components/EditCourse/Requests.d.ts +12 -0
  141. package/lib/cjs/components/EditCourse/Requests.js +97 -0
  142. package/lib/cjs/components/EditCourse/Skeleton.d.ts +8 -0
  143. package/lib/cjs/components/EditCourse/Skeleton.js +28 -0
  144. package/lib/cjs/components/EditCourse/Status.d.ts +9 -0
  145. package/lib/cjs/components/EditCourse/Status.js +33 -0
  146. package/lib/cjs/components/EditCourse/Users/Skeleton.d.ts +1 -0
  147. package/lib/cjs/components/EditCourse/Users/Skeleton.js +15 -0
  148. package/lib/cjs/components/EditCourse/Users.d.ts +11 -0
  149. package/lib/cjs/components/EditCourse/Users.js +140 -0
  150. package/lib/cjs/components/EditCourse/constants.d.ts +1 -0
  151. package/lib/cjs/components/EditCourse/constants.js +4 -0
  152. package/lib/cjs/components/EditCourse/hooks.d.ts +3 -0
  153. package/lib/cjs/components/EditCourse/hooks.js +22 -0
  154. package/lib/cjs/components/EditCourse/index.d.ts +4 -0
  155. package/lib/cjs/components/EditCourse/index.js +8 -0
  156. package/lib/cjs/components/EditCourse/types.d.ts +29 -0
  157. package/lib/cjs/components/EditCourse/types.js +19 -0
  158. package/lib/cjs/components/Editor/Editor.d.ts +37 -0
  159. package/lib/cjs/components/Editor/Editor.js +13 -10
  160. package/lib/cjs/components/Editor/nodes/HashtagNode.js +2 -0
  161. package/lib/cjs/components/Editor/nodes/MentionNode.js +2 -0
  162. package/lib/cjs/components/Editor/plugins/EmojiPlugin.d.ts +3 -1
  163. package/lib/cjs/components/Editor/plugins/EmojiPlugin.js +4 -10
  164. package/lib/cjs/components/Editor/plugins/HorizontalRulePlugin.d.ts +8 -0
  165. package/lib/cjs/components/Editor/plugins/HorizontalRulePlugin.js +34 -0
  166. package/lib/cjs/components/Editor/plugins/LexicalRichTextPlugin.d.ts +2 -2
  167. package/lib/cjs/components/Editor/plugins/LexicalRichTextPlugin.js +2 -3
  168. package/lib/cjs/components/Editor/plugins/MediaPlugin.d.ts +14 -0
  169. package/lib/cjs/components/Editor/plugins/MediaPlugin.js +121 -0
  170. package/lib/cjs/components/Editor/plugins/ToolbarPlugin.d.ts +5 -0
  171. package/lib/cjs/components/Editor/plugins/ToolbarPlugin.js +3 -2
  172. package/lib/cjs/components/Editor/plugins/index.d.ts +2 -1
  173. package/lib/cjs/components/Editor/plugins/index.js +3 -1
  174. package/lib/cjs/components/Event/Event.js +6 -3
  175. package/lib/cjs/components/EventForm/EventAddress.js +1 -1
  176. package/lib/cjs/components/EventForm/EventForm.js +41 -23
  177. package/lib/cjs/components/EventForm/utils.d.ts +1 -0
  178. package/lib/cjs/components/EventForm/utils.js +6 -1
  179. package/lib/cjs/components/EventFormDialog/EventFormDialog.d.ts +1 -1
  180. package/lib/cjs/components/EventFormDialog/EventFormDialog.js +3 -3
  181. package/lib/cjs/components/EventHeader/EventHeader.js +3 -2
  182. package/lib/cjs/components/EventMembersWidget/EventMembersWidget.js +12 -12
  183. package/lib/cjs/components/EventMembersWidget/TabContentComponent.js +8 -8
  184. package/lib/cjs/components/EventMembersWidget/types.d.ts +4 -5
  185. package/lib/cjs/components/EventMembersWidget/types.js +7 -7
  186. package/lib/cjs/components/EventParticipantsButton/EventParticipantsButton.js +1 -1
  187. package/lib/cjs/components/EventSubscribeButton/EventSubscribeButton.js +1 -1
  188. package/lib/cjs/components/Events/Events.d.ts +11 -0
  189. package/lib/cjs/components/Events/Events.js +21 -10
  190. package/lib/cjs/components/Events/OngoingEventsFilter.d.ts +8 -0
  191. package/lib/cjs/components/Events/OngoingEventsFilter.js +24 -0
  192. package/lib/cjs/components/FeedObject/Actions/Share/Share.js +4 -1
  193. package/lib/cjs/components/FeedObject/Activities/Activities.js +1 -1
  194. package/lib/cjs/components/Footer/Footer.js +9 -6
  195. package/lib/cjs/components/Footer/constants.d.ts +1 -0
  196. package/lib/cjs/components/Footer/constants.js +2 -1
  197. package/lib/cjs/components/GroupForm/GroupForm.js +2 -2
  198. package/lib/cjs/components/GroupInvitedWidget/GroupInvitedWidget.js +1 -1
  199. package/lib/cjs/components/GroupRequestsWidget/GroupRequestsWidget.js +1 -1
  200. package/lib/cjs/components/Groups/Groups.js +18 -16
  201. package/lib/cjs/components/LessonAppbar/LessonAppbar.d.ts +42 -0
  202. package/lib/cjs/components/LessonAppbar/LessonAppbar.js +34 -0
  203. package/lib/cjs/components/LessonAppbar/constants.d.ts +1 -0
  204. package/lib/cjs/components/LessonAppbar/constants.js +4 -0
  205. package/lib/cjs/components/LessonAppbar/index.d.ts +3 -0
  206. package/lib/cjs/components/LessonAppbar/index.js +5 -0
  207. package/lib/cjs/components/LessonCommentObject/LessonCommentObject.d.ts +94 -0
  208. package/lib/cjs/components/LessonCommentObject/LessonCommentObject.js +202 -0
  209. package/lib/cjs/components/LessonCommentObject/Skeleton.d.ts +21 -0
  210. package/lib/cjs/components/LessonCommentObject/Skeleton.js +46 -0
  211. package/lib/cjs/components/LessonCommentObject/constants.d.ts +1 -0
  212. package/lib/cjs/components/LessonCommentObject/constants.js +4 -0
  213. package/lib/cjs/components/LessonCommentObject/index.d.ts +4 -0
  214. package/lib/cjs/components/LessonCommentObject/index.js +8 -0
  215. package/lib/cjs/components/LessonCommentObjects/LessonCommentObjects.d.ts +76 -0
  216. package/lib/cjs/components/LessonCommentObjects/LessonCommentObjects.js +185 -0
  217. package/lib/cjs/components/LessonCommentObjects/Skeleton.d.ts +23 -0
  218. package/lib/cjs/components/LessonCommentObjects/Skeleton.js +40 -0
  219. package/lib/cjs/components/LessonCommentObjects/constants.d.ts +1 -0
  220. package/lib/cjs/components/LessonCommentObjects/constants.js +4 -0
  221. package/lib/cjs/components/LessonCommentObjects/index.d.ts +4 -0
  222. package/lib/cjs/components/LessonCommentObjects/index.js +8 -0
  223. package/lib/cjs/components/LessonDrawer/LessonDrawer.d.ts +50 -0
  224. package/lib/cjs/components/LessonDrawer/LessonDrawer.js +37 -0
  225. package/lib/cjs/components/LessonDrawer/constants.d.ts +1 -0
  226. package/lib/cjs/components/LessonDrawer/constants.js +4 -0
  227. package/lib/cjs/components/LessonDrawer/index.d.ts +3 -0
  228. package/lib/cjs/components/LessonDrawer/index.js +5 -0
  229. package/lib/cjs/components/LessonEditForm/LessonEditForm.d.ts +24 -0
  230. package/lib/cjs/components/LessonEditForm/LessonEditForm.js +45 -0
  231. package/lib/cjs/components/LessonEditForm/constants.d.ts +1 -0
  232. package/lib/cjs/components/LessonEditForm/constants.js +4 -0
  233. package/lib/cjs/components/LessonEditForm/index.d.ts +3 -0
  234. package/lib/cjs/components/LessonEditForm/index.js +5 -0
  235. package/lib/cjs/components/LessonObject/LessonObject.d.ts +40 -0
  236. package/lib/cjs/components/LessonObject/LessonObject.js +70 -0
  237. package/lib/cjs/components/LessonObject/constants.d.ts +1 -0
  238. package/lib/cjs/components/LessonObject/constants.js +4 -0
  239. package/lib/cjs/components/LessonObject/index.d.ts +3 -0
  240. package/lib/cjs/components/LessonObject/index.js +5 -0
  241. package/lib/cjs/components/LessonReleaseMenu/LessonReleaseMenu.d.ts +26 -0
  242. package/lib/cjs/components/LessonReleaseMenu/LessonReleaseMenu.js +172 -0
  243. package/lib/cjs/components/LessonReleaseMenu/constants.d.ts +5 -0
  244. package/lib/cjs/components/LessonReleaseMenu/constants.js +9 -0
  245. package/lib/cjs/components/LessonReleaseMenu/index.d.ts +3 -0
  246. package/lib/cjs/components/LessonReleaseMenu/index.js +5 -0
  247. package/lib/cjs/components/LiveStreamForm/LiveStreamForm.js +65 -6
  248. package/lib/cjs/components/LiveStreamForm/LiveStreamFormSettings.js +8 -3
  249. package/lib/cjs/components/LiveStreamRoom/LiveStreamRoom.js +8 -6
  250. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/ControlBar.js +3 -1
  251. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/FocusLayout.d.ts +2 -1
  252. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/FocusLayout.js +2 -2
  253. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/LiveStreamSettingsMenu.d.ts +9 -0
  254. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/LiveStreamSettingsMenu.js +106 -0
  255. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/NoParticipants.d.ts +4 -0
  256. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/NoParticipants.js +37 -0
  257. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/ParticipantTile.d.ts +1 -0
  258. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/ParticipantTile.js +2 -2
  259. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/PreJoin.d.ts +3 -2
  260. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/PreJoin.js +45 -2
  261. package/lib/cjs/components/LiveStreamRoom/LiveStreamVideoConference/VideoConference.js +62 -5
  262. package/lib/cjs/components/NavigationMenuIconButton/DefaultDrawerContent.js +7 -5
  263. package/lib/cjs/components/NavigationMenuIconButton/NavigationMenuDrawer.d.ts +3 -1
  264. package/lib/cjs/components/NavigationMenuIconButton/NavigationMenuDrawer.js +13 -6
  265. package/lib/cjs/components/NavigationToolbar/NavigationToolbar.d.ts +1 -1
  266. package/lib/cjs/components/NavigationToolbar/NavigationToolbar.js +14 -3
  267. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +1 -1
  268. package/lib/cjs/components/NavigationToolbarMobile/NavigationToolbarMobile.js +4 -4
  269. package/lib/cjs/components/Notification/Course/Course.d.ts +15 -0
  270. package/lib/cjs/components/Notification/Course/Course.js +89 -0
  271. package/lib/cjs/components/Notification/Course/index.d.ts +3 -0
  272. package/lib/cjs/components/Notification/Course/index.js +5 -0
  273. package/lib/cjs/components/Notification/Course/utils.d.ts +5 -0
  274. package/lib/cjs/components/Notification/Course/utils.js +44 -0
  275. package/lib/cjs/components/Notification/Event/Event.js +20 -2
  276. package/lib/cjs/components/Notification/Notification.js +9 -0
  277. package/lib/cjs/components/RelatedEventsWidget/RelatedEventsWidget.js +1 -2
  278. package/lib/cjs/components/SearchDialog/SearchDialog.d.ts +4 -1
  279. package/lib/cjs/components/SearchDialog/SearchDialog.js +2 -2
  280. package/lib/cjs/components/SnippetNotifications/SnippetNotifications.js +9 -0
  281. package/lib/cjs/components/TagAutocomplete/TagAutocomplete.js +2 -2
  282. package/lib/cjs/components/ToastNotifications/ToastNotifications.js +9 -0
  283. package/lib/cjs/components/UserCreatedCoursesWidget/Skeleton.d.ts +21 -0
  284. package/lib/cjs/components/UserCreatedCoursesWidget/Skeleton.js +43 -0
  285. package/lib/cjs/components/UserCreatedCoursesWidget/UserCreatedCoursesWidget.d.ts +63 -0
  286. package/lib/cjs/components/UserCreatedCoursesWidget/UserCreatedCoursesWidget.js +154 -0
  287. package/lib/cjs/components/UserCreatedCoursesWidget/constants.d.ts +1 -0
  288. package/lib/cjs/components/UserCreatedCoursesWidget/constants.js +4 -0
  289. package/lib/cjs/components/UserCreatedCoursesWidget/index.d.ts +4 -0
  290. package/lib/cjs/components/UserCreatedCoursesWidget/index.js +8 -0
  291. package/lib/cjs/constants/Course.d.ts +6 -0
  292. package/lib/cjs/constants/Course.js +10 -0
  293. package/lib/cjs/constants/LiveStream.d.ts +1 -0
  294. package/lib/cjs/constants/LiveStream.js +2 -1
  295. package/lib/cjs/constants/PubSub.d.ts +14 -0
  296. package/lib/cjs/constants/PubSub.js +16 -1
  297. package/lib/cjs/index.d.ts +23 -2
  298. package/lib/cjs/index.js +60 -5
  299. package/lib/cjs/shared/AccordionLessons/AccordionLessons.d.ts +8 -0
  300. package/lib/cjs/shared/AccordionLessons/AccordionLessons.js +65 -0
  301. package/lib/cjs/shared/AccordionLessons/Skeleton.d.ts +1 -0
  302. package/lib/cjs/shared/AccordionLessons/Skeleton.js +21 -0
  303. package/lib/cjs/shared/AccordionLessons/constants.d.ts +1 -0
  304. package/lib/cjs/shared/AccordionLessons/constants.js +4 -0
  305. package/lib/cjs/shared/AccordionLessons/index.d.ts +4 -0
  306. package/lib/cjs/shared/AccordionLessons/index.js +8 -0
  307. package/lib/cjs/shared/AddUsersButton/AddUsersButton.d.ts +29 -0
  308. package/lib/cjs/shared/AddUsersButton/AddUsersButton.js +136 -0
  309. package/lib/cjs/shared/AddUsersButton/index.d.ts +3 -0
  310. package/lib/cjs/shared/AddUsersButton/index.js +5 -0
  311. package/lib/cjs/shared/CourseTypePopover/CourseTypePopover.d.ts +9 -0
  312. package/lib/cjs/shared/CourseTypePopover/CourseTypePopover.js +48 -0
  313. package/lib/cjs/shared/CourseTypePopover/index.d.ts +3 -0
  314. package/lib/cjs/shared/CourseTypePopover/index.js +5 -0
  315. package/lib/cjs/shared/CourseUsersTable/ChangeUsersStatus.d.ts +9 -0
  316. package/lib/cjs/shared/CourseUsersTable/ChangeUsersStatus.js +58 -0
  317. package/lib/cjs/shared/CourseUsersTable/CourseUsersTable.d.ts +21 -0
  318. package/lib/cjs/shared/CourseUsersTable/CourseUsersTable.js +155 -0
  319. package/lib/cjs/shared/CourseUsersTable/RemoveButton.d.ts +10 -0
  320. package/lib/cjs/shared/CourseUsersTable/RemoveButton.js +51 -0
  321. package/lib/cjs/shared/CourseUsersTable/RequestButton.d.ts +10 -0
  322. package/lib/cjs/shared/CourseUsersTable/RequestButton.js +79 -0
  323. package/lib/cjs/shared/CourseUsersTable/RowSkeleton.d.ts +8 -0
  324. package/lib/cjs/shared/CourseUsersTable/RowSkeleton.js +14 -0
  325. package/lib/cjs/shared/CourseUsersTable/SeeProgressButton.d.ts +9 -0
  326. package/lib/cjs/shared/CourseUsersTable/SeeProgressButton.js +56 -0
  327. package/lib/cjs/shared/CourseUsersTable/Skeleton.d.ts +1 -0
  328. package/lib/cjs/shared/CourseUsersTable/Skeleton.js +19 -0
  329. package/lib/cjs/shared/CourseUsersTable/constants.d.ts +1 -0
  330. package/lib/cjs/shared/CourseUsersTable/constants.js +4 -0
  331. package/lib/cjs/shared/CourseUsersTable/index.d.ts +4 -0
  332. package/lib/cjs/shared/CourseUsersTable/index.js +8 -0
  333. package/lib/cjs/shared/DateTimeAgo/index.d.ts +1 -1
  334. package/lib/cjs/shared/EmptyStatus/EmptyStatus.d.ts +11 -0
  335. package/lib/cjs/shared/EmptyStatus/EmptyStatus.js +26 -0
  336. package/lib/cjs/shared/EmptyStatus/index.d.ts +3 -0
  337. package/lib/cjs/shared/EmptyStatus/index.js +5 -0
  338. package/lib/cjs/shared/EventActionsMenu/index.js +5 -1
  339. package/lib/cjs/shared/LessonCommentActionsMenu/index.d.ts +41 -0
  340. package/lib/cjs/shared/LessonCommentActionsMenu/index.js +197 -0
  341. package/lib/cjs/shared/LessonFilePreview/index.d.ts +12 -0
  342. package/lib/cjs/shared/LessonFilePreview/index.js +29 -0
  343. package/lib/cjs/shared/Media/Link/UrlTextField/index.js +2 -3
  344. package/lib/cjs/shared/UpScalingTierBadge/index.js +9 -0
  345. package/lib/cjs/types/course.d.ts +40 -0
  346. package/lib/cjs/types/course.js +33 -0
  347. package/lib/cjs/types/index.d.ts +2 -1
  348. package/lib/cjs/types/index.js +6 -1
  349. package/lib/cjs/utils/buttonCounters.d.ts +1 -0
  350. package/lib/cjs/utils/buttonCounters.js +4 -3
  351. package/lib/cjs/utils/course.d.ts +14 -0
  352. package/lib/cjs/utils/course.js +39 -0
  353. package/lib/cjs/utils/events.d.ts +1 -0
  354. package/lib/cjs/utils/events.js +6 -1
  355. package/lib/esm/assets/courses/clapping.d.ts +1 -0
  356. package/lib/esm/assets/courses/clapping.js +1 -0
  357. package/lib/esm/components/BottomNavigation/BottomNavigation.js +17 -2
  358. package/lib/esm/components/CategoryAutocomplete/CategoryAutocomplete.d.ts +5 -0
  359. package/lib/esm/components/CategoryAutocomplete/CategoryAutocomplete.js +9 -11
  360. package/lib/esm/components/CommentObject/CommentObject.d.ts +5 -0
  361. package/lib/esm/components/CommentObject/CommentObject.js +2 -2
  362. package/lib/esm/components/CommentObjectReply/CommentObjectReply.d.ts +24 -2
  363. package/lib/esm/components/CommentObjectReply/CommentObjectReply.js +18 -5
  364. package/lib/esm/components/Composer/Content/ContentLesson/ContentLesson.d.ts +38 -0
  365. package/lib/esm/components/Composer/Content/ContentLesson/ContentLesson.js +64 -0
  366. package/lib/esm/components/Composer/Content/ContentLesson/index.d.ts +3 -0
  367. package/lib/esm/components/Composer/Content/ContentLesson/index.js +2 -0
  368. package/lib/esm/components/Composer/Layer/AudienceLayer/AudienceLayer.js +2 -2
  369. package/lib/esm/components/Composer/Layer/CategoryLayer/CategoryLayer.d.ts +1 -1
  370. package/lib/esm/components/Composer/Layer/CategoryLayer/CategoryLayer.js +4 -1
  371. package/lib/esm/components/ComposerIconButton/ComposerIconButton.d.ts +9 -3
  372. package/lib/esm/components/ComposerIconButton/ComposerIconButton.js +47 -10
  373. package/lib/esm/components/Course/Course.d.ts +92 -0
  374. package/lib/esm/components/Course/Course.js +182 -0
  375. package/lib/esm/components/Course/CreatePlaceholder.d.ts +39 -0
  376. package/lib/esm/components/Course/CreatePlaceholder.js +56 -0
  377. package/lib/esm/components/Course/Skeleton.d.ts +51 -0
  378. package/lib/esm/components/Course/Skeleton.js +74 -0
  379. package/lib/esm/components/Course/constants.d.ts +1 -0
  380. package/lib/esm/components/Course/constants.js +1 -0
  381. package/lib/esm/components/Course/index.d.ts +4 -0
  382. package/lib/esm/components/Course/index.js +4 -0
  383. package/lib/esm/components/CourseCompletedDialog/CourseCompletedDialog.d.ts +9 -0
  384. package/lib/esm/components/CourseCompletedDialog/CourseCompletedDialog.js +37 -0
  385. package/lib/esm/components/CourseCompletedDialog/index.d.ts +3 -0
  386. package/lib/esm/components/CourseCompletedDialog/index.js +2 -0
  387. package/lib/esm/components/CourseContentMenu/CourseContentMenu.d.ts +25 -0
  388. package/lib/esm/components/CourseContentMenu/CourseContentMenu.js +44 -0
  389. package/lib/esm/components/CourseContentMenu/constants.d.ts +1 -0
  390. package/lib/esm/components/CourseContentMenu/constants.js +1 -0
  391. package/lib/esm/components/CourseContentMenu/index.d.ts +3 -0
  392. package/lib/esm/components/CourseContentMenu/index.js +2 -0
  393. package/lib/esm/components/CourseDashboard/Header/Skeleton.d.ts +1 -0
  394. package/lib/esm/components/CourseDashboard/Header/Skeleton.js +13 -0
  395. package/lib/esm/components/CourseDashboard/Header.d.ts +9 -0
  396. package/lib/esm/components/CourseDashboard/Header.js +41 -0
  397. package/lib/esm/components/CourseDashboard/Student/ActionButton.d.ts +8 -0
  398. package/lib/esm/components/CourseDashboard/Student/ActionButton.js +13 -0
  399. package/lib/esm/components/CourseDashboard/Student/Skeleton.d.ts +1 -0
  400. package/lib/esm/components/CourseDashboard/Student/Skeleton.js +26 -0
  401. package/lib/esm/components/CourseDashboard/Student.d.ts +11 -0
  402. package/lib/esm/components/CourseDashboard/Student.js +201 -0
  403. package/lib/esm/components/CourseDashboard/Teacher/Comments.d.ts +9 -0
  404. package/lib/esm/components/CourseDashboard/Teacher/Comments.js +106 -0
  405. package/lib/esm/components/CourseDashboard/Teacher/Info.d.ts +11 -0
  406. package/lib/esm/components/CourseDashboard/Teacher/Info.js +16 -0
  407. package/lib/esm/components/CourseDashboard/Teacher/Skeleton.d.ts +1 -0
  408. package/lib/esm/components/CourseDashboard/Teacher/Skeleton.js +21 -0
  409. package/lib/esm/components/CourseDashboard/Teacher/Students.d.ts +10 -0
  410. package/lib/esm/components/CourseDashboard/Teacher/Students.js +68 -0
  411. package/lib/esm/components/CourseDashboard/Teacher.d.ts +11 -0
  412. package/lib/esm/components/CourseDashboard/Teacher.js +60 -0
  413. package/lib/esm/components/CourseDashboard/constants.d.ts +1 -0
  414. package/lib/esm/components/CourseDashboard/constants.js +1 -0
  415. package/lib/esm/components/CourseDashboard/index.d.ts +11 -0
  416. package/lib/esm/components/CourseDashboard/index.js +6 -0
  417. package/lib/esm/components/CourseDashboard/types.d.ts +8 -0
  418. package/lib/esm/components/CourseDashboard/types.js +10 -0
  419. package/lib/esm/components/CourseForm/CourseForm.d.ts +74 -0
  420. package/lib/esm/components/CourseForm/CourseForm.js +270 -0
  421. package/lib/esm/components/CourseForm/Dialog.d.ts +8 -0
  422. package/lib/esm/components/CourseForm/Dialog.js +16 -0
  423. package/lib/esm/components/CourseForm/Edit.d.ts +24 -0
  424. package/lib/esm/components/CourseForm/Edit.js +50 -0
  425. package/lib/esm/components/CourseForm/Skeleton.d.ts +1 -0
  426. package/lib/esm/components/CourseForm/Skeleton.js +14 -0
  427. package/lib/esm/components/CourseForm/UploadCourseCover.d.ts +45 -0
  428. package/lib/esm/components/CourseForm/UploadCourseCover.js +91 -0
  429. package/lib/esm/components/CourseForm/constants.d.ts +1 -0
  430. package/lib/esm/components/CourseForm/constants.js +1 -0
  431. package/lib/esm/components/CourseForm/index.d.ts +4 -0
  432. package/lib/esm/components/CourseForm/index.js +4 -0
  433. package/lib/esm/components/CourseFormDialog/CourseFormDialog.d.ts +48 -0
  434. package/lib/esm/components/CourseFormDialog/CourseFormDialog.js +64 -0
  435. package/lib/esm/components/CourseFormDialog/constants.d.ts +1 -0
  436. package/lib/esm/components/CourseFormDialog/constants.js +1 -0
  437. package/lib/esm/components/CourseFormDialog/index.d.ts +3 -0
  438. package/lib/esm/components/CourseFormDialog/index.js +2 -0
  439. package/lib/esm/components/CourseJoinButton/CourseJoinButton.d.ts +56 -0
  440. package/lib/esm/components/CourseJoinButton/CourseJoinButton.js +145 -0
  441. package/lib/esm/components/CourseJoinButton/index.d.ts +3 -0
  442. package/lib/esm/components/CourseJoinButton/index.js +2 -0
  443. package/lib/esm/components/CourseParticipantsButton/CourseParticipantsButton.d.ts +53 -0
  444. package/lib/esm/components/CourseParticipantsButton/CourseParticipantsButton.js +147 -0
  445. package/lib/esm/components/CourseParticipantsButton/index.d.ts +3 -0
  446. package/lib/esm/components/CourseParticipantsButton/index.js +2 -0
  447. package/lib/esm/components/Courses/Courses.d.ts +100 -0
  448. package/lib/esm/components/Courses/Courses.js +233 -0
  449. package/lib/esm/components/Courses/Skeleton.d.ts +54 -0
  450. package/lib/esm/components/Courses/Skeleton.js +42 -0
  451. package/lib/esm/components/Courses/constants.d.ts +1 -0
  452. package/lib/esm/components/Courses/constants.js +1 -0
  453. package/lib/esm/components/Courses/index.d.ts +4 -0
  454. package/lib/esm/components/Courses/index.js +4 -0
  455. package/lib/esm/components/Courses/prefetchedCourses.d.ts +81 -0
  456. package/lib/esm/components/Courses/prefetchedCourses.js +183 -0
  457. package/lib/esm/components/CreateCourseButton/CreateCourseButton.d.ts +38 -0
  458. package/lib/esm/components/CreateCourseButton/CreateCourseButton.js +78 -0
  459. package/lib/esm/components/CreateCourseButton/index.d.ts +3 -0
  460. package/lib/esm/components/CreateCourseButton/index.js +2 -0
  461. package/lib/esm/components/CreateEventButton/CreateEventButton.d.ts +1 -1
  462. package/lib/esm/components/CreateEventButton/CreateEventButton.js +1 -1
  463. package/lib/esm/components/CreateLiveStreamButton/CreateLiveStreamButton.d.ts +0 -6
  464. package/lib/esm/components/CreateLiveStreamButton/CreateLiveStreamButton.js +2 -9
  465. package/lib/esm/components/CreateLiveStreamDialog/CreateLiveStreamDialog.d.ts +10 -4
  466. package/lib/esm/components/CreateLiveStreamDialog/CreateLiveStreamDialog.js +17 -11
  467. package/lib/esm/components/CreateLiveStreamDialog/LiveStreamSelector/LiveStreamSelector.js +12 -4
  468. package/lib/esm/components/EditCourse/Customize.d.ts +9 -0
  469. package/lib/esm/components/EditCourse/Customize.js +28 -0
  470. package/lib/esm/components/EditCourse/EditCourse.d.ts +13 -0
  471. package/lib/esm/components/EditCourse/EditCourse.js +107 -0
  472. package/lib/esm/components/EditCourse/Lessons/AddButton.d.ts +9 -0
  473. package/lib/esm/components/EditCourse/Lessons/AddButton.js +27 -0
  474. package/lib/esm/components/EditCourse/Lessons/ChangeLessonStatus.d.ts +13 -0
  475. package/lib/esm/components/EditCourse/Lessons/ChangeLessonStatus.js +89 -0
  476. package/lib/esm/components/EditCourse/Lessons/FieldName.d.ts +15 -0
  477. package/lib/esm/components/EditCourse/Lessons/FieldName.js +80 -0
  478. package/lib/esm/components/EditCourse/Lessons/LessonRow.d.ts +15 -0
  479. package/lib/esm/components/EditCourse/Lessons/LessonRow.js +65 -0
  480. package/lib/esm/components/EditCourse/Lessons/SectionRow.d.ts +14 -0
  481. package/lib/esm/components/EditCourse/Lessons/SectionRow.js +155 -0
  482. package/lib/esm/components/EditCourse/Lessons/Skeleton.d.ts +1 -0
  483. package/lib/esm/components/EditCourse/Lessons/Skeleton.js +17 -0
  484. package/lib/esm/components/EditCourse/Lessons.d.ts +11 -0
  485. package/lib/esm/components/EditCourse/Lessons.js +193 -0
  486. package/lib/esm/components/EditCourse/MenuRow.d.ts +9 -0
  487. package/lib/esm/components/EditCourse/MenuRow.js +22 -0
  488. package/lib/esm/components/EditCourse/Options/Skeleton.d.ts +1 -0
  489. package/lib/esm/components/EditCourse/Options/Skeleton.js +12 -0
  490. package/lib/esm/components/EditCourse/Options/SwitchForm.d.ts +11 -0
  491. package/lib/esm/components/EditCourse/Options/SwitchForm.js +18 -0
  492. package/lib/esm/components/EditCourse/Options.d.ts +9 -0
  493. package/lib/esm/components/EditCourse/Options.js +93 -0
  494. package/lib/esm/components/EditCourse/Requests.d.ts +12 -0
  495. package/lib/esm/components/EditCourse/Requests.js +94 -0
  496. package/lib/esm/components/EditCourse/Skeleton.d.ts +8 -0
  497. package/lib/esm/components/EditCourse/Skeleton.js +25 -0
  498. package/lib/esm/components/EditCourse/Status.d.ts +9 -0
  499. package/lib/esm/components/EditCourse/Status.js +29 -0
  500. package/lib/esm/components/EditCourse/Users/Skeleton.d.ts +1 -0
  501. package/lib/esm/components/EditCourse/Users/Skeleton.js +12 -0
  502. package/lib/esm/components/EditCourse/Users.d.ts +11 -0
  503. package/lib/esm/components/EditCourse/Users.js +137 -0
  504. package/lib/esm/components/EditCourse/constants.d.ts +1 -0
  505. package/lib/esm/components/EditCourse/constants.js +1 -0
  506. package/lib/esm/components/EditCourse/hooks.d.ts +3 -0
  507. package/lib/esm/components/EditCourse/hooks.js +17 -0
  508. package/lib/esm/components/EditCourse/index.d.ts +4 -0
  509. package/lib/esm/components/EditCourse/index.js +4 -0
  510. package/lib/esm/components/EditCourse/types.d.ts +29 -0
  511. package/lib/esm/components/EditCourse/types.js +16 -0
  512. package/lib/esm/components/Editor/Editor.d.ts +37 -0
  513. package/lib/esm/components/Editor/Editor.js +14 -11
  514. package/lib/esm/components/Editor/nodes/HashtagNode.js +2 -0
  515. package/lib/esm/components/Editor/nodes/MentionNode.js +2 -0
  516. package/lib/esm/components/Editor/plugins/EmojiPlugin.d.ts +3 -1
  517. package/lib/esm/components/Editor/plugins/EmojiPlugin.js +4 -10
  518. package/lib/esm/components/Editor/plugins/HorizontalRulePlugin.d.ts +8 -0
  519. package/lib/esm/components/Editor/plugins/HorizontalRulePlugin.js +30 -0
  520. package/lib/esm/components/Editor/plugins/LexicalRichTextPlugin.d.ts +2 -2
  521. package/lib/esm/components/Editor/plugins/LexicalRichTextPlugin.js +1 -1
  522. package/lib/esm/components/Editor/plugins/MediaPlugin.d.ts +14 -0
  523. package/lib/esm/components/Editor/plugins/MediaPlugin.js +117 -0
  524. package/lib/esm/components/Editor/plugins/ToolbarPlugin.d.ts +5 -0
  525. package/lib/esm/components/Editor/plugins/ToolbarPlugin.js +3 -2
  526. package/lib/esm/components/Editor/plugins/index.d.ts +2 -1
  527. package/lib/esm/components/Editor/plugins/index.js +2 -1
  528. package/lib/esm/components/Event/Event.js +6 -3
  529. package/lib/esm/components/EventForm/EventAddress.js +1 -1
  530. package/lib/esm/components/EventForm/EventForm.js +43 -25
  531. package/lib/esm/components/EventForm/utils.d.ts +1 -0
  532. package/lib/esm/components/EventForm/utils.js +4 -0
  533. package/lib/esm/components/EventFormDialog/EventFormDialog.d.ts +1 -1
  534. package/lib/esm/components/EventFormDialog/EventFormDialog.js +3 -3
  535. package/lib/esm/components/EventHeader/EventHeader.js +3 -2
  536. package/lib/esm/components/EventMembersWidget/EventMembersWidget.js +14 -14
  537. package/lib/esm/components/EventMembersWidget/TabContentComponent.js +9 -9
  538. package/lib/esm/components/EventMembersWidget/types.d.ts +4 -5
  539. package/lib/esm/components/EventMembersWidget/types.js +6 -6
  540. package/lib/esm/components/EventParticipantsButton/EventParticipantsButton.js +1 -1
  541. package/lib/esm/components/EventSubscribeButton/EventSubscribeButton.js +1 -1
  542. package/lib/esm/components/Events/Events.d.ts +11 -0
  543. package/lib/esm/components/Events/Events.js +22 -11
  544. package/lib/esm/components/Events/OngoingEventsFilter.d.ts +8 -0
  545. package/lib/esm/components/Events/OngoingEventsFilter.js +21 -0
  546. package/lib/esm/components/FeedObject/Actions/Share/Share.js +4 -1
  547. package/lib/esm/components/FeedObject/Activities/Activities.js +1 -1
  548. package/lib/esm/components/Footer/Footer.js +10 -7
  549. package/lib/esm/components/Footer/constants.d.ts +1 -0
  550. package/lib/esm/components/Footer/constants.js +1 -0
  551. package/lib/esm/components/GroupForm/GroupForm.js +2 -2
  552. package/lib/esm/components/GroupInvitedWidget/GroupInvitedWidget.js +1 -1
  553. package/lib/esm/components/GroupRequestsWidget/GroupRequestsWidget.js +1 -1
  554. package/lib/esm/components/Groups/Groups.js +21 -19
  555. package/lib/esm/components/LessonAppbar/LessonAppbar.d.ts +42 -0
  556. package/lib/esm/components/LessonAppbar/LessonAppbar.js +31 -0
  557. package/lib/esm/components/LessonAppbar/constants.d.ts +1 -0
  558. package/lib/esm/components/LessonAppbar/constants.js +1 -0
  559. package/lib/esm/components/LessonAppbar/index.d.ts +3 -0
  560. package/lib/esm/components/LessonAppbar/index.js +2 -0
  561. package/lib/esm/components/LessonCommentObject/LessonCommentObject.d.ts +94 -0
  562. package/lib/esm/components/LessonCommentObject/LessonCommentObject.js +199 -0
  563. package/lib/esm/components/LessonCommentObject/Skeleton.d.ts +21 -0
  564. package/lib/esm/components/LessonCommentObject/Skeleton.js +43 -0
  565. package/lib/esm/components/LessonCommentObject/constants.d.ts +1 -0
  566. package/lib/esm/components/LessonCommentObject/constants.js +1 -0
  567. package/lib/esm/components/LessonCommentObject/index.d.ts +4 -0
  568. package/lib/esm/components/LessonCommentObject/index.js +4 -0
  569. package/lib/esm/components/LessonCommentObjects/LessonCommentObjects.d.ts +76 -0
  570. package/lib/esm/components/LessonCommentObjects/LessonCommentObjects.js +182 -0
  571. package/lib/esm/components/LessonCommentObjects/Skeleton.d.ts +23 -0
  572. package/lib/esm/components/LessonCommentObjects/Skeleton.js +37 -0
  573. package/lib/esm/components/LessonCommentObjects/constants.d.ts +1 -0
  574. package/lib/esm/components/LessonCommentObjects/constants.js +1 -0
  575. package/lib/esm/components/LessonCommentObjects/index.d.ts +4 -0
  576. package/lib/esm/components/LessonCommentObjects/index.js +4 -0
  577. package/lib/esm/components/LessonDrawer/LessonDrawer.d.ts +50 -0
  578. package/lib/esm/components/LessonDrawer/LessonDrawer.js +34 -0
  579. package/lib/esm/components/LessonDrawer/constants.d.ts +1 -0
  580. package/lib/esm/components/LessonDrawer/constants.js +1 -0
  581. package/lib/esm/components/LessonDrawer/index.d.ts +3 -0
  582. package/lib/esm/components/LessonDrawer/index.js +2 -0
  583. package/lib/esm/components/LessonEditForm/LessonEditForm.d.ts +24 -0
  584. package/lib/esm/components/LessonEditForm/LessonEditForm.js +42 -0
  585. package/lib/esm/components/LessonEditForm/constants.d.ts +1 -0
  586. package/lib/esm/components/LessonEditForm/constants.js +1 -0
  587. package/lib/esm/components/LessonEditForm/index.d.ts +3 -0
  588. package/lib/esm/components/LessonEditForm/index.js +2 -0
  589. package/lib/esm/components/LessonObject/LessonObject.d.ts +40 -0
  590. package/lib/esm/components/LessonObject/LessonObject.js +67 -0
  591. package/lib/esm/components/LessonObject/constants.d.ts +1 -0
  592. package/lib/esm/components/LessonObject/constants.js +1 -0
  593. package/lib/esm/components/LessonObject/index.d.ts +3 -0
  594. package/lib/esm/components/LessonObject/index.js +2 -0
  595. package/lib/esm/components/LessonReleaseMenu/LessonReleaseMenu.d.ts +26 -0
  596. package/lib/esm/components/LessonReleaseMenu/LessonReleaseMenu.js +169 -0
  597. package/lib/esm/components/LessonReleaseMenu/constants.d.ts +5 -0
  598. package/lib/esm/components/LessonReleaseMenu/constants.js +6 -0
  599. package/lib/esm/components/LessonReleaseMenu/index.d.ts +3 -0
  600. package/lib/esm/components/LessonReleaseMenu/index.js +2 -0
  601. package/lib/esm/components/LiveStreamForm/LiveStreamForm.js +67 -8
  602. package/lib/esm/components/LiveStreamForm/LiveStreamFormSettings.js +8 -3
  603. package/lib/esm/components/LiveStreamRoom/LiveStreamRoom.js +8 -6
  604. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/ControlBar.js +3 -1
  605. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/FocusLayout.d.ts +2 -1
  606. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/FocusLayout.js +2 -2
  607. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/LiveStreamSettingsMenu.d.ts +9 -0
  608. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/LiveStreamSettingsMenu.js +103 -0
  609. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/NoParticipants.d.ts +4 -0
  610. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/NoParticipants.js +34 -0
  611. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/ParticipantTile.d.ts +1 -0
  612. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/ParticipantTile.js +2 -2
  613. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/PreJoin.d.ts +3 -2
  614. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/PreJoin.js +45 -2
  615. package/lib/esm/components/LiveStreamRoom/LiveStreamVideoConference/VideoConference.js +66 -9
  616. package/lib/esm/components/NavigationMenuIconButton/DefaultDrawerContent.js +9 -7
  617. package/lib/esm/components/NavigationMenuIconButton/NavigationMenuDrawer.d.ts +3 -1
  618. package/lib/esm/components/NavigationMenuIconButton/NavigationMenuDrawer.js +13 -6
  619. package/lib/esm/components/NavigationToolbar/NavigationToolbar.d.ts +1 -1
  620. package/lib/esm/components/NavigationToolbar/NavigationToolbar.js +14 -3
  621. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.d.ts +1 -1
  622. package/lib/esm/components/NavigationToolbarMobile/NavigationToolbarMobile.js +4 -4
  623. package/lib/esm/components/Notification/Course/Course.d.ts +15 -0
  624. package/lib/esm/components/Notification/Course/Course.js +86 -0
  625. package/lib/esm/components/Notification/Course/index.d.ts +3 -0
  626. package/lib/esm/components/Notification/Course/index.js +2 -0
  627. package/lib/esm/components/Notification/Course/utils.d.ts +5 -0
  628. package/lib/esm/components/Notification/Course/utils.js +39 -0
  629. package/lib/esm/components/Notification/Event/Event.js +21 -3
  630. package/lib/esm/components/Notification/Notification.js +9 -0
  631. package/lib/esm/components/RelatedEventsWidget/RelatedEventsWidget.js +1 -2
  632. package/lib/esm/components/SearchDialog/SearchDialog.d.ts +4 -1
  633. package/lib/esm/components/SearchDialog/SearchDialog.js +2 -2
  634. package/lib/esm/components/SnippetNotifications/SnippetNotifications.js +9 -0
  635. package/lib/esm/components/TagAutocomplete/TagAutocomplete.js +2 -2
  636. package/lib/esm/components/ToastNotifications/ToastNotifications.js +9 -0
  637. package/lib/esm/components/UserCreatedCoursesWidget/Skeleton.d.ts +21 -0
  638. package/lib/esm/components/UserCreatedCoursesWidget/Skeleton.js +39 -0
  639. package/lib/esm/components/UserCreatedCoursesWidget/UserCreatedCoursesWidget.d.ts +63 -0
  640. package/lib/esm/components/UserCreatedCoursesWidget/UserCreatedCoursesWidget.js +151 -0
  641. package/lib/esm/components/UserCreatedCoursesWidget/constants.d.ts +1 -0
  642. package/lib/esm/components/UserCreatedCoursesWidget/constants.js +1 -0
  643. package/lib/esm/components/UserCreatedCoursesWidget/index.d.ts +4 -0
  644. package/lib/esm/components/UserCreatedCoursesWidget/index.js +4 -0
  645. package/lib/esm/constants/Course.d.ts +6 -0
  646. package/lib/esm/constants/Course.js +7 -0
  647. package/lib/esm/constants/LiveStream.d.ts +1 -0
  648. package/lib/esm/constants/LiveStream.js +1 -0
  649. package/lib/esm/constants/PubSub.d.ts +14 -0
  650. package/lib/esm/constants/PubSub.js +15 -0
  651. package/lib/esm/index.d.ts +23 -2
  652. package/lib/esm/index.js +26 -5
  653. package/lib/esm/shared/AccordionLessons/AccordionLessons.d.ts +8 -0
  654. package/lib/esm/shared/AccordionLessons/AccordionLessons.js +61 -0
  655. package/lib/esm/shared/AccordionLessons/Skeleton.d.ts +1 -0
  656. package/lib/esm/shared/AccordionLessons/Skeleton.js +18 -0
  657. package/lib/esm/shared/AccordionLessons/constants.d.ts +1 -0
  658. package/lib/esm/shared/AccordionLessons/constants.js +1 -0
  659. package/lib/esm/shared/AccordionLessons/index.d.ts +4 -0
  660. package/lib/esm/shared/AccordionLessons/index.js +4 -0
  661. package/lib/esm/shared/AddUsersButton/AddUsersButton.d.ts +29 -0
  662. package/lib/esm/shared/AddUsersButton/AddUsersButton.js +134 -0
  663. package/lib/esm/shared/AddUsersButton/index.d.ts +3 -0
  664. package/lib/esm/shared/AddUsersButton/index.js +2 -0
  665. package/lib/esm/shared/CourseTypePopover/CourseTypePopover.d.ts +9 -0
  666. package/lib/esm/shared/CourseTypePopover/CourseTypePopover.js +45 -0
  667. package/lib/esm/shared/CourseTypePopover/index.d.ts +3 -0
  668. package/lib/esm/shared/CourseTypePopover/index.js +2 -0
  669. package/lib/esm/shared/CourseUsersTable/ChangeUsersStatus.d.ts +9 -0
  670. package/lib/esm/shared/CourseUsersTable/ChangeUsersStatus.js +56 -0
  671. package/lib/esm/shared/CourseUsersTable/CourseUsersTable.d.ts +21 -0
  672. package/lib/esm/shared/CourseUsersTable/CourseUsersTable.js +152 -0
  673. package/lib/esm/shared/CourseUsersTable/RemoveButton.d.ts +10 -0
  674. package/lib/esm/shared/CourseUsersTable/RemoveButton.js +48 -0
  675. package/lib/esm/shared/CourseUsersTable/RequestButton.d.ts +10 -0
  676. package/lib/esm/shared/CourseUsersTable/RequestButton.js +76 -0
  677. package/lib/esm/shared/CourseUsersTable/RowSkeleton.d.ts +8 -0
  678. package/lib/esm/shared/CourseUsersTable/RowSkeleton.js +11 -0
  679. package/lib/esm/shared/CourseUsersTable/SeeProgressButton.d.ts +9 -0
  680. package/lib/esm/shared/CourseUsersTable/SeeProgressButton.js +53 -0
  681. package/lib/esm/shared/CourseUsersTable/Skeleton.d.ts +1 -0
  682. package/lib/esm/shared/CourseUsersTable/Skeleton.js +15 -0
  683. package/lib/esm/shared/CourseUsersTable/constants.d.ts +1 -0
  684. package/lib/esm/shared/CourseUsersTable/constants.js +1 -0
  685. package/lib/esm/shared/CourseUsersTable/index.d.ts +4 -0
  686. package/lib/esm/shared/CourseUsersTable/index.js +4 -0
  687. package/lib/esm/shared/DateTimeAgo/index.d.ts +1 -1
  688. package/lib/esm/shared/EmptyStatus/EmptyStatus.d.ts +11 -0
  689. package/lib/esm/shared/EmptyStatus/EmptyStatus.js +23 -0
  690. package/lib/esm/shared/EmptyStatus/index.d.ts +3 -0
  691. package/lib/esm/shared/EmptyStatus/index.js +2 -0
  692. package/lib/esm/shared/EventActionsMenu/index.js +6 -2
  693. package/lib/esm/shared/LessonCommentActionsMenu/index.d.ts +41 -0
  694. package/lib/esm/shared/LessonCommentActionsMenu/index.js +194 -0
  695. package/lib/esm/shared/LessonFilePreview/index.d.ts +12 -0
  696. package/lib/esm/shared/LessonFilePreview/index.js +25 -0
  697. package/lib/esm/shared/Media/Link/UrlTextField/index.js +3 -4
  698. package/lib/esm/shared/UpScalingTierBadge/index.js +9 -0
  699. package/lib/esm/types/course.d.ts +40 -0
  700. package/lib/esm/types/course.js +30 -0
  701. package/lib/esm/types/index.d.ts +2 -1
  702. package/lib/esm/types/index.js +2 -1
  703. package/lib/esm/utils/buttonCounters.d.ts +1 -0
  704. package/lib/esm/utils/buttonCounters.js +3 -2
  705. package/lib/esm/utils/course.d.ts +14 -0
  706. package/lib/esm/utils/course.js +32 -0
  707. package/lib/esm/utils/events.d.ts +1 -0
  708. package/lib/esm/utils/events.js +4 -0
  709. package/lib/umd/578.js +2 -0
  710. package/lib/umd/60a7fdeaadfe844bc015.woff2 +0 -0
  711. package/lib/umd/assets/icons.svg +9 -3
  712. package/lib/umd/{c3528e120c4e831db2ae.woff → b6dbec3d5816ff8baef1.woff} +0 -0
  713. package/lib/umd/{2aa155858f48b8f3911a.eot → ba74e493633796d551d1.ttf} +0 -0
  714. package/lib/umd/{a221d3aba0f6753cfbb7.ttf → c473ce30406a3dad83e1.eot} +0 -0
  715. package/lib/umd/react-ui.js +1 -1
  716. package/package.json +16 -14
  717. package/lib/umd/36f3af7f155d916c26ff.woff2 +0 -0
  718. package/lib/umd/653.js +0 -2
  719. /package/lib/umd/{653.js.LICENSE.txt → 578.js.LICENSE.txt} +0 -0
@@ -0,0 +1,199 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import React, { useContext, useState } from 'react';
4
+ import { styled } from '@mui/material/styles';
5
+ import Widget from '../Widget';
6
+ import { FormattedMessage } from 'react-intl';
7
+ import { Avatar, Box, CardContent, Typography } from '@mui/material';
8
+ import Bullet from '../../shared/Bullet';
9
+ import classNames from 'classnames';
10
+ import { SCOPE_SC_UI } from '../../constants/Errors';
11
+ import CommentObjectSkeleton from './Skeleton';
12
+ import CommentObjectReply from '../CommentObjectReply';
13
+ import DateTimeAgo from '../../shared/DateTimeAgo';
14
+ import { getCommentContributionHtml } from '../../utils/contribution';
15
+ import { useSnackbar } from 'notistack';
16
+ import { useThemeProps } from '@mui/system';
17
+ import BaseItem from '../../shared/BaseItem';
18
+ import { Endpoints, http } from '@selfcommunity/api-services';
19
+ import { CacheStrategies, Logger, LRUCache } from '@selfcommunity/utils';
20
+ import { Link, SCCache, SCRoutes, SCUserContext, UserUtils, useSCFetchLessonCommentObject, useSCRouting } from '@selfcommunity/react-core';
21
+ import UserDeletedSnackBar from '../../shared/UserDeletedSnackBar';
22
+ import UserAvatar from '../../shared/UserAvatar';
23
+ import { PREFIX } from './constants';
24
+ import LessonCommentActionsMenu from '../../shared/LessonCommentActionsMenu';
25
+ import LessonFilePreview from '../../shared/LessonFilePreview';
26
+ const classes = {
27
+ root: `${PREFIX}-root`,
28
+ comment: `${PREFIX}-comment`,
29
+ avatar: `${PREFIX}-avatar`,
30
+ content: `${PREFIX}-content`,
31
+ author: `${PREFIX}-author`,
32
+ textContent: `${PREFIX}-text-content`,
33
+ mediaContent: `${PREFIX}-media-content`,
34
+ commentActionsMenu: `${PREFIX}-comment-actions-menu`
35
+ };
36
+ const Root = styled(Box, {
37
+ name: PREFIX,
38
+ slot: 'Root'
39
+ })(() => ({}));
40
+ /**
41
+ * > API documentation for the Community-JS Comment Object component. Learn about the available props and the CSS API.
42
+ *
43
+ *
44
+ * This component renders a comment item.
45
+ * Take a look at our <strong>demo</strong> component [here](/docs/sdk/community-js/react-ui/Components/CommentObject)
46
+
47
+ #### Import
48
+
49
+ ```jsx
50
+ import {CommentObject} from '@selfcommunity/react-ui';
51
+ ```
52
+
53
+ #### Component Name
54
+
55
+ The name `SCCommentObject` can be used when providing style overrides in the theme.
56
+
57
+
58
+ #### CSS
59
+
60
+ |Rule Name|Global class|Description|
61
+ |---|---|---|
62
+ |root|.SCCommentObject-root|Styles applied to the root element.|
63
+ |comment|.SCCommentObject-comment|Styles applied to comment element.|
64
+ |avatar|.SCCommentObject-avatar|Styles applied to the avatar element.|
65
+ |author|.SCCommentObject-author|Styles applied to the author section.|
66
+ |content|.SCCommentObject-content|Styles applied to content section.|
67
+ |textContent|.SCCommentObject-text-content|Styles applied to text content section.|
68
+ |mediaContent|.SCCommentObject-media-content|Styles applied to media content section.|
69
+ |commentActionsMenu|.SCCommentObject-comment-actions-menu|Styles applied to comment action menu element.|
70
+
71
+
72
+ * @param inProps
73
+ */
74
+ export default function LessonCommentObject(inProps) {
75
+ // PROPS
76
+ const props = useThemeProps({
77
+ props: inProps,
78
+ name: PREFIX
79
+ });
80
+ const { id = `lesson_comment_object_${props.commentObjectId ? props.commentObjectId : props.commentObject ? props.commentObject.id : ''}`, className, commentObjectId, commentObject, isEditing, lessonObjectId, lessonObject, onDelete, elevation = 0, CommentObjectSkeletonProps = { elevation }, CommentObjectReplyProps = { elevation }, cacheStrategy = CacheStrategies.NETWORK_ONLY } = props, rest = __rest(props, ["id", "className", "commentObjectId", "commentObject", "isEditing", "lessonObjectId", "lessonObject", "onDelete", "elevation", "CommentObjectSkeletonProps", "CommentObjectReplyProps", "cacheStrategy"]);
81
+ // CONTEXT
82
+ const scUserContext = useContext(SCUserContext);
83
+ const scRoutingContext = useSCRouting();
84
+ const { enqueueSnackbar } = useSnackbar();
85
+ // STATE
86
+ const { obj, setObj } = useSCFetchLessonCommentObject({ id: commentObjectId, commentObject: commentObject, lesson: lessonObject, cacheStrategy });
87
+ const [isSavingComment, setIsSavingComment] = useState(false);
88
+ const [editComment, setEditComment] = useState(null);
89
+ const [openAlert, setOpenAlert] = useState(false);
90
+ // HANDLERS
91
+ /**
92
+ * Update state object
93
+ * @param newObj
94
+ */
95
+ function updateObject(newObj) {
96
+ LRUCache.set(SCCache.getLessonCommentCacheKey(obj.id), newObj);
97
+ setObj(newObj);
98
+ LRUCache.deleteKeysWithPrefix(SCCache.getLessonCommentsCachePrefixKeys(lessonObject.id));
99
+ }
100
+ /**
101
+ * Handle comment delete
102
+ */
103
+ function handleDelete(comment) {
104
+ updateObject(comment);
105
+ onDelete && onDelete(comment);
106
+ }
107
+ /**
108
+ * Handle edit comment
109
+ */
110
+ function handleEdit(comment) {
111
+ setEditComment(comment);
112
+ isEditing && isEditing(true);
113
+ }
114
+ function handleCancel() {
115
+ setEditComment(null);
116
+ isEditing && isEditing(false);
117
+ }
118
+ /**
119
+ * Perform save/update comment
120
+ */
121
+ const performUpdate = (comment, medias) => {
122
+ const mediaIds = medias ? medias.map((media) => media.id) : [];
123
+ return http
124
+ .request({
125
+ url: Endpoints.UpdateCourseComment.url({
126
+ id: lessonObject.course_id,
127
+ section_id: lessonObject.section_id,
128
+ lesson_id: lessonObject.id,
129
+ comment_id: commentObject.id
130
+ }),
131
+ method: Endpoints.UpdateCourseComment.method,
132
+ data: { text: comment, medias: mediaIds }
133
+ })
134
+ .then((res) => {
135
+ if (res.status >= 300) {
136
+ return Promise.reject(res);
137
+ }
138
+ return Promise.resolve(res.data);
139
+ });
140
+ };
141
+ /**
142
+ * Handle save comment
143
+ */
144
+ function handleUpdate(comment, medias) {
145
+ if (UserUtils.isBlocked(scUserContext.user)) {
146
+ enqueueSnackbar(_jsx(FormattedMessage, { id: "ui.common.userBlocked", defaultMessage: "ui.common.userBlocked" }), {
147
+ variant: 'warning',
148
+ autoHideDuration: 3000
149
+ });
150
+ }
151
+ else {
152
+ setIsSavingComment(true);
153
+ performUpdate(comment, medias)
154
+ .then((data) => {
155
+ const newObj = Object.assign({}, obj, {
156
+ text: data.text,
157
+ html: data.html,
158
+ created_at: data.created_at,
159
+ medias: medias
160
+ });
161
+ updateObject(newObj);
162
+ setEditComment(null);
163
+ setIsSavingComment(false);
164
+ isEditing && isEditing(false);
165
+ })
166
+ .catch((error) => {
167
+ Logger.error(SCOPE_SC_UI, error);
168
+ enqueueSnackbar(_jsx(FormattedMessage, { id: "ui.common.error.action", defaultMessage: "ui.common.error.action" }), {
169
+ variant: 'error',
170
+ autoHideDuration: 3000
171
+ });
172
+ });
173
+ }
174
+ }
175
+ /**
176
+ * Render comment & latest activities
177
+ * @param comment
178
+ */
179
+ function renderComment(comment) {
180
+ const summaryHtml = getCommentContributionHtml(comment.html, scRoutingContext.url);
181
+ return (_jsx(React.Fragment, { children: editComment && editComment.id === comment.id ? (_jsx(Box, Object.assign({ className: classes.comment }, { children: _jsx(CommentObjectReply, Object.assign({ text: comment.html, medias: comment.medias, autoFocus: true, id: `edit-${comment.id}`, onSave: handleUpdate, onCancel: handleCancel, editable: !isSavingComment, EditorProps: { uploadFile: true, uploadImage: false, isLessonCommentEditor: true } }, CommentObjectReplyProps)) }))) : (_jsx(BaseItem, { elevation: 0, className: classes.comment, image: _jsx(Link, Object.assign({}, (!comment.created_by.deleted && { to: scRoutingContext.url(SCRoutes.USER_PROFILE_ROUTE_NAME, comment.created_by) }), { onClick: comment.created_by.deleted ? () => setOpenAlert(true) : null }, { children: _jsx(UserAvatar, Object.assign({ hide: !obj.created_by.community_badge }, { children: _jsx(Avatar, { alt: obj.created_by.username, variant: "circular", src: comment.created_by.avatar, className: classes.avatar }) })) })), disableTypography: true, primary: _jsx(_Fragment, { children: _jsxs(Widget, Object.assign({ className: classes.content, elevation: elevation }, rest, { children: [_jsxs(CardContent, { children: [_jsx(Link, Object.assign({ className: classes.author }, (!comment.created_by.deleted && { to: scRoutingContext.url(SCRoutes.USER_PROFILE_ROUTE_NAME, comment.created_by) }), { onClick: comment.created_by.deleted ? () => setOpenAlert(true) : null }, { children: _jsx(Typography, Object.assign({ component: "span" }, { children: comment.created_by.username })) })), _jsxs(_Fragment, { children: [_jsx(Bullet, {}), _jsx(DateTimeAgo, { date: comment.created_at, showStartIcon: false })] }), _jsx(Typography, { className: classes.textContent, variant: "body2", gutterBottom: true, dangerouslySetInnerHTML: { __html: summaryHtml } }), obj.medias && obj.medias.length > 0 && (_jsx(_Fragment, { children: obj.medias.map((media) => {
182
+ return _jsx(LessonFilePreview, { className: classes.mediaContent, media: media }, media.id);
183
+ }) }))] }), scUserContext.user && scUserContext.user.id === comment.created_by.id && (_jsx(Box, Object.assign({ className: classes.commentActionsMenu }, { children: _jsx(LessonCommentActionsMenu, { lesson: lessonObject, commentObject: comment, onDelete: handleDelete, onEdit: handleEdit }) })))] })) }) })) }, comment.id));
184
+ }
185
+ /**
186
+ * Render comments
187
+ */
188
+ let comment;
189
+ if (obj) {
190
+ comment = renderComment(obj);
191
+ }
192
+ else {
193
+ comment = _jsx(CommentObjectSkeleton, Object.assign({}, CommentObjectSkeletonProps));
194
+ }
195
+ /**
196
+ * Render object
197
+ */
198
+ return (_jsxs(_Fragment, { children: [_jsx(Root, Object.assign({ id: id, className: classNames(classes.root, className) }, { children: comment })), openAlert && _jsx(UserDeletedSnackBar, { open: openAlert, handleClose: () => setOpenAlert(false) })] }));
199
+ }
@@ -0,0 +1,21 @@
1
+ /**
2
+ * > API documentation for the Community-JS Lesson Comment Object Skeleton component. Learn about the available props and the CSS API.
3
+
4
+ #### Import
5
+
6
+ ```jsx
7
+ import {LessonCommentObjectSkeleton} from '@selfcommunity/react-ui';
8
+ ```
9
+
10
+ #### Component Name
11
+
12
+ The name `SCLessonCommentObject-skeleton-root` can be used when providing style overrides in the theme.
13
+
14
+ #### CSS
15
+
16
+ |Rule Name|Global class|Description|
17
+ |---|---|---|
18
+ |root|.SCLessonCommentObject-skeleton-root|Styles applied to the root element.|
19
+ *
20
+ */
21
+ export default function LessonCommentObjectSkeleton(props: any): JSX.Element;
@@ -0,0 +1,43 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import Widget from '../Widget';
4
+ import { styled } from '@mui/material/styles';
5
+ import Skeleton from '@mui/material/Skeleton';
6
+ import { CardContent, useTheme } from '@mui/material';
7
+ import BaseItem from '../../shared/BaseItem';
8
+ import { PREFIX } from './constants';
9
+ const classes = {
10
+ root: `${PREFIX}-skeleton-root`,
11
+ avatar: `${PREFIX}-avatar`,
12
+ primaryContent: `${PREFIX}-primary-content`,
13
+ secondaryContent: `${PREFIX}-secondary-content`
14
+ };
15
+ const Root = styled(BaseItem, {
16
+ name: PREFIX,
17
+ slot: 'SkeletonRoot'
18
+ })(() => ({}));
19
+ /**
20
+ * > API documentation for the Community-JS Lesson Comment Object Skeleton component. Learn about the available props and the CSS API.
21
+
22
+ #### Import
23
+
24
+ ```jsx
25
+ import {LessonCommentObjectSkeleton} from '@selfcommunity/react-ui';
26
+ ```
27
+
28
+ #### Component Name
29
+
30
+ The name `SCLessonCommentObject-skeleton-root` can be used when providing style overrides in the theme.
31
+
32
+ #### CSS
33
+
34
+ |Rule Name|Global class|Description|
35
+ |---|---|---|
36
+ |root|.SCLessonCommentObject-skeleton-root|Styles applied to the root element.|
37
+ *
38
+ */
39
+ export default function LessonCommentObjectSkeleton(props) {
40
+ const { WidgetProps } = props, rest = __rest(props, ["WidgetProps"]);
41
+ const theme = useTheme();
42
+ return (_jsx(Root, Object.assign({ className: classes.root, disableTypography: true }, rest, { image: _jsx(Skeleton, { animation: "wave", variant: "circular", width: theme.selfcommunity.user.avatar.sizeMedium, height: theme.selfcommunity.user.avatar.sizeMedium, className: classes.avatar }), primary: _jsx(Skeleton, { animation: "wave", height: 10, width: "25%", className: classes.primaryContent }), secondary: _jsx(_Fragment, { children: _jsx(Widget, Object.assign({}, WidgetProps, { children: _jsxs(CardContent, Object.assign({ className: classes.secondaryContent }, { children: [_jsx(Skeleton, { animation: "wave", height: 10, width: "80%" }), _jsx(Skeleton, { animation: "wave", height: 10, width: "70%" }), _jsx(Skeleton, { animation: "wave", height: 10, width: "60%" })] })) })) }) })));
43
+ }
@@ -0,0 +1 @@
1
+ export declare const PREFIX = "SCLessonCommentObject";
@@ -0,0 +1 @@
1
+ export const PREFIX = 'SCLessonCommentObject';
@@ -0,0 +1,4 @@
1
+ import LessonCommentObject, { LessonCommentObjectProps } from './LessonCommentObject';
2
+ import LessonCommentObjectSkeleton from './Skeleton';
3
+ export default LessonCommentObject;
4
+ export { LessonCommentObjectProps, LessonCommentObjectSkeleton };
@@ -0,0 +1,4 @@
1
+ import LessonCommentObject from './LessonCommentObject';
2
+ import LessonCommentObjectSkeleton from './Skeleton';
3
+ export default LessonCommentObject;
4
+ export { LessonCommentObjectSkeleton };
@@ -0,0 +1,76 @@
1
+ import { LessonCommentObjectProps } from '../LessonCommentObject';
2
+ import { SCCourseLessonType } from '@selfcommunity/types';
3
+ import { CacheStrategies } from '@selfcommunity/utils';
4
+ export interface LessonCommentObjectsProps {
5
+ /**
6
+ * Id of the LessonCommentObjects
7
+ * @default `lesson_comments_object_<lessonObjectId | lessonObject.id>`
8
+ */
9
+ id?: string;
10
+ /**
11
+ * Overrides or extends the styles applied to the component.
12
+ * @default null
13
+ */
14
+ className?: string;
15
+ /**
16
+ * Id of lesson object
17
+ * @default null
18
+ */
19
+ lessonObjectId?: number;
20
+ /**
21
+ * Lesson object
22
+ * @default null
23
+ */
24
+ lessonObject?: SCCourseLessonType;
25
+ /**
26
+ * Props to spread to single comment object
27
+ * @default {}
28
+ */
29
+ CommentComponentProps?: LessonCommentObjectProps;
30
+ /**
31
+ * Props to spread to CommentsObjectSkeleton
32
+ * @default {}
33
+ */
34
+ CommentsObjectSkeletonProps?: any;
35
+ /**
36
+ * Props to spread to single comment object skeleton
37
+ * @default {elevation: 0},
38
+ */
39
+ CommentObjectSkeletonProps?: any;
40
+ /**
41
+ * Caching strategies
42
+ * @default CacheStrategies.CACHE_FIRST
43
+ */
44
+ cacheStrategy?: CacheStrategies;
45
+ /**
46
+ * Other props
47
+ */
48
+ [p: string]: any;
49
+ }
50
+ /**
51
+ * > API documentation for the Community-JS Comments Object component. Learn about the available props and the CSS API.
52
+
53
+ #### Import
54
+
55
+ ```jsx
56
+ import {LessonCommentObjects} from '@selfcommunity/react-ui';
57
+ ```
58
+
59
+ #### Component Name
60
+
61
+ The name `SCLessonCommentObjects` can be used when providing style overrides in the theme.
62
+
63
+ #### CSS
64
+
65
+ |Rule Name|Global class|Description|
66
+ |---|---|---|
67
+ |root|.SCLessonCommentObjects-root|Styles applied to the root element.|
68
+ |pagination|.SCLessonCommentObjects-pagination|Styles applied to the pagination controls.|
69
+ |paginationLink|.SCLessonCommentObjects-pagination-link|Styles applied to the pagination link.|
70
+ |loadNextCommentsButton|.SCLessonCommentObjects-load-next-comments-button|Styles applied to the load next comments button.|
71
+ |loadPreviousCommentsButton|.SCLessonCommentObjects-load-previous-comments-button|Styles applied to the load previous comments button.|
72
+ |commentsCounter|.SCLessonCommentObjects-comments-counter|Styles applied to the comments counter element.|
73
+
74
+ * @param inProps
75
+ */
76
+ export default function LessonCommentObjects(inProps: LessonCommentObjectsProps): JSX.Element;
@@ -0,0 +1,182 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useEffect, useRef, useState } from 'react';
4
+ import { styled } from '@mui/material/styles';
5
+ import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
6
+ import LessonCommentObject, { LessonCommentObjectSkeleton } from '../LessonCommentObject';
7
+ import { Box, List, ListItem } from '@mui/material';
8
+ import classNames from 'classnames';
9
+ import { useThemeProps } from '@mui/system';
10
+ import { SCCommentsOrderBy } from '@selfcommunity/types';
11
+ import { CacheStrategies, Logger, LRUCache } from '@selfcommunity/utils';
12
+ import { SCCache, UserUtils, useSCFetchLessonCommentObjects, useSCUser } from '@selfcommunity/react-core';
13
+ import { PREFIX } from './constants';
14
+ import LessonCommentsObjectSkeleton from './Skeleton';
15
+ import CommentObjectReply from '../CommentObjectReply';
16
+ import { enqueueSnackbar } from 'notistack';
17
+ import { SCOPE_SC_UI } from '../../constants/Errors';
18
+ import { Endpoints, http } from '@selfcommunity/api-services';
19
+ import InfiniteScroll from '../../shared/InfiniteScroll';
20
+ import HiddenPlaceholder from '../../shared/HiddenPlaceholder';
21
+ const messages = defineMessages({
22
+ commentEditorPlaceholder: {
23
+ id: 'ui.lessonCommentObjects.editor.placeholder',
24
+ defaultMessage: 'ui.lessonCommentObjects.editor.placeholder'
25
+ }
26
+ });
27
+ const classes = {
28
+ root: `${PREFIX}-root`,
29
+ loadNextCommentsButton: `${PREFIX}-load-more-comments-button`,
30
+ loadPreviousCommentsButton: `${PREFIX}-load-previous-comments-button`,
31
+ paginationLink: `${PREFIX}-pagination-link`,
32
+ pagination: `${PREFIX}-pagination`,
33
+ commentsCounter: `${PREFIX}-comments-counter`,
34
+ commentNotFound: `${PREFIX}-comment-not-found`,
35
+ noOtherComments: `${PREFIX}-no-other-comment`
36
+ };
37
+ const Root = styled(Box, {
38
+ name: PREFIX,
39
+ slot: 'Root'
40
+ })(() => ({}));
41
+ /**
42
+ * > API documentation for the Community-JS Comments Object component. Learn about the available props and the CSS API.
43
+
44
+ #### Import
45
+
46
+ ```jsx
47
+ import {LessonCommentObjects} from '@selfcommunity/react-ui';
48
+ ```
49
+
50
+ #### Component Name
51
+
52
+ The name `SCLessonCommentObjects` can be used when providing style overrides in the theme.
53
+
54
+ #### CSS
55
+
56
+ |Rule Name|Global class|Description|
57
+ |---|---|---|
58
+ |root|.SCLessonCommentObjects-root|Styles applied to the root element.|
59
+ |pagination|.SCLessonCommentObjects-pagination|Styles applied to the pagination controls.|
60
+ |paginationLink|.SCLessonCommentObjects-pagination-link|Styles applied to the pagination link.|
61
+ |loadNextCommentsButton|.SCLessonCommentObjects-load-next-comments-button|Styles applied to the load next comments button.|
62
+ |loadPreviousCommentsButton|.SCLessonCommentObjects-load-previous-comments-button|Styles applied to the load previous comments button.|
63
+ |commentsCounter|.SCLessonCommentObjects-comments-counter|Styles applied to the comments counter element.|
64
+
65
+ * @param inProps
66
+ */
67
+ export default function LessonCommentObjects(inProps) {
68
+ const props = useThemeProps({
69
+ props: inProps,
70
+ name: PREFIX
71
+ });
72
+ // PROPS
73
+ const { id = `lesson_comment_objects_lesson_${props.lessonObjectId ? props.lessonObjectId : props.lessonObject ? props.lessonObject.id : ''}`, className, lessonObjectId, lessonObject, CommentComponentProps = {}, CommentObjectSkeletonProps = { elevation: 0 }, CommentsObjectSkeletonProps = {}, cacheStrategy = CacheStrategies.STALE_WHILE_REVALIDATE } = props, rest = __rest(props, ["id", "className", "lessonObjectId", "lessonObject", "CommentComponentProps", "CommentObjectSkeletonProps", "CommentsObjectSkeletonProps", "cacheStrategy"]);
74
+ //STATE
75
+ const [commenting, setIsCommenting] = useState(false);
76
+ const [editing, setIsEditing] = useState(false);
77
+ const [replyKey, setReplyKey] = useState(0);
78
+ // CONTEXT
79
+ const scUserContext = useSCUser();
80
+ // INTL
81
+ const intl = useIntl();
82
+ // REF
83
+ const commentsEndRef = useRef(null);
84
+ // STATE
85
+ const commentsObject = useSCFetchLessonCommentObjects({
86
+ id: lessonObject.id,
87
+ lessonObject: lessonObject,
88
+ orderBy: SCCommentsOrderBy.ADDED_AT_ASC,
89
+ cacheStrategy
90
+ });
91
+ // EFFECTS
92
+ useEffect(() => {
93
+ if (commentsObject.lessonObject) {
94
+ commentsObject.getNextPage();
95
+ }
96
+ }, [commentsObject.lessonObject]);
97
+ //HANDLERS
98
+ function handleNext() {
99
+ commentsObject.getNextPage();
100
+ }
101
+ const scrollToBottom = () => {
102
+ var _a;
103
+ (_a = commentsEndRef.current) === null || _a === void 0 ? void 0 : _a.scrollIntoView({ block: 'end', behavior: 'smooth' });
104
+ };
105
+ useEffect(() => {
106
+ if (commentsObject.comments.length > 0) {
107
+ scrollToBottom();
108
+ }
109
+ }, [commentsObject.comments]);
110
+ /**
111
+ * Perform save/update comment
112
+ */
113
+ const performComment = (comment, medias) => {
114
+ const mediaIds = medias ? medias.map((media) => media.id) : [];
115
+ return http
116
+ .request({
117
+ url: Endpoints.CreateCourseComment.url({ id: lessonObject.course_id, section_id: lessonObject.section_id, lesson_id: lessonObject.id }),
118
+ method: Endpoints.CreateCourseComment.method,
119
+ data: { text: comment, medias: mediaIds }
120
+ })
121
+ .then((res) => {
122
+ if (res.status >= 300) {
123
+ return Promise.reject(res);
124
+ }
125
+ return Promise.resolve(res.data);
126
+ });
127
+ };
128
+ /**
129
+ * Handle save comment
130
+ */
131
+ function handleCommentAction(comment, medias) {
132
+ if (UserUtils.isBlocked(scUserContext.user)) {
133
+ enqueueSnackbar(_jsx(FormattedMessage, { id: "ui.common.userBlocked", defaultMessage: "ui.common.userBlocked" }), {
134
+ variant: 'warning',
135
+ autoHideDuration: 3000
136
+ });
137
+ }
138
+ else {
139
+ setIsCommenting(true);
140
+ performComment(comment, medias)
141
+ .then((data) => {
142
+ handleCommentsUpdate(data);
143
+ setReplyKey(comment.id);
144
+ setIsCommenting(false);
145
+ })
146
+ .catch((error) => {
147
+ Logger.error(SCOPE_SC_UI, error);
148
+ enqueueSnackbar(_jsx(FormattedMessage, { id: "ui.common.error.action", defaultMessage: "ui.common.error.action" }), {
149
+ variant: 'error',
150
+ autoHideDuration: 3000
151
+ });
152
+ });
153
+ }
154
+ }
155
+ const handleCommentsUpdate = (comment, forDeletion) => {
156
+ let updated;
157
+ if (forDeletion) {
158
+ updated = commentsObject.comments.filter((c) => c.id !== comment.id);
159
+ }
160
+ else {
161
+ updated = [...commentsObject.comments, comment];
162
+ }
163
+ commentsObject.updateLessonComments([...updated]);
164
+ LRUCache.set(SCCache.getLessonCommentCacheKey(lessonObject.id), updated);
165
+ LRUCache.deleteKeysWithPrefix(SCCache.getLessonCommentsCachePrefixKeys(lessonObject.id));
166
+ };
167
+ /**
168
+ * Renders root object(if obj)
169
+ */
170
+ if (!commentsObject.lessonObject) {
171
+ return _jsx(HiddenPlaceholder, {});
172
+ }
173
+ if (!commentsObject.comments.length && commentsObject.isLoadingNext) {
174
+ return _jsx(LessonCommentsObjectSkeleton, Object.assign({ count: 5 }, CommentsObjectSkeletonProps));
175
+ }
176
+ return (_jsx(Root, Object.assign({ id: id, className: classNames(classes.root, className) }, rest, { children: _jsxs(_Fragment, { children: [_jsx(_Fragment, { children: commentsObject.comments.length > 0 ? (_jsx(InfiniteScroll, Object.assign({ height: '100%', dataLength: commentsObject.comments.length, next: handleNext, hasMoreNext: Boolean(commentsObject.next), loaderNext: _jsx(LessonCommentObjectSkeleton, Object.assign({}, CommentObjectSkeletonProps, { count: 1 })) }, { children: _jsx(List, Object.assign({ ref: commentsEndRef }, { children: commentsObject.comments.map((c, index) => (_jsx(ListItem, { children: _jsx(LessonCommentObject, Object.assign({ commentObject: c, lessonObject: commentsObject.lessonObject, onDelete: (comment) => handleCommentsUpdate(comment, true), isEditing: (editing) => setIsEditing(editing) }, CommentComponentProps, { CommentObjectSkeletonProps: CommentObjectSkeletonProps }), c.id) }, index))) })) }))) : null }), !editing && (_jsx(CommentObjectReply, { id: `reply-lessonCommentObjects`, showAvatar: false, replyIcon: true, editable: !commenting, onReply: handleCommentAction, EditorProps: {
177
+ placeholder: intl.formatMessage(messages.commentEditorPlaceholder),
178
+ uploadFile: true,
179
+ uploadImage: false,
180
+ isLessonCommentEditor: true
181
+ } }, replyKey))] }) })));
182
+ }
@@ -0,0 +1,23 @@
1
+ /**
2
+ * > API documentation for the Community-JS Comments Object Skeleton component. Learn about the available props and the CSS API.
3
+
4
+ #### Import
5
+
6
+ ```jsx
7
+ import {LessonCommentObjectsSkeleton} from '@selfcommunity/react-ui';
8
+ ```
9
+
10
+ #### Component Name
11
+
12
+ The name `SCLessonCommentObjects-skeleton-root` can be used when providing style overrides in the theme.
13
+
14
+ #### CSS
15
+
16
+ |Rule Name|Global class|Description|
17
+ |---|---|---|
18
+ |root|.SCLessonCommentObjects-skeleton-root|Styles applied to the root element.|
19
+ *
20
+ */
21
+ export default function LessonCommentObjectsSkeleton(props: {
22
+ count?: number;
23
+ }): JSX.Element;
@@ -0,0 +1,37 @@
1
+ import { __rest } from "tslib";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { styled } from '@mui/material/styles';
4
+ import { Box } from '@mui/material';
5
+ import { PREFIX } from './constants';
6
+ import LessonCommentObjectSkeleton from '../LessonCommentObject/Skeleton';
7
+ const classes = {
8
+ root: `${PREFIX}-skeleton-root`
9
+ };
10
+ const Root = styled(Box, {
11
+ name: PREFIX,
12
+ slot: 'SkeletonRoot'
13
+ })(() => ({}));
14
+ /**
15
+ * > API documentation for the Community-JS Comments Object Skeleton component. Learn about the available props and the CSS API.
16
+
17
+ #### Import
18
+
19
+ ```jsx
20
+ import {LessonCommentObjectsSkeleton} from '@selfcommunity/react-ui';
21
+ ```
22
+
23
+ #### Component Name
24
+
25
+ The name `SCLessonCommentObjects-skeleton-root` can be used when providing style overrides in the theme.
26
+
27
+ #### CSS
28
+
29
+ |Rule Name|Global class|Description|
30
+ |---|---|---|
31
+ |root|.SCLessonCommentObjects-skeleton-root|Styles applied to the root element.|
32
+ *
33
+ */
34
+ export default function LessonCommentObjectsSkeleton(props) {
35
+ const { count = 3 } = props, rest = __rest(props, ["count"]);
36
+ return (_jsx(Root, Object.assign({ className: classes.root }, rest, { children: [...Array(count)].map((comment, index) => (_jsx(LessonCommentObjectSkeleton, { elevation: 0 }, index))) })));
37
+ }
@@ -0,0 +1 @@
1
+ export declare const PREFIX = "SCLessonCommentObjects";
@@ -0,0 +1 @@
1
+ export const PREFIX = 'SCLessonCommentObjects';
@@ -0,0 +1,4 @@
1
+ import LessonCommentObjects, { LessonCommentObjectsProps } from './LessonCommentObjects';
2
+ import LessonCommentObjectsSkeleton from './Skeleton';
3
+ export default LessonCommentObjects;
4
+ export { LessonCommentObjectsProps, LessonCommentObjectsSkeleton };
@@ -0,0 +1,4 @@
1
+ import LessonCommentObjects from './LessonCommentObjects';
2
+ import LessonCommentObjectsSkeleton from './Skeleton';
3
+ export default LessonCommentObjects;
4
+ export { LessonCommentObjectsSkeleton };