@rolatech/angular-course 17.3.27 → 17.3.29
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/esm2022/lib/components/course-schedule-add-dialog/course-schedule-add-dialog.component.mjs +10 -18
- package/esm2022/lib/components/schedule-item/schedule-item.component.mjs +7 -2
- package/esm2022/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.mjs +12 -21
- package/fesm2022/{rolatech-angular-course-course-index.component-mCY9aUg6.mjs → rolatech-angular-course-course-index.component-D339dt6A.mjs} +4 -4
- package/fesm2022/{rolatech-angular-course-course-index.component-mCY9aUg6.mjs.map → rolatech-angular-course-course-index.component-D339dt6A.mjs.map} +1 -1
- package/fesm2022/{rolatech-angular-course-rolatech-angular-course-Cyt2SX4m.mjs → rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs} +26 -33
- package/fesm2022/rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs.map +1 -0
- package/fesm2022/rolatech-angular-course.mjs +1 -1
- package/lib/components/course-schedule-add-dialog/course-schedule-add-dialog.component.d.ts +5 -7
- package/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.d.ts +0 -2
- package/package.json +1 -1
- package/fesm2022/rolatech-angular-course-rolatech-angular-course-Cyt2SX4m.mjs.map +0 -1
package/esm2022/lib/components/course-schedule-add-dialog/course-schedule-add-dialog.component.mjs
CHANGED
|
@@ -1,16 +1,11 @@
|
|
|
1
|
-
import { Component,
|
|
2
|
-
import { MatDialogRef, MAT_DIALOG_DATA, MatDialogClose } from '@angular/material/dialog';
|
|
1
|
+
import { Component, output } from '@angular/core';
|
|
3
2
|
import { MatButtonModule } from '@angular/material/button';
|
|
4
3
|
import { ScheduleItemComponent } from '../schedule-item/schedule-item.component';
|
|
5
4
|
import { MatIconModule } from '@angular/material/icon';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/material/dialog";
|
|
8
|
-
import * as i2 from "@angular/material/icon";
|
|
9
|
-
import * as i3 from "@angular/material/button";
|
|
10
6
|
export class CourseScheduleAddDialogComponent {
|
|
11
|
-
constructor(
|
|
12
|
-
this.
|
|
13
|
-
this.data = data;
|
|
7
|
+
constructor() {
|
|
8
|
+
this.output = output();
|
|
14
9
|
this.schedule = {
|
|
15
10
|
title: '',
|
|
16
11
|
content: '',
|
|
@@ -18,17 +13,14 @@ export class CourseScheduleAddDialogComponent {
|
|
|
18
13
|
endAt: '',
|
|
19
14
|
};
|
|
20
15
|
}
|
|
21
|
-
|
|
22
|
-
this.
|
|
16
|
+
ngDoCheck() {
|
|
17
|
+
this.output.emit(this.schedule);
|
|
23
18
|
}
|
|
24
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, deps: [
|
|
25
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
20
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: CourseScheduleAddDialogComponent, isStandalone: true, selector: "rolatech-course-schedule-add-dialog", outputs: { output: "output" }, ngImport: i0, template: "<div class=\"flex flex-col h-full\">\n <div class=\"flex-1 overflow-y-auto max-h-[55vh] px-3\">\n <rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: ScheduleItemComponent, selector: "rolatech-schedule-item", inputs: ["value", "actions"], outputs: ["delete", "save"] }, { kind: "ngmodule", type: MatButtonModule }] }); }
|
|
26
21
|
}
|
|
27
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, decorators: [{
|
|
28
23
|
type: Component,
|
|
29
|
-
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule
|
|
30
|
-
}]
|
|
31
|
-
|
|
32
|
-
args: [MAT_DIALOG_DATA]
|
|
33
|
-
}] }] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsY0FBYyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDekYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7QUFVdkQsTUFBTSxPQUFPLGdDQUFnQztJQU8zQyxZQUNVLFNBQXlELEVBQ2pDLElBQVM7UUFEakMsY0FBUyxHQUFULFNBQVMsQ0FBZ0Q7UUFDakMsU0FBSSxHQUFKLElBQUksQ0FBSztRQVIzQyxhQUFRLEdBQWE7WUFDbkIsS0FBSyxFQUFFLEVBQUU7WUFDVCxPQUFPLEVBQUUsRUFBRTtZQUNYLE9BQU8sRUFBRSxFQUFFO1lBQ1gsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0lBSUMsQ0FBQztJQUVKLEtBQUs7UUFDSCxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7OEdBZFUsZ0NBQWdDLDhDQVNqQyxlQUFlO2tHQVRkLGdDQUFnQywrRkNkN0MsMHNCQWlCQSx5RERMWSxhQUFhLG9MQUFFLHFCQUFxQiw2SEFBRSxlQUFlLDROQUFFLGNBQWM7OzJGQUVwRSxnQ0FBZ0M7a0JBUDVDLFNBQVM7K0JBQ0UscUNBQXFDLGNBR25DLElBQUksV0FDUCxDQUFDLGFBQWEsRUFBRSxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsY0FBYyxDQUFDOzswQkFXN0UsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZ1JlZiwgTUFUX0RJQUxPR19EQVRBLCBNYXREaWFsb2dDbG9zZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgU2NoZWR1bGVJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi4vc2NoZWR1bGUtaXRlbS9zY2hlZHVsZS1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBTY2hlZHVsZSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyb2xhdGVjaC1jb3Vyc2Utc2NoZWR1bGUtYWRkLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3Vyc2Utc2NoZWR1bGUtYWRkLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NvdXJzZS1zY2hlZHVsZS1hZGQtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtNYXRJY29uTW9kdWxlLCBTY2hlZHVsZUl0ZW1Db21wb25lbnQsIE1hdEJ1dHRvbk1vZHVsZSwgTWF0RGlhbG9nQ2xvc2VdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3Vyc2VTY2hlZHVsZUFkZERpYWxvZ0NvbXBvbmVudCB7XG4gIHNjaGVkdWxlOiBTY2hlZHVsZSA9IHtcbiAgICB0aXRsZTogJycsXG4gICAgY29udGVudDogJycsXG4gICAgc3RhcnRBdDogJycsXG4gICAgZW5kQXQ6ICcnLFxuICB9O1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPENvdXJzZVNjaGVkdWxlQWRkRGlhbG9nQ29tcG9uZW50PixcbiAgICBASW5qZWN0KE1BVF9ESUFMT0dfREFUQSkgcHVibGljIGRhdGE6IGFueSxcbiAgKSB7fVxuXG4gIGNsb3NlKCkge1xuICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGgtZnVsbFwiPlxuICA8ZGl2IGNsYXNzPVwiaC0xNiBmbGV4IGp1c3RpZnktYmV0d2VlbiBpdGVtcy1jZW50ZXIgcHgtNVwiPlxuICAgIEBpZiAoZGF0YS50aXRsZSkge1xuICAgICAgPGRpdiBjbGFzcz1cInRleHQteGwgZm9udC1ib2xkXCI+e3sgZGF0YS50aXRsZSB9fTwvZGl2PlxuICAgIH1cbiAgICA8ZGl2IGNsYXNzPVwiY3Vyc29yLXBvaW50ZXJcIiAoY2xpY2spPVwiY2xvc2UoKVwiPlxuICAgICAgPG1hdC1pY29uIGZvbnRJY29uPVwiY2xvc2VcIj48L21hdC1pY29uPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImZsZXgtMSBvdmVyZmxvdy15LWF1dG8gbWF4LWgtWzU1dmhdIHB4LTNcIj5cbiAgICA8cm9sYXRlY2gtc2NoZWR1bGUtaXRlbSBbdmFsdWVdPVwic2NoZWR1bGVcIj48L3JvbGF0ZWNoLXNjaGVkdWxlLWl0ZW0+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiaC0xNiBmbGV4IGp1c3RpZnktZW5kIGl0ZW1zLWNlbnRlciBweC01IGdhcC0zXCI+XG4gICAgPGJ1dHRvbiBtYXQtYnV0dG9uIG1hdC1kaWFsb2ctY2xvc2U+5Y+W5raIPC9idXR0b24+XG4gICAgPGJ1dHRvbiBtYXQtZmxhdC1idXR0b24gW21hdC1kaWFsb2ctY2xvc2VdPVwic2NoZWR1bGVcIiBjZGtGb2N1c0luaXRpYWw+5L+d5a2YPC9idXR0b24+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
24
|
+
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule], template: "<div class=\"flex flex-col h-full\">\n <div class=\"flex-1 overflow-y-auto max-h-[55vh] px-3\">\n <rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\n </div>\n</div>\n" }]
|
|
25
|
+
}] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVyxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFVdkQsTUFBTSxPQUFPLGdDQUFnQztJQVA3QztRQVFFLFdBQU0sR0FBRyxNQUFNLEVBQU8sQ0FBQztRQUN2QixhQUFRLEdBQWE7WUFDbkIsS0FBSyxFQUFFLEVBQUU7WUFDVCxPQUFPLEVBQUUsRUFBRTtZQUNYLE9BQU8sRUFBRSxFQUFFO1lBQ1gsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0tBS0g7SUFIQyxTQUFTO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7OEdBWFUsZ0NBQWdDO2tHQUFoQyxnQ0FBZ0MsOEhDYjdDLGtNQUtBLHlERE1ZLGFBQWEsK0JBQUUscUJBQXFCLDZIQUFFLGVBQWU7OzJGQUVwRCxnQ0FBZ0M7a0JBUDVDLFNBQVM7K0JBQ0UscUNBQXFDLGNBR25DLElBQUksV0FDUCxDQUFDLGFBQWEsRUFBRSxxQkFBcUIsRUFBRSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIERvQ2hlY2ssIG91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IFNjaGVkdWxlSXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL3NjaGVkdWxlLWl0ZW0vc2NoZWR1bGUtaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgU2NoZWR1bGUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncm9sYXRlY2gtY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jb3Vyc2Utc2NoZWR1bGUtYWRkLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTWF0SWNvbk1vZHVsZSwgU2NoZWR1bGVJdGVtQ29tcG9uZW50LCBNYXRCdXR0b25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3Vyc2VTY2hlZHVsZUFkZERpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIERvQ2hlY2sge1xuICBvdXRwdXQgPSBvdXRwdXQ8YW55PigpO1xuICBzY2hlZHVsZTogU2NoZWR1bGUgPSB7XG4gICAgdGl0bGU6ICcnLFxuICAgIGNvbnRlbnQ6ICcnLFxuICAgIHN0YXJ0QXQ6ICcnLFxuICAgIGVuZEF0OiAnJyxcbiAgfTtcblxuICBuZ0RvQ2hlY2soKTogdm9pZCB7XG4gICAgdGhpcy5vdXRwdXQuZW1pdCh0aGlzLnNjaGVkdWxlKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wgaC1mdWxsXCI+XG4gIDxkaXYgY2xhc3M9XCJmbGV4LTEgb3ZlcmZsb3cteS1hdXRvIG1heC1oLVs1NXZoXSBweC0zXCI+XG4gICAgPHJvbGF0ZWNoLXNjaGVkdWxlLWl0ZW0gW3ZhbHVlXT1cInNjaGVkdWxlXCI+PC9yb2xhdGVjaC1zY2hlZHVsZS1pdGVtPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -41,7 +41,12 @@ export class ScheduleItemComponent {
|
|
|
41
41
|
this.save = output();
|
|
42
42
|
this.date = ScheduleDate;
|
|
43
43
|
this.schedule = effect(() => {
|
|
44
|
-
this.schedule = this.value()
|
|
44
|
+
this.schedule = this.value() || {
|
|
45
|
+
title: '',
|
|
46
|
+
content: '',
|
|
47
|
+
startAt: '',
|
|
48
|
+
endAt: '',
|
|
49
|
+
};
|
|
45
50
|
this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');
|
|
46
51
|
this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');
|
|
47
52
|
this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');
|
|
@@ -120,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
120
125
|
MatDividerModule,
|
|
121
126
|
], template: "<div class=\"flex flex-col py-3\">\n <mat-form-field appearance=\"fill\">\n <mat-label> \u6807\u9898 </mat-label>\n <input matInput type=\"text\" [(ngModel)]=\"schedule.title\" name=\"title\" required />\n </mat-form-field>\n <mat-form-field appearance=\"fill\">\n <mat-label> \u5185\u5BB9 </mat-label>\n <textarea\n matInput\n type=\"text\"\n [(ngModel)]=\"schedule.content\"\n name=\"content\"\n cdkTextareaAutosize\n cdkAutosizeMinRows=\"3\"\n required\n ></textarea>\n </mat-form-field>\n <div class=\"flex flex-row gap-3\">\n <mat-form-field appearance=\"fill\">\n <mat-label>\u5F00\u59CB\u65E5\u671F</mat-label>\n <input\n matInput\n [matDatepicker]=\"picker\"\n (focus)=\"picker.open()\"\n name=\"startAt\"\n [(ngModel)]=\"schedule.startDate\"\n (ngModelChange)=\"startDateChanged($event)\"\n (dateInput)=\"schedule.startDate = $event.value.format('YYYY-MM-DD')\"\n readonly\n required\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n </mat-form-field>\n <mat-form-field appearance=\"fill\">\n <mat-label>\u5F00\u59CB\u65F6\u95F4</mat-label>\n <mat-select [(ngModel)]=\"schedule.startTime\" (selectionChange)=\"startTimeChanged($event)\" required readonly>\n @for (d of date; track d) {\n <mat-option [value]=\"d\">\n {{ d }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n </div>\n <div class=\"flex flex-row gap-3\">\n <mat-form-field appearance=\"fill\">\n <mat-label>\u7ED3\u675F\u65E5\u671F</mat-label>\n <input\n matInput\n [matDatepicker]=\"picker2\"\n name=\"endAt\"\n (focus)=\"picker2.open()\"\n (ngModelChange)=\"endDateChanged($event)\"\n [(ngModel)]=\"schedule.endDate\"\n (dateInput)=\"schedule.endDate = $event.value.format('YYYY-MM-DD')\"\n readonly\n required\n />\n <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n <mat-datepicker #picker2></mat-datepicker>\n </mat-form-field>\n <mat-form-field appearance=\"fill\">\n <mat-label>\u7ED3\u675F\u65F6\u95F4</mat-label>\n <mat-select [(ngModel)]=\"schedule.endTime\" (selectionChange)=\"endTimeChanged($event)\" required readonly>\n @for (d of date; track d) {\n <mat-option [value]=\"d\">\n {{ d }}\n </mat-option>\n }\n </mat-select>\n </mat-form-field>\n </div>\n</div>\n@if (actions()) {\n <div class=\"flex flex-row justify-end p-3 gap-3\">\n <button mat-button class=\"max-h-8\" (click)=\"onDelete(schedule)\">\u5220\u9664</button>\n <button mat-flat-button class=\"max-h-8\" (click)=\"onSave(schedule)\">\u4FDD\u5B58</button>\n </div>\n}\n<mat-divider></mat-divider>\n" }]
|
|
122
127
|
}] });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schedule-item.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-course/src/lib/components/schedule-item/schedule-item.component.ts","../../../../../../../libs/angular-course/src/lib/components/schedule-item/schedule-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MomentDateAdapter } from '@angular/material-moment-adapter';\nimport { Component, OnInit, OnDestroy, output, model, input, effect, computed } from '@angular/core';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE, MatOptionModule } from '@angular/material/core';\nimport moment from 'moment';\nimport { DatePipe, NgClass } from '@angular/common';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { TextFieldModule } from '@angular/cdk/text-field';\nimport { FormsModule } from '@angular/forms';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { Schedule, ScheduleDate } from '../../interfaces';\nexport const COURSE_SCHEDULE_DATE_FORMATS = {\n  parse: {\n    dateInput: 'YYYY-MM-DD',\n  },\n  display: {\n    dateInput: 'YYYY-MM-DD',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'YYYY-MM-DD',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n};\n\n@Component({\n  selector: 'rolatech-schedule-item',\n  templateUrl: './schedule-item.component.html',\n  styleUrls: ['./schedule-item.component.scss'],\n  providers: [\n    {\n      provide: DateAdapter,\n      useClass: MomentDateAdapter,\n      deps: [MAT_DATE_LOCALE],\n    },\n    { provide: MAT_DATE_FORMATS, useValue: COURSE_SCHEDULE_DATE_FORMATS },\n    DatePipe,\n  ],\n  standalone: true,\n  imports: [\n    NgClass,\n    MatFormFieldModule,\n    MatInputModule,\n    FormsModule,\n    TextFieldModule,\n    MatDatepickerModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatButtonModule,\n    MatDividerModule,\n  ],\n})\nexport class ScheduleItemComponent implements OnInit, OnDestroy {\n  value = input<Schedule | undefined>();\n  actions = input<boolean>(false);\n  delete = output<Schedule>();\n  save = output<Schedule>();\n  date = ScheduleDate;\n  schedule: any = effect(() => {\n    this.schedule = this.value();\n    this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');\n    this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');\n    this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');\n    this.schedule.endTime = moment(this.schedule.endAt).format('HH:mm');\n  });\n  // constructor() {\n  //   this.schedule = this.value();\n  // }\n\n  ngOnInit(): void {\n    // this.schedule = computed(() => {\n    //   console.log(this.value());\n    //   return this.value();\n    // })();\n    // this.schedule = this.value();\n    // this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');\n    // this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');\n    // this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');\n    // this.schedule.endTime = moment(this.schedule.endAt).format('HH:mm');\n  }\n  ngOnDestroy(): void {\n    const { startAt, endAt, startTime, startDate, endDate, endTime } = this.schedule;\n    this.schedule.startAt = this.schedule.startDate + ' ' + this.schedule.startTime;\n    this.schedule.endAt = this.schedule.endDate + ' ' + this.schedule.endTime;\n    delete this.schedule.startDate;\n    delete this.schedule.startTime;\n    delete this.schedule.endDate;\n    delete this.schedule.endTime;\n  }\n  startDateChanged(event: any) {}\n  startTimeChanged(event: any) {}\n\n  endDateChanged(event: any) {}\n  endTimeChanged(event: any) {}\n\n  onSave(schedule: Schedule) {\n    this.format();\n    this.save.emit(schedule);\n  }\n  onDelete(schedule: Schedule) {\n    this.delete.emit(schedule);\n  }\n  private format() {\n    this.schedule.startAt = this.schedule.startDate + ' ' + this.schedule.startTime;\n    this.schedule.endAt = this.schedule.endDate + ' ' + this.schedule.endTime;\n  }\n}\n","<div class=\"flex flex-col py-3\">\n  <mat-form-field appearance=\"fill\">\n    <mat-label> 标题 </mat-label>\n    <input matInput type=\"text\" [(ngModel)]=\"schedule.title\" name=\"title\" required />\n  </mat-form-field>\n  <mat-form-field appearance=\"fill\">\n    <mat-label> 内容 </mat-label>\n    <textarea\n      matInput\n      type=\"text\"\n      [(ngModel)]=\"schedule.content\"\n      name=\"content\"\n      cdkTextareaAutosize\n      cdkAutosizeMinRows=\"3\"\n      required\n    ></textarea>\n  </mat-form-field>\n  <div class=\"flex flex-row gap-3\">\n    <mat-form-field appearance=\"fill\">\n      <mat-label>开始日期</mat-label>\n      <input\n        matInput\n        [matDatepicker]=\"picker\"\n        (focus)=\"picker.open()\"\n        name=\"startAt\"\n        [(ngModel)]=\"schedule.startDate\"\n        (ngModelChange)=\"startDateChanged($event)\"\n        (dateInput)=\"schedule.startDate = $event.value.format('YYYY-MM-DD')\"\n        readonly\n        required\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </mat-form-field>\n    <mat-form-field appearance=\"fill\">\n      <mat-label>开始时间</mat-label>\n      <mat-select [(ngModel)]=\"schedule.startTime\" (selectionChange)=\"startTimeChanged($event)\" required readonly>\n        @for (d of date; track d) {\n          <mat-option [value]=\"d\">\n            {{ d }}\n          </mat-option>\n        }\n      </mat-select>\n    </mat-form-field>\n  </div>\n  <div class=\"flex flex-row gap-3\">\n    <mat-form-field appearance=\"fill\">\n      <mat-label>结束日期</mat-label>\n      <input\n        matInput\n        [matDatepicker]=\"picker2\"\n        name=\"endAt\"\n        (focus)=\"picker2.open()\"\n        (ngModelChange)=\"endDateChanged($event)\"\n        [(ngModel)]=\"schedule.endDate\"\n        (dateInput)=\"schedule.endDate = $event.value.format('YYYY-MM-DD')\"\n        readonly\n        required\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n      <mat-datepicker #picker2></mat-datepicker>\n    </mat-form-field>\n    <mat-form-field appearance=\"fill\">\n      <mat-label>结束时间</mat-label>\n      <mat-select [(ngModel)]=\"schedule.endTime\" (selectionChange)=\"endTimeChanged($event)\" required readonly>\n        @for (d of date; track d) {\n          <mat-option [value]=\"d\">\n            {{ d }}\n          </mat-option>\n        }\n      </mat-select>\n    </mat-form-field>\n  </div>\n</div>\n@if (actions()) {\n  <div class=\"flex flex-row justify-end p-3 gap-3\">\n    <button mat-button class=\"max-h-8\" (click)=\"onDelete(schedule)\">删除</button>\n    <button mat-flat-button class=\"max-h-8\" (click)=\"onSave(schedule)\">保存</button>\n  </div>\n}\n<mat-divider></mat-divider>\n"]}
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schedule-item.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-course/src/lib/components/schedule-item/schedule-item.component.ts","../../../../../../../libs/angular-course/src/lib/components/schedule-item/schedule-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MomentDateAdapter } from '@angular/material-moment-adapter';\nimport { Component, OnInit, OnDestroy, output, model, input, effect, computed } from '@angular/core';\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE, MatOptionModule } from '@angular/material/core';\nimport moment from 'moment';\nimport { DatePipe, NgClass } from '@angular/common';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { TextFieldModule } from '@angular/cdk/text-field';\nimport { FormsModule } from '@angular/forms';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { Schedule, ScheduleDate } from '../../interfaces';\nexport const COURSE_SCHEDULE_DATE_FORMATS = {\n  parse: {\n    dateInput: 'YYYY-MM-DD',\n  },\n  display: {\n    dateInput: 'YYYY-MM-DD',\n    monthYearLabel: 'MMM YYYY',\n    dateA11yLabel: 'YYYY-MM-DD',\n    monthYearA11yLabel: 'MMMM YYYY',\n  },\n};\n\n@Component({\n  selector: 'rolatech-schedule-item',\n  templateUrl: './schedule-item.component.html',\n  styleUrls: ['./schedule-item.component.scss'],\n  providers: [\n    {\n      provide: DateAdapter,\n      useClass: MomentDateAdapter,\n      deps: [MAT_DATE_LOCALE],\n    },\n    { provide: MAT_DATE_FORMATS, useValue: COURSE_SCHEDULE_DATE_FORMATS },\n    DatePipe,\n  ],\n  standalone: true,\n  imports: [\n    NgClass,\n    MatFormFieldModule,\n    MatInputModule,\n    FormsModule,\n    TextFieldModule,\n    MatDatepickerModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatButtonModule,\n    MatDividerModule,\n  ],\n})\nexport class ScheduleItemComponent implements OnInit, OnDestroy {\n  value = input<Schedule | undefined>();\n  actions = input<boolean>(false);\n  delete = output<Schedule>();\n  save = output<Schedule>();\n  date = ScheduleDate;\n  schedule: any = effect(() => {\n    this.schedule = this.value() || {\n      title: '',\n      content: '',\n      startAt: '',\n      endAt: '',\n    };\n    this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');\n    this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');\n    this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');\n    this.schedule.endTime = moment(this.schedule.endAt).format('HH:mm');\n  });\n  // constructor() {\n  //   this.schedule = this.value();\n  // }\n\n  ngOnInit(): void {\n    // this.schedule = computed(() => {\n    //   console.log(this.value());\n    //   return this.value();\n    // })();\n    // this.schedule = this.value();\n    // this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');\n    // this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');\n    // this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');\n    // this.schedule.endTime = moment(this.schedule.endAt).format('HH:mm');\n  }\n  ngOnDestroy(): void {\n    const { startAt, endAt, startTime, startDate, endDate, endTime } = this.schedule;\n    this.schedule.startAt = this.schedule.startDate + ' ' + this.schedule.startTime;\n    this.schedule.endAt = this.schedule.endDate + ' ' + this.schedule.endTime;\n    delete this.schedule.startDate;\n    delete this.schedule.startTime;\n    delete this.schedule.endDate;\n    delete this.schedule.endTime;\n  }\n  startDateChanged(event: any) {}\n  startTimeChanged(event: any) {}\n\n  endDateChanged(event: any) {}\n  endTimeChanged(event: any) {}\n\n  onSave(schedule: Schedule) {\n    this.format();\n    this.save.emit(schedule);\n  }\n  onDelete(schedule: Schedule) {\n    this.delete.emit(schedule);\n  }\n  private format() {\n    this.schedule.startAt = this.schedule.startDate + ' ' + this.schedule.startTime;\n    this.schedule.endAt = this.schedule.endDate + ' ' + this.schedule.endTime;\n  }\n}\n","<div class=\"flex flex-col py-3\">\n  <mat-form-field appearance=\"fill\">\n    <mat-label> 标题 </mat-label>\n    <input matInput type=\"text\" [(ngModel)]=\"schedule.title\" name=\"title\" required />\n  </mat-form-field>\n  <mat-form-field appearance=\"fill\">\n    <mat-label> 内容 </mat-label>\n    <textarea\n      matInput\n      type=\"text\"\n      [(ngModel)]=\"schedule.content\"\n      name=\"content\"\n      cdkTextareaAutosize\n      cdkAutosizeMinRows=\"3\"\n      required\n    ></textarea>\n  </mat-form-field>\n  <div class=\"flex flex-row gap-3\">\n    <mat-form-field appearance=\"fill\">\n      <mat-label>开始日期</mat-label>\n      <input\n        matInput\n        [matDatepicker]=\"picker\"\n        (focus)=\"picker.open()\"\n        name=\"startAt\"\n        [(ngModel)]=\"schedule.startDate\"\n        (ngModelChange)=\"startDateChanged($event)\"\n        (dateInput)=\"schedule.startDate = $event.value.format('YYYY-MM-DD')\"\n        readonly\n        required\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n      <mat-datepicker #picker></mat-datepicker>\n    </mat-form-field>\n    <mat-form-field appearance=\"fill\">\n      <mat-label>开始时间</mat-label>\n      <mat-select [(ngModel)]=\"schedule.startTime\" (selectionChange)=\"startTimeChanged($event)\" required readonly>\n        @for (d of date; track d) {\n          <mat-option [value]=\"d\">\n            {{ d }}\n          </mat-option>\n        }\n      </mat-select>\n    </mat-form-field>\n  </div>\n  <div class=\"flex flex-row gap-3\">\n    <mat-form-field appearance=\"fill\">\n      <mat-label>结束日期</mat-label>\n      <input\n        matInput\n        [matDatepicker]=\"picker2\"\n        name=\"endAt\"\n        (focus)=\"picker2.open()\"\n        (ngModelChange)=\"endDateChanged($event)\"\n        [(ngModel)]=\"schedule.endDate\"\n        (dateInput)=\"schedule.endDate = $event.value.format('YYYY-MM-DD')\"\n        readonly\n        required\n      />\n      <mat-datepicker-toggle matIconSuffix [for]=\"picker2\"></mat-datepicker-toggle>\n      <mat-datepicker #picker2></mat-datepicker>\n    </mat-form-field>\n    <mat-form-field appearance=\"fill\">\n      <mat-label>结束时间</mat-label>\n      <mat-select [(ngModel)]=\"schedule.endTime\" (selectionChange)=\"endTimeChanged($event)\" required readonly>\n        @for (d of date; track d) {\n          <mat-option [value]=\"d\">\n            {{ d }}\n          </mat-option>\n        }\n      </mat-select>\n    </mat-form-field>\n  </div>\n</div>\n@if (actions()) {\n  <div class=\"flex flex-row justify-end p-3 gap-3\">\n    <button mat-button class=\"max-h-8\" (click)=\"onDelete(schedule)\">删除</button>\n    <button mat-flat-button class=\"max-h-8\" (click)=\"onSave(schedule)\">保存</button>\n  </div>\n}\n<mat-divider></mat-divider>\n"]}
|
package/esm2022/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.mjs
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
import { Component, inject } from '@angular/core';
|
|
2
|
-
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
3
2
|
import { remove } from 'lodash';
|
|
4
3
|
import { MatIconModule } from '@angular/material/icon';
|
|
5
4
|
import { MatButtonModule } from '@angular/material/button';
|
|
6
5
|
import { BaseComponent, ConfirmationDialogComponent, ToolbarComponent } from '@rolatech/angular-components';
|
|
7
6
|
import { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';
|
|
8
|
-
import { ScheduleItemComponent } from '../../../components';
|
|
7
|
+
import { ScheduleItemComponent, CourseScheduleAddDialogComponent } from '../../../components';
|
|
9
8
|
import { CourseStatus, CourseType } from '../../../interfaces';
|
|
10
9
|
import { CourseService } from '../../../services';
|
|
11
10
|
import * as i0 from "@angular/core";
|
|
@@ -15,7 +14,6 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
15
14
|
constructor() {
|
|
16
15
|
super(...arguments);
|
|
17
16
|
this.courseService = inject(CourseService);
|
|
18
|
-
this.snackBar = inject(MatSnackBar);
|
|
19
17
|
this.isLoading = false;
|
|
20
18
|
this.schedule = [];
|
|
21
19
|
this.status = CourseStatus;
|
|
@@ -40,15 +38,8 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
40
38
|
title: '添加课表',
|
|
41
39
|
cancelText: '取消',
|
|
42
40
|
confirmText: '确认',
|
|
43
|
-
component:
|
|
44
|
-
data: {
|
|
45
|
-
schedule: {
|
|
46
|
-
title: '',
|
|
47
|
-
content: '',
|
|
48
|
-
startAt: '',
|
|
49
|
-
endAt: '',
|
|
50
|
-
},
|
|
51
|
-
},
|
|
41
|
+
component: CourseScheduleAddDialogComponent,
|
|
42
|
+
data: {},
|
|
52
43
|
};
|
|
53
44
|
this.dialogService.open(options);
|
|
54
45
|
this.dialogService.confirmed().subscribe({
|
|
@@ -57,10 +48,10 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
57
48
|
this.courseService.addSchedule(this.id, schedule).subscribe({
|
|
58
49
|
next: (res) => {
|
|
59
50
|
this.schedule.push(res.data);
|
|
60
|
-
this.
|
|
51
|
+
this.snackBarService.open('添加成功');
|
|
61
52
|
},
|
|
62
53
|
error: (error) => {
|
|
63
|
-
this.
|
|
54
|
+
this.snackBarService.open(error.message);
|
|
64
55
|
},
|
|
65
56
|
});
|
|
66
57
|
}
|
|
@@ -86,10 +77,10 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
86
77
|
if (result) {
|
|
87
78
|
this.courseService.addSchedule(this.id, { schedule: result }).subscribe({
|
|
88
79
|
next: (res) => {
|
|
89
|
-
this.
|
|
80
|
+
this.snackBarService.open('编辑成功');
|
|
90
81
|
},
|
|
91
82
|
error: (error) => {
|
|
92
|
-
this.
|
|
83
|
+
this.snackBarService.open(error.message);
|
|
93
84
|
},
|
|
94
85
|
});
|
|
95
86
|
}
|
|
@@ -99,10 +90,10 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
99
90
|
onScheduleSave(schedule) {
|
|
100
91
|
this.courseService.updateSchedule(this.id, schedule.id, schedule).subscribe({
|
|
101
92
|
next: (res) => {
|
|
102
|
-
this.
|
|
93
|
+
this.snackBarService.open('保存成功');
|
|
103
94
|
},
|
|
104
95
|
error: (e) => {
|
|
105
|
-
this.
|
|
96
|
+
this.snackBarService.open(e.message);
|
|
106
97
|
},
|
|
107
98
|
});
|
|
108
99
|
}
|
|
@@ -121,10 +112,10 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
121
112
|
remove(this.schedule, {
|
|
122
113
|
id: schedule.id,
|
|
123
114
|
});
|
|
124
|
-
this.
|
|
115
|
+
this.snackBarService.open(res.data);
|
|
125
116
|
},
|
|
126
117
|
error: (e) => {
|
|
127
|
-
this.
|
|
118
|
+
this.snackBarService.open(e.message);
|
|
128
119
|
},
|
|
129
120
|
});
|
|
130
121
|
}
|
|
@@ -137,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
137
128
|
type: Component,
|
|
138
129
|
args: [{ selector: 'rolatech-course-manage-schedule', standalone: true, imports: [ScheduleItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent], template: "<rolatech-course-manage-content>\n <rolatech-toolbar title=\"\u8BFE\u7A0B\u8868\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (item of schedule; track item) {\n <rolatech-schedule-item\n [value]=\"item\"\n [actions]=\"true\"\n (save)=\"onScheduleSave($event)\"\n (delete)=\"onScheduleDelete($event)\"\n >\n </rolatech-schedule-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addSchedule()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u589E\u52A0\u8BFE\u8868</span>\n </button>\n </div>\n</rolatech-course-manage-content>\n" }]
|
|
139
130
|
}] });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-manage-schedule.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.ts","../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { remove } from 'lodash';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { BaseComponent, ConfirmationDialogComponent, ToolbarComponent } from '@rolatech/angular-components';\nimport { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';\nimport { ScheduleItemComponent, CourseScheduleAddDialogComponent, CourseScheduleDialogComponent } from '../../../components';\nimport { Schedule, CourseStatus, CourseType } from '../../../interfaces';\nimport { CourseService } from '../../../services';\n\n@Component({\n  selector: 'rolatech-course-manage-schedule',\n  templateUrl: './course-manage-schedule.component.html',\n  styleUrls: ['./course-manage-schedule.component.scss'],\n  standalone: true,\n  imports: [ScheduleItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent],\n})\nexport class CourseManageScheduleComponent extends BaseComponent implements OnInit {\n  courseService = inject(CourseService);\n  snackBar = inject(MatSnackBar);\n  isLoading = false;\n  schedule: Schedule[] = [];\n  status = CourseStatus;\n  courseType: any = CourseType;\n  ngOnInit(): void {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n    this.find();\n  }\n  find() {\n    this.courseService.findSchedule(this.id).subscribe({\n      next: (res) => {\n        if (res.data) {\n          this.schedule = res.data;\n        }\n      },\n    });\n  }\n  addSchedule() {\n    const options = {\n      width: '500px',\n      title: '添加课表',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: ScheduleItemComponent,\n      data: {\n        schedule: {\n          title: '',\n          content: '',\n          startAt: '',\n          endAt: '',\n        },\n      },\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe({\n      next: (schedule) => {\n        if (schedule) {\n          this.courseService.addSchedule(this.id, schedule).subscribe({\n            next: (res) => {\n              this.schedule.push(res.data);\n              this.snackBar.open('添加成功');\n            },\n            error: (error) => {\n              this.snackBar.open(error.message);\n            },\n          });\n        }\n      },\n    });\n  }\n  editSchedule() {\n    const options = {\n      width: '500px',\n      height: '90%',\n      title: '编辑课表',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: ScheduleItemComponent,\n      data: {\n        courseId: this.id,\n        schedule: this.schedule,\n      },\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe({\n      next: (result) => {\n        if (result) {\n          this.courseService.addSchedule(this.id, { schedule: result }).subscribe({\n            next: (res) => {\n              this.snackBar.open('编辑成功');\n            },\n            error: (error) => {\n              this.snackBar.open(error.message);\n            },\n          });\n        }\n      },\n    });\n  }\n  onScheduleSave(schedule: Schedule | any) {\n    this.courseService.updateSchedule(this.id, schedule.id, schedule).subscribe({\n      next: (res: any) => {\n        this.snackBar.open('保存成功');\n      },\n      error: (e) => {\n        this.snackBar.open(e.message);\n      },\n    });\n  }\n  onScheduleDelete(schedule: Schedule | any) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除课表',\n        message: '确定删除此课表吗?',\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.courseService.deleteSchedule(this.id, schedule.id).subscribe({\n          next: (res: any) => {\n            remove(this.schedule, {\n              id: schedule.id,\n            });\n            this.snackBar.open(res.data);\n          },\n          error: (e) => {\n            this.snackBar.open(e.message);\n          },\n        });\n      }\n    });\n  }\n}\n","<rolatech-course-manage-content>\n  <rolatech-toolbar title=\"课程表\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n  <div>\n    <div>\n      @for (item of schedule; track item) {\n        <rolatech-schedule-item\n          [value]=\"item\"\n          [actions]=\"true\"\n          (save)=\"onScheduleSave($event)\"\n          (delete)=\"onScheduleDelete($event)\"\n        >\n        </rolatech-schedule-item>\n      }\n    </div>\n    <button mat-stroked-button (click)=\"addSchedule()\" class=\"mt-3\">\n      <mat-icon>add</mat-icon>\n      <span>增加课表</span>\n    </button>\n  </div>\n</rolatech-course-manage-content>\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-manage-schedule.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.ts","../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject } from '@angular/core';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { remove } from 'lodash';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { BaseComponent, ConfirmationDialogComponent, ToolbarComponent } from '@rolatech/angular-components';\nimport { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';\nimport { ScheduleItemComponent, CourseScheduleAddDialogComponent, CourseScheduleDialogComponent } from '../../../components';\nimport { Schedule, CourseStatus, CourseType } from '../../../interfaces';\nimport { CourseService } from '../../../services';\n\n@Component({\n  selector: 'rolatech-course-manage-schedule',\n  templateUrl: './course-manage-schedule.component.html',\n  styleUrls: ['./course-manage-schedule.component.scss'],\n  standalone: true,\n  imports: [ScheduleItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent],\n})\nexport class CourseManageScheduleComponent extends BaseComponent implements OnInit {\n  courseService = inject(CourseService);\n  isLoading = false;\n  schedule: Schedule[] = [];\n  status = CourseStatus;\n  courseType: any = CourseType;\n  ngOnInit(): void {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n    this.find();\n  }\n  find() {\n    this.courseService.findSchedule(this.id).subscribe({\n      next: (res) => {\n        if (res.data) {\n          this.schedule = res.data;\n        }\n      },\n    });\n  }\n  addSchedule() {\n    const options = {\n      width: '500px',\n      title: '添加课表',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: CourseScheduleAddDialogComponent,\n      data: {},\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe({\n      next: (schedule) => {\n        if (schedule) {\n          this.courseService.addSchedule(this.id, schedule).subscribe({\n            next: (res) => {\n              this.schedule.push(res.data);\n              this.snackBarService.open('添加成功');\n            },\n            error: (error) => {\n              this.snackBarService.open(error.message);\n            },\n          });\n        }\n      },\n    });\n  }\n  editSchedule() {\n    const options = {\n      width: '500px',\n      height: '90%',\n      title: '编辑课表',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: ScheduleItemComponent,\n      data: {\n        courseId: this.id,\n        schedule: this.schedule,\n      },\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe({\n      next: (result) => {\n        if (result) {\n          this.courseService.addSchedule(this.id, { schedule: result }).subscribe({\n            next: (res) => {\n              this.snackBarService.open('编辑成功');\n            },\n            error: (error) => {\n              this.snackBarService.open(error.message);\n            },\n          });\n        }\n      },\n    });\n  }\n  onScheduleSave(schedule: Schedule | any) {\n    this.courseService.updateSchedule(this.id, schedule.id, schedule).subscribe({\n      next: (res: any) => {\n        this.snackBarService.open('保存成功');\n      },\n      error: (e) => {\n        this.snackBarService.open(e.message);\n      },\n    });\n  }\n  onScheduleDelete(schedule: Schedule | any) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除课表',\n        message: '确定删除此课表吗?',\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.courseService.deleteSchedule(this.id, schedule.id).subscribe({\n          next: (res: any) => {\n            remove(this.schedule, {\n              id: schedule.id,\n            });\n            this.snackBarService.open(res.data);\n          },\n          error: (e) => {\n            this.snackBarService.open(e.message);\n          },\n        });\n      }\n    });\n  }\n}\n","<rolatech-course-manage-content>\n  <rolatech-toolbar title=\"课程表\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n  <div>\n    <div>\n      @for (item of schedule; track item) {\n        <rolatech-schedule-item\n          [value]=\"item\"\n          [actions]=\"true\"\n          (save)=\"onScheduleSave($event)\"\n          (delete)=\"onScheduleDelete($event)\"\n        >\n        </rolatech-schedule-item>\n      }\n    </div>\n    <button mat-stroked-button (click)=\"addSchedule()\" class=\"mt-3\">\n      <mat-icon>add</mat-icon>\n      <span>增加课表</span>\n    </button>\n  </div>\n</rolatech-course-manage-content>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { inject, Component } from '@angular/core';
|
|
3
|
-
import { C as CourseService, a as CategoryService } from './rolatech-angular-course-rolatech-angular-course-
|
|
3
|
+
import { C as CourseService, a as CategoryService } from './rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs';
|
|
4
4
|
import { AngularCommonModule } from '@rolatech/angular-common';
|
|
5
5
|
import { BaseComponent, AngularComponentsModule } from '@rolatech/angular-components';
|
|
6
6
|
import * as i1 from '@angular/router';
|
|
@@ -68,12 +68,12 @@ class CourseIndexComponent extends BaseComponent {
|
|
|
68
68
|
});
|
|
69
69
|
}
|
|
70
70
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseIndexComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseIndexComponent, isStandalone: true, selector: "rolatech-course-index", usesInheritance: true, ngImport: i0, template: "<div class=\"min-w-[320px] max-w-[1120px] m-auto\">\n <div class=\"p-3 hidden md:block text-2xl font-medium\">\u5168\u90E8\u8BFE\u7A0B</div>\n @if (loading) {\n @for (number of [0, 1, 2, 3, 4, 5]; track number) {\n <div class=\"flex flex-row animate-pulse mt-3 mr-4 cursor-pointer w-full\">\n <div class=\"h-fit w-2/5 md:w-1/4 aspect-video hover:bg-[--rt-base-background] rounded-lg\"></div>\n <div class=\"w-3/5 md:w-3/4 ml-3 py-1 flex flex-col justify-between\">\n <div class=\"space-y-3\">\n <div class=\"h-4 bg-[--rt-base-background] rounded col-span-2\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1 py-1\"></div>\n </div>\n <div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-2 py-1\"></div>\n </div>\n </div>\n </div>\n }\n } @else {\n @for (item of courses; track $index) {\n <div\n class=\"py-2 cursor-pointer min-w-[80%] md:min-w-[33%] hover:bg-[--rt-base-background]\"\n [routerLink]=\"['./', item.id]\"\n >\n @defer {\n <rolatech-course-item [course]=\"item\"></rolatech-course-item>\n }\n </div>\n }\n }\n</div>\n", styles: ["img:before{border-radius:12px}\n"], dependencies: [{ kind: "ngmodule", type: AngularCommonModule }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: AngularComponentsModule }], deferBlockDependencies: [() => [import('./rolatech-angular-course-rolatech-angular-course-
|
|
71
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseIndexComponent, isStandalone: true, selector: "rolatech-course-index", usesInheritance: true, ngImport: i0, template: "<div class=\"min-w-[320px] max-w-[1120px] m-auto\">\n <div class=\"p-3 hidden md:block text-2xl font-medium\">\u5168\u90E8\u8BFE\u7A0B</div>\n @if (loading) {\n @for (number of [0, 1, 2, 3, 4, 5]; track number) {\n <div class=\"flex flex-row animate-pulse mt-3 mr-4 cursor-pointer w-full\">\n <div class=\"h-fit w-2/5 md:w-1/4 aspect-video hover:bg-[--rt-base-background] rounded-lg\"></div>\n <div class=\"w-3/5 md:w-3/4 ml-3 py-1 flex flex-col justify-between\">\n <div class=\"space-y-3\">\n <div class=\"h-4 bg-[--rt-base-background] rounded col-span-2\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1 py-1\"></div>\n </div>\n <div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-2 py-1\"></div>\n </div>\n </div>\n </div>\n }\n } @else {\n @for (item of courses; track $index) {\n <div\n class=\"py-2 cursor-pointer min-w-[80%] md:min-w-[33%] hover:bg-[--rt-base-background]\"\n [routerLink]=\"['./', item.id]\"\n >\n @defer {\n <rolatech-course-item [course]=\"item\"></rolatech-course-item>\n }\n </div>\n }\n }\n</div>\n", styles: ["img:before{border-radius:12px}\n"], dependencies: [{ kind: "ngmodule", type: AngularCommonModule }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: AngularComponentsModule }], deferBlockDependencies: [() => [import('./rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs').then(function (n) { return n.G; }).then(m => m.CourseItemComponent)]] }); }
|
|
72
72
|
}
|
|
73
|
-
i0.ɵɵngDeclareClassMetadataAsync({ minVersion: "18.0.0", version: "18.0.2", ngImport: i0, type: CourseIndexComponent, resolveDeferredDeps: () => [import('./rolatech-angular-course-rolatech-angular-course-
|
|
73
|
+
i0.ɵɵngDeclareClassMetadataAsync({ minVersion: "18.0.0", version: "18.0.2", ngImport: i0, type: CourseIndexComponent, resolveDeferredDeps: () => [import('./rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs').then(function (n) { return n.G; }).then(m => m.CourseItemComponent)], resolveMetadata: CourseItemComponent => ({ decorators: [{
|
|
74
74
|
type: Component,
|
|
75
75
|
args: [{ standalone: true, imports: [AngularCommonModule, AngularComponentsModule, CourseItemComponent], selector: 'rolatech-course-index', template: "<div class=\"min-w-[320px] max-w-[1120px] m-auto\">\n <div class=\"p-3 hidden md:block text-2xl font-medium\">\u5168\u90E8\u8BFE\u7A0B</div>\n @if (loading) {\n @for (number of [0, 1, 2, 3, 4, 5]; track number) {\n <div class=\"flex flex-row animate-pulse mt-3 mr-4 cursor-pointer w-full\">\n <div class=\"h-fit w-2/5 md:w-1/4 aspect-video hover:bg-[--rt-base-background] rounded-lg\"></div>\n <div class=\"w-3/5 md:w-3/4 ml-3 py-1 flex flex-col justify-between\">\n <div class=\"space-y-3\">\n <div class=\"h-4 bg-[--rt-base-background] rounded col-span-2\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1 py-1\"></div>\n </div>\n <div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-2 py-1\"></div>\n </div>\n </div>\n </div>\n }\n } @else {\n @for (item of courses; track $index) {\n <div\n class=\"py-2 cursor-pointer min-w-[80%] md:min-w-[33%] hover:bg-[--rt-base-background]\"\n [routerLink]=\"['./', item.id]\"\n >\n @defer {\n <rolatech-course-item [course]=\"item\"></rolatech-course-item>\n }\n </div>\n }\n }\n</div>\n", styles: ["img:before{border-radius:12px}\n"] }]
|
|
76
76
|
}], ctorParameters: null, propDecorators: null }) });
|
|
77
77
|
|
|
78
78
|
export { CourseIndexComponent };
|
|
79
|
-
//# sourceMappingURL=rolatech-angular-course-course-index.component-
|
|
79
|
+
//# sourceMappingURL=rolatech-angular-course-course-index.component-D339dt6A.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rolatech-angular-course-course-index.component-
|
|
1
|
+
{"version":3,"file":"rolatech-angular-course-course-index.component-D339dt6A.mjs","sources":["../../../../libs/angular-course/src/lib/pages/course/course-index/course-index.component.ts","../../../../libs/angular-course/src/lib/pages/course/course-index/course-index.component.html"],"sourcesContent":["import { Component, inject, OnInit } from '@angular/core';\nimport { CourseCategory, Course } from '../../../interfaces';\nimport { CategoryService, CourseService } from '../../../services';\nimport { AngularCommonModule } from '@rolatech/angular-common';\nimport { AngularComponentsModule, BaseComponent } from '@rolatech/angular-components';\nimport { CourseItemComponent } from '../../../components/course-item/course-item.component';\n\n@Component({\n standalone: true,\n imports: [AngularCommonModule, AngularComponentsModule, CourseItemComponent],\n selector: 'rolatech-course-index',\n templateUrl: './course-index.component.html',\n styleUrls: ['./course-index.component.scss'],\n})\nexport class CourseIndexComponent extends BaseComponent implements OnInit {\n courses: Course[] = [];\n categories: CourseCategory[] = [];\n courseService = inject(CourseService);\n categoryService = inject(CategoryService);\n meta: any;\n loading = false;\n\n ngOnInit(): void {\n this.findCategories();\n this.findCourses();\n this.titleService.setTitle('课程 - 拼小课');\n }\n findCourses() {\n this.loading = true;\n const options = {\n sort: 'updatedAt desc',\n filter: 'published:true',\n };\n this.courseService.find(options).subscribe({\n next: (res: any) => {\n this.courses = res.data;\n this.meta = res.meta;\n this.loading = false;\n },\n error: (error) => {\n this.loading = false;\n },\n });\n }\n findCategories() {\n this.categoryService.find({}).subscribe({\n next: (res: any) => {\n this.categories = res.data;\n },\n });\n }\n}\n","<div class=\"min-w-[320px] max-w-[1120px] m-auto\">\n <div class=\"p-3 hidden md:block text-2xl font-medium\">全部课程</div>\n @if (loading) {\n @for (number of [0, 1, 2, 3, 4, 5]; track number) {\n <div class=\"flex flex-row animate-pulse mt-3 mr-4 cursor-pointer w-full\">\n <div class=\"h-fit w-2/5 md:w-1/4 aspect-video hover:bg-[--rt-base-background] rounded-lg\"></div>\n <div class=\"w-3/5 md:w-3/4 ml-3 py-1 flex flex-col justify-between\">\n <div class=\"space-y-3\">\n <div class=\"h-4 bg-[--rt-base-background] rounded col-span-2\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1\"></div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-1 py-1\"></div>\n </div>\n <div>\n <div class=\"h-2 bg-[--rt-base-background] rounded col-span-2 py-1\"></div>\n </div>\n </div>\n </div>\n }\n } @else {\n @for (item of courses; track $index) {\n <div\n class=\"py-2 cursor-pointer min-w-[80%] md:min-w-[33%] hover:bg-[--rt-base-background]\"\n [routerLink]=\"['./', item.id]\"\n >\n @defer {\n <rolatech-course-item [course]=\"item\"></rolatech-course-item>\n }\n </div>\n }\n }\n</div>\n"],"names":[],"mappings":"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"}
|
|
@@ -729,7 +729,12 @@ class ScheduleItemComponent {
|
|
|
729
729
|
this.save = output();
|
|
730
730
|
this.date = ScheduleDate;
|
|
731
731
|
this.schedule = effect(() => {
|
|
732
|
-
this.schedule = this.value()
|
|
732
|
+
this.schedule = this.value() || {
|
|
733
|
+
title: '',
|
|
734
|
+
content: '',
|
|
735
|
+
startAt: '',
|
|
736
|
+
endAt: '',
|
|
737
|
+
};
|
|
733
738
|
this.schedule.startDate = moment(this.schedule.startAt).format('YYYY-MM-DD');
|
|
734
739
|
this.schedule.startTime = moment(this.schedule.startAt).format('HH:mm');
|
|
735
740
|
this.schedule.endDate = moment(this.schedule.endAt).format('YYYY-MM-DD');
|
|
@@ -1090,9 +1095,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
1090
1095
|
}] }] });
|
|
1091
1096
|
|
|
1092
1097
|
class CourseScheduleAddDialogComponent {
|
|
1093
|
-
constructor(
|
|
1094
|
-
this.
|
|
1095
|
-
this.data = data;
|
|
1098
|
+
constructor() {
|
|
1099
|
+
this.output = output();
|
|
1096
1100
|
this.schedule = {
|
|
1097
1101
|
title: '',
|
|
1098
1102
|
content: '',
|
|
@@ -1100,19 +1104,16 @@ class CourseScheduleAddDialogComponent {
|
|
|
1100
1104
|
endAt: '',
|
|
1101
1105
|
};
|
|
1102
1106
|
}
|
|
1103
|
-
|
|
1104
|
-
this.
|
|
1107
|
+
ngDoCheck() {
|
|
1108
|
+
this.output.emit(this.schedule);
|
|
1105
1109
|
}
|
|
1106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, deps: [
|
|
1107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
1110
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1111
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: CourseScheduleAddDialogComponent, isStandalone: true, selector: "rolatech-course-schedule-add-dialog", outputs: { output: "output" }, ngImport: i0, template: "<div class=\"flex flex-col h-full\">\n <div class=\"flex-1 overflow-y-auto max-h-[55vh] px-3\">\n <rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: ScheduleItemComponent, selector: "rolatech-schedule-item", inputs: ["value", "actions"], outputs: ["delete", "save"] }, { kind: "ngmodule", type: MatButtonModule }] }); }
|
|
1108
1112
|
}
|
|
1109
1113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, decorators: [{
|
|
1110
1114
|
type: Component,
|
|
1111
|
-
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule
|
|
1112
|
-
}]
|
|
1113
|
-
type: Inject,
|
|
1114
|
-
args: [MAT_DIALOG_DATA]
|
|
1115
|
-
}] }] });
|
|
1115
|
+
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule], template: "<div class=\"flex flex-col h-full\">\n <div class=\"flex-1 overflow-y-auto max-h-[55vh] px-3\">\n <rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\n </div>\n</div>\n" }]
|
|
1116
|
+
}] });
|
|
1116
1117
|
|
|
1117
1118
|
class CoursePricingDialogComponent {
|
|
1118
1119
|
constructor(dialogRef, data, courseService, snackBar, dialog) {
|
|
@@ -1927,7 +1928,7 @@ const courseRoutes = [
|
|
|
1927
1928
|
children: [
|
|
1928
1929
|
{
|
|
1929
1930
|
path: '',
|
|
1930
|
-
loadComponent: () => import('./rolatech-angular-course-course-index.component-
|
|
1931
|
+
loadComponent: () => import('./rolatech-angular-course-course-index.component-D339dt6A.mjs').then((x) => x.CourseIndexComponent),
|
|
1931
1932
|
},
|
|
1932
1933
|
{
|
|
1933
1934
|
path: 'categories/:id',
|
|
@@ -2106,7 +2107,6 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2106
2107
|
constructor() {
|
|
2107
2108
|
super(...arguments);
|
|
2108
2109
|
this.courseService = inject(CourseService);
|
|
2109
|
-
this.snackBar = inject(MatSnackBar);
|
|
2110
2110
|
this.isLoading = false;
|
|
2111
2111
|
this.schedule = [];
|
|
2112
2112
|
this.status = CourseStatus;
|
|
@@ -2131,15 +2131,8 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2131
2131
|
title: '添加课表',
|
|
2132
2132
|
cancelText: '取消',
|
|
2133
2133
|
confirmText: '确认',
|
|
2134
|
-
component:
|
|
2135
|
-
data: {
|
|
2136
|
-
schedule: {
|
|
2137
|
-
title: '',
|
|
2138
|
-
content: '',
|
|
2139
|
-
startAt: '',
|
|
2140
|
-
endAt: '',
|
|
2141
|
-
},
|
|
2142
|
-
},
|
|
2134
|
+
component: CourseScheduleAddDialogComponent,
|
|
2135
|
+
data: {},
|
|
2143
2136
|
};
|
|
2144
2137
|
this.dialogService.open(options);
|
|
2145
2138
|
this.dialogService.confirmed().subscribe({
|
|
@@ -2148,10 +2141,10 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2148
2141
|
this.courseService.addSchedule(this.id, schedule).subscribe({
|
|
2149
2142
|
next: (res) => {
|
|
2150
2143
|
this.schedule.push(res.data);
|
|
2151
|
-
this.
|
|
2144
|
+
this.snackBarService.open('添加成功');
|
|
2152
2145
|
},
|
|
2153
2146
|
error: (error) => {
|
|
2154
|
-
this.
|
|
2147
|
+
this.snackBarService.open(error.message);
|
|
2155
2148
|
},
|
|
2156
2149
|
});
|
|
2157
2150
|
}
|
|
@@ -2177,10 +2170,10 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2177
2170
|
if (result) {
|
|
2178
2171
|
this.courseService.addSchedule(this.id, { schedule: result }).subscribe({
|
|
2179
2172
|
next: (res) => {
|
|
2180
|
-
this.
|
|
2173
|
+
this.snackBarService.open('编辑成功');
|
|
2181
2174
|
},
|
|
2182
2175
|
error: (error) => {
|
|
2183
|
-
this.
|
|
2176
|
+
this.snackBarService.open(error.message);
|
|
2184
2177
|
},
|
|
2185
2178
|
});
|
|
2186
2179
|
}
|
|
@@ -2190,10 +2183,10 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2190
2183
|
onScheduleSave(schedule) {
|
|
2191
2184
|
this.courseService.updateSchedule(this.id, schedule.id, schedule).subscribe({
|
|
2192
2185
|
next: (res) => {
|
|
2193
|
-
this.
|
|
2186
|
+
this.snackBarService.open('保存成功');
|
|
2194
2187
|
},
|
|
2195
2188
|
error: (e) => {
|
|
2196
|
-
this.
|
|
2189
|
+
this.snackBarService.open(e.message);
|
|
2197
2190
|
},
|
|
2198
2191
|
});
|
|
2199
2192
|
}
|
|
@@ -2212,10 +2205,10 @@ class CourseManageScheduleComponent extends BaseComponent {
|
|
|
2212
2205
|
remove(this.schedule, {
|
|
2213
2206
|
id: schedule.id,
|
|
2214
2207
|
});
|
|
2215
|
-
this.
|
|
2208
|
+
this.snackBarService.open(res.data);
|
|
2216
2209
|
},
|
|
2217
2210
|
error: (e) => {
|
|
2218
|
-
this.
|
|
2211
|
+
this.snackBarService.open(e.message);
|
|
2219
2212
|
},
|
|
2220
2213
|
});
|
|
2221
2214
|
}
|
|
@@ -3051,4 +3044,4 @@ const courseManageRoutes = [
|
|
|
3051
3044
|
*/
|
|
3052
3045
|
|
|
3053
3046
|
export { CourseDetailsComponent as A, CourseMediaOwnerRendererComponent as B, CourseService as C, CourseSectionLectureVideoDialogComponent as D, ScheduleItemComponent as E, DetailItemComponent as F, courseItem_component as G, PricingItemComponent as P, ScheduleDate as S, CategoryService as a, courseManageRoutes as b, courseRoutes as c, CourseStatus as d, CourseRequestStatus as e, CourseType as f, CourseReviewStatus as g, CourseSectionLectureContentType as h, CoursePreviewComponent as i, CourseInfoComponent as j, CourseMediaComponent as k, CoursePricingComponent as l, CourseActionComponent as m, CourseScheduleComponent as n, CourseSectionsComponent as o, provideAngulaCourse as p, CourseSectionItemComponent as q, CourseSectionLectureItemComponent as r, CourseSectionLectureVideoItemComponent as s, CourseItemComponent as t, CoursePricingAddDialogComponent as u, CourseScheduleAddDialogComponent as v, CoursePricingDialogComponent as w, CourseScheduleDialogComponent as x, CourseDetailsDialogComponent as y, CourseEditDialogComponent as z };
|
|
3054
|
-
//# sourceMappingURL=rolatech-angular-course-rolatech-angular-course-
|
|
3047
|
+
//# sourceMappingURL=rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs.map
|