from django.db import models from apps.utils.models import CommonADModel, CommonBDModel from apps.mtm.models import Material, Mgroup # Create your models here. class Utask(CommonBDModel): """ 生产大任务 """ UTASK_CREATED = 10 UTASK_DECOMPOSE = 14 UTASK_ASSGINED = 20 UTASK_WORKING = 30 UTASK_STOP = 34 UTASK_DONE = 40 UTASK_STATES = ( (UTASK_CREATED, '创建中'), (UTASK_DECOMPOSE, '已分解'), (UTASK_ASSGINED, '已下达'), (UTASK_WORKING, '生产中'), (UTASK_STOP, '已停止'), (UTASK_DONE, '已提交') ) state = models.PositiveIntegerField( '状态', choices=UTASK_STATES, default=UTASK_CREATED, help_text=str(UTASK_STATES)) number = models.CharField('编号', max_length=50, unique=True) material = models.ForeignKey( Material, verbose_name='产品', on_delete=models.CASCADE) mgroup = models.ForeignKey( Mgroup, verbose_name='工段', on_delete=models.CASCADE, null=True, blank=True) material_in = models.ForeignKey( Material, verbose_name='领用物', on_delete=models.CASCADE, related_name='utask_material_in', null=True, blank=True) count = models.PositiveIntegerField('任务数', default=1) count_real = models.PositiveIntegerField('实际生产数', default=0) count_day = models.PositiveIntegerField('日均任务数', default=0) count_ok = models.PositiveIntegerField('合格数', default=0) count_notok = models.PositiveIntegerField('不合格数', default=0) start_date = models.DateField('计划开工日期') end_date = models.DateField('计划完工日期') class Mtask(CommonADModel): """ 生产任务 """ MTASK_CREATED = 10 MTASK_ASSGINED = 20 MTASK_STOP = 34 MTASK_DONE = 40 MTASK_STATES = ( (MTASK_CREATED, '创建中'), (MTASK_ASSGINED, '已下达'), (MTASK_STOP, '已停止'), (MTASK_DONE, '已提交') ) state = models.PositiveIntegerField( '状态', choices=MTASK_STATES, default=MTASK_CREATED, help_text=str(MTASK_STATES)) number = models.CharField('编号', max_length=50, unique=True) mgroup = models.ForeignKey( Mgroup, verbose_name='工段', on_delete=models.CASCADE) material_in = models.ForeignKey( Material, verbose_name='领用物', on_delete=models.CASCADE, related_name='mtask_material_in', null=True, blank=True) material_out = models.ForeignKey( Material, verbose_name='产物', on_delete=models.CASCADE, related_name='mtask_material_out') is_count_utask = models.BooleanField('是否主任务统计', default=False) count = models.PositiveIntegerField('任务数', default=1) count_real = models.PositiveIntegerField('实际生产数', default=0) count_ok = models.PositiveIntegerField('合格数', default=0) count_notok = models.PositiveIntegerField('不合格数', default=0) start_date = models.DateField('计划开工日期') end_date = models.DateField('计划完工日期') utask = models.ForeignKey( Utask, verbose_name='关联大任务', on_delete=models.CASCADE, related_name='mtask_utask', null=True, blank=True) peifen_kg = models.FloatField('配粉料数', default=0) submit_time = models.DateTimeField('提交时间', null=True, blank=True) submit_user = models.ForeignKey( 'system.user', verbose_name='提交人', on_delete=models.CASCADE, null=True, blank=True, related_name='mtask_submit_user') @property def related(self): """ 当天已下达的所有的兄弟小任务 """ if self.utask: return Mtask.objects.filter( utask=self.utask, mgroup__belong_dept=self.mgroup.belong_dept, start_date=self.start_date, end_date=self.start_date, state=self.MTASK_ASSGINED).order_by( 'utask', 'mgroup__process__sort', 'create_time' ) return Mtask.objects.none() @property def mlogs(self): from apps.wpm.models import Mlog return Mlog.objects.filter(mtask=self)