@openedx/frontend-app-learner-dashboard 1.0.0-alpha.6 → 1.0.0-alpha.8
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.
- package/dist/Main.js +2 -3
- package/dist/Main.js.map +1 -1
- package/dist/app.js +1 -2
- package/dist/app.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js +14 -5
- package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js +14 -5
- package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js +3 -3
- package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js +5 -3
- package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardActions/index.js +5 -4
- package/dist/containers/CourseCard/components/CourseCardActions/index.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js +26 -9
- package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js +12 -4
- package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js +23 -4
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js +11 -5
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js +5 -3
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js +3 -3
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js +5 -5
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js +4 -3
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js +3 -2
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js +13 -5
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js +10 -6
- package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js +5 -4
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/index.d.ts +1 -1
- package/dist/containers/CourseCard/components/CourseCardBanners/index.js +6 -2
- package/dist/containers/CourseCard/components/CourseCardBanners/index.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.d.ts +3 -3
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js +14 -12
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardImage.js +7 -6
- package/dist/containers/CourseCard/components/CourseCardImage.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js +14 -11
- package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js +26 -6
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardMenu/index.js +5 -5
- package/dist/containers/CourseCard/components/CourseCardMenu/index.js.map +1 -1
- package/dist/containers/CourseCard/components/CourseCardTitle.js +6 -4
- package/dist/containers/CourseCard/components/CourseCardTitle.js.map +1 -1
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js +4 -2
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js.map +1 -1
- package/dist/containers/CourseCard/components/hooks.d.ts +1 -1
- package/dist/containers/CourseCard/components/hooks.js +9 -7
- package/dist/containers/CourseCard/components/hooks.js.map +1 -1
- package/dist/containers/CourseCard/hooks.d.ts +0 -12
- package/dist/containers/CourseCard/hooks.js +0 -14
- package/dist/containers/CourseCard/hooks.js.map +1 -1
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.d.ts +1 -11
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.js +4 -9
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.js.map +1 -1
- package/dist/containers/CourseFilterControls/CourseFilterControls.d.ts +1 -13
- package/dist/containers/CourseFilterControls/CourseFilterControls.js +26 -16
- package/dist/containers/CourseFilterControls/CourseFilterControls.js.map +1 -1
- package/dist/containers/CoursesPanel/CourseList/index.d.ts +0 -1
- package/dist/containers/CoursesPanel/CourseList/index.js +2 -3
- package/dist/containers/CoursesPanel/CourseList/index.js.map +1 -1
- package/dist/containers/CoursesPanel/NoCoursesView/index.js +4 -2
- package/dist/containers/CoursesPanel/NoCoursesView/index.js.map +1 -1
- package/dist/containers/CoursesPanel/index.js +27 -6
- package/dist/containers/CoursesPanel/index.js.map +1 -1
- package/dist/containers/Dashboard/hooks.js.map +1 -1
- package/dist/containers/Dashboard/index.js +7 -4
- package/dist/containers/Dashboard/index.js.map +1 -1
- package/dist/containers/EmailSettingsModal/hooks.js +8 -5
- package/dist/containers/EmailSettingsModal/hooks.js.map +1 -1
- package/dist/containers/RelatedProgramsModal/index.js +5 -3
- package/dist/containers/RelatedProgramsModal/index.js.map +1 -1
- package/dist/containers/SelectSessionModal/hooks.d.ts +1 -1
- package/dist/containers/SelectSessionModal/hooks.js +25 -15
- package/dist/containers/SelectSessionModal/hooks.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.d.ts +3 -1
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js +9 -3
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.d.ts +3 -3
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js +9 -4
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.d.ts +3 -2
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js +3 -3
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/components/messages.d.ts +7 -7
- package/dist/containers/UnenrollConfirmModal/components/messages.js +12 -12
- package/dist/containers/UnenrollConfirmModal/components/messages.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/constants.d.ts +5 -0
- package/dist/containers/UnenrollConfirmModal/constants.js +7 -1
- package/dist/containers/UnenrollConfirmModal/constants.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/hooks/index.d.ts +1 -3
- package/dist/containers/UnenrollConfirmModal/hooks/index.js +18 -13
- package/dist/containers/UnenrollConfirmModal/hooks/index.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.d.ts +0 -2
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.js +13 -15
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.js.map +1 -1
- package/dist/containers/UnenrollConfirmModal/index.js +1 -1
- package/dist/containers/UnenrollConfirmModal/index.js.map +1 -1
- package/dist/data/constants/files.js +1 -1
- package/dist/data/constants/files.js.map +1 -1
- package/dist/data/constants/htmlKeys.js +1 -1
- package/dist/data/constants/htmlKeys.js.map +1 -1
- package/dist/data/context/FiltersProvider.d.ts +18 -0
- package/dist/data/context/FiltersProvider.js +37 -0
- package/dist/data/context/FiltersProvider.js.map +1 -0
- package/dist/data/context/MasqueradeProvider.d.ts +11 -0
- package/dist/data/context/MasqueradeProvider.js +19 -0
- package/dist/data/context/MasqueradeProvider.js.map +1 -0
- package/dist/data/context/SelectSessionProvider.d.ts +15 -0
- package/dist/data/context/SelectSessionProvider.js +40 -0
- package/dist/data/context/SelectSessionProvider.js.map +1 -0
- package/dist/data/context/index.d.ts +10 -0
- package/dist/data/context/index.js +8 -0
- package/dist/data/context/index.js.map +1 -0
- package/dist/data/contexts/GlobalDataContext.d.ts +15 -11
- package/dist/data/contexts/GlobalDataContext.js.map +1 -1
- package/dist/data/hooks/index.d.ts +3 -0
- package/dist/data/hooks/index.js +4 -0
- package/dist/data/hooks/index.js.map +1 -0
- package/dist/data/hooks/mutationHooks.d.ts +26 -0
- package/dist/data/hooks/mutationHooks.js +84 -0
- package/dist/data/hooks/mutationHooks.js.map +1 -0
- package/dist/data/hooks/queryHooks.d.ts +164 -0
- package/dist/data/hooks/queryHooks.js +57 -0
- package/dist/data/hooks/queryHooks.js.map +1 -0
- package/dist/data/hooks/queryKeys.d.ts +13 -0
- package/dist/data/hooks/queryKeys.js +15 -0
- package/dist/data/hooks/queryKeys.js.map +1 -0
- package/dist/data/services/lms/api.d.ts +18 -27
- package/dist/data/services/lms/api.js +77 -38
- package/dist/data/services/lms/api.js.map +1 -1
- package/dist/data/services/lms/index.js +1 -1
- package/dist/data/services/lms/index.js.map +1 -1
- package/dist/data/services/lms/urls.d.ts +0 -1
- package/dist/data/services/lms/urls.js +6 -2
- package/dist/data/services/lms/urls.js.map +1 -1
- package/dist/data/services/segment/utils.d.ts +1 -1
- package/dist/hooks/index.d.ts +5 -4
- package/dist/hooks/index.js +8 -4
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/useCourseData.d.ts +2 -0
- package/dist/hooks/useCourseData.js +8 -0
- package/dist/hooks/useCourseData.js.map +1 -0
- package/dist/hooks/useCourseTrackingEvent.d.ts +2 -0
- package/dist/hooks/useCourseTrackingEvent.js +13 -0
- package/dist/hooks/useCourseTrackingEvent.js.map +1 -0
- package/dist/hooks/useEntitlementInfo.d.ts +22 -0
- package/dist/hooks/useEntitlementInfo.js +29 -0
- package/dist/hooks/useEntitlementInfo.js.map +1 -0
- package/dist/hooks/useIsMasquerading.d.ts +2 -0
- package/dist/hooks/useIsMasquerading.js +9 -0
- package/dist/hooks/useIsMasquerading.js.map +1 -0
- package/dist/i18n/index.d.ts +1 -25
- package/dist/i18n/index.js +1 -25
- package/dist/i18n/index.js.map +1 -1
- package/dist/providers.js +2 -2
- package/dist/providers.js.map +1 -1
- package/dist/routes.d.ts +2 -0
- package/dist/routes.js +3 -1
- package/dist/routes.js.map +1 -1
- package/dist/tracking/trackers/findCourses.d.ts +1 -1
- package/dist/tracking/trackers/socialShare.js +2 -2
- package/dist/tracking/trackers/socialShare.js.map +1 -1
- package/dist/utils/dataTransformers.d.ts +7 -0
- package/dist/utils/dataTransformers.js +58 -0
- package/dist/utils/dataTransformers.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.d.ts +5 -6
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js +9 -14
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js.map +1 -1
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.d.ts +12 -14
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js +24 -34
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js.map +1 -1
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js +1 -1
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js.map +1 -1
- package/dist/widgets/LearnerDashboardHeader/hooks.js +1 -1
- package/dist/widgets/LearnerDashboardHeader/hooks.js.map +1 -1
- package/dist/widgets/LookingForChallengeWidget/index.js +4 -2
- package/dist/widgets/LookingForChallengeWidget/index.js.map +1 -1
- package/dist/widgets/LookingForChallengeWidget/track.d.ts +1 -1
- package/package.json +26 -18
- package/dist/containers/CourseFilterControls/hooks.d.ts +0 -3
- package/dist/containers/CourseFilterControls/hooks.js +0 -48
- package/dist/containers/CourseFilterControls/hooks.js.map +0 -1
- package/dist/containers/CoursesPanel/hooks.d.ts +0 -15
- package/dist/containers/CoursesPanel/hooks.js +0 -45
- package/dist/containers/CoursesPanel/hooks.js.map +0 -1
- package/dist/containers/RelatedProgramsModal/hooks.d.ts +0 -7
- package/dist/containers/RelatedProgramsModal/hooks.js +0 -7
- package/dist/containers/RelatedProgramsModal/hooks.js.map +0 -1
- package/dist/data/contexts/MasqueradeUserContext.d.ts +0 -13
- package/dist/data/contexts/MasqueradeUserContext.js +0 -15
- package/dist/data/contexts/MasqueradeUserContext.js.map +0 -1
- package/dist/data/contexts/MasqueradeUserProvider.d.ts +0 -3
- package/dist/data/contexts/MasqueradeUserProvider.js +0 -24
- package/dist/data/contexts/MasqueradeUserProvider.js.map +0 -1
- package/dist/data/redux/app/index.d.ts +0 -2
- package/dist/data/redux/app/index.js +0 -3
- package/dist/data/redux/app/index.js.map +0 -1
- package/dist/data/redux/app/reducer.d.ts +0 -25
- package/dist/data/redux/app/reducer.js +0 -42
- package/dist/data/redux/app/reducer.js.map +0 -1
- package/dist/data/redux/app/selectors/appSelectors.d.ts +0 -17
- package/dist/data/redux/app/selectors/appSelectors.js +0 -13
- package/dist/data/redux/app/selectors/appSelectors.js.map +0 -1
- package/dist/data/redux/app/selectors/courseCard.d.ts +0 -3
- package/dist/data/redux/app/selectors/courseCard.js +0 -114
- package/dist/data/redux/app/selectors/courseCard.js.map +0 -1
- package/dist/data/redux/app/selectors/currentList.d.ts +0 -24
- package/dist/data/redux/app/selectors/currentList.js +0 -45
- package/dist/data/redux/app/selectors/currentList.js.map +0 -1
- package/dist/data/redux/app/selectors/index.d.ts +0 -2
- package/dist/data/redux/app/selectors/index.js +0 -8
- package/dist/data/redux/app/selectors/index.js.map +0 -1
- package/dist/data/redux/app/selectors/simpleSelectors.d.ts +0 -5
- package/dist/data/redux/app/selectors/simpleSelectors.js +0 -31
- package/dist/data/redux/app/selectors/simpleSelectors.js.map +0 -1
- package/dist/data/redux/hooks/app.d.ts +0 -42
- package/dist/data/redux/hooks/app.js +0 -99
- package/dist/data/redux/hooks/app.js.map +0 -1
- package/dist/data/redux/hooks/index.d.ts +0 -2
- package/dist/data/redux/hooks/index.js +0 -3
- package/dist/data/redux/hooks/index.js.map +0 -1
- package/dist/data/redux/hooks/requests.d.ts +0 -16
- package/dist/data/redux/hooks/requests.js +0 -38
- package/dist/data/redux/hooks/requests.js.map +0 -1
- package/dist/data/redux/index.d.ts +0 -6
- package/dist/data/redux/index.js +0 -26
- package/dist/data/redux/index.js.map +0 -1
- package/dist/data/redux/requests/index.d.ts +0 -2
- package/dist/data/redux/requests/index.js +0 -3
- package/dist/data/redux/requests/index.js.map +0 -1
- package/dist/data/redux/requests/reducer.d.ts +0 -36
- package/dist/data/redux/requests/reducer.js +0 -32
- package/dist/data/redux/requests/reducer.js.map +0 -1
- package/dist/data/redux/requests/selectors.d.ts +0 -21
- package/dist/data/redux/requests/selectors.js +0 -24
- package/dist/data/redux/requests/selectors.js.map +0 -1
- package/dist/data/services/lms/fakeData/courses.d.ts +0 -788
- package/dist/data/services/lms/fakeData/courses.js +0 -744
- package/dist/data/services/lms/fakeData/courses.js.map +0 -1
- package/dist/data/services/lms/fakeData/testUtils.d.ts +0 -18
- package/dist/data/services/lms/fakeData/testUtils.js +0 -31
- package/dist/data/services/lms/fakeData/testUtils.js.map +0 -1
- package/dist/data/store.d.ts +0 -12
- package/dist/data/store.js +0 -14
- package/dist/data/store.js.map +0 -1
- package/dist/data/utils.d.ts +0 -10
- package/dist/data/utils.js +0 -14
- package/dist/data/utils.js.map +0 -1
- package/dist/hooks/api.d.ts +0 -9
- package/dist/hooks/api.js +0 -96
- package/dist/hooks/api.js.map +0 -1
- package/dist/slots/CourseBannerSlot/images/course_banner_slot_default.png +0 -0
- package/dist/slots/CourseBannerSlot/images/custom_course_banner.png +0 -0
- package/dist/slots/CourseCardActionSlot/images/post_course_card_action.png +0 -0
- package/dist/slots/CourseListSlot/images/course_list_slot.png +0 -0
- package/dist/slots/CourseListSlot/images/readme_custom_course_list.png +0 -0
- package/dist/slots/DashboardModalSlot/images/dashboard_modal_slot.png +0 -0
- package/dist/slots/NoCoursesViewSlot/images/no_course_view_slot.png +0 -0
- package/dist/slots/NoCoursesViewSlot/images/readme_custom_no_courses.png +0 -0
- package/dist/slots/WidgetSidebarSlot/images/readme_custom_sidebar.png +0 -0
- package/dist/slots/WidgetSidebarSlot/images/widget_sidebar_slot.png +0 -0
- package/dist/test/inspector.d.ts +0 -28
- package/dist/test/inspector.js +0 -38
- package/dist/test/inspector.js.map +0 -1
- package/dist/test/messages.d.ts +0 -8
- package/dist/test/messages.js +0 -18
- package/dist/test/messages.js.map +0 -1
- package/dist/test/utils.d.ts +0 -2
- package/dist/test/utils.js +0 -3
- 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
|
|
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(
|
|
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,
|
|
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
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import { appId } from './constants';
|
|
2
2
|
import routes from './routes';
|
|
3
3
|
import providers from './providers';
|
|
4
|
-
import messages from './i18n';
|
|
5
4
|
import slots from './slots';
|
|
6
5
|
const app = {
|
|
7
6
|
appId,
|
|
8
7
|
routes,
|
|
9
8
|
providers,
|
|
10
|
-
messages,
|
|
11
9
|
slots,
|
|
12
10
|
config: {
|
|
13
11
|
LEARNING_BASE_URL: 'http://apps.local.openedx.io:2000',
|
|
@@ -15,6 +13,7 @@ const app = {
|
|
|
15
13
|
ECOMMERCE_BASE_URL: '',
|
|
16
14
|
ORDER_HISTORY_URL: '',
|
|
17
15
|
SUPPORT_URL: '',
|
|
16
|
+
SHOW_UNENROLL_SURVEY: false,
|
|
18
17
|
}
|
|
19
18
|
};
|
|
20
19
|
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,
|
|
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,KAAK,MAAM,SAAS,CAAC;AAE5B,MAAM,GAAG,GAAQ;IACf,KAAK;IACL,MAAM;IACN,SAAS;IACT,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 slots from './slots';\n\nconst app: App = {\n appId,\n routes,\n providers,\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 {
|
|
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 {
|
|
13
|
-
const
|
|
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 =
|
|
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;
|
|
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 {
|
|
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 {
|
|
13
|
-
const
|
|
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 =
|
|
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;
|
|
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 {
|
|
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
|
|
13
|
-
return (_jsx(ActionButton, { disabled: disableSelectSession, onClick:
|
|
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,
|
|
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 {
|
|
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
|
|
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 =
|
|
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,
|
|
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 {
|
|
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
|
|
13
|
-
const
|
|
14
|
-
const {
|
|
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,
|
|
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 {
|
|
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
|
|
14
|
-
const
|
|
15
|
-
const { isPassing } =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
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.
|
|
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":";AAAA,4BAA4B;AAC5B,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
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, { 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,
|
|
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;
|
|
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 {
|
|
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
|
-
|
|
15
|
-
const
|
|
16
|
-
|
|
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,
|
|
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
|
|
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
|
|
12
|
-
const {
|
|
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,
|
|
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 {
|
|
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
|
|
12
|
-
const
|
|
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,
|
|
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
|
|
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
|
|
13
|
+
const isMasquerading = useIsMasquerading();
|
|
14
14
|
return (_jsx(CreditContent, { action: {
|
|
15
15
|
message: formatMessage(messages.requestCredit),
|
|
16
16
|
onClick: createCreditRequest,
|