<?php

namespace App\Repositories\Webprofile;

use App\Models\Webprofile\Categories;
use App\Repositories\Repository;
use DataTables;

class CategoryRepository extends Repository
{
    protected $model;

    public function __construct(Categories $model)
    {
        $this->model = $model;
    }

    public function get($with = null, $name = null, $orderBy = null)
    {
        return $this->model
            ->when($with, function ($query) use ($with) {
                return $query->with($with);
            })
            ->when($name, function ($query) use ($name) {
                return $query->where('name', 'ilike', '%' . $name . '%');
            })
            ->when($orderBy, function ($query) use ($orderBy) {
                return $query->orderBy($orderBy[0], $orderBy[1]);
            })
            ->get();
    }

    public function datatable($data)
    {
        return DataTables::of($data)
            ->addIndexColumn()
            ->addColumn('action', function ($row) {
                $btn = '<a href="'.url('/webprofile/category/'.$row->id.'/edit').'" data-toggle="tooltip"  data-id="'.$row->id.'" data-original-title="'.trans('label.editsemuabahasa').'" class="edit btn btn-warning btn-round btn-sm edit">'.trans('label.editsemuabahasa').'</a>';

                $btn = $btn . ' <a href="'.url('/webprofile/category/'.$row->id.'/editperbahasa').'" data-toggle="tooltip"  data-id="'.$row->id.'" data-original-title="'.trans('label.edittiapbahasa').'" class="edit btn btn-warning btn-round btn-sm edit">'.trans('label.edittiapbahasa').'</a>';

                $btn = $btn . ' <a href="javascript:void(0)" data-toggle="tooltip"  data-id="' . $row->id . '" data-original-title="Delete" class="btn btn-danger btn-round btn-sm delete">Delete</a>';

                $btn = $btn . '<br>';

                return $btn;
            })
            ->addColumn('status', function ($row) {
                if ($row->is_active == true) {
                    $str = '<div style="color: green;"><i class="fa fa-check"></i></div>';
                } else {
                    $str = '<div style="color: red;"><i class="fa fa-times"></i></div>';
                }
                return $str;
            })
            ->addColumn('name', function ($row) {                
                $str = $row->name . '<br>';
                if ($row->rEn) {
                    $str .= '<i style="color: blue;">' . $row->rEn->name . '</i>';
                }
                
                return $str;
            })
            ->rawColumns(['action', 'status', 'name'])
            ->make(true);
    }
}