Newer
Older
<div class="course-list-wrapper">
<div class="course-list">
<div class="course-list-inner">
<ng-container *ngIf="enrolledCourses.length === 0">
<p *ngIf="(term$ | async).termCode.isPast()" class="no-courses">
<p *ngIf="(term$ | async).termCode.isActive()" class="no-courses">
Not enrolled in any courses
</p>
</ng-container>
role="button"
aria-labelledby="enrolled-courses"
*ngFor="let course of enrolledCourses"
type="course"
[disabled]="true"
[course]="course"
[era]="(term$ | async).era">
</div>
</ng-template>
<div class="course-list-wrapper">
<div
class="course-list"
cdkDropList
id="term-{{ termCode }}"
[cdkDropListData]="(term$ | async).termCode"
[cdkDropListConnectedTo]="dropZoneIds$ | async"
(cdkDropListDropped)="drop($event)"
(cdkDropListEntered)="dragEnter($event)"
(cdkDropListExited)="dragExit($event)">
<div class="course-list-inner term-body">
<ng-container
*ngIf="plannedCourses.length === 0 && !hasItemDraggedOver">
<p *ngIf="(term$ | async).termCode.isActive()" class="no-courses">
<p *ngIf="(term$ | async).termCode.isFuture()" class="no-courses">
<p *ngIf="(term$ | async).termCode.isPast()" class="no-courses">
No courses planned
</p>
</ng-container>
<span class="assistive-text">{{ assistiveText }}</span>
<div
cdkDrag
[cdkDragData]="course"
[cdkDragDisabled]="mobileView.matches"
(cdkDragStarted)="startDrag($event)"
*ngFor="let course of plannedCourses">
role="button"
aria-labelledby="planned-courses"
[era]="(term$ | async).era">
</div>
</div>
</div>
<!-- Add course -->
<div class="add-new-wrapper" *ngIf="(term$ | async).termCode.isPast() == false">
attr.aria-label="Add course to {{ termCode | getTermDescription }}"
(click)="openCourseSearch()">
</div>
</ng-template>
<mat-card
class="term-container"
[ngClass]="{ 'no-scrolling': mobileView.matches }"
role="region"
cdkFocusInitial
>
fxLayoutAlign="space-between center">
<h3 tabindex="0" class="term-description">{{ termCode | getTermDescription }}</h3>
<div fxLayout="row" fxLayoutAlign="space-between center">
<p class="text-right semi-bold credits">
<span *ngIf="visibleCredits === 'planned'" attr.aria-label="{{ plannedCredits }} credits">
{{ plannedCredits }} Cr
</span>
<span *ngIf="visibleCredits === 'enrolled'" attr.aria-label="{{ enrolledCredits }} credits">
{{ enrolledCredits }} Cr
</span>
</p>
<ng-container *ngIf="(note$ | async) as note; else newNote">
attr.aria-label="Edit note for {{ termCode | getTermDescription }}"
(click)="openNotesDialog(note)">
alt="Edit note"
matTooltipPosition="above">
<button
mat-icon-button
(click)="openNotesDialog()"
attr.aria-label="Add note to {{ termCode | getTermDescription }}">
alt="Add note"
matTooltipPosition="above">
<p class="credit-overload-warning" *ngIf="tooManyCredits$ | async">
Warning: credit overload
</p>
<!-- Render term note (if it exists) -->
<ng-container *ngIf="(note$ | async) as note">
<ng-container *ngIf="note.isLoaded; else noteIsLoading">
<div class="note-item" (click)="openNotesDialog(note)">
<p class="semi-bold">Note</p>
<p class="note-excerpt">{{ note.text }}</p>
</div>
</ng-container>
<ng-template #noteIsLoading>
<div class="note-item note-item-loading">
<p class="semi-bold">Note</p>
<p class="note-excerpt">{{ note.text }}</p>
<mat-progress-spinner
mode="indeterminate"
diameter="24">
</mat-progress-spinner>
</div>
<!-- If this term is an active term -->
<ng-container *ngIf="(term$ | async).termCode.isActive()">
<mat-tab-group (selectedTabChange)="changeVisibleCredits($event)" [selectedIndex]="(enrolledCourses.length > 0) ? 0 : 1">
<mat-tab [label]="'In Progress (' + enrolledCourses.length + ')'" aria-label="In progress courses">
<ng-container cdkFocusinitial *ngTemplateOutlet="enrolled"></ng-container>
</mat-tab>
<mat-tab [label]="'Cart (' + plannedCourses.length + ')'" aria-label="Cart courses">
<ng-container cdkFocusinitial *ngTemplateOutlet="planned"></ng-container>
</mat-tab>
</ng-container>
<!-- If this term is a past term -->
<ng-container *ngIf="(term$ | async).termCode.isPast()">
<mat-tab-group (selectedTabChange)="changeVisibleCredits($event)" [selectedIndex]="0">
<mat-tab [label]="'Completed (' + enrolledCourses.length + ')'" aria-label="Completed courses">
<ng-container cdkFocusinitial *ngTemplateOutlet="enrolled"></ng-container>
</mat-tab>
<mat-tab [label]="'Cart (' + plannedCourses.length + ')'" aria-label="Cart courses">
<ng-container cdkFocusinitial *ngTemplateOutlet="planned"></ng-container>
</mat-tab>
</mat-tab-group>
</ng-container>
<!-- If this term is a future term -->
<ng-container *ngIf="(term$ | async).termCode.isFuture()">
<ng-container cdkFocusinitial *ngTemplateOutlet="planned"></ng-container>
</ng-container>