@edx/frontend-app-subscription-learner-dashboard 1.0.0
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/LICENSE +661 -0
- package/README.rst +84 -0
- package/dist/Main.d.ts +2 -0
- package/dist/Main.js +9 -0
- package/dist/Main.js.map +1 -0
- package/dist/app.d.ts +3 -0
- package/dist/app.js +20 -0
- package/dist/app.js.map +1 -0
- package/dist/assets/empty-course.svg +49 -0
- package/dist/assets/more-courses-sidewidget.svg +52 -0
- package/dist/assets/verified-ribbon.png +0 -0
- package/dist/components/Banner.d.ts +24 -0
- package/dist/components/Banner.js +19 -0
- package/dist/components/Banner.js.map +1 -0
- package/dist/constants.d.ts +1 -0
- package/dist/constants.js +2 -0
- package/dist/constants.js.map +1 -0
- package/dist/containers/CourseCard/CourseCard.scss +73 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/hooks.d.ts +2 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/hooks.js +7 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/index.d.ts +2 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/index.js +10 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ActionButton/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js +31 -0
- package/dist/containers/CourseCard/components/CourseCardActions/BeginCourseButton.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js +32 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ResumeButton.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js +19 -0
- package/dist/containers/CourseCard/components/CourseCardActions/SelectSessionButton.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js +23 -0
- package/dist/containers/CourseCard/components/CourseCardActions/ViewCourseButton.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/index.d.ts +12 -0
- package/dist/containers/CourseCard/components/CourseCardActions/index.js +30 -0
- package/dist/containers/CourseCard/components/CourseCardActions/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardActions/messages.d.ts +48 -0
- package/dist/containers/CourseCard/components/CourseCardActions/messages.js +35 -0
- package/dist/containers/CourseCard/components/CourseCardActions/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js +63 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CertificateBanner.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js +36 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CourseBanner.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.d.ts +17 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js +58 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/index.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/index.js +23 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/messages.d.ts +16 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/messages.js +15 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js +30 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/ApprovedContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js +26 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/EligibleContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js +27 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/MustRequestContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js +23 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/PendingContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js +22 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/RejectedContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditContent.d.ts +30 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditContent.js +27 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditContent.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/hooks.d.ts +5 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/hooks.js +12 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/index.d.ts +19 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/index.js +24 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/CreditRequestForm/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js +16 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/components/ProviderLink.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.d.ts +9 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js +31 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/messages.d.ts +88 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/messages.js +60 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/CreditBanner/views/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js +42 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/EntitlementBanner.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RedeemBanner.d.ts +2 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RedeemBanner.js +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RedeemBanner.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/ProgramsList.d.ts +13 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/ProgramsList.js +12 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/ProgramsList.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.d.ts +10 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js +23 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/messages.d.ts +40 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/messages.js +30 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/RelatedProgramsBanner/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/index.d.ts +12 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/index.js +17 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/messages.d.ts +168 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/messages.js +110 -0
- package/dist/containers/CourseCard/components/CourseCardBanners/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.d.ts +16 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js +51 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/index.d.ts +11 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/index.js +16 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/index.scss +3 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/messages.d.ts +56 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/messages.js +40 -0
- package/dist/containers/CourseCard/components/CourseCardDetails/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardImage.d.ts +13 -0
- package/dist/containers/CourseCard/components/CourseCardImage.js +35 -0
- package/dist/containers/CourseCard/components/CourseCardImage.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.d.ts +17 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js +43 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/SocialShareMenu.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.d.ts +26 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js +67 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/index.d.ts +13 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/index.js +34 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/index.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/messages.d.ts +48 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/messages.js +35 -0
- package/dist/containers/CourseCard/components/CourseCardMenu/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/CourseCardTitle.d.ts +11 -0
- package/dist/containers/CourseCard/components/CourseCardTitle.js +22 -0
- package/dist/containers/CourseCard/components/CourseCardTitle.js.map +1 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.d.ts +11 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js +29 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/hooks.js.map +1 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/index.d.ts +10 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/index.js +20 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/index.js.map +1 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/messages.d.ts +16 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/messages.js +14 -0
- package/dist/containers/CourseCard/components/RelatedProgramsBadge/messages.js.map +1 -0
- package/dist/containers/CourseCard/components/hooks.d.ts +8 -0
- package/dist/containers/CourseCard/components/hooks.js +25 -0
- package/dist/containers/CourseCard/components/hooks.js.map +1 -0
- package/dist/containers/CourseCard/hooks.d.ts +1 -0
- package/dist/containers/CourseCard/hooks.js +6 -0
- package/dist/containers/CourseCard/hooks.js.map +1 -0
- package/dist/containers/CourseCard/index.d.ts +12 -0
- package/dist/containers/CourseCard/index.js +21 -0
- package/dist/containers/CourseCard/index.js.map +1 -0
- package/dist/containers/CourseCard/messages.d.ts +32 -0
- package/dist/containers/CourseCard/messages.js +25 -0
- package/dist/containers/CourseCard/messages.js.map +1 -0
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.d.ts +2 -0
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.js +15 -0
- package/dist/containers/CourseFilterControls/ActiveCourseFilters.js.map +1 -0
- package/dist/containers/CourseFilterControls/CourseFilterControls.d.ts +2 -0
- package/dist/containers/CourseFilterControls/CourseFilterControls.js +41 -0
- package/dist/containers/CourseFilterControls/CourseFilterControls.js.map +1 -0
- package/dist/containers/CourseFilterControls/components/Checkbox.d.ts +10 -0
- package/dist/containers/CourseFilterControls/components/Checkbox.js +15 -0
- package/dist/containers/CourseFilterControls/components/Checkbox.js.map +1 -0
- package/dist/containers/CourseFilterControls/components/FilterForm.d.ts +13 -0
- package/dist/containers/CourseFilterControls/components/FilterForm.js +25 -0
- package/dist/containers/CourseFilterControls/components/FilterForm.js.map +1 -0
- package/dist/containers/CourseFilterControls/components/SortForm.d.ts +12 -0
- package/dist/containers/CourseFilterControls/components/SortForm.js +17 -0
- package/dist/containers/CourseFilterControls/components/SortForm.js.map +1 -0
- package/dist/containers/CourseFilterControls/index.d.ts +4 -0
- package/dist/containers/CourseFilterControls/index.js +5 -0
- package/dist/containers/CourseFilterControls/index.js.map +1 -0
- package/dist/containers/CourseFilterControls/index.scss +29 -0
- package/dist/containers/CourseFilterControls/messages.d.ts +88 -0
- package/dist/containers/CourseFilterControls/messages.js +60 -0
- package/dist/containers/CourseFilterControls/messages.js.map +1 -0
- package/dist/containers/CoursesPanel/CourseList/hooks.d.ts +2 -0
- package/dist/containers/CoursesPanel/CourseList/hooks.js +7 -0
- package/dist/containers/CoursesPanel/CourseList/hooks.js.map +1 -0
- package/dist/containers/CoursesPanel/CourseList/index.d.ts +17 -0
- package/dist/containers/CoursesPanel/CourseList/index.js +22 -0
- package/dist/containers/CoursesPanel/CourseList/index.js.map +1 -0
- package/dist/containers/CoursesPanel/NoCoursesView/index.d.ts +2 -0
- package/dist/containers/CoursesPanel/NoCoursesView/index.js +17 -0
- package/dist/containers/CoursesPanel/NoCoursesView/index.js.map +1 -0
- package/dist/containers/CoursesPanel/NoCoursesView/messages.d.ts +16 -0
- package/dist/containers/CoursesPanel/NoCoursesView/messages.js +15 -0
- package/dist/containers/CoursesPanel/NoCoursesView/messages.js.map +1 -0
- package/dist/containers/CoursesPanel/index.d.ts +5 -0
- package/dist/containers/CoursesPanel/index.js +48 -0
- package/dist/containers/CoursesPanel/index.js.map +1 -0
- package/dist/containers/CoursesPanel/index.scss +42 -0
- package/dist/containers/CoursesPanel/messages.d.ts +16 -0
- package/dist/containers/CoursesPanel/messages.js +15 -0
- package/dist/containers/CoursesPanel/messages.js.map +1 -0
- package/dist/containers/Dashboard/DashboardLayout.d.ts +58 -0
- package/dist/containers/Dashboard/DashboardLayout.js +34 -0
- package/dist/containers/Dashboard/DashboardLayout.js.map +1 -0
- package/dist/containers/Dashboard/DashboardTabs.d.ts +2 -0
- package/dist/containers/Dashboard/DashboardTabs.js +34 -0
- package/dist/containers/Dashboard/DashboardTabs.js.map +1 -0
- package/dist/containers/Dashboard/DashboardTitle.d.ts +2 -0
- package/dist/containers/Dashboard/DashboardTitle.js +9 -0
- package/dist/containers/Dashboard/DashboardTitle.js.map +1 -0
- package/dist/containers/Dashboard/LoadingView.d.ts +2 -0
- package/dist/containers/Dashboard/LoadingView.js +10 -0
- package/dist/containers/Dashboard/LoadingView.js.map +1 -0
- package/dist/containers/Dashboard/hooks.d.ts +15 -0
- package/dist/containers/Dashboard/hooks.js +30 -0
- package/dist/containers/Dashboard/hooks.js.map +1 -0
- package/dist/containers/Dashboard/index.d.ts +2 -0
- package/dist/containers/Dashboard/index.js +25 -0
- package/dist/containers/Dashboard/index.js.map +1 -0
- package/dist/containers/Dashboard/index.scss +29 -0
- package/dist/containers/Dashboard/messages.d.ts +13 -0
- package/dist/containers/Dashboard/messages.js +15 -0
- package/dist/containers/Dashboard/messages.js.map +1 -0
- package/dist/containers/EmailSettingsModal/hooks.d.ts +10 -0
- package/dist/containers/EmailSettingsModal/hooks.js +27 -0
- package/dist/containers/EmailSettingsModal/hooks.js.map +1 -0
- package/dist/containers/EmailSettingsModal/index.d.ts +14 -0
- package/dist/containers/EmailSettingsModal/index.js +20 -0
- package/dist/containers/EmailSettingsModal/index.js.map +1 -0
- package/dist/containers/EmailSettingsModal/messages.d.ts +49 -0
- package/dist/containers/EmailSettingsModal/messages.js +35 -0
- package/dist/containers/EmailSettingsModal/messages.js.map +1 -0
- package/dist/containers/ProductCard/index.d.ts +4 -0
- package/dist/containers/ProductCard/index.js +8 -0
- package/dist/containers/ProductCard/index.js.map +1 -0
- package/dist/containers/ProductCard/index.scss +6 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgress.d.ts +4 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgress.js +54 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgress.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressHeader.d.ts +4 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressHeader.js +13 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressHeader.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressInfo.d.ts +4 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressInfo.js +12 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressInfo.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressProvider.d.ts +10 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressProvider.js +30 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/ProgramProgressProvider.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/UpgradeAllButton.d.ts +4 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/UpgradeAllButton.js +29 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/UpgradeAllButton.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/index.d.ts +2 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/index.js +3 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/index.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/index.scss +7 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/messages.d.ts +8 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/messages.js +10 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/UpgradeButton/messages.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/index.d.ts +2 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/index.js +6 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/index.js.map +1 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/index.scss +20 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/messages.d.ts +33 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/messages.js +35 -0
- package/dist/containers/ProgramDashboard/ProgramProgress/messages.js.map +1 -0
- package/dist/containers/ProgramDashboard/assets/micromasters-icon.svg +17 -0
- package/dist/containers/ProgramDashboard/assets/professional-certificate-program-details.svg +1 -0
- package/dist/containers/ProgramDashboard/assets/rwth-aachen-university.svg +47 -0
- package/dist/containers/ProgramDashboard/assets/xseries-program-details.svg +1 -0
- package/dist/containers/ProgramDashboard/data/api.d.ts +1 -0
- package/dist/containers/ProgramDashboard/data/api.js +18 -0
- package/dist/containers/ProgramDashboard/data/api.js.map +1 -0
- package/dist/containers/ProgramDashboard/data/constants.d.ts +8 -0
- package/dist/containers/ProgramDashboard/data/constants.js +9 -0
- package/dist/containers/ProgramDashboard/data/constants.js.map +1 -0
- package/dist/containers/ProgramDashboard/data/util.d.ts +1 -0
- package/dist/containers/ProgramDashboard/data/util.js +17 -0
- package/dist/containers/ProgramDashboard/data/util.js.map +1 -0
- package/dist/containers/ProgramDashboard/index.d.ts +2 -0
- package/dist/containers/ProgramDashboard/index.js +3 -0
- package/dist/containers/ProgramDashboard/index.js.map +1 -0
- package/dist/containers/RecommendedCourse/index.d.ts +3 -0
- package/dist/containers/RecommendedCourse/index.js +16 -0
- package/dist/containers/RecommendedCourse/index.js.map +1 -0
- package/dist/containers/RecommendedCourse/index.scss +21 -0
- package/dist/containers/RecommendedCourse/messages.d.ts +8 -0
- package/dist/containers/RecommendedCourse/messages.js +10 -0
- package/dist/containers/RecommendedCourse/messages.js.map +1 -0
- package/dist/containers/RelatedProgramsModal/components/ProgramCard.d.ts +19 -0
- package/dist/containers/RelatedProgramsModal/components/ProgramCard.js +29 -0
- package/dist/containers/RelatedProgramsModal/components/ProgramCard.js.map +1 -0
- package/dist/containers/RelatedProgramsModal/components/index.scss +23 -0
- package/dist/containers/RelatedProgramsModal/components/messages.d.ts +32 -0
- package/dist/containers/RelatedProgramsModal/components/messages.js +24 -0
- package/dist/containers/RelatedProgramsModal/components/messages.js.map +1 -0
- package/dist/containers/RelatedProgramsModal/index.d.ts +14 -0
- package/dist/containers/RelatedProgramsModal/index.js +25 -0
- package/dist/containers/RelatedProgramsModal/index.js.map +1 -0
- package/dist/containers/RelatedProgramsModal/index.scss +5 -0
- package/dist/containers/RelatedProgramsModal/messages.d.ts +17 -0
- package/dist/containers/RelatedProgramsModal/messages.js +15 -0
- package/dist/containers/RelatedProgramsModal/messages.js.map +1 -0
- package/dist/containers/SelectSessionModal/constants.d.ts +1 -0
- package/dist/containers/SelectSessionModal/constants.js +2 -0
- package/dist/containers/SelectSessionModal/constants.js.map +1 -0
- package/dist/containers/SelectSessionModal/hooks.d.ts +17 -0
- package/dist/containers/SelectSessionModal/hooks.js +76 -0
- package/dist/containers/SelectSessionModal/hooks.js.map +1 -0
- package/dist/containers/SelectSessionModal/index.d.ts +2 -0
- package/dist/containers/SelectSessionModal/index.js +17 -0
- package/dist/containers/SelectSessionModal/index.js.map +1 -0
- package/dist/containers/SelectSessionModal/messages.d.ts +56 -0
- package/dist/containers/SelectSessionModal/messages.js +40 -0
- package/dist/containers/SelectSessionModal/messages.js.map +1 -0
- package/dist/containers/SubscriptionBanner/components/SubscriptionBanner.d.ts +2 -0
- package/dist/containers/SubscriptionBanner/components/SubscriptionBanner.js +72 -0
- package/dist/containers/SubscriptionBanner/components/SubscriptionBanner.js.map +1 -0
- package/dist/containers/SubscriptionBanner/index.d.ts +1 -0
- package/dist/containers/SubscriptionBanner/index.js +2 -0
- package/dist/containers/SubscriptionBanner/index.js.map +1 -0
- package/dist/containers/SubscriptionBanner/messages.d.ts +38 -0
- package/dist/containers/SubscriptionBanner/messages.js +40 -0
- package/dist/containers/SubscriptionBanner/messages.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.d.ts +14 -0
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js +22 -0
- package/dist/containers/UnenrollConfirmModal/components/ConfirmPane.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.d.ts +12 -0
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js +21 -0
- package/dist/containers/UnenrollConfirmModal/components/FinishedPane.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.d.ts +22 -0
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js +28 -0
- package/dist/containers/UnenrollConfirmModal/components/ReasonPane.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/components/messages.d.ts +80 -0
- package/dist/containers/UnenrollConfirmModal/components/messages.js +55 -0
- package/dist/containers/UnenrollConfirmModal/components/messages.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/constants.d.ts +65 -0
- package/dist/containers/UnenrollConfirmModal/constants.js +89 -0
- package/dist/containers/UnenrollConfirmModal/constants.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/hooks/index.d.ts +25 -0
- package/dist/containers/UnenrollConfirmModal/hooks/index.js +53 -0
- package/dist/containers/UnenrollConfirmModal/hooks/index.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.d.ts +15 -0
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.js +53 -0
- package/dist/containers/UnenrollConfirmModal/hooks/reasons.js.map +1 -0
- package/dist/containers/UnenrollConfirmModal/index.d.ts +14 -0
- package/dist/containers/UnenrollConfirmModal/index.js +22 -0
- package/dist/containers/UnenrollConfirmModal/index.js.map +1 -0
- package/dist/data/constants/app.d.ts +5 -0
- package/dist/data/constants/app.js +17 -0
- package/dist/data/constants/app.js.map +1 -0
- package/dist/data/constants/course.d.ts +11 -0
- package/dist/data/constants/course.js +17 -0
- package/dist/data/constants/course.js.map +1 -0
- package/dist/data/constants/credit.d.ts +5 -0
- package/dist/data/constants/credit.js +8 -0
- package/dist/data/constants/credit.js.map +1 -0
- package/dist/data/constants/files.d.ts +4 -0
- package/dist/data/constants/files.js +18 -0
- package/dist/data/constants/files.js.map +1 -0
- package/dist/data/constants/htmlKeys.d.ts +7 -0
- package/dist/data/constants/htmlKeys.js +19 -0
- package/dist/data/constants/htmlKeys.js.map +1 -0
- package/dist/data/constants/requests.d.ts +4 -0
- package/dist/data/constants/requests.js +31 -0
- package/dist/data/constants/requests.js.map +1 -0
- 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 +16 -0
- package/dist/data/contexts/GlobalDataContext.js +14 -0
- package/dist/data/contexts/GlobalDataContext.js.map +1 -0
- package/dist/data/contexts/GlobalDataProvider.d.ts +3 -0
- package/dist/data/contexts/GlobalDataProvider.js +15 -0
- package/dist/data/contexts/GlobalDataProvider.js.map +1 -0
- 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 +32 -0
- package/dist/data/services/lms/api.js +80 -0
- package/dist/data/services/lms/api.js.map +1 -0
- package/dist/data/services/lms/constants.d.ts +8 -0
- package/dist/data/services/lms/constants.js +16 -0
- package/dist/data/services/lms/constants.js.map +1 -0
- package/dist/data/services/lms/index.d.ts +2 -0
- package/dist/data/services/lms/index.js +8 -0
- package/dist/data/services/lms/index.js.map +1 -0
- package/dist/data/services/lms/urls.d.ts +8 -0
- package/dist/data/services/lms/urls.js +37 -0
- package/dist/data/services/lms/urls.js.map +1 -0
- package/dist/data/services/lms/utils.d.ts +6 -0
- package/dist/data/services/lms/utils.js +56 -0
- package/dist/data/services/lms/utils.js.map +1 -0
- package/dist/data/services/segment/utils.d.ts +3 -0
- package/dist/data/services/segment/utils.js +12 -0
- package/dist/data/services/segment/utils.js.map +1 -0
- package/dist/data/services/subs/api.d.ts +10 -0
- package/dist/data/services/subs/api.js +66 -0
- package/dist/data/services/subs/api.js.map +1 -0
- package/dist/data/services/subs/index.d.ts +1 -0
- package/dist/data/services/subs/index.js +2 -0
- package/dist/data/services/subs/index.js.map +1 -0
- package/dist/hooks/index.d.ts +7 -0
- package/dist/hooks/index.js +11 -0
- package/dist/hooks/index.js.map +1 -0
- 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/hooks/useRecommendedCourseData.d.ts +15 -0
- package/dist/hooks/useRecommendedCourseData.js +6 -0
- package/dist/hooks/useRecommendedCourseData.js.map +1 -0
- package/dist/hooks/utils.d.ts +7 -0
- package/dist/hooks/utils.js +14 -0
- package/dist/hooks/utils.js.map +1 -0
- package/dist/i18n/index.d.ts +25 -0
- package/dist/i18n/index.js +26 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/messages.d.ts +13 -0
- package/dist/messages.js +15 -0
- package/dist/messages.js.map +1 -0
- package/dist/providers.d.ts +3 -0
- package/dist/providers.js +8 -0
- package/dist/providers.js.map +1 -0
- package/dist/routes.d.ts +13 -0
- package/dist/routes.js +42 -0
- package/dist/routes.js.map +1 -0
- package/dist/segment.d.ts +1 -0
- package/dist/segment.js +74 -0
- package/dist/segment.js.map +1 -0
- package/dist/slots/CourseBannerSlot/index.d.ts +10 -0
- package/dist/slots/CourseBannerSlot/index.js +10 -0
- package/dist/slots/CourseBannerSlot/index.js.map +1 -0
- package/dist/slots/CourseCardActionSlot/index.d.ts +10 -0
- package/dist/slots/CourseCardActionSlot/index.js +9 -0
- package/dist/slots/CourseCardActionSlot/index.js.map +1 -0
- package/dist/slots/CourseListSlot/index.d.ts +10 -0
- package/dist/slots/CourseListSlot/index.js +9 -0
- package/dist/slots/CourseListSlot/index.js.map +1 -0
- package/dist/slots/DashboardModalSlot/index.d.ts +2 -0
- package/dist/slots/DashboardModalSlot/index.js +5 -0
- package/dist/slots/DashboardModalSlot/index.js.map +1 -0
- package/dist/slots/NoCoursesViewSlot/index.d.ts +2 -0
- package/dist/slots/NoCoursesViewSlot/index.js +6 -0
- package/dist/slots/NoCoursesViewSlot/index.js.map +1 -0
- package/dist/slots/WidgetSidebarSlot/index.d.ts +2 -0
- package/dist/slots/WidgetSidebarSlot/index.js +6 -0
- package/dist/slots/WidgetSidebarSlot/index.js.map +1 -0
- package/dist/slots.d.ts +3 -0
- package/dist/slots.js +6 -0
- package/dist/slots.js.map +1 -0
- package/dist/style.scss +36 -0
- package/dist/testUtils.d.ts +86 -0
- package/dist/testUtils.js +183 -0
- package/dist/testUtils.js.map +1 -0
- package/dist/tracking/constants.d.ts +6 -0
- package/dist/tracking/constants.js +45 -0
- package/dist/tracking/constants.js.map +1 -0
- package/dist/tracking/index.d.ts +17 -0
- package/dist/tracking/index.js +17 -0
- package/dist/tracking/index.js.map +1 -0
- package/dist/tracking/trackers/course.d.ts +13 -0
- package/dist/tracking/trackers/course.js +31 -0
- package/dist/tracking/trackers/course.js.map +1 -0
- package/dist/tracking/trackers/credit.d.ts +5 -0
- package/dist/tracking/trackers/credit.js +16 -0
- package/dist/tracking/trackers/credit.js.map +1 -0
- package/dist/tracking/trackers/engagement.d.ts +9 -0
- package/dist/tracking/trackers/engagement.js +18 -0
- package/dist/tracking/trackers/engagement.js.map +1 -0
- package/dist/tracking/trackers/entitlements.d.ts +9 -0
- package/dist/tracking/trackers/entitlements.js +27 -0
- package/dist/tracking/trackers/entitlements.js.map +1 -0
- package/dist/tracking/trackers/filter.d.ts +7 -0
- package/dist/tracking/trackers/filter.js +13 -0
- package/dist/tracking/trackers/filter.js.map +1 -0
- package/dist/tracking/trackers/findCourses.d.ts +5 -0
- package/dist/tracking/trackers/findCourses.js +7 -0
- package/dist/tracking/trackers/findCourses.js.map +1 -0
- package/dist/tracking/trackers/socialShare.d.ts +2 -0
- package/dist/tracking/trackers/socialShare.js +10 -0
- package/dist/tracking/trackers/socialShare.js.map +1 -0
- package/dist/utils/StrictDict.d.ts +2 -0
- package/dist/utils/StrictDict.js +15 -0
- package/dist/utils/StrictDict.js.map +1 -0
- 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/utils/dateFormatter.d.ts +2 -0
- package/dist/utils/dateFormatter.js +8 -0
- package/dist/utils/dateFormatter.js.map +1 -0
- package/dist/utils/hooks.d.ts +5 -0
- package/dist/utils/hooks.js +10 -0
- package/dist/utils/hooks.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.js +5 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/keyStore.d.ts +2 -0
- package/dist/utils/keyStore.js +4 -0
- package/dist/utils/keyStore.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/ConfirmEmailBanner.scss +3 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/assets/confirm-email.svg +76 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.d.ts +10 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js +34 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/hooks.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/index.d.ts +2 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/index.js +19 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/index.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/messages.d.ts +48 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/messages.js +35 -0
- package/dist/widgets/LearnerDashboardHeader/ConfirmEmailBanner/messages.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/CoursesLink.d.ts +1 -0
- package/dist/widgets/LearnerDashboardHeader/CoursesLink.js +8 -0
- package/dist/widgets/LearnerDashboardHeader/CoursesLink.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/DiscoverLinkMenuItem.d.ts +3 -0
- package/dist/widgets/LearnerDashboardHeader/DiscoverLinkMenuItem.js +17 -0
- package/dist/widgets/LearnerDashboardHeader/DiscoverLinkMenuItem.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.d.ts +22 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js +44 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/hooks.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.d.ts +2 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js +20 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/index.scss +38 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/messages.d.ts +48 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/messages.js +35 -0
- package/dist/widgets/LearnerDashboardHeader/MasqueradeBar/messages.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/OrderHistoryLinkMenuItem.d.ts +3 -0
- package/dist/widgets/LearnerDashboardHeader/OrderHistoryLinkMenuItem.js +15 -0
- package/dist/widgets/LearnerDashboardHeader/OrderHistoryLinkMenuItem.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/ProgramsLinkMenuItem.d.ts +3 -0
- package/dist/widgets/LearnerDashboardHeader/ProgramsLinkMenuItem.js +13 -0
- package/dist/widgets/LearnerDashboardHeader/ProgramsLinkMenuItem.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/SupportLinkMenuItem.d.ts +3 -0
- package/dist/widgets/LearnerDashboardHeader/SupportLinkMenuItem.js +15 -0
- package/dist/widgets/LearnerDashboardHeader/SupportLinkMenuItem.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/app.d.ts +3 -0
- package/dist/widgets/LearnerDashboardHeader/app.js +69 -0
- package/dist/widgets/LearnerDashboardHeader/app.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/hooks.d.ts +9 -0
- package/dist/widgets/LearnerDashboardHeader/hooks.js +15 -0
- package/dist/widgets/LearnerDashboardHeader/hooks.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/index.d.ts +1 -0
- package/dist/widgets/LearnerDashboardHeader/index.js +2 -0
- package/dist/widgets/LearnerDashboardHeader/index.js.map +1 -0
- package/dist/widgets/LearnerDashboardHeader/messages.d.ts +136 -0
- package/dist/widgets/LearnerDashboardHeader/messages.js +90 -0
- package/dist/widgets/LearnerDashboardHeader/messages.js.map +1 -0
- package/dist/widgets/LookingForChallengeWidget/index.d.ts +6 -0
- package/dist/widgets/LookingForChallengeWidget/index.js +22 -0
- package/dist/widgets/LookingForChallengeWidget/index.js.map +1 -0
- package/dist/widgets/LookingForChallengeWidget/index.scss +6 -0
- package/dist/widgets/LookingForChallengeWidget/messages.d.ts +16 -0
- package/dist/widgets/LookingForChallengeWidget/messages.js +15 -0
- package/dist/widgets/LookingForChallengeWidget/messages.js.map +1 -0
- package/dist/widgets/LookingForChallengeWidget/track.d.ts +7 -0
- package/dist/widgets/LookingForChallengeWidget/track.js +13 -0
- package/dist/widgets/LookingForChallengeWidget/track.js.map +1 -0
- package/package.json +84 -0
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function CourseCardTitle({ cardId }: {
|
|
2
|
+
cardId: any;
|
|
3
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export namespace CourseCardTitle {
|
|
5
|
+
namespace propTypes {
|
|
6
|
+
let cardId: PropTypes.Validator<string>;
|
|
7
|
+
}
|
|
8
|
+
let defaultProps: {};
|
|
9
|
+
}
|
|
10
|
+
export default CourseCardTitle;
|
|
11
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import PropTypes from 'prop-types';
|
|
4
|
+
import track from '../../../tracking';
|
|
5
|
+
import { useCourseData, useCourseTrackingEvent } from '../../../hooks';
|
|
6
|
+
import useActionDisabledState from './hooks';
|
|
7
|
+
const { courseTitleClicked } = track.course;
|
|
8
|
+
export const CourseCardTitle = ({ cardId }) => {
|
|
9
|
+
var _a, _b;
|
|
10
|
+
const courseData = useCourseData(cardId);
|
|
11
|
+
const courseName = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.course) === null || _a === void 0 ? void 0 : _a.courseName;
|
|
12
|
+
const homeUrl = (_b = courseData === null || courseData === void 0 ? void 0 : courseData.courseRun) === null || _b === void 0 ? void 0 : _b.homeUrl;
|
|
13
|
+
const handleTitleClicked = useCourseTrackingEvent(courseTitleClicked, cardId, homeUrl);
|
|
14
|
+
const { disableCourseTitle } = useActionDisabledState(cardId);
|
|
15
|
+
return (_jsx("h3", { children: disableCourseTitle ? (_jsx("span", { className: "course-card-title", "data-testid": "CourseCardTitle", children: courseName })) : (_jsx("a", { href: homeUrl, className: "course-card-title", "data-testid": "CourseCardTitle", onClick: handleTitleClicked, children: courseName })) }));
|
|
16
|
+
};
|
|
17
|
+
CourseCardTitle.propTypes = {
|
|
18
|
+
cardId: PropTypes.string.isRequired,
|
|
19
|
+
};
|
|
20
|
+
CourseCardTitle.defaultProps = {};
|
|
21
|
+
export default CourseCardTitle;
|
|
22
|
+
//# sourceMappingURL=CourseCardTitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CourseCardTitle.js","sourceRoot":"","sources":["../../../../src/containers/CourseCard/components/CourseCardTitle.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,KAAK,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC;AACnE,OAAO,sBAAsB,MAAM,SAAS,CAAC;AAE7C,MAAM,EAAE,kBAAkB,EAAE,GAAG,KAAK,CAAC,MAAM,CAAC;AAE5C,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IAC5C,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,UAAU,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,0CAAE,UAAU,CAAC;IAClD,MAAM,OAAO,GAAG,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,SAAS,0CAAE,OAAO,CAAC;IAC/C,MAAM,kBAAkB,GAAG,sBAAsB,CAC/C,kBAAkB,EAClB,MAAM,EACN,OAAO,CACR,CAAC;IACF,MAAM,EAAE,kBAAkB,EAAE,GAAG,sBAAsB,CAAC,MAAM,CAAC,CAAC;IAC9D,OAAO,CACL,uBACG,kBAAkB,CAAC,CAAC,CAAC,CACpB,eAAM,SAAS,EAAC,mBAAmB,iBAAa,iBAAiB,YAAE,UAAU,GAAQ,CACtF,CAAC,CAAC,CAAC,CACF,YACE,IAAI,EAAE,OAAO,EACb,SAAS,EAAC,mBAAmB,iBACjB,iBAAiB,EAC7B,OAAO,EAAE,kBAAkB,YAE1B,UAAU,GACT,CACL,GACE,CACN,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,CAAC,SAAS,GAAG;IAC1B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,CAAC,YAAY,GAAG,EAAE,CAAC;AAElC,eAAe,eAAe,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\n\nimport track from '@src/tracking';\nimport { useCourseData, useCourseTrackingEvent } from '@src/hooks';\nimport useActionDisabledState from './hooks';\n\nconst { courseTitleClicked } = track.course;\n\nexport const CourseCardTitle = ({ cardId }) => {\n const courseData = useCourseData(cardId);\n const courseName = courseData?.course?.courseName;\n const homeUrl = courseData?.courseRun?.homeUrl;\n const handleTitleClicked = useCourseTrackingEvent(\n courseTitleClicked,\n cardId,\n homeUrl,\n );\n const { disableCourseTitle } = useActionDisabledState(cardId);\n return (\n <h3>\n {disableCourseTitle ? (\n <span className=\"course-card-title\" data-testid=\"CourseCardTitle\">{courseName}</span>\n ) : (\n <a\n href={homeUrl}\n className=\"course-card-title\"\n data-testid=\"CourseCardTitle\"\n onClick={handleTitleClicked}\n >\n {courseName}\n </a>\n )}\n </h3>\n );\n};\n\nCourseCardTitle.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nCourseCardTitle.defaultProps = {};\n\nexport default CourseCardTitle;\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export const state: any;
|
|
2
|
+
export function useRelatedProgramsBadgeData({ cardId }: {
|
|
3
|
+
cardId: any;
|
|
4
|
+
}): {
|
|
5
|
+
numPrograms: any;
|
|
6
|
+
programsMessage: string;
|
|
7
|
+
isOpen: any;
|
|
8
|
+
openModal: () => any;
|
|
9
|
+
closeModal: () => any;
|
|
10
|
+
};
|
|
11
|
+
export default module.useRelatedProgramsBadgeData;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
3
|
+
import { StrictDict } from '../../../../utils';
|
|
4
|
+
import { useCourseData } from '../../../../hooks';
|
|
5
|
+
import messages from './messages';
|
|
6
|
+
import * as module from './hooks';
|
|
7
|
+
export const state = StrictDict({
|
|
8
|
+
isOpen: (val) => React.useState(val), // eslint-disable-line
|
|
9
|
+
});
|
|
10
|
+
export const useRelatedProgramsBadgeData = ({ cardId }) => {
|
|
11
|
+
var _a, _b;
|
|
12
|
+
const [isOpen, setIsOpen] = module.state.isOpen(false);
|
|
13
|
+
const { formatMessage } = useIntl();
|
|
14
|
+
const courseData = useCourseData(cardId);
|
|
15
|
+
const numPrograms = ((_b = (_a = courseData === null || courseData === void 0 ? void 0 : courseData.programs) === null || _a === void 0 ? void 0 : _a.relatedPrograms) === null || _b === void 0 ? void 0 : _b.length) || 0;
|
|
16
|
+
let programsMessage = '';
|
|
17
|
+
if (numPrograms) {
|
|
18
|
+
programsMessage = formatMessage(numPrograms === 1 ? messages.badgeLabelSingular : messages.badgeLabelPlural, { numPrograms });
|
|
19
|
+
}
|
|
20
|
+
return {
|
|
21
|
+
numPrograms,
|
|
22
|
+
programsMessage,
|
|
23
|
+
isOpen,
|
|
24
|
+
openModal: () => setIsOpen(true),
|
|
25
|
+
closeModal: () => setIsOpen(false),
|
|
26
|
+
};
|
|
27
|
+
};
|
|
28
|
+
export default useRelatedProgramsBadgeData;
|
|
29
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/RelatedProgramsBadge/hooks.jsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE3C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,KAAK,MAAM,MAAM,SAAS,CAAC;AAElC,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAC;IAC9B,MAAM,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,sBAAsB;CAC7D,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;;IACxD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACvD,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,WAAW,GAAG,CAAA,MAAA,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,QAAQ,0CAAE,eAAe,0CAAE,MAAM,KAAI,CAAC,CAAC;IACvE,IAAI,eAAe,GAAG,EAAE,CAAC;IACzB,IAAI,WAAW,EAAE,CAAC;QAChB,eAAe,GAAG,aAAa,CAC7B,WAAW,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC,QAAQ,CAAC,gBAAgB,EAC3E,EAAE,WAAW,EAAE,CAChB,CAAC;IACJ,CAAC;IAED,OAAO;QACL,WAAW;QACX,eAAe;QACf,MAAM;QACN,SAAS,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC;QAChC,UAAU,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC;KACnC,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,2BAA2B,CAAC","sourcesContent":["import React from 'react';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { StrictDict } from '@src/utils';\nimport { useCourseData } from '@src/hooks';\n\nimport messages from './messages';\nimport * as module from './hooks';\n\nexport const state = StrictDict({\n isOpen: (val) => React.useState(val), // eslint-disable-line\n});\n\nexport const useRelatedProgramsBadgeData = ({ cardId }) => {\n const [isOpen, setIsOpen] = module.state.isOpen(false);\n const { formatMessage } = useIntl();\n const courseData = useCourseData(cardId);\n const numPrograms = courseData?.programs?.relatedPrograms?.length || 0;\n let programsMessage = '';\n if (numPrograms) {\n programsMessage = formatMessage(\n numPrograms === 1 ? messages.badgeLabelSingular : messages.badgeLabelPlural,\n { numPrograms },\n );\n }\n\n return {\n numPrograms,\n programsMessage,\n isOpen,\n openModal: () => setIsOpen(true),\n closeModal: () => setIsOpen(false),\n };\n};\n\nexport default useRelatedProgramsBadgeData;\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export function RelatedProgramsBadge({ cardId }: {
|
|
2
|
+
cardId: any;
|
|
3
|
+
}): import("react/jsx-runtime").JSX.Element | null;
|
|
4
|
+
export namespace RelatedProgramsBadge {
|
|
5
|
+
namespace propTypes {
|
|
6
|
+
let cardId: PropTypes.Validator<string>;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export default RelatedProgramsBadge;
|
|
10
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/* eslint-disable quotes */
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import PropTypes from 'prop-types';
|
|
5
|
+
import { Button, Icon } from '@openedx/paragon';
|
|
6
|
+
import { Program } from '@openedx/paragon/icons';
|
|
7
|
+
import RelatedProgramsBadgeModal from '../../../../containers/RelatedProgramsModal';
|
|
8
|
+
import useRelatedProgramsBadgeData from './hooks';
|
|
9
|
+
export const RelatedProgramsBadge = ({ cardId }) => {
|
|
10
|
+
const { isOpen, openModal, closeModal, numPrograms, programsMessage, } = useRelatedProgramsBadgeData({ cardId });
|
|
11
|
+
if (numPrograms === 0) {
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
return (_jsxs(_Fragment, { children: [_jsxs(Button, { "data-testid": "RelatedProgramsBadge", className: "pl-0 mr-0 justify-content-start align-self-start flex-shrink-1", variant: "tertiary", size: "sm", onClick: openModal, children: [_jsx(Icon, { src: Program, className: "mr-2 pr-0" }), " ", programsMessage] }), _jsx(RelatedProgramsBadgeModal, { isOpen, closeModal, cardId })] }));
|
|
15
|
+
};
|
|
16
|
+
RelatedProgramsBadge.propTypes = {
|
|
17
|
+
cardId: PropTypes.string.isRequired,
|
|
18
|
+
};
|
|
19
|
+
export default RelatedProgramsBadge;
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/RelatedProgramsBadge/index.jsx"],"names":[],"mappings":";AAAA,2BAA2B;AAC3B,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,yBAAyB,MAAM,sCAAsC,CAAC;AAC7E,OAAO,2BAA2B,MAAM,SAAS,CAAC;AAElD,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACjD,MAAM,EACJ,MAAM,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,GAC5D,GAAG,2BAA2B,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAE5C,IAAI,WAAW,KAAK,CAAC,EAAE,CAAC;QACtB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,CACL,8BACE,MAAC,MAAM,mBACO,sBAAsB,EAClC,SAAS,EAAC,gEAAgE,EAC1E,OAAO,EAAC,UAAU,EAClB,IAAI,EAAC,IAAI,EACT,OAAO,EAAE,SAAS,aAElB,KAAC,IAAI,IAAC,GAAG,EAAE,OAAO,EAAE,SAAS,EAAC,WAAW,GAAG,OAAE,eAAe,IACtD,EACT,KAAC,yBAAyB,IAAO,MAAM,EAAE,UAAU,EAAE,MAAM,GAAM,IAChE,CACJ,CAAC;AACJ,CAAC,CAAC;AACF,oBAAoB,CAAC,SAAS,GAAG;IAC/B,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,oBAAoB,CAAC","sourcesContent":["/* eslint-disable quotes */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport { Button, Icon } from '@openedx/paragon';\nimport { Program } from '@openedx/paragon/icons';\n\nimport RelatedProgramsBadgeModal from '@src/containers/RelatedProgramsModal';\nimport useRelatedProgramsBadgeData from './hooks';\n\nexport const RelatedProgramsBadge = ({ cardId }) => {\n const {\n isOpen, openModal, closeModal, numPrograms, programsMessage,\n } = useRelatedProgramsBadgeData({ cardId });\n\n if (numPrograms === 0) {\n return null;\n }\n\n return (\n <>\n <Button\n data-testid=\"RelatedProgramsBadge\"\n className=\"pl-0 mr-0 justify-content-start align-self-start flex-shrink-1\"\n variant=\"tertiary\"\n size=\"sm\"\n onClick={openModal}\n >\n <Icon src={Program} className=\"mr-2 pr-0\" /> {programsMessage}\n </Button>\n <RelatedProgramsBadgeModal {...{ isOpen, closeModal, cardId }} />\n </>\n );\n};\nRelatedProgramsBadge.propTypes = {\n cardId: PropTypes.string.isRequired,\n};\n\nexport default RelatedProgramsBadge;\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export namespace messages {
|
|
2
|
+
namespace badgeLabelPlural {
|
|
3
|
+
let id: string;
|
|
4
|
+
let description: string;
|
|
5
|
+
let defaultMessage: string;
|
|
6
|
+
}
|
|
7
|
+
namespace badgeLabelSingular {
|
|
8
|
+
let id_1: string;
|
|
9
|
+
export { id_1 as id };
|
|
10
|
+
let description_1: string;
|
|
11
|
+
export { description_1 as description };
|
|
12
|
+
let defaultMessage_1: string;
|
|
13
|
+
export { defaultMessage_1 as defaultMessage };
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export default messages;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export const messages = {
|
|
2
|
+
badgeLabelPlural: {
|
|
3
|
+
id: 'learner-dash.courseCard.relatedProgramsBadge.label.plural',
|
|
4
|
+
description: 'Label test indicating number of related programs for a course card',
|
|
5
|
+
defaultMessage: '{numPrograms} Related Programs',
|
|
6
|
+
},
|
|
7
|
+
badgeLabelSingular: {
|
|
8
|
+
id: 'learner-dash.courseCard.relatedProgramsBadge.label.singular',
|
|
9
|
+
description: 'Label test indicating a single related program for a course card',
|
|
10
|
+
defaultMessage: '{numPrograms} Related Program',
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
export default messages;
|
|
14
|
+
//# sourceMappingURL=messages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../../../src/containers/CourseCard/components/RelatedProgramsBadge/messages.js"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,gBAAgB,EAAE;QAChB,EAAE,EAAE,2DAA2D;QAC/D,WAAW,EAAE,oEAAoE;QACjF,cAAc,EAAE,gCAAgC;KACjD;IACD,kBAAkB,EAAE;QAClB,EAAE,EAAE,6DAA6D;QACjE,WAAW,EAAE,kEAAkE;QAC/E,cAAc,EAAE,+BAA+B;KAChD;CACF,CAAC;AACF,eAAe,QAAQ,CAAC","sourcesContent":["export const messages = {\n badgeLabelPlural: {\n id: 'learner-dash.courseCard.relatedProgramsBadge.label.plural',\n description: 'Label test indicating number of related programs for a course card',\n defaultMessage: '{numPrograms} Related Programs',\n },\n badgeLabelSingular: {\n id: 'learner-dash.courseCard.relatedProgramsBadge.label.singular',\n description: 'Label test indicating a single related program for a course card',\n defaultMessage: '{numPrograms} Related Program',\n },\n};\nexport default messages;\n"]}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { useCourseData, useEntitlementInfo, useIsMasquerading } from '../../../hooks';
|
|
2
|
+
export const useActionDisabledState = (cardId) => {
|
|
3
|
+
var _a;
|
|
4
|
+
const courseData = useCourseData(cardId);
|
|
5
|
+
const isMasquerading = useIsMasquerading();
|
|
6
|
+
const { isAudit, isAuditAccessExpired, } = courseData.enrollment || {};
|
|
7
|
+
const { isStaff, hasUnmetPrereqs, isTooEarly } = ((_a = courseData.enrollment) === null || _a === void 0 ? void 0 : _a.coursewareAccess) || {};
|
|
8
|
+
const hasAccess = isStaff || !(hasUnmetPrereqs || isTooEarly);
|
|
9
|
+
const { isEntitlement, isFulfilled, canChange, hasSessions, } = useEntitlementInfo(courseData);
|
|
10
|
+
const { resumeUrl, homeUrl } = courseData.courseRun || {};
|
|
11
|
+
const disableBeginCourse = !homeUrl || (isMasquerading || !hasAccess || (isAudit && isAuditAccessExpired));
|
|
12
|
+
const disableResumeCourse = !resumeUrl || (isMasquerading || !hasAccess || (isAudit && isAuditAccessExpired));
|
|
13
|
+
const disableViewCourse = !hasAccess || (isAudit && isAuditAccessExpired);
|
|
14
|
+
const disableSelectSession = !isEntitlement || isMasquerading || !hasAccess || (!canChange || !hasSessions);
|
|
15
|
+
const disableCourseTitle = (isEntitlement && !isFulfilled) || disableViewCourse;
|
|
16
|
+
return {
|
|
17
|
+
disableBeginCourse,
|
|
18
|
+
disableResumeCourse,
|
|
19
|
+
disableViewCourse,
|
|
20
|
+
disableSelectSession,
|
|
21
|
+
disableCourseTitle,
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
export default useActionDisabledState;
|
|
25
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../../src/containers/CourseCard/components/hooks.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAElF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,MAAM,EAAE,EAAE;;IAC/C,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,cAAc,GAAG,iBAAiB,EAAE,CAAC;IAE3C,MAAM,EACJ,OAAO,EAAE,oBAAoB,GAC9B,GAAG,UAAU,CAAC,UAAU,IAAI,EAAE,CAAC;IAChC,MAAM,EAAE,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,GAAG,CAAA,MAAA,UAAU,CAAC,UAAU,0CAAE,gBAAgB,KAAI,EAAE,CAAC;IAC/F,MAAM,SAAS,GAAG,OAAO,IAAI,CAAC,CAAC,eAAe,IAAI,UAAU,CAAC,CAAC;IAC9D,MAAM,EACJ,aAAa,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,GACnD,GAAG,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAEnC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC,SAAS,IAAI,EAAE,CAAC;IAC1D,MAAM,kBAAkB,GAAG,CAAC,OAAO,IAAI,CAAC,cAAc,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,IAAI,oBAAoB,CAAC,CAAC,CAAC;IAC3G,MAAM,mBAAmB,GAAG,CAAC,SAAS,IAAI,CAAC,cAAc,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,IAAI,oBAAoB,CAAC,CAAC,CAAC;IAC9G,MAAM,iBAAiB,GAAG,CAAC,SAAS,IAAI,CAAC,OAAO,IAAI,oBAAoB,CAAC,CAAC;IAC1E,MAAM,oBAAoB,GAAG,CAAC,aAAa,IAAI,cAAc,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,SAAS,IAAI,CAAC,WAAW,CAAC,CAAC;IAE5G,MAAM,kBAAkB,GAAG,CAAC,aAAa,IAAI,CAAC,WAAW,CAAC,IAAI,iBAAiB,CAAC;IAEhF,OAAO;QACL,kBAAkB;QAClB,mBAAmB;QACnB,iBAAiB;QACjB,oBAAoB;QACpB,kBAAkB;KACnB,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,sBAAsB,CAAC","sourcesContent":["import { useCourseData, useEntitlementInfo, useIsMasquerading } from '@src/hooks';\n\nexport const useActionDisabledState = (cardId) => {\n const courseData = useCourseData(cardId);\n const isMasquerading = useIsMasquerading();\n\n const {\n isAudit, isAuditAccessExpired,\n } = courseData.enrollment || {};\n const { isStaff, hasUnmetPrereqs, isTooEarly } = courseData.enrollment?.coursewareAccess || {};\n const hasAccess = isStaff || !(hasUnmetPrereqs || isTooEarly);\n const {\n isEntitlement, isFulfilled, canChange, hasSessions,\n } = useEntitlementInfo(courseData);\n\n const { resumeUrl, homeUrl } = courseData.courseRun || {};\n const disableBeginCourse = !homeUrl || (isMasquerading || !hasAccess || (isAudit && isAuditAccessExpired));\n const disableResumeCourse = !resumeUrl || (isMasquerading || !hasAccess || (isAudit && isAuditAccessExpired));\n const disableViewCourse = !hasAccess || (isAudit && isAuditAccessExpired);\n const disableSelectSession = !isEntitlement || isMasquerading || !hasAccess || (!canChange || !hasSessions);\n\n const disableCourseTitle = (isEntitlement && !isFulfilled) || disableViewCourse;\n\n return {\n disableBeginCourse,\n disableResumeCourse,\n disableViewCourse,\n disableSelectSession,\n disableCourseTitle,\n };\n};\n\nexport default useActionDisabledState;\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export function useIsCollapsed(): boolean;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/containers/CourseCard/hooks.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE9D,MAAM,CAAC,MAAM,cAAc,GAAG,GAAG,EAAE;IACjC,MAAM,EAAE,KAAK,EAAE,GAAG,aAAa,EAAE,CAAC;IAClC,OAAO,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC;AAC5C,CAAC,CAAC","sourcesContent":["import { useWindowSize, breakpoints } from '@openedx/paragon';\n\nexport const useIsCollapsed = () => {\n const { width } = useWindowSize();\n return width < breakpoints.small.maxWidth;\n};\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function CourseCard({ cardId, verifiedCourse }: {
|
|
2
|
+
cardId: any;
|
|
3
|
+
verifiedCourse: any;
|
|
4
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
export namespace CourseCard {
|
|
6
|
+
namespace propTypes {
|
|
7
|
+
let cardId: PropTypes.Validator<string>;
|
|
8
|
+
let verifiedCourse: PropTypes.Requireable<boolean>;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export default CourseCard;
|
|
12
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import PropTypes from 'prop-types';
|
|
3
|
+
import { Card } from '@openedx/paragon';
|
|
4
|
+
import { useIsCollapsed } from './hooks';
|
|
5
|
+
import CourseCardMenu from './components/CourseCardMenu';
|
|
6
|
+
import CourseCardActions from './components/CourseCardActions';
|
|
7
|
+
import CourseCardDetails from './components/CourseCardDetails';
|
|
8
|
+
import CourseCardTitle from './components/CourseCardTitle';
|
|
9
|
+
import './CourseCard.scss';
|
|
10
|
+
import CourseCardBanners from './components/CourseCardBanners';
|
|
11
|
+
export const CourseCard = ({ cardId, verifiedCourse }) => {
|
|
12
|
+
const isCollapsed = useIsCollapsed();
|
|
13
|
+
const orientation = isCollapsed ? 'vertical' : 'horizontal';
|
|
14
|
+
return (_jsx("div", { className: "mb-4.5 course-card", id: cardId, "data-testid": "CourseCard", children: _jsx(Card, { orientation: orientation, children: _jsxs("div", { className: "d-flex flex-column w-100", children: [_jsx("div", Object.assign({}, (!isCollapsed && { className: 'd-flex' }), { children: _jsxs(Card.Body, { children: [_jsx(Card.Header, { title: _jsx(CourseCardTitle, { cardId: cardId }), actions: _jsx(CourseCardMenu, { cardId: cardId }) }), _jsxs(Card.Section, { className: "pt-0", children: [_jsx(CourseCardDetails, { cardId: cardId }), _jsx(CourseCardActions, { cardId: cardId, verifiedCourse: verifiedCourse })] })] }) })), _jsx(CourseCardBanners, { cardId: cardId, verifiedCourse: verifiedCourse })] }) }) }));
|
|
15
|
+
};
|
|
16
|
+
CourseCard.propTypes = {
|
|
17
|
+
cardId: PropTypes.string.isRequired,
|
|
18
|
+
verifiedCourse: PropTypes.bool,
|
|
19
|
+
};
|
|
20
|
+
export default CourseCard;
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/containers/CourseCard/index.jsx"],"names":[],"mappings":";AAAA,OAAO,SAAS,MAAM,YAAY,CAAC;AAEnC,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAExC,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,cAAc,MAAM,6BAA6B,CAAC;AACzD,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,eAAe,MAAM,8BAA8B,CAAC;AAE3D,OAAO,mBAAmB,CAAC;AAC3B,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAE/D,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,MAAM,EACN,cAAc,EACf,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,WAAW,GAAG,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY,CAAC;IAC5D,OAAO,CACL,cAAK,SAAS,EAAC,oBAAoB,EAAC,EAAE,EAAE,MAAM,iBAAc,YAAY,YACtE,KAAC,IAAI,IAAC,WAAW,EAAE,WAAW,YAC5B,eAAK,SAAS,EAAC,0BAA0B,aACvC,8BAAS,CAAC,CAAC,WAAW,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC,cAChD,MAAC,IAAI,CAAC,IAAI,eACR,KAAC,IAAI,CAAC,MAAM,IACV,KAAK,EAAE,KAAC,eAAe,IAAC,MAAM,EAAE,MAAM,GAAI,EAC1C,OAAO,EAAE,KAAC,cAAc,IAAC,MAAM,EAAE,MAAM,GAAI,GAC3C,EACF,MAAC,IAAI,CAAC,OAAO,IAAC,SAAS,EAAC,MAAM,aAC5B,KAAC,iBAAiB,IAAC,MAAM,EAAE,MAAM,GAAI,EACrC,KAAC,iBAAiB,IAAC,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,cAAc,GAAI,IACxD,IACL,IACR,EACN,KAAC,iBAAiB,IAAC,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,cAAc,GAAI,IACjE,GACD,GACH,CACP,CAAC;AACJ,CAAC,CAAC;AACF,UAAU,CAAC,SAAS,GAAG;IACrB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;IACnC,cAAc,EAAE,SAAS,CAAC,IAAI;CAC/B,CAAC;AAEF,eAAe,UAAU,CAAC","sourcesContent":["import PropTypes from 'prop-types';\n\nimport { Card } from '@openedx/paragon';\n\nimport { useIsCollapsed } from './hooks';\nimport CourseCardMenu from './components/CourseCardMenu';\nimport CourseCardActions from './components/CourseCardActions';\nimport CourseCardDetails from './components/CourseCardDetails';\nimport CourseCardTitle from './components/CourseCardTitle';\n\nimport './CourseCard.scss';\nimport CourseCardBanners from './components/CourseCardBanners';\n\nexport const CourseCard = ({\n cardId,\n verifiedCourse\n}) => {\n const isCollapsed = useIsCollapsed();\n const orientation = isCollapsed ? 'vertical' : 'horizontal';\n return (\n <div className=\"mb-4.5 course-card\" id={cardId} data-testid=\"CourseCard\">\n <Card orientation={orientation}>\n <div className=\"d-flex flex-column w-100\">\n <div {...(!isCollapsed && { className: 'd-flex' })}>\n <Card.Body>\n <Card.Header\n title={<CourseCardTitle cardId={cardId} />}\n actions={<CourseCardMenu cardId={cardId} />}\n />\n <Card.Section className=\"pt-0\">\n <CourseCardDetails cardId={cardId} />\n <CourseCardActions cardId={cardId} verifiedCourse={verifiedCourse} />\n </Card.Section>\n </Card.Body>\n </div>\n <CourseCardBanners cardId={cardId} verifiedCourse={verifiedCourse} />\n </div>\n </Card>\n </div>\n );\n};\nCourseCard.propTypes = {\n cardId: PropTypes.string.isRequired,\n verifiedCourse: PropTypes.bool,\n};\n\nexport default CourseCard;\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
export default messages;
|
|
2
|
+
declare namespace messages {
|
|
3
|
+
namespace bannerAlt {
|
|
4
|
+
let id: string;
|
|
5
|
+
let description: string;
|
|
6
|
+
let defaultMessage: string;
|
|
7
|
+
}
|
|
8
|
+
namespace verifiedBanner {
|
|
9
|
+
let id_1: string;
|
|
10
|
+
export { id_1 as id };
|
|
11
|
+
let description_1: string;
|
|
12
|
+
export { description_1 as description };
|
|
13
|
+
let defaultMessage_1: string;
|
|
14
|
+
export { defaultMessage_1 as defaultMessage };
|
|
15
|
+
}
|
|
16
|
+
namespace verifiedHoverDescription {
|
|
17
|
+
let id_2: string;
|
|
18
|
+
export { id_2 as id };
|
|
19
|
+
let description_2: string;
|
|
20
|
+
export { description_2 as description };
|
|
21
|
+
let defaultMessage_2: string;
|
|
22
|
+
export { defaultMessage_2 as defaultMessage };
|
|
23
|
+
}
|
|
24
|
+
namespace verifiedBannerRibbonAlt {
|
|
25
|
+
let id_3: string;
|
|
26
|
+
export { id_3 as id };
|
|
27
|
+
let description_3: string;
|
|
28
|
+
export { description_3 as description };
|
|
29
|
+
let defaultMessage_3: string;
|
|
30
|
+
export { defaultMessage_3 as defaultMessage };
|
|
31
|
+
}
|
|
32
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { defineMessages } from '@openedx/frontend-base';
|
|
2
|
+
const messages = defineMessages({
|
|
3
|
+
bannerAlt: {
|
|
4
|
+
id: 'learner-dash.courseCard.bannerAlt',
|
|
5
|
+
description: 'Course card banner alt-text',
|
|
6
|
+
defaultMessage: 'Course thumbnail',
|
|
7
|
+
},
|
|
8
|
+
verifiedBanner: {
|
|
9
|
+
id: 'learner-dash.courseCard.verifiedBanner',
|
|
10
|
+
description: 'Course card verified banner',
|
|
11
|
+
defaultMessage: 'Verified',
|
|
12
|
+
},
|
|
13
|
+
verifiedHoverDescription: {
|
|
14
|
+
id: 'learner-dash.courseCard.verifiedHoverDescription',
|
|
15
|
+
description: 'Course card verified hover description',
|
|
16
|
+
defaultMessage: 'You\'re enrolled as a verified student',
|
|
17
|
+
},
|
|
18
|
+
verifiedBannerRibbonAlt: {
|
|
19
|
+
id: 'learner-dash.courseCard.verifiedBannerRibbonAlt',
|
|
20
|
+
description: 'Course card verified banner ribbon alt-text',
|
|
21
|
+
defaultMessage: 'ID Verified Ribbon/Badge',
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
export default messages;
|
|
25
|
+
//# sourceMappingURL=messages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../../src/containers/CourseCard/messages.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,MAAM,QAAQ,GAAG,cAAc,CAAC;IAC9B,SAAS,EAAE;QACT,EAAE,EAAE,mCAAmC;QACvC,WAAW,EAAE,6BAA6B;QAC1C,cAAc,EAAE,kBAAkB;KACnC;IACD,cAAc,EAAE;QACd,EAAE,EAAE,wCAAwC;QAC5C,WAAW,EAAE,6BAA6B;QAC1C,cAAc,EAAE,UAAU;KAC3B;IACD,wBAAwB,EAAE;QACxB,EAAE,EAAE,kDAAkD;QACtD,WAAW,EAAE,wCAAwC;QACrD,cAAc,EAAE,wCAAwC;KACzD;IACD,uBAAuB,EAAE;QACvB,EAAE,EAAE,iDAAiD;QACrD,WAAW,EAAE,6CAA6C;QAC1D,cAAc,EAAE,0BAA0B;KAC3C;CACF,CAAC,CAAC;AAEH,eAAe,QAAQ,CAAC","sourcesContent":["import { defineMessages } from '@openedx/frontend-base';\n\nconst messages = defineMessages({\n bannerAlt: {\n id: 'learner-dash.courseCard.bannerAlt',\n description: 'Course card banner alt-text',\n defaultMessage: 'Course thumbnail',\n },\n verifiedBanner: {\n id: 'learner-dash.courseCard.verifiedBanner',\n description: 'Course card verified banner',\n defaultMessage: 'Verified',\n },\n verifiedHoverDescription: {\n id: 'learner-dash.courseCard.verifiedHoverDescription',\n description: 'Course card verified hover description',\n defaultMessage: 'You\\'re enrolled as a verified student',\n },\n verifiedBannerRibbonAlt: {\n id: 'learner-dash.courseCard.verifiedBannerRibbonAlt',\n description: 'Course card verified banner ribbon alt-text',\n defaultMessage: 'ID Verified Ribbon/Badge',\n },\n});\n\nexport default messages;\n"]}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
4
|
+
import { Button, Chip } from '@openedx/paragon';
|
|
5
|
+
import { CloseSmall } from '@openedx/paragon/icons';
|
|
6
|
+
import { useFilters } from '../../data/context';
|
|
7
|
+
import messages from './messages';
|
|
8
|
+
import './index.scss';
|
|
9
|
+
export const ActiveCourseFilters = () => {
|
|
10
|
+
const { formatMessage } = useIntl();
|
|
11
|
+
const { filters, clearFilters, removeFilter } = useFilters();
|
|
12
|
+
return (_jsxs("div", { id: "course-list-active-filters", children: [filters.map(filter => (_jsx(Chip, { iconAfter: CloseSmall, onClick: () => removeFilter(filter), children: formatMessage(messages[filter]) }, filter))), _jsx(Button, { variant: "link", onClick: clearFilters, children: formatMessage(messages.clearAll) })] }));
|
|
13
|
+
};
|
|
14
|
+
export default ActiveCourseFilters;
|
|
15
|
+
//# sourceMappingURL=ActiveCourseFilters.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActiveCourseFilters.js","sourceRoot":"","sources":["../../../src/containers/CourseFilterControls/ActiveCourseFilters.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,MAAM,mBAAmB,GAAG,GAAG,EAAE;IACtC,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,UAAU,EAAE,CAAC;IAE7D,OAAO,CACL,eAAK,EAAE,EAAC,4BAA4B,aACjC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CACrB,KAAC,IAAI,IAEH,SAAS,EAAE,UAAU,EACrB,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,YAElC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAJ3B,MAAM,CAKN,CACR,CAAC,EACF,KAAC,MAAM,IAAC,OAAO,EAAC,MAAM,EAAC,OAAO,EAAE,YAAY,YACzC,aAAa,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAC1B,IACL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,mBAAmB,CAAC","sourcesContent":["import React from 'react';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { Button, Chip } from '@openedx/paragon';\nimport { CloseSmall } from '@openedx/paragon/icons';\nimport { useFilters } from '@src/data/context';\n\nimport messages from './messages';\nimport './index.scss';\n\nexport const ActiveCourseFilters = () => {\n const { formatMessage } = useIntl();\n const { filters, clearFilters, removeFilter } = useFilters();\n\n return (\n <div id=\"course-list-active-filters\">\n {filters.map(filter => (\n <Chip\n key={filter}\n iconAfter={CloseSmall}\n onClick={() => removeFilter(filter)}\n >\n {formatMessage(messages[filter])}\n </Chip>\n ))}\n <Button variant=\"link\" onClick={clearFilters}>\n {formatMessage(messages.clearAll)}\n </Button>\n </div>\n );\n};\n\nexport default ActiveCourseFilters;\n"]}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
4
|
+
import track from '../../tracking';
|
|
5
|
+
import { Button, Form, Icon, ModalPopup, Sheet, breakpoints, useWindowSize, ModalCloseButton, } from '@openedx/paragon';
|
|
6
|
+
import { Close, Tune } from '@openedx/paragon/icons';
|
|
7
|
+
import { useInitializeLearnerHome } from '../../data/hooks';
|
|
8
|
+
import { useFilters } from '../../data/context';
|
|
9
|
+
import FilterForm from './components/FilterForm';
|
|
10
|
+
import SortForm from './components/SortForm';
|
|
11
|
+
import messages from './messages';
|
|
12
|
+
import './index.scss';
|
|
13
|
+
export const CourseFilterControls = () => {
|
|
14
|
+
const [isOpen, setIsOpen] = React.useState(false);
|
|
15
|
+
const [targetRef, setTargetRef] = React.useState(null);
|
|
16
|
+
const { formatMessage } = useIntl();
|
|
17
|
+
const { data } = useInitializeLearnerHome();
|
|
18
|
+
const hasCourses = React.useMemo(() => { var _a; return ((_a = data === null || data === void 0 ? void 0 : data.courses) === null || _a === void 0 ? void 0 : _a.length) > 0; }, [data]);
|
|
19
|
+
const { filters, sortBy, setSortBy, addFilter, removeFilter, } = useFilters();
|
|
20
|
+
const openFiltersOptions = () => {
|
|
21
|
+
track.filter.filterClicked();
|
|
22
|
+
setIsOpen(true);
|
|
23
|
+
};
|
|
24
|
+
const closeFiltersOptions = () => {
|
|
25
|
+
track.filter.filterOptionSelected(filters);
|
|
26
|
+
setIsOpen(false);
|
|
27
|
+
};
|
|
28
|
+
const handleSortChange = (event) => {
|
|
29
|
+
setSortBy(event.target.value);
|
|
30
|
+
};
|
|
31
|
+
const handleFilterChange = ({ target: { checked, value } }) => {
|
|
32
|
+
const update = checked ? addFilter : removeFilter;
|
|
33
|
+
update(value);
|
|
34
|
+
};
|
|
35
|
+
const { width } = useWindowSize();
|
|
36
|
+
const isMobile = width < breakpoints.small.minWidth;
|
|
37
|
+
return (_jsxs("div", { id: "course-filter-controls", children: [_jsx(Button, { ref: setTargetRef, variant: "outline-primary", iconBefore: Tune, onClick: openFiltersOptions, disabled: !hasCourses, children: formatMessage(messages.refine) }), _jsx(Form, { children: isMobile
|
|
38
|
+
? (_jsxs(Sheet, { className: "w-75", position: "left", show: isOpen, onClose: closeFiltersOptions, children: [_jsx("div", { className: "p-1 mr-3", children: _jsx("b", { children: formatMessage(messages.refine) }) }), _jsx("hr", {}), _jsx("div", { className: "filter-form-row", children: _jsx(FilterForm, { filters, handleFilterChange }) }), _jsx("div", { className: "filter-form-row text-left m-1", children: _jsx(SortForm, { sortBy, handleSortChange }) }), _jsx("div", { className: "pgn__modal-close-container", children: _jsx(ModalCloseButton, { variant: "tertiary", onClick: closeFiltersOptions, children: _jsx(Icon, { src: Close }) }) })] })) : (_jsx(ModalPopup, { positionRef: targetRef, isOpen: isOpen, onClose: closeFiltersOptions, placement: "bottom-end", children: _jsxs("div", { id: "course-filter-controls-card", className: "bg-white p-3 rounded shadow d-flex flex-row", children: [_jsx("div", { className: "filter-form-col", children: _jsx(FilterForm, { filters, handleFilterChange }) }), _jsx("hr", { className: "h-100 bg-primary-200 mx-3 my-0" }), _jsx("div", { className: "filter-form-col text-left m-1", children: _jsx(SortForm, { sortBy, handleSortChange }) })] }) })) })] }));
|
|
39
|
+
};
|
|
40
|
+
export default CourseFilterControls;
|
|
41
|
+
//# sourceMappingURL=CourseFilterControls.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CourseFilterControls.js","sourceRoot":"","sources":["../../../src/containers/CourseFilterControls/CourseFilterControls.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,KAAK,MAAM,eAAe,CAAC;AAClC,OAAO,EACL,MAAM,EACN,IAAI,EACJ,IAAI,EACJ,UAAU,EACV,KAAK,EACL,WAAW,EACX,aAAa,EACb,gBAAgB,GACjB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,wBAAwB,CAAC;AAErD,OAAO,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAC/C,OAAO,UAAU,MAAM,yBAAyB,CAAC;AACjD,OAAO,QAAQ,MAAM,uBAAuB,CAAC;AAC7C,OAAO,QAAQ,MAAM,YAAY,CAAC;AAElC,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,MAAM,oBAAoB,GAAG,GAAG,EAAE;IACvC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,MAAM,EAAE,IAAI,EAAE,GAAG,wBAAwB,EAAE,CAAC;IAC5C,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,WAAC,OAAA,CAAA,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,0CAAE,MAAM,IAAG,CAAC,CAAA,EAAA,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,MAAM,EACJ,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,YAAY,GACpD,GAAG,UAAU,EAAE,CAAC;IAEjB,MAAM,kBAAkB,GAAG,GAAG,EAAE;QAC9B,KAAK,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;QAC7B,SAAS,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC,CAAC;IACF,MAAM,mBAAmB,GAAG,GAAG,EAAE;QAC/B,KAAK,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;QAC3C,SAAS,CAAC,KAAK,CAAC,CAAC;IACnB,CAAC,CAAC;IAEF,MAAM,gBAAgB,GAAG,CAAC,KAAK,EAAE,EAAE;QACjC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC;IAEF,MAAM,kBAAkB,GAAG,CAAC,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,YAAY,CAAC;QAClD,MAAM,CAAC,KAAK,CAAC,CAAC;IAChB,CAAC,CAAC;IACF,MAAM,EAAE,KAAK,EAAE,GAAG,aAAa,EAAE,CAAC;IAClC,MAAM,QAAQ,GAAG,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,QAAQ,CAAC;IAEpD,OAAO,CACL,eAAK,EAAE,EAAC,wBAAwB,aAC9B,KAAC,MAAM,IACL,GAAG,EAAE,YAAY,EACjB,OAAO,EAAC,iBAAiB,EACzB,UAAU,EAAE,IAAI,EAChB,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,EAAE,CAAC,UAAU,YAEpB,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,GACxB,EACT,KAAC,IAAI,cACF,QAAQ;oBACP,CAAC,CAAC,CACA,MAAC,KAAK,IACJ,SAAS,EAAC,MAAM,EAChB,QAAQ,EAAC,MAAM,EACf,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,mBAAmB,aAE5B,cAAK,SAAS,EAAC,UAAU,YACvB,sBAAI,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAK,GACnC,EACN,cAAM,EACN,cAAK,SAAS,EAAC,iBAAiB,YAC9B,KAAC,UAAU,IAAO,OAAO,EAAE,kBAAkB,GAAM,GAC/C,EACN,cAAK,SAAS,EAAC,+BAA+B,YAC5C,KAAC,QAAQ,IAAO,MAAM,EAAE,gBAAgB,GAAM,GAC1C,EACN,cAAK,SAAS,EAAC,4BAA4B,YACzC,KAAC,gBAAgB,IAAC,OAAO,EAAC,UAAU,EAAC,OAAO,EAAE,mBAAmB,YAC/D,KAAC,IAAI,IAAC,GAAG,EAAE,KAAK,GAAI,GACH,GACf,IACA,CACT,CAAC,CAAC,CAAC,CACF,KAAC,UAAU,IACT,WAAW,EAAE,SAAS,EACtB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,mBAAmB,EAC5B,SAAS,EAAC,YAAY,YAEtB,eACE,EAAE,EAAC,6BAA6B,EAChC,SAAS,EAAC,6CAA6C,aAEvD,cAAK,SAAS,EAAC,iBAAiB,YAC9B,KAAC,UAAU,IAAO,OAAO,EAAE,kBAAkB,GAAM,GAC/C,EACN,aAAI,SAAS,EAAC,gCAAgC,GAAG,EACjD,cAAK,SAAS,EAAC,+BAA+B,YAC5C,KAAC,QAAQ,IAAO,MAAM,EAAE,gBAAgB,GAAM,GAC1C,IACF,GACK,CACd,GACE,IACH,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC","sourcesContent":["import React from 'react';\nimport { useIntl } from '@openedx/frontend-base';\nimport track from '@src/tracking';\nimport {\n Button,\n Form,\n Icon,\n ModalPopup,\n Sheet,\n breakpoints,\n useWindowSize,\n ModalCloseButton,\n} from '@openedx/paragon';\nimport { Close, Tune } from '@openedx/paragon/icons';\n\nimport { useInitializeLearnerHome } from '@src/data/hooks';\nimport { useFilters } from '@src/data/context';\nimport FilterForm from './components/FilterForm';\nimport SortForm from './components/SortForm';\nimport messages from './messages';\n\nimport './index.scss';\n\nexport const CourseFilterControls = () => {\n const [isOpen, setIsOpen] = React.useState(false);\n const [targetRef, setTargetRef] = React.useState(null);\n const { formatMessage } = useIntl();\n const { data } = useInitializeLearnerHome();\n const hasCourses = React.useMemo(() => data?.courses?.length > 0, [data]);\n const {\n filters, sortBy, setSortBy, addFilter, removeFilter,\n } = useFilters();\n\n const openFiltersOptions = () => {\n track.filter.filterClicked();\n setIsOpen(true);\n };\n const closeFiltersOptions = () => {\n track.filter.filterOptionSelected(filters);\n setIsOpen(false);\n };\n\n const handleSortChange = (event) => {\n setSortBy(event.target.value);\n };\n\n const handleFilterChange = ({ target: { checked, value } }) => {\n const update = checked ? addFilter : removeFilter;\n update(value);\n };\n const { width } = useWindowSize();\n const isMobile = width < breakpoints.small.minWidth;\n\n return (\n <div id=\"course-filter-controls\">\n <Button\n ref={setTargetRef}\n variant=\"outline-primary\"\n iconBefore={Tune}\n onClick={openFiltersOptions}\n disabled={!hasCourses}\n >\n {formatMessage(messages.refine)}\n </Button>\n <Form>\n {isMobile\n ? (\n <Sheet\n className=\"w-75\"\n position=\"left\"\n show={isOpen}\n onClose={closeFiltersOptions}\n >\n <div className=\"p-1 mr-3\">\n <b>{formatMessage(messages.refine)}</b>\n </div>\n <hr />\n <div className=\"filter-form-row\">\n <FilterForm {...{ filters, handleFilterChange }} />\n </div>\n <div className=\"filter-form-row text-left m-1\">\n <SortForm {...{ sortBy, handleSortChange }} />\n </div>\n <div className=\"pgn__modal-close-container\">\n <ModalCloseButton variant=\"tertiary\" onClick={closeFiltersOptions}>\n <Icon src={Close} />\n </ModalCloseButton>\n </div>\n </Sheet>\n ) : (\n <ModalPopup\n positionRef={targetRef}\n isOpen={isOpen}\n onClose={closeFiltersOptions}\n placement=\"bottom-end\"\n >\n <div\n id=\"course-filter-controls-card\"\n className=\"bg-white p-3 rounded shadow d-flex flex-row\"\n >\n <div className=\"filter-form-col\">\n <FilterForm {...{ filters, handleFilterChange }} />\n </div>\n <hr className=\"h-100 bg-primary-200 mx-3 my-0\" />\n <div className=\"filter-form-col text-left m-1\">\n <SortForm {...{ sortBy, handleSortChange }} />\n </div>\n </div>\n </ModalPopup>\n )}\n </Form>\n </div>\n );\n};\n\nexport default CourseFilterControls;\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export function Checkbox({ filterKey }: {
|
|
2
|
+
filterKey: any;
|
|
3
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export namespace Checkbox {
|
|
5
|
+
namespace propTypes {
|
|
6
|
+
let filterKey: PropTypes.Validator<string>;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
export default Checkbox;
|
|
10
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import PropTypes from 'prop-types';
|
|
4
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
5
|
+
import { Form } from '@openedx/paragon';
|
|
6
|
+
import messages from '../messages';
|
|
7
|
+
export const Checkbox = ({ filterKey }) => {
|
|
8
|
+
const { formatMessage } = useIntl();
|
|
9
|
+
return (_jsx(Form.Checkbox, { className: "py-2", value: filterKey, children: formatMessage(messages[filterKey]) }));
|
|
10
|
+
};
|
|
11
|
+
Checkbox.propTypes = {
|
|
12
|
+
filterKey: PropTypes.string.isRequired,
|
|
13
|
+
};
|
|
14
|
+
export default Checkbox;
|
|
15
|
+
//# sourceMappingURL=Checkbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Checkbox.js","sourceRoot":"","sources":["../../../../src/containers/CourseFilterControls/components/Checkbox.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAExC,OAAO,QAAQ,MAAM,aAAa,CAAC;AAEnC,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;IACxC,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,OAAO,CACL,KAAC,IAAI,CAAC,QAAQ,IAAC,SAAS,EAAC,MAAM,EAAC,KAAK,EAAE,SAAS,YAC7C,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,GACrB,CACjB,CAAC;AACJ,CAAC,CAAC;AACF,QAAQ,CAAC,SAAS,GAAG;IACnB,SAAS,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACvC,CAAC;AAEF,eAAe,QAAQ,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { Form } from '@openedx/paragon';\n\nimport messages from '../messages';\n\nexport const Checkbox = ({ filterKey }) => {\n const { formatMessage } = useIntl();\n return (\n <Form.Checkbox className=\"py-2\" value={filterKey}>\n {formatMessage(messages[filterKey])}\n </Form.Checkbox>\n );\n};\nCheckbox.propTypes = {\n filterKey: PropTypes.string.isRequired,\n};\n\nexport default Checkbox;\n"]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export const filterOrder: any[];
|
|
2
|
+
export function FilterForm({ filters, handleFilterChange, }: {
|
|
3
|
+
filters: any;
|
|
4
|
+
handleFilterChange: any;
|
|
5
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export namespace FilterForm {
|
|
7
|
+
namespace propTypes {
|
|
8
|
+
let filters: PropTypes.Validator<(string | null | undefined)[]>;
|
|
9
|
+
let handleFilterChange: PropTypes.Validator<(...args: any[]) => any>;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export default FilterForm;
|
|
13
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import PropTypes from 'prop-types';
|
|
4
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
5
|
+
import { FilterKeys } from '../../../data/constants/app';
|
|
6
|
+
import { Form } from '@openedx/paragon';
|
|
7
|
+
import Checkbox from './Checkbox';
|
|
8
|
+
import messages from '../messages';
|
|
9
|
+
export const filterOrder = [
|
|
10
|
+
FilterKeys.inProgress,
|
|
11
|
+
FilterKeys.notStarted,
|
|
12
|
+
FilterKeys.done,
|
|
13
|
+
FilterKeys.notEnrolled,
|
|
14
|
+
FilterKeys.upgraded,
|
|
15
|
+
];
|
|
16
|
+
export const FilterForm = ({ filters, handleFilterChange, }) => {
|
|
17
|
+
const { formatMessage } = useIntl();
|
|
18
|
+
return (_jsxs(Form.Group, { children: [_jsx("div", { className: "filter-form-heading mb-1", children: formatMessage(messages.courseStatus) }), _jsx(Form.CheckboxSet, { name: "course-status-filters", onChange: handleFilterChange, value: filters, children: filterOrder.map(filterKey => (_jsx(Checkbox, { filterKey: filterKey }, filterKey))) })] }));
|
|
19
|
+
};
|
|
20
|
+
FilterForm.propTypes = {
|
|
21
|
+
filters: PropTypes.arrayOf(PropTypes.string).isRequired,
|
|
22
|
+
handleFilterChange: PropTypes.func.isRequired,
|
|
23
|
+
};
|
|
24
|
+
export default FilterForm;
|
|
25
|
+
//# sourceMappingURL=FilterForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FilterForm.js","sourceRoot":"","sources":["../../../../src/containers/CourseFilterControls/components/FilterForm.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAEzD,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAExC,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,QAAQ,MAAM,aAAa,CAAC;AAEnC,MAAM,CAAC,MAAM,WAAW,GAAG;IACzB,UAAU,CAAC,UAAU;IACrB,UAAU,CAAC,UAAU;IACrB,UAAU,CAAC,IAAI;IACf,UAAU,CAAC,WAAW;IACtB,UAAU,CAAC,QAAQ;CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EACzB,OAAO,EACP,kBAAkB,GACnB,EAAE,EAAE;IACH,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,OAAO,CACL,MAAC,IAAI,CAAC,KAAK,eACT,cAAK,SAAS,EAAC,0BAA0B,YAAE,aAAa,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAO,EACtF,KAAC,IAAI,CAAC,WAAW,IACf,IAAI,EAAC,uBAAuB,EAC5B,QAAQ,EAAE,kBAAkB,EAC5B,KAAK,EAAE,OAAO,YAEb,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,CAC5B,KAAC,QAAQ,IAAC,SAAS,EAAE,SAAS,IAAO,SAAS,CAAI,CACnD,CAAC,GACe,IACR,CACd,CAAC;AACJ,CAAC,CAAC;AACF,UAAU,CAAC,SAAS,GAAG;IACrB,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,UAAU;IACvD,kBAAkB,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU;CAC9C,CAAC;AAEF,eAAe,UAAU,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { FilterKeys } from '../../../data/constants/app';\n\nimport { Form } from '@openedx/paragon';\n\nimport Checkbox from './Checkbox';\nimport messages from '../messages';\n\nexport const filterOrder = [\n FilterKeys.inProgress,\n FilterKeys.notStarted,\n FilterKeys.done,\n FilterKeys.notEnrolled,\n FilterKeys.upgraded,\n];\n\nexport const FilterForm = ({\n filters,\n handleFilterChange,\n}) => {\n const { formatMessage } = useIntl();\n return (\n <Form.Group>\n <div className=\"filter-form-heading mb-1\">{formatMessage(messages.courseStatus)}</div>\n <Form.CheckboxSet\n name=\"course-status-filters\"\n onChange={handleFilterChange}\n value={filters}\n >\n {filterOrder.map(filterKey => (\n <Checkbox filterKey={filterKey} key={filterKey} />\n ))}\n </Form.CheckboxSet>\n </Form.Group>\n );\n};\nFilterForm.propTypes = {\n filters: PropTypes.arrayOf(PropTypes.string).isRequired,\n handleFilterChange: PropTypes.func.isRequired,\n};\n\nexport default FilterForm;\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export function SortForm({ handleSortChange, sortBy, }: {
|
|
2
|
+
handleSortChange: any;
|
|
3
|
+
sortBy: any;
|
|
4
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
5
|
+
export namespace SortForm {
|
|
6
|
+
namespace propTypes {
|
|
7
|
+
let handleSortChange: PropTypes.Validator<(...args: any[]) => any>;
|
|
8
|
+
let sortBy: PropTypes.Validator<string>;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export default SortForm;
|
|
12
|
+
import PropTypes from 'prop-types';
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import PropTypes from 'prop-types';
|
|
4
|
+
import { useIntl } from '@openedx/frontend-base';
|
|
5
|
+
import { SortKeys } from '../../../data/constants/app';
|
|
6
|
+
import { Form } from '@openedx/paragon';
|
|
7
|
+
import messages from '../messages';
|
|
8
|
+
export const SortForm = ({ handleSortChange, sortBy, }) => {
|
|
9
|
+
const { formatMessage } = useIntl();
|
|
10
|
+
return (_jsxs(_Fragment, { children: [_jsx("div", { className: "filter-form-heading mb-1", children: formatMessage(messages.sort) }), _jsxs(Form.RadioSet, { name: "sort", onChange: handleSortChange, value: sortBy, children: [_jsx(Form.Radio, { className: "py-2", value: SortKeys.enrolled, children: formatMessage(messages.sortLastEnrolled) }), _jsx(Form.Radio, { className: "py-2", value: SortKeys.title, children: formatMessage(messages.sortTitle) })] })] }));
|
|
11
|
+
};
|
|
12
|
+
SortForm.propTypes = {
|
|
13
|
+
handleSortChange: PropTypes.func.isRequired,
|
|
14
|
+
sortBy: PropTypes.string.isRequired,
|
|
15
|
+
};
|
|
16
|
+
export default SortForm;
|
|
17
|
+
//# sourceMappingURL=SortForm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SortForm.js","sourceRoot":"","sources":["../../../../src/containers/CourseFilterControls/components/SortForm.jsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,SAAS,MAAM,YAAY,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAC;AAEvD,OAAO,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAExC,OAAO,QAAQ,MAAM,aAAa,CAAC;AAEnC,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EACvB,gBAAgB,EAChB,MAAM,GACP,EAAE,EAAE;IACH,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,EAAE,CAAC;IACpC,OAAO,CACL,8BACE,cAAK,SAAS,EAAC,0BAA0B,YAAE,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAO,EAC9E,MAAC,IAAI,CAAC,QAAQ,IACZ,IAAI,EAAC,MAAM,EACX,QAAQ,EAAE,gBAAgB,EAC1B,KAAK,EAAE,MAAM,aAEb,KAAC,IAAI,CAAC,KAAK,IAAC,SAAS,EAAC,MAAM,EAAC,KAAK,EAAE,QAAQ,CAAC,QAAQ,YAClD,aAAa,CAAC,QAAQ,CAAC,gBAAgB,CAAC,GAC9B,EACb,KAAC,IAAI,CAAC,KAAK,IAAC,SAAS,EAAC,MAAM,EAAC,KAAK,EAAE,QAAQ,CAAC,KAAK,YAC/C,aAAa,CAAC,QAAQ,CAAC,SAAS,CAAC,GACvB,IACC,IACf,CACJ,CAAC;AACJ,CAAC,CAAC;AACF,QAAQ,CAAC,SAAS,GAAG;IACnB,gBAAgB,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU;IAC3C,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;CACpC,CAAC;AAEF,eAAe,QAAQ,CAAC","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { useIntl } from '@openedx/frontend-base';\n\nimport { SortKeys } from '../../../data/constants/app';\n\nimport { Form } from '@openedx/paragon';\n\nimport messages from '../messages';\n\nexport const SortForm = ({\n handleSortChange,\n sortBy,\n}) => {\n const { formatMessage } = useIntl();\n return (\n <>\n <div className=\"filter-form-heading mb-1\">{formatMessage(messages.sort)}</div>\n <Form.RadioSet\n name=\"sort\"\n onChange={handleSortChange}\n value={sortBy}\n >\n <Form.Radio className=\"py-2\" value={SortKeys.enrolled}>\n {formatMessage(messages.sortLastEnrolled)}\n </Form.Radio>\n <Form.Radio className=\"py-2\" value={SortKeys.title}>\n {formatMessage(messages.sortTitle)}\n </Form.Radio>\n </Form.RadioSet>\n </>\n );\n};\nSortForm.propTypes = {\n handleSortChange: PropTypes.func.isRequired,\n sortBy: PropTypes.string.isRequired,\n};\n\nexport default SortForm;\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/containers/CourseFilterControls/index.jsx"],"names":[],"mappings":"AAAA,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAE1D,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAEvE,OAAO,EAAE,oBAAoB,EAAE,CAAC;AAChC,eAAe,oBAAoB,CAAC","sourcesContent":["import CourseFilterControls from './CourseFilterControls';\n\nexport { default as ActiveCourseFilters } from './ActiveCourseFilters';\n\nexport { CourseFilterControls };\nexport default CourseFilterControls;\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
.pgn__sheet-component {
|
|
2
|
+
max-width: 75% !important;
|
|
3
|
+
width: 75% !important;
|
|
4
|
+
|
|
5
|
+
.filter-form-heading {
|
|
6
|
+
font-weight: bold;
|
|
7
|
+
font-size: 18px;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
#course-filter-controls-card {
|
|
11
|
+
width: 512px;
|
|
12
|
+
height: 288px;
|
|
13
|
+
&.no-enrollments {
|
|
14
|
+
height: 172px;
|
|
15
|
+
}
|
|
16
|
+
.filter-form-heading {
|
|
17
|
+
font-weight: bold;
|
|
18
|
+
font-size: 18px;
|
|
19
|
+
}
|
|
20
|
+
hr {
|
|
21
|
+
width: 1px;
|
|
22
|
+
};
|
|
23
|
+
.filter-form-col {
|
|
24
|
+
width: 256px;
|
|
25
|
+
display: inline-block;
|
|
26
|
+
text-align: left;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|