我得到了它最后的工作。
这里是我的回答:
的views.py
class InboxCompany(generic.UpdateView):
model = CandidateToJob
template_name = 'dashboard/inbox-company.html'
form_class = ComposeMessage
def get_success_url(self):
return reverse('inboxcompany', kwargs={'pk': self.object.pk})
def get_context_data(self, **kwargs):
context = super(InboxCompany, self).get_context_data(**kwargs)
context['message_list'] = Message.objects.inbox_for(self.request.user)
context['sent_list'] = Message.objects.outbox_for(self.request.user)
return context
def get_initial(self, *args, **kwargs):
recipient = self.get_object(queryset=CandidateToJob.objects.select_related('candidate.user.id'))
self.initial = {'recipient': recipient}
return self.initial
def get_form_kwargs(self, *args, **kwargs):
kwargs = {'initial': self.get_initial()}
return kwargs
def post(self, request, *args, **kwargs):
form = self.form_class(request.POST)
if form.is_valid():
#get data from the form
data = form.cleaned_data
body = data['body']
#auto fill fields
sender = request.user
sent_at = timezone.now()
recipient = self.get_object(queryset=CandidateToJob.objects.select_related('candidate.user.id'))
user = User.objects.all().get(id=recipient.candidate.user.id)
a = Message.objects.create(sender=sender, recipient=user, sent_at=sent_at, body=body)
a.save()
return HttpResponse('Success')
的forms.py
class ComposeMessage(forms.Form):
recipient = forms.CharField(
required=True,
widget=forms.HiddenInput(attrs={'class': 'form-control'})
)
body = forms.CharField(
required=True,
label="Mensagem",
widget=forms.TextInput(attrs={'class': 'form-control'})
)
def __init__(self, *args, **kwargs):
recipient_filter = kwargs.pop('recipient_filter', None)
super(ComposeMessage, self).__init__(*args, **kwargs)
if recipient_filter is not None:
self.fields['recipient']._recipient_filter = recipient_filter
def save(self, sender, parent_msg=None):
recipients = self.cleaned_data['recipient']
body = self.cleaned_data['body']
message_list = []
for r in recipients:
msg = Message(
sender = sender,
recipient = r,
subject = subject,
body = body,
)
if parent_msg is not None:
msg.parent_msg = parent_msg
parent_msg.replied_at = datetime.datetime.now()
parent_msg.save()
msg.save()
message_list.append(msg)
if notification:
if parent_msg is not None:
notification.send([sender], "messages_replied", {'message': msg,})
notification.send([r], "messages_reply_received", {'message': msg,})
else:
notification.send([sender], "messages_sent", {'message': msg,})
notification.send([r], "messages_received", {'message': msg,})
return message_list
的models.py
class Message(models.Model):
"""
A private message from user to user
"""
body = models.TextField(_("Mensagem"))
sender = models.ForeignKey(AUTH_USER_MODEL, related_name='sent_messages')
recipient = models.ForeignKey(AUTH_USER_MODEL, related_name='received_messages', null=False, blank=True)
parent_msg = models.ForeignKey('self', related_name='next_messages', null=True, blank=True)
sent_at = models.DateTimeField(null=True, blank=True)
的信息是明确问题。你正在试图将'User'分配给Charfield,这是没有意义的。记住你的'receient'字段是一个外键(我假设),所以它在你的'Message'表中由一个整数值表示。所以表示外键关系的表单字段也应该返回一个整数。你是否希望用户能够在表单字段中输入用户名并让它查找该用户并将它们保存为“收件人”? – 2014-11-08 13:17:40
感谢Timmy的快速反应。我不希望用户在收件人字段中输入用户名。即使我更改id的用户名,它也会返回相同的错误。 – 2014-11-08 13:21:03
你想用表格做什么?您是否试图向用户预先填写“收件人”字段,然后验证该用户并在表单发布后将其保存到'收件人'字段? – 2014-11-08 13:27:08