Skip to content

Commit

Permalink
Allow partial export
Browse files Browse the repository at this point in the history
  • Loading branch information
ClFeSc committed Sep 16, 2022
1 parent cb4f1e7 commit 79038e9
Show file tree
Hide file tree
Showing 8 changed files with 153 additions and 7 deletions.
2 changes: 2 additions & 0 deletions frontend/src/app/pages/exercises/exercise/exercise.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import { ExerciseSettingsModalComponent } from './shared/exercise-settings/exerc
import { ExerciseStateBadgeComponent } from './shared/exercise-state-badge/exercise-state-badge.component';
import { ExerciseStatisticsModule } from './shared/exercise-statistics/exercise-statistics.module';
import { HospitalEditorModule } from './shared/hospital-editor/hospital-editor.module';
import { PartialExportSelectionComponent } from './shared/partial-export-selection/partial-export-selection-modal/partial-export-selection.component';
import { TimeTravelComponent } from './shared/time-travel/time-travel.component';
import { TrainerMapEditorComponent } from './shared/trainer-map-editor/trainer-map-editor.component';
import { TrainerToolbarComponent } from './shared/trainer-toolbar/trainer-toolbar.component';
Expand All @@ -32,6 +33,7 @@ import { TransferOverviewModule } from './shared/transfer-overview/transfer-over
CreateImageTemplateModalComponent,
EditImageTemplateModalComponent,
ImageTemplateFormComponent,
PartialExportSelectionComponent,
],
imports: [
CommonModule,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,10 @@ <h2>
um {{ timeConstraints.current | formatDuration }}
</span>
</button>
<button ngbDropdownItem (click)="partialExport()">
<i class="bi-card-list me-2"> </i>
Partieller Export
</button>
</div>
</div>
</h2>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import type { OnDestroy, OnInit } from '@angular/core';
import { Component } from '@angular/core';
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
import { Store } from '@ngrx/store';
import {
cloneDeepMutable,
Expand All @@ -14,6 +15,7 @@ import type { AppState } from 'src/app/state/app.state';
import { selectParticipantId } from 'src/app/state/exercise/exercise.selectors';
import { getStateSnapshot } from 'src/app/state/get-state-snapshot';
import { NotificationService } from '../core/notification.service';
import { openPartialExportSelectionModal } from '../shared/partial-export-selection/open-partial-export-selection-modal';

@Component({
selector: 'app-exercise',
Expand All @@ -29,6 +31,7 @@ export class ExerciseComponent implements OnInit, OnDestroy {
private readonly store: Store<AppState>,
public readonly apiService: ApiService,
private readonly messageService: MessageService,
private readonly modalService: NgbModal,
private readonly notificationService: NotificationService
) {}

Expand Down Expand Up @@ -86,6 +89,10 @@ export class ExerciseComponent implements OnInit, OnDestroy {
saveBlob(blob, `exercise-state-${currentState.participantId}.json`);
}

public partialExport() {
openPartialExportSelectionModal(this.modalService);
}

public exportExerciseState() {
const currentState = getStateSnapshot(this.store).exercise;
const blob = new Blob([
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import type { NgbModal } from '@ng-bootstrap/ng-bootstrap';
import { PartialExportSelectionComponent } from './partial-export-selection-modal/partial-export-selection.component';

export function openPartialExportSelectionModal(ngbModalService: NgbModal) {
ngbModalService.open(PartialExportSelectionComponent, {
size: 'm',
});
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
<div class="modal-header">
<h4 class="modal-title">Partieller Export</h4>
<button type="button" class="btn-close" (click)="close()"></button>
</div>
<div class="modal-body">
<table class="table">
<tbody>
<tr>
<td>Patientenvorlagen</td>
<td>
<div class="form-switch">
<input
[(ngModel)]="configuration.patientCategories"
class="form-check-input"
type="checkbox"
/>
</div>
</td>
</tr>
<tr>
<td>Fahrzeugvorlagen</td>
<td>
<div class="form-switch">
<input
[(ngModel)]="configuration.vehicleTemplates"
class="form-check-input"
type="checkbox"
/>
</div>
</td>
</tr>
<tr>
<td>Bildvorlagen</td>
<td>
<div class="form-switch">
<input
[(ngModel)]="configuration.mapImageTemplates"
class="form-check-input"
type="checkbox"
/>
</div>
</td>
</tr>
</tbody>
</table>
<button
(click)="partialExport()"
[disabled]="
!(
configuration.mapImageTemplates ||
configuration.patientCategories ||
configuration.vehicleTemplates
)
"
class="btn btn-primary"
>
Exportieren
</button>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
import { Component } from '@angular/core';
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
import { Store } from '@ngrx/store';
import { cloneDeepMutable, PartialExport } from 'digital-fuesim-manv-shared';
import { saveBlob } from 'src/app/shared/functions/save-blob';
import type { AppState } from 'src/app/state/app.state';
import { getStateSnapshot } from 'src/app/state/get-state-snapshot';

interface PartialExportConfiguration {
patientCategories: boolean;
vehicleTemplates: boolean;
mapImageTemplates: boolean;
}

@Component({
selector: 'app-partial-export-selection',
templateUrl: './partial-export-selection.component.html',
styleUrls: ['./partial-export-selection.component.scss'],
})
export class PartialExportSelectionComponent {
constructor(
private readonly store: Store<AppState>,
public activeModal: NgbActiveModal
) {}

public configuration: PartialExportConfiguration = {
mapImageTemplates: false,
patientCategories: false,
vehicleTemplates: false,
};

public close() {
this.activeModal.close();
}

public partialExport() {
const currentState = getStateSnapshot(this.store).exercise;
const patientCategories = this.configuration.patientCategories
? currentState.patientCategories
: undefined;
const vehicleTemplates = this.configuration.vehicleTemplates
? currentState.vehicleTemplates
: undefined;
const mapImageTemplates = this.configuration.mapImageTemplates
? currentState.mapImageTemplates
: undefined;
const blob = new Blob([
JSON.stringify(
new PartialExport(
cloneDeepMutable(patientCategories),
cloneDeepMutable(vehicleTemplates),
cloneDeepMutable(mapImageTemplates)
)
),
]);
saveBlob(blob, `exercise-partial-${currentState.participantId}.json`);
}
}
22 changes: 15 additions & 7 deletions shared/src/export-import/file-format/partial-export.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,8 @@ import {
IsString,
ValidateNested,
} from 'class-validator';
import {
MapImageTemplate,
PatientTemplate,
VehicleTemplate,
} from '../../models';
import { MapImageTemplate, VehicleTemplate } from '../../models';
import { PatientCategory } from '../../models/patient-category';
import { BaseExportImportFile } from './base-file';

export class PartialExport extends BaseExportImportFile {
Expand All @@ -21,8 +18,8 @@ export class PartialExport extends BaseExportImportFile {
@IsOptional()
@IsArray()
@ValidateNested({ each: true })
@Type(() => PatientTemplate)
public readonly patientTemplates?: PatientTemplate[];
@Type(() => PatientCategory)
public readonly patientCategories?: PatientCategory[];

@IsOptional()
@IsArray()
Expand All @@ -35,4 +32,15 @@ export class PartialExport extends BaseExportImportFile {
@ValidateNested({ each: true })
@Type(() => MapImageTemplate)
public readonly mapImageTemplates?: MapImageTemplate[];

public constructor(
patientCategories?: PatientCategory[],
vehicleTemplates?: VehicleTemplate[],
mapImageTemplates?: MapImageTemplate[]
) {
super();
this.patientCategories = patientCategories;
this.vehicleTemplates = vehicleTemplates;
this.mapImageTemplates = mapImageTemplates;
}
}

0 comments on commit 79038e9

Please sign in to comment.