@rolatech/angular-course 17.3.29 → 17.3.30
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-pricing-add-dialog/course-pricing-add-dialog.component.mjs +10 -18
- package/esm2022/lib/components/course-schedule-add-dialog/course-schedule-add-dialog.component.mjs +3 -3
- package/esm2022/lib/components/course-section-lecture-video-dialog/course-section-lecture-video-dialog.component.mjs +3 -3
- package/esm2022/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.mjs +42 -41
- package/esm2022/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.mjs +10 -10
- package/fesm2022/{rolatech-angular-course-course-index.component-D339dt6A.mjs → rolatech-angular-course-course-index.component-BILowjd2.mjs} +4 -4
- package/fesm2022/{rolatech-angular-course-course-index.component-D339dt6A.mjs.map → rolatech-angular-course-course-index.component-BILowjd2.mjs.map} +1 -1
- package/fesm2022/{rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs → rolatech-angular-course-rolatech-angular-course-Du0SRSCJ.mjs} +61 -61
- package/fesm2022/rolatech-angular-course-rolatech-angular-course-Du0SRSCJ.mjs.map +1 -0
- package/fesm2022/rolatech-angular-course.mjs +1 -1
- package/lib/components/course-pricing-add-dialog/course-pricing-add-dialog.component.d.ts +5 -7
- package/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.d.ts +2 -9
- package/package.json +1 -1
- package/themes/_default.scss +1 -1
- package/fesm2022/rolatech-angular-course-rolatech-angular-course-AX5M1HKZ.mjs.map +0 -1
package/esm2022/lib/components/course-pricing-add-dialog/course-pricing-add-dialog.component.mjs
CHANGED
|
@@ -1,33 +1,25 @@
|
|
|
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 { PricingItemComponent } from '../pricing-item/pricing-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 CoursePricingAddDialogComponent {
|
|
11
|
-
constructor(
|
|
12
|
-
this.
|
|
13
|
-
this.data = data;
|
|
7
|
+
constructor() {
|
|
8
|
+
this.output = output();
|
|
14
9
|
this.pricing = {
|
|
15
10
|
min: 0,
|
|
16
11
|
max: 0,
|
|
17
12
|
total: 0,
|
|
18
13
|
};
|
|
19
14
|
}
|
|
20
|
-
|
|
21
|
-
this.
|
|
15
|
+
ngDoCheck() {
|
|
16
|
+
this.output.emit(this.pricing);
|
|
22
17
|
}
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CoursePricingAddDialogComponent, deps: [
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CoursePricingAddDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.2", type: CoursePricingAddDialogComponent, isStandalone: true, selector: "rolatech-course-pricing-add-dialog", outputs: { output: "output" }, ngImport: i0, template: "<rolatech-pricing-item [pricing]=\"pricing\"></rolatech-pricing-item>\n", styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: PricingItemComponent, selector: "rolatech-pricing-item", inputs: ["actions", "pricing"], outputs: ["pricingChange", "delete", "save"] }, { kind: "ngmodule", type: MatButtonModule }] }); }
|
|
25
20
|
}
|
|
26
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CoursePricingAddDialogComponent, decorators: [{
|
|
27
22
|
type: Component,
|
|
28
|
-
args: [{ selector: 'rolatech-course-pricing-add-dialog', standalone: true, imports: [MatIconModule, PricingItemComponent, MatButtonModule
|
|
29
|
-
}]
|
|
30
|
-
|
|
31
|
-
args: [MAT_DIALOG_DATA]
|
|
32
|
-
}] }] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItY291cnNlL3NyYy9saWIvY29tcG9uZW50cy9jb3Vyc2UtcHJpY2luZy1hZGQtZGlhbG9nL2NvdXJzZS1wcmljaW5nLWFkZC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy9jb3Vyc2UtcHJpY2luZy1hZGQtZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7Ozs7O0FBVXZELE1BQU0sT0FBTywrQkFBK0I7SUFNMUMsWUFDVSxTQUF3RCxFQUNoQyxJQUFTO1FBRGpDLGNBQVMsR0FBVCxTQUFTLENBQStDO1FBQ2hDLFNBQUksR0FBSixJQUFJLENBQUs7UUFQM0MsWUFBTyxHQUFZO1lBQ2pCLEdBQUcsRUFBRSxDQUFDO1lBQ04sR0FBRyxFQUFFLENBQUM7WUFDTixLQUFLLEVBQUUsQ0FBQztTQUNULENBQUM7SUFJQyxDQUFDO0lBRUosS0FBSztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDekIsQ0FBQzs4R0FiVSwrQkFBK0IsOENBUWhDLGVBQWU7a0dBUmQsK0JBQStCLDhGQ2Q1QyxrdUJBaUJBLHFGRExZLGFBQWEsb0xBQUUsb0JBQW9CLCtJQUFFLGVBQWUsNE5BQUUsY0FBYzs7MkZBRW5FLCtCQUErQjtrQkFQM0MsU0FBUzsrQkFDRSxvQ0FBb0MsY0FHbEMsSUFBSSxXQUNQLENBQUMsYUFBYSxFQUFFLG9CQUFvQixFQUFFLGVBQWUsRUFBRSxjQUFjLENBQUM7OzBCQVU1RSxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nUmVmLCBNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ0Nsb3NlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBQcmljaW5nSXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL3ByaWNpbmctaXRlbS9wcmljaW5nLWl0ZW0uY29tcG9uZW50JztcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7IFByaWNpbmcgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncm9sYXRlY2gtY291cnNlLXByaWNpbmctYWRkLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9jb3Vyc2UtcHJpY2luZy1hZGQtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTWF0SWNvbk1vZHVsZSwgUHJpY2luZ0l0ZW1Db21wb25lbnQsIE1hdEJ1dHRvbk1vZHVsZSwgTWF0RGlhbG9nQ2xvc2VdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3Vyc2VQcmljaW5nQWRkRGlhbG9nQ29tcG9uZW50IHtcbiAgcHJpY2luZzogUHJpY2luZyA9IHtcbiAgICBtaW46IDAsXG4gICAgbWF4OiAwLFxuICAgIHRvdGFsOiAwLFxuICB9O1xuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPENvdXJzZVByaWNpbmdBZGREaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogYW55LFxuICApIHt9XG5cbiAgY2xvc2UoKSB7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImZsZXggZmxleC1jb2wgaC1mdWxsIG92ZXJmbG93LWhpZGRlblwiPlxuICA8ZGl2IGNsYXNzPVwiaC0xNiBmbGV4IGp1c3RpZnktYmV0d2VlbiBpdGVtcy1jZW50ZXIgcHgtNVwiPlxuICAgIEBpZiAoZGF0YS50aXRsZSkge1xuICAgICAgPGRpdiBjbGFzcz1cInRleHQteGwgZm9udC1ib2xkXCI+e3sgZGF0YS50aXRsZSB9fTwvZGl2PlxuICAgIH1cbiAgICA8ZGl2IGNsYXNzPVwiY3Vyc29yLXBvaW50ZXJcIiAoY2xpY2spPVwiY2xvc2UoKVwiPlxuICAgICAgPG1hdC1pY29uIGZvbnRJY29uPVwiY2xvc2VcIj48L21hdC1pY29uPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cImZsZXgtMSBvdmVyZmxvdy1oaWRkZW4gcC0zIG92ZXJmbG93LXktYXV0byBtYXgtaC1bNTV2aF1cIj5cbiAgICA8cm9sYXRlY2gtcHJpY2luZy1pdGVtIFtwcmljaW5nXT1cInByaWNpbmdcIj48L3JvbGF0ZWNoLXByaWNpbmctaXRlbT5cbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJoLTE2IGZsZXgganVzdGlmeS1lbmQgaXRlbXMtY2VudGVyIHB4LTUgZ2FwLTNcIj5cbiAgICA8YnV0dG9uIG1hdC1idXR0b24gbWF0LWRpYWxvZy1jbG9zZT7lj5bmtog8L2J1dHRvbj5cbiAgICA8YnV0dG9uIG1hdC1idXR0b24gW21hdC1kaWFsb2ctY2xvc2VdPVwicHJpY2luZ1wiIGNka0ZvY3VzSW5pdGlhbD7kv53lrZg8L2J1dHRvbj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
23
|
+
args: [{ selector: 'rolatech-course-pricing-add-dialog', standalone: true, imports: [MatIconModule, PricingItemComponent, MatButtonModule], template: "<rolatech-pricing-item [pricing]=\"pricing\"></rolatech-pricing-item>\n", styles: ["mat-form-field{width:100%}\n"] }]
|
|
24
|
+
}] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItY291cnNlL3NyYy9saWIvY29tcG9uZW50cy9jb3Vyc2UtcHJpY2luZy1hZGQtZGlhbG9nL2NvdXJzZS1wcmljaW5nLWFkZC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy9jb3Vyc2UtcHJpY2luZy1hZGQtZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVcsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBVXZELE1BQU0sT0FBTywrQkFBK0I7SUFQNUM7UUFRRSxXQUFNLEdBQUcsTUFBTSxFQUFPLENBQUM7UUFDdkIsWUFBTyxHQUFZO1lBQ2pCLEdBQUcsRUFBRSxDQUFDO1lBQ04sR0FBRyxFQUFFLENBQUM7WUFDTixLQUFLLEVBQUUsQ0FBQztTQUNULENBQUM7S0FJSDtJQUhDLFNBQVM7UUFDUCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDakMsQ0FBQzs4R0FUVSwrQkFBK0I7a0dBQS9CLCtCQUErQiw2SENiNUMseUVBQ0EscUZEVVksYUFBYSwrQkFBRSxvQkFBb0IsK0lBQUUsZUFBZTs7MkZBRW5ELCtCQUErQjtrQkFQM0MsU0FBUzsrQkFDRSxvQ0FBb0MsY0FHbEMsSUFBSSxXQUNQLENBQUMsYUFBYSxFQUFFLG9CQUFvQixFQUFFLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRG9DaGVjaywgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgUHJpY2luZ0l0ZW1Db21wb25lbnQgfSBmcm9tICcuLi9wcmljaW5nLWl0ZW0vcHJpY2luZy1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQgeyBQcmljaW5nIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3JvbGF0ZWNoLWNvdXJzZS1wcmljaW5nLWFkZC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vY291cnNlLXByaWNpbmctYWRkLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NvdXJzZS1wcmljaW5nLWFkZC1kaWFsb2cuY29tcG9uZW50LnNjc3MnXSxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW01hdEljb25Nb2R1bGUsIFByaWNpbmdJdGVtQ29tcG9uZW50LCBNYXRCdXR0b25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3Vyc2VQcmljaW5nQWRkRGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgRG9DaGVjayB7XG4gIG91dHB1dCA9IG91dHB1dDxhbnk+KCk7XG4gIHByaWNpbmc6IFByaWNpbmcgPSB7XG4gICAgbWluOiAwLFxuICAgIG1heDogMCxcbiAgICB0b3RhbDogMCxcbiAgfTtcbiAgbmdEb0NoZWNrKCk6IHZvaWQge1xuICAgIHRoaXMub3V0cHV0LmVtaXQodGhpcy5wcmljaW5nKTtcbiAgfVxufVxuIiwiPHJvbGF0ZWNoLXByaWNpbmctaXRlbSBbcHJpY2luZ109XCJwcmljaW5nXCI+PC9yb2xhdGVjaC1wcmljaW5nLWl0ZW0+XG4iXX0=
|
package/esm2022/lib/components/course-schedule-add-dialog/course-schedule-add-dialog.component.mjs
CHANGED
|
@@ -17,10 +17,10 @@ export class CourseScheduleAddDialogComponent {
|
|
|
17
17
|
this.output.emit(this.schedule);
|
|
18
18
|
}
|
|
19
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: "<
|
|
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: "<rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\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 }] }); }
|
|
21
21
|
}
|
|
22
22
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseScheduleAddDialogComponent, decorators: [{
|
|
23
23
|
type: Component,
|
|
24
|
-
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule], template: "<
|
|
24
|
+
args: [{ selector: 'rolatech-course-schedule-add-dialog', standalone: true, imports: [MatIconModule, ScheduleItemComponent, MatButtonModule], template: "<rolatech-schedule-item [value]=\"schedule\"></rolatech-schedule-item>\n" }]
|
|
25
25
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWNvdXJzZS9zcmMvbGliL2NvbXBvbmVudHMvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cvY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVyxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFVdkQsTUFBTSxPQUFPLGdDQUFnQztJQVA3QztRQVFFLFdBQU0sR0FBRyxNQUFNLEVBQU8sQ0FBQztRQUN2QixhQUFRLEdBQWE7WUFDbkIsS0FBSyxFQUFFLEVBQUU7WUFDVCxPQUFPLEVBQUUsRUFBRTtZQUNYLE9BQU8sRUFBRSxFQUFFO1lBQ1gsS0FBSyxFQUFFLEVBQUU7U0FDVixDQUFDO0tBSUg7SUFIQyxTQUFTO1FBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2xDLENBQUM7OEdBVlUsZ0NBQWdDO2tHQUFoQyxnQ0FBZ0MsOEhDYjdDLDBFQUNBLHlERFVZLGFBQWEsK0JBQUUscUJBQXFCLDZIQUFFLGVBQWU7OzJGQUVwRCxnQ0FBZ0M7a0JBUDVDLFNBQVM7K0JBQ0UscUNBQXFDLGNBR25DLElBQUksV0FDUCxDQUFDLGFBQWEsRUFBRSxxQkFBcUIsRUFBRSxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIERvQ2hlY2ssIG91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7IFNjaGVkdWxlSXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL3NjaGVkdWxlLWl0ZW0vc2NoZWR1bGUtaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuaW1wb3J0IHsgU2NoZWR1bGUgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncm9sYXRlY2gtY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vY291cnNlLXNjaGVkdWxlLWFkZC1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jb3Vyc2Utc2NoZWR1bGUtYWRkLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbTWF0SWNvbk1vZHVsZSwgU2NoZWR1bGVJdGVtQ29tcG9uZW50LCBNYXRCdXR0b25Nb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBDb3Vyc2VTY2hlZHVsZUFkZERpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIERvQ2hlY2sge1xuICBvdXRwdXQgPSBvdXRwdXQ8YW55PigpO1xuICBzY2hlZHVsZTogU2NoZWR1bGUgPSB7XG4gICAgdGl0bGU6ICcnLFxuICAgIGNvbnRlbnQ6ICcnLFxuICAgIHN0YXJ0QXQ6ICcnLFxuICAgIGVuZEF0OiAnJyxcbiAgfTtcbiAgbmdEb0NoZWNrKCk6IHZvaWQge1xuICAgIHRoaXMub3V0cHV0LmVtaXQodGhpcy5zY2hlZHVsZSk7XG4gIH1cbn1cbiIsIjxyb2xhdGVjaC1zY2hlZHVsZS1pdGVtIFt2YWx1ZV09XCJzY2hlZHVsZVwiPjwvcm9sYXRlY2gtc2NoZWR1bGUtaXRlbT5cbiJdfQ==
|
|
@@ -91,7 +91,7 @@ export class CourseSectionLectureVideoDialogComponent {
|
|
|
91
91
|
});
|
|
92
92
|
}
|
|
93
93
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseSectionLectureVideoDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseSectionLectureVideoDialogComponent, isStandalone: true, selector: "rolatech-course-section-lecture-video-dialog", outputs: { thumbnailUpload: "thumbnailUpload" }, ngImport: i0, template: "<div class=\"flex flex-col-reverse
|
|
94
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseSectionLectureVideoDialogComponent, isStandalone: true, selector: "rolatech-course-section-lecture-video-dialog", outputs: { thumbnailUpload: "thumbnailUpload" }, ngImport: i0, template: "<div class=\"flex flex-col-reverse md:flex-row justify-between h-full gap-3\">\n <div class=\"w-full md:w-1/2\">\n <div>\n <div class=\"py-3 flex flex-col\">\n <span class=\"text-lg font-bold\"> \u5C01\u9762 </span>\n <span class=\"text-sm\">\u4E00\u4E2A\u597D\u7684\u5C01\u9762\u53EF\u4EE5\u5F15\u8D77\u66F4\u591A\u7684\u5173\u6CE8</span>\n </div>\n\n <div class=\"flex gap-3\">\n <div\n class=\"p-3 w-36 flex flex-col items-center justify-center outline-dashed outline-1 rounded cursor-pointer\"\n (click)=\"fileInput.click()\"\n >\n <mat-icon>upload</mat-icon>\n <span class=\"text-sm\">\u4E0A\u4F20\u5C01\u9762</span>\n </div>\n <input type=\"file\" accept=\"image/*\" (change)=\"onThumbnailUpload($event)\" #fileInput style=\"display: none\" />\n @if (lecture.item.thumbnail) {\n <div class=\"aspect-video w-32 h-auto bg-black\">\n <img [src]=\"lecture.item.thumbnail\" class=\"aspect-video object-contain\" />\n </div>\n } @else {\n <div class=\"aspect-video w-32 h-auto\">\n <img [src]=\"mediaSrc\" class=\"aspect-video object-contain\" />\n </div>\n }\n </div>\n </div>\n <div class=\"mt-3\">\n <div class=\"py-3 flex flex-col\">\n <span class=\"text-lg font-bold\"> \u8BD5\u770B\u5185\u5BB9 </span>\n <span class=\"text-sm\">\u5C11\u91CF\u7684\u8BD5\u770B\u5185\u5BB9, \u53EF\u4EE5\u589E\u52A0\u8D2D\u4E70\u7387</span>\n </div>\n <mat-checkbox color=\"primary\" (change)=\"onPreviewChange($event)\" [checked]=\"lecture.item.canBePreviewed\"\n >\u5141\u8BB8\u8BD5\u770B</mat-checkbox\n >\n </div>\n </div>\n <div class=\"w-full md:w-1/2\">\n @if (lecture) {\n <div>\n <div id=\"dplayer\" class=\"w-full h-auto aspect-video md:rounded-xl\"></div>\n </div>\n }\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatDividerModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatStepperModule }, { kind: "ngmodule", type: MatButtonModule }, { kind: "ngmodule", type: MatCheckboxModule }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }] }); }
|
|
95
95
|
}
|
|
96
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseSectionLectureVideoDialogComponent, decorators: [{
|
|
97
97
|
type: Component,
|
|
@@ -104,9 +104,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
104
104
|
MatButtonModule,
|
|
105
105
|
MatDialogClose,
|
|
106
106
|
MatCheckboxModule,
|
|
107
|
-
], template: "<div class=\"flex flex-col-reverse
|
|
107
|
+
], template: "<div class=\"flex flex-col-reverse md:flex-row justify-between h-full gap-3\">\n <div class=\"w-full md:w-1/2\">\n <div>\n <div class=\"py-3 flex flex-col\">\n <span class=\"text-lg font-bold\"> \u5C01\u9762 </span>\n <span class=\"text-sm\">\u4E00\u4E2A\u597D\u7684\u5C01\u9762\u53EF\u4EE5\u5F15\u8D77\u66F4\u591A\u7684\u5173\u6CE8</span>\n </div>\n\n <div class=\"flex gap-3\">\n <div\n class=\"p-3 w-36 flex flex-col items-center justify-center outline-dashed outline-1 rounded cursor-pointer\"\n (click)=\"fileInput.click()\"\n >\n <mat-icon>upload</mat-icon>\n <span class=\"text-sm\">\u4E0A\u4F20\u5C01\u9762</span>\n </div>\n <input type=\"file\" accept=\"image/*\" (change)=\"onThumbnailUpload($event)\" #fileInput style=\"display: none\" />\n @if (lecture.item.thumbnail) {\n <div class=\"aspect-video w-32 h-auto bg-black\">\n <img [src]=\"lecture.item.thumbnail\" class=\"aspect-video object-contain\" />\n </div>\n } @else {\n <div class=\"aspect-video w-32 h-auto\">\n <img [src]=\"mediaSrc\" class=\"aspect-video object-contain\" />\n </div>\n }\n </div>\n </div>\n <div class=\"mt-3\">\n <div class=\"py-3 flex flex-col\">\n <span class=\"text-lg font-bold\"> \u8BD5\u770B\u5185\u5BB9 </span>\n <span class=\"text-sm\">\u5C11\u91CF\u7684\u8BD5\u770B\u5185\u5BB9, \u53EF\u4EE5\u589E\u52A0\u8D2D\u4E70\u7387</span>\n </div>\n <mat-checkbox color=\"primary\" (change)=\"onPreviewChange($event)\" [checked]=\"lecture.item.canBePreviewed\"\n >\u5141\u8BB8\u8BD5\u770B</mat-checkbox\n >\n </div>\n </div>\n <div class=\"w-full md:w-1/2\">\n @if (lecture) {\n <div>\n <div id=\"dplayer\" class=\"w-full h-auto aspect-video md:rounded-xl\"></div>\n </div>\n }\n </div>\n</div>\n" }]
|
|
108
108
|
}], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
109
109
|
type: Inject,
|
|
110
110
|
args: [MAT_DIALOG_DATA]
|
|
111
111
|
}] }] });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-section-lecture-video-dialog.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-course/src/lib/components/course-section-lecture-video-dialog/course-section-lecture-video-dialog.component.ts","../../../../../../../libs/angular-course/src/lib/components/course-section-lecture-video-dialog/course-section-lecture-video-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Inject, OnDestroy, OnInit, PLATFORM_ID, inject, output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogClose, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatStepperModule } from '@angular/material/stepper';\nimport { ScheduleItemComponent } from '../schedule-item/schedule-item.component';\nimport { isPlatformBrowser } from '@angular/common';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { CourseSectionLecture } from '../../interfaces';\nimport { CourseSectionService, CourseService } from '../../services';\ndeclare const DPlayer: any;\n\n@Component({\n  selector: 'rolatech-course-section-lecture-video-dialog',\n  standalone: true,\n  imports: [\n    MatIconModule,\n    MatDividerModule,\n    FormsModule,\n    MatStepperModule,\n    ScheduleItemComponent,\n    MatButtonModule,\n    MatDialogClose,\n    MatCheckboxModule,\n  ],\n  templateUrl: './course-section-lecture-video-dialog.component.html',\n  styleUrl: './course-section-lecture-video-dialog.component.scss',\n})\nexport class CourseSectionLectureVideoDialogComponent implements OnInit, AfterViewInit, OnDestroy {\n  lecture!: CourseSectionLecture;\n  thumbnailUpload = output<any>();\n  courseService = inject(CourseService);\n  courseSectionService = inject(CourseSectionService);\n\n  snackBar = inject(MatSnackBar);\n  platformId = inject(PLATFORM_ID);\n  el = inject(ElementRef);\n  mediaSrc: any;\n  player: any;\n\n  constructor(\n    private dialogRef: MatDialogRef<CourseSectionLectureVideoDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n  ) {\n    this.lecture = data.data;\n  }\n  ngAfterViewInit(): void {\n    this.initPlayer(this.lecture.item.url, this.lecture.item.thumbnail);\n  }\n  close() {\n    this.dialogRef.close();\n  }\n  initPlayer(url: string, thumbnail?: string) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return;\n    }\n    // 'https://cos-video-1258344699.cos.ap-guangzhou.tencentcos.cn/test.mp4',\n    if (!this.player) {\n      const playerContainer = this.el.nativeElement.querySelector('#dplayer');\n      this.player = new DPlayer({\n        container: playerContainer,\n        screenshot: true,\n        preload: 'metadata',\n        video: {\n          url: url,\n          pic: thumbnail,\n        },\n      });\n      // this.player.on('loadedmetadata', () => {\n      //   console.log('Video duration:', this.player.video.duration);\n      // });\n    }\n  }\n  ngOnInit(): void {}\n  ngOnDestroy(): void {\n    if (this.player) {\n      this.player.destroy();\n    }\n  }\n  onThumbnailUpload(event: any) {\n    const file = event.target.files[0];\n    if (file) {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n        this.mediaSrc = reader.result;\n        const formData = new FormData();\n        formData.append('file', file);\n        this.courseService.uploadLectureVideoThumbnail(this.lecture.item.id, formData).subscribe({\n          next: (res) => {\n            this.lecture.item = res.data;\n            this.snackBar.open('上传成功');\n            this.player.switchVideo({\n              url: this.lecture.item.url,\n              pic: res.data.thumbnail,\n            });\n          },\n        });\n      };\n      reader.onerror = (error) => {};\n    }\n  }\n  onPreviewChange(event: any) {\n    this.courseSectionService.canBePreviewed(this.lecture.item.id, { canBePreviewed: event.checked }).subscribe({\n      next: (res) => {\n        this.lecture.item.canBePreviewed = res.data.canBePreviewed;\n        // this.lecture = res.data;\n      },\n    });\n  }\n}\n","<div class=\"flex flex-col-reverse sm:flex-row justify-between h-full gap-3\">\n  <div class=\"w-full sm:w-1/2\">\n    <div>\n      <div class=\"py-3 flex flex-col\">\n        <span class=\"text-lg font-bold\"> 封面 </span>\n        <span class=\"text-sm\">一个好的封面可以引起更多的关注</span>\n      </div>\n\n      <div class=\"flex gap-3\">\n        <div\n          class=\"p-3 w-36 flex flex-col items-center justify-center outline-dashed outline-1 rounded cursor-pointer\"\n          (click)=\"fileInput.click()\"\n        >\n          <mat-icon>upload</mat-icon>\n          <span class=\"text-sm\">上传封面</span>\n        </div>\n        <input type=\"file\" accept=\"image/*\" (change)=\"onThumbnailUpload($event)\" #fileInput style=\"display: none\" />\n        @if (lecture.item.thumbnail) {\n          <div class=\"aspect-video w-32 h-auto bg-black\">\n            <img [src]=\"lecture.item.thumbnail\" class=\"aspect-video object-contain\" />\n          </div>\n        } @else {\n          <div class=\"aspect-video w-32 h-auto\">\n            <img [src]=\"mediaSrc\" class=\"aspect-video object-contain\" />\n          </div>\n        }\n      </div>\n    </div>\n    <div class=\"mt-3\">\n      <div class=\"py-3 flex flex-col\">\n        <span class=\"text-lg font-bold\"> 试看内容 </span>\n        <span class=\"text-sm\">少量的试看内容, 可以增加购买率</span>\n      </div>\n      <mat-checkbox color=\"primary\" (change)=\"onPreviewChange($event)\" [checked]=\"lecture.item.canBePreviewed\"\n        >允许试看</mat-checkbox\n      >\n    </div>\n  </div>\n  <div class=\"w-full sm:w-1/2\">\n    @if (lecture) {\n      <div>\n        <div id=\"dplayer\" class=\"w-full h-auto aspect-video sm:rounded-xl\"></div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-section-lecture-video-dialog.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular-course/src/lib/components/course-section-lecture-video-dialog/course-section-lecture-video-dialog.component.ts","../../../../../../../libs/angular-course/src/lib/components/course-section-lecture-video-dialog/course-section-lecture-video-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Inject, OnDestroy, OnInit, PLATFORM_ID, inject, output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogClose, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatDividerModule } from '@angular/material/divider';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatStepperModule } from '@angular/material/stepper';\nimport { ScheduleItemComponent } from '../schedule-item/schedule-item.component';\nimport { isPlatformBrowser } from '@angular/common';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { CourseSectionLecture } from '../../interfaces';\nimport { CourseSectionService, CourseService } from '../../services';\ndeclare const DPlayer: any;\n\n@Component({\n  selector: 'rolatech-course-section-lecture-video-dialog',\n  standalone: true,\n  imports: [\n    MatIconModule,\n    MatDividerModule,\n    FormsModule,\n    MatStepperModule,\n    ScheduleItemComponent,\n    MatButtonModule,\n    MatDialogClose,\n    MatCheckboxModule,\n  ],\n  templateUrl: './course-section-lecture-video-dialog.component.html',\n  styleUrl: './course-section-lecture-video-dialog.component.scss',\n})\nexport class CourseSectionLectureVideoDialogComponent implements OnInit, AfterViewInit, OnDestroy {\n  lecture!: CourseSectionLecture;\n  thumbnailUpload = output<any>();\n  courseService = inject(CourseService);\n  courseSectionService = inject(CourseSectionService);\n\n  snackBar = inject(MatSnackBar);\n  platformId = inject(PLATFORM_ID);\n  el = inject(ElementRef);\n  mediaSrc: any;\n  player: any;\n\n  constructor(\n    private dialogRef: MatDialogRef<CourseSectionLectureVideoDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: any,\n  ) {\n    this.lecture = data.data;\n  }\n  ngAfterViewInit(): void {\n    this.initPlayer(this.lecture.item.url, this.lecture.item.thumbnail);\n  }\n  close() {\n    this.dialogRef.close();\n  }\n  initPlayer(url: string, thumbnail?: string) {\n    if (!isPlatformBrowser(this.platformId)) {\n      return;\n    }\n    // 'https://cos-video-1258344699.cos.ap-guangzhou.tencentcos.cn/test.mp4',\n    if (!this.player) {\n      const playerContainer = this.el.nativeElement.querySelector('#dplayer');\n      this.player = new DPlayer({\n        container: playerContainer,\n        screenshot: true,\n        preload: 'metadata',\n        video: {\n          url: url,\n          pic: thumbnail,\n        },\n      });\n      // this.player.on('loadedmetadata', () => {\n      //   console.log('Video duration:', this.player.video.duration);\n      // });\n    }\n  }\n  ngOnInit(): void {}\n  ngOnDestroy(): void {\n    if (this.player) {\n      this.player.destroy();\n    }\n  }\n  onThumbnailUpload(event: any) {\n    const file = event.target.files[0];\n    if (file) {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n        this.mediaSrc = reader.result;\n        const formData = new FormData();\n        formData.append('file', file);\n        this.courseService.uploadLectureVideoThumbnail(this.lecture.item.id, formData).subscribe({\n          next: (res) => {\n            this.lecture.item = res.data;\n            this.snackBar.open('上传成功');\n            this.player.switchVideo({\n              url: this.lecture.item.url,\n              pic: res.data.thumbnail,\n            });\n          },\n        });\n      };\n      reader.onerror = (error) => {};\n    }\n  }\n  onPreviewChange(event: any) {\n    this.courseSectionService.canBePreviewed(this.lecture.item.id, { canBePreviewed: event.checked }).subscribe({\n      next: (res) => {\n        this.lecture.item.canBePreviewed = res.data.canBePreviewed;\n        // this.lecture = res.data;\n      },\n    });\n  }\n}\n","<div class=\"flex flex-col-reverse md:flex-row justify-between h-full gap-3\">\n  <div class=\"w-full md:w-1/2\">\n    <div>\n      <div class=\"py-3 flex flex-col\">\n        <span class=\"text-lg font-bold\"> 封面 </span>\n        <span class=\"text-sm\">一个好的封面可以引起更多的关注</span>\n      </div>\n\n      <div class=\"flex gap-3\">\n        <div\n          class=\"p-3 w-36 flex flex-col items-center justify-center outline-dashed outline-1 rounded cursor-pointer\"\n          (click)=\"fileInput.click()\"\n        >\n          <mat-icon>upload</mat-icon>\n          <span class=\"text-sm\">上传封面</span>\n        </div>\n        <input type=\"file\" accept=\"image/*\" (change)=\"onThumbnailUpload($event)\" #fileInput style=\"display: none\" />\n        @if (lecture.item.thumbnail) {\n          <div class=\"aspect-video w-32 h-auto bg-black\">\n            <img [src]=\"lecture.item.thumbnail\" class=\"aspect-video object-contain\" />\n          </div>\n        } @else {\n          <div class=\"aspect-video w-32 h-auto\">\n            <img [src]=\"mediaSrc\" class=\"aspect-video object-contain\" />\n          </div>\n        }\n      </div>\n    </div>\n    <div class=\"mt-3\">\n      <div class=\"py-3 flex flex-col\">\n        <span class=\"text-lg font-bold\"> 试看内容 </span>\n        <span class=\"text-sm\">少量的试看内容, 可以增加购买率</span>\n      </div>\n      <mat-checkbox color=\"primary\" (change)=\"onPreviewChange($event)\" [checked]=\"lecture.item.canBePreviewed\"\n        >允许试看</mat-checkbox\n      >\n    </div>\n  </div>\n  <div class=\"w-full md:w-1/2\">\n    @if (lecture) {\n      <div>\n        <div id=\"dplayer\" class=\"w-full h-auto aspect-video md:rounded-xl\"></div>\n      </div>\n    }\n  </div>\n</div>\n"]}
|
package/esm2022/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.mjs
CHANGED
|
@@ -1,31 +1,26 @@
|
|
|
1
1
|
import { Component, inject } from '@angular/core';
|
|
2
|
-
import { MatDialog } from '@angular/material/dialog';
|
|
3
|
-
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
4
|
-
import { ActivatedRoute } from '@angular/router';
|
|
5
2
|
import { remove } from 'lodash';
|
|
6
3
|
import { MatIconModule } from '@angular/material/icon';
|
|
7
4
|
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
-
import {
|
|
5
|
+
import { BaseComponent, ToolbarComponent } from '@rolatech/angular-components';
|
|
9
6
|
import { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';
|
|
10
|
-
import { PricingItemComponent,
|
|
7
|
+
import { PricingItemComponent, CoursePricingAddDialogComponent } from '../../../components';
|
|
11
8
|
import { CourseStatus, CourseType } from '../../../interfaces';
|
|
12
9
|
import { CourseService } from '../../../services';
|
|
13
10
|
import * as i0 from "@angular/core";
|
|
14
11
|
import * as i1 from "@angular/material/button";
|
|
15
12
|
import * as i2 from "@angular/material/icon";
|
|
16
|
-
export class CourseManagePricingComponent {
|
|
13
|
+
export class CourseManagePricingComponent extends BaseComponent {
|
|
17
14
|
constructor() {
|
|
18
|
-
|
|
15
|
+
super(...arguments);
|
|
19
16
|
this.courseService = inject(CourseService);
|
|
20
|
-
this.dialog = inject(MatDialog);
|
|
21
|
-
this.snackBar = inject(MatSnackBar);
|
|
22
17
|
this.isLoading = false;
|
|
23
18
|
this.pricing = [];
|
|
24
19
|
this.status = CourseStatus;
|
|
25
20
|
this.courseType = CourseType;
|
|
26
|
-
this.id = this.route.parent?.snapshot.paramMap.get('id');
|
|
27
21
|
}
|
|
28
22
|
ngOnInit() {
|
|
23
|
+
this.id = this.route.parent?.snapshot.paramMap.get('id');
|
|
29
24
|
this.find();
|
|
30
25
|
}
|
|
31
26
|
find() {
|
|
@@ -38,45 +33,51 @@ export class CourseManagePricingComponent {
|
|
|
38
33
|
});
|
|
39
34
|
}
|
|
40
35
|
editPricing() {
|
|
41
|
-
const
|
|
36
|
+
const options = {
|
|
42
37
|
width: '500px',
|
|
38
|
+
title: '编辑价格',
|
|
43
39
|
height: '90%',
|
|
40
|
+
cancelText: '取消',
|
|
41
|
+
confirmText: '确认',
|
|
42
|
+
component: CoursePricingAddDialogComponent,
|
|
44
43
|
data: {
|
|
45
|
-
title: '编辑价格',
|
|
46
44
|
courseId: this.id,
|
|
47
45
|
pricing: this.pricing,
|
|
48
46
|
},
|
|
49
|
-
}
|
|
50
|
-
|
|
47
|
+
};
|
|
48
|
+
this.dialogService.open(options);
|
|
49
|
+
this.dialogService.confirmed().subscribe((result) => {
|
|
51
50
|
if (result) {
|
|
52
51
|
this.courseService.addPricing(this.id, { pricing: result }).subscribe({
|
|
53
52
|
next: (res) => {
|
|
54
|
-
this.
|
|
53
|
+
this.snackBarService.open('编辑成功');
|
|
55
54
|
},
|
|
56
55
|
error: (error) => {
|
|
57
|
-
this.
|
|
56
|
+
this.snackBarService.open(error.message);
|
|
58
57
|
},
|
|
59
58
|
});
|
|
60
59
|
}
|
|
61
60
|
});
|
|
62
61
|
}
|
|
63
62
|
addPricing() {
|
|
64
|
-
const
|
|
65
|
-
disableClose: true,
|
|
63
|
+
const options = {
|
|
66
64
|
width: '500px',
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
65
|
+
title: '添加价格',
|
|
66
|
+
cancelText: '取消',
|
|
67
|
+
confirmText: '确认',
|
|
68
|
+
component: CoursePricingAddDialogComponent,
|
|
69
|
+
data: {},
|
|
70
|
+
};
|
|
71
|
+
this.dialogService.open(options);
|
|
72
|
+
this.dialogService.confirmed().subscribe((pricing) => {
|
|
72
73
|
if (pricing) {
|
|
73
74
|
this.courseService.addPricing(this.id, { ...pricing, total: pricing.total * 100 }).subscribe({
|
|
74
75
|
next: (res) => {
|
|
75
76
|
this.pricing.push(res.data);
|
|
76
|
-
this.
|
|
77
|
+
this.snackBarService.open('添加成功');
|
|
77
78
|
},
|
|
78
79
|
error: (error) => {
|
|
79
|
-
this.
|
|
80
|
+
this.snackBarService.open(error.message);
|
|
80
81
|
},
|
|
81
82
|
});
|
|
82
83
|
}
|
|
@@ -85,42 +86,42 @@ export class CourseManagePricingComponent {
|
|
|
85
86
|
onPricingSave(pricing) {
|
|
86
87
|
this.courseService.updatePricing(this.id, pricing.id, pricing).subscribe({
|
|
87
88
|
next: (res) => {
|
|
88
|
-
this.
|
|
89
|
+
this.snackBarService.open('保存成功');
|
|
89
90
|
},
|
|
90
91
|
error: (e) => {
|
|
91
|
-
this.
|
|
92
|
+
this.snackBarService.open(e.message);
|
|
92
93
|
},
|
|
93
94
|
});
|
|
94
95
|
}
|
|
95
96
|
onPricingDelete(pricing) {
|
|
96
|
-
const
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
97
|
+
const options = {
|
|
98
|
+
title: '删除价格',
|
|
99
|
+
message: '确定删除此价格吗?',
|
|
100
|
+
cancelText: '取消',
|
|
101
|
+
confirmText: '确认',
|
|
102
|
+
};
|
|
103
|
+
this.dialogService.open(options);
|
|
104
|
+
this.dialogService.confirmed().subscribe((result) => {
|
|
104
105
|
if (result) {
|
|
105
106
|
this.courseService.deletePricing(this.id, pricing.id).subscribe({
|
|
106
107
|
next: (res) => {
|
|
107
108
|
remove(this.pricing, {
|
|
108
109
|
id: pricing.id,
|
|
109
110
|
});
|
|
110
|
-
this.
|
|
111
|
+
this.snackBarService.open(res.data);
|
|
111
112
|
},
|
|
112
113
|
error: (e) => {
|
|
113
|
-
this.
|
|
114
|
+
this.snackBarService.open(e.message);
|
|
114
115
|
},
|
|
115
116
|
});
|
|
116
117
|
}
|
|
117
118
|
});
|
|
118
119
|
}
|
|
119
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseManagePricingComponent, deps:
|
|
120
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseManagePricingComponent, isStandalone: true, selector: "rolatech-course-manage-pricing", ngImport: i0, template: "<rolatech-course-manage-content>\n <rolatech-toolbar title=\"\u4EF7\u683C\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (item of pricing; track item) {\n <rolatech-pricing-item\n [pricing]=\"item\"\n [actions]=\"true\"\n (save)=\"onPricingSave($event)\"\n (delete)=\"onPricingDelete($event)\"\n >\n </rolatech-pricing-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addPricing()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u6DFB\u52A0\u4EF7\u683C</span>\n </button>\n </div>\n</rolatech-course-manage-content>\n", styles: [""], dependencies: [{ kind: "component", type: PricingItemComponent, selector: "rolatech-pricing-item", inputs: ["actions", "pricing"], outputs: ["pricingChange", "delete", "save"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "component", type: CourseManageContentComponent, selector: "rolatech-course-manage-content" }] }); }
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseManagePricingComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.2", type: CourseManagePricingComponent, isStandalone: true, selector: "rolatech-course-manage-pricing", usesInheritance: true, ngImport: i0, template: "<rolatech-course-manage-content>\n <rolatech-toolbar title=\"\u4EF7\u683C\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (item of pricing; track item) {\n <rolatech-pricing-item\n [pricing]=\"item\"\n [actions]=\"true\"\n (save)=\"onPricingSave($event)\"\n (delete)=\"onPricingDelete($event)\"\n >\n </rolatech-pricing-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addPricing()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u6DFB\u52A0\u4EF7\u683C</span>\n </button>\n </div>\n</rolatech-course-manage-content>\n", styles: [""], dependencies: [{ kind: "component", type: PricingItemComponent, selector: "rolatech-pricing-item", inputs: ["actions", "pricing"], outputs: ["pricingChange", "delete", "save"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "component", type: CourseManageContentComponent, selector: "rolatech-course-manage-content" }] }); }
|
|
121
122
|
}
|
|
122
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImport: i0, type: CourseManagePricingComponent, decorators: [{
|
|
123
124
|
type: Component,
|
|
124
125
|
args: [{ selector: 'rolatech-course-manage-pricing', standalone: true, imports: [PricingItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent], template: "<rolatech-course-manage-content>\n <rolatech-toolbar title=\"\u4EF7\u683C\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (item of pricing; track item) {\n <rolatech-pricing-item\n [pricing]=\"item\"\n [actions]=\"true\"\n (save)=\"onPricingSave($event)\"\n (delete)=\"onPricingDelete($event)\"\n >\n </rolatech-pricing-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addPricing()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u6DFB\u52A0\u4EF7\u683C</span>\n </button>\n </div>\n</rolatech-course-manage-content>\n" }]
|
|
125
|
-
}]
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-manage-pricing.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.ts","../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { ActivatedRoute } from '@angular/router';\nimport { remove } from 'lodash';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { ConfirmationDialogComponent, ToolbarComponent } from '@rolatech/angular-components';\nimport { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';\nimport { PricingItemComponent, CoursePricingDialogComponent, CoursePricingAddDialogComponent } from '../../../components';\nimport { Pricing, CourseStatus, CourseType } from '../../../interfaces';\nimport { CourseService } from '../../../services';\n\n@Component({\n  selector: 'rolatech-course-manage-pricing',\n  templateUrl: './course-manage-pricing.component.html',\n  styleUrls: ['./course-manage-pricing.component.scss'],\n  standalone: true,\n  imports: [PricingItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent],\n})\nexport class CourseManagePricingComponent implements OnInit {\n  route = inject(ActivatedRoute);\n  courseService = inject(CourseService);\n  dialog = inject(MatDialog);\n  snackBar = inject(MatSnackBar);\n  id: string;\n  isLoading = false;\n  pricing: Pricing[] = [];\n  status = CourseStatus;\n  courseType: any = CourseType;\n  constructor() {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n  }\n  ngOnInit(): void {\n    this.find();\n  }\n  find() {\n    this.courseService.findPricing(this.id).subscribe({\n      next: (res) => {\n        if (res.data) {\n          this.pricing = res.data;\n        }\n      },\n    });\n  }\n  editPricing() {\n    const dialogRef = this.dialog.open(CoursePricingDialogComponent, {\n      width: '500px',\n      height: '90%',\n      data: {\n        title: '编辑价格',\n        courseId: this.id,\n        pricing: this.pricing,\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.courseService.addPricing(this.id, { pricing: 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  addPricing() {\n    const dialogRef = this.dialog.open(CoursePricingAddDialogComponent, {\n      disableClose: true,\n      width: '500px',\n      data: {\n        title: '添加价格',\n      },\n    });\n    dialogRef.afterClosed().subscribe((pricing) => {\n      if (pricing) {\n        this.courseService.addPricing(this.id, { ...pricing, total: pricing.total * 100 }).subscribe({\n          next: (res) => {\n            this.pricing.push(res.data);\n            this.snackBar.open('添加成功');\n          },\n          error: (error) => {\n            this.snackBar.open(error.message);\n          },\n        });\n      }\n    });\n  }\n\n  onPricingSave(pricing: Pricing | any) {\n    this.courseService.updatePricing(this.id, pricing.id, pricing).subscribe({\n      next: (res: any) => {\n        this.snackBar.open('保存成功');\n      },\n      error: (e) => {\n        this.snackBar.open(e.message);\n      },\n    });\n  }\n  onPricingDelete(pricing: Pricing | 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.deletePricing(this.id, pricing.id).subscribe({\n          next: (res: any) => {\n            remove(this.pricing, {\n              id: pricing.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 pricing; track item) {\n        <rolatech-pricing-item\n          [pricing]=\"item\"\n          [actions]=\"true\"\n          (save)=\"onPricingSave($event)\"\n          (delete)=\"onPricingDelete($event)\"\n        >\n        </rolatech-pricing-item>\n      }\n    </div>\n    <button mat-stroked-button (click)=\"addPricing()\" class=\"mt-3\">\n      <mat-icon>add</mat-icon>\n      <span>添加价格</span>\n    </button>\n  </div>\n</rolatech-course-manage-content>\n"]}
|
|
126
|
+
}] });
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"course-manage-pricing.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.ts","../../../../../../../../libs/angular-course/src/lib/pages/course-manage/course-manage-pricing/course-manage-pricing.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, inject } from '@angular/core';\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 { PricingItemComponent, CoursePricingDialogComponent, CoursePricingAddDialogComponent } from '../../../components';\nimport { Pricing, CourseStatus, CourseType } from '../../../interfaces';\nimport { CourseService } from '../../../services';\n\n@Component({\n  selector: 'rolatech-course-manage-pricing',\n  templateUrl: './course-manage-pricing.component.html',\n  styleUrls: ['./course-manage-pricing.component.scss'],\n  standalone: true,\n  imports: [PricingItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, CourseManageContentComponent],\n})\nexport class CourseManagePricingComponent extends BaseComponent implements OnInit {\n  courseService = inject(CourseService);\n  isLoading = false;\n  pricing: Pricing[] = [];\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.findPricing(this.id).subscribe({\n      next: (res) => {\n        if (res.data) {\n          this.pricing = res.data;\n        }\n      },\n    });\n  }\n  editPricing() {\n    const options = {\n      width: '500px',\n      title: '编辑价格',\n      height: '90%',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: CoursePricingAddDialogComponent,\n      data: {\n        courseId: this.id,\n        pricing: this.pricing,\n      },\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe((result) => {\n      if (result) {\n        this.courseService.addPricing(this.id, { pricing: 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  addPricing() {\n    const options = {\n      width: '500px',\n      title: '添加价格',\n      cancelText: '取消',\n      confirmText: '确认',\n      component: CoursePricingAddDialogComponent,\n      data: {},\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe((pricing) => {\n      if (pricing) {\n        this.courseService.addPricing(this.id, { ...pricing, total: pricing.total * 100 }).subscribe({\n          next: (res) => {\n            this.pricing.push(res.data);\n            this.snackBarService.open('添加成功');\n          },\n          error: (error) => {\n            this.snackBarService.open(error.message);\n          },\n        });\n      }\n    });\n  }\n\n  onPricingSave(pricing: Pricing | any) {\n    this.courseService.updatePricing(this.id, pricing.id, pricing).subscribe({\n      next: (res: any) => {\n        this.snackBarService.open('保存成功');\n      },\n      error: (e) => {\n        this.snackBarService.open(e.message);\n      },\n    });\n  }\n  onPricingDelete(pricing: Pricing | any) {\n    const options = {\n      title: '删除价格',\n      message: '确定删除此价格吗?',\n      cancelText: '取消',\n      confirmText: '确认',\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe((result) => {\n      if (result) {\n        this.courseService.deletePricing(this.id, pricing.id).subscribe({\n          next: (res: any) => {\n            remove(this.pricing, {\n              id: pricing.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 pricing; track item) {\n        <rolatech-pricing-item\n          [pricing]=\"item\"\n          [actions]=\"true\"\n          (save)=\"onPricingSave($event)\"\n          (delete)=\"onPricingDelete($event)\"\n        >\n        </rolatech-pricing-item>\n      }\n    </div>\n    <button mat-stroked-button (click)=\"addPricing()\" class=\"mt-3\">\n      <mat-icon>add</mat-icon>\n      <span>添加价格</span>\n    </button>\n  </div>\n</rolatech-course-manage-content>\n"]}
|
package/esm2022/lib/pages/course-manage/course-manage-schedule/course-manage-schedule.component.mjs
CHANGED
|
@@ -2,7 +2,7 @@ import { Component, inject } from '@angular/core';
|
|
|
2
2
|
import { remove } from 'lodash';
|
|
3
3
|
import { MatIconModule } from '@angular/material/icon';
|
|
4
4
|
import { MatButtonModule } from '@angular/material/button';
|
|
5
|
-
import { BaseComponent,
|
|
5
|
+
import { BaseComponent, ToolbarComponent } from '@rolatech/angular-components';
|
|
6
6
|
import { CourseManageContentComponent } from '../course-manage-content/course-manage-content.component';
|
|
7
7
|
import { ScheduleItemComponent, CourseScheduleAddDialogComponent } from '../../../components';
|
|
8
8
|
import { CourseStatus, CourseType } from '../../../interfaces';
|
|
@@ -98,14 +98,14 @@ export class CourseManageScheduleComponent extends BaseComponent {
|
|
|
98
98
|
});
|
|
99
99
|
}
|
|
100
100
|
onScheduleDelete(schedule) {
|
|
101
|
-
const
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
101
|
+
const options = {
|
|
102
|
+
title: '删除课表',
|
|
103
|
+
message: '确定删除此课表吗?',
|
|
104
|
+
cancelText: '取消',
|
|
105
|
+
confirmText: '确认',
|
|
106
|
+
};
|
|
107
|
+
this.dialogService.open(options);
|
|
108
|
+
this.dialogService.confirmed().subscribe((result) => {
|
|
109
109
|
if (result) {
|
|
110
110
|
this.courseService.deleteSchedule(this.id, schedule.id).subscribe({
|
|
111
111
|
next: (res) => {
|
|
@@ -128,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.2", ngImpor
|
|
|
128
128
|
type: Component,
|
|
129
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" }]
|
|
130
130
|
}] });
|
|
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"]}
|
|
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 options = {\n      title: '删除课表',\n      message: '确定删除此课表吗?',\n      cancelText: '取消',\n      confirmText: '确认',\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().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-Du0SRSCJ.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-Du0SRSCJ.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-Du0SRSCJ.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-BILowjd2.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rolatech-angular-course-course-index.component-
|
|
1
|
+
{"version":3,"file":"rolatech-angular-course-course-index.component-BILowjd2.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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"}
|