From e14c7e3990921e369808d5a74e1f03997e3b0463 Mon Sep 17 00:00:00 2001 From: didier Date: Sun, 10 Nov 2024 17:10:11 +0100 Subject: [PATCH] add optional action plan --- app/Http/Controllers/ControlController.php | 37 ++++++++++++++++++++-- resources/views/controls/make.blade.php | 37 ++++++++++++++++++++-- resources/views/layout.blade.php | 1 + 3 files changed, 69 insertions(+), 6 deletions(-) diff --git a/app/Http/Controllers/ControlController.php b/app/Http/Controllers/ControlController.php index 9f68604..1d80107 100644 --- a/app/Http/Controllers/ControlController.php +++ b/app/Http/Controllers/ControlController.php @@ -7,6 +7,8 @@ use App\Models\Document; use App\Models\Domain; use App\Models\User; +use App\Models\Action; + use Carbon\Carbon; use Illuminate\Http\Request; use Illuminate\Http\Response; @@ -1242,13 +1244,13 @@ public function make(Request $request) } /** - * Do a Control + * Make a Control * - * @param \App\Domain $domain + * @param Request $request * * @return \Illuminate\Http\Response */ - public function doMake() + public function doMake(Request $request) { // Only for admin, user and auditee abort_if( @@ -1295,10 +1297,39 @@ public function doMake() $control->note = request('note'); $control->score = request('score'); $control->realisation_date = request('realisation_date'); + // only admin and user can update the plan_date and action_plan if (Auth::User()->role === 1 || Auth::User()->role === 2) { $control->plan_date = request('plan_date'); $control->action_plan = request('action_plan'); + + // Create an action plan ? + if ($request->has('add_action_plan')) { + $action = new Action(); + $action->name = $control->name; + $action->scope = $control->scope; + $action->status = 0; + $action->cause = $control->observations; + $action->remediation = $control->action_plan; + $action->due_date = request('next_date'); + $action->control_id = $control->id; + $action->save(); + + // Sync measures + $measures = DB::table('control_measure') + ->select('measure_id') + ->where('control_id',$control->id) + ->pluck('measure_id')->toArray(); + $action->measures()->sync($measures); + + // Sync owners + $owners = DB::table('control_user') + ->select('user_id') + ->where('control_id',$control->id) + ->pluck('user_id')->toArray(); + $action->owners()->sync($owners); + + } } else { $control->realisation_date = date('Y-m-d', strtotime('today')); } diff --git a/resources/views/controls/make.blade.php b/resources/views/controls/make.blade.php index c2be1f0..7a7b44a 100644 --- a/resources/views/controls/make.blade.php +++ b/resources/views/controls/make.blade.php @@ -1,6 +1,16 @@ @extends("layout") - +@section("style") + + @endsection @section("content") +
@@ -162,6 +172,14 @@
@if ((Auth::User()->role === 1)||(Auth::User()->role === 2)) +
+
+
+
+ + Create an action plan +
+
{{ trans('cruds.control.fields.action_plan') }} @@ -334,20 +352,33 @@ items.forEach((item) => { console.log(item.kind); if (item.kind === 'file') { - // adds the file to your dropzone instance myDropzone.addFile(item.getAsFile()) } }) } @if ((Auth::User()->role === 1)||(Auth::User()->role === 2)) - const mde1 = new EasyMDE({ + const easyMDE = new EasyMDE({ element: document.getElementById('mde1'), minHeight: "200px", maxHeight: "200px", status: false, spellChecker: false, }); + + // Rendre l'éditeur en lecture seule par défaut + easyMDE.codemirror.setOption("readOnly", true); + easyMDE.codemirror.getWrapperElement().classList.add('disabled-editor'); + + document.getElementById('toggleTextarea').addEventListener('change', function() { + if (this.checked) { + easyMDE.codemirror.setOption("readOnly", false); + easyMDE.codemirror.getWrapperElement().classList.remove('disabled-editor'); + } else { + easyMDE.codemirror.setOption("readOnly", true); + easyMDE.codemirror.getWrapperElement().classList.add('disabled-editor'); + } + }); @endif diff --git a/resources/views/layout.blade.php b/resources/views/layout.blade.php index d549758..e0c3c7c 100644 --- a/resources/views/layout.blade.php +++ b/resources/views/layout.blade.php @@ -11,6 +11,7 @@ + @yield('style')