Не совсем понимаю, это init какого класса...Но можно попробовать так:
def __init__(self, *args, **kwargs):
-- def __init__(self, *args, **kwargs):
# delete 'user' from kwargs before calling perent init
четверг, 30 апреля 2020 г., 15:46:43 UTC+3 пользователь Sergei Sokov написал:
user = kwargs.pop('user', None)
super().__init__(*args, **kwargs)
#количество строк в поле комментариев
self.fields['comment'].widget = Textarea(attrs={'rows': 3})
for field in self.fields:
self.fields[field].widget.attrs ['class'] = 'form-control'
super().__init__(*args, **kwargs)
#количество строк в поле комментариев
self.fields['comment'].widget = Textarea(attrs={'rows': 3})
for field in self.fields:
self.fields[field].widget.attr
четверг, 30 апреля 2020 г., 15:46:43 UTC+3 пользователь Sergei Sokov написал:
так работает, но если я добавляю вот это для редактирования отображения полей в форме
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
#количество строк в поле комментариев
self.fields['comment'].widget = Textarea(attrs={'rows': 3})
for field in self.fields:
self.fields[field].widget.attrs ['class'] = 'form-control'тогда у меня вот такая ошибкаTypeError at /new-big-print-order
__init__() got an unexpected keyword argument 'user'Я так понимаю потому что во views.py вот это
def get_form_kwargs(self):
kwargs = super(OrderNewBigPrintView, self).get_form_kwargs()
kwargs['user'] = self.request.user
return kwargs
четверг, 30 апреля 2020 г., 12:19:35 UTC+2 пользователь hend hend написал:Уже приводил вариант без self, хотя и с self должно бы работать нормально, но раз ругается попробуйте без self.def __init__(self, *args, **kwargs ):# get 'user' param from kwargs# user without selfuser = kwargs.pop('user', None)
super().__init__(*args, **kwargs )# set 'name_job' queryset# user.id without selfself.fields['name_job'].queryset = TypJob.objects.filter(author__id =user.id)
четверг, 30 апреля 2020 г., 11:34:28 UTC+3 пользователь Sergei Sokov написал:А как тогда?self.fields['name_job'].queryset = TypJob.objects.filter(author__ id=self.user.id) как тогда фильтр будет работать?
среда, 29 апреля 2020 г., 20:36:00 UTC+2 пользователь hend hend написал:Не нужно нигде в классе формы обращаться к 'self.user'.среда, 29 апреля 2020 г., 19:49:45 UTC+3 пользователь Sergei Sokov написал:без self такая ошибка'OrderForm' object has no attribute 'user'
среда, 29 апреля 2020 г., 17:56:10 UTC+2 пользователь hend hend написал:Если 'user' в классе не нужен, можно не вешать его на self. просто вместо 'self.user' используем 'user': в этом случае 'user' просто локальная переменная метода init.def __init__(self, *args, **kwargs ):# get 'user' param from kwargsuser = kwargs.pop('user', None)
super().__init__(*args, **kwargs )# set 'name_job' querysetself.fields['name_job'].queryset = TypJob.objects.filter(author__id =user.id)
среда, 29 апреля 2020 г., 17:19:41 UTC+3 пользователь Sergei Sokov написал:hend hend спасибо большое!Работает!Но!Теперь у меня не получается управлять внешним видом полейЯ хочу переопределить класс в форме, но "user" из представления попадает в этот __init__ тожеdef __init__(self, *args, **kwargs):super().__init__(*args, **kwargs)#количество строк в поле комментариевself.fields['comment'].widget = Textarea(attrs={'rows': 3})for field in self.fields:self.fields[field].widget.attrs['class'] = 'form-control'
среда, 29 апреля 2020 г., 13:54:23 UTC+2 пользователь hend hend написал:
вторник, 28 апреля 2020 г., 19:56:37 UTC+3 пользователь Sergei Sokov написал:
forms.py
class OrderForm(forms.ModelForm):
class Meta:
model = Order
name_job = forms.ModelMultipleChoiceField( queryset=None)
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
qs = TypJob.objects.filter(author__id =request.user.id)views.py
class OrderNewBigPrintView(LoginRequiredMixin , CustomSuccessMessageMixin, CreateView):
model = Order
template_name = 'new_order_bp.html'
form_class = OrderForm
success_url = reverse_lazy('orders')
success_msg = 'Ok'
models.py
class TypJob(models.Model):
author = models.ForeignKey(User, on_delete = models.CASCADE, verbose_name='author', null=True)
name_job = models.CharField('name job', max_length=200)
class Order(models.Model):
author = models.ForeignKey(User, on_delete = models.CASCADE, verbose_name='author', blank=True, null=True)
number_order = models.CharField('number of order', max_length=100)
date_create = models.DateTimeField(auto_now=True )
name = models.ForeignKey(Customer, on_delete = models.CASCADE, verbose_name='customer', null=True)
name_order = models.CharField('name of order', max_length=200)# Так должно работать вроде..# viewclass OrderNewBigPrintView(Lomodel = OrderginRequiredMixin , CustomSuccessMessageMixin , CreateView):
template_name = 'new_order_bp.html'
form_class = OrderForm
success_url = reverse_lazy('orders' )
success_msg = 'Ok'# this method will pass 'user' as param in kwargs to form __init__()def get_form_kwargs(self):kwargs = super(OrderNewBigPrintView, self).get_form_kwargs()kwargs['user'] = self.request.userreturn kwargs# formclass OrderForm(forms.ModelForm ):
class Meta:
model = Order
name_job = forms.ModelMultipleChoiceField (queryset=None)
def __init__(self, *args, **kwargs ):# get 'user' param from kwargsself.user = kwargs.pop('user', None)
super().__init__(*args, **kwargs )# set 'name_job' querysetself.fields['name_job'].queryset = TypJob.objects.filter(author__id =self.user.id)
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/3ddec6d2-4e66-4a14-a0bf-59f136a6e404%40googlegroups.com.
No comments:
Post a Comment