実施内容 # 変更内容 ファイル 1 OfficialChusankanField に 11 フィールド追加(17列化) models.py 2 中山間インポート: 17 列すべて読み込み対応 views.py 3 共済インポート: 面積カラム名不一致バグ修正 + a→m2 変換(×100) views.py 4 シリアライザに 11 フィールド追加 serializers.py 5 共済 PDF: A4 縦、表形式、@page 設定、ページ番号、中国語除去 kyosai_template.html 6 中山間 PDF: A4 横、表形式、@page 設定、ページ番号、中国語除去 chusankan_template.html 7 PDF 生成ロジック: フラットテーブル、null 安全、prefetch_related reports/views.py 8 既存データ再インポート(共済面積修正 + 中山間 17 列埋め) — 9 Playwright E2E テスト 11 件全 PASS verify-fixes.spec.ts 追加発見・修正したバグ 共済 ODS の 本地面積 (m2) カラム名にスペースが含まれ、インポート時に面積が全件 0 になっていた 面積の単位がアール(a)であることが判明。m2 への変換 (×100) を追加 PDF は http://localhost:3000/reports からダウンロードして確認できます。
79 lines
4.0 KiB
Python
79 lines
4.0 KiB
Python
from django.contrib.gis.db import models as gis_models
|
|
from django.db import models
|
|
|
|
|
|
class OfficialKyosaiField(models.Model):
|
|
k_num = models.CharField(max_length=20, verbose_name="共済番号")
|
|
s_num = models.CharField(max_length=20, blank=True, default='', verbose_name="枝番")
|
|
address = models.CharField(max_length=255, verbose_name="住所")
|
|
kanji_name = models.CharField(max_length=100, verbose_name="漢字名")
|
|
area = models.IntegerField(default=0, verbose_name="面積(m2)")
|
|
|
|
class Meta:
|
|
verbose_name = "共済マスタ"
|
|
verbose_name_plural = "共済マスタ"
|
|
unique_together = [['k_num', 's_num']]
|
|
|
|
def __str__(self):
|
|
return f"{self.k_num} ({self.kanji_name})"
|
|
|
|
|
|
class OfficialChusankanField(models.Model):
|
|
c_id = models.CharField(max_length=20, unique=True, verbose_name="中山間ID")
|
|
chusankan_flag = models.CharField(max_length=10, blank=True, null=True, verbose_name="中山間フラグ")
|
|
oaza = models.CharField(max_length=100, verbose_name="大字")
|
|
aza = models.CharField(max_length=100, verbose_name="字")
|
|
chiban = models.CharField(max_length=50, verbose_name="地番")
|
|
branch_num = models.CharField(max_length=20, blank=True, null=True, verbose_name="枝番")
|
|
land_type = models.CharField(max_length=20, blank=True, null=True, verbose_name="地目")
|
|
area = models.IntegerField(default=0, verbose_name="農地面積(m2)")
|
|
planting_area = models.IntegerField(blank=True, null=True, verbose_name="植栽面積(m2)")
|
|
original_crop = models.CharField(max_length=100, blank=True, null=True, verbose_name="作付け品目")
|
|
manager = models.CharField(max_length=100, blank=True, null=True, verbose_name="協定管理者")
|
|
owner = models.CharField(max_length=100, blank=True, null=True, verbose_name="所有者")
|
|
slope = models.CharField(max_length=20, blank=True, null=True, verbose_name="傾斜度")
|
|
base_amount = models.IntegerField(blank=True, null=True, verbose_name="基本金額")
|
|
steep_slope_addition = models.IntegerField(blank=True, null=True, verbose_name="超急傾斜加算額")
|
|
smart_agri_addition = models.IntegerField(blank=True, null=True, verbose_name="スマート農業加算額")
|
|
payment_amount = models.IntegerField(blank=True, null=True, verbose_name="交付金額")
|
|
|
|
class Meta:
|
|
verbose_name = "中山間マスタ"
|
|
verbose_name_plural = "中山間マスタ"
|
|
|
|
def __str__(self):
|
|
return f"{self.c_id} ({self.oaza}{self.aza})"
|
|
|
|
|
|
class Field(models.Model):
|
|
name = models.CharField(max_length=100, verbose_name="圃場名")
|
|
address = models.CharField(max_length=255, verbose_name="住所")
|
|
area_tan = models.DecimalField(max_digits=6, decimal_places=4, verbose_name="面積(反)")
|
|
area_m2 = models.IntegerField(verbose_name="面積(m2)")
|
|
owner_name = models.CharField(max_length=100, verbose_name="所有者名")
|
|
group_name = models.CharField("グループ名", max_length=50, blank=True, null=True, help_text="エリアや用途によるグループ分け")
|
|
display_order = models.IntegerField("表示順", default=0, help_text="リスト表示時の順序")
|
|
raw_kyosai_k_num = models.CharField("細目_耕地番号", max_length=20, null=True, blank=True)
|
|
raw_kyosai_s_num = models.CharField("細目_分筆番号", max_length=20, null=True, blank=True)
|
|
raw_chusankan_id = models.CharField("中山間_ID", max_length=20, null=True, blank=True)
|
|
kyosai_fields = models.ManyToManyField(
|
|
OfficialKyosaiField,
|
|
blank=True,
|
|
related_name='fields',
|
|
verbose_name="関連共済マスタ"
|
|
)
|
|
chusankan_fields = models.ManyToManyField(
|
|
OfficialChusankanField,
|
|
blank=True,
|
|
related_name='fields',
|
|
verbose_name="関連中山間マスタ"
|
|
)
|
|
location = gis_models.PointField(blank=True, null=True, verbose_name="位置情報")
|
|
|
|
class Meta:
|
|
verbose_name = "圃場"
|
|
verbose_name_plural = "圃場"
|
|
|
|
def __str__(self):
|
|
return self.name
|