ScheduleRequest.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <?php
  2. namespace App\Http\Requests;
  3. use Illuminate\Foundation\Http\FormRequest;
  4. class ScheduleRequest extends FormRequest
  5. {
  6. public function authorize(): bool
  7. {
  8. return true;
  9. }
  10. public function rules(): array
  11. {
  12. $rules = [
  13. 'client_id' => 'sometimes|required|exists:clients,id',
  14. 'provider_id' => 'sometimes|required|exists:providers,id',
  15. 'address_id' => 'sometimes|required|exists:addresses,id',
  16. 'date' => 'nullable|date|after_or_equal:today',
  17. 'dates' => 'nullable|array',
  18. 'dates.*' => 'date|after_or_equal:today',
  19. 'schedules' => 'nullable|array',
  20. 'schedules.*.date' => 'required|date|after_or_equal:today',
  21. 'schedules.*.period_type' => 'required|in:2,4,6,8',
  22. 'schedules.*.start_time' => 'required|date_format:H:i',
  23. 'schedules.*.end_time' => 'required|date_format:H:i|after:schedules.*.start_time',
  24. 'schedules.*.total_amount' => 'required|numeric|min:0',
  25. 'period_type' => 'sometimes|required|in:2,4,6,8',
  26. 'schedule_type' => 'sometimes|in:default,custom',
  27. 'start_time' => 'sometimes|required|date_format:H:i:s',
  28. 'end_time' => 'sometimes|required|date_format:H:i:s|after:start_time',
  29. 'status' => 'sometimes|in:pending,accepted,rejected,paid,cancelled,started,finished',
  30. 'code_verified' => 'sometimes|boolean',
  31. ];
  32. if ($this->isMethod('POST')) {
  33. $rules['client_id'] = 'required|exists:clients,id';
  34. $rules['provider_id'] = 'required|exists:providers,id';
  35. $rules['address_id'] = 'required|exists:addresses,id';
  36. $rules['date'] = 'required_without_all:dates,schedules|nullable|date|after_or_equal:today';
  37. $rules['dates'] = 'nullable|array';
  38. $rules['dates.*'] = 'date|after_or_equal:today';
  39. $rules['schedules'] = 'nullable|array|min:1';
  40. $rules['schedules.*.date'] = 'required|date|after_or_equal:today';
  41. $rules['schedules.*.period_type'] = 'required|in:2,4,6,8';
  42. $rules['schedules.*.start_time'] = 'required|date_format:H:i';
  43. $rules['schedules.*.end_time'] = 'required|date_format:H:i|after:schedules.*.start_time';
  44. $rules['schedules.*.total_amount'] = 'required|numeric|min:0';
  45. $rules['period_type'] = 'required_without:schedules|in:2,4,6,8';
  46. $rules['start_time'] = 'required_without:schedules|date_format:H:i';
  47. $rules['end_time'] = 'required_without:schedules|date_format:H:i|after:start_time';
  48. $rules['status'] = 'in:pending';
  49. }
  50. return $rules;
  51. }
  52. public function messages(): array
  53. {
  54. return [
  55. 'client_id.required' => 'O cliente é obrigatório.',
  56. 'client_id.exists' => 'Cliente não encontrado.',
  57. 'provider_id.required' => 'O prestador é obrigatório.',
  58. 'provider_id.exists' => 'Prestador não encontrado.',
  59. 'address_id.required' => 'O endereço é obrigatório.',
  60. 'address_id.exists' => 'Endereço não encontrado.',
  61. 'date.required_without_all' => 'A data é obrigatória quando não há múltiplas datas ou agendamentos.',
  62. 'date.date' => 'Data inválida.',
  63. 'date.after_or_equal' => 'A data deve ser hoje ou futura.',
  64. 'dates.array' => 'Datas devem ser um array.',
  65. 'dates.*.date' => 'Uma das datas é inválida.',
  66. 'dates.*.after_or_equal' => 'Todas as datas devem ser hoje ou futuras.',
  67. 'schedules.array' => 'Agendamentos devem ser um array.',
  68. 'schedules.min' => 'É necessário pelo menos um agendamento.',
  69. 'schedules.*.date.required' => 'A data do agendamento é obrigatória.',
  70. 'schedules.*.date.date' => 'Data do agendamento inválida.',
  71. 'schedules.*.date.after_or_equal' => 'A data do agendamento deve ser hoje ou futura.',
  72. 'schedules.*.period_type.required' => 'O período do agendamento é obrigatório.',
  73. 'schedules.*.period_type.in' => 'Período do agendamento inválido.',
  74. 'schedules.*.start_time.required' => 'O horário de início do agendamento é obrigatório.',
  75. 'schedules.*.start_time.date_format' => 'Formato de horário de início inválido.',
  76. 'schedules.*.end_time.required' => 'O horário de término do agendamento é obrigatório.',
  77. 'schedules.*.end_time.date_format' => 'Formato de horário de término inválido.',
  78. 'schedules.*.end_time.after' => 'O horário de término deve ser após o horário de início.',
  79. 'schedules.*.total_amount.required' => 'O valor total do agendamento é obrigatório.',
  80. 'schedules.*.total_amount.numeric' => 'O valor total deve ser numérico.',
  81. 'schedules.*.total_amount.min' => 'O valor total deve ser maior ou igual a zero.',
  82. 'period_type.required' => 'O período é obrigatório.',
  83. 'period_type.required_without' => 'O período é obrigatório quando não há agendamentos múltiplos.',
  84. 'period_type.in' => 'Período inválido.',
  85. 'start_time.required' => 'O horário de início é obrigatório.',
  86. 'start_time.required_without' => 'O horário de início é obrigatório quando não há agendamentos múltiplos.',
  87. 'start_time.date_format' => 'Formato de horário inválido.',
  88. 'end_time.required' => 'O horário de término é obrigatório.',
  89. 'end_time.required_without' => 'O horário de término é obrigatório quando não há agendamentos múltiplos.',
  90. 'end_time.date_format' => 'Formato de horário inválido.',
  91. 'end_time.after' => 'O horário de término deve ser após o horário de início.',
  92. 'status.in' => 'Status inválido.',
  93. ];
  94. }
  95. }