<?php

namespace App\Http\Controllers;

use App\Http\Support\ValidationRule;
use App\Models\Kegiatan;
use App\Models\KegiatanPeserta;
use App\Models\Konferensi;
use App\Models\Registrasi;
use Carbon\Carbon;
use Exception;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Log;

class RegistrasiController extends Controller
{
    public function create(){
        $kegiatan = Kegiatan::get();
        $konferensi = Konferensi::get();
        $jumlahPendaftar = Registrasi::count();
        $nourut = sprintf("%05s", $jumlahPendaftar+1);
        $tgldaftar = Carbon::now()->format('d-m-Y');
        $komponen = explode('-', $tgldaftar);
        $koderegistrasi = 'REG-'.$komponen[0].$komponen[1].$komponen[2].$nourut;

        $data = [
            'kegiatan' => $kegiatan,
            'konferensi' => $konferensi,
            'kode_registrasi' => $koderegistrasi
        ];

        return view('form_registrasi', $data);
    }

    public function store(Request $request) {
        // dd($request);
        $rules = [
            'nama' => 'required|string',
            'email' => 'required|email:rfc,dns',
            'telepon' => 'required|numeric',
            'instansi' => 'required|string',
            'jabatan' => 'required|string',
            'alamat' => 'required|string',
            'kodepos' => 'required|string',
            'kota' => 'required|string',
            'kode_registrasi' => 'required'
        ];

        $request->validate($rules, ValidationRule::getErrorMessage($rules));

        DB::beginTransaction();

        try{
            $registrasi = [
                'nama' => strip_tags($request->nama),
                'email' => strip_tags($request->email),
                'telepon' => strip_tags($request->telepon),
                'instansi' => strip_tags($request->instansi),
                'jabatan' => strip_tags($request->jabatan),
                'alamat' => strip_tags($request->alamat),
                'kode_pos' => strip_tags($request->kodepos),
                'kota' => strip_tags($request->kota),
                'kode_registrasi' => strip_tags($request->kode_registrasi)
            ];

            $tglRegistrasi = Carbon::now()->format('Y-m-d h:i:s');
            // $kegiatan = Kegiatan::find($request->kegiatan);
            // $konferensi = Konferensi::find($request->konferensi);


            $id_registrasi = Registrasi::query()->create($registrasi)->id;

            foreach($request->konferensi as $kon){
                $i = 0;
                $daftarKonferensi[] = $kon;
                $konferensi = Konferensi::select('nama')->where('id', $kon)->first();

                foreach($request->input('kegiatan'.$i) as $keg){
                    $daftarKegiatan[] = $keg;
                    $kegiatan[] = Kegiatan::select('nama', 'harga')->where('id', $keg)->first();
                }

                $kegiatanpeserta[] = [
                    'id_registrasi' => $id_registrasi,
                    'id_kegiatan' => $kon,
                    'id_konferensi' => $daftarKonferensi[$i],
                    'nama_kegiatan' => $kegiatan[$i]['nama'],
                    'nama_konferensi' => $konferensi->nama,
                    'harga' => $kegiatan[$i]['harga']
                ];

                $i++;
            }

            foreach($kegiatanpeserta as $keg){
                KegiatanPeserta::query()->create($keg);
            }
            DB::commit();

            // return redirect()->back()
            //     ->with('success', 'Data saved successfully');
            // dd($kegiatanpeserta);
            return view('invoice', compact('registrasi', 'tglRegistrasi', 'kegiatanpeserta'))->with('success', 'Data saved successfully');

        }
        catch(Exception $e){
            dd($e);
            Log::error($e);
            DB::rollBack();

            return redirect()->back()
                ->with('error', 'Data failed to save');
        }

    }

    public function addFormKegiatan(Request $request)
    {
        $data['kegiatan'] = Kegiatan::get();
        $data['konferensi'] = Konferensi::get();
        $data['i'] = $request->i;

        return view('form_kegiatan', $data);
    }
}