Merge pull request #4201 from crazyserver/MOBILE-4616

MOBILE-4616 course: Fix change section from course index when mod opens
main
Dani Palou 2024-10-10 14:46:19 +02:00 committed by GitHub
commit a33027e818
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 18 additions and 6 deletions

View File

@ -483,12 +483,15 @@ export class CoreCourseFormatComponent implements OnInit, OnChanges, OnDestroy {
id: data.moduleId === undefined ? data.sectionId : undefined, id: data.moduleId === undefined ? data.sectionId : undefined,
}); });
// Select the root section. // If a section is selected (no moduleId), or all sections are not displayed. Change section.
this.sectionChanged(parents[0] ?? section); if (!data.moduleId || !this.selectedSection || this.selectedSection.id !== this.allSectionsId) {
// Select the root section.
this.sectionChanged(parents[0] ?? section);
}
if (parents.length && section) { if (section) {
// It's a subsection. Expand all the parents and the subsection. // It's a subsection. Expand its parents too.
for (let i = 1; i < parents.length; i++) { for (let i = 0; i < parents.length; i++) {
this.setSectionExpanded(parents[i]); this.setSectionExpanded(parents[i]);
} }
@ -811,6 +814,9 @@ export class CoreCourseFormatComponent implements OnInit, OnChanges, OnDestroy {
*/ */
accordionMultipleChange(ev: AccordionGroupChangeEventDetail): void { accordionMultipleChange(ev: AccordionGroupChangeEventDetail): void {
const sectionIds = ev.value as string[] | undefined; const sectionIds = ev.value as string[] | undefined;
this.accordionMultipleValue = ev.value;
const allSections = CoreCourseHelper.flattenSections(this.sections); const allSections = CoreCourseHelper.flattenSections(this.sections);
allSections.forEach((section) => { allSections.forEach((section) => {
section.expanded = false; section.expanded = false;
@ -836,8 +842,14 @@ export class CoreCourseFormatComponent implements OnInit, OnChanges, OnDestroy {
*/ */
protected setSectionExpanded(section: CoreCourseSectionToDisplay): void { protected setSectionExpanded(section: CoreCourseSectionToDisplay): void {
section.expanded = true; section.expanded = true;
if (!this.accordionMultipleValue.includes(section.id.toString())) { if (!this.accordionMultipleValue.includes(section.id.toString())) {
this.accordionMultipleValue.push(section.id.toString()); // Force detect changes to update the view.
this.accordionMultipleValue = [
...this.accordionMultipleValue,
section.id.toString(),
];
this.saveExpandedSections(); this.saveExpandedSections();
} }
} }