HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/ivs.kaunokolegija.lt/laravel/app/Http/Controllers/Admin/ScienceEventController.php
<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\Controller;
use App\Http\Controllers\Traits\CsvImportTrait;
use App\Http\Requests\MassDestroyScienceEventRequest;
use App\Http\Requests\StoreScienceEventRequest;
use App\Http\Requests\UpdateScienceEventRequest;
use App\Models\ScienceEvent;
use Gate;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use Yajra\DataTables\Facades\DataTables;

class ScienceEventController extends Controller
{
    use CsvImportTrait;

    public function index(Request $request)
    {
        abort_if(Gate::denies('science_event_access'), Response::HTTP_FORBIDDEN, '403 Forbidden');

        if ($request->ajax()) {
            $query = ScienceEvent::query()->select(sprintf('%s.*', (new ScienceEvent)->table));
            $table = DataTables::of($query);

            $table->addColumn('placeholder', '&nbsp;');
            $table->addColumn('actions', '&nbsp;');

            $table->editColumn('actions', function ($row) {
                $viewGate      = 'science_event_show';
                $editGate      = 'science_event_edit';
                $deleteGate    = 'science_event_delete';
                $crudRoutePart = 'science-events';
                $modal         = true;
                $rowData       = $row;

                return view('partials.datatablesActions', compact(
                    'viewGate',
                    'editGate',
                    'deleteGate',
                    'crudRoutePart',
                    'row',
                    'modal',
                    'rowData'
                ));
            });

            $table->editColumn('id', fn($row) => $row->id ?: '');
            $table->editColumn('type', fn($row) => $row->type ?: '');
            $table->editColumn('title', fn($row) => $row->title ?: '');
            $table->editColumn('link', fn($row) => $row->link ?: '');
            $table->editColumn('science_fields', fn($row) => $row->science_fields ?: '');
            $table->editColumn('date', function ($row) {
    return !empty($row->date) && strtotime($row->date) ? date('Y-m-d', strtotime($row->date)) : '';
});
            $table->editColumn('price', fn($row) => $row->price ?: '');
            $table->editColumn('additional_info', fn($row) => $row->additional_info ?: '');

            $table->rawColumns(['actions', 'placeholder']);

            return $table->make(true);
        }

        return view('admin.scienceEvents.index');
    }

    public function create()
    {
        abort_if(Gate::denies('science_event_create'), Response::HTTP_FORBIDDEN, '403 Forbidden');

        return view('admin.scienceEvents.create');
    }

    public function store(StoreScienceEventRequest $request)
    {
        $scienceEvent = ScienceEvent::create($request->all());

        if ($request->ajax()) {
            return response()->json([
                'success' => true,
                'message' => __('global.create_success'),
                'data' => $scienceEvent,
            ], 201);
        }

        return redirect()->route('admin.science-events.index');
    }

    public function edit(ScienceEvent $scienceEvent)
{
    abort_if(Gate::denies('science_event_edit'), Response::HTTP_FORBIDDEN, '403 Forbidden');

    $scienceEvent->load('scienceFields'); // jeigu reikia susijusiĊ³ laukĊ³

    return response()->json($scienceEvent);
}


    public function update(UpdateScienceEventRequest $request, ScienceEvent $scienceEvent)
    {
        $scienceEvent->update($request->all());

        if ($request->ajax()) {
            return response()->json([
                'success' => true,
                'data' => $scienceEvent
            ]);
        }

        return redirect()->route('admin.science-events.index');
    }

    public function destroy(ScienceEvent $scienceEvent)
    {
        abort_if(Gate::denies('science_event_delete'), Response::HTTP_FORBIDDEN, '403 Forbidden');

        $scienceEvent->delete();

        return back();
    }

    public function massDestroy(MassDestroyScienceEventRequest $request)
    {
        $events = ScienceEvent::find(request('ids'));

        foreach ($events as $event) {
            $event->delete();
        }

        return response(null, Response::HTTP_NO_CONTENT);
    }
}