From 2368900d3bd44606c5964f39239c17b0161f4d6a Mon Sep 17 00:00:00 2001 From: Yanick Minder Date: Thu, 21 Nov 2024 15:19:29 +0100 Subject: [PATCH] add delte option --- .../src/app/components/objective/ObjectiveMenuActions.ts | 7 +++++++ .../app/components/objective/ObjectiveMenuAfterActions.ts | 6 ++++++ .../src/app/services/objective-menu-actions.service.ts | 2 +- .../dialog/objective-dialog/objective-form.component.html | 7 +------ 4 files changed, 15 insertions(+), 7 deletions(-) diff --git a/frontend/src/app/components/objective/ObjectiveMenuActions.ts b/frontend/src/app/components/objective/ObjectiveMenuActions.ts index 2e36aa7ed6..a18b2a4920 100644 --- a/frontend/src/app/components/objective/ObjectiveMenuActions.ts +++ b/frontend/src/app/components/objective/ObjectiveMenuActions.ts @@ -47,6 +47,13 @@ export class ObjectiveMenuActions { return { displayName: 'Objective duplizieren', action: action, afterAction: afterAction }; } + deleteObjectiveAction(objective: ObjectiveMin): ObjectiveMenuEntry { + const action: ObjectiveMenuAction = () => this.dialogService.openConfirmDialog('CONFIRMATION.DELETE.OBJECTIVE'); + const afterAction: ObjectiveMenuAfterAction = (objective, dialogResult) => + this.afterActions.deleteObjective(objective); + return { displayName: 'Objective löschen', action: action, afterAction: afterAction }; + } + completeObjectiveAction(objective: ObjectiveMin): ObjectiveMenuEntry { const config = { data: { objectiveTitle: objective.title }, diff --git a/frontend/src/app/components/objective/ObjectiveMenuAfterActions.ts b/frontend/src/app/components/objective/ObjectiveMenuAfterActions.ts index 4d0e237e21..8dec478557 100644 --- a/frontend/src/app/components/objective/ObjectiveMenuAfterActions.ts +++ b/frontend/src/app/components/objective/ObjectiveMenuAfterActions.ts @@ -37,6 +37,12 @@ export class ObjectiveMenuAfterActions { }); } + deleteObjective(objective: ObjectiveMin) { + this.objectiveService.deleteObjective(objective.id).subscribe(() => { + this.refreshDataService.markDataRefresh(); + }); + } + objectiveBackToDraft(objectiveMin: ObjectiveMin) { this.objectiveService.getFullObjective(objectiveMin.id).subscribe((objective: Objective) => { objective.state = 'DRAFT' as State; diff --git a/frontend/src/app/services/objective-menu-actions.service.ts b/frontend/src/app/services/objective-menu-actions.service.ts index 32d27aac32..2de87653d8 100644 --- a/frontend/src/app/services/objective-menu-actions.service.ts +++ b/frontend/src/app/services/objective-menu-actions.service.ts @@ -50,7 +50,7 @@ export class ObjectiveMenuActionsService { } private getDefaultActions(objective: ObjectiveMin): ObjectiveMenuEntry[] { - return [this.actions.duplicateObjectiveAction(objective)]; + return [this.actions.duplicateObjectiveAction(objective), this.actions.deleteObjectiveAction(objective)]; } private getDraftMenuActions(objective: ObjectiveMin): ObjectiveMenuEntry[] { diff --git a/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.html b/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.html index f6a1b30d0e..68f425f669 100644 --- a/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.html +++ b/frontend/src/app/shared/dialog/objective-dialog/objective-form.component.html @@ -95,11 +95,6 @@ - -
- -
+ >