<?php

namespace App\Http\Controllers\Admin;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Arr;
use App\Http\Resources\Admin\PaymentResource;
use App\Helpers\Helper;
use App\Payment;
use Validator;

/**
 * Class PaymentController
 *
 * @package App\Http\Controllers
 */
class PaymentController extends Controller
{
    const ITEM_PER_PAGE = 100;

    public function index(Request $request)
    {
        $searchParams = $request->all();
        $list = Payment::notDeleted();
        $limit = Arr::get($searchParams, 'limit', static::ITEM_PER_PAGE);
        $id = Arr::get($searchParams, 'id', '');
        $keyword = Arr::get($searchParams, 'keyword', '');
        $status = Arr::get($searchParams, 'status', '');

        if (!empty($id)) {
            $list->where('id', $id);
        }

        if (!empty($keyword)) {
            $list->where('code', 'LIKE', '%' . $keyword . '%');
        }

        if ($status != '') {
            $list->where('status', $status);
        }

        $list->orderBy('id', 'DESC');

        return PaymentResource::collection($list->paginate($limit));
    }

    public function all(Request $request)
    {
        $searchParams = $request->all();
        $limit = Arr::get($searchParams, 'limit', static::ITEM_PER_PAGE);
        $list = Payment::select('id', 'name', 'slug')->notDeleted()->orderBy('id');

        return PaymentResource::collection($list->paginate($limit));
    }

    public function available(Request $request)
    {
        $ignoreId = Arr::get($request->all(), 'ignoreId', '');
        $list = Payment::select('id', 'name')->isPublished();

        if ($ignoreId != null && $ignoreId != "") {
            $list->where('id', '!=', $ignoreId);
        }

        $list->orderBy('id');

        return PaymentResource::collection($list->get());
    }

    public function show($id = 0)
    {
        $payment = Payment::notDeleted()->where('id', $id)->first();
        if (!isset($payment)) return response()->json(['errors' => 'Payment is not valid'], 403);

        return new PaymentResource($payment);
    }

    public function update(Request $request, $id = 0)
    {
        $validator = Validator::make($request->all(), ['name' => ['required'], 'is_activated' => ['required']]);
        if ($validator->fails()) return response()->json(['errors' => $validator->errors()], 403);
        $payment = Payment::notDeleted()->where('id', $id)->first();
        if (!isset($payment)) return response()->json(['errors' => 'Payment is not valid'], 403);
        $params = $request->all();
        $slug = $params['slug'];
        if ($slug == null || $slug == "") $slug = Helper::slug($params['name']);

        $parentId = 0;
        if (is_array($params['parent_id']) && isset($params['parent_id'][array_key_last($params['parent_id'])])) {
            $parentId = $params['parent_id'][array_key_last($params['parent_id'])];
        }

        $payment->update([
            'name'         => $params['name'],
            'slug'         => Helper::slug($slug),
            'parent_id'    => $parentId,
            'image'        => $params['image'],
            'sub_title'    => $params['sub_title'],
            'group'        => $params['group'],
            'description'  => $params['description'],
            'is_activated' => ($params['is_activated'] === true) ? 1 : 0,
            'updated_at'   => date('Y-m-d H:i:s')
        ]);

        return response()->json(null, 204);
    }

    public function destroy($id = 0)
    {
        $payment = Payment::notDeleted()->where('id', $id)->first();
        if (!isset($payment)) response()->json(['error' => 'Ehhh! Can not delete this Payment'], 403);

        try {
            $payment->update(['is_deleted' => true]);
        } catch (\Exception $ex) {
            response()->json(['error' => $ex->getMessage()], 403);
        }

        return response()->json(null, 204);
    }

    public function destroyMultiple(Request $request)
    {
        $validator = Validator::make($request->all(), ['ids' => 'required']);
        if ($validator->fails()) return response()->json(['errors' => $validator->errors()], 403);
        $listIds = $request->get('ids', []);
        $payments = Payment::notDeleted()->whereIn('id', $listIds)->get();
        if ($payments->count() <= 0) response()->json(['error' => 'Payment is not valid.'], 403);
        try {
            Payment::notDeleted()->whereIn('id', $listIds)->update(['is_deleted' => true]);
        } catch (\Exception $ex) {
            response()->json(['error' => $ex->getMessage()], 403);
        }

        return response()->json(null, 204);
    }

    public function activateMultiple(Request $request)
    {
        $validator = Validator::make($request->all(), ['ids' => 'required']);
        if ($validator->fails()) return response()->json(['errors' => $validator->errors()], 403);
        $listIds = $request->get('ids', []);
        $payments = Payment::notDeleted()->whereIn('id', $listIds)->get();
        if ($payments->count() <= 0) response()->json(['error' => 'Payment is not valid.'], 403);
        try {
            Payment::notDeleted()->whereIn('id', $listIds)->update(['is_activated' => true]);
        } catch (\Exception $ex) {
            response()->json(['error' => $ex->getMessage()], 403);
        }

        return response()->json(null, 204);
    }

    public function deactivateMultiple(Request $request)
    {
        $validator = Validator::make($request->all(), ['ids' => 'required']);
        if ($validator->fails()) return response()->json(['errors' => $validator->errors()], 403);
        $listIds = $request->get('ids', []);
        $payments = Payment::notDeleted()->whereIn('id', $listIds)->get();
        if ($payments->count() <= 0) response()->json(['error' => 'Payment is not valid.'], 403);
        try {
            Payment::notDeleted()->whereIn('id', $listIds)->update(['is_activated' => false]);
        } catch (\Exception $ex) {
            response()->json(['error' => $ex->getMessage()], 403);
        }

        return response()->json(null, 204);
    }
}
