@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,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const material_1 = require("@mui/material");
5
+ const constants_1 = require("../constants");
6
+ const classes = {
7
+ lessonTitle: `${constants_1.PREFIX}-lesson-title`,
8
+ lessonInfoWrapper: `${constants_1.PREFIX}-lesson-info-wrapper`,
9
+ lessonInfo: `${constants_1.PREFIX}-lesson-info`,
10
+ lessonsSectionsWrapper: `${constants_1.PREFIX}-lessons-sections-wrapper`,
11
+ lessonsSections: `${constants_1.PREFIX}-lessons-sections`,
12
+ tableContainer: `${constants_1.PREFIX}-table-container`,
13
+ margin: `${constants_1.PREFIX}-margin`,
14
+ marginLeft: `${constants_1.PREFIX}-margin-left`,
15
+ actionsWrapper: `${constants_1.PREFIX}-actions-wrapper`
16
+ };
17
+ function LessonsSkeleton() {
18
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, { children: [(0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "150px", height: "21px", className: classes.lessonTitle }), (0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonInfoWrapper }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonInfo }, { children: [(0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rectangular", width: "14px", height: "14px" }), (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "150px", height: "21px" })] })), (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rectangular", width: "105px", height: "32px" })] })), (0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonsSectionsWrapper }, { children: [(0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", width: "159px", height: "21px" }), (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", width: "100px", height: "32px" })] })), (0, jsx_runtime_1.jsx)(material_1.TableContainer, Object.assign({ className: classes.tableContainer }, { children: (0, jsx_runtime_1.jsxs)(material_1.Table, { children: [(0, jsx_runtime_1.jsx)(material_1.TableHead, { children: (0, jsx_runtime_1.jsxs)(material_1.TableRow, { children: [(0, jsx_runtime_1.jsx)(material_1.TableCell, {}), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "102px", height: "32px" }) }), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "87px", height: "32px", className: classes.margin }) }), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "48px", height: "32px", className: classes.marginLeft }) })] }) }), (0, jsx_runtime_1.jsx)(material_1.TableBody, { children: (0, jsx_runtime_1.jsxs)(material_1.TableRow, { children: [(0, jsx_runtime_1.jsx)(material_1.TableCell, {}), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "102px", height: "21px" }) }), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rectangular", width: "250px", height: "54px", className: classes.margin }) }), (0, jsx_runtime_1.jsx)(material_1.TableCell, { children: (0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.actionsWrapper }, { children: [(0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rounded", width: "105px", height: "37px" }), (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "circular", width: "36px", height: "36px" })] })) })] }) })] }) }))] }));
19
+ }
20
+ exports.default = LessonsSkeleton;
@@ -0,0 +1,11 @@
1
+ import { SyntheticEvent } from 'react';
2
+ import { SCCourseType } from '@selfcommunity/types';
3
+ import { SCCourseEditTabType } from '../../types';
4
+ interface LessonsProps {
5
+ course: SCCourseType;
6
+ setCourse: (course: SCCourseType) => void;
7
+ handleTabChange: (_e: SyntheticEvent, newTabValue: SCCourseEditTabType) => void;
8
+ }
9
+ declare function Lessons(props: LessonsProps): JSX.Element;
10
+ declare const _default: import("react").MemoExoticComponent<typeof Lessons>;
11
+ export default _default;
@@ -0,0 +1,196 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_intl_1 = require("react-intl");
6
+ const constants_1 = require("./constants");
7
+ const react_1 = require("react");
8
+ const dnd_1 = require("@hello-pangea/dnd");
9
+ const types_1 = require("@selfcommunity/types");
10
+ const api_services_1 = require("@selfcommunity/api-services");
11
+ const utils_1 = require("@selfcommunity/utils");
12
+ const Errors_1 = require("../../constants/Errors");
13
+ const notistack_1 = require("notistack");
14
+ const material_1 = require("@mui/material");
15
+ const Status_1 = tslib_1.__importDefault(require("./Status"));
16
+ const EmptyStatus_1 = tslib_1.__importDefault(require("../../shared/EmptyStatus"));
17
+ const AddButton_1 = tslib_1.__importDefault(require("./Lessons/AddButton"));
18
+ const SectionRow_1 = tslib_1.__importDefault(require("./Lessons/SectionRow"));
19
+ const types_2 = require("./types");
20
+ const hooks_1 = require("./hooks");
21
+ const ConfirmDialog_1 = tslib_1.__importDefault(require("../../shared/ConfirmDialog/ConfirmDialog"));
22
+ const CourseTypePopover_1 = tslib_1.__importDefault(require("../../shared/CourseTypePopover"));
23
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
24
+ const classes = {
25
+ lessonTitle: `${constants_1.PREFIX}-lesson-title`,
26
+ lessonInfoWrapper: `${constants_1.PREFIX}-lesson-info-wrapper`,
27
+ lessonsInnerWrapper: `${constants_1.PREFIX}-lessons-inner-wrapper`,
28
+ lessonsSectionsWrapper: `${constants_1.PREFIX}-lessons-sections-wrapper`,
29
+ lessonsSections: `${constants_1.PREFIX}-lessons-sections`,
30
+ circle: `${constants_1.PREFIX}-circle`,
31
+ tableContainer: `${constants_1.PREFIX}-table-container`,
32
+ table: `${constants_1.PREFIX}-table`,
33
+ tableHeader: `${constants_1.PREFIX}-table-header`,
34
+ tableHeaderTypography: `${constants_1.PREFIX}-table-header-typography`,
35
+ tableBody: `${constants_1.PREFIX}-table-body`,
36
+ cellWidth: `${constants_1.PREFIX}-cell-width`,
37
+ cellAlignRight: `${constants_1.PREFIX}-cell-align-right`,
38
+ cellAlignCenter: `${constants_1.PREFIX}-cell-align-center`,
39
+ lessonEmptyStatus: `${constants_1.PREFIX}-lesson-empty-status`,
40
+ emptyStatusButton: `${constants_1.PREFIX}-empty-status-button`,
41
+ contrastColor: `${constants_1.PREFIX}-contrast-color`
42
+ };
43
+ function Lessons(props) {
44
+ // PROPS
45
+ const { course, setCourse, handleTabChange } = props;
46
+ // STATES
47
+ const [sections, setSections] = (0, react_1.useState)([]);
48
+ const [dialog, setDialog] = (0, react_1.useState)(null);
49
+ // REFS
50
+ const ref = (0, react_1.useRef)(null);
51
+ // HOOKS
52
+ const { isDisabled } = (0, hooks_1.useIsDisabled)();
53
+ const { enqueueSnackbar } = (0, notistack_1.useSnackbar)();
54
+ const intl = (0, react_intl_1.useIntl)();
55
+ // EFFECTS
56
+ (0, react_1.useEffect)(() => {
57
+ if (course.sections) {
58
+ setSections(course.sections);
59
+ }
60
+ }, [course]);
61
+ // MEMOS
62
+ const isNewRow = (0, react_1.useMemo)(() => { var _a; return sections.length > ((_a = course.sections) === null || _a === void 0 ? void 0 : _a.length); }, [course, sections]);
63
+ const headerCells = (0, react_1.useMemo)(() => [
64
+ {
65
+ className: undefined,
66
+ id: 'ui.editCourse.tab.lessons.table.header.lessonName'
67
+ },
68
+ ...(course.type !== types_1.SCCourseTypologyType.SELF
69
+ ? [
70
+ {
71
+ className: classes.cellAlignCenter,
72
+ id: 'ui.editCourse.tab.lessons.table.header.calendar'
73
+ }
74
+ ]
75
+ : []),
76
+ {
77
+ className: classes.cellAlignRight,
78
+ id: 'ui.editCourse.tab.lessons.table.header.actions'
79
+ }
80
+ ], [course]);
81
+ // FUNCTIONS
82
+ const getSection = (0, react_1.useCallback)((id) => {
83
+ return {
84
+ id,
85
+ name: intl.formatMessage({ id: 'ui.editCourse.tab.lessons.table.newSection', defaultMessage: 'ui.editCourse.tab.lessons.table.newSection' }, { num: id })
86
+ };
87
+ }, []);
88
+ // HANDLERS
89
+ const handleDragEnd = (0, react_1.useCallback)((e) => {
90
+ if (!e.destination || e.destination.index === e.source.index) {
91
+ return;
92
+ }
93
+ const tempSections = Array.from(course.sections);
94
+ const [sourceData] = tempSections.splice(e.source.index, 1);
95
+ tempSections.splice(e.destination.index, 0, sourceData);
96
+ const data = {
97
+ sections_order: tempSections.map((tempSection) => tempSection.id)
98
+ };
99
+ api_services_1.CourseService.patchCourse(course.id, data)
100
+ .then(() => {
101
+ setCourse(Object.assign(Object.assign({}, course), { sections: tempSections }));
102
+ enqueueSnackbar((0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.editCourse.tab.lessons.table.snackbar.save", defaultMessage: "ui.editCourse.tab.lessons.table.snackbar.save" }), {
103
+ variant: 'success',
104
+ autoHideDuration: 3000
105
+ });
106
+ })
107
+ .catch((error) => {
108
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
109
+ enqueueSnackbar((0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.common.error.action", defaultMessage: "ui.common.error.action" }), {
110
+ variant: 'error',
111
+ autoHideDuration: 3000
112
+ });
113
+ });
114
+ }, [course]);
115
+ const handleAddTempSection = (0, react_1.useCallback)(() => {
116
+ setSections((prevSections) => (prevSections.length > 0 ? [...prevSections, getSection(prevSections.length + 1)] : [getSection(1)]));
117
+ }, [setSections]);
118
+ const handleManageSection = (0, react_1.useCallback)((section, type, newRow = false) => {
119
+ switch (type) {
120
+ case types_2.ActionLessonType.ADD: {
121
+ const newSection = Object.assign(Object.assign({}, section), { lessons: [] });
122
+ setCourse(Object.assign(Object.assign({}, course), { num_sections: course.num_sections + 1, sections: [...course.sections, newSection] }));
123
+ break;
124
+ }
125
+ case types_2.ActionLessonType.RENAME:
126
+ setCourse(Object.assign(Object.assign({}, course), { sections: course.sections.map((prevSection) => {
127
+ if (prevSection.id === section.id) {
128
+ return Object.assign(Object.assign({}, prevSection), { name: section.name });
129
+ }
130
+ return prevSection;
131
+ }) }));
132
+ break;
133
+ case types_2.ActionLessonType.DELETE: {
134
+ if (newRow) {
135
+ setCourse(Object.assign(Object.assign({}, course), { sections: course.sections.filter((prevSection) => prevSection.id !== section.id) }));
136
+ }
137
+ else {
138
+ setCourse(Object.assign(Object.assign({}, course), { num_sections: course.num_sections - 1, num_lessons: course.num_lessons - section.num_lessons, sections: course.sections.filter((prevSection) => prevSection.id !== section.id) }));
139
+ }
140
+ break;
141
+ }
142
+ case types_2.ActionLessonType.UPDATE:
143
+ setCourse(Object.assign(Object.assign({}, course), { sections: course.sections.map((prevSection) => {
144
+ if (prevSection.id === section.id) {
145
+ return Object.assign(Object.assign({}, prevSection), { lessons: section.lessons });
146
+ }
147
+ return prevSection;
148
+ }) }));
149
+ break;
150
+ case type.endsWith(types_2.ActionLessonType.UPDATE) && type: {
151
+ if (newRow) {
152
+ setCourse(Object.assign(Object.assign({}, course), { sections: course.sections.map((prevSection) => {
153
+ if (prevSection.id === section.id) {
154
+ return section;
155
+ }
156
+ return prevSection;
157
+ }) }));
158
+ }
159
+ else {
160
+ let numLessons = course.num_lessons;
161
+ if (type === types_2.ActionLessonType.ADD_UPDATE) {
162
+ numLessons = course.num_lessons + 1;
163
+ }
164
+ else if (type === types_2.ActionLessonType.DELETE_UPDATE) {
165
+ numLessons = course.num_lessons - 1;
166
+ }
167
+ setCourse(Object.assign(Object.assign({}, course), { num_lessons: numLessons, sections: course.sections.map((prevSection) => {
168
+ if (prevSection.id === section.id) {
169
+ return section;
170
+ }
171
+ return prevSection;
172
+ }) }));
173
+ }
174
+ }
175
+ }
176
+ }, [course]);
177
+ const handleOpenDialog = (0, react_1.useCallback)((row) => {
178
+ setDialog(row);
179
+ }, [setDialog]);
180
+ const handleDeleteRow = (0, react_1.useCallback)(() => {
181
+ switch (dialog.row) {
182
+ case types_2.RowType.SECTION:
183
+ ref.current.handleDeleteSection(dialog.section);
184
+ break;
185
+ case types_2.RowType.LESSON:
186
+ ref.current.handleDeleteLesson(dialog.section, dialog.lesson);
187
+ }
188
+ handleOpenDialog(null);
189
+ }, [dialog, handleOpenDialog]);
190
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, { children: [(0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ className: (0, classnames_1.default)(classes.lessonTitle, classes.contrastColor), variant: "h4" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.editCourse.tab.lessons", defaultMessage: "ui.editCourse.tab.lessons" }) })), (0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonInfoWrapper }, { children: [(0, jsx_runtime_1.jsx)(CourseTypePopover_1.default, { course: course }), (0, jsx_runtime_1.jsx)(Status_1.default, { course: course, handleTabChange: handleTabChange })] })), sections.length === 0 && ((0, jsx_runtime_1.jsx)(EmptyStatus_1.default, { icon: "courses", title: "ui.editCourse.tab.lessons.table.empty.title", description: "ui.editCourse.tab.lessons.table.empty.description", actions: (0, jsx_runtime_1.jsx)(AddButton_1.default, { className: classes.emptyStatusButton, label: "ui.editCourse.tab.lessons.table.section", handleAddRow: handleAddTempSection, color: "inherit", variant: "outlined" }), className: classes.lessonEmptyStatus })), sections.length > 0 && ((0, jsx_runtime_1.jsxs)(material_1.Box, Object.assign({ className: classes.lessonsInnerWrapper }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonsSectionsWrapper }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.lessonsSections }, { children: [(0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "h5" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.course.table.sections.title", defaultMessage: "ui.course.table.sections.title", values: {
191
+ sectionsNumber: course.num_sections
192
+ } }) })), (0, jsx_runtime_1.jsx)(material_1.Box, { className: classes.circle }), (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "h5" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.course.table.lessons.title", defaultMessage: "ui.course.table.lessons.title", values: {
193
+ lessonsNumber: course.num_lessons
194
+ } }) }))] })), (0, jsx_runtime_1.jsx)(AddButton_1.default, { label: "ui.editCourse.tab.lessons.table.section", handleAddRow: handleAddTempSection, color: "primary", variant: "contained", disabled: isDisabled })] })), (0, jsx_runtime_1.jsx)(dnd_1.DragDropContext, Object.assign({ onDragEnd: handleDragEnd }, { children: (0, jsx_runtime_1.jsx)(material_1.TableContainer, Object.assign({ className: classes.tableContainer }, { children: (0, jsx_runtime_1.jsxs)(material_1.Table, Object.assign({ className: classes.table }, { children: [(0, jsx_runtime_1.jsx)(material_1.TableHead, Object.assign({ className: classes.tableHeader }, { children: (0, jsx_runtime_1.jsxs)(material_1.TableRow, { children: [(0, jsx_runtime_1.jsx)(material_1.TableCell, { className: classes.cellWidth }), headerCells.map((cell, i) => ((0, jsx_runtime_1.jsx)(material_1.TableCell, Object.assign({ className: cell.className }, { children: (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ className: classes.tableHeaderTypography, variant: "overline" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: cell.id, defaultMessage: cell.id }) })) }), i)))] }) })), (0, jsx_runtime_1.jsx)(dnd_1.Droppable, Object.assign({ droppableId: "droppable-1" }, { children: (outerProvider) => ((0, jsx_runtime_1.jsxs)(material_1.TableBody, Object.assign({ ref: outerProvider.innerRef }, outerProvider.droppableProps, { className: classes.tableBody }, { children: [sections.map((section, i, array) => ((0, jsx_runtime_1.jsx)(dnd_1.Draggable, Object.assign({ draggableId: i.toString(), index: i, isDragDisabled: isDisabled }, { children: (innerProvider) => ((0, jsx_runtime_1.jsx)(SectionRow_1.default, { course: course, provider: innerProvider, section: section, isNewRow: isNewRow && i + 1 === array.length, handleManageSection: handleManageSection, handleOpenDialog: handleOpenDialog, ref: ref }, i)) }), i))), outerProvider.placeholder] }))) }))] })) })) })), dialog && (0, jsx_runtime_1.jsx)(ConfirmDialog_1.default, { open: true, onClose: () => handleOpenDialog(null), onConfirm: handleDeleteRow })] })))] }));
195
+ }
196
+ exports.default = (0, react_1.memo)(Lessons);
@@ -0,0 +1,9 @@
1
+ import { HTMLAttributes, PropsWithChildren, ReactNode } from 'react';
2
+ interface MenuRowProps extends PropsWithChildren {
3
+ icon?: ReactNode;
4
+ buttonClassName?: HTMLAttributes<HTMLButtonElement>['className'];
5
+ disabled?: boolean;
6
+ }
7
+ declare function MenuRow(props: MenuRowProps): JSX.Element;
8
+ declare const _default: import("react").MemoExoticComponent<typeof MenuRow>;
9
+ export default _default;
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const Menu_1 = tslib_1.__importDefault(require("@mui/material/Menu"));
6
+ const material_1 = require("@mui/material");
7
+ const react_1 = require("react");
8
+ function MenuRow(props) {
9
+ // PROPS
10
+ const { icon = (0, jsx_runtime_1.jsx)(material_1.Icon, { children: "more_vert" }), buttonClassName, disabled, children } = props;
11
+ // STATES
12
+ const [anchorEl, setAnchorEl] = (0, react_1.useState)(null);
13
+ // HOOKS
14
+ const theme = (0, material_1.useTheme)();
15
+ const isMobile = (0, material_1.useMediaQuery)(theme.breakpoints.down('md'));
16
+ // HANDLERS
17
+ const handleClick = (0, react_1.useCallback)((e) => {
18
+ setAnchorEl(e.currentTarget);
19
+ }, [anchorEl]);
20
+ const handleClose = (0, react_1.useCallback)(() => {
21
+ setAnchorEl(null);
22
+ }, [anchorEl]);
23
+ return ((0, jsx_runtime_1.jsxs)(react_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.IconButton, Object.assign({ className: buttonClassName, onClick: handleClick, disabled: disabled }, { children: icon })), isMobile ? ((0, jsx_runtime_1.jsx)(material_1.SwipeableDrawer, Object.assign({ open: Boolean(anchorEl), onClick: handleClose, onClose: handleClose, onOpen: () => null, anchor: "bottom", disableSwipeToOpen: true }, { children: children }))) : ((0, jsx_runtime_1.jsx)(Menu_1.default, Object.assign({ anchorEl: anchorEl, open: Boolean(anchorEl), onClick: handleClose }, { children: children })))] }));
24
+ }
25
+ exports.default = (0, react_1.memo)(MenuRow);
@@ -0,0 +1 @@
1
+ export default function OptionsSkeleton(): JSX.Element;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const material_1 = require("@mui/material");
5
+ const constants_1 = require("../constants");
6
+ const react_1 = require("react");
7
+ const classes = {
8
+ optionsWrapper: `${constants_1.PREFIX}-options-wrapper`,
9
+ optionsDivider: `${constants_1.PREFIX}-options-divider`,
10
+ optionsButtonWrapper: `${constants_1.PREFIX}-options-button-wrapper`
11
+ };
12
+ function OptionsSkeleton() {
13
+ return ((0, jsx_runtime_1.jsxs)(react_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.optionsWrapper }, { children: Array.from(Array(3)).map((_, i) => ((0, jsx_runtime_1.jsxs)(material_1.FormControl, Object.assign({ component: "fieldset", variant: "standard" }, { children: [(0, jsx_runtime_1.jsx)(material_1.FormLabel, Object.assign({ component: "legend" }, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "52px", height: "21px" }) })), (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Switch, {}), label: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "215px", height: "38px" }) })] }), i))) })), (0, jsx_runtime_1.jsx)(material_1.Divider, { className: classes.optionsDivider }), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.optionsButtonWrapper }, { children: (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rounded", width: "133px", height: "33px" }) }))] }));
14
+ }
15
+ exports.default = OptionsSkeleton;
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ interface SwitchFormProps {
3
+ name: string;
4
+ title: string;
5
+ description: string;
6
+ checked: boolean;
7
+ handleChangeOptions: (key: string, value: boolean) => void;
8
+ }
9
+ declare function SwitchForm(props: SwitchFormProps): JSX.Element;
10
+ declare const _default: import("react").MemoExoticComponent<typeof SwitchForm>;
11
+ export default _default;
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const jsx_runtime_1 = require("react/jsx-runtime");
4
+ const material_1 = require("@mui/material");
5
+ const react_1 = require("react");
6
+ const react_intl_1 = require("react-intl");
7
+ function SwitchForm(props) {
8
+ // PROPS
9
+ const { name, title, description, checked, handleChangeOptions } = props;
10
+ // STATES
11
+ const [value, setValue] = (0, react_1.useState)(checked);
12
+ // HANDLERS
13
+ const handleChange = (0, react_1.useCallback)((e) => {
14
+ const _checked = e.target.checked;
15
+ setValue(_checked);
16
+ handleChangeOptions(name, _checked);
17
+ }, [setValue]);
18
+ return ((0, jsx_runtime_1.jsxs)(material_1.FormControl, Object.assign({ component: "fieldset", variant: "standard" }, { children: [(0, jsx_runtime_1.jsx)(material_1.FormLabel, Object.assign({ component: "legend" }, { children: (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "h5" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: title, defaultMessage: title }) })) })), (0, jsx_runtime_1.jsx)(material_1.FormControlLabel, { control: (0, jsx_runtime_1.jsx)(material_1.Switch, { color: "primary", checked: value, name: name, onChange: handleChange }), label: (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "body1" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: description, defaultMessage: description }) })) })] })));
19
+ }
20
+ exports.default = (0, react_1.memo)(SwitchForm);
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { SCCourseType } from '@selfcommunity/types';
3
+ interface OptionsProps {
4
+ course: SCCourseType;
5
+ setCourse: (course: SCCourseType) => void;
6
+ }
7
+ declare function Options(props: OptionsProps): JSX.Element;
8
+ declare const _default: import("react").MemoExoticComponent<typeof Options>;
9
+ export default _default;
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const material_1 = require("@mui/material");
6
+ const react_intl_1 = require("react-intl");
7
+ const constants_1 = require("./constants");
8
+ const react_1 = require("react");
9
+ const utils_1 = require("@selfcommunity/utils");
10
+ const Errors_1 = require("../../constants/Errors");
11
+ const notistack_1 = require("notistack");
12
+ const SwitchForm_1 = tslib_1.__importDefault(require("./Options/SwitchForm"));
13
+ const use_deep_compare_effect_1 = tslib_1.__importDefault(require("use-deep-compare-effect"));
14
+ const lab_1 = require("@mui/lab");
15
+ const api_services_1 = require("@selfcommunity/api-services");
16
+ const classes = {
17
+ optionsContainer: `${constants_1.PREFIX}-options-container`,
18
+ optionsWrapper: `${constants_1.PREFIX}-options-wrapper`,
19
+ optionsDivider: `${constants_1.PREFIX}-options-divider`,
20
+ optionsButtonWrapper: `${constants_1.PREFIX}-options-button-wrapper`
21
+ };
22
+ const OPTIONS = {
23
+ enforce_lessons_order: {
24
+ title: 'ui.editCourse.tab.options',
25
+ description: 'ui.editCourse.tab.options.description'
26
+ },
27
+ new_comment_notification_enabled: {
28
+ title: 'ui.editCourse.tab.options.notifications',
29
+ description: 'ui.editCourse.tab.options.notifications.description'
30
+ },
31
+ hide_member_count: {
32
+ title: 'ui.editCourse.tab.options.permissions',
33
+ description: 'ui.editCourse.tab.options.permissions.description'
34
+ }
35
+ };
36
+ function Options(props) {
37
+ // PROPS
38
+ const { course, setCourse } = props;
39
+ // STATES
40
+ const [tempOptions, setTempOptions] = (0, react_1.useState)(null);
41
+ const [canSave, setCanSave] = (0, react_1.useState)(false);
42
+ const [loading, setLoading] = (0, react_1.useState)(false);
43
+ // HOOKS
44
+ const { enqueueSnackbar } = (0, notistack_1.useSnackbar)();
45
+ // EFFECTS
46
+ (0, use_deep_compare_effect_1.default)(() => {
47
+ if (!tempOptions) {
48
+ return;
49
+ }
50
+ if (course.enforce_lessons_order !== tempOptions.enforce_lessons_order ||
51
+ course.new_comment_notification_enabled !== tempOptions.new_comment_notification_enabled ||
52
+ course.hide_member_count !== tempOptions.hide_member_count) {
53
+ setCanSave(true);
54
+ }
55
+ else {
56
+ setCanSave(false);
57
+ }
58
+ }, [course, tempOptions, setCanSave]);
59
+ // HANDLERS
60
+ const handleChange = (0, react_1.useCallback)((key, value) => {
61
+ setTempOptions((prevOptions) => {
62
+ if (!prevOptions) {
63
+ return {
64
+ enforce_lessons_order: course.enforce_lessons_order,
65
+ new_comment_notification_enabled: course.new_comment_notification_enabled,
66
+ hide_member_count: course.hide_member_count,
67
+ [key]: value
68
+ };
69
+ }
70
+ return Object.assign(Object.assign({}, prevOptions), { [key]: value });
71
+ });
72
+ }, [setTempOptions, course]);
73
+ const handleSubmit = (0, react_1.useCallback)(() => {
74
+ setLoading(true);
75
+ api_services_1.CourseService.patchCourse(course.id, Object.assign({ id: course.id }, tempOptions))
76
+ .then((data) => {
77
+ setCourse(Object.assign(Object.assign({}, course), data));
78
+ setTempOptions(null);
79
+ setCanSave(false);
80
+ setLoading(false);
81
+ enqueueSnackbar((0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.contributionActionMenu.actionSuccess", defaultMessage: "ui.contributionActionMenu.actionSuccess" }), {
82
+ variant: 'success',
83
+ autoHideDuration: 3000
84
+ });
85
+ })
86
+ .catch((error) => {
87
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
88
+ enqueueSnackbar((0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.common.error.action", defaultMessage: "ui.common.error.action" }), {
89
+ variant: 'error',
90
+ autoHideDuration: 3000
91
+ });
92
+ });
93
+ }, [course, tempOptions, setCanSave, setLoading]);
94
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, Object.assign({ className: classes.optionsContainer }, { children: [(0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.optionsWrapper }, { children: Object.entries(OPTIONS).map(([key, value], i) => ((0, jsx_runtime_1.jsx)(SwitchForm_1.default, { name: key, title: value.title, description: value.description, checked: course[key], handleChangeOptions: handleChange }, i))) })), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.optionsButtonWrapper }, { children: (0, jsx_runtime_1.jsx)(lab_1.LoadingButton, Object.assign({ size: "small", variant: "contained", disabled: !canSave, onClick: handleSubmit, loading: loading }, { children: (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "body1" }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.editCourse.tab.options.button.save", defaultMessage: "ui.editCourse.tab.options.button.save" }) })) })) }))] })));
95
+ }
96
+ exports.default = (0, react_1.memo)(Options);
@@ -0,0 +1,12 @@
1
+ import { SyntheticEvent } from 'react';
2
+ import { SCCourseType } from '@selfcommunity/types';
3
+ import { BaseGetParams } from '@selfcommunity/api-services';
4
+ import { SCCourseEditTabType } from '../../types/course';
5
+ interface RequestsProps {
6
+ course: SCCourseType;
7
+ endpointQueryParams?: BaseGetParams;
8
+ handleTabChange: (_e: SyntheticEvent, newTabValue: SCCourseEditTabType) => void;
9
+ }
10
+ declare function Requests(props: RequestsProps): JSX.Element;
11
+ declare const _default: import("react").MemoExoticComponent<typeof Requests>;
12
+ export default _default;
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const material_1 = require("@mui/material");
6
+ const react_intl_1 = require("react-intl");
7
+ const react_1 = require("react");
8
+ const utils_1 = require("@selfcommunity/utils");
9
+ const Errors_1 = require("../../constants/Errors");
10
+ const Status_1 = tslib_1.__importDefault(require("./Status"));
11
+ const CourseUsersTable_1 = tslib_1.__importDefault(require("../../shared/CourseUsersTable"));
12
+ const Pagination_1 = require("../../constants/Pagination");
13
+ const react_core_1 = require("@selfcommunity/react-core");
14
+ const widget_1 = require("../../utils/widget");
15
+ const api_services_1 = require("@selfcommunity/api-services");
16
+ const constants_1 = require("./constants");
17
+ const pubsub_js_1 = tslib_1.__importDefault(require("pubsub-js"));
18
+ const PubSub_1 = require("../../constants/PubSub");
19
+ const course_1 = require("../../types/course");
20
+ const classes = {
21
+ usersStatusWrapper: `${constants_1.PREFIX}-users-status-wrapper`,
22
+ contrastColor: `${constants_1.PREFIX}-contrast-color`
23
+ };
24
+ const headerCells = [
25
+ {
26
+ id: 'ui.editCourse.tab.users.table.header.name'
27
+ },
28
+ {
29
+ id: 'ui.editCourse.tab.users.table.header.registration'
30
+ },
31
+ {
32
+ id: 'ui.editCourse.tab.users.table.header.latestActivity'
33
+ },
34
+ {}
35
+ ];
36
+ function Requests(props) {
37
+ // PROPS
38
+ const { course, endpointQueryParams = {
39
+ limit: 6,
40
+ offset: Pagination_1.DEFAULT_PAGINATION_OFFSET
41
+ }, handleTabChange } = props;
42
+ // STATES
43
+ const [state, dispatch] = (0, react_1.useReducer)(widget_1.dataWidgetReducer, {
44
+ isLoadingPrevious: false,
45
+ isLoadingNext: false,
46
+ next: null,
47
+ cacheKey: react_core_1.SCCache.getWidgetStateCacheKey(react_core_1.SCCache.USERS_REQUESTS_COURSES_STATE_CACHE_PREFIX_KEY, course.id),
48
+ cacheStrategy: utils_1.CacheStrategies.NETWORK_ONLY,
49
+ visibleItems: endpointQueryParams.limit
50
+ }, widget_1.stateWidgetInitializer);
51
+ // CONTEXTS
52
+ const scUserContext = (0, react_core_1.useSCUser)();
53
+ // REFS
54
+ const updatedUsers = (0, react_1.useRef)(null);
55
+ // CALLBACKS
56
+ const _init = (0, react_1.useCallback)(() => {
57
+ if (!state.initialized && !state.isLoadingNext) {
58
+ dispatch({ type: widget_1.actionWidgetTypes.LOADING_NEXT });
59
+ api_services_1.CourseService.getCourseWaitingApproval(course.id, Object.assign({}, endpointQueryParams))
60
+ .then((payload) => {
61
+ dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_SUCCESS, payload: Object.assign(Object.assign({}, payload), { initialized: true }) });
62
+ })
63
+ .catch((error) => {
64
+ dispatch({ type: widget_1.actionWidgetTypes.LOAD_NEXT_FAILURE, payload: { errorLoadNext: error } });
65
+ utils_1.Logger.error(Errors_1.SCOPE_SC_UI, error);
66
+ });
67
+ }
68
+ }, [state.isLoadingNext, state.initialized, course, dispatch, endpointQueryParams]);
69
+ // HANDLERS
70
+ const handleRejectUser = (0, react_1.useCallback)((_msg, user) => {
71
+ dispatch({
72
+ type: widget_1.actionWidgetTypes.SET_RESULTS,
73
+ payload: { count: state.results.length - 1, results: state.results.filter((result) => result.id !== user.id) }
74
+ });
75
+ }, [state.count, state.results, dispatch]);
76
+ // EFFECTS
77
+ (0, react_1.useEffect)(() => {
78
+ let _t;
79
+ if (scUserContext.user) {
80
+ _t = setTimeout(_init);
81
+ return () => {
82
+ clearTimeout(_t);
83
+ };
84
+ }
85
+ }, [scUserContext.user, _init]);
86
+ (0, react_1.useEffect)(() => {
87
+ updatedUsers.current = pubsub_js_1.default.subscribe(`${PubSub_1.SCTopicType.COURSE}.${PubSub_1.SCCourseEventType.REJECT_MEMBER}`, handleRejectUser);
88
+ return () => {
89
+ updatedUsers.current && pubsub_js_1.default.unsubscribe(updatedUsers.current);
90
+ };
91
+ }, [handleRejectUser]);
92
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, { children: [(0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "h6", className: classes.contrastColor }, { children: (0, jsx_runtime_1.jsx)(react_intl_1.FormattedMessage, { id: "ui.editCourse.tab.requests.title", defaultMessage: "ui.editCourse.tab.requests.title", values: { requestsNumber: state.results.length } }) })), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.usersStatusWrapper }, { children: (0, jsx_runtime_1.jsx)(Status_1.default, { course: course, handleTabChange: handleTabChange }) })), (0, jsx_runtime_1.jsx)(CourseUsersTable_1.default, { state: state, dispatch: dispatch, course: course, endpointSearch: {
93
+ url: () => api_services_1.Endpoints.GetCourseWaitingApproval.url({ id: course.id }),
94
+ method: api_services_1.Endpoints.GetCourseWaitingApproval.method
95
+ }, headerCells: headerCells, mode: course_1.SCCourseUsersTableModeType.REQUESTS, emptyStatusTitle: "ui.courseUsersTable.empty.requests.title" })] }));
96
+ }
97
+ exports.default = (0, react_1.memo)(Requests);
@@ -0,0 +1,8 @@
1
+ /// <reference types="react" />
2
+ import { SCCourseEditTabType } from '../../types';
3
+ interface EditCourseSkeletonProps {
4
+ tab?: SCCourseEditTabType;
5
+ }
6
+ declare function EditCourseSkeleton(props: EditCourseSkeletonProps): JSX.Element;
7
+ declare const _default: import("react").MemoExoticComponent<typeof EditCourseSkeleton>;
8
+ export default _default;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const constants_1 = require("./constants");
6
+ const material_1 = require("@mui/material");
7
+ const Skeleton_1 = tslib_1.__importDefault(require("./Lessons/Skeleton"));
8
+ const Skeleton_2 = tslib_1.__importDefault(require("./Users/Skeleton"));
9
+ const Skeleton_3 = tslib_1.__importDefault(require("../CourseForm/Skeleton"));
10
+ const Skeleton_4 = tslib_1.__importDefault(require("./Options/Skeleton"));
11
+ const types_1 = require("../../types");
12
+ const react_1 = require("react");
13
+ const classes = {
14
+ root: `${constants_1.PREFIX}-skeleton-root`,
15
+ header: `${constants_1.PREFIX}-header`,
16
+ tabList: `${constants_1.PREFIX}-tab-list`
17
+ };
18
+ const Root = (0, material_1.styled)(material_1.Box, {
19
+ name: constants_1.PREFIX,
20
+ slot: 'SkeletonRoot',
21
+ overridesResolver: (_props, styles) => styles.skeletonRoot
22
+ })(() => ({}));
23
+ function EditCourseSkeleton(props) {
24
+ // PROPS
25
+ const { tab } = props;
26
+ return ((0, jsx_runtime_1.jsxs)(Root, Object.assign({ className: classes.root }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Stack, Object.assign({ className: classes.header }, { children: [(0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "rectangular", width: "14px", height: "14px" }), (0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "125px", height: "21px" })] })), (0, jsx_runtime_1.jsx)(material_1.Stack, Object.assign({ className: classes.tabList }, { children: Array.from(new Array(5)).map((_, i) => ((0, jsx_runtime_1.jsx)(material_1.Skeleton, { animation: "wave", variant: "text", width: "80px", height: "21px" }, i))) })), tab === types_1.SCCourseEditTabType.LESSONS && (0, jsx_runtime_1.jsx)(Skeleton_1.default, {}), tab === types_1.SCCourseEditTabType.CUSTOMIZE && (0, jsx_runtime_1.jsx)(Skeleton_3.default, {}), tab === types_1.SCCourseEditTabType.USERS && (0, jsx_runtime_1.jsx)(Skeleton_2.default, {}), tab === types_1.SCCourseEditTabType.REQUESTS && (0, jsx_runtime_1.jsx)(Skeleton_2.default, {}), tab === types_1.SCCourseEditTabType.OPTIONS && (0, jsx_runtime_1.jsx)(Skeleton_4.default, {})] })));
27
+ }
28
+ exports.default = (0, react_1.memo)(EditCourseSkeleton);
@@ -0,0 +1,9 @@
1
+ import { SCCourseType } from '@selfcommunity/types';
2
+ import { SyntheticEvent } from 'react';
3
+ import { SCCourseEditTabType } from '../../types';
4
+ interface StatusProps {
5
+ course: SCCourseType;
6
+ handleTabChange: (_e: SyntheticEvent, newTabValue: SCCourseEditTabType) => void;
7
+ }
8
+ export default function Status(props: StatusProps): JSX.Element;
9
+ export {};
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const material_1 = require("@mui/material");
6
+ const react_intl_1 = require("react-intl");
7
+ const constants_1 = require("./constants");
8
+ const types_1 = require("@selfcommunity/types");
9
+ const classnames_1 = tslib_1.__importDefault(require("classnames"));
10
+ const react_1 = require("react");
11
+ const types_2 = require("../../types");
12
+ const classes = {
13
+ status: `${constants_1.PREFIX}-status`,
14
+ contrastColor: `${constants_1.PREFIX}-contrast-color`
15
+ };
16
+ function Status(props) {
17
+ // STATES
18
+ const { course, handleTabChange } = props;
19
+ // HOOKS
20
+ const intl = (0, react_intl_1.useIntl)();
21
+ // HANDLERS
22
+ const handleClick = (0, react_1.useCallback)(() => {
23
+ handleTabChange(null, types_2.SCCourseEditTabType.CUSTOMIZE);
24
+ }, [handleTabChange]);
25
+ return ((0, jsx_runtime_1.jsx)(material_1.Chip, { label: (0, jsx_runtime_1.jsx)(material_1.Button, Object.assign({ size: "small", variant: "text", color: "inherit", onClick: handleClick }, { children: (0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ variant: "body1" }, { children: intl.formatMessage({ id: 'ui.editCourse.tab.lessons.status', defaultMessage: 'ui.editCourse.tab.lessons.status' }, {
26
+ status: intl.formatMessage({
27
+ id: `ui.course.privacy.${course.privacy === types_1.SCCoursePrivacyType.DRAFT ? 'draft' : course.privacy}`,
28
+ defaultMessage: `ui.course.privacy.${course.privacy === types_1.SCCoursePrivacyType.DRAFT ? 'draft' : course.privacy}`
29
+ }),
30
+ b: (chunks) => ((0, jsx_runtime_1.jsx)(material_1.Typography, Object.assign({ component: "b", fontWeight: "bold" }, { children: chunks })))
31
+ }) })) })), className: (0, classnames_1.default)(classes.status, classes.contrastColor) }));
32
+ }
33
+ exports.default = Status;
@@ -0,0 +1 @@
1
+ export default function UsersSkeleton(): JSX.Element;