<?php

namespace {{namespacePrefix}}\{{model}};

use Illuminate\Foundation\Http\FormRequest;

class {{class}} 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()
    {
        $rules = [
            'name' => 'required',
            'phone'  => [
                'nullable',
                'regex:/^\+[1-9]\d{6,14}$/', // Require + sign (E.164 format)
                'phone:AUTO',
            ],
            'email'    => [
                'required',
                'email:rfc,dns',
                'indisposable',
                'email',
                Rule::unique('users', 'email')->where(function ($query) {
                    return $query->where('user_type', 'staff_members')
                        ->orWhere('user_type', 'super_admins');
                })
            ],
            'status' => 'required',
        ];

        if ($this->allow_login == 1) {
            $rules['password'] = 'required|min:8';
            $rules['role_id'] = 'required';
        }

        return $rules;
    }

    public function messages()
    {
        return [
            'phone.phone'    => 'The :attribute field must be a valid number.',
            'phone.regex' => 'The phone number must include the country code with + sign.',
        ];
    }
}
