Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
webbingbrasil/courses-module / Http / Controllers / Admin / CoursesController.php
Size: Mime:
<?php namespace Modules\Courses\Http\Controllers\Admin;

use Illuminate\Http\Request;

use Modules\Core\Http\Controllers\AdminController;
use Modules\Core\Services\Asset;
use Modules\Courses\Entities\Course;
use Modules\Courses\Http\Requests\CadastroCourseRequest;
use Modules\Courses\Services\CourseService;

class CoursesController extends AdminController
{
    /**
     * @var CourseService
     */
    private $service;

    public function __construct(CourseService $service){
        parent::__construct();
        $this->service = $service;

        Asset::add(\Config::get('core.assets.datatable'));
    }

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        //$this->authorize($this);
        return $this->service->render('courses::admin.list');
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        //$this->authorize($this);
        return view('courses::admin.create');
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(CadastroCourseRequest $request)
    {
        $input = $request->all();
        /** @var Course $result */
        $result = $this->service->create($input);

        if ($result instanceof Course) {
            $msg = trans('courses::courses.create.alerts.success', ['course' => $result->title]);
            $response = $this->getResponse($msg, 200, 'courses.index');
        } else {
            $msg = trans('courses::courses.create.alerts.error', ['course' => $result->title]);
            $response = $this->getResponse($msg, 400);
        }

        return $response;
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit($id)
    {
        //$this->authorize($this);
        return view('courses::admin.edit', ['data' => $this->service->editId($id)]);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(CadastroCourseRequest $request, $id)
    {
        //$data = $this->service->editId($id);
        $input = $request->all();

        /*$rules = [];
        if ($input['cnpj'] != $laboratorio->cnpj) {
            $rules['cnpj'] = 'required|cnpj|max:50|unique:laboratorios';
        }
        if (!empty($rules)) {
            $validation = Validator::make($request->all(), $rules);

            if ($validation->fails()) {
                return response()->json($validation->messages(), 400);
            }
        }*/

        /** @var Course $result */
        $result = $this->service->update($id, $input);

        if ($result instanceof Course) {
            $msg = trans('courses::courses.edit.alerts.success', ['course' => $result->title]);
            $response = $this->getResponse($msg, 200, 'courses.index');
        } else {
            $msg = trans('courses::courses.edit.alerts.error', ['course' => $result->title]);
            $response = $this->getResponse($msg, 400);
        }

        return $response;

    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy($id)
    {
        //$this->authorize($this);
        $status = $this->service->delete($id);

        return response()->json([
            'success' => $status
        ]);
    }

}