У меня есть форма регистрации ниже для регистрации пользователя на конгрессе.Есть 4 разных сценария для регистрации.Таким образом, регистрационная форма должна обрабатывать 4 различных сценария.Но это не работает, только сценарий 1 работает нормально.
Знаете ли вы, как достичь этого сценария?
Сценарий 1: (единственный сценарий, который работает нормально)
- есть два типа заявок на конгресс: «тип заявки 1» и «заявка типа 2»
- тип заявки «tt1» имеет пользовательский вопросник «Что этоphone? ", билет типа" tt2 "не имеет какого-либо пользовательского вопроса, связанного
- все участники -" 1 ", что означает, что необходимо собрать информацию (имя и фамилию) каждого участника
- Схема для этого сценария:
Сценарий 2:
- Есть два типа билетов на конгресс "tt1 "и" tt2 "
- с типами заявок" tt1 "и" tt2 "не связан пользовательский вопрос
- всем участникам соответствует" 1 ", что означает, что необходимо собирать информацию о каждомучастник
- Диаграмма для этого сценария:
Сценарий 3:
- Существует два типа билетов на конгресс: "tt1" и "tt2"
- тип заявкиУ «tt1» есть пользовательский вопросник «Whats your phone?», с типом заявки «tt2» не связан пользовательский вопрос
- у всех участников «0», что означает, что нет необходимости собирать информацию (имяи фамилия) каждого участника
- Диаграмма для этого сценария:
Сценарий 4:
- есть два типа заявок на конгресс "tt1" и "tt2"
- с типами заявок "tt1" и "tt2" не связано ни одного пользовательского вопроса
- все участники is "0 ", что означает, что нет необходимости собирать информацию (имя и фамилию) каждого участника
- Диаграмма для этого сценария:
Выбранныйбилеты с предыдущей страницы доступны в переменной «$selectedTypes
»
// регистрационная форма при регистрации.blade.php page
<form method="post" id="step1form" action="">
{{csrf_field()}}
@if (!empty($allParticipants))
@if($allParticipants == 1)
<p>Please fill in all fields. Your tickets will be sent to
p{{ (\Auth::check()) ? Auth::user()->email : old('email')}}.</p>
@foreach($selectedTypes as $k => $selectedType)
@foreach(range(1,$selectedType['quantity']) as $val)
<h6>Participant - {{$val}} - {{$k}}</h6>
<div class="form-check">
<input class="form-check-input" type="radio" name="payment_method" value="referencias">
<label class="form-check-label d-flex align-items-center" for="exampleRadios1">
<span class="mr-auto">Fill the following fields with the authenticated user information.</span>
</label>
</div>
<div class="form-group font-size-sm">
<label for="participant_name" class="text-gray">Name</label>
<input type="text" name="participant_name[]" required class="form-control" value="">
</div>
<div class="form-group font-size-sm">
<label for="participant_surname" class="text-gray">Surname</label>
<input type="text" required class="form-control" name="participant_surname[]" value="">
</div>
<input type="hidden" name="ttypes[]" value="{{ $selectedType['id'] }}"/>
@foreach($selectedType['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
@endforeach
@endforeach
@else
<p>Its not necessary aditional info. Your tickets will be sent to {{ (\Auth::check()) ? Auth::user()->email : old('email')}}.</p>
@endif
@endif
<input type="submit" href="#step2"
id="goToStep2Free" class="btn btn-primary btn float-right next-step" value="Go to step 2"/>
</form>
// registration.blade.php завершенный метод регистрации пользователя в конгрессе
public function StoreUserInfo(Request $request, $id, $slug = null, Validator $validator){
$allParticipants = Congress::where('id', $id)->first()->all_participants;
$user = Auth::user();
if($allParticipants){
$rules = [
'participant_name.*' => 'required|max:255|string',
'participant_surname.*' => 'required|max:255|string',
];
$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;
}
$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++)
$participants[] = Participant::create([
'name' => $request->participant_name[$i],
'surname' => $request->participant_surname[$i],
'registration_id' => $registration->id,
'ticket_type_id' => $request->rtypes[$i]
]);
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);
}
else {
$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;
}
$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++)
$participants[] = Participant::create([
'name' => '',
'surname' => '',
'registration_id' => $registration->id,
'ticket_type_id' => $request->rtypes[$i]
]);
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);
}
}
Соответствующие модели на вопрос:
class Congress extends Model
{
// A conference has many ticket types
public function ticketTypes(){
return $this->hasMany('App\TicketType', 'congress_id');
}
public function registrations(){
return $this->hasMany('App\Registration', 'congress_id');
}
}
// RegistrationModel
class Registration extends Model
{
// a registration has one user that do the registration (main_participant_id)
public function customer(){
return $this->belongsTo('App\User');
}
public function congress(){
return $this->belongsTo('App\Congress');
}
}
class TicketType extends Model
{
public function congress(){
return $this->belongsTo('App\Congress');
}
}
class Question extends Model
{
public function registration_type(){
return $this->belongsToMany('App\RegistrationType', 'ticket_type_questions')
->withPivot('required');
}
}
class Answer extends Model
{
public function question(){
return $this->belongsTo('Question');
}
public function participant(){
return $this->belongsTo('Participant');
}
}
Диаграмма, которая показывает некоторые проблемы с кодом, который у меня есть на данный момент, который является кодом в вопросе: