def forwards(self, orm): for a in orm['q13es.Answer'].objects.filter(q13e_slug='personal-details'): print a.user.email user = a.user data = json.loads(a.data) update_personal_details(user, data) user.forms_filled = user.answers.count() if user.forms_filled: user.last_form_filled = user.answers.aggregate( Max('created_at'))['created_at__max'] user.save()
def form_valid(self, form): u = self.request.user data = form.cleaned_data form_name = get_user_next_form(u) logger.info("User %s filled %s" % (u, form_name)) a = Answer.objects.create(user=u, q13e_slug=form_name, data=data) # Save personal information if form_name == FORM_NAMES[0]: if not u.first_name: u.first_name = data['hebrew_first_name'] if not u.last_name: u.last_name = data['hebrew_last_name'] update_personal_details(u, data) u.save() # keep it on the safe side message = "\n".join(u"{label}: {html}".format(**fld) for fld in get_pretty_answer(form, data)['fields']) mail_managers(u"{}: {hebrew_last_name} {hebrew_first_name}".format( _("New User"), **data), message) elif form_name == 'cohort1': COHORTS = ( ('group_monday_morning', 1), ('group_thursday_morning', 2), ('group_evenings', 3), ) cohorts = {x[1]: Cohort.objects.get(ordinal=x[1]) for x in COHORTS} for k, ordinal in COHORTS: v = data[k] == u"כן" UserCohort.objects.create(user=u, cohort=cohorts[ordinal], status=UserCohortStatus.AVAILABLE if v else UserCohortStatus.UNAVAILABLE) # update denormalized index fields u.forms_filled = u.answers.count() u.last_form_filled = a.created_at u.save() if get_user_next_form(u) is None: messages.success(self.request, _("Registration completed! Thank you very much!")) url = self.request.build_absolute_uri(reverse('user_dashboard', args=(u.id,))) mail_managers(_("User registered: %s") % u.email, url) return redirect('dashboard') messages.success(self.request, _("'%s' was saved.") % form.form_title) return redirect('register')