证书颁发小程序端
This commit is contained in:
parent
2f7262cbad
commit
806f9df685
|
@ -81,5 +81,26 @@ Page({
|
||||||
*/
|
*/
|
||||||
onShareAppMessage: function () {
|
onShareAppMessage: function () {
|
||||||
|
|
||||||
|
},
|
||||||
|
issue: function(e){
|
||||||
|
let id = e.currentTarget.dataset.id; // 考试id
|
||||||
|
wx.showLoading({
|
||||||
|
title: '证书颁发中...',
|
||||||
|
})
|
||||||
|
api.requesta(`/examtest/examtest/${id}/issue/`, 'POST').then(res=>{
|
||||||
|
wx.hideLoading()
|
||||||
|
let index = e.currentTarget.dataset.index;
|
||||||
|
this.setData({
|
||||||
|
['tests[' + index + '].candidate_']:res.data
|
||||||
|
})
|
||||||
|
wx.showToast({
|
||||||
|
title: '证书颁发成功',
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
|
godetail: function(e){
|
||||||
|
wx.navigateTo({
|
||||||
|
url: '/pages/test/detail?id='+e.currentTarget.dataset.id,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
})
|
})
|
|
@ -42,10 +42,14 @@
|
||||||
<view class="weui-media-box__desc">
|
<view class="weui-media-box__desc">
|
||||||
得分:{{item.score}}
|
得分:{{item.score}}
|
||||||
</view>
|
</view>
|
||||||
|
<view class="weui-media-box__desc" wx:if="{{item.candidate_}}">
|
||||||
|
证书编号:
|
||||||
|
<text style="color:darkblue">{{item.candidate_.number}}</text>
|
||||||
|
</view>
|
||||||
<view style="text-align:right;padding-right:8rpx">
|
<view style="text-align:right;padding-right:8rpx">
|
||||||
<button type="primary" size="mini" bindtap="issue">颁发证书</button>
|
<button type="default" size="mini" bindtap="goCandidate" style="margin-left:4px" data-id="{{item.id}}" wx:if="{{item.candidate_}}">查看证书</button>
|
||||||
<button type="default" size="mini" bindtap="unbindmp" style="margin-left:4px">查看证书</button>
|
<button type="primary" size="mini" bindtap="issue" data-id="{{item.id}}" data-index="{{index}}" wx:else>颁发证书</button>
|
||||||
<button type="default" size="mini" bindtap="logout" style="margin-left:4px">答卷详情</button>
|
<button type="default" size="mini" bindtap="godetail" style="margin-left:4px" data-id="{{item.id}}">答卷详情</button>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
|
|
||||||
|
|
|
@ -38,7 +38,7 @@
|
||||||
"minifyWXSS": true
|
"minifyWXSS": true
|
||||||
},
|
},
|
||||||
"compileType": "miniprogram",
|
"compileType": "miniprogram",
|
||||||
"libVersion": "2.16.1",
|
"libVersion": "2.15.0",
|
||||||
"appid": "wxf1e9471c93f05ad6",
|
"appid": "wxf1e9471c93f05ad6",
|
||||||
"projectname": "test_mini",
|
"projectname": "test_mini",
|
||||||
"debugOptions": {
|
"debugOptions": {
|
||||||
|
|
|
@ -0,0 +1,73 @@
|
||||||
|
# Generated by Django 3.0.4 on 2021-06-06 00:53
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('examtest', '0030_examtest_consumer_detail'),
|
||||||
|
('crm', '0030_auto_20210414_2200'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterModelOptions(
|
||||||
|
name='candidate',
|
||||||
|
options={'verbose_name': '证书', 'verbose_name_plural': '证书'},
|
||||||
|
),
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='report_number',
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='ID_number',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='身份证号'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='compnay_name',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='单位'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='consumer_name',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='姓名'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='deptname',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='部门'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='end_date',
|
||||||
|
field=models.DateField(blank=True, null=True, verbose_name='有效期止'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='examtest',
|
||||||
|
field=models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='candidate_examtest', to='examtest.ExamTest', verbose_name='关联考试'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='number',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='报告单号'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='start_date',
|
||||||
|
field=models.DateField(blank=True, null=True, verbose_name='有效期始'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='workscope_name',
|
||||||
|
field=models.CharField(blank=True, max_length=60, null=True, verbose_name='证书工作类别'),
|
||||||
|
),
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='workscope',
|
||||||
|
field=models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, related_name='candidate_workscope', to='examtest.WorkScope'),
|
||||||
|
),
|
||||||
|
]
|
|
@ -0,0 +1,20 @@
|
||||||
|
# Generated by Django 3.0.4 on 2021-06-06 13:53
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
import django.db.models.deletion
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('examtest', '0030_examtest_consumer_detail'),
|
||||||
|
('crm', '0031_auto_20210606_0853'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterField(
|
||||||
|
model_name='candidate',
|
||||||
|
name='examtest',
|
||||||
|
field=models.OneToOneField(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='examtest.ExamTest', verbose_name='关联考试'),
|
||||||
|
),
|
||||||
|
]
|
|
@ -0,0 +1,18 @@
|
||||||
|
# Generated by Django 3.0.4 on 2021-06-06 14:09
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('crm', '0032_auto_20210606_2153'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RenameField(
|
||||||
|
model_name='candidate',
|
||||||
|
old_name='compnay_name',
|
||||||
|
new_name='company_name',
|
||||||
|
),
|
||||||
|
]
|
|
@ -114,16 +114,16 @@ class Candidate(CommonModel):
|
||||||
workscope_name = models.CharField('证书工作类别', max_length=60, null=True, blank=True)
|
workscope_name = models.CharField('证书工作类别', max_length=60, null=True, blank=True)
|
||||||
consumer_name = models.CharField('姓名', max_length=60, null=True, blank=True)
|
consumer_name = models.CharField('姓名', max_length=60, null=True, blank=True)
|
||||||
ID_number = models.CharField('身份证号', max_length=60, null=True, blank=True)
|
ID_number = models.CharField('身份证号', max_length=60, null=True, blank=True)
|
||||||
compnay_name = models.CharField('单位', max_length=60, null=True, blank=True)
|
company_name = models.CharField('单位', max_length=60, null=True, blank=True)
|
||||||
deptname = models.CharField('部门', max_length=60, null=True, blank=True)
|
deptname = models.CharField('部门', max_length=60, null=True, blank=True)
|
||||||
issue_date = models.DateField('发证日期', null=True, blank=True)
|
issue_date = models.DateField('发证日期', null=True, blank=True)
|
||||||
start_date = models.DateField('有效期始', null=True, blank=True)
|
start_date = models.DateField('有效期始', null=True, blank=True)
|
||||||
end_date = models.DateField('有效期止', null=True, blank=True)
|
end_date = models.DateField('有效期止', null=True, blank=True)
|
||||||
examtest = models.OneToOneField(to='examtest.examtest', verbose_name='关联考试', null=True, blank=True, on_delete=models.DO_NOTHING, related_name='candidate_examtest')
|
examtest = models.OneToOneField(to='examtest.examtest', verbose_name='关联考试', null=True, blank=True, on_delete=models.DO_NOTHING)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name = '证书'
|
verbose_name = '证书'
|
||||||
verbose_name_plural = verbose_name
|
verbose_name_plural = verbose_name
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.number
|
return self.consumer.username
|
||||||
|
|
|
@ -222,4 +222,35 @@ class ExamTestDetailSerializer(serializers.ModelSerializer):
|
||||||
""" Perform necessary eager loading of data. """
|
""" Perform necessary eager loading of data. """
|
||||||
queryset = queryset.select_related('consumer','paper', 'workscope', 'exam')
|
queryset = queryset.select_related('consumer','paper', 'workscope', 'exam')
|
||||||
queryset = queryset.prefetch_related('answerdetail_examtest')
|
queryset = queryset.prefetch_related('answerdetail_examtest')
|
||||||
|
return queryset
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class ExamTestExamListSerializer(serializers.ModelSerializer):
|
||||||
|
"""
|
||||||
|
正式考试列表序列化
|
||||||
|
"""
|
||||||
|
start_time = serializers.DateTimeField(format="%Y-%m-%d %H:%M:%S")
|
||||||
|
end_time = serializers.DateTimeField(format="%Y-%m-%d %H:%M:%S")
|
||||||
|
workscope_name = serializers.StringRelatedField(source='workscope', read_only=True)
|
||||||
|
took_format = serializers.SerializerMethodField()
|
||||||
|
candidate_ = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = ExamTest
|
||||||
|
exclude = ('detail',)
|
||||||
|
|
||||||
|
def get_took_format(self, obj):
|
||||||
|
m, s = divmod(obj.took, 60)
|
||||||
|
h, m = divmod(m, 60)
|
||||||
|
return "%02d:%02d:%02d" % (h, m, s)
|
||||||
|
|
||||||
|
def get_candidate_(self, obj):
|
||||||
|
candidate = obj.candidate if hasattr(obj, 'candidate') else None
|
||||||
|
if candidate:
|
||||||
|
return {'id':obj.candidate.id, 'number':obj.candidate.number}
|
||||||
|
@staticmethod
|
||||||
|
def setup_eager_loading(queryset):
|
||||||
|
""" Perform necessary eager loading of data. """
|
||||||
|
queryset = queryset.select_related('candidate')
|
||||||
return queryset
|
return queryset
|
|
@ -27,7 +27,7 @@ from .exports import export_test, exportw_test
|
||||||
from .models import AnswerDetail, Banner, ExamTest, Exam
|
from .models import AnswerDetail, Banner, ExamTest, Exam
|
||||||
from .models_paper import Paper, PaperQuestions, TestRule, WorkScope
|
from .models_paper import Paper, PaperQuestions, TestRule, WorkScope
|
||||||
from .serializers import (
|
from .serializers import (
|
||||||
AnswerDetailCreateSerializer, AnswerDetailSerializer, BannerSerializer,
|
AnswerDetailCreateSerializer, AnswerDetailSerializer, BannerSerializer, ExamTestExamListSerializer,
|
||||||
ExamTestListSerializer, MoniTestSerializer, PaperDetailSerializer,
|
ExamTestListSerializer, MoniTestSerializer, PaperDetailSerializer,
|
||||||
PaperQuestionsCreateSerializer, PaperSerializer, TestRuleSerializer,
|
PaperQuestionsCreateSerializer, PaperSerializer, TestRuleSerializer,
|
||||||
WorkScopeSerializer, ExamCreateUpdateSerializer, ExamListSerializer, ExamTestDetailSerializer)
|
WorkScopeSerializer, ExamCreateUpdateSerializer, ExamListSerializer, ExamTestDetailSerializer)
|
||||||
|
@ -383,7 +383,7 @@ class ExamTestViewSet(PageOrNot, ModelViewSet):
|
||||||
perms_map = [{'get': 'examtest_view'},{'post': '*'}, {'delete':'examtest_delete'}]
|
perms_map = [{'get': 'examtest_view'},{'post': '*'}, {'delete':'examtest_delete'}]
|
||||||
pagination_class = CommonPagination
|
pagination_class = CommonPagination
|
||||||
queryset = ExamTest.objects.filter(is_delete=0).all()
|
queryset = ExamTest.objects.filter(is_delete=0).all()
|
||||||
serializer_class = ExamTestListSerializer
|
serializer_class = ExamTestExamListSerializer
|
||||||
ordering_fields = ('id','create_time','took','score')
|
ordering_fields = ('id','create_time','took','score')
|
||||||
ordering = ['-create_time']
|
ordering = ['-create_time']
|
||||||
search_fields = ('consumer__name', 'consumer__company__name')
|
search_fields = ('consumer__name', 'consumer__company__name')
|
||||||
|
@ -504,28 +504,30 @@ class ExamTestViewSet(PageOrNot, ModelViewSet):
|
||||||
颁发证书
|
颁发证书
|
||||||
'''
|
'''
|
||||||
obj = self.get_object()
|
obj = self.get_object()
|
||||||
try:
|
candidate = obj.candidate if hasattr(obj, 'candidate') else None
|
||||||
candidate = Candidate.objects.get_or_create(examtest=obj)
|
# if not obj.is_pass:
|
||||||
|
# return Response({'error':'考试未通过'})
|
||||||
|
if candidate:
|
||||||
return Response({'error':'证书已存在'})
|
return Response({'error':'证书已存在'})
|
||||||
except:
|
candidates = Candidate.objects.filter(consumer=obj.consumer, workscope=obj.workscope, number__isnull=True)
|
||||||
candidates = Candidate.objects.filter(consumer=obj.consumer, workscope=obj.workscope, number__isnull=True)
|
if candidates.exists():
|
||||||
if candidates.exists():
|
candidate = candidates[0]
|
||||||
candidate = candidates(1)
|
else:
|
||||||
else:
|
candidate = Candidate.objects.create(consumer=obj.consumer, workscope=obj.workscope)
|
||||||
candidate = Candidate.objects.create(consumer=obj.consumer, workscope=obj.workscope)
|
count = Candidate.objects.exclude(number__isnull=True).count()
|
||||||
count = Candidate.objects.filter(number__isnull=True).count()
|
candidate.examtest = obj
|
||||||
candidate.examtest = obj
|
now = timezone.now()
|
||||||
now = timezone.now()
|
candidate.issue_date = now
|
||||||
candidate.issue_date = now
|
candidate.start_date = now
|
||||||
candidate.start_date = now
|
candidate.end_date = now + timedelta(days=3*365)
|
||||||
candidate.end_date = now + timedelta(years=3)
|
candidate.workscope_name = obj.workscope.name
|
||||||
candidate.workscope_name = obj.workscope.name
|
candidate.consumer_name = obj.consumer_detail['name']
|
||||||
candidate.consumer_name = obj.consumer_detail.consumer_name
|
candidate.ID_number = obj.consumer_detail['ID_number']
|
||||||
candidate.ID_number = obj.consumer_detail.ID_number
|
candidate.company_name = obj.consumer_detail['company_name']
|
||||||
candidate.company_name = obj.consumer_detail.company_name
|
candidate.deptname = obj.consumer_detail['deptname']
|
||||||
candidate.deptname = obj.consumer_detail.deptname
|
candidate.number='SL'+ str(now.year)[-2:] + str(count+1).zfill(6)
|
||||||
candidate.number='SL'+ str(now.year)[-2:] + str(count+1).zfill(6)
|
candidate.save()
|
||||||
return Response()
|
return Response({"id":candidate.pk, "number":candidate.number})
|
||||||
|
|
||||||
class PaperViewSet(ModelViewSet):
|
class PaperViewSet(ModelViewSet):
|
||||||
"""
|
"""
|
||||||
|
|
Binary file not shown.
Loading…
Reference in New Issue