Почему сообщения проверки не появляются, когда обязательные поля не заполнены? - PullRequest
0 голосов
/ 06 мая 2018

У меня есть форма регистрации ниже и storeUserInfo () для обработки формы регистрации. Но есть одна проблема, если пользователь не заполняет поля participant_name и participant_surname, обязательные для заполнения, не появляется ошибка проверки, появляется:

{success: true, message: "success"}
message: "success"
success:true

Таким образом, не отображаются какие-либо ошибки проверки, появляется сообщение об успешном завершении и любая информация вставляется в дБ.

Знаете ли вы, где проблема?

// Форма регистрации

 <form method="post" id="step1formfree" action="">
            {{csrf_field()}}
            @if (!is_null($allParticipants) && is_int($allParticipants))
                @if($allParticipants == 1)
                    <p>Please fill all fields. Your tickets will be send to <b>{{ (\Auth::check()) ? Auth::user()->email : old('email')}}</b>.</p>
                @else
                    <p>Is not necessary additional info. Your tickets will be send to <b>{{ (\Auth::check()) ? Auth::user()->email : old('email')}}</b>.</p>
                @endif

                <span id="userData" data-name="{{ auth()->user()->name }}" data-surname="{{ auth()->user()->surname }}"></span>

                @foreach($selectedRtypes as $k => $selectedRtype)
                    //{{dd($selectedRtype)}}
                    @foreach(range(1,$selectedRtype['quantity']) as $val)
                        @if($allParticipants == 1)
                            <h6>Participant - {{$val}} - {{$k}}</h6>
                            <div class="form-check">
                                <input class="form-check-input" type="checkbox" id="fill_auth_info{{ $val }}" data-id="{{ $k }}_{{ $val }}"name="fill_with_auth_info">
                                <label class="form-check-label d-flex align-items-center" for="fill_auth_info{{ $val }}">
                                    <span class="mr-auto">Fill with auth user info.</span>
                                </label>
                            </div>
                            <div class="form-group font-size-sm">
                                <label for="name{{ $k }}_{{ $val }}" class="text-gray">Name</label>
                                <input type="text"  id="name{{ $k }}_{{ $val }}" name="participant_name[]" required class="form-control" value="">
                            </div>
                            <div class="form-group font-size-sm">
                                <label for="surname{{ $k }}_{{ $val }}" class="text-gray">Surname</label>
                                <input type="text" id="surname{{ $k }}_{{ $val }}" required class="form-control" name="participant_surname[]" value="">
                            </div>
                            @foreach($selectedRtype['questions'] as $customQuestion)
                                <div class="form-group">
                                    <label for="participant_question">{{$customQuestion->question}}</label>
                                    <input type="text"
                                           @if($customQuestion->pivot->required == "1") required @endif
                                           class="form-control" name="participant_question[]">
                                    <input type="hidden" name="participant_question_required[]"
                                           value="{{ $customQuestion->pivot->required }}">
                                    <input type="hidden" value="{{ $customQuestion->id }}" name="participant_question_id[]"/>
                                </div>
                            @endforeach
                        @else
                            <input type="hidden" value="foo" name="participant_name[]"/>
                            <input type="hidden" value="bar" name="participant_surname[]"/>
                        @endif
                        <input type="hidden" name="rtypes[]" value="{{ $selectedRtype['id'] }}"/>
                    @endforeach
                            <div class="form-group">
                    @if ($allParticipants == 0)
                        @foreach($selectedRtype['questions'] as $customQuestion)
                                <label for="participant_question">{{$customQuestion->question}}</label>
                                <input type="text"
                                       @if($customQuestion->pivot->required == "1") required @endif
                                       class="form-control" name="participant_question[]">
                                <input type="hidden" name="participant_question_required[]"
                                       value="{{ $customQuestion->pivot->required }}">
                                <input type="hidden" value="{{ $customQuestion->id }}" name="participant_question_id[]"/>
                            </div>
                        @endforeach
                    @endif
                @endforeach
            @endif
            <input type="submit" href="#step2"
                   id="goToStep2Free" class="btn btn-primary btn float-right next-step" value="Go to step 2"/>
        </form>

// метод storeUserInfo, код переходит к этому методу при нажатии «Перейти к шагу 2»:

 public function storeUserInfo(Request $request, $id, $slug = null, Validator $validator){
        $allParticipants = Congress::where('id', $id)->first()->all_participants;
        $user = Auth::user();

        $rules = [];
        $messages = [];

        if(isset($request->participant_question_required)) {
            $messages = [
                'participant_question.*.required' => 'The participant is required'
            ];

            foreach ($request->participant_question_required as $key => $value) {
                $rule = 'string|max:255'; // I think string should come before max
                //dd($value);
                // if this was required, ie 1, prepend "required|" to the rule
                if ($value) {
                    $rule = 'required|' . $rule;
                }

                // add the individual rule for this array key to the $rules array
                $rules["participant_question.{$key}"] = $rule;
            }
        }

        if($allParticipants){
            $rules = [
                'participant_name.*' => 'required|max:255|string',
                'participant_surname.*' => 'required|max:255|string',
            ];
        }

        $validator = Validator::make($request->all(), $rules, $messages);

        if($validator->passes()) {
            $registration = Registration::create([
                'congress_id' => $id,
                'main_participant_id' => $user->id,
                'status' => 'C',
            ]);

            $participants = [];
            for ($i = 0; $i < count($request->participant_name); $i++) {
                $name = ($allParticipants) ? $request->participant_name[$i] : '';
                $surname = ($allParticipants) ? $request->participant_surname[$i] : '';
                $participants[] = Participant::create([
                    'name' => $name,
                    'surname' => $surname,
                    'registration_id' => $registration->id,
                    'registration_type_id' => $request->rtypes[$i]

                ]);
            }

            if (isset($request->participant_question))
                for ($i = 0; $i < count($request->participant_question); $i++)
                    $answer = Answer::create([
                        'question_id' => $request->participant_question_id[$i],
                        'participant_id' => $participants[$i]->id,
                        'answer' => $request->participant_question[$i],
                    ]);
        }

        return response()->json([
            'success' => true,
            'message' => 'success'
        ], 200);
    }

1 Ответ

0 голосов
/ 06 мая 2018

Похоже, что вы не перехватываете экземпляр ошибки валидатора, который игнорирует переменную $validator и возвращает успех. Вы должны поймать это так

if($validator->fails()) {
   return \Response::json([
        'data' => [
        'message'   => $validator->errors(),
        'success'   => false
        ]
    ], 404);;
}

В качестве примера вы можете добавить свой собственный ответ JSON. И вы можете получить все ошибки валидатора от $validator-errors(), не забудьте вернуть его, если $validator->fails() является правдивым

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...