рассчитать количество баллов и сохранить результат в базе данных профиля пользователя - PullRequest
0 голосов
/ 27 мая 2019

Итак, у меня есть форма, содержащая вопросы типа свободных полей (текст), множественного выбора (флажок), одиночного выбора (радио).

enter image description here

Я проверяю значения кнопки и сохраняю в базе данных для каждого пользователя, но я хочу изменить это значение следующим образом:

data-point "2" = 10 points,                                                                                                                          
data-point "3" = 7 points,                                                                                                                          
data-point "4" = 4 points,                                                                                                                         
data-point "5" = 2 points,                                                                                                                         

и затем с этими значениями я должен сделать расчет и определить профиль в соответствии с результатом .. как мне это сделать? Запрос SQL? в петле? небольшая помощь будет приветствоваться .. здесь моя веточка, чтобы зациклить на подвопросе.

<div class=" col-6 d-flex">
     <div class="label-div1">

           <label for="subscale{{subQuestion.id}}for{{i}}>
              <img src="{{asset('images/survey/humeur/'~ i ~'.jpg')}}">
            </label>

             <input type="radio" class="radio-pict" name="{{subQuestion.id}}" id="subscale{{i}}" data-point="{{i}}"value="{{i}}">

         </div>

здесь мой контроллер для сохранения ответов

 public function saveAnswer(Request $request)
{
    /* Repository */
    $questionRepo =  $this->getDoctrine()->getRepository(Question::class);
    $answerRepo =  $this->getDoctrine()->getRepository(Answer::class);
    $choiceRepo = $this->getDoctrine()->getRepository(Choice::class);
    $userSlpRepo = $this->getDoctrine()->getRepository(UserSlp::class);

    /* Entity Manager */
    $em = $this->getDoctrine()->getManager();


    $datas = $request->request->all();

    $userSlp = $userSlpRepo->findOneByGaeaUserId($this->getUser()->getId());

    foreach ($datas as $data => $value) {

        $questionId = explode("_", $data);
        $question = $questionRepo->findOneById($questionId[0]);
       switch ($question) {
            case 'Sub_question_free':

                $answer = new Answer_free;
                $answer->setFreeAswere($value);

                break;

            case 'Sub_question_scale':

                $answer = new Answer_scale;

                $answer->setScale($value);

                break; 

        $answer->setQuestion($question);
        $answer->setUserSlp($userSlp);

        $em->persist($answer);
        $em->flush();
       }
      exit;
    }
  }

и вот моя веточка для отображения на админке результатов ..

{% if answer.question == "Sub_question_choice" or
      answer.question == "Sub_question_scale" or
      answer.question == "Sub_question_free" %}
{% if answer == "choice" %} 
{% for choice in answer.choices %}
<p>{{choice.name}}</p>
{% endfor %}
{% elseif answer == "free" %}
<p>{{answer.freeAswere}}</p>
 {% elseif answer == "scale" %}
<p> {{answer.scale}}</p>
{% endif %}

1 Ответ

1 голос
/ 01 июня 2019

Итак, во-первых, в Symfony контроллеру всегда нужно отправлять ответ.Даже если это просто перенаправление или JsonResponse.Так что вы не должны использовать выход в вашем контроллере.

Вы должны использовать форму Symfony, но если вы новичок в Symfony, я могу понять, что это нелегко.

Здесь, чтобы помочь вам, у вас есть много вариантов:

  1. Вы можете изменить значение с некоторыми условиями внутри вашего оператора swith в вашем контроллере
  2. Вы можете отделить это всервис, поищите сервис в Symfony на документах.И используйте внедрение зависимостей внутри вашего контроллера следующим образом:
Service : 
    public function conversion(){
    //Some conditions
    }
controller: 
    public function saveAnswer(Request $request, YourService $service)

И используйте его внутри как функцию.

(более простой вариант) Вы можете перегрузить свой установщик в своей сущности (например, Answer.php):
public function yourSetter(...){
//do some conditions and after set your variables depending on result
}

Надеюсь, это поможет вам, не стесняйтесь спрашивать, хотите ли вы!

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