@@ -6,6 +6,7 @@ from django.conf import settings |
||
| 6 | 6 |
from django_logit import logit |
| 7 | 7 |
from django_response import response |
| 8 | 8 |
from paginator import pagination |
| 9 |
+from TimeConvert import TimeConvert as tc |
|
| 9 | 10 |
|
| 10 | 11 |
from maintenance.models import MaintenaceInfo |
| 11 | 12 |
from utils.admin_utils import is_admin, is_maintenanceman |
@@ -26,7 +27,7 @@ def maintenance_add(request): |
||
| 26 | 27 |
point_name = request.POST.get('point_name', '')
|
| 27 | 28 |
express_name = request.POST.get('express_name', '')
|
| 28 | 29 |
tracking_number = request.POST.get('tracking_number', '')
|
| 29 |
- maintenance_status = request.POST.get('maintenace_status', '')
|
|
| 30 |
+ maintenance_status = request.POST.get('maintenance_status', u'寄出运送中')
|
|
| 30 | 31 |
|
| 31 | 32 |
maintenance = MaintenaceInfo.objects.create( |
| 32 | 33 |
user_id=user_id, |
@@ -41,7 +42,8 @@ def maintenance_add(request): |
||
| 41 | 42 |
point_name=point_name, |
| 42 | 43 |
express_name=express_name, |
| 43 | 44 |
tracking_number=tracking_number, |
| 44 |
- maintenace_status=maintenance_status, |
|
| 45 |
+ maintenance_status=maintenance_status, |
|
| 46 |
+ maintenance_status_at={maintenance_status: tc.utc_datetime()}
|
|
| 45 | 47 |
) |
| 46 | 48 |
|
| 47 | 49 |
return response(data={
|
@@ -86,7 +88,7 @@ def maintenance_update(request): |
||
| 86 | 88 |
tracking_number = request.POST.get('tracking_number', '')
|
| 87 | 89 |
back_express_name = request.POST.get('back_express_name', '')
|
| 88 | 90 |
back_tracking_number = request.POST.get('back_tracking_number', '')
|
| 89 |
- maintenance_status = request.POST.get('maintenace_status', '')
|
|
| 91 |
+ maintenance_status = request.POST.get('maintenance_status', u'寄出运送中')
|
|
| 90 | 92 |
|
| 91 | 93 |
try: |
| 92 | 94 |
maintenance = MaintenaceInfo.objects.get(id=maintenance_id, status=True) |
@@ -119,7 +121,10 @@ def maintenance_update(request): |
||
| 119 | 121 |
if back_tracking_number: |
| 120 | 122 |
maintenance.back_tracking_number = back_tracking_number |
| 121 | 123 |
if maintenance_status: |
| 122 |
- maintenance.maintenace_status = maintenance_status |
|
| 124 |
+ maintenance.maintenance_status = maintenance_status |
|
| 125 |
+ maintenance_status_at = maintenance.maintenance_status_at |
|
| 126 |
+ maintenance_status_at[maintenance_status] = tc.utc_datetime() |
|
| 127 |
+ maintenance.maintenance_status_at = maintenance_status_at |
|
| 123 | 128 |
maintenance.save() |
| 124 | 129 |
|
| 125 | 130 |
return response() |
@@ -14,7 +14,7 @@ class ExpressCompanyInfoAdmin(admin.ModelAdmin): |
||
| 14 | 14 |
|
| 15 | 15 |
|
| 16 | 16 |
class MaintenanceInfoAdmin(admin.ModelAdmin): |
| 17 |
- list_display = ('user_id', 'name', 'phone', 'address', 'sn', 'desc', 'point_id', 'point_name', 'express_name', 'tracking_number', 'back_express_name', 'back_tracking_number', 'maintenace_status', 'status', 'created_at', 'updated_at')
|
|
| 17 |
+ list_display = ('user_id', 'name', 'phone', 'address', 'sn', 'desc', 'point_id', 'point_name', 'express_name', 'tracking_number', 'back_express_name', 'back_tracking_number', 'maintenance_status', 'status', 'created_at', 'updated_at')
|
|
| 18 | 18 |
|
| 19 | 19 |
|
| 20 | 20 |
admin.site.register(MaintenacePointInfo, MaintenancePointInfoAdmin) |
@@ -0,0 +1,30 @@ |
||
| 1 |
+# -*- coding: utf-8 -*- |
|
| 2 |
+# Generated by Django 1.11.29 on 2021-09-22 07:18 |
|
| 3 |
+from __future__ import unicode_literals |
|
| 4 |
+ |
|
| 5 |
+from django.db import migrations, models |
|
| 6 |
+import jsonfield.fields |
|
| 7 |
+ |
|
| 8 |
+ |
|
| 9 |
+class Migration(migrations.Migration): |
|
| 10 |
+ |
|
| 11 |
+ dependencies = [ |
|
| 12 |
+ ('maintenance', '0005_auto_20210916_1827'),
|
|
| 13 |
+ ] |
|
| 14 |
+ |
|
| 15 |
+ operations = [ |
|
| 16 |
+ migrations.RemoveField( |
|
| 17 |
+ model_name='maintenaceinfo', |
|
| 18 |
+ name='maintenace_status', |
|
| 19 |
+ ), |
|
| 20 |
+ migrations.AddField( |
|
| 21 |
+ model_name='maintenaceinfo', |
|
| 22 |
+ name='maintenance_status', |
|
| 23 |
+ field=models.CharField(blank=True, help_text='\u7ef4\u4fee\u72b6\u6001', max_length=8, null=True, verbose_name='maintenance_status'), |
|
| 24 |
+ ), |
|
| 25 |
+ migrations.AddField( |
|
| 26 |
+ model_name='maintenaceinfo', |
|
| 27 |
+ name='maintenance_status_at', |
|
| 28 |
+ field=jsonfield.fields.JSONField(default={}, help_text='\u7ef4\u4fee\u72b6\u6001\u53d8\u66f4\u65f6\u95f4', verbose_name='maintenance_status_at'),
|
|
| 29 |
+ ), |
|
| 30 |
+ ] |
@@ -0,0 +1,20 @@ |
||
| 1 |
+# -*- coding: utf-8 -*- |
|
| 2 |
+# Generated by Django 1.11.29 on 2021-09-22 07:22 |
|
| 3 |
+from __future__ import unicode_literals |
|
| 4 |
+ |
|
| 5 |
+from django.db import migrations, models |
|
| 6 |
+ |
|
| 7 |
+ |
|
| 8 |
+class Migration(migrations.Migration): |
|
| 9 |
+ |
|
| 10 |
+ dependencies = [ |
|
| 11 |
+ ('maintenance', '0006_auto_20210922_1518'),
|
|
| 12 |
+ ] |
|
| 13 |
+ |
|
| 14 |
+ operations = [ |
|
| 15 |
+ migrations.AlterField( |
|
| 16 |
+ model_name='maintenaceinfo', |
|
| 17 |
+ name='maintenance_status', |
|
| 18 |
+ field=models.CharField(default='\u5bc4\u51fa\u8fd0\u9001\u4e2d', help_text='\u7ef4\u4fee\u72b6\u6001', max_length=8, verbose_name='maintenance_status'), |
|
| 19 |
+ ), |
|
| 20 |
+ ] |
@@ -3,6 +3,7 @@ |
||
| 3 | 3 |
from django.db import models |
| 4 | 4 |
from django.utils.translation import ugettext_lazy as _ |
| 5 | 5 |
from django_models_ext import BaseModelMixin |
| 6 |
+from jsonfield import JSONField |
|
| 6 | 7 |
from TimeConvert import TimeConvert as tc |
| 7 | 8 |
|
| 8 | 9 |
from mch.models import ModelInfo |
@@ -71,7 +72,9 @@ class MaintenaceInfo(BaseModelMixin): |
||
| 71 | 72 |
back_express_name = models.CharField(_(u'back_express_name'), max_length=255, blank=True, null=True, help_text=u'寄回快递公司') |
| 72 | 73 |
back_tracking_number = models.CharField(_(u'back_tracking_number'), max_length=255, blank=True, null=True, help_text=u'寄回快递单号') |
| 73 | 74 |
|
| 74 |
- maintenace_status = models.CharField(_(u'maintenace_status'), max_length=8, blank=True, null=True, help_text=u'维修状态') |
|
| 75 |
+ # 寄出运送中、已签收修理中、已修复寄回、寄回签收 |
|
| 76 |
+ maintenance_status = models.CharField(_(u'maintenance_status'), max_length=8, default=u'寄出运送中', help_text=u'维修状态') |
|
| 77 |
+ maintenance_status_at = JSONField(_(u'maintenance_status_at'), default={}, help_text=u'维修状态变更时间')
|
|
| 75 | 78 |
|
| 76 | 79 |
class Meta: |
| 77 | 80 |
verbose_name = _(u'维修信息') |
@@ -82,7 +85,10 @@ class MaintenaceInfo(BaseModelMixin): |
||
| 82 | 85 |
|
| 83 | 86 |
@property |
| 84 | 87 |
def data(self): |
| 85 |
- model = ModelInfo.objects.get(model_id=self.model_id, status=True) |
|
| 88 |
+ try: |
|
| 89 |
+ model = ModelInfo.objects.get(model_id=self.model_id, status=True) |
|
| 90 |
+ except ModelInfo.DoesNotExist: |
|
| 91 |
+ model = None |
|
| 86 | 92 |
return {
|
| 87 | 93 |
'maintenance_id': self.pk, |
| 88 | 94 |
'user_id': self.user_id, |
@@ -90,8 +96,8 @@ class MaintenaceInfo(BaseModelMixin): |
||
| 90 | 96 |
'phone': self.phone, |
| 91 | 97 |
'address': self.address, |
| 92 | 98 |
'model_id': self.model_id, |
| 93 |
- 'model_name': model.model_name, |
|
| 94 |
- 'model_full_name': model.model_full_name, |
|
| 99 |
+ 'model_name': model.model_name if model else '', |
|
| 100 |
+ 'model_full_name': model.model_full_name if model else '', |
|
| 95 | 101 |
'log_id': self.log_id, |
| 96 | 102 |
'sn': self.sn, |
| 97 | 103 |
'desc': self.desc, |
@@ -101,7 +107,8 @@ class MaintenaceInfo(BaseModelMixin): |
||
| 101 | 107 |
'tracking_number': self.tracking_number, |
| 102 | 108 |
'back_express_name': self.back_express_name, |
| 103 | 109 |
'back_tracking_number': self.back_tracking_number, |
| 104 |
- 'maintenace_status': self.maintenace_status, |
|
| 110 |
+ 'maintenance_status': self.maintenance_status, |
|
| 111 |
+ 'maintenance_status_at': {k: tc.local_string(utc_dt=tc.string_to_utc_datetime(v, format='%Y-%m-%dT%H:%M:%S.%fZ')) for k, v in self.maintenance_status_at.items()},
|
|
| 105 | 112 |
'created_at': tc.local_string(utc_dt=self.created_at), |
| 106 | 113 |
'updated_at': tc.local_string(utc_dt=self.updated_at), |
| 107 | 114 |
} |