@openedx/frontend-app-learner-dashboard 1.0.0-alpha.6 → 1.0.0-alpha.7

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 (279) hide show
  1. package/dist/Main.js +2 -3
  2. package/dist/Main.js.map +1 -1
  3. package/dist/app.js +1 -0
  4. package/dist/app.js.map +1 -1
  5. package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js +14 -5
  6. package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js.map +1 -1
  7. package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js +14 -5
  8. package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js.map +1 -1
  9. package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js +3 -3
  10. package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js.map +1 -1
  11. package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js +5 -3
  12. package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js.map +1 -1
  13. package/dist/containers/CourseCard/components/CourseCardActions/index.js +5 -4
  14. package/dist/containers/CourseCard/components/CourseCardActions/index.js.map +1 -1
  15. package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js +26 -9
  16. package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js.map +1 -1
  17. package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js +12 -4
  18. package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js.map +1 -1
  19. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js +23 -4
  20. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js.map +1 -1
  21. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js +11 -5
  22. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js.map +1 -1
  23. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js +5 -3
  24. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js.map +1 -1
  25. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js +3 -3
  26. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js.map +1 -1
  27. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js +5 -5
  28. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js.map +1 -1
  29. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js +4 -3
  30. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js.map +1 -1
  31. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js +3 -2
  32. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js.map +1 -1
  33. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js +13 -5
  34. package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js.map +1 -1
  35. package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js +10 -6
  36. package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js.map +1 -1
  37. package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js +5 -4
  38. package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js.map +1 -1
  39. package/dist/containers/CourseCard/components/CourseCardBanners/index.d.ts +1 -1
  40. package/dist/containers/CourseCard/components/CourseCardBanners/index.js +6 -2
  41. package/dist/containers/CourseCard/components/CourseCardBanners/index.js.map +1 -1
  42. package/dist/containers/CourseCard/components/CourseCardDetails/hooks.d.ts +3 -3
  43. package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js +14 -12
  44. package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js.map +1 -1
  45. package/dist/containers/CourseCard/components/CourseCardImage.js +7 -6
  46. package/dist/containers/CourseCard/components/CourseCardImage.js.map +1 -1
  47. package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js +14 -11
  48. package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js.map +1 -1
  49. package/dist/containers/CourseCard/components/CourseCardMenu/hooks.d.ts +10 -0
  50. package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js +26 -6
  51. package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js.map +1 -1
  52. package/dist/containers/CourseCard/components/CourseCardMenu/index.js +5 -5
  53. package/dist/containers/CourseCard/components/CourseCardMenu/index.js.map +1 -1
  54. package/dist/containers/CourseCard/components/CourseCardTitle.js +6 -4
  55. package/dist/containers/CourseCard/components/CourseCardTitle.js.map +1 -1
  56. package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js +4 -2
  57. package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js.map +1 -1
  58. package/dist/containers/CourseCard/components/hooks.d.ts +1 -1
  59. package/dist/containers/CourseCard/components/hooks.js +9 -7
  60. package/dist/containers/CourseCard/components/hooks.js.map +1 -1
  61. package/dist/containers/CourseCard/hooks.d.ts +0 -12
  62. package/dist/containers/CourseCard/hooks.js +0 -14
  63. package/dist/containers/CourseCard/hooks.js.map +1 -1
  64. package/dist/containers/CourseFilterControls/ActiveCourseFilters.d.ts +1 -11
  65. package/dist/containers/CourseFilterControls/ActiveCourseFilters.js +4 -9
  66. package/dist/containers/CourseFilterControls/ActiveCourseFilters.js.map +1 -1
  67. package/dist/containers/CourseFilterControls/CourseFilterControls.d.ts +1 -13
  68. package/dist/containers/CourseFilterControls/CourseFilterControls.js +26 -16
  69. package/dist/containers/CourseFilterControls/CourseFilterControls.js.map +1 -1
  70. package/dist/containers/CoursesPanel/CourseList/index.d.ts +0 -1
  71. package/dist/containers/CoursesPanel/CourseList/index.js +2 -3
  72. package/dist/containers/CoursesPanel/CourseList/index.js.map +1 -1
  73. package/dist/containers/CoursesPanel/NoCoursesView/index.js +4 -2
  74. package/dist/containers/CoursesPanel/NoCoursesView/index.js.map +1 -1
  75. package/dist/containers/CoursesPanel/index.js +27 -6
  76. package/dist/containers/CoursesPanel/index.js.map +1 -1
  77. package/dist/containers/Dashboard/hooks.js.map +1 -1
  78. package/dist/containers/Dashboard/index.js +7 -4
  79. package/dist/containers/Dashboard/index.js.map +1 -1
  80. package/dist/containers/EmailSettingsModal/hooks.js +8 -5
  81. package/dist/containers/EmailSettingsModal/hooks.js.map +1 -1
  82. package/dist/containers/RelatedProgramsModal/index.js +5 -3
  83. package/dist/containers/RelatedProgramsModal/index.js.map +1 -1
  84. package/dist/containers/SelectSessionModal/hooks.d.ts +1 -1
  85. package/dist/containers/SelectSessionModal/hooks.js +25 -15
  86. package/dist/containers/SelectSessionModal/hooks.js.map +1 -1
  87. package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.d.ts +3 -1
  88. package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js +9 -3
  89. package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js.map +1 -1
  90. package/dist/containers/UnenrollConfirmModal/components/FinishedPane.d.ts +3 -3
  91. package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js +9 -4
  92. package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js.map +1 -1
  93. package/dist/containers/UnenrollConfirmModal/components/ReasonPane.d.ts +3 -2
  94. package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js +3 -3
  95. package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js.map +1 -1
  96. package/dist/containers/UnenrollConfirmModal/components/messages.d.ts +7 -7
  97. package/dist/containers/UnenrollConfirmModal/components/messages.js +12 -12
  98. package/dist/containers/UnenrollConfirmModal/components/messages.js.map +1 -1
  99. package/dist/containers/UnenrollConfirmModal/constants.d.ts +5 -0
  100. package/dist/containers/UnenrollConfirmModal/constants.js +7 -1
  101. package/dist/containers/UnenrollConfirmModal/constants.js.map +1 -1
  102. package/dist/containers/UnenrollConfirmModal/hooks/index.d.ts +1 -3
  103. package/dist/containers/UnenrollConfirmModal/hooks/index.js +18 -13
  104. package/dist/containers/UnenrollConfirmModal/hooks/index.js.map +1 -1
  105. package/dist/containers/UnenrollConfirmModal/hooks/reasons.d.ts +0 -2
  106. package/dist/containers/UnenrollConfirmModal/hooks/reasons.js +13 -15
  107. package/dist/containers/UnenrollConfirmModal/hooks/reasons.js.map +1 -1
  108. package/dist/containers/UnenrollConfirmModal/index.js +1 -1
  109. package/dist/containers/UnenrollConfirmModal/index.js.map +1 -1
  110. package/dist/data/constants/files.js +1 -1
  111. package/dist/data/constants/files.js.map +1 -1
  112. package/dist/data/constants/htmlKeys.js +1 -1
  113. package/dist/data/constants/htmlKeys.js.map +1 -1
  114. package/dist/data/context/FiltersProvider.d.ts +18 -0
  115. package/dist/data/context/FiltersProvider.js +37 -0
  116. package/dist/data/context/FiltersProvider.js.map +1 -0
  117. package/dist/data/context/MasqueradeProvider.d.ts +11 -0
  118. package/dist/data/context/MasqueradeProvider.js +19 -0
  119. package/dist/data/context/MasqueradeProvider.js.map +1 -0
  120. package/dist/data/context/SelectSessionProvider.d.ts +15 -0
  121. package/dist/data/context/SelectSessionProvider.js +40 -0
  122. package/dist/data/context/SelectSessionProvider.js.map +1 -0
  123. package/dist/data/context/index.d.ts +10 -0
  124. package/dist/data/context/index.js +8 -0
  125. package/dist/data/context/index.js.map +1 -0
  126. package/dist/data/contexts/GlobalDataContext.d.ts +15 -11
  127. package/dist/data/contexts/GlobalDataContext.js.map +1 -1
  128. package/dist/data/hooks/index.d.ts +3 -0
  129. package/dist/data/hooks/index.js +4 -0
  130. package/dist/data/hooks/index.js.map +1 -0
  131. package/dist/data/hooks/mutationHooks.d.ts +26 -0
  132. package/dist/data/hooks/mutationHooks.js +84 -0
  133. package/dist/data/hooks/mutationHooks.js.map +1 -0
  134. package/dist/data/hooks/queryHooks.d.ts +164 -0
  135. package/dist/data/hooks/queryHooks.js +57 -0
  136. package/dist/data/hooks/queryHooks.js.map +1 -0
  137. package/dist/data/hooks/queryKeys.d.ts +13 -0
  138. package/dist/data/hooks/queryKeys.js +15 -0
  139. package/dist/data/hooks/queryKeys.js.map +1 -0
  140. package/dist/data/services/lms/api.d.ts +18 -27
  141. package/dist/data/services/lms/api.js +77 -38
  142. package/dist/data/services/lms/api.js.map +1 -1
  143. package/dist/data/services/lms/index.js +1 -1
  144. package/dist/data/services/lms/index.js.map +1 -1
  145. package/dist/data/services/lms/urls.d.ts +0 -1
  146. package/dist/data/services/lms/urls.js +6 -2
  147. package/dist/data/services/lms/urls.js.map +1 -1
  148. package/dist/data/services/segment/utils.d.ts +1 -1
  149. package/dist/hooks/index.d.ts +5 -4
  150. package/dist/hooks/index.js +8 -4
  151. package/dist/hooks/index.js.map +1 -1
  152. package/dist/hooks/useCourseData.d.ts +2 -0
  153. package/dist/hooks/useCourseData.js +8 -0
  154. package/dist/hooks/useCourseData.js.map +1 -0
  155. package/dist/hooks/useCourseTrackingEvent.d.ts +2 -0
  156. package/dist/hooks/useCourseTrackingEvent.js +13 -0
  157. package/dist/hooks/useCourseTrackingEvent.js.map +1 -0
  158. package/dist/hooks/useEntitlementInfo.d.ts +22 -0
  159. package/dist/hooks/useEntitlementInfo.js +29 -0
  160. package/dist/hooks/useEntitlementInfo.js.map +1 -0
  161. package/dist/hooks/useIsMasquerading.d.ts +2 -0
  162. package/dist/hooks/useIsMasquerading.js +9 -0
  163. package/dist/hooks/useIsMasquerading.js.map +1 -0
  164. package/dist/providers.js +2 -2
  165. package/dist/providers.js.map +1 -1
  166. package/dist/routes.d.ts +2 -0
  167. package/dist/routes.js +3 -1
  168. package/dist/routes.js.map +1 -1
  169. package/dist/tracking/trackers/findCourses.d.ts +1 -1
  170. package/dist/tracking/trackers/socialShare.js +2 -2
  171. package/dist/tracking/trackers/socialShare.js.map +1 -1
  172. package/dist/utils/dataTransformers.d.ts +7 -0
  173. package/dist/utils/dataTransformers.js +58 -0
  174. package/dist/utils/dataTransformers.js.map +1 -0
  175. package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.d.ts +5 -6
  176. package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js +9 -14
  177. package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js.map +1 -1
  178. package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.d.ts +12 -14
  179. package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js +24 -34
  180. package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js.map +1 -1
  181. package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js +1 -1
  182. package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js.map +1 -1
  183. package/dist/widgets/LearnerDashboardHeader/hooks.js +1 -1
  184. package/dist/widgets/LearnerDashboardHeader/hooks.js.map +1 -1
  185. package/dist/widgets/LookingForChallengeWidget/index.js +4 -2
  186. package/dist/widgets/LookingForChallengeWidget/index.js.map +1 -1
  187. package/dist/widgets/LookingForChallengeWidget/track.d.ts +1 -1
  188. package/package.json +19 -18
  189. package/dist/containers/CourseFilterControls/hooks.d.ts +0 -3
  190. package/dist/containers/CourseFilterControls/hooks.js +0 -48
  191. package/dist/containers/CourseFilterControls/hooks.js.map +0 -1
  192. package/dist/containers/CoursesPanel/hooks.d.ts +0 -15
  193. package/dist/containers/CoursesPanel/hooks.js +0 -45
  194. package/dist/containers/CoursesPanel/hooks.js.map +0 -1
  195. package/dist/containers/RelatedProgramsModal/hooks.d.ts +0 -7
  196. package/dist/containers/RelatedProgramsModal/hooks.js +0 -7
  197. package/dist/containers/RelatedProgramsModal/hooks.js.map +0 -1
  198. package/dist/data/contexts/MasqueradeUserContext.d.ts +0 -13
  199. package/dist/data/contexts/MasqueradeUserContext.js +0 -15
  200. package/dist/data/contexts/MasqueradeUserContext.js.map +0 -1
  201. package/dist/data/contexts/MasqueradeUserProvider.d.ts +0 -3
  202. package/dist/data/contexts/MasqueradeUserProvider.js +0 -24
  203. package/dist/data/contexts/MasqueradeUserProvider.js.map +0 -1
  204. package/dist/data/redux/app/index.d.ts +0 -2
  205. package/dist/data/redux/app/index.js +0 -3
  206. package/dist/data/redux/app/index.js.map +0 -1
  207. package/dist/data/redux/app/reducer.d.ts +0 -25
  208. package/dist/data/redux/app/reducer.js +0 -42
  209. package/dist/data/redux/app/reducer.js.map +0 -1
  210. package/dist/data/redux/app/selectors/appSelectors.d.ts +0 -17
  211. package/dist/data/redux/app/selectors/appSelectors.js +0 -13
  212. package/dist/data/redux/app/selectors/appSelectors.js.map +0 -1
  213. package/dist/data/redux/app/selectors/courseCard.d.ts +0 -3
  214. package/dist/data/redux/app/selectors/courseCard.js +0 -114
  215. package/dist/data/redux/app/selectors/courseCard.js.map +0 -1
  216. package/dist/data/redux/app/selectors/currentList.d.ts +0 -24
  217. package/dist/data/redux/app/selectors/currentList.js +0 -45
  218. package/dist/data/redux/app/selectors/currentList.js.map +0 -1
  219. package/dist/data/redux/app/selectors/index.d.ts +0 -2
  220. package/dist/data/redux/app/selectors/index.js +0 -8
  221. package/dist/data/redux/app/selectors/index.js.map +0 -1
  222. package/dist/data/redux/app/selectors/simpleSelectors.d.ts +0 -5
  223. package/dist/data/redux/app/selectors/simpleSelectors.js +0 -31
  224. package/dist/data/redux/app/selectors/simpleSelectors.js.map +0 -1
  225. package/dist/data/redux/hooks/app.d.ts +0 -42
  226. package/dist/data/redux/hooks/app.js +0 -99
  227. package/dist/data/redux/hooks/app.js.map +0 -1
  228. package/dist/data/redux/hooks/index.d.ts +0 -2
  229. package/dist/data/redux/hooks/index.js +0 -3
  230. package/dist/data/redux/hooks/index.js.map +0 -1
  231. package/dist/data/redux/hooks/requests.d.ts +0 -16
  232. package/dist/data/redux/hooks/requests.js +0 -38
  233. package/dist/data/redux/hooks/requests.js.map +0 -1
  234. package/dist/data/redux/index.d.ts +0 -6
  235. package/dist/data/redux/index.js +0 -26
  236. package/dist/data/redux/index.js.map +0 -1
  237. package/dist/data/redux/requests/index.d.ts +0 -2
  238. package/dist/data/redux/requests/index.js +0 -3
  239. package/dist/data/redux/requests/index.js.map +0 -1
  240. package/dist/data/redux/requests/reducer.d.ts +0 -36
  241. package/dist/data/redux/requests/reducer.js +0 -32
  242. package/dist/data/redux/requests/reducer.js.map +0 -1
  243. package/dist/data/redux/requests/selectors.d.ts +0 -21
  244. package/dist/data/redux/requests/selectors.js +0 -24
  245. package/dist/data/redux/requests/selectors.js.map +0 -1
  246. package/dist/data/services/lms/fakeData/courses.d.ts +0 -788
  247. package/dist/data/services/lms/fakeData/courses.js +0 -744
  248. package/dist/data/services/lms/fakeData/courses.js.map +0 -1
  249. package/dist/data/services/lms/fakeData/testUtils.d.ts +0 -18
  250. package/dist/data/services/lms/fakeData/testUtils.js +0 -31
  251. package/dist/data/services/lms/fakeData/testUtils.js.map +0 -1
  252. package/dist/data/store.d.ts +0 -12
  253. package/dist/data/store.js +0 -14
  254. package/dist/data/store.js.map +0 -1
  255. package/dist/data/utils.d.ts +0 -10
  256. package/dist/data/utils.js +0 -14
  257. package/dist/data/utils.js.map +0 -1
  258. package/dist/hooks/api.d.ts +0 -9
  259. package/dist/hooks/api.js +0 -96
  260. package/dist/hooks/api.js.map +0 -1
  261. package/dist/slots/CourseBannerSlot/images/course_banner_slot_default.png +0 -0
  262. package/dist/slots/CourseBannerSlot/images/custom_course_banner.png +0 -0
  263. package/dist/slots/CourseCardActionSlot/images/post_course_card_action.png +0 -0
  264. package/dist/slots/CourseListSlot/images/course_list_slot.png +0 -0
  265. package/dist/slots/CourseListSlot/images/readme_custom_course_list.png +0 -0
  266. package/dist/slots/DashboardModalSlot/images/dashboard_modal_slot.png +0 -0
  267. package/dist/slots/NoCoursesViewSlot/images/no_course_view_slot.png +0 -0
  268. package/dist/slots/NoCoursesViewSlot/images/readme_custom_no_courses.png +0 -0
  269. package/dist/slots/WidgetSidebarSlot/images/readme_custom_sidebar.png +0 -0
  270. package/dist/slots/WidgetSidebarSlot/images/widget_sidebar_slot.png +0 -0
  271. package/dist/test/inspector.d.ts +0 -28
  272. package/dist/test/inspector.js +0 -38
  273. package/dist/test/inspector.js.map +0 -1
  274. package/dist/test/messages.d.ts +0 -8
  275. package/dist/test/messages.js +0 -18
  276. package/dist/test/messages.js.map +0 -1
  277. package/dist/test/utils.d.ts +0 -2
  278. package/dist/test/utils.js +0 -3
  279. package/dist/test/utils.js.map +0 -1
package/dist/Main.js CHANGED
@@ -1,10 +1,9 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import { Provider as ReduxProvider } from 'react-redux';
3
2
  import { CurrentAppProvider, PageWrap } from '@openedx/frontend-base';
4
3
  import { appId } from './constants';
5
- import store from './data/store';
4
+ import ContextProviders from './data/context';
6
5
  import Dashboard from './containers/Dashboard';
7
6
  import './app.scss';
8
- const Main = () => (_jsx(CurrentAppProvider, { appId: appId, children: _jsx(ReduxProvider, { store: store, children: _jsx(PageWrap, { children: _jsx(Dashboard, {}) }) }) }));
7
+ const Main = () => (_jsx(CurrentAppProvider, { appId: appId, children: _jsx(ContextProviders, { children: _jsx(PageWrap, { children: _jsx(Dashboard, {}) }) }) }));
9
8
  export default Main;
10
9
  //# sourceMappingURL=Main.js.map
package/dist/Main.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Main.js","sourceRoot":"","sources":["../src/Main.jsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,IAAI,aAAa,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEtE,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,KAAK,MAAM,cAAc,CAAC;AACjC,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAE/C,OAAO,YAAY,CAAC;AAEpB,MAAM,IAAI,GAAG,GAAG,EAAE,CAAC,CACjB,KAAC,kBAAkB,IAAC,KAAK,EAAE,KAAK,YAC9B,KAAC,aAAa,IAAC,KAAK,EAAE,KAAK,YACzB,KAAC,QAAQ,cACP,KAAC,SAAS,KAAG,GACJ,GACG,GACG,CACtB,CAAC;AAEF,eAAe,IAAI,CAAC","sourcesContent":["import { Provider as ReduxProvider } from 'react-redux';\nimport { CurrentAppProvider, PageWrap } from '@openedx/frontend-base';\n\nimport { appId } from './constants';\nimport store from './data/store';\nimport Dashboard from './containers/Dashboard';\n\nimport './app.scss';\n\nconst Main = () => (\n <CurrentAppProvider appId={appId}>\n <ReduxProvider store={store}>\n <PageWrap>\n <Dashboard />\n </PageWrap>\n </ReduxProvider>\n </CurrentAppProvider>\n);\n\nexport default Main;\n"]}
1
+ {"version":3,"file":"Main.js","sourceRoot":"","sources":["../src/Main.jsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,kBAAkB,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAEtE,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,gBAAgB,MAAM,gBAAgB,CAAC;AAC9C,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAE/C,OAAO,YAAY,CAAC;AAEpB,MAAM,IAAI,GAAG,GAAG,EAAE,CAAC,CACjB,KAAC,kBAAkB,IAAC,KAAK,EAAE,KAAK,YAC9B,KAAC,gBAAgB,cACf,KAAC,QAAQ,cACP,KAAC,SAAS,KAAG,GACJ,GACM,GACA,CACtB,CAAC;AAEF,eAAe,IAAI,CAAC","sourcesContent":["import { CurrentAppProvider, PageWrap } from '@openedx/frontend-base';\n\nimport { appId } from './constants';\nimport ContextProviders from './data/context';\nimport Dashboard from './containers/Dashboard';\n\nimport './app.scss';\n\nconst Main = () => (\n <CurrentAppProvider appId={appId}>\n <ContextProviders>\n <PageWrap>\n <Dashboard />\n </PageWrap>\n </ContextProviders>\n </CurrentAppProvider>\n);\n\nexport default Main;\n"]}
package/dist/app.js CHANGED
@@ -15,6 +15,7 @@ const app = {
15
15
  ECOMMERCE_BASE_URL: '',
16
16
  ORDER_HISTORY_URL: '',
17
17
  SUPPORT_URL: '',
18
+ SHOW_UNENROLL_SURVEY: false,
18
19
  }
19
20
  };
20
21
  export default app;
package/dist/app.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,QAAQ,MAAM,QAAQ,CAAC;AAC9B,OAAO,KAAK,MAAM,SAAS,CAAC;AAE5B,MAAM,GAAG,GAAQ;IACf,KAAK;IACL,MAAM;IACN,SAAS;IACT,QAAQ;IACR,KAAK;IACL,MAAM,EAAE;QACN,iBAAiB,EAAE,mCAAmC;QACtD,eAAe,EAAE,KAAK;QACtB,kBAAkB,EAAE,EAAE;QACtB,iBAAiB,EAAE,EAAE;QACrB,WAAW,EAAE,EAAE;KAChB;CACF,CAAC;AAEF,eAAe,GAAG,CAAC","sourcesContent":["import { App } from '@openedx/frontend-base';\nimport { appId } from './constants';\nimport routes from './routes';\nimport providers from './providers';\nimport messages from './i18n';\nimport slots from './slots';\n\nconst app: App = {\n appId,\n routes,\n providers,\n messages,\n slots,\n config: {\n LEARNING_BASE_URL: 'http://apps.local.openedx.io:2000',\n ENABLE_PROGRAMS: false,\n ECOMMERCE_BASE_URL: '',\n ORDER_HISTORY_URL: '',\n SUPPORT_URL: '',\n }\n};\n\nexport default app;\n"]}
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACpC,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,QAAQ,MAAM,QAAQ,CAAC;AAC9B,OAAO,KAAK,MAAM,SAAS,CAAC;AAE5B,MAAM,GAAG,GAAQ;IACf,KAAK;IACL,MAAM;IACN,SAAS;IACT,QAAQ;IACR,KAAK;IACL,MAAM,EAAE;QACN,iBAAiB,EAAE,mCAAmC;QACtD,eAAe,EAAE,KAAK;QACtB,kBAAkB,EAAE,EAAE;QACtB,iBAAiB,EAAE,EAAE;QACrB,WAAW,EAAE,EAAE;QACf,oBAAoB,EAAE,KAAK;KAC5B;CACF,CAAC;AAEF,eAAe,GAAG,CAAC","sourcesContent":["import { App } from '@openedx/frontend-base';\nimport { appId } from './constants';\nimport routes from './routes';\nimport providers from './providers';\nimport messages from './i18n';\nimport slots from './slots';\n\nconst app: App = {\n appId,\n routes,\n providers,\n messages,\n slots,\n config: {\n LEARNING_BASE_URL: 'http://apps.local.openedx.io:2000',\n ENABLE_PROGRAMS: false,\n ECOMMERCE_BASE_URL: '',\n ORDER_HISTORY_URL: '',\n SUPPORT_URL: '',\n SHOW_UNENROLL_SURVEY: false,\n }\n};\n\nexport default app;\n"]}
@@ -1,18 +1,27 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import React from 'react';
2
+ import React, { useMemo } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
+ import { EXECUTIVE_EDUCATION_COURSE_MODES } from '../../../../data/constants/course';
5
6
  import track from '../../../../tracking';
6
- import { reduxHooks } from '../../../../hooks';
7
+ import { useCourseData, useCourseTrackingEvent } from '../../../../hooks';
8
+ import { useInitializeLearnerHome } from '../../../../data/hooks';
7
9
  import useActionDisabledState from '../hooks';
8
10
  import ActionButton from './ActionButton';
9
11
  import messages from './messages';
10
12
  export const BeginCourseButton = ({ cardId }) => {
13
+ var _a;
11
14
  const { formatMessage } = useIntl();
12
- const { homeUrl } = reduxHooks.useCardCourseRunData(cardId);
13
- const execEdTrackingParam = reduxHooks.useCardExecEdTrackingParam(cardId);
15
+ const { data: learnerData } = useInitializeLearnerHome();
16
+ const courseData = useCourseData(cardId);
17
+ const homeUrl = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _a === void 0 ? void 0 : _a.homeUrl;
18
+ const execEdTrackingParam = useMemo(() => {
19
+ const isExecEd2UCourse = EXECUTIVE_EDUCATION_COURSE_MODES.includes(courseData.enrollment.mode);
20
+ const { authOrgId } = learnerData.enterpriseDashboard || {};
21
+ return isExecEd2UCourse ? `?org_id=${authOrgId}` : '';
22
+ }, [courseData.enrollment.mode, learnerData.enterpriseDashboard]);
14
23
  const { disableBeginCourse } = useActionDisabledState(cardId);
15
- const handleClick = reduxHooks.useTrackCourseEvent(track.course.enterCourseClicked, cardId, homeUrl + execEdTrackingParam);
24
+ const handleClick = useCourseTrackingEvent(track.course.enterCourseClicked, cardId, homeUrl + execEdTrackingParam);
16
25
  return (_jsx(ActionButton, { disabled: disableBeginCourse, as: "a", href: "#", onClick: handleClick, children: formatMessage(messages.beginCourse) }));
17
26
  };
18
27
  BeginCourseButton.propTypes = {
@@ -1 +1 @@
1
- {"version":3,"file":"BeginCourseButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/BeginCourseButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,KAAK,MAAM,sBAAsB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC9C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC5D,MAAM,mBAAmB,GAAG,UAAU,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC;IAC1E,MAAM,EAAE,kBAAkB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE9D,MAAM,WAAW,GAAG,UAAU,CAAC,mBAAmB,CAChD,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,OAAO,GAAG,mBAAmB,CAC9B,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,kBAAkB,EAC5B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,GACvB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,iBAAiB,CAAC,SAAS,GAAG;IAC5B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,iBAAiB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport track from '../../../../tracking';\nimport { reduxHooks } from '../../../../hooks';\n\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const BeginCourseButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { homeUrl } = reduxHooks.useCardCourseRunData(cardId);\n const execEdTrackingParam = reduxHooks.useCardExecEdTrackingParam(cardId);\n const { disableBeginCourse } = useActionDisabledState(cardId);\n\n const handleClick = reduxHooks.useTrackCourseEvent(\n track.course.enterCourseClicked,\n cardId,\n homeUrl + execEdTrackingParam,\n );\n return (\n <ActionButton\n disabled={disableBeginCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.beginCourse)}\n </ActionButton>\n );\n};\nBeginCourseButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default BeginCourseButton;\n"]}
1
+ {"version":3,"file":"BeginCourseButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/BeginCourseButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,4BAA4B,CAAC;AAE9E,OAAO,KAAK,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IAC9C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,wBAAwB,EAAE,CAAC;IACzD,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,OAAO,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,OAAO,CAAC;IAC/C,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,EAAE;QACvC,MAAM,gBAAgB,GAAG,gCAAgC,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC/F,MAAM,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC,mBAAmB,IAAI,EAAE,CAAC;QAC5D,OAAO,gBAAgB,CAAC,CAAC,CAAC,WAAW,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACxD,CAAC,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAAC;IAClE,MAAM,EAAE,kBAAkB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE9D,MAAM,WAAW,GAAG,sBAAsB,CACxC,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,OAAO,GAAG,mBAAmB,CAC9B,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,kBAAkB,EAC5B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,WAAW,CAAC,GACvB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,iBAAiB,CAAC,SAAS,GAAG;IAC5B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,iBAAiB,CAAC","sourcesContent":["import React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\nimport { EXECUTIVE_EDUCATION_COURSE_MODES } from '@src/data/constants/course';\n\nimport track from '@src/tracking';\nimport { useCourseData, useCourseTrackingEvent } from '@src/hooks';\nimport { useInitializeLearnerHome } from '@src/data/hooks';\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const BeginCourseButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { data: learnerData } = useInitializeLearnerHome();\n const courseData = useCourseData(cardId);\n const homeUrl = courseData?.courseRun?.homeUrl;\n const execEdTrackingParam = useMemo(() => {\n const isExecEd2UCourse = EXECUTIVE_EDUCATION_COURSE_MODES.includes(courseData.enrollment.mode);\n const { authOrgId } = learnerData.enterpriseDashboard || {};\n return isExecEd2UCourse ? `?org_id=${authOrgId}` : '';\n }, [courseData.enrollment.mode, learnerData.enterpriseDashboard]);\n const { disableBeginCourse } = useActionDisabledState(cardId);\n\n const handleClick = useCourseTrackingEvent(\n track.course.enterCourseClicked,\n cardId,\n homeUrl + execEdTrackingParam,\n );\n return (\n <ActionButton\n disabled={disableBeginCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.beginCourse)}\n </ActionButton>\n );\n};\nBeginCourseButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default BeginCourseButton;\n"]}
@@ -1,18 +1,27 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
- import React from 'react';
2
+ import React, { useMemo } from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
+ import { EXECUTIVE_EDUCATION_COURSE_MODES } from '../../../../data/constants/course';
5
6
  import track from '../../../../tracking';
6
- import { reduxHooks } from '../../../../hooks';
7
+ import { useCourseTrackingEvent, useCourseData } from '../../../../hooks';
8
+ import { useInitializeLearnerHome } from '../../../../data/hooks';
7
9
  import useActionDisabledState from '../hooks';
8
10
  import ActionButton from './ActionButton';
9
11
  import messages from './messages';
10
12
  export const ResumeButton = ({ cardId }) => {
13
+ var _a;
11
14
  const { formatMessage } = useIntl();
12
- const { resumeUrl } = reduxHooks.useCardCourseRunData(cardId);
13
- const execEdTrackingParam = reduxHooks.useCardExecEdTrackingParam(cardId);
15
+ const { data: learnerData } = useInitializeLearnerHome();
16
+ const courseData = useCourseData(cardId);
17
+ const resumeUrl = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _a === void 0 ? void 0 : _a.resumeUrl;
18
+ const execEdTrackingParam = useMemo(() => {
19
+ const isExecEd2UCourse = EXECUTIVE_EDUCATION_COURSE_MODES.includes(courseData.enrollment.mode);
20
+ const { authOrgId } = learnerData.enterpriseDashboard || {};
21
+ return isExecEd2UCourse ? `?org_id=${authOrgId}` : '';
22
+ }, [courseData.enrollment.mode, learnerData.enterpriseDashboard]);
14
23
  const { disableResumeCourse } = useActionDisabledState(cardId);
15
- const handleClick = reduxHooks.useTrackCourseEvent(track.course.enterCourseClicked, cardId, resumeUrl + execEdTrackingParam);
24
+ const handleClick = useCourseTrackingEvent(track.course.enterCourseClicked, cardId, resumeUrl + execEdTrackingParam);
16
25
  return (_jsx(ActionButton, { disabled: disableResumeCourse, as: "a", href: "#", onClick: handleClick, children: formatMessage(messages.resume) }));
17
26
  };
18
27
  ResumeButton.propTypes = {
@@ -1 +1 @@
1
- {"version":3,"file":"ResumeButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/ResumeButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,KAAK,MAAM,sBAAsB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACzC,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC9D,MAAM,mBAAmB,GAAG,UAAU,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC;IAC1E,MAAM,EAAE,mBAAmB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE/D,MAAM,WAAW,GAAG,UAAU,CAAC,mBAAmB,CAChD,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,SAAS,GAAG,mBAAmB,CAChC,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,mBAAmB,EAC7B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,GAClB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,YAAY,CAAC,SAAS,GAAG;IACvB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,YAAY,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport track from '../../../../tracking';\nimport { reduxHooks } from '../../../../hooks';\n\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const ResumeButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { resumeUrl } = reduxHooks.useCardCourseRunData(cardId);\n const execEdTrackingParam = reduxHooks.useCardExecEdTrackingParam(cardId);\n const { disableResumeCourse } = useActionDisabledState(cardId);\n\n const handleClick = reduxHooks.useTrackCourseEvent(\n track.course.enterCourseClicked,\n cardId,\n resumeUrl + execEdTrackingParam,\n );\n return (\n <ActionButton\n disabled={disableResumeCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.resume)}\n </ActionButton>\n );\n};\nResumeButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default ResumeButton;\n"]}
1
+ {"version":3,"file":"ResumeButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/ResumeButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,gCAAgC,EAAE,MAAM,4BAA4B,CAAC;AAC9E,OAAO,KAAK,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IACzC,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,GAAG,wBAAwB,EAAE,CAAC;IACzD,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,SAAS,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,SAAS,CAAC;IACnD,MAAM,mBAAmB,GAAG,OAAO,CAAC,GAAG,EAAE;QACvC,MAAM,gBAAgB,GAAG,gCAAgC,CAAC,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC/F,MAAM,EAAE,SAAS,EAAE,GAAG,WAAW,CAAC,mBAAmB,IAAI,EAAE,CAAC;QAC5D,OAAO,gBAAgB,CAAC,CAAC,CAAC,WAAW,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACxD,CAAC,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,EAAE,WAAW,CAAC,mBAAmB,CAAC,CAAC,CAAC;IAClE,MAAM,EAAE,mBAAmB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE/D,MAAM,WAAW,GAAG,sBAAsB,CACxC,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,SAAS,GAAG,mBAAmB,CAChC,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,mBAAmB,EAC7B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,GAClB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,YAAY,CAAC,SAAS,GAAG;IACvB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,YAAY,CAAC","sourcesContent":["import React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { EXECUTIVE_EDUCATION_COURSE_MODES } from '@src/data/constants/course';\nimport track from '@src/tracking';\nimport { useCourseTrackingEvent, useCourseData } from '@src/hooks';\nimport { useInitializeLearnerHome } from '@src/data/hooks';\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const ResumeButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { data: learnerData } = useInitializeLearnerHome();\n const courseData = useCourseData(cardId);\n const resumeUrl = courseData?.courseRun?.resumeUrl;\n const execEdTrackingParam = useMemo(() => {\n const isExecEd2UCourse = EXECUTIVE_EDUCATION_COURSE_MODES.includes(courseData.enrollment.mode);\n const { authOrgId } = learnerData.enterpriseDashboard || {};\n return isExecEd2UCourse ? `?org_id=${authOrgId}` : '';\n }, [courseData.enrollment.mode, learnerData.enterpriseDashboard]);\n const { disableResumeCourse } = useActionDisabledState(cardId);\n\n const handleClick = useCourseTrackingEvent(\n track.course.enterCourseClicked,\n cardId,\n resumeUrl + execEdTrackingParam,\n );\n return (\n <ActionButton\n disabled={disableResumeCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.resume)}\n </ActionButton>\n );\n};\nResumeButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default ResumeButton;\n"]}
@@ -2,15 +2,15 @@ import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
- import { reduxHooks } from '../../../../hooks';
5
+ import { useSelectSessionModal } from '../../../../data/context';
6
6
  import useActionDisabledState from '../hooks';
7
7
  import ActionButton from './ActionButton';
8
8
  import messages from './messages';
9
9
  export const SelectSessionButton = ({ cardId }) => {
10
10
  const { formatMessage } = useIntl();
11
11
  const { disableSelectSession } = useActionDisabledState(cardId);
12
- const openSessionModal = reduxHooks.useUpdateSelectSessionModalCallback(cardId);
13
- return (_jsx(ActionButton, { disabled: disableSelectSession, onClick: openSessionModal, children: formatMessage(messages.selectSession) }));
12
+ const { updateSelectSessionModal } = useSelectSessionModal();
13
+ return (_jsx(ActionButton, { disabled: disableSelectSession, onClick: () => updateSelectSessionModal(cardId), children: formatMessage(messages.selectSession) }));
14
14
  };
15
15
  SelectSessionButton.propTypes = {
16
16
  cardId: PropTypes.string.isRequired,
@@ -1 +1 @@
1
- {"version":3,"file":"SelectSessionButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/SelectSessionButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAChD,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,oBAAoB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAChE,MAAM,gBAAgB,GAAG,UAAU,CAAC,mCAAmC,CAAC,MAAM,CAAC,CAAC;IAChF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,oBAAoB,EAC9B,OAAO,EAAE,gBAAgB,YAExB,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,GACzB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,mBAAmB,CAAC,SAAS,GAAG;IAC9B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,mBAAmB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { reduxHooks } from '../../../../hooks';\n\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const SelectSessionButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { disableSelectSession } = useActionDisabledState(cardId);\n const openSessionModal = reduxHooks.useUpdateSelectSessionModalCallback(cardId);\n return (\n <ActionButton\n disabled={disableSelectSession}\n onClick={openSessionModal}\n >\n {formatMessage(messages.selectSession)}\n </ActionButton>\n );\n};\nSelectSessionButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default SelectSessionButton;\n"]}
1
+ {"version":3,"file":"SelectSessionButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/SelectSessionButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAChD,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,oBAAoB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAChE,MAAM,EAAE,wBAAwB,EAAE,GAAG,qBAAqB,EAAE,CAAC;IAC7D,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,oBAAoB,EAC9B,OAAO,EAAE,GAAG,EAAE,CAAC,wBAAwB,CAAC,MAAM,CAAC,YAE9C,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC,GACzB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,mBAAmB,CAAC,SAAS,GAAG;IAC9B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,mBAAmB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { useSelectSessionModal } from '@src/data/context';\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const SelectSessionButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { disableSelectSession } = useActionDisabledState(cardId);\n const { updateSelectSessionModal } = useSelectSessionModal();\n return (\n <ActionButton\n disabled={disableSelectSession}\n onClick={() => updateSelectSessionModal(cardId)}\n >\n {formatMessage(messages.selectSession)}\n </ActionButton>\n );\n};\nSelectSessionButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default SelectSessionButton;\n"]}
@@ -3,15 +3,17 @@ import React from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
5
  import track from '../../../../tracking';
6
- import { reduxHooks } from '../../../../hooks';
6
+ import { useCourseTrackingEvent, useCourseData } from '../../../../hooks';
7
7
  import useActionDisabledState from '../hooks';
8
8
  import ActionButton from './ActionButton';
9
9
  import messages from './messages';
10
10
  export const ViewCourseButton = ({ cardId }) => {
11
+ var _a;
11
12
  const { formatMessage } = useIntl();
12
- const { homeUrl } = reduxHooks.useCardCourseRunData(cardId);
13
+ const courseData = useCourseData(cardId);
14
+ const homeUrl = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _a === void 0 ? void 0 : _a.homeUrl;
13
15
  const { disableViewCourse } = useActionDisabledState(cardId);
14
- const handleClick = reduxHooks.useTrackCourseEvent(track.course.enterCourseClicked, cardId, homeUrl);
16
+ const handleClick = useCourseTrackingEvent(track.course.enterCourseClicked, cardId, homeUrl);
15
17
  return (_jsx(ActionButton, { disabled: disableViewCourse, as: "a", href: "#", onClick: handleClick, children: formatMessage(messages.viewCourse) }));
16
18
  };
17
19
  ViewCourseButton.propTypes = {
@@ -1 +1 @@
1
- {"version":3,"file":"ViewCourseButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/ViewCourseButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,KAAK,MAAM,sBAAsB,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC7C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC5D,MAAM,EAAE,iBAAiB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE7D,MAAM,WAAW,GAAG,UAAU,CAAC,mBAAmB,CAChD,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,OAAO,CACR,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,iBAAiB,EAC3B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,GACtB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,gBAAgB,CAAC,SAAS,GAAG;IAC3B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,gBAAgB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport track from '../../../../tracking';\nimport { reduxHooks } from '../../../../hooks';\n\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const ViewCourseButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { homeUrl } = reduxHooks.useCardCourseRunData(cardId);\n const { disableViewCourse } = useActionDisabledState(cardId);\n\n const handleClick = reduxHooks.useTrackCourseEvent(\n track.course.enterCourseClicked,\n cardId,\n homeUrl,\n );\n return (\n <ActionButton\n disabled={disableViewCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.viewCourse)}\n </ActionButton>\n );\n};\nViewCourseButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default ViewCourseButton;\n"]}
1
+ {"version":3,"file":"ViewCourseButton.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/ViewCourseButton.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,KAAK,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,sBAAsB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,sBAAsB,MAAM,UAAU,CAAC;AAC9C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IAC7C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,OAAO,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,OAAO,CAAC;IAC/C,MAAM,EAAE,iBAAiB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAE7D,MAAM,WAAW,GAAG,sBAAsB,CACxC,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAC/B,MAAM,EACN,OAAO,CACR,CAAC;IACF,OAAO,CACL,KAAC,YAAY,IACX,QAAQ,EAAE,iBAAiB,EAC3B,EAAE,EAAC,GAAG,EACN,IAAI,EAAC,GAAG,EACR,OAAO,EAAE,WAAW,YAEnB,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,GACtB,CAChB,CAAC;AACJ,CAAC,CAAC;AACF,gBAAgB,CAAC,SAAS,GAAG;IAC3B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AACF,eAAe,gBAAgB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport track from '@src/tracking';\nimport { useCourseTrackingEvent, useCourseData } from '@src/hooks';\nimport useActionDisabledState from '../hooks';\nimport ActionButton from './ActionButton';\nimport messages from './messages';\n\nexport const ViewCourseButton = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const courseData = useCourseData(cardId);\n const homeUrl = courseData?.courseRun?.homeUrl;\n const { disableViewCourse } = useActionDisabledState(cardId);\n\n const handleClick = useCourseTrackingEvent(\n track.course.enterCourseClicked,\n cardId,\n homeUrl,\n );\n return (\n <ActionButton\n disabled={disableViewCourse}\n as=\"a\"\n href=\"#\"\n onClick={handleClick}\n >\n {formatMessage(messages.viewCourse)}\n </ActionButton>\n );\n};\nViewCourseButton.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\nexport default ViewCourseButton;\n"]}
@@ -2,16 +2,17 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { ActionRow } from '@openedx/paragon';
5
- import { reduxHooks } from '../../../../hooks';
5
+ import { useCourseData, useEntitlementInfo } from '../../../../hooks';
6
6
  import CourseCardActionSlot from '../../../../slots/CourseCardActionSlot';
7
7
  import SelectSessionButton from './SelectSessionButton';
8
8
  import BeginCourseButton from './BeginCourseButton';
9
9
  import ResumeButton from './ResumeButton';
10
10
  import ViewCourseButton from './ViewCourseButton';
11
11
  export const CourseCardActions = ({ cardId }) => {
12
- const { isEntitlement, isFulfilled } = reduxHooks.useCardEntitlementData(cardId);
13
- const { hasStarted, } = reduxHooks.useCardEnrollmentData(cardId);
14
- const { isArchived } = reduxHooks.useCardCourseRunData(cardId);
12
+ const cardData = useCourseData(cardId);
13
+ const hasStarted = cardData.enrollment.hasStarted || false;
14
+ const { isEntitlement, isFulfilled } = useEntitlementInfo(cardData);
15
+ const isArchived = cardData.courseRun.isArchived || false;
15
16
  return (_jsxs(ActionRow, { "data-test-id": "CourseCardActions", children: [_jsx(CourseCardActionSlot, { cardId: cardId }), isEntitlement && (isFulfilled
16
17
  ? _jsx(ViewCourseButton, { cardId: cardId })
17
18
  : _jsx(SelectSessionButton, { cardId: cardId })), (isArchived && !isEntitlement) && (_jsx(ViewCourseButton, { cardId: cardId })), !(isArchived || isEntitlement) && (hasStarted
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/index.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,oBAAoB,MAAM,wCAAwC,CAAC;AAE1E,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAElD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC9C,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,GAAG,UAAU,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;IACjF,MAAM,EACJ,UAAU,GACX,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,EAAE,UAAU,EAAE,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAE/D,OAAO,CACL,MAAC,SAAS,oBAAc,mBAAmB,aACzC,KAAC,oBAAoB,IAAC,MAAM,EAAE,MAAM,GAAI,EACvC,aAAa,IAAI,CAAC,WAAW;gBAC5B,CAAC,CAAC,KAAC,gBAAgB,IAAC,MAAM,EAAE,MAAM,GAAI;gBACtC,CAAC,CAAC,KAAC,mBAAmB,IAAC,MAAM,EAAE,MAAM,GAAI,CAC1C,EACA,CAAC,UAAU,IAAI,CAAC,aAAa,CAAC,IAAI,CACjC,KAAC,gBAAgB,IAAC,MAAM,EAAE,MAAM,GAAI,CACrC,EACA,CAAC,CAAC,UAAU,IAAI,aAAa,CAAC,IAAI,CAAC,UAAU;gBAC5C,CAAC,CAAC,KAAC,YAAY,IAAC,MAAM,EAAE,MAAM,GAAI;gBAClC,CAAC,CAAC,KAAC,iBAAiB,IAAC,MAAM,EAAE,MAAM,GAAI,CACxC,IACS,CACb,CAAC;AACJ,CAAC,CAAC;AACF,iBAAiB,CAAC,SAAS,GAAG;IAC5B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,iBAAiB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { ActionRow } from '@openedx/paragon';\n\nimport { reduxHooks } from '../../../../hooks';\nimport CourseCardActionSlot from '../../../../slots/CourseCardActionSlot';\n\nimport SelectSessionButton from './SelectSessionButton';\nimport BeginCourseButton from './BeginCourseButton';\nimport ResumeButton from './ResumeButton';\nimport ViewCourseButton from './ViewCourseButton';\n\nexport const CourseCardActions = ({ cardId }) => {\n const { isEntitlement, isFulfilled } = reduxHooks.useCardEntitlementData(cardId);\n const {\n hasStarted,\n } = reduxHooks.useCardEnrollmentData(cardId);\n const { isArchived } = reduxHooks.useCardCourseRunData(cardId);\n\n return (\n <ActionRow data-test-id=\"CourseCardActions\">\n <CourseCardActionSlot cardId={cardId} />\n {isEntitlement && (isFulfilled\n ? <ViewCourseButton cardId={cardId} />\n : <SelectSessionButton cardId={cardId} />\n )}\n {(isArchived && !isEntitlement) && (\n <ViewCourseButton cardId={cardId} />\n )}\n {!(isArchived || isEntitlement) && (hasStarted\n ? <ResumeButton cardId={cardId} />\n : <BeginCourseButton cardId={cardId} />\n )}\n </ActionRow>\n );\n};\nCourseCardActions.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CourseCardActions;\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardActions/index.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAE/D,OAAO,oBAAoB,MAAM,iCAAiC,CAAC;AACnE,OAAO,mBAAmB,MAAM,uBAAuB,CAAC;AACxD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,gBAAgB,MAAM,oBAAoB,CAAC;AAElD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC9C,MAAM,QAAQ,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACvC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC,UAAU,IAAI,KAAK,CAAC;IAC3D,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACpE,MAAM,UAAU,GAAG,QAAQ,CAAC,SAAS,CAAC,UAAU,IAAI,KAAK,CAAC;IAE1D,OAAO,CACL,MAAC,SAAS,oBAAc,mBAAmB,aACzC,KAAC,oBAAoB,IAAC,MAAM,EAAE,MAAM,GAAI,EACvC,aAAa,IAAI,CAAC,WAAW;gBAC5B,CAAC,CAAC,KAAC,gBAAgB,IAAC,MAAM,EAAE,MAAM,GAAI;gBACtC,CAAC,CAAC,KAAC,mBAAmB,IAAC,MAAM,EAAE,MAAM,GAAI,CAC1C,EACA,CAAC,UAAU,IAAI,CAAC,aAAa,CAAC,IAAI,CACjC,KAAC,gBAAgB,IAAC,MAAM,EAAE,MAAM,GAAI,CACrC,EACA,CAAC,CAAC,UAAU,IAAI,aAAa,CAAC,IAAI,CAAC,UAAU;gBAC5C,CAAC,CAAC,KAAC,YAAY,IAAC,MAAM,EAAE,MAAM,GAAI;gBAClC,CAAC,CAAC,KAAC,iBAAiB,IAAC,MAAM,EAAE,MAAM,GAAI,CACxC,IACS,CACb,CAAC;AACJ,CAAC,CAAC;AACF,iBAAiB,CAAC,SAAS,GAAG;IAC5B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,iBAAiB,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { ActionRow } from '@openedx/paragon';\n\nimport { useCourseData, useEntitlementInfo } from '@src/hooks';\n\nimport CourseCardActionSlot from '@src/slots/CourseCardActionSlot';\nimport SelectSessionButton from './SelectSessionButton';\nimport BeginCourseButton from './BeginCourseButton';\nimport ResumeButton from './ResumeButton';\nimport ViewCourseButton from './ViewCourseButton';\n\nexport const CourseCardActions = ({ cardId }) => {\n const cardData = useCourseData(cardId);\n const hasStarted = cardData.enrollment.hasStarted || false;\n const { isEntitlement, isFulfilled } = useEntitlementInfo(cardData);\n const isArchived = cardData.courseRun.isArchived || false;\n\n return (\n <ActionRow data-test-id=\"CourseCardActions\">\n <CourseCardActionSlot cardId={cardId} />\n {isEntitlement && (isFulfilled\n ? <ViewCourseButton cardId={cardId} />\n : <SelectSessionButton cardId={cardId} />\n )}\n {(isArchived && !isEntitlement) && (\n <ViewCourseButton cardId={cardId} />\n )}\n {!(isArchived || isEntitlement) && (hasStarted\n ? <ResumeButton cardId={cardId} />\n : <BeginCourseButton cardId={cardId} />\n )}\n </ActionRow>\n );\n};\nCourseCardActions.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CourseCardActions;\n"]}
@@ -1,21 +1,38 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  /* eslint-disable max-len */
3
- import React from 'react';
3
+ import React, { useMemo } from 'react';
4
4
  import PropTypes from 'prop-types';
5
5
  import { MailtoLink, Hyperlink } from '@openedx/paragon';
6
6
  import { CheckCircle } from '@openedx/paragon/icons';
7
7
  import { useIntl } from '@openedx/frontend-base';
8
- import { utilHooks, reduxHooks } from '../../../../hooks';
8
+ import { baseAppUrl } from '../../../../data/services/lms/urls';
9
+ import { useInitializeLearnerHome } from '../../../../data/hooks';
10
+ import { utilHooks, useCourseData } from '../../../../hooks';
9
11
  import Banner from '../../../../components/Banner';
10
12
  import messages from './messages';
11
13
  const { useFormatDate } = utilHooks;
12
14
  export const CertificateBanner = ({ cardId }) => {
13
- const certificate = reduxHooks.useCardCertificateData(cardId);
14
- const { isAudit, isVerified, } = reduxHooks.useCardEnrollmentData(cardId);
15
- const { isPassing } = reduxHooks.useCardGradeData(cardId);
16
- const { isArchived } = reduxHooks.useCardCourseRunData(cardId);
17
- const { minPassingGrade, progressUrl } = reduxHooks.useCardCourseRunData(cardId);
18
- const { supportEmail, billingEmail } = reduxHooks.usePlatformSettingsData();
15
+ const { data: learnerHomeData } = useInitializeLearnerHome();
16
+ const courseData = useCourseData(cardId);
17
+ const { certificate = {}, isVerified = false, isAudit = false, isPassing = false, isArchived = false, minPassingGrade = 0, progressUrl = '', } = useMemo(() => {
18
+ var _a, _b, _c, _d, _e, _f, _g;
19
+ return ({
20
+ isVerified: (_a = courseData === null || courseData === void 0 ? void 0 : courseData.enrollment) === null || _a === void 0 ? void 0 : _a.isVerified,
21
+ isAudit: (_b = courseData === null || courseData === void 0 ? void 0 : courseData.enrollment) === null || _b === void 0 ? void 0 : _b.isAudit,
22
+ certificate: (courseData === null || courseData === void 0 ? void 0 : courseData.certificate) || {},
23
+ isPassing: (_c = courseData === null || courseData === void 0 ? void 0 : courseData.gradeData) === null || _c === void 0 ? void 0 : _c.isPassing,
24
+ isArchived: (_d = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _d === void 0 ? void 0 : _d.isArchived,
25
+ minPassingGrade: Math.floor(((_f = (_e = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _e === void 0 ? void 0 : _e.minPassingGrade) !== null && _f !== void 0 ? _f : 0) * 100),
26
+ progressUrl: baseAppUrl(((_g = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _g === void 0 ? void 0 : _g.progressUrl) || ''),
27
+ });
28
+ }, [courseData]);
29
+ const { supportEmail, billingEmail } = useMemo(() => {
30
+ var _a, _b;
31
+ return ({
32
+ supportEmail: (_a = learnerHomeData === null || learnerHomeData === void 0 ? void 0 : learnerHomeData.platformSettings) === null || _a === void 0 ? void 0 : _a.supportEmail,
33
+ billingEmail: (_b = learnerHomeData === null || learnerHomeData === void 0 ? void 0 : learnerHomeData.platformSettings) === null || _b === void 0 ? void 0 : _b.billingEmail,
34
+ });
35
+ }, [learnerHomeData]);
19
36
  const { formatMessage } = useIntl();
20
37
  const formatDate = useFormatDate();
21
38
  const emailLink = address => _jsx(MailtoLink, { to: address, children: address });
@@ -34,7 +51,7 @@ export const CertificateBanner = ({ cardId }) => {
34
51
  }
35
52
  return (_jsx(Banner, { variant: "warning", children: formatMessage(messages.certMinGrade, { minPassingGrade }) }));
36
53
  }
37
- if (certificate.isEarnedButUnavailable) {
54
+ if (certificate.isEarned && new Date(certificate.availableDate) > new Date()) {
38
55
  return (_jsx(Banner, { children: formatMessage(messages.gradeAndCertReadyAfter, { availableDate: formatDate(certificate.availableDate) }) }));
39
56
  }
40
57
  return null;
@@ -1 +1 @@
1
- {"version":3,"file":"CertificateBanner.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardBanners/CertificateBanner.jsx"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable max-len */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { MailtoLink, Hyperlink } from '@openedx/paragon';\nimport { CheckCircle } from '@openedx/paragon/icons';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { utilHooks, reduxHooks } from '../../../../hooks';\nimport Banner from '../../../../components/Banner';\n\nimport messages from './messages';\n\nconst { useFormatDate } = utilHooks;\n\nexport const CertificateBanner = ({ cardId }) => {\n const certificate = reduxHooks.useCardCertificateData(cardId);\n const {\n isAudit,\n isVerified,\n } = reduxHooks.useCardEnrollmentData(cardId);\n const { isPassing } = reduxHooks.useCardGradeData(cardId);\n const { isArchived } = reduxHooks.useCardCourseRunData(cardId);\n const { minPassingGrade, progressUrl } = reduxHooks.useCardCourseRunData(cardId);\n const { supportEmail, billingEmail } = reduxHooks.usePlatformSettingsData();\n const { formatMessage } = useIntl();\n const formatDate = useFormatDate();\n\n const emailLink = address => <MailtoLink to={address}>{address}</MailtoLink>;\n\n if (certificate.isRestricted) {\n return (\n <Banner variant=\"danger\">\n {supportEmail ? formatMessage(messages.certRestricted, { supportEmail: emailLink(supportEmail) }) : formatMessage(messages.certRestrictedNoEmail)}\n {isVerified && ' '}\n {isVerified && (billingEmail ? formatMessage(messages.certRefundContactBilling, { billingEmail: emailLink(billingEmail) }) : formatMessage(messages.certRefundContactBillingNoEmail))}\n </Banner>\n );\n }\n if (certificate.isDownloadable) {\n return (\n <Banner variant=\"success\" icon={CheckCircle}>\n {formatMessage(messages.certReady)}\n {certificate.certPreviewUrl && (\n <>\n {' '}\n <Hyperlink isInline destination={certificate.certPreviewUrl}>\n {formatMessage(messages.viewCertificate)}\n </Hyperlink>\n </>\n )}\n </Banner>\n );\n }\n if (!isPassing) {\n if (isAudit) {\n return (\n <Banner>\n {formatMessage(messages.passingGrade, { minPassingGrade })}\n </Banner>\n );\n }\n if (isArchived) {\n return (\n <Banner variant=\"warning\">\n {formatMessage(messages.notEligibleForCert)}\n {' '}\n <Hyperlink isInline destination={progressUrl}>{formatMessage(messages.viewGrades)}</Hyperlink>\n </Banner>\n );\n }\n return (\n <Banner variant=\"warning\">\n {formatMessage(messages.certMinGrade, { minPassingGrade })}\n </Banner>\n );\n }\n if (certificate.isEarnedButUnavailable) {\n return (\n <Banner>\n {formatMessage(\n messages.gradeAndCertReadyAfter,\n { availableDate: formatDate(certificate.availableDate) },\n )}\n </Banner>\n );\n }\n\n return null;\n};\nCertificateBanner.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CertificateBanner;\n"]}
1
+ {"version":3,"file":"CertificateBanner.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardBanners/CertificateBanner.jsx"],"names":[],"mappings":";AAAA,4BAA4B;AAC5B,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAEzD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,MAAM,MAAM,wBAAwB,CAAC;AAE5C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,EAAE,aAAa,EAAE,GAAG,SAAS,CAAC;AAEpC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC9C,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,GAAG,wBAAwB,EAAE,CAAC;IAC7D,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,EACJ,WAAW,GAAG,EAAE,EAChB,UAAU,GAAG,KAAK,EAClB,OAAO,GAAG,KAAK,EACf,SAAS,GAAG,KAAK,EACjB,UAAU,GAAG,KAAK,EAClB,eAAe,GAAG,CAAC,EACnB,WAAW,GAAG,EAAE,GACjB,GAAG,OAAO,CAAC,GAAG,EAAE;;QAAC,OAAA,CAAC;YACjB,UAAU,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,UAAU,0CAAE,UAAU;YAC9C,OAAO,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,UAAU,0CAAE,OAAO;YACxC,WAAW,EAAE,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,WAAW,KAAI,EAAE;YAC1C,SAAS,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,SAAS;YAC3C,UAAU,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,UAAU;YAC7C,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,MAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,eAAe,mCAAI,CAAC,CAAC,GAAG,GAAG,CAAC;YAChF,WAAW,EAAE,UAAU,CAAC,CAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,WAAW,KAAI,EAAE,CAAC;SAClE,CAAC,CAAA;KAAA,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAClB,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,OAAO,CAC5C,GAAG,EAAE;;QAAC,OAAA,CAAC;YACL,YAAY,EAAE,MAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,gBAAgB,0CAAE,YAAY;YAC7D,YAAY,EAAE,MAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,gBAAgB,0CAAE,YAAY;SAC9D,CAAC,CAAA;KAAA,EACF,CAAC,eAAe,CAAC,CAClB,CAAC;IACF,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IAEnC,MAAM,SAAS,GAAG,OAAO,CAAC,EAAE,CAAC,KAAC,UAAU,IAAC,EAAE,EAAE,OAAO,YAAG,OAAO,GAAc,CAAC;IAE7E,IAAI,WAAW,CAAC,YAAY,EAAE,CAAC;QAC7B,OAAO,CACL,MAAC,MAAM,IAAC,OAAO,EAAC,QAAQ,aACpB,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,cAAc,EAAE,EAAE,YAAY,EAAE,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,qBAAqB,CAAC,EACjJ,UAAU,IAAI,IAAI,EAClB,UAAU,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,wBAAwB,EAAE,EAAE,YAAY,EAAE,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,+BAA+B,CAAC,CAAC,IAC9K,CACV,CAAC;IACJ,CAAC;IACD,IAAI,WAAW,CAAC,cAAc,EAAE,CAAC;QAC/B,OAAO,CACL,MAAC,MAAM,IAAC,OAAO,EAAC,SAAS,EAAC,IAAI,EAAE,WAAW,aACxC,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,EACjC,WAAW,CAAC,cAAc,IAAI,CAC7B,8BACG,IAAI,EACL,KAAC,SAAS,IAAC,QAAQ,QAAC,WAAW,EAAE,WAAW,CAAC,cAAc,YACxD,aAAa,CAAC,QAAQ,CAAC,eAAe,CAAC,GAC9B,IACX,CACJ,IACM,CACV,CAAC;IACJ,CAAC;IACD,IAAI,CAAC,SAAS,EAAE,CAAC;QACf,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CACL,KAAC,MAAM,cACJ,aAAa,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,eAAe,EAAE,CAAC,GACnD,CACV,CAAC;QACJ,CAAC;QACD,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,CACL,MAAC,MAAM,IAAC,OAAO,EAAC,SAAS,aACtB,aAAa,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAC1C,IAAI,EACL,KAAC,SAAS,IAAC,QAAQ,QAAC,WAAW,EAAE,WAAW,YAAG,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAa,IACvF,CACV,CAAC;QACJ,CAAC;QACD,OAAO,CACL,KAAC,MAAM,IAAC,OAAO,EAAC,SAAS,YACtB,aAAa,CAAC,QAAQ,CAAC,YAAY,EAAE,EAAE,eAAe,EAAE,CAAC,GACnD,CACV,CAAC;IACJ,CAAC;IACD,IAAI,WAAW,CAAC,QAAQ,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,GAAG,IAAI,IAAI,EAAE,EAAE,CAAC;QAC7E,OAAO,CACL,KAAC,MAAM,cACJ,aAAa,CACZ,QAAQ,CAAC,sBAAsB,EAC/B,EAAE,aAAa,EAAE,UAAU,CAAC,WAAW,CAAC,aAAa,CAAC,EAAE,CACzD,GACM,CACV,CAAC;IACJ,CAAC;IAED,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AACF,iBAAiB,CAAC,SAAS,GAAG;IAC5B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,iBAAiB,CAAC","sourcesContent":["/* eslint-disable max-len */\nimport React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { MailtoLink, Hyperlink } from '@openedx/paragon';\nimport { CheckCircle } from '@openedx/paragon/icons';\nimport { useIntl } from '@openedx/frontend-base';\nimport { baseAppUrl } from '@src/data/services/lms/urls';\n\nimport { useInitializeLearnerHome } from '@src/data/hooks';\nimport { utilHooks, useCourseData } from '@src/hooks';\nimport Banner from '@src/components/Banner';\n\nimport messages from './messages';\n\nconst { useFormatDate } = utilHooks;\n\nexport const CertificateBanner = ({ cardId }) => {\n const { data: learnerHomeData } = useInitializeLearnerHome();\n const courseData = useCourseData(cardId);\n const {\n certificate = {},\n isVerified = false,\n isAudit = false,\n isPassing = false,\n isArchived = false,\n minPassingGrade = 0,\n progressUrl = '',\n } = useMemo(() => ({\n isVerified: courseData?.enrollment?.isVerified,\n isAudit: courseData?.enrollment?.isAudit,\n certificate: courseData?.certificate || {},\n isPassing: courseData?.gradeData?.isPassing,\n isArchived: courseData?.courseRun?.isArchived,\n minPassingGrade: Math.floor((courseData?.courseRun?.minPassingGrade ?? 0) * 100),\n progressUrl: baseAppUrl(courseData?.courseRun?.progressUrl || ''),\n }), [courseData]);\n const { supportEmail, billingEmail } = useMemo(\n () => ({\n supportEmail: learnerHomeData?.platformSettings?.supportEmail,\n billingEmail: learnerHomeData?.platformSettings?.billingEmail,\n }),\n [learnerHomeData],\n );\n const { formatMessage } = useIntl();\n const formatDate = useFormatDate();\n\n const emailLink = address => <MailtoLink to={address}>{address}</MailtoLink>;\n\n if (certificate.isRestricted) {\n return (\n <Banner variant=\"danger\">\n { supportEmail ? formatMessage(messages.certRestricted, { supportEmail: emailLink(supportEmail) }) : formatMessage(messages.certRestrictedNoEmail)}\n {isVerified && ' '}\n {isVerified && (billingEmail ? formatMessage(messages.certRefundContactBilling, { billingEmail: emailLink(billingEmail) }) : formatMessage(messages.certRefundContactBillingNoEmail))}\n </Banner>\n );\n }\n if (certificate.isDownloadable) {\n return (\n <Banner variant=\"success\" icon={CheckCircle}>\n {formatMessage(messages.certReady)}\n {certificate.certPreviewUrl && (\n <>\n {' '}\n <Hyperlink isInline destination={certificate.certPreviewUrl}>\n {formatMessage(messages.viewCertificate)}\n </Hyperlink>\n </>\n )}\n </Banner>\n );\n }\n if (!isPassing) {\n if (isAudit) {\n return (\n <Banner>\n {formatMessage(messages.passingGrade, { minPassingGrade })}\n </Banner>\n );\n }\n if (isArchived) {\n return (\n <Banner variant=\"warning\">\n {formatMessage(messages.notEligibleForCert)}\n {' '}\n <Hyperlink isInline destination={progressUrl}>{formatMessage(messages.viewGrades)}</Hyperlink>\n </Banner>\n );\n }\n return (\n <Banner variant=\"warning\">\n {formatMessage(messages.certMinGrade, { minPassingGrade })}\n </Banner>\n );\n }\n if (certificate.isEarned && new Date(certificate.availableDate) > new Date()) {\n return (\n <Banner>\n {formatMessage(\n messages.gradeAndCertReadyAfter,\n { availableDate: formatDate(certificate.availableDate) },\n )}\n </Banner>\n );\n }\n\n return null;\n};\nCertificateBanner.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CertificateBanner;\n"]}
@@ -1,16 +1,24 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
2
  /* eslint-disable max-len */
3
- import React from 'react';
3
+ import React, { useMemo } from 'react';
4
4
  import PropTypes from 'prop-types';
5
5
  import { Hyperlink } from '@openedx/paragon';
6
6
  import { useIntl } from '@openedx/frontend-base';
7
- import { utilHooks, reduxHooks } from '../../../../hooks';
7
+ import { utilHooks, useCourseData } from '../../../../hooks';
8
8
  import Banner from '../../../../components/Banner';
9
9
  import messages from './messages';
10
10
  export const CourseBanner = ({ cardId }) => {
11
- const { isVerified, isAuditAccessExpired, coursewareAccess = {}, } = reduxHooks.useCardEnrollmentData(cardId);
12
- const courseRun = reduxHooks.useCardCourseRunData(cardId);
13
11
  const { formatMessage } = useIntl();
12
+ const courseData = useCourseData(cardId);
13
+ const { isVerified = false, isAuditAccessExpired = false, coursewareAccess = {}, } = useMemo(() => {
14
+ var _a, _b, _c;
15
+ return ({
16
+ isVerified: (_a = courseData.enrollment) === null || _a === void 0 ? void 0 : _a.isVerified,
17
+ isAuditAccessExpired: (_b = courseData.enrollment) === null || _b === void 0 ? void 0 : _b.isAuditAccessExpired,
18
+ coursewareAccess: ((_c = courseData.enrollment) === null || _c === void 0 ? void 0 : _c.coursewareAccess) || {},
19
+ });
20
+ }, [courseData]);
21
+ const courseRun = (courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) || {};
14
22
  const formatDate = utilHooks.useFormatDate();
15
23
  const { hasUnmetPrerequisites, isStaff, isTooEarly } = coursewareAccess;
16
24
  if (isVerified) {
@@ -1 +1 @@
1
- {"version":3,"file":"CourseBanner.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardBanners/CourseBanner.jsx"],"names":[],"mappings":";AAAA,4BAA4B;AAC5B,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,MAAM,MAAM,+BAA+B,CAAC;AAEnD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACzC,MAAM,EACJ,UAAU,EACV,oBAAoB,EACpB,gBAAgB,GAAG,EAAE,GACtB,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,SAAS,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAC1D,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,SAAS,CAAC,aAAa,EAAE,CAAC;IAE7C,MAAM,EAAE,qBAAqB,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;IAExE,IAAI,UAAU,EAAE,CAAC;QAAC,OAAO,IAAI,CAAC;IAAC,CAAC;IAEhC,OAAO,CACL,8BACG,oBAAoB;mBAChB,CACD,MAAC,MAAM,eACJ,aAAa,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAC1C,IAAI,EACL,KAAC,SAAS,IAAC,QAAQ,QAAC,WAAW,EAAC,EAAE,YAC/B,aAAa,CAAC,QAAQ,CAAC,iBAAiB,CAAC,GAChC,IACL,CACV,EAEF,CAAC,CAAC,OAAO,IAAI,UAAU,IAAI,SAAS,CAAC,SAAS,CAAC,IAAI,CAClD,KAAC,MAAM,cACJ,aAAa,CAAC,QAAQ,CAAC,mBAAmB,EAAE;oBAC3C,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC;iBAC3C,CAAC,GACK,CACV,EAEA,CAAC,CAAC,OAAO,IAAI,qBAAqB,CAAC,IAAI,CACtC,KAAC,MAAM,cAAE,aAAa,CAAC,QAAQ,CAAC,mBAAmB,CAAC,GAAU,CAC/D,IACA,CACJ,CAAC;AACJ,CAAC,CAAC;AACF,YAAY,CAAC,SAAS,GAAG;IACvB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,YAAY,CAAC","sourcesContent":["/* eslint-disable max-len */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { Hyperlink } from '@openedx/paragon';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { utilHooks, reduxHooks } from '../../../../hooks';\nimport Banner from '../../../../components/Banner';\n\nimport messages from './messages';\n\nexport const CourseBanner = ({ cardId }) => {\n const {\n isVerified,\n isAuditAccessExpired,\n coursewareAccess = {},\n } = reduxHooks.useCardEnrollmentData(cardId);\n const courseRun = reduxHooks.useCardCourseRunData(cardId);\n const { formatMessage } = useIntl();\n const formatDate = utilHooks.useFormatDate();\n\n const { hasUnmetPrerequisites, isStaff, isTooEarly } = coursewareAccess;\n\n if (isVerified) { return null; }\n\n return (\n <>\n {isAuditAccessExpired\n && (\n <Banner>\n {formatMessage(messages.auditAccessExpired)}\n {' '}\n <Hyperlink isInline destination=\"\">\n {formatMessage(messages.findAnotherCourse)}\n </Hyperlink>\n </Banner>\n )}\n\n {(!isStaff && isTooEarly && courseRun.startDate) && (\n <Banner>\n {formatMessage(messages.courseHasNotStarted, {\n startDate: formatDate(courseRun.startDate),\n })}\n </Banner>\n )}\n\n {(!isStaff && hasUnmetPrerequisites) && (\n <Banner>{formatMessage(messages.prerequisitesNotMet)}</Banner>\n )}\n </>\n );\n};\nCourseBanner.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CourseBanner;\n"]}
1
+ {"version":3,"file":"CourseBanner.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/CourseCardBanners/CourseBanner.jsx"],"names":[],"mappings":";AAAA,4BAA4B;AAC5B,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AACtD,OAAO,MAAM,MAAM,wBAAwB,CAAC;AAC5C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACzC,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,EACJ,UAAU,GAAG,KAAK,EAClB,oBAAoB,GAAG,KAAK,EAC5B,gBAAgB,GAAG,EAAE,GACtB,GAAG,OAAO,CAAC,GAAG,EAAE;;QAAC,OAAA,CAAC;YACjB,UAAU,EAAE,MAAA,UAAU,CAAC,UAAU,0CAAE,UAAU;YAC7C,oBAAoB,EAAE,MAAA,UAAU,CAAC,UAAU,0CAAE,oBAAoB;YACjE,gBAAgB,EAAE,CAAA,MAAA,UAAU,CAAC,UAAU,0CAAE,gBAAgB,KAAI,EAAE;SAChE,CAAC,CAAA;KAAA,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAClB,MAAM,SAAS,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,KAAI,EAAE,CAAC;IAC9C,MAAM,UAAU,GAAG,SAAS,CAAC,aAAa,EAAE,CAAC;IAE7C,MAAM,EAAE,qBAAqB,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;IAExE,IAAI,UAAU,EAAE,CAAC;QAAC,OAAO,IAAI,CAAC;IAAC,CAAC;IAEhC,OAAO,CACL,8BACG,oBAAoB;mBAChB,CACD,MAAC,MAAM,eACJ,aAAa,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAC1C,IAAI,EACL,KAAC,SAAS,IAAC,QAAQ,QAAC,WAAW,EAAC,EAAE,YAC/B,aAAa,CAAC,QAAQ,CAAC,iBAAiB,CAAC,GAChC,IACL,CACV,EAEF,CAAC,CAAC,OAAO,IAAI,UAAU,IAAI,SAAS,CAAC,SAAS,CAAC,IAAI,CAClD,KAAC,MAAM,cACJ,aAAa,CAAC,QAAQ,CAAC,mBAAmB,EAAE;oBAC3C,SAAS,EAAE,UAAU,CAAC,SAAS,CAAC,SAAS,CAAC;iBAC3C,CAAC,GACK,CACV,EAEA,CAAC,CAAC,OAAO,IAAI,qBAAqB,CAAC,IAAI,CACtC,KAAC,MAAM,cAAE,aAAa,CAAC,QAAQ,CAAC,mBAAmB,CAAC,GAAU,CAC/D,IACA,CACJ,CAAC;AACJ,CAAC,CAAC;AACF,YAAY,CAAC,SAAS,GAAG;IACvB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,YAAY,CAAC","sourcesContent":["/* eslint-disable max-len */\nimport React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\nimport { Hyperlink } from '@openedx/paragon';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { utilHooks, useCourseData } from '@src/hooks';\nimport Banner from '@src/components/Banner';\nimport messages from './messages';\n\nexport const CourseBanner = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const courseData = useCourseData(cardId);\n const {\n isVerified = false,\n isAuditAccessExpired = false,\n coursewareAccess = {},\n } = useMemo(() => ({\n isVerified: courseData.enrollment?.isVerified,\n isAuditAccessExpired: courseData.enrollment?.isAuditAccessExpired,\n coursewareAccess: courseData.enrollment?.coursewareAccess || {},\n }), [courseData]);\n const courseRun = courseData?.courseRun || {};\n const formatDate = utilHooks.useFormatDate();\n\n const { hasUnmetPrerequisites, isStaff, isTooEarly } = coursewareAccess;\n\n if (isVerified) { return null; }\n\n return (\n <>\n {isAuditAccessExpired\n && (\n <Banner>\n {formatMessage(messages.auditAccessExpired)}\n {' '}\n <Hyperlink isInline destination=\"\">\n {formatMessage(messages.findAnotherCourse)}\n </Hyperlink>\n </Banner>\n )}\n\n {(!isStaff && isTooEarly && courseRun.startDate) && (\n <Banner>\n {formatMessage(messages.courseHasNotStarted, {\n startDate: formatDate(courseRun.startDate),\n })}\n </Banner>\n )}\n\n {(!isStaff && hasUnmetPrerequisites) && (\n <Banner>{formatMessage(messages.prerequisitesNotMet)}</Banner>\n )}\n </>\n );\n};\nCourseBanner.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default CourseBanner;\n"]}
@@ -1,5 +1,7 @@
1
+ import { useMemo } from 'react';
2
+ import { useInitializeLearnerHome } from '../../../../../data/hooks';
1
3
  import { StrictDict } from '../../../../../utils';
2
- import { reduxHooks } from '../../../../../hooks';
4
+ import { useCourseData } from '../../../../../hooks';
3
5
  import ApprovedContent from './views/ApprovedContent';
4
6
  import EligibleContent from './views/EligibleContent';
5
7
  import MustRequestContent from './views/MustRequestContent';
@@ -11,9 +13,26 @@ export const statusComponents = StrictDict({
11
13
  rejected: RejectedContent,
12
14
  });
13
15
  export const useCreditBannerData = (cardId) => {
14
- const credit = reduxHooks.useCardCreditData(cardId);
15
- const { supportEmail } = reduxHooks.usePlatformSettingsData();
16
- if (!credit.isEligible) {
16
+ var _a;
17
+ const courseData = useCourseData(cardId);
18
+ const { data: learnerHomeData } = useInitializeLearnerHome();
19
+ const supportEmail = useMemo(() => { var _a; return ((_a = learnerHomeData === null || learnerHomeData === void 0 ? void 0 : learnerHomeData.platformSettings) === null || _a === void 0 ? void 0 : _a.supportEmail); }, [learnerHomeData]);
20
+ const credit = useMemo(() => {
21
+ const creditData = courseData === null || courseData === void 0 ? void 0 : courseData.credit;
22
+ if (!creditData || Object.keys(creditData).length === 0) {
23
+ return { isEligible: false };
24
+ }
25
+ return {
26
+ isEligible: true,
27
+ providerStatusUrl: creditData.providerStatusUrl,
28
+ providerName: creditData.providerName,
29
+ providerId: creditData.providerId,
30
+ error: creditData.error,
31
+ purchased: creditData.purchased,
32
+ requestStatus: creditData.requestStatus,
33
+ };
34
+ }, [courseData]);
35
+ if (!credit.isEligible || !((_a = courseData === null || courseData === void 0 ? void 0 : courseData.credit) === null || _a === void 0 ? void 0 : _a.isEligible)) {
17
36
  return null;
18
37
  }
19
38
  const { error, purchased, requestStatus } = credit;
@@ -1 +1 @@
1
- {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,OAAO,eAAe,MAAM,yBAAyB,CAAC;AACtD,OAAO,eAAe,MAAM,yBAAyB,CAAC;AACtD,OAAO,kBAAkB,MAAM,4BAA4B,CAAC;AAC5D,OAAO,cAAc,MAAM,wBAAwB,CAAC;AACpD,OAAO,eAAe,MAAM,yBAAyB,CAAC;AAEtD,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAAU,CAAC;IACzC,OAAO,EAAE,cAAc;IACvB,QAAQ,EAAE,eAAe;IACzB,QAAQ,EAAE,eAAe;CAC1B,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,MAAM,EAAE,EAAE;IAC5C,MAAM,MAAM,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACpD,MAAM,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,uBAAuB,EAAE,CAAC;IAC9D,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC;QACvB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC;IACnD,IAAI,gBAAgB,GAAG,eAAe,CAAC;IACvC,IAAI,SAAS,EAAE,CAAC;QACd,IAAI,aAAa,IAAI,IAAI,EAAE,CAAC;YAC1B,gBAAgB,GAAG,kBAAkB,CAAC;QACxC,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;YACjE,gBAAgB,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QACrD,CAAC;QACD,oFAAoF;IACtF,CAAC;IACD,OAAO;QACL,gBAAgB;QAChB,KAAK;QACL,YAAY;KACb,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe;IACb,mBAAmB;CACpB,CAAC","sourcesContent":["import { StrictDict } from '../../../../../utils';\nimport { reduxHooks } from '../../../../../hooks';\n\nimport ApprovedContent from './views/ApprovedContent';\nimport EligibleContent from './views/EligibleContent';\nimport MustRequestContent from './views/MustRequestContent';\nimport PendingContent from './views/PendingContent';\nimport RejectedContent from './views/RejectedContent';\n\nexport const statusComponents = StrictDict({\n pending: PendingContent,\n approved: ApprovedContent,\n rejected: RejectedContent,\n});\n\nexport const useCreditBannerData = (cardId) => {\n const credit = reduxHooks.useCardCreditData(cardId);\n const { supportEmail } = reduxHooks.usePlatformSettingsData();\n if (!credit.isEligible) {\n return null;\n }\n\n const { error, purchased, requestStatus } = credit;\n let ContentComponent = EligibleContent;\n if (purchased) {\n if (requestStatus == null) {\n ContentComponent = MustRequestContent;\n } else if (Object.keys(statusComponents).includes(requestStatus)) {\n ContentComponent = statusComponents[requestStatus];\n }\n // Current behavior is to show Elligible State if unknown request status is returned\n }\n return {\n ContentComponent,\n error,\n supportEmail,\n };\n};\n\nexport default {\n useCreditBannerData,\n};\n"]}
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAExC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,eAAe,MAAM,yBAAyB,CAAC;AACtD,OAAO,eAAe,MAAM,yBAAyB,CAAC;AACtD,OAAO,kBAAkB,MAAM,4BAA4B,CAAC;AAC5D,OAAO,cAAc,MAAM,wBAAwB,CAAC;AACpD,OAAO,eAAe,MAAM,yBAAyB,CAAC;AAEtD,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAAU,CAAC;IACzC,OAAO,EAAE,cAAc;IACvB,QAAQ,EAAE,eAAe;IACzB,QAAQ,EAAE,eAAe;CAC1B,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,MAAM,EAAE,EAAE;;IAC5C,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,EAAE,IAAI,EAAE,eAAe,EAAE,GAAG,wBAAwB,EAAE,CAAC;IAC7D,MAAM,YAAY,GAAG,OAAO,CAC1B,GAAG,EAAE,WAAC,OAAA,CAAC,MAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,gBAAgB,0CAAE,YAAY,CAAC,CAAA,EAAA,EACvD,CAAC,eAAe,CAAC,CAClB,CAAC;IAEF,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE;QAC1B,MAAM,UAAU,GAAG,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,CAAC;QACtC,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxD,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC;QAC/B,CAAC;QACD,OAAO;YACL,UAAU,EAAE,IAAI;YAChB,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;YAC/C,YAAY,EAAE,UAAU,CAAC,YAAY;YACrC,UAAU,EAAE,UAAU,CAAC,UAAU;YACjC,KAAK,EAAE,UAAU,CAAC,KAAK;YACvB,SAAS,EAAE,UAAU,CAAC,SAAS;YAC/B,aAAa,EAAE,UAAU,CAAC,aAAa;SACxC,CAAC;IACJ,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IACjB,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,CAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,0CAAE,UAAU,CAAA,EAAE,CAAC;QAC1D,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC;IACnD,IAAI,gBAAgB,GAAG,eAAe,CAAC;IACvC,IAAI,SAAS,EAAE,CAAC;QACd,IAAI,aAAa,IAAI,IAAI,EAAE,CAAC;YAC1B,gBAAgB,GAAG,kBAAkB,CAAC;QACxC,CAAC;aAAM,IAAI,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,EAAE,CAAC;YACjE,gBAAgB,GAAG,gBAAgB,CAAC,aAAa,CAAC,CAAC;QACrD,CAAC;QACD,oFAAoF;IACtF,CAAC;IACD,OAAO;QACL,gBAAgB;QAChB,KAAK;QACL,YAAY;KACb,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe;IACb,mBAAmB;CACpB,CAAC","sourcesContent":["import { useMemo } from 'react';\nimport { useInitializeLearnerHome } from '@src/data/hooks';\nimport { StrictDict } from '@src/utils';\n\nimport { useCourseData } from '@src/hooks';\n\nimport ApprovedContent from './views/ApprovedContent';\nimport EligibleContent from './views/EligibleContent';\nimport MustRequestContent from './views/MustRequestContent';\nimport PendingContent from './views/PendingContent';\nimport RejectedContent from './views/RejectedContent';\n\nexport const statusComponents = StrictDict({\n pending: PendingContent,\n approved: ApprovedContent,\n rejected: RejectedContent,\n});\n\nexport const useCreditBannerData = (cardId) => {\n const courseData = useCourseData(cardId);\n const { data: learnerHomeData } = useInitializeLearnerHome();\n const supportEmail = useMemo(\n () => (learnerHomeData?.platformSettings?.supportEmail),\n [learnerHomeData],\n );\n\n const credit = useMemo(() => {\n const creditData = courseData?.credit;\n if (!creditData || Object.keys(creditData).length === 0) {\n return { isEligible: false };\n }\n return {\n isEligible: true,\n providerStatusUrl: creditData.providerStatusUrl,\n providerName: creditData.providerName,\n providerId: creditData.providerId,\n error: creditData.error,\n purchased: creditData.purchased,\n requestStatus: creditData.requestStatus,\n };\n }, [courseData]);\n if (!credit.isEligible || !courseData?.credit?.isEligible) {\n return null;\n }\n\n const { error, purchased, requestStatus } = credit;\n let ContentComponent = EligibleContent;\n if (purchased) {\n if (requestStatus == null) {\n ContentComponent = MustRequestContent;\n } else if (Object.keys(statusComponents).includes(requestStatus)) {\n ContentComponent = statusComponents[requestStatus];\n }\n // Current behavior is to show Elligible State if unknown request status is returned\n }\n return {\n ContentComponent,\n error,\n supportEmail,\n };\n};\n\nexport default {\n useCreditBannerData,\n};\n"]}
@@ -1,15 +1,21 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React, { useMemo } from 'react';
2
3
  import PropTypes from 'prop-types';
3
- import { useContext } from 'react';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
- import MasqueradeUserContext from '../../../../../../data/contexts/MasqueradeUserContext';
6
- import { reduxHooks } from '../../../../../../hooks';
5
+ import { useCourseData, useIsMasquerading } from '../../../../../../hooks';
7
6
  import CreditContent from './components/CreditContent';
8
7
  import ProviderLink from './components/ProviderLink';
9
8
  import messages from './messages';
10
9
  export const ApprovedContent = ({ cardId }) => {
11
- const { providerStatusUrl: href, providerName } = reduxHooks.useCardCreditData(cardId);
12
- const { isMasquerading } = useContext(MasqueradeUserContext);
10
+ const courseData = useCourseData(cardId);
11
+ const { providerStatusUrl: href, providerName } = useMemo(() => {
12
+ const creditData = courseData === null || courseData === void 0 ? void 0 : courseData.credit;
13
+ return {
14
+ providerStatusUrl: creditData.providerStatusUrl,
15
+ providerName: creditData.providerName,
16
+ };
17
+ }, [courseData]);
18
+ const isMasquerading = useIsMasquerading();
13
19
  const { formatMessage } = useIntl();
14
20
  return (_jsx(CreditContent, { action: { href, message: formatMessage(messages.viewCredit), disabled: isMasquerading }, message: formatMessage(messages.approved, {
15
21
  congratulations: _jsx("b", { children: formatMessage(messages.congratulations) }),
@@ -1 +1 @@
1
- {"version":3,"file":"ApprovedContent.js","sourceRoot":"","sources":["../../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.jsx"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,qBAAqB,MAAM,uDAAuD,CAAC;AAC1F,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,YAAY,MAAM,2BAA2B,CAAC;AAErD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC5C,MAAM,EAAE,iBAAiB,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IACvF,MAAM,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC,qBAAqB,CAAC,CAAC;IAC7D,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,OAAO,CACL,KAAC,aAAa,IACZ,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,cAAc,EAAE,EACvF,OAAO,EAAE,aAAa,CACpB,QAAQ,CAAC,QAAQ,EACjB;YACE,eAAe,EAAE,sBAAI,aAAa,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAK;YACjE,kBAAkB,EAAE,KAAC,YAAY,IAAC,MAAM,EAAE,MAAM,GAAI;YACpD,YAAY;SACb,CACF,GACD,CACH,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,CAAC,SAAS,GAAG;IAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,eAAe,CAAC","sourcesContent":["import PropTypes from 'prop-types';\nimport { useContext } from 'react';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport MasqueradeUserContext from '../../../../../../data/contexts/MasqueradeUserContext';\nimport { reduxHooks } from '../../../../../../hooks';\nimport CreditContent from './components/CreditContent';\nimport ProviderLink from './components/ProviderLink';\n\nimport messages from './messages';\n\nexport const ApprovedContent = ({ cardId }) => {\n const { providerStatusUrl: href, providerName } = reduxHooks.useCardCreditData(cardId);\n const { isMasquerading } = useContext(MasqueradeUserContext);\n const { formatMessage } = useIntl();\n return (\n <CreditContent\n action={{ href, message: formatMessage(messages.viewCredit), disabled: isMasquerading }}\n message={formatMessage(\n messages.approved,\n {\n congratulations: <b>{formatMessage(messages.congratulations)}</b>,\n linkToProviderSite: <ProviderLink cardId={cardId} />,\n providerName,\n },\n )}\n />\n );\n};\nApprovedContent.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default ApprovedContent;\n"]}
1
+ {"version":3,"file":"ApprovedContent.js","sourceRoot":"","sources":["../../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC9D,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,YAAY,MAAM,2BAA2B,CAAC;AAErD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC5C,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,EAAE,iBAAiB,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE;QAC7D,MAAM,UAAU,GAAG,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,CAAC;QACtC,OAAO;YACL,iBAAiB,EAAE,UAAU,CAAC,iBAAiB;YAC/C,YAAY,EAAE,UAAU,CAAC,YAAY;SACtC,CAAC;IACJ,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IACjB,MAAM,cAAc,GAAG,iBAAiB,EAAE,CAAC;IAC3C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,OAAO,CACL,KAAC,aAAa,IACZ,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,aAAa,CAAC,QAAQ,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,cAAc,EAAE,EACvF,OAAO,EAAE,aAAa,CACpB,QAAQ,CAAC,QAAQ,EACjB;YACE,eAAe,EAAE,sBAAI,aAAa,CAAC,QAAQ,CAAC,eAAe,CAAC,GAAK;YACjE,kBAAkB,EAAE,KAAC,YAAY,IAAC,MAAM,EAAE,MAAM,GAAI;YACpD,YAAY;SACb,CACF,GACD,CACH,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,CAAC,SAAS,GAAG;IAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,eAAe,CAAC","sourcesContent":["import React, { useMemo } from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { useCourseData, useIsMasquerading } from '@src/hooks';\nimport CreditContent from './components/CreditContent';\nimport ProviderLink from './components/ProviderLink';\n\nimport messages from './messages';\n\nexport const ApprovedContent = ({ cardId }) => {\n const courseData = useCourseData(cardId);\n const { providerStatusUrl: href, providerName } = useMemo(() => {\n const creditData = courseData?.credit;\n return {\n providerStatusUrl: creditData.providerStatusUrl,\n providerName: creditData.providerName,\n };\n }, [courseData]);\n const isMasquerading = useIsMasquerading();\n const { formatMessage } = useIntl();\n return (\n <CreditContent\n action={{ href, message: formatMessage(messages.viewCredit), disabled: isMasquerading }}\n message={formatMessage(\n messages.approved,\n {\n congratulations: <b>{formatMessage(messages.congratulations)}</b>,\n linkToProviderSite: <ProviderLink cardId={cardId} />,\n providerName,\n },\n )}\n />\n );\n};\nApprovedContent.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default ApprovedContent;\n"]}
@@ -2,14 +2,16 @@ import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import React from 'react';
3
3
  import PropTypes from 'prop-types';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
- import { reduxHooks } from '../../../../../../hooks';
5
+ import { useCourseData } from '../../../../../../hooks';
6
6
  import track from '../../../../../../tracking';
7
7
  import CreditContent from './components/CreditContent';
8
8
  import messages from './messages';
9
9
  export const EligibleContent = ({ cardId }) => {
10
+ var _a, _b;
10
11
  const { formatMessage } = useIntl();
11
- const { providerName } = reduxHooks.useCardCreditData(cardId);
12
- const { courseId } = reduxHooks.useCardCourseRunData(cardId);
12
+ const courseData = useCourseData(cardId);
13
+ const providerName = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.credit) === null || _a === void 0 ? void 0 : _a.providerName;
14
+ const courseId = (_b = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _b === void 0 ? void 0 : _b.courseId;
13
15
  const onClick = track.credit.purchase(courseId);
14
16
  const getCredit = formatMessage(messages.getCredit);
15
17
  const message = providerName
@@ -1 +1 @@
1
- {"version":3,"file":"EligibleContent.js","sourceRoot":"","sources":["../../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,KAAK,MAAM,4BAA4B,CAAC;AAE/C,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC5C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;IAC9D,MAAM,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAE7D,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IACpD,MAAM,OAAO,GAAG,YAAY;QAC1B,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,oBAAoB,EAAE,EAAE,YAAY,EAAE,CAAC;QAChE,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,CAAC,sBAAI,SAAS,GAAK,CAAC,EAAE,CAAC,CAAC;IAE1E,OAAO,CACL,KAAC,aAAa,IACZ,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,EACvC,OAAO,EAAE,OAAO,GAChB,CACH,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,CAAC,SAAS,GAAG;IAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,eAAe,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { reduxHooks } from '../../../../../../hooks';\nimport track from '../../../../../../tracking';\n\nimport CreditContent from './components/CreditContent';\nimport messages from './messages';\n\nexport const EligibleContent = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const { providerName } = reduxHooks.useCardCreditData(cardId);\n const { courseId } = reduxHooks.useCardCourseRunData(cardId);\n\n const onClick = track.credit.purchase(courseId);\n const getCredit = formatMessage(messages.getCredit);\n const message = providerName\n ? formatMessage(messages.eligibleFromProvider, { providerName })\n : formatMessage(messages.eligible, { getCredit: (<b>{getCredit}</b>) });\n\n return (\n <CreditContent\n action={{ onClick, message: getCredit }}\n message={message}\n />\n );\n};\nEligibleContent.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default EligibleContent;\n"]}
1
+ {"version":3,"file":"EligibleContent.js","sourceRoot":"","sources":["../../../../../../../src/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,KAAK,MAAM,eAAe,CAAC;AAElC,OAAO,aAAa,MAAM,4BAA4B,CAAC;AACvD,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IAC5C,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,YAAY,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,0CAAE,YAAY,CAAC;IACtD,MAAM,QAAQ,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,QAAQ,CAAC;IAEjD,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAChD,MAAM,SAAS,GAAG,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IACpD,MAAM,OAAO,GAAG,YAAY;QAC1B,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,oBAAoB,EAAE,EAAE,YAAY,EAAE,CAAC;QAChE,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,CAAC,sBAAI,SAAS,GAAK,CAAC,EAAE,CAAC,CAAC;IAE1E,OAAO,CACL,KAAC,aAAa,IACZ,MAAM,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,EACvC,OAAO,EAAE,OAAO,GAChB,CACH,CAAC;AACJ,CAAC,CAAC;AACF,eAAe,CAAC,SAAS,GAAG;IAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,eAAe,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { useCourseData } from '@src/hooks';\nimport track from '@src/tracking';\n\nimport CreditContent from './components/CreditContent';\nimport messages from './messages';\n\nexport const EligibleContent = ({ cardId }) => {\n const { formatMessage } = useIntl();\n const courseData = useCourseData(cardId);\n const providerName = courseData?.credit?.providerName;\n const courseId = courseData?.courseRun?.courseId;\n\n const onClick = track.credit.purchase(courseId);\n const getCredit = formatMessage(messages.getCredit);\n const message = providerName\n ? formatMessage(messages.eligibleFromProvider, { providerName })\n : formatMessage(messages.eligible, { getCredit: (<b>{getCredit}</b>) });\n\n return (\n <CreditContent\n action={{ onClick, message: getCredit }}\n message={message}\n />\n );\n};\nEligibleContent.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default EligibleContent;\n"]}
@@ -1,8 +1,8 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
+ import React from 'react';
2
3
  import PropTypes from 'prop-types';
3
- import { useContext } from 'react';
4
4
  import { useIntl } from '@openedx/frontend-base';
5
- import MasqueradeUserContext from '../../../../../../data/contexts/MasqueradeUserContext';
5
+ import { useIsMasquerading } from '../../../../../../hooks';
6
6
  import CreditContent from './components/CreditContent';
7
7
  import ProviderLink from './components/ProviderLink';
8
8
  import hooks from './hooks';
@@ -10,7 +10,7 @@ import messages from './messages';
10
10
  export const MustRequestContent = ({ cardId }) => {
11
11
  const { formatMessage } = useIntl();
12
12
  const { requestData, createCreditRequest } = hooks.useCreditRequestData(cardId);
13
- const { isMasquerading } = useContext(MasqueradeUserContext);
13
+ const isMasquerading = useIsMasquerading();
14
14
  return (_jsx(CreditContent, { action: {
15
15
  message: formatMessage(messages.requestCredit),
16
16
  onClick: createCreditRequest,