Merge branch 'master' of http://gitea.xxhhcty.xyz:8080/zcdsj/factory
This commit is contained in:
		
						commit
						caf00a107a
					
				| 
						 | 
				
			
			@ -0,0 +1,18 @@
 | 
			
		|||
# Generated by Django 3.2.12 on 2025-10-28 08:55
 | 
			
		||||
 | 
			
		||||
from django.db import migrations, models
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class Migration(migrations.Migration):
 | 
			
		||||
 | 
			
		||||
    dependencies = [
 | 
			
		||||
        ('enm', '0058_mpoint_save_expr'),
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    operations = [
 | 
			
		||||
        migrations.AlterField(
 | 
			
		||||
            model_name='mpoint',
 | 
			
		||||
            name='cal_related_mgroup_running',
 | 
			
		||||
            field=models.PositiveSmallIntegerField(blank=True, choices=[(10, '不涉及'), (20, '运行时统计')], default=10, null=True, verbose_name='与工段运行状态的关联'),
 | 
			
		||||
        ),
 | 
			
		||||
    ]
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,41 @@
 | 
			
		|||
# Generated by Django 3.2.12 on 2025-10-29 03:13
 | 
			
		||||
 | 
			
		||||
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 = [
 | 
			
		||||
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
 | 
			
		||||
        ('wf', '0004_workflow_view_path2'),
 | 
			
		||||
        ('ofm', '0025_alter_patentinfo_area'),
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    operations = [
 | 
			
		||||
        migrations.CreateModel(
 | 
			
		||||
            name='PaperSe',
 | 
			
		||||
            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='删除标记')),
 | 
			
		||||
                ('paper_name', models.CharField(max_length=100, verbose_name='拟发表论文名称')),
 | 
			
		||||
                ('publication_name', models.CharField(max_length=100, verbose_name='拟投期刊名称')),
 | 
			
		||||
                ('author', models.CharField(max_length=100, verbose_name='作者')),
 | 
			
		||||
                ('paper_type', models.CharField(max_length=100, verbose_name='拟发表文章类型')),
 | 
			
		||||
                ('is_chinese_core', models.BooleanField(default=False, verbose_name='是否为中文核心')),
 | 
			
		||||
                ('is_sci', models.BooleanField(default=False, verbose_name='是否被SCI/EI收录')),
 | 
			
		||||
                ('tech_status', models.JSONField(blank=True, default=list, help_text='技术状态信息列表,每个条目包含name(名称)、status(状态)、file(文件)字段', verbose_name='技术状态')),
 | 
			
		||||
                ('tech_file', models.JSONField(default=list, help_text='技术文件信息列表,每个条目包含name(名称)page(页数)字段', verbose_name='技术文件')),
 | 
			
		||||
                ('create_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='paperse_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='paperse_ticket', to='wf.ticket', verbose_name='关联工单')),
 | 
			
		||||
                ('update_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='paperse_update_by', to=settings.AUTH_USER_MODEL, verbose_name='最后编辑人')),
 | 
			
		||||
            ],
 | 
			
		||||
            options={
 | 
			
		||||
                'abstract': False,
 | 
			
		||||
            },
 | 
			
		||||
        ),
 | 
			
		||||
    ]
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,44 @@
 | 
			
		|||
# Generated by Django 3.2.12 on 2025-10-29 06:26
 | 
			
		||||
 | 
			
		||||
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 = [
 | 
			
		||||
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
 | 
			
		||||
        ('wf', '0004_workflow_view_path2'),
 | 
			
		||||
        ('ofm', '0026_paperse'),
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    operations = [
 | 
			
		||||
        migrations.CreateModel(
 | 
			
		||||
            name='Papersecret',
 | 
			
		||||
            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='删除标记')),
 | 
			
		||||
                ('paper_name', models.CharField(max_length=100, verbose_name='拟发表论文名称')),
 | 
			
		||||
                ('publication_name', models.CharField(max_length=100, verbose_name='拟投期刊名称')),
 | 
			
		||||
                ('author', models.CharField(max_length=100, verbose_name='作者')),
 | 
			
		||||
                ('paper_type', models.CharField(max_length=100, verbose_name='拟发表文章类型')),
 | 
			
		||||
                ('is_chinese_core', models.BooleanField(default=False, verbose_name='是否为中文核心')),
 | 
			
		||||
                ('is_sci', models.BooleanField(default=False, verbose_name='是否被SCI/EI收录')),
 | 
			
		||||
                ('tech_status', models.JSONField(blank=True, default=list, help_text='技术状态信息列表,每个条目包含name(名称)、status(状态)、file(文件)字段', verbose_name='技术状态')),
 | 
			
		||||
                ('tech_file', models.JSONField(default=list, help_text='技术文件信息列表,每个条目包含name(名称)page(页数)字段', verbose_name='技术文件')),
 | 
			
		||||
                ('create_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='papersecret_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='paperse_ticket', to='wf.ticket', verbose_name='关联工单')),
 | 
			
		||||
                ('update_by', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='papersecret_update_by', to=settings.AUTH_USER_MODEL, verbose_name='最后编辑人')),
 | 
			
		||||
            ],
 | 
			
		||||
            options={
 | 
			
		||||
                'abstract': False,
 | 
			
		||||
            },
 | 
			
		||||
        ),
 | 
			
		||||
        migrations.DeleteModel(
 | 
			
		||||
            name='PaperSe',
 | 
			
		||||
        ),
 | 
			
		||||
    ]
 | 
			
		||||
| 
						 | 
				
			
			@ -0,0 +1,20 @@
 | 
			
		|||
# Generated by Django 3.2.12 on 2025-10-30 05:55
 | 
			
		||||
 | 
			
		||||
from django.db import migrations, models
 | 
			
		||||
import django.db.models.deletion
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class Migration(migrations.Migration):
 | 
			
		||||
 | 
			
		||||
    dependencies = [
 | 
			
		||||
        ('system', '0006_auto_20241213_1249'),
 | 
			
		||||
        ('ofm', '0027_auto_20251029_1426'),
 | 
			
		||||
    ]
 | 
			
		||||
 | 
			
		||||
    operations = [
 | 
			
		||||
        migrations.AddField(
 | 
			
		||||
            model_name='papersecret',
 | 
			
		||||
            name='belong_dept',
 | 
			
		||||
            field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='papersecret_belong_dept', to='system.dept', verbose_name='所属部门'),
 | 
			
		||||
        ),
 | 
			
		||||
    ]
 | 
			
		||||
| 
						 | 
				
			
			@ -182,37 +182,18 @@ class PatentInfo(CommonBDModel):
 | 
			
		|||
    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):
 | 
			
		||||
#     """TN: 论文申密审批表单"""
 | 
			
		||||
#     PAPER_TYPE_CHOICES = (
 | 
			
		||||
#     ('research', '研究论文'),
 | 
			
		||||
#     ('comprehensive', '综合'),
 | 
			
		||||
#     )
 | 
			
		||||
#     name = models.CharField('拟申请专利名称', max_length=100)
 | 
			
		||||
#     author = models.CharField('发明人(设计人)', max_length=100)
 | 
			
		||||
#     paper_type = models.CharField('论文类型', max_length=50, choices=PAPER_TYPE_CHOICES, default='research')
 | 
			
		||||
#     is_chinese_core = models.BooleanField('是否为中文核心', default=False)
 | 
			
		||||
#     is_sci = models.BooleanField('是否被SCI/EI收录', default=False)
 | 
			
		||||
#     has_appraisal = models.BooleanField('是否进行过科技成果鉴定', default=False)
 | 
			
		||||
#     has_published_article = models.BooleanField('是否发表过文章', default=False)
 | 
			
		||||
#     has_exhibited = models.BooleanField('是否参与过展会展出', default=False)
 | 
			
		||||
#     has_applied_in_production = models.BooleanField('是否参与应用于生产/销售', default=False)
 | 
			
		||||
#     has_technical_exchange = models.BooleanField('是否参与过技术交流', default=False)
 | 
			
		||||
#     paper_page_count = models.PositiveIntegerField('论文页数', null=True, blank=True)
 | 
			
		||||
#     image_count = models.PositiveIntegerField('图/照片张数', null=True, blank=True)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class Platform(CommonADModel):
 | 
			
		||||
#     name = models.CharField(max_length=100)
 | 
			
		||||
 | 
			
		||||
#     def __str__(self):
 | 
			
		||||
#         return self.name
 | 
			
		||||
 | 
			
		||||
# class Project(CommonADModel):
 | 
			
		||||
#     name = models.CharField(max_length=100)
 | 
			
		||||
 | 
			
		||||
#     def __str__(self):
 | 
			
		||||
#         return self.name
 | 
			
		||||
class Papersecret(CommonBDModel):
 | 
			
		||||
    """TN: 论文申密审批表单"""
 | 
			
		||||
    paper_name = models.CharField('拟发表论文名称', max_length=100)
 | 
			
		||||
    publication_name = models.CharField('拟投期刊名称', max_length=100)
 | 
			
		||||
    author = models.CharField('作者', max_length=100)
 | 
			
		||||
    paper_type = models.CharField('拟发表文章类型', max_length=100)
 | 
			
		||||
    is_chinese_core = models.BooleanField('是否为中文核心', default=False)
 | 
			
		||||
    is_sci = models.BooleanField('是否被SCI/EI收录', default=False)
 | 
			
		||||
    tech_status = models.JSONField('技术状态', default=list, 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='paperse_ticket', null=True, blank=True, db_constraint=False)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class PatentRecord(CommonADModel):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,4 +1,4 @@
 | 
			
		|||
from .models import (Mroom, MroomBooking, MroomSlot,  LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo)
 | 
			
		||||
from .models import (Mroom, MroomBooking, MroomSlot,  LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo, Papersecret)
 | 
			
		||||
# Publicity, PatetInfo, PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
			
		||||
from apps.utils.serializers import CustomModelSerializer
 | 
			
		||||
from rest_framework import serializers
 | 
			
		||||
| 
						 | 
				
			
			@ -132,11 +132,14 @@ class PatentInfoSerializer(CustomModelSerializer):
 | 
			
		|||
        read_only_fields = EXCLUDE_FIELDS
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class PaperSerializer(CustomModelSerializer):
 | 
			
		||||
#     class Meta:
 | 
			
		||||
#         model = PaperOfm
 | 
			
		||||
#         fields = '__all__'
 | 
			
		||||
#         read_only_fields = EXCLUDE_FIELDS
 | 
			
		||||
class PaperSeSerializer(CustomModelSerializer):
 | 
			
		||||
    create_by_name = serializers.CharField(source='create_by.name', read_only=True)
 | 
			
		||||
    belong_dept_name = serializers.CharField(source='belong_dept.name', read_only=True)
 | 
			
		||||
    ticket_ = TicketSimpleSerializer(source='ticket', read_only=True)
 | 
			
		||||
    class Meta:
 | 
			
		||||
        model = Papersecret
 | 
			
		||||
        fields = '__all__'
 | 
			
		||||
        read_only_fields = EXCLUDE_FIELDS
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class PlatformSerializer(serializers.ModelSerializer):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,7 @@
 | 
			
		|||
 | 
			
		||||
from apps.wf.models import Ticket
 | 
			
		||||
# TicketFlow, Transition, Workflow, CustomField, State, 
 | 
			
		||||
from apps.ofm.models import LendingSeal, Vehicle, BorrowRecord, Publicity, MroomBooking, MroomSlot, PatentInfo
 | 
			
		||||
from apps.ofm.models import LendingSeal, Vehicle, BorrowRecord, Publicity, MroomBooking, MroomSlot, PatentInfo, Papersecret
 | 
			
		||||
from rest_framework.exceptions import ParseError
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -165,3 +165,28 @@ def patent_save_ticket_data(ticket: Ticket, new_ticket_data: dict, **kwargs):
 | 
			
		|||
        setattr(obj, k, v)
 | 
			
		||||
    obj.save()
 | 
			
		||||
    
 | 
			
		||||
 | 
			
		||||
def paperse_patent(ticket: Ticket, transition, new_ticket_data: dict):
 | 
			
		||||
    ins = Papersecret.objects.get(id=new_ticket_data['t_id'])
 | 
			
		||||
    ticket_data = ticket.ticket_data
 | 
			
		||||
    ticket_data.update({
 | 
			
		||||
        't_model': 'paperse',
 | 
			
		||||
        '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()
 | 
			
		||||
 | 
			
		||||
def paperse_save_ticket_data(ticket: Ticket, new_ticket_data: dict, **kwargs):
 | 
			
		||||
    try:
 | 
			
		||||
        obj = Papersecret.objects.get(id=new_ticket_data['t_id'])
 | 
			
		||||
    except Papersecret.DoesNotExist:
 | 
			
		||||
        raise ParseError("Publicity t_id 不存在")
 | 
			
		||||
    data_save = {k: v for k, v in new_ticket_data.items() if k not in ['t_model', 't_id']}
 | 
			
		||||
 | 
			
		||||
    for k, v in data_save.items():
 | 
			
		||||
        setattr(obj, k, v)
 | 
			
		||||
    obj.save()
 | 
			
		||||
| 
						 | 
				
			
			@ -1,7 +1,7 @@
 | 
			
		|||
from django.urls import path, include
 | 
			
		||||
from rest_framework.routers import DefaultRouter
 | 
			
		||||
from apps.ofm.views import (MroomViewSet, MroomBookingViewSet, MroomSlotViewSet,LendingSealViewSet, VehicleViewSet, FilerecordViewSet, 
 | 
			
		||||
                            FileborrowViewSet, PublicityViewSet, PatentInfoViewSet)
 | 
			
		||||
                            FileborrowViewSet, PublicityViewSet, PatentInfoViewSet, PapersecretViewSet)
 | 
			
		||||
                            # SealModelViewSet, 
 | 
			
		||||
                            #   , PublicityViewSet, , PaperViewSet, PlatformViewSet,
 | 
			
		||||
                            #     ProjectViewSet, PatentRecordViewSet, PaperRecordViewSet, ProjectApprovalViewSet, ProjectInfoViewSet)
 | 
			
		||||
| 
						 | 
				
			
			@ -20,7 +20,7 @@ router.register('filerecord', FilerecordViewSet, basename='filerecord')
 | 
			
		|||
router.register('fileborrow', FileborrowViewSet, basename='fileborrow')
 | 
			
		||||
router.register('publicity', PublicityViewSet, basename='publicity')
 | 
			
		||||
router.register('patentinfo', PatentInfoViewSet, basename='patentinfo')
 | 
			
		||||
# router.register('paper', PaperViewSet, basename='paper')
 | 
			
		||||
router.register('paperse', PapersecretViewSet, basename='PaperSe')
 | 
			
		||||
# router.register('platform', PlatformViewSet, basename='platform')
 | 
			
		||||
# router.register('project', ProjectViewSet, basename='project')
 | 
			
		||||
# router.register('patentrecord', PatentRecordViewSet, basename='patentrecord')
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,9 +1,9 @@
 | 
			
		|||
from django.shortcuts import render
 | 
			
		||||
from apps.utils.viewsets import CustomModelViewSet, CustomGenericViewSet
 | 
			
		||||
from .models import Mroom, MroomBooking, MroomSlot, LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo
 | 
			
		||||
from .models import Mroom, MroomBooking, MroomSlot, LendingSeal, Vehicle, FileRecord, BorrowRecord, Publicity, PatentInfo, Papersecret
 | 
			
		||||
                    # Publicity, , PaperOfm, Platform, Project, PatentRecord, PaperRecord, ProjectApproval, ProjectInfo)
 | 
			
		||||
from .serializers import (MroomSerializer, MroomBookingSerializer, MroomSlotSerializer, LendingSealSerializer, 
 | 
			
		||||
                          VehicleSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, PatentInfoSerializer)
 | 
			
		||||
                          VehicleSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, PatentInfoSerializer, PaperSeSerializer)
 | 
			
		||||
    #                       ,SealSerializer, 
 | 
			
		||||
    # LendingSealSerializer, FileRecordSerializer, BorrowRecordSerializer, PublicitySerializer, 
 | 
			
		||||
    # PatentInfoSerializer, PaperSerializer, PlatformSerializer, ProjectSerializer, ProjectMemberSerializer, PaperRecordSerializer, ProjectApprovalSerializer, ProjectInfoSerializer)
 | 
			
		||||
| 
						 | 
				
			
			@ -182,15 +182,15 @@ class PatentInfoViewSet(CustomModelViewSet):
 | 
			
		|||
    ordering = ["-create_time", "name", "author", "type"]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class PaperViewSet(CustomModelViewSet):
 | 
			
		||||
#     """list: 论文申密审批
 | 
			
		||||
class PapersecretViewSet(CustomModelViewSet):
 | 
			
		||||
    """list: 论文申密审批
 | 
			
		||||
 | 
			
		||||
#     论文申密审批
 | 
			
		||||
#     """
 | 
			
		||||
#     queryset = PaperOfm.objects.all()
 | 
			
		||||
#     serializer_class = PaperSerializer
 | 
			
		||||
#     filterset_fields = ["name", "author"]
 | 
			
		||||
#     ordering = ["create_time", "name"]
 | 
			
		||||
    论文申密审批
 | 
			
		||||
    """
 | 
			
		||||
    queryset = Papersecret.objects.all()
 | 
			
		||||
    serializer_class = PaperSeSerializer
 | 
			
		||||
    filterset_fields = ["paper_name", "author"]
 | 
			
		||||
    ordering = ["create_time", "paper_name"]
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
# class PlatformViewSet(CustomModelViewSet):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -30,7 +30,7 @@ myLogger = logging.getLogger('log')
 | 
			
		|||
 | 
			
		||||
def check_wpr_number(number: str):
 | 
			
		||||
    return (len(number) >= 5 and 
 | 
			
		||||
            number[-4:].isdigit() and 
 | 
			
		||||
            (number[-4:].isdigit() or number[-2] == "-" or number[-3] == "-") and 
 | 
			
		||||
            not any(char.islower() for char in number))
 | 
			
		||||
    
 | 
			
		||||
def generate_new_batch(old_batch: str, mlog: Mlog):
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue