У меня 2 модели
class WorkOrder(models.Model):
work_order_id = models.AutoField(db_column='Work_order_id',
primary_key=True)
work_order_number = models.CharField(db_column='Work_order_number',
max_length=50, blank=True, null=True)
work_order_date = models.DateField(db_column='Work_order_date',
blank=True, null=True)
customer = models.ForeignKey(Customer, db_column='Customer_id',
blank=True, null=True,on_delete=models.CASCADE)
description = models.CharField(db_column='Description', max_length=50,
blank=True, null=True)
completed_date = models.DateField(db_column='Completed_date',
blank=True, null=True)
completed = Bit1BooleanField(db_column='Completed',
editable=False,default=0)
class Meta:
managed = False
db_table = 'work_order'
class WorkOrderItem(models.Model):
work_order_item_id = models.AutoField(db_column='Work_order_item_id',
primary_key=True) # Field name made lowercase.
work_order = models.ForeignKey(WorkOrder, models.DO_NOTHING,
db_column='Work_order_id') # Field name made lowercase.
part = models.ForeignKey(Part,db_column='Part_id', blank=True,
null=True,on_delete=models.CASCADE) # Field name made lowercase.
quantity = models.IntegerField(db_column='Quantity', blank=True,
null=True) # Field name made lowercase.
class Meta:
managed = False
db_table = 'work_order_item'
Я использую набор форм в forms.py
WorkOrderFormSet = inlineformset_factory(WorkOrder, WorkOrderItem,
# fields='__all__'
# widgets = {'work_order_date' :
DateInput(attrs = {'type': 'datetime'}),},
form=WorkOrderForm,
extra=3, can_delete=False)
Я хочу добавить виджет для work_order_date в таблицу Workorder. Когда я добавляю его в WorkOrderFormset, он показывает ошибку, что WorkOrderItem не имеет этого конкретного поля. Итак, я попытался добавить form = WorkOrderForm и добавить туда виджет как: -
class WorkOrderForm(forms.ModelForm):
class Meta:
model = WorkOrder
fields = '__all__'
widgets = {'work_order_date': DateInput(attrs = {'type': 'datetime'}),}
Но нет никаких изменений, когда он отображается на веб-странице.
Вид: -
class CreateWorkOrderItem(CreateView):
model=WorkOrder
fields=['work_order_number','work_order_date','customer','description']
success_url=reverse_lazy('WorkOrder:WorkOrderPending_list')
def get_context_data(self, **kwargs):
print("from get_context_data")
data = super(CreateWorkOrderItem, self).get_context_data(**kwargs)
if self.request.POST:
data['workorder'] = WorkOrderFormSet(self.request.POST)
else:
data['workorder'] = WorkOrderFormSet()
return data
def form_valid(self, form):
context = self.get_context_data()
workorders = context['workorder']
with transaction.atomic():
self.object = form.save()
В шаблоне у меня есть: -
{% bootstrap_form form %}
{{ workorders.management_form }}
{% for form in workorder.forms %}
{% bootstrap_form form %}
{% endfor %}
Ps: -обе модели отображаются на веб-странице. Проблема только с изменением виджета. В документации к django просто упоминается, что виджет можно изменить так же, как и modelformset_factory. но в нем все модели одинаковые, так что этой ошибки нет. Использование python 3.6.4 Django 2.0.2
Если вам нужна дополнительная информация, спрашивайте. Спасибо!
Вам необходимо установить form_Class
в вашем представлении, а не в полях. widgets
, указанный для WorkOrderForm
, достаточно.
class CreateWorkOrderItem(CreateView):
model=WorkOrder
#fields=['work_order_number','work_order_date','customer','description']
form_class=WorkOrderForm
Редактировать:
Поскольку inlineformset_factory () создает несколько форм для подмодели, не передавайте в нее modelFOrm родительской формы. Достаточно следующего.
WorkOrderFormSet = inlineformset_factory(WorkOrder, WorkOrderItem,
extra=3, can_delete=False)
Если вам нужна специальная форма для подмодели, вы можете создать и указать ее выше.
Добавление
widgets
кWorkOrderForm
должно было сработать. Проверьте источник html вашей страницы или проверьте с помощью firebug, чтобы увидеть тип ввода.