File: /var/www/vhost/disk-apps/comfama.sports-crowd.com/app/Http/Controllers/ExperienceController.php
<?php
namespace App\Http\Controllers;
use Carbon\Carbon;
use App\Models\Experience\Experience;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\DB;
use Yajra\DataTables\Facades\DataTables;
class ExperienceController extends Controller
{
public function index($experience_type = 'children')
{
return view('experiences.settings.list', compact('experience_type'));
}
public function indexAdd($experience_type = 'children')
{
return view('experiences.settings.create', compact('experience_type'));
}
public function indexEdit($id)
{
$object = Experience::findOrFail($id);
return view('experiences.settings.edit', compact('object'));
}
public function tableFilter(Request $request)
{
$obj = $this->tableFilterQuery($request);
DB::enableQueryLog();
$dataTable = DataTables::of($obj);
$this->tableFilterCustomColumns($dataTable);
$response = $dataTable->make(true);
$data = $response->getData();
$data = json_decode(json_encode($data), true);
$queries = \DB::getQueryLog();
$data['queries'] = $queries;
return $data;
}
public function create(Request $request)
{
try {
if (Experience::where([['name', $request->input('name')], ['active', true]])->first()) {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.already_exists', ['name' => $request->input('name')]), "data" => null));
}
$data = $request->all();
if ($model = Experience::create($data)) {
$this->registerLog(Auth::user()->id, 'Crear experiencia', json_encode($request->all()), "Create", $this->getModule($request));
return response(array("r" => true, "type" => "success", "title" => "", "m" => __('experiences.settings.messages.create_success'), "data" => $model->id));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('experiences.settings.messages.create_error'), "data" => null));
}
} catch (\Exception $e) {
return response(
array(
"r" => false,
"type" => "error",
"title" => "Oops...",
"m" => __($e->getMessage()),
"data" => null
)
);
}
}
public function update(Request $request, $id)
{
try {
$request['id'] = $id;
if (Experience::where([['id', '!=', $id], ['name', $request->input('name')], ['active', true]])->first()) {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.already_exists', ['name' => $request->input('name')]), "data" => null));
}
$data = $request->all();
if (Experience::where('id', $id)->update($data)) {
$this->registerLog(Auth::user()->id, 'Editar experiencia', json_encode($request->all()), "Update", $this->getModule($request));
return response(array("r" => true, "type" => "success", "title" => "", "m" => __('messages.updated_successfully'), "data" => $id));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.error_updating'), "data" => null));
}
} catch (\Exception $e) {
return response(
array(
"r" => false,
"type" => "error",
"title" => "Oops...",
"m" => __($e->getMessage()),
"data" => null
)
);
}
}
public function delete(Request $request, $id)
{
try {
$experience = Experience::find($id);
if (Experience::where('id', $id)->delete()) {
$this->registerLog(Auth::user()->id, 'Eliminar experiencia', json_encode($experience), "Delete", $this->getModule($request));
return response(array("r" => true, "type" => "success", "title" => "", "m" => __('messages.deleted_successfully'), "data" => null));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.error_removing'), "data" => null));
}
} catch (\Illuminate\Database\QueryException $e) {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.delete_relation_data'), "data" => null));
}
}
public function activate(Request $request)
{
try {
$id = $request['id'];
$state = $request['state'];
$experience = Experience::find($id);
$experience->active = $state;
$experience->update();
$this->registerLog(Auth::user()->id, 'Activar/Desactivar experiencia', json_encode($experience), "Update", $this->getModule($request));
return array('r' => true, 'd' => null, 'm' => __('messages.updated_successfully'));
} catch (\Throwable $th) {
return array('r' => false, 'd' => null, 'm' => __('messages.error_updating'));
}
}
private function tableFilterQuery($request)
{
$experienceType = $request->experienceType;
DB::statement("SET sql_mode = ''");
$obj = Experience::select(
'id',
'name',
'icon',
'short_description',
'description',
'apply_to',
'includes',
'when',
'experience_type',
'active',
'created_at'
)
->where('experience_type', $experienceType)
->orderBy('created_at', 'DESC');
DB::statement("SET sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION'");
return $obj;
}
private function tableFilterCustomColumns($dataTable)
{
$dataTable->addColumn('actions', function ($obj) {
if (
$this->validateRolePermissions('experience', 'administrator') ||
$this->validateRolePermissions('experience', 'supervisor')
) {
$actions = '
<i class="fa fa-pencil iconMini" onClick="clickEdit(' . $obj->id . ')" data-id="' . $obj->id . '" data-toggle="tooltip" data-placement="bottom" title="Editar" style="cursor:pointer;"></i>
<i class="fa fa-trash iconMini" onClick="clickDelete(' . $obj->id . ')" data-id="' . $obj->id . '" data-toggle="tooltip" data-placement="bottom" title="Eliminar" style="cursor:pointer;"></i>
';
$actions .= '<i class="fa fa-list iconMini" onClick="getExperiencePlans(' . $obj->id . ')" data-id="' . $obj->id . '" title="Planes"></i>';
return $actions;
} else {
return '';
}
})
->editColumn('created_at', function ($obj) {
return Carbon::parse($obj->created_at)->format('Y-m-d h:i:s A');
})
->editColumn('active', function ($obj) {
if ($obj->active == 0) {
return '<div class="switch"><label><div class="checkbox checbox-switch switch-success"> <label> ' . __('messages.no') . ' <input type="checkbox" onChange="chk(' . $obj->id . ')" data-id="' . $obj->id . '" id="Checkactive' . $obj->id . '" name="Checkactivo" /> <span></span>' . __('messages.yes') . ' </label></div> </label> </div>';
} else {
return '<div class="switch"><label> <div class="checkbox checbox-switch switch-success"> <label> ' . __('messages.no') . ' <input type="checkbox" onChange="chk(' . $obj->id . ')" data-id="' . $obj->id . '" id="Checkactive' . $obj->id . '" name="Checkactivo" checked="" />
<span></span> ' . __('messages.yes') . ' </label> </div> </label> </div>';
}
})
->rawColumns(['actions', 'created_at', 'active']);
}
}