子计划增加count_real count_ok字段

This commit is contained in:
caoqianming 2021-12-09 16:39:13 +08:00
parent 590059b23f
commit 65e6ee21fc
4 changed files with 104 additions and 0 deletions

View File

@ -0,0 +1,23 @@
# Generated by Django 3.2.9 on 2021-12-09 08:38
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('pm', '0015_auto_20211122_1556'),
]
operations = [
migrations.AddField(
model_name='productionplan',
name='count_ok',
field=models.IntegerField(default=0, verbose_name='合格数'),
),
migrations.AddField(
model_name='productionplan',
name='count_real',
field=models.IntegerField(default=0, verbose_name='实际产出数'),
),
]

View File

@ -0,0 +1,19 @@
# Generated by Django 3.2.9 on 2021-12-09 08:38
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('qm', '0014_alter_testrecord_type'),
]
operations = [
migrations.AlterField(
model_name='testrecord',
name='test_record',
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='qm.testrecord', verbose_name='关联的检验记录'),
),
]

View File

@ -0,0 +1,55 @@
# Generated by Django 3.2.9 on 2021-12-09 08:38
from django.conf import settings
from django.db import migrations, models
import django.db.models.deletion
import django.utils.timezone
class Migration(migrations.Migration):
dependencies = [
('wf', '0017_auto_20211203_1501'),
('pm', '0016_auto_20211209_1638'),
('mtm', '0041_alter_material_type'),
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
('wpm', '0030_alter_wproduct_act_state'),
]
operations = [
migrations.AlterField(
model_name='operationmaterial',
name='count',
field=models.PositiveSmallIntegerField(blank=True, null=True, verbose_name='消耗或产出数量'),
),
migrations.AlterField(
model_name='operationwproduct',
name='subproduction_plan',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='ow_subplan', to='pm.subproductionplan', verbose_name='当前子生产计划'),
),
migrations.AlterField(
model_name='wproduct',
name='act_state',
field=models.IntegerField(choices=[(6, '待复检'), (8, '操作准备中'), (10, '操作进行中'), (20, '待检验'), (26, '待夹层检验'), (30, '已合格'), (40, '已入库'), (50, '不合格'), (60, '待成品检验')], default=0, verbose_name='进行状态'),
),
migrations.CreateModel(
name='WprouctTicket',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('create_time', models.DateTimeField(default=django.utils.timezone.now, help_text='创建时间', verbose_name='创建时间')),
('update_time', models.DateTimeField(auto_now=True, help_text='修改时间', verbose_name='修改时间')),
('is_deleted', models.BooleanField(default=False, help_text='删除标记', verbose_name='删除标记')),
('number', models.CharField(blank=True, max_length=50, null=True, verbose_name='物品编号')),
('create_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='wprouctticket_create_by', to=settings.AUTH_USER_MODEL, verbose_name='创建人')),
('material', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='mtm.material', verbose_name='所在物料状态')),
('step', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='mtm.step', verbose_name='所在步骤')),
('subproduction_plan', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='pm.subproductionplan', verbose_name='所在子生产计划')),
('ticket', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='wf.ticket', verbose_name='关联工单')),
('update_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='wprouctticket_update_by', to=settings.AUTH_USER_MODEL, verbose_name='最后编辑人')),
('wproduct', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='wpm.wproduct', verbose_name='关联产品')),
],
options={
'abstract': False,
},
),
]

View File

@ -202,6 +202,13 @@ class WProductViewSet(ListModelMixin, GenericViewSet):
trs = TestRecord.objects.filter(wproduct=wproduct, type=TestRecord.TEST_PROCESS).order_by('-id').first() trs = TestRecord.objects.filter(wproduct=wproduct, type=TestRecord.TEST_PROCESS).order_by('-id').first()
if trs: if trs:
origin_data = TestRecordDetailSerializer() origin_data = TestRecordDetailSerializer()
data = RecordFormDetailSerializer(instance=form).data
data['origin_data'] = origin_data
o_dict = {}
for i in origin_data['record_data_']:
o_dict['field_key'] = o_dict['field_value']
for i in data['form_fields']:
i['origin_value'] = o_dict[i['field_key']]
else: else:
raise exceptions.APIException('原工序检验记录不存在') raise exceptions.APIException('原工序检验记录不存在')
else: else: