File: /var/www/vhost/disk-apps/dev-telemedicina.teky.com.co/app/Http/Controllers/FieldsController.php
<?php
namespace Telemedicina\Http\Controllers;
use DB;
use DataTables;
use Telemedicina\Field;
use Telemedicina\FieldInput;
use Telemedicina\FieldValue;
use Telemedicina\FieldDatasource;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class FieldsController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
return view('fields.list');
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
$fieldInputs = FieldInput::where('active', 1)->get();
$fieldValues = FieldValue::where('active', 1)->get();
$fieldDatasources = FieldDatasource::where('active', 1)->get();
return view('fields.create', compact('fieldInputs', 'fieldValues', 'fieldDatasources'));
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
if (!Field::where('name_control', $request->input('name_control'))->first()) {
if ($input = Field::create($request->all())) {
return response(array("r" => true, "type" => "success", "title" => "", "m" => __('messages.created_successfully'), "data" => null));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.error_creating'), "data" => null));
}
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.already_exists', ['name' => $request->input('name_control')]), "data" => null));
}
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
return redirect()->back();
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
$field = Field::findOrFail($id);
$fieldInputs = FieldInput::where('active', 1)->get();
$fieldValues = FieldValue::where('active', 1)->get();
$fieldDatasources = FieldDatasource::where('active', 1)->get();
if ($field) {
return view('fields.edit', compact('field','fieldInputs', 'fieldValues', 'fieldDatasources'));
} else {
return redirect()->back();
}
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
if (!Field::where([['id', '!=', $id], ['name_control', $request->input('name_control')]])->first()) {
if (Field::where('id', $id)->update(array_slice($request->all(), 1))) {
return response(array("r" => true, "type" => "success", "title" => "", "m" => __('messages.updated_successfully'), "data" => null));
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.error_updating'), "data" => null));
}
} else {
return response(array("r" => false, "type" => "error", "title" => "Oops...", "m" => __('messages.already_exists', ['name' => $request->input('name_control')]), "data" => null));
}
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
if (Field::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));
}
}
public function tableFilter(){
$obj = $obj = DB::table('fields')
->select('fields.id','fields.name','fields.active')->whereNull('fields.deleted_at');
return DataTables::of($obj)
->addColumn('actions', function ($obj) {
return '
<i class="fa fa-pencil iconMini " onClick="clickEdit('.$obj->id.')" data-id="'.$obj->id.'" data-toggle="tooltip" data-placement="bottom" style="cursor:pointer;"></i>
<i class="fa fa-trash iconMini " onClick="clickDelete('.$obj->id.')" data-id="'.$obj->id.'" data-toggle="tooltip" data-placement="bottom" style="cursor:pointer;"></i>
';
})
->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([ 'active','actions'])
->make(true);
}
public function activate(Request $request){
$id= $request['id'];
$state= $request['state'];
$field = Field::find($id);
$field->active = $state;
$field->update();
if ($field) {
return array('r' => true, 'd' => null, 'm'=> __('messages.updated_successfully'));
}else{
return array('r' => false,'d' => null, 'm'=> __('messages.error_updating'));
}
}
}