我正在尝试创建一个带有django-suit扩展名的标签,以查看报价并列出所有报价项目。我不太确定如何在django-suit扩展中执行此操作,因为我知道我会使用{% for items in x %}
类型的模板代码。
如果有任何人有使用此扩展程序和完成此任务的经验,或者我可以通过其他方式执行此操作,请使用original.pk
传递主键,这将非常棒。
models.py
from django.db import models
class Quote(models.Model):
description = models.CharField(max_length=200)
date = models.DateField('Date Issued')
client = models.ForeignKey('organizations.Contact')
gst = models.BooleanField(default=True, verbose_name='GST Applicable')
assigned = models.BooleanField(default=True, verbose_name='Quote Assigned')
notes = models.TextField(blank=True)
def __str__(self):
return self.date.__str__().replace("-", "") + "-" + self.id.__str__().zfill(3)
class QuoteItem(models.Model):
order = models.PositiveIntegerField() # For Suit order sorting
invoice = models.ForeignKey(Quote)
description = models.CharField(max_length=200)
quantity = models.IntegerField(default=0)
price = models.DecimalField(max_digits=9, decimal_places=2)
def __str__(self):
return self.description
view_quote.html
<h2 class="legend">View Invoice
</h2><br>
{% if original.pk %}
<span>Invoice Information</span>
<table class="table-overview">
<tr>
<th>Invoice ID</th>
<td>
{{ original }}
</td>
</tr>
<tr>
<th>Description</th>
<td>
{{ original.description }}
</td>
</tr>
<tr>
<th>Client</th>
<td>
{{ original.client }}
</td>
</tr>
<tr>
<th>Notes</th>
<td>
{{ original.notes }}
</td>
</tr>
</table>
<span>Invoice Items</span>
<table class="table-overview">
<tr>
<th>Description</th>
<th>Price</th>
<th>Quantity</th>
<th>Total</th>
</tr>
{% for items in original.quoteitems %}
<tr>
<td>
{{ items.description }}
</td>
<td>
{{ items.price }}
</td> <td>
{{ items.quantity }}
</td> <td>
{{ items.total }}
</td>
</tr>
{% endfor %}
</table>
{% else %}
Item is not saved yet
{% endif %}
答案 0 :(得分:0)
必须使用related_name更改models.py
class QuoteItem(models.Model):
order = models.PositiveIntegerField() # For Suit order sorting
quote = models.ForeignKey(Quote, related_name='quote_set') <<
description = models.CharField(max_length=200)
quantity = models.IntegerField(default=0)
price = models.DecimalField(max_digits=9, decimal_places=2)
和view_quote.html
{% for item in original.quote_set.all %}
<tr>
<td>
{{ item.description }}
</td>
<td>
{{ item.price }}
</td> <td>
{{ item.quantity }}
</td> <td>
{{ item.total }}
</td>
</tr>
{% endfor %}