<?php

namespace App\Http\Requests\Auth;

use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Support\Str;

class User extends FormRequest
{
    /**
     * Determine if the user is authorized to make this request.
     *
     * @return bool
     */
    public function authorize()
    {
        return true;
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        $picture = 'nullable';

        if ($this->files->get('picture')) {
            $picture = 'mimes:' . config('filesystems.mimes')
                    . '|between:0,' . config('filesystems.max_size') * 1024
                    . '|dimensions:max_width=' . config('filesystems.max_width') . ',max_height=' . config('filesystems.max_height');
        }

        $email = 'required|email:rfc,dns';

        if ($this->getMethod() == 'PATCH') {
            // Updating user
            $id = is_numeric($this->user) ? $this->user : $this->user->getAttribute('id');
            $companies = $this->user->can('read-common-companies') ? 'required' : '';
            $roles = $this->user->can('read-auth-roles') ? 'required|string' : '';

            if ($this->user->contact) {
                $email .= '|unique:contacts,NULL,'
                          . $this->user->contact->id . ',id'
                          . ',company_id,' . company_id()
                          . ',type,customer'
                          . ',deleted_at,NULL';
            }
        } else {
            // Creating user
            $id = null;
            $companies = 'required';
            $roles = 'required|string';
        }

        $email .= '|unique:users,email,' . $id . ',id,deleted_at,NULL';

        $change_password = $this->request->get('change_password') == true || $this->request->get('change_password') != null;

        $current_password = $change_password ? '|current_password' : '';
        $password = $change_password ? '|confirmed' : '';

        return [
            'name'              => 'required|string',
            'email'             => $email,
            'current_password'  => 'required_if:change_password,true' . $current_password,
            'password'          => 'required_if:change_password,true' . $password,
            'companies'         => $companies,
            'roles'             => $roles,
            'picture'           => $picture,
        ];
    }

    public function messages()
    {
        $picture_dimensions = trans('validation.custom.invalid_dimension', [
            'attribute'     => Str::lower(trans_choice('general.pictures', 1)),
            'width'         => config('filesystems.max_width'),
            'height'        => config('filesystems.max_height'),
        ]);

        return [
            'picture.dimensions' => $picture_dimensions,
        ];
    }
}