如何为用户保存调查进度

时间:2019-06-07 07:44:57

标签: symfony

嗨,我正在做调查,我可以根据用户记录测验的进度

示例:用户遇到问题15/50时,他必须能够断开连接并继续在其停止的地方。

我设法将答案分配给用户,但不必担心进度。非常感谢

所以我在这里通过post方法得到了答案 我的controlleur来为用户保存答案。

class DefaultController extends Controller

{

     /**
     * @Route("/Reponse/thematique", name="thematique_reponse")
     * @Method({"GET", "POST"})
     */

    public function reponseThematique(Request $request)

    {
            //instance des repository
            $userSlpRepo = $this->getDoctrine()->getRepository(UserSlp::class);
            $reponseThematiqueRepo = $this->getDoctrine()->getRepository(Reponse_thematique::class);
            $questionMangerRepo = $this->getDoctrine()->getRepository(Manger::class);//here all the questions

            $em = $this->getDoctrine()->getManager();
            $userSlp = $userSlpRepo->findOneByGaeaUserId($this->getUser()->getId());
            $datas = $request->request->all();


           foreach ($datas as $data => $value ){
            $question = $questionMangerRepo->find($data);  

            $answer = new Reponse_thematique;
            $answer->setManger($question); 
            $answer->setValue($value); 
            $answer->setUserSlp($userSlp);          
            $em->persist($answer); 
            $em->flush();
           }

     return new response('ok');

    }

例如,我想与实体“ questionnaire-progress”建立关系,否则我们将有一个id,question_id,user_id以及为什么没有一个列,或者如果该问卷已完成,我们将放置一个布尔值。

>
/**
 * SurveyProgress
 *

 * @ORM\Table(name="survey_progress", indexes={@ORM\Index(name="IDX_7EF6B461B3FE509D",
 *  columns={"questionnaire_id"}), @ORM\Index(name="IDX_7EF6B4611E27F6BF",
 *  columns={"manger_id"}), @ORM\Index(name="IDX_7EF6B461FDDFEACC",
 *  columns={"userSlp_id"})})
 * @ORM\Entity
 */
class QuestionnaireProgress
{
    /**
     * @var int
     *
     * @ORM\Column(name="id", type="integer", nullable=false)
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="IDENTITY")
     */
    private $id;

    /**
     * @var bool
     *
     * @ORM\Column(name="done", type="boolean", nullable=false)
     */
    private $done;

    /**
     * @var \Question
     *
     * @ORM\ManyToOne(targetEntity="manger")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="question_id", referencedColumnName="id")
     * })
     */
    private $manger;

    /**
     * @var \Survey
     *
     * @ORM\ManyToOne(targetEntity="questionnaire")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="questionnaire_id", referencedColumnName="id")
     * })
     */
    private $questionnaire;

    /**
     * @var \UserSlp
     *
     * @ORM\ManyToOne(targetEntity="UserSlp")
     * @ORM\JoinColumns({
     *   @ORM\JoinColumn(name="userSlp_id", referencedColumnName="id")
     * })
     */
    private $userslp;
   }

1 个答案:

答案 0 :(得分:0)

您可以在用户每次回答时保存答案。然后,您将存储此信息。

我想一个session = Session() session.connection(execution_options={ "schema_translate_map": {"per_user": "account_one"}}) # will query from the ``account_one.user`` table session.query(User).get(5) 包含一个Survey的列表。然后,您可以获得问题的总数。

如果您在用户回答时保存了答案,则给定Question和给定Reponse_thematique的{​​{1}}数/总问题数将为您提供进度