mirror of
https://gitlab.com/TheGamecraft/c-cms.git
synced 2026-04-21 10:49:10 -04:00
Working schedule v2
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Event;
|
||||
use App\EventType;
|
||||
use App\GoogleDriveFile;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Response;
|
||||
@@ -57,6 +58,8 @@ class EventController extends Controller
|
||||
{
|
||||
$event->weekly_msg_file = [''];
|
||||
}
|
||||
} else {
|
||||
$event->weekly_msg_file = [''];
|
||||
}
|
||||
|
||||
$event->name = request('name');
|
||||
@@ -77,11 +80,13 @@ class EventController extends Controller
|
||||
if(\request("use_weekly_msg"))
|
||||
{
|
||||
$event->use_weekly_msg = 1;
|
||||
$event->weekly_msg_publication_time = \request('date_msg');
|
||||
$event->msg = request('admin_desc');
|
||||
}
|
||||
else
|
||||
{
|
||||
$event->use_weekly_msg = 0;
|
||||
$event->weekly_msg_publication_time = null;
|
||||
$event->msg = "";
|
||||
}
|
||||
|
||||
@@ -203,7 +208,7 @@ class EventController extends Controller
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
return view('admin.schedule.event.edit',['activity' => \App\Event::find($id)]);
|
||||
return view('admin.schedule.event.edit',['event' => \App\Event::find($id)]);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -215,52 +220,101 @@ class EventController extends Controller
|
||||
*/
|
||||
public function update($id)
|
||||
{
|
||||
$event = Event::find($id);
|
||||
$event = Event::findOrFail($id);
|
||||
|
||||
// if (\App\GoogleDriveFile::checkConfig())
|
||||
// {
|
||||
// if (\request()->hasFile('files'))
|
||||
// {
|
||||
// $dir = \App\GoogleDriveFile::findByPath('.Systeme/.Fichier/.MessageDeLaSemaine');
|
||||
// $files = [];
|
||||
// foreach (\request()->file('files') as $f)
|
||||
// {
|
||||
// $name = urlencode(pathinfo($f->getClientOriginalName())['filename'].'_'.uniqid().'.'.$f->getClientOriginalExtension());
|
||||
// \Storage::cloud()->putFileAs($dir->id,$f,$name);
|
||||
// array_push($files,$name);
|
||||
// }
|
||||
// $event->weekly_msg_file = $files;
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// $event->weekly_msg_file = [''];
|
||||
// }
|
||||
// } else {
|
||||
// $event->weekly_msg_file = [''];
|
||||
// }
|
||||
|
||||
$event->name = request('name');
|
||||
$event->date_begin = request('begin');
|
||||
$event->date_end = request('end');
|
||||
$event->date_begin = request('begin_time');
|
||||
$event->date_end = request('end_time');
|
||||
$event->user_id = \Auth::user()->id;
|
||||
$event->location = request('location');
|
||||
|
||||
if(request('is_mandatory') != null){
|
||||
$event->is_mandatory = 1;
|
||||
} else {
|
||||
$event->is_mandatory = 0;
|
||||
}
|
||||
$event->desc = request('desc');
|
||||
if(\request('msg'))
|
||||
|
||||
$event->desc = \request('admin_desc');
|
||||
|
||||
if(\request("use_weekly_msg"))
|
||||
{
|
||||
$event->msg = request('msg');
|
||||
$event->use_weekly_msg = 1;
|
||||
$event->weekly_msg_publication_time = \request('date_msg');
|
||||
$event->msg = request('admin_desc');
|
||||
}
|
||||
else
|
||||
{
|
||||
$event->use_weekly_msg = 0;
|
||||
$event->weekly_msg_publication_time = null;
|
||||
$event->msg = "";
|
||||
}
|
||||
if(\request('date_msg'))
|
||||
|
||||
if(\request("use_schedule"))
|
||||
{
|
||||
$event->date_msg = request('date_msg');
|
||||
$event->use_schedule = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
$event->date_msg = "";
|
||||
$event->use_schedule = 0;
|
||||
}
|
||||
|
||||
$event->calendar_color = \request('calendar_color');
|
||||
$event->calendar_icon = \request('calendar_icon');
|
||||
|
||||
$nbLevel = 1;
|
||||
$niveaux = [];
|
||||
while (\request('level_name_'.$nbLevel))
|
||||
{
|
||||
array_push($niveaux,['name' => \request('level_name_'.$nbLevel)]);
|
||||
$nbLevel++;
|
||||
}
|
||||
|
||||
$nbPeriode = 1;
|
||||
$periodes = [];
|
||||
while (\request('periode_name_'.$nbPeriode))
|
||||
{
|
||||
array_push($periodes,[
|
||||
'name' => \request('periode_name_'.$nbPeriode),
|
||||
'begin_time' => \request('periode_begin_time_'.$nbPeriode),
|
||||
'end_time' => \request('periode_end_time_'.$nbPeriode)
|
||||
]);
|
||||
$nbPeriode++;
|
||||
}
|
||||
$event->schedule = [
|
||||
'periodes' => $periodes,
|
||||
'niveaux' => $niveaux,
|
||||
'courses' => []
|
||||
];
|
||||
|
||||
$event->save();
|
||||
|
||||
if ($event->type == 1) {
|
||||
for ($l=1; $l <= \App\Config::getData('admin_level_in_schedule_nb'); $l++) {
|
||||
for ($p=1; $p <= \App\Config::getData('admin_periode_nb'); $p++) {
|
||||
if ($event->use_schedule) {
|
||||
for ($l=1; $l < $nbLevel; $l++) {
|
||||
for ($p=1; $p < $nbPeriode; $p++) {
|
||||
|
||||
$course = new \App\Course();
|
||||
|
||||
foreach ($event->courses as $c)
|
||||
{
|
||||
if ($c->periode == $p)
|
||||
{
|
||||
if ($c->level == $l)
|
||||
{
|
||||
$course = $c;
|
||||
}
|
||||
}
|
||||
}
|
||||
$course = $event->course($p,$l);
|
||||
|
||||
$users = \App\User::all();
|
||||
$instructor = request('instruc_n'.$l.'_p'.$p);
|
||||
@@ -272,22 +326,48 @@ class EventController extends Controller
|
||||
}
|
||||
}
|
||||
|
||||
$course->name = request('name_n'.$l.'_p'.$p);
|
||||
$course->user_id = $instructor;
|
||||
$course->ocom = request('ocom_n'.$l.'_p'.$p);
|
||||
$course->location = request('loc_n'.$l.'_p'.$p);
|
||||
$course->location = request('location_n'.$l.'_p'.$p);
|
||||
$course->periode = $p;
|
||||
$course->level = $l;
|
||||
$course->comment_officer = "";
|
||||
$course->comment = "";
|
||||
|
||||
$course->event_id = $event->id;
|
||||
|
||||
if(\request("use_course_n".$l."_p".$p) == 'on')
|
||||
{
|
||||
$course->name = request('name_n'.$l.'_p'.$p);
|
||||
$course->ocom = request('ocom_n'.$l.'_p'.$p);
|
||||
$course->desc = "";
|
||||
}
|
||||
else
|
||||
{
|
||||
$course->name = "";
|
||||
$course->ocom = "";
|
||||
if (request('desc_n'.$l.'_p'.$p) == null)
|
||||
{
|
||||
$course->desc = "";
|
||||
}
|
||||
else
|
||||
{
|
||||
$course->desc = request('desc_n'.$l.'_p'.$p);
|
||||
}
|
||||
}
|
||||
$course->comment_officer = "";
|
||||
$course->comment = "";
|
||||
$course->save();
|
||||
|
||||
$ocom = \App\OCOM::where('ocom','=',request('ocom_n'.$l.'_p'.$p))->first();
|
||||
if ($ocom != null)
|
||||
{
|
||||
$foo = $ocom->courses();
|
||||
$foo->push($course);
|
||||
$ocom->saveCourses($foo);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
clog('edit','success','a modifié un évènement',null,'App\Event',$event->id);
|
||||
return redirect('/admin/schedule')->with('success','Modification à l\'événement sauvegarder à l\'horaire');
|
||||
clog('add','success','a modifier un évènement',null,'App\Event',$event->id);
|
||||
return redirect('/admin/schedule')->with('success','Événement modifier à l\'horaire');
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -305,4 +385,35 @@ class EventController extends Controller
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
public function toJson($id)
|
||||
{
|
||||
$event = Event::findOrFail($id);
|
||||
$model = $event->schedule;
|
||||
$default_value = [];
|
||||
foreach ($model['periodes'] as $periode_index => $periode)
|
||||
{
|
||||
$niveau_array = [];
|
||||
foreach ($model['niveaux'] as $niveau_index => $niveau)
|
||||
{
|
||||
$course = $event->course($periode_index+1,$niveau_index+1);
|
||||
$use_course = "on";
|
||||
if ($course->name == null) {
|
||||
$use_course = "off";
|
||||
}
|
||||
array_push($niveau_array,[
|
||||
'ocom' => $course->ocom,
|
||||
'name' => $course->name,
|
||||
'location' => $course->location,
|
||||
'instructor' => $course->instructor(),
|
||||
'desc' => $course->desc,
|
||||
'use_course' => $use_course
|
||||
]);
|
||||
}
|
||||
array_push($default_value,$niveau_array);
|
||||
}
|
||||
$model['default_value'] = $default_value;
|
||||
$event->schedule_model = $model;
|
||||
return $event->toArray();
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user