Merge branch 'master' of http://gitea.xxhhcty.xyz:8080/zcdsj/factory
This commit is contained in:
		
						commit
						97026d86c6
					
				| 
						 | 
					@ -0,0 +1,49 @@
 | 
				
			||||||
 | 
					# Generated by Django 3.2.12 on 2025-10-21 06:08
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					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', '0004_workflow_view_path2'),
 | 
				
			||||||
 | 
					        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
 | 
				
			||||||
 | 
					        ('system', '0006_auto_20241213_1249'),
 | 
				
			||||||
 | 
					        ('ofm', '0022_alter_mroomslot_unique_together'),
 | 
				
			||||||
 | 
					    ]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    operations = [
 | 
				
			||||||
 | 
					        migrations.CreateModel(
 | 
				
			||||||
 | 
					            name='PatentInfo',
 | 
				
			||||||
 | 
					            fields=[
 | 
				
			||||||
 | 
					                ('id', models.CharField(editable=False, help_text='主键ID', max_length=20, 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='删除标记')),
 | 
				
			||||||
 | 
					                ('name', models.CharField(max_length=100, verbose_name='拟申请专利名称')),
 | 
				
			||||||
 | 
					                ('author', models.CharField(max_length=100, verbose_name='发明人(设计人)')),
 | 
				
			||||||
 | 
					                ('type', models.CharField(choices=[('invention', '发明专利'), ('utility', '实用新型专利'), ('design', '外观设计专利')], default='invention', max_length=50, verbose_name='专利类型')),
 | 
				
			||||||
 | 
					                ('is_public', models.BooleanField(default=False, verbose_name='是否公开')),
 | 
				
			||||||
 | 
					                ('area', models.CharField(choices=[('Domestic', '国内申请'), ('Foreign', '国外申请'), (' PCT', 'PCT申请')], default='Domestic', max_length=50, verbose_name='拟申请地域')),
 | 
				
			||||||
 | 
					                ('identified', models.BooleanField(default=False, verbose_name='是否进行过科技成果鉴定')),
 | 
				
			||||||
 | 
					                ('published_article', models.BooleanField(default=False, verbose_name='是否发表过文章')),
 | 
				
			||||||
 | 
					                ('exhibited', models.BooleanField(default=False, verbose_name='是否参与过展会展出')),
 | 
				
			||||||
 | 
					                ('applied_to_production', models.BooleanField(default=False, verbose_name='是否参与应用于生产/销售')),
 | 
				
			||||||
 | 
					                ('participated_in_exchange', models.BooleanField(default=False, verbose_name='是否参与过技术交流')),
 | 
				
			||||||
 | 
					                ('tech_background_pages', models.PositiveIntegerField(blank=True, null=True, verbose_name='技术背景材料页数')),
 | 
				
			||||||
 | 
					                ('tech_disclosure_pages', models.PositiveIntegerField(blank=True, null=True, verbose_name='技术交底材料页数')),
 | 
				
			||||||
 | 
					                ('novelty_report_pages', models.PositiveIntegerField(blank=True, null=True, verbose_name='查新检索报告页数')),
 | 
				
			||||||
 | 
					                ('diagrams_or_photos_pages', models.PositiveIntegerField(blank=True, null=True, verbose_name='图/照片页数或张数')),
 | 
				
			||||||
 | 
					                ('belong_dept', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='patentinfo_belong_dept', to='system.dept', verbose_name='所属部门')),
 | 
				
			||||||
 | 
					                ('create_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='patentinfo_create_by', to=settings.AUTH_USER_MODEL, verbose_name='创建人')),
 | 
				
			||||||
 | 
					                ('ticket', models.ForeignKey(blank=True, db_constraint=False, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='patentInfo_ticket', to='wf.ticket', verbose_name='关联工单')),
 | 
				
			||||||
 | 
					                ('update_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='patentinfo_update_by', to=settings.AUTH_USER_MODEL, verbose_name='最后编辑人')),
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
 | 
					            options={
 | 
				
			||||||
 | 
					                'abstract': False,
 | 
				
			||||||
 | 
					            },
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					    ]
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1,95 @@
 | 
				
			||||||
 | 
					# Generated by Django 3.2.12 on 2025-10-22 02:05
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import apps.ofm.models
 | 
				
			||||||
 | 
					from django.db import migrations, models
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class Migration(migrations.Migration):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    dependencies = [
 | 
				
			||||||
 | 
					        ('ofm', '0023_patentinfo'),
 | 
				
			||||||
 | 
					    ]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    operations = [
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='applied_to_production',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='diagrams_or_photos_pages',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='exhibited',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='identified',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='novelty_report_pages',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='participated_in_exchange',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='published_article',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='tech_background_pages',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.RemoveField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='tech_disclosure_pages',
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AddField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='other_area',
 | 
				
			||||||
 | 
					            field=models.CharField(blank=True, max_length=50, null=True, verbose_name='其它申请地域'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AddField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='tech_file',
 | 
				
			||||||
 | 
					            field=models.JSONField(default=list, help_text='技术文件信息列表,每个条目包含name(名称)page(页数)字段', verbose_name='技术文件'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AddField(
 | 
				
			||||||
 | 
					            model_name='patentinfo',
 | 
				
			||||||
 | 
					            name='tech_status',
 | 
				
			||||||
 | 
					            field=models.JSONField(blank=True, default=apps.ofm.models.PatentInfo.default_document_state, help_text='技术状态信息列表,每个条目包含name(名称)、status(状态)、file(文件)字段', verbose_name='技术状态'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='borrowrecord',
 | 
				
			||||||
 | 
					            name='remark',
 | 
				
			||||||
 | 
					            field=models.JSONField(default=list, help_text="['借阅', '复印', '查阅']", verbose_name='用途'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='publicity',
 | 
				
			||||||
 | 
					            name='channel',
 | 
				
			||||||
 | 
					            field=models.JSONField(default=list, help_text="['互联网', '信息平台', '官微', '公开发行物', '其它']", verbose_name='发布渠道'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='publicity',
 | 
				
			||||||
 | 
					            name='content',
 | 
				
			||||||
 | 
					            field=models.JSONField(default=list, help_text="['武器装备科研生产综合事项', '其它']", verbose_name='稿件内容涉及'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='publicity',
 | 
				
			||||||
 | 
					            name='dept_opinion',
 | 
				
			||||||
 | 
					            field=models.JSONField(blank=True, default=list, help_text="['同意', '不同意']", null=True, verbose_name='部门负责人意见'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='publicity',
 | 
				
			||||||
 | 
					            name='level',
 | 
				
			||||||
 | 
					            field=models.JSONField(default=list, help_text="['重要', '一般', '非涉密']", verbose_name='涉密等级'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					        migrations.AlterField(
 | 
				
			||||||
 | 
					            model_name='publicity',
 | 
				
			||||||
 | 
					            name='review',
 | 
				
			||||||
 | 
					            field=models.JSONField(blank=True, default=list, help_text="['内容不涉及国家秘密和商业秘密,申请公开', '内容涉及国家秘密,申请按涉密渠道发布']", null=True, verbose_name='第一撰稿人自审'),
 | 
				
			||||||
 | 
					        ),
 | 
				
			||||||
 | 
					    ]
 | 
				
			||||||
| 
						 | 
					@ -112,7 +112,7 @@ class BorrowRecord(CommonBDModel):
 | 
				
			||||||
    borrow_date = models.DateField('借阅日期',  null=True, blank=True)
 | 
					    borrow_date = models.DateField('借阅日期',  null=True, blank=True)
 | 
				
			||||||
    return_date = models.DateField('归还日期',  null=True, blank=True)
 | 
					    return_date = models.DateField('归还日期',  null=True, blank=True)
 | 
				
			||||||
    contacts = models.CharField('借阅人电话', max_length=50, validators=[phone_validator], null=True, blank=True)
 | 
					    contacts = models.CharField('借阅人电话', max_length=50, validators=[phone_validator], null=True, blank=True)
 | 
				
			||||||
    remark = models.JSONField('用途', default=list, help_text=['借阅', '复印', '查阅'])
 | 
					    remark = models.JSONField('用途', default=list, help_text=str(['借阅', '复印', '查阅']))
 | 
				
			||||||
    ticket = models.ForeignKey('wf.ticket', verbose_name='关联工单',
 | 
					    ticket = models.ForeignKey('wf.ticket', verbose_name='关联工单',
 | 
				
			||||||
                               on_delete=models.SET_NULL, related_name='borrow_ticket', null=True, blank=True, db_constraint=False)
 | 
					                               on_delete=models.SET_NULL, related_name='borrow_ticket', null=True, blank=True, db_constraint=False)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -124,18 +124,18 @@ class Publicity(CommonBDModel):
 | 
				
			||||||
    participants = models.CharField('所有撰稿人', max_length=50)
 | 
					    participants = models.CharField('所有撰稿人', max_length=50)
 | 
				
			||||||
    pub_dept = models.CharField('部室/研究院', null=True, blank=True, max_length=50)
 | 
					    pub_dept = models.CharField('部室/研究院', null=True, blank=True, max_length=50)
 | 
				
			||||||
    pfile = models.CharField('稿件路径', null=True, blank=True, max_length=100)
 | 
					    pfile = models.CharField('稿件路径', null=True, blank=True, max_length=100)
 | 
				
			||||||
    level = models.JSONField('涉密等级', default=list, help_text=['重要', '一般', '非涉密'])
 | 
					    level = models.JSONField('涉密等级', default=list, help_text=str(['重要', '一般', '非涉密']))
 | 
				
			||||||
    content = models.JSONField('稿件内容涉及', default=list, help_text=[
 | 
					    content = models.JSONField('稿件内容涉及', default=list, help_text=str([
 | 
				
			||||||
            "武器装备科研生产综合事项",
 | 
					            "武器装备科研生产综合事项",
 | 
				
			||||||
            "其它"
 | 
					            "其它"
 | 
				
			||||||
        ])
 | 
					        ]))
 | 
				
			||||||
    other_content = models.CharField('其它内容', max_length=100, blank=True, null=True)
 | 
					    other_content = models.CharField('其它内容', max_length=100, blank=True, null=True)
 | 
				
			||||||
    report_purpose = models.CharField('宣传报道目的', max_length=100, blank=True, null=True)
 | 
					    report_purpose = models.CharField('宣传报道目的', max_length=100, blank=True, null=True)
 | 
				
			||||||
    channel = models.JSONField('发布渠道', default=list, help_text=['互联网', '信息平台', '官微', '公开发行物', '其它'])
 | 
					    channel = models.JSONField('发布渠道', default=list, help_text=str(['互联网', '信息平台', '官微', '公开发行物', '其它']))
 | 
				
			||||||
    other_channel = models.CharField('其它渠道', max_length=50, blank=True, null=True)
 | 
					    other_channel = models.CharField('其它渠道', max_length=50, blank=True, null=True)
 | 
				
			||||||
    report_name = models.CharField('报道名称', max_length=50, blank=True, null=True)
 | 
					    report_name = models.CharField('报道名称', max_length=50, blank=True, null=True)
 | 
				
			||||||
    review = models.JSONField('第一撰稿人自审', default=list, help_text=['内容不涉及国家秘密和商业秘密,申请公开', '内容涉及国家秘密,申请按涉密渠道发布'], null=True,blank=True)
 | 
					    review = models.JSONField('第一撰稿人自审', default=list, help_text=str(['内容不涉及国家秘密和商业秘密,申请公开', '内容涉及国家秘密,申请按涉密渠道发布']), null=True,blank=True)
 | 
				
			||||||
    dept_opinion = models.JSONField('部门负责人意见', default=list, help_text=['同意', '不同意'], null=True, blank=True)
 | 
					    dept_opinion = models.JSONField('部门负责人意见', default=list, help_text=str(['同意', '不同意']), null=True, blank=True)
 | 
				
			||||||
    secret_period = models.CharField('秘密期限', max_length=50, blank=True, null=True)
 | 
					    secret_period = models.CharField('秘密期限', max_length=50, blank=True, null=True)
 | 
				
			||||||
    dept_opinion_review = models.CharField('部门审查意见', max_length=100, blank=True, null=True)
 | 
					    dept_opinion_review = models.CharField('部门审查意见', max_length=100, blank=True, null=True)
 | 
				
			||||||
    publicity_opinion = models.CharField('宣传报道意见', max_length=100, blank=True, null=True)
 | 
					    publicity_opinion = models.CharField('宣传报道意见', max_length=100, blank=True, null=True)
 | 
				
			||||||
| 
						 | 
					@ -158,34 +158,33 @@ class Publicity(CommonBDModel):
 | 
				
			||||||
        super().save(*args, **kwargs)
 | 
					        super().save(*args, **kwargs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# class PatentInfo(CommonBDModel):
 | 
					class PatentInfo(CommonBDModel):
 | 
				
			||||||
#     """TN: 专利申密审批表单样式"""
 | 
					    """TN: 专利申密审批表单样式"""
 | 
				
			||||||
#     PATENT_TYPE_CHOICES = (
 | 
					    PATENT_TYPE_CHOICES = (
 | 
				
			||||||
#     ('invention', '发明专利'),
 | 
					    ('invention', '发明专利'),
 | 
				
			||||||
#     ('utility', '实用新型专利'),
 | 
					    ('utility', '实用新型专利'),
 | 
				
			||||||
#     ('design', '外观设计专利'),
 | 
					    ('design', '外观设计专利'),
 | 
				
			||||||
#     )
 | 
					    )
 | 
				
			||||||
#     APPLY_AREAS = (
 | 
					    APPLY_AREAS = (
 | 
				
			||||||
#         ('Domestic', '国内申请'),
 | 
					        ('Domestic', '国内申请'),
 | 
				
			||||||
#         ('Foreign', '国外申请'),
 | 
					        ('Foreign', '国外申请'),
 | 
				
			||||||
#         (' PCT', 'PCT申请'),
 | 
					        (' PCT', 'PCT申请'),
 | 
				
			||||||
#     )
 | 
					    )
 | 
				
			||||||
#     name = models.CharField('拟申请专利名称', max_length=100)
 | 
					 | 
				
			||||||
#     author = models.CharField('发明人(设计人)', max_length=100)
 | 
					 | 
				
			||||||
#     type = models.CharField('专利类型', max_length=50, choices=PATENT_TYPE_CHOICES, default='invention')
 | 
					 | 
				
			||||||
#     is_public = models.BooleanField('是否公开', default=False)
 | 
					 | 
				
			||||||
#     area = models.CharField('拟申请地域', max_length=50, choices=APPLY_AREAS, default='Domestic')
 | 
					 | 
				
			||||||
#     identified = models.BooleanField('是否进行过科技成果鉴定', default=False)
 | 
					 | 
				
			||||||
#     published_article = models.BooleanField('是否发表过文章', default=False)
 | 
					 | 
				
			||||||
#     exhibited = models.BooleanField('是否参与过展会展出', default=False)
 | 
					 | 
				
			||||||
#     applied_to_production = models.BooleanField('是否参与应用于生产/销售', default=False)
 | 
					 | 
				
			||||||
#     participated_in_exchange = models.BooleanField('是否参与过技术交流', default=False)
 | 
					 | 
				
			||||||
#     tech_background_pages = models.PositiveIntegerField('技术背景材料页数', null=True, blank=True)
 | 
					 | 
				
			||||||
#     tech_disclosure_pages = models.PositiveIntegerField('技术交底材料页数', null=True, blank=True)
 | 
					 | 
				
			||||||
#     novelty_report_pages = models.PositiveIntegerField('查新检索报告页数', null=True, blank=True)
 | 
					 | 
				
			||||||
#     diagrams_or_photos_pages = models.PositiveIntegerField('图/照片页数或张数', null=True, blank=True)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def default_document_state(self):
 | 
				
			||||||
 | 
					        return []
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    name = models.CharField('拟申请专利名称', max_length=100)
 | 
				
			||||||
 | 
					    author = models.CharField('发明人(设计人)', max_length=100)
 | 
				
			||||||
 | 
					    type = models.CharField('专利类型', max_length=50, choices=PATENT_TYPE_CHOICES, default='invention')
 | 
				
			||||||
 | 
					    is_public = models.BooleanField('是否公开', default=False)
 | 
				
			||||||
 | 
					    area = models.CharField('拟申请地域', max_length=50, choices=APPLY_AREAS, default='Domestic')
 | 
				
			||||||
 | 
					    other_area = models.CharField('其它申请地域', max_length=50, blank=True, null=True)
 | 
				
			||||||
 | 
					    tech_status = models.JSONField('技术状态', default=default_document_state, blank=True, help_text='技术状态信息列表,每个条目包含name(名称)、status(状态)、file(文件)字段')
 | 
				
			||||||
 | 
					    tech_file = models.JSONField('技术文件', default=list, help_text='技术文件信息列表,每个条目包含name(名称)page(页数)字段')
 | 
				
			||||||
 | 
					    ticket = models.ForeignKey('wf.ticket', verbose_name='关联工单',
 | 
				
			||||||
 | 
					                               on_delete=models.SET_NULL, related_name='patentInfo_ticket', null=True, blank=True, db_constraint=False)
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
# class PaperOfm(CommonADModel):
 | 
					# class PaperOfm(CommonADModel):
 | 
				
			||||||
#     """TN: 论文申密审批表单"""
 | 
					#     """TN: 论文申密审批表单"""
 | 
				
			||||||
#     PAPER_TYPE_CHOICES = (
 | 
					#     PAPER_TYPE_CHOICES = (
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,5 +1,5 @@
 | 
				
			||||||
from .models import (Mroom, MroomBooking, MroomSlot,  LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity)
 | 
					from .models import (Mroom, MroomBooking, MroomSlot,  LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo)
 | 
				
			||||||
# Publicity, PatentInfo, PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
					# Publicity, PatetInfo, PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
				
			||||||
from apps.utils.serializers import CustomModelSerializer
 | 
					from apps.utils.serializers import CustomModelSerializer
 | 
				
			||||||
from rest_framework import serializers
 | 
					from rest_framework import serializers
 | 
				
			||||||
from django.db import transaction
 | 
					from django.db import transaction
 | 
				
			||||||
| 
						 | 
					@ -122,11 +122,14 @@ class PublicitySerializer(CustomModelSerializer):
 | 
				
			||||||
        read_only_fields = EXCLUDE_FIELDS
 | 
					        read_only_fields = EXCLUDE_FIELDS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# class PatentInfoSerializer(CustomModelSerializer):
 | 
					class PatentInfoSerializer(CustomModelSerializer):
 | 
				
			||||||
#     class Meta:
 | 
					    create_by_name = serializers.CharField(source='create_by.name', read_only=True)
 | 
				
			||||||
#         model = PatentInfo
 | 
					    belong_dept_name = serializers.CharField(source='belong_dept.name', read_only=True)
 | 
				
			||||||
#         fields = '__all__'
 | 
					    ticket_ = TicketSimpleSerializer(source='ticket', read_only=True)
 | 
				
			||||||
#         read_only_fields = EXCLUDE_FIELDS
 | 
					    class Meta:
 | 
				
			||||||
 | 
					        model = PatentInfo
 | 
				
			||||||
 | 
					        fields = '__all__'
 | 
				
			||||||
 | 
					        read_only_fields = EXCLUDE_FIELDS
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# class PaperSerializer(CustomModelSerializer):
 | 
					# class PaperSerializer(CustomModelSerializer):
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,7 +1,7 @@
 | 
				
			||||||
 | 
					
 | 
				
			||||||
from apps.wf.models import Ticket
 | 
					from apps.wf.models import Ticket
 | 
				
			||||||
# TicketFlow, Transition, Workflow, CustomField, State, 
 | 
					# TicketFlow, Transition, Workflow, CustomField, State, 
 | 
				
			||||||
from apps.ofm.models import LendingSeal, Vehicle, BorrowRecord, Publicity, MroomBooking, MroomSlot
 | 
					from apps.ofm.models import LendingSeal, Vehicle, BorrowRecord, Publicity, MroomBooking, MroomSlot, PatentInfo
 | 
				
			||||||
from rest_framework.exceptions import ParseError
 | 
					from rest_framework.exceptions import ParseError
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -138,4 +138,18 @@ def save_ticket_data(ticket: Ticket, new_ticket_data: dict, **kwargs):
 | 
				
			||||||
    for k, v in data_save.items():
 | 
					    for k, v in data_save.items():
 | 
				
			||||||
        setattr(obj, k, v)
 | 
					        setattr(obj, k, v)
 | 
				
			||||||
    obj.save()
 | 
					    obj.save()
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def bind_patent(ticket: Ticket, transition, new_ticket_data: dict):
 | 
				
			||||||
 | 
					    ins = PatentInfo.objects.get(id=new_ticket_data['t_id'])
 | 
				
			||||||
 | 
					    ticket_data = ticket.ticket_data
 | 
				
			||||||
 | 
					    ticket_data.update({
 | 
				
			||||||
 | 
					        't_model': 'patent',
 | 
				
			||||||
 | 
					        't_id': ins.id,
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					    ticket.ticket_data = ticket_data
 | 
				
			||||||
 | 
					    ticket.create_by = ins.create_by
 | 
				
			||||||
 | 
					    ticket.save()
 | 
				
			||||||
 | 
					    if ins.ticket is None:
 | 
				
			||||||
 | 
					        ins.ticket = ticket
 | 
				
			||||||
 | 
					        ins.save()
 | 
				
			||||||
| 
						 | 
					@ -1,8 +1,9 @@
 | 
				
			||||||
from django.urls import path, include
 | 
					from django.urls import path, include
 | 
				
			||||||
from rest_framework.routers import DefaultRouter
 | 
					from rest_framework.routers import DefaultRouter
 | 
				
			||||||
from apps.ofm.views import (MroomViewSet, MroomBookingViewSet, MroomSlotViewSet,LendingSealViewSet, VehicleViewSet, FilerecordViewSet, FileborrowViewSet, PublicityViewSet)
 | 
					from apps.ofm.views import (MroomViewSet, MroomBookingViewSet, MroomSlotViewSet,LendingSealViewSet, VehicleViewSet, FilerecordViewSet, 
 | 
				
			||||||
 | 
					                            FileborrowViewSet, PublicityViewSet, PatentInfoViewSet)
 | 
				
			||||||
                            # SealModelViewSet, 
 | 
					                            # SealModelViewSet, 
 | 
				
			||||||
                            #   , PublicityViewSet, PatentInfoViewSet, PaperViewSet, PlatformViewSet,
 | 
					                            #   , PublicityViewSet, , PaperViewSet, PlatformViewSet,
 | 
				
			||||||
                            #     ProjectViewSet, PatentRecordViewSet, PaperRecordViewSet, ProjectApprovalViewSet, ProjectInfoViewSet)
 | 
					                            #     ProjectViewSet, PatentRecordViewSet, PaperRecordViewSet, ProjectApprovalViewSet, ProjectInfoViewSet)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
API_BASE_URL = 'api/ofm/'
 | 
					API_BASE_URL = 'api/ofm/'
 | 
				
			||||||
| 
						 | 
					@ -18,7 +19,7 @@ router.register('vehicle', VehicleViewSet, basename='vehicle')
 | 
				
			||||||
router.register('filerecord', FilerecordViewSet, basename='filerecord')
 | 
					router.register('filerecord', FilerecordViewSet, basename='filerecord')
 | 
				
			||||||
router.register('fileborrow', FileborrowViewSet, basename='fileborrow')
 | 
					router.register('fileborrow', FileborrowViewSet, basename='fileborrow')
 | 
				
			||||||
router.register('publicity', PublicityViewSet, basename='publicity')
 | 
					router.register('publicity', PublicityViewSet, basename='publicity')
 | 
				
			||||||
# router.register('patentinfo', PatentInfoViewSet, basename='patentinfo')
 | 
					router.register('patentinfo', PatentInfoViewSet, basename='patentinfo')
 | 
				
			||||||
# router.register('paper', PaperViewSet, basename='paper')
 | 
					# router.register('paper', PaperViewSet, basename='paper')
 | 
				
			||||||
# router.register('platform', PlatformViewSet, basename='platform')
 | 
					# router.register('platform', PlatformViewSet, basename='platform')
 | 
				
			||||||
# router.register('project', ProjectViewSet, basename='project')
 | 
					# router.register('project', ProjectViewSet, basename='project')
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1,8 +1,9 @@
 | 
				
			||||||
from django.shortcuts import render
 | 
					from django.shortcuts import render
 | 
				
			||||||
from apps.utils.viewsets import CustomModelViewSet, CustomGenericViewSet
 | 
					from apps.utils.viewsets import CustomModelViewSet, CustomGenericViewSet
 | 
				
			||||||
from .models import Mroom, MroomBooking, MroomSlot, LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity
 | 
					from .models import Mroom, MroomBooking, MroomSlot, LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo
 | 
				
			||||||
                    # Publicity, PatentInfo, PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
					                    # Publicity, , PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
				
			||||||
from .serializers import (MroomSerializer, MroomBookingSerializer, MroomSlotSerializer, LendingSealSerializer, VehicleSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer,)
 | 
					from .serializers import (MroomSerializer, MroomBookingSerializer, MroomSlotSerializer, LendingSealSerializer, 
 | 
				
			||||||
 | 
					                          VehicleSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, PatentInfoSerializer)
 | 
				
			||||||
    #                       ,SealSerializer, 
 | 
					    #                       ,SealSerializer, 
 | 
				
			||||||
    # LendingSealSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, 
 | 
					    # LendingSealSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, 
 | 
				
			||||||
    # PatentInfoSerializer, PaperSerializer, PlatformSerializer, ProjectSerializer, ProjectMemberSerializer, PaperRecordSerializer, ProjectApprovalSerializer, ProjectInfoSerializer)
 | 
					    # PatentInfoSerializer, PaperSerializer, PlatformSerializer, ProjectSerializer, ProjectMemberSerializer, PaperRecordSerializer, ProjectApprovalSerializer, ProjectInfoSerializer)
 | 
				
			||||||
| 
						 | 
					@ -170,15 +171,15 @@ class PublicityViewSet(CustomModelViewSet):
 | 
				
			||||||
    ordering = ["-create_time", "number"]
 | 
					    ordering = ["-create_time", "number"]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# class PatentInfoViewSet(CustomModelViewSet):
 | 
					class PatentInfoViewSet(CustomModelViewSet):
 | 
				
			||||||
#     """list: 专利
 | 
					    """list: 专利
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#     专利
 | 
					    专利
 | 
				
			||||||
#     """
 | 
					    """
 | 
				
			||||||
#     queryset = PatentInfo.objects.all()
 | 
					    queryset = PatentInfo.objects.all()
 | 
				
			||||||
#     serializer_class = PatentInfoSerializer
 | 
					    serializer_class = PatentInfoSerializer
 | 
				
			||||||
#     filterset_fields = ["name", "author", "type"]
 | 
					    filterset_fields = ["name", "author", "type"]
 | 
				
			||||||
#     ordering = ["create_time", "name", "author", "type"]
 | 
					    ordering = ["-create_time", "name", "author", "type"]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# class PaperViewSet(CustomModelViewSet):
 | 
					# class PaperViewSet(CustomModelViewSet):
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in New Issue