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, 'landing_page' => 'required|string', ]; } 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, ]; } }