File: /var/www/vhost/disk-apps/qas.sports-crowd.com/app/Http/Controllers/PlayerController.php
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use DataTables;
use App\Player;
use App\Country;
use App\Position;
use App\EquipmentCategory;
use App\Services\PlayersService;
use Illuminate\Support\Facades\Storage;
use App\Http\Controllers\UtilController;
class PlayerController extends Controller
{
private $util;
public function __construct()
{
$this->util = new UtilController();
}
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
return view('players.list');
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
$positions = Position::all();
$equipmentCategories = EquipmentCategory::all();
$countries = Country::all();
$player = null;
return view('players.create', compact('positions', 'equipmentCategories', 'countries', 'player'));
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request, PlayersService $playersService)
{
try {
if (!Position::where('name', $request->input('name'))->first()) {
$player = $playersService->store($request);
return response(array("r" => true, "type" => "success", "title" => "", "m" =>
__('messages.created_successfully'), "data" => $player->id));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
__('messages.error_creating'), "data" => null));
}
} catch (\Throwable $th) {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
__('messages.error_creating'), "data" => $th->getMessage()));
}
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
//
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
$positions = Position::all();
$equipmentCategories = EquipmentCategory::all();
$countries = Country::all();
$player = Player::findOrFail($id);
return view('players.edit', compact('player', 'positions', 'equipmentCategories', 'countries'));
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id, PlayersService $playersService)
{
try {
if (!Player::where([['id', '!=', $id], ['name', $request->input('name')]])->first()) {
$playersService->update($request, $id);
return response(array("r" => true, "type" => "success", "title" => "", "m" =>
__('messages.updated_successfully'), "data" => '$player->id'));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
__('messages.already_exists', ['name' => $request->input('name')]), "data" => null));
}
} catch (\Throwable $th) {
return response(array("r" => false, "type" => "error", "title" => "Oops... " . $th, "m" =>
__('messages.error_creating'), "data" => null));
}
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
try {
if (Player::where('id', $id)->delete()) {
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 tableFilter()
{
$obj = Player::select('id', 'image', 'name', 'number', 'age', 'country_id', 'date_of_birth');
return DataTables::of($obj)
->addColumn('actions', function ($obj) {
return
'<i class="fa fa-pencil iconMini" onClick="clickEdit(' . $obj->id . ')" data-id="' . $obj->id . '"
title="Editar"></i>
<i class="fa fa-trash iconMini" onClick="clickDelete(' . $obj->id . ')" data-id="' . $obj->id . '"
title="Eliminar"></i>
';
})
->addColumn('image', function ($obj) {
if (!$obj->image) {
return $this->util->generateEmptyImageColumn();
} else {
return $this->util->generateImageColumnRound(config('filesystems.disks.s3.url') . '/players/' . $obj->image, $obj->name, 'dorsal' . $obj->id);
}
})
->rawColumns(['actions', 'image'])
->make(true);
}
public function saveImage(Request $request)
{
try {
$extension = $request->file('image')->getClientOriginalExtension();
$filenametostore = $request->id . '.' . $extension;
Storage::disk('s3')->put(
config('s3.players') . $filenametostore,
fopen($request->file('image'), 'r+'),
'public'
);
$player = Player::find($request->id);
$player->image = $filenametostore;
$player->update();
return response(array("r" => true, "type" => "success", "title" => "", "m" =>
__('messages.updated_successfully'), "data" => null));
} catch (\Throwable $th) {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" =>
__('messages.error_updating'), "data" => $th->getMessage()));
}
}
}