Djangoで、工事台帳を作成しています。
支払状況を扱うPaymentというモデルを作りました。
python
1#models.py 2class Payment(models.Model): 3 date = models.DateField(u'支払日') 4 payee = models.ForeignKey(SpecialtyContractor) 5 site_id = models.ForeignKey(Site) 6 CLASSIFY_CHOICES = ((1, u'材料費'), (2, u'外注費'), (3, u'経費'),) 7 classifies = models.IntegerField(u'分類', choices = CLASSIFY_CHOICES) 8 contents = models.CharField(u'内容', max_length = 50) 9 work_type = models.ForeignKey(WorkType, blank = True, null = True) 10 ammount = models.IntegerField(u'金額') 11 # def __unicode__(self): 12 # return self.name
admin.pyでは、下記のようにしています。
python
1#admin.py 2class PaymentAdmin(admin.ModelAdmin): 3admin.site.register(Payment, PaymentAdmin)
これによって、Djangoが作ってくれた画面は、下記のものです。
しかし、これでは、毎回「Save and another」を押して入力しなければならず非常に不都合です。
私の希望としては、下記のようなフォーマットで入力して、ある程度連続して入力した後で「Save」したいです。
このようにAdmin画面を作る方法はないでしょうか?
一つ考えた方法は、モデルを2つに分ける方法です。
①Paymentモデル
・支払日だけを登録するモデル
②PaymentDetailモデル
・支払日以外の項目(payee、site_id、分類、内容、Work_type、金額)を登録するモデル
admin.pyにおいて、下記の2つのclassを作ります。
python
1class PaymentInline(admin.TabularInline): 2 model = Payment 3 extra = 50 4class PaymentAdmin(admin.ModelAdmin): 5 inlines = [PaymentInline] 6admin.site.register(Payment, PaymentAdmin)
これによって、ある支払日に対して、複数行の登録ができることにはなります。
ただ、異なる支払日の場合に同時に入力できないし、そもそもAdmin画面を作るために、tableを2つに分けるという事自体、良くないのではないかと思います。
何か、良い解決策をお気づきの方、ご教示頂ければ幸いです。
どうぞよろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2015/08/28 13:24