| @@ -64,23 +64,12 @@ def shot_create(request, administrator): | ||
| 64 | 64 |      model_id = request.POST.get('model_id', '') | 
| 65 | 65 |      model_name = request.POST.get('model_name', '') | 
| 66 | 66 |      sn = request.POST.get('sn', '') | 
| 67 | -    front_cap_status = request.POST.get('front_cap_status', 1) | |
| 68 | -    rear_cap_status = request.POST.get('rear_cap_status', 1) | |
| 69 | -    lens_hood_status = request.POST.get('lens_hood_status', 1) | |
| 70 | -    tripod_ring_status = request.POST.get('tripod_ring_status', 1) | |
| 71 | -    appearance_performance_status = request.POST.get('appearance_performance_status', 1) | |
| 72 | 67 |      tenancy_status = request.POST.get('tenancy_status', 0) | 
| 73 | 68 |  | 
| 74 | 69 | shot = TenancyShotInfo.objects.create( | 
| 75 | 70 | model_id=model_id, | 
| 76 | 71 | model_name=model_name, | 
| 77 | 72 | sn=sn, | 
| 78 | - front_cap_status=front_cap_status, | |
| 79 | - rear_cap_status=rear_cap_status, | |
| 80 | - lens_hood_status=lens_hood_status, | |
| 81 | - tripod_ring_status=tripod_ring_status, | |
| 82 | - appearance_performance_status=appearance_performance_status, | |
| 83 | - tenancy_status=tenancy_status, | |
| 84 | 73 | ) | 
| 85 | 74 |  | 
| 86 | 75 |      return response(data={ | 
| @@ -95,22 +84,12 @@ def shot_update(request, administrator): | ||
| 95 | 84 |      model_id = request.POST.get('model_id', '') | 
| 96 | 85 |      model_name = request.POST.get('model_name', '') | 
| 97 | 86 |      sn = request.POST.get('sn', '') | 
| 98 | -    front_cap_status = request.POST.get('front_cap_status', 1) | |
| 99 | -    rear_cap_status = request.POST.get('rear_cap_status', 1) | |
| 100 | -    lens_hood_status = request.POST.get('lens_hood_status', 1) | |
| 101 | -    tripod_ring_status = request.POST.get('tripod_ring_status', 1) | |
| 102 | -    appearance_performance_status = request.POST.get('appearance_performance_status', 1) | |
| 103 | 87 |      tenancy_status = request.POST.get('tenancy_status', 0) | 
| 104 | 88 |  | 
| 105 | 89 |      shot, _ = TenancyShotInfo.objects.update_or_create(shot_id=shot_id, defaults={ | 
| 106 | 90 | 'model_id': model_id, | 
| 107 | 91 | 'model_name': model_name, | 
| 108 | 92 | 'sn': sn, | 
| 109 | - 'front_cap_status': front_cap_status, | |
| 110 | - 'rear_cap_status': rear_cap_status, | |
| 111 | - 'lens_hood_status': lens_hood_status, | |
| 112 | - 'tripod_ring_status': tripod_ring_status, | |
| 113 | - 'appearance_performance_status': appearance_performance_status, | |
| 114 | 93 | 'tenancy_status': tenancy_status, | 
| 115 | 94 | }) | 
| 116 | 95 |  | 
| @@ -132,7 +111,9 @@ def shot_request_list(request, administrator): | ||
| 132 | 111 |      reqs = TenancyShotRequestInfo.objects.filter(status=True).order_by('-pk') | 
| 133 | 112 |  | 
| 134 | 113 | if query: | 
| 135 | - reqs = reqs.filter(Q(phone__icontains=query) | Q(name__icontains=query)) | |
| 114 | +        shots = list(TenancyShotInfo.objects.values_list('model_id', flat=True).filter(sn__icontains=query)) | |
| 115 | + reqs = reqs.filter(Q(phone__icontains=query) | Q(name__icontains=query) | Q(shot_id__in=shots)) | |
| 116 | + | |
| 136 | 117 |  | 
| 137 | 118 | if request_status != 'all': | 
| 138 | 119 | reqs = reqs.filter(request_status=request_status) | 
| @@ -264,17 +245,34 @@ def shot_request_send(request, administrator): | ||
| 264 | 245 |      express_name = request.POST.get('express_name', '') | 
| 265 | 246 |      express_com = request.POST.get('express_com', '') | 
| 266 | 247 |      tracking_number = request.POST.get('tracking_number', '') | 
| 248 | +    shot_id = request.POST.get('shot_id', '') | |
| 249 | +    front_cap_status = request.POST.get('front_cap_status', 0) | |
| 250 | +    rear_cap_status = request.POST.get('rear_cap_status', 0) | |
| 251 | +    lens_hood_status = request.POST.get('lens_hood_status', 0) | |
| 252 | +    tripod_ring_status = request.POST.get('tripod_ring_status', 0) | |
| 253 | +    appearance_performance_status = request.POST.get('appearance_performance_status', 0) | |
| 267 | 254 |  | 
| 268 | 255 | try: | 
| 269 | 256 | req = TenancyShotRequestInfo.objects.select_for_update().get(request_id=req_id, status=True) | 
| 270 | 257 | except TenancyShotRequestInfo.DoesNotExist: | 
| 271 | 258 | return response(TenancyStatusCode.TENANCY_SHOT_REQUEST_NOT_FOUND) | 
| 259 | + | |
| 260 | + try: | |
| 261 | + shot = TenancyShotInfo.objects.get(shot_id=shot_id, status=True) | |
| 262 | + except TenancyShotInfo.DoesNotExist: | |
| 263 | + return response() | |
| 272 | 264 |  | 
| 273 | 265 | old_tracking_number = req.tracking_number | 
| 274 | 266 |  | 
| 275 | 267 | req.express_name = express_name | 
| 276 | 268 | req.express_com = express_com | 
| 277 | 269 | req.tracking_number = tracking_number | 
| 270 | + req.shot_id = shot_id | |
| 271 | + req.front_cap_status = front_cap_status | |
| 272 | + req.rear_cap_status = rear_cap_status | |
| 273 | + req.lens_hood_status = lens_hood_status | |
| 274 | + req.tripod_ring_status = tripod_ring_status | |
| 275 | + req.appearance_performance_status = appearance_performance_status | |
| 278 | 276 | req.request_status = TenancyShotRequestInfo.TENANCY_TRACKING_SEND | 
| 279 | 277 | request_status_at = req.request_status_at | 
| 280 | 278 | request_status_at[TenancyShotRequestInfo.TENANCY_TRACKING_SEND] = tc.utc_string() | 
| @@ -14,22 +14,20 @@ from paginator import pagination | ||
| 14 | 14 | from TimeConvert import TimeConvert as tc | 
| 15 | 15 |  | 
| 16 | 16 | from tenancy.models import TenancyShotInfo, TenancyShotRequestInfo | 
| 17 | +from mch.models import ModelInfo | |
| 17 | 18 | from utils.error.errno_utils import TenancyStatusCode | 
| 18 | 19 | from utils.kuaidi.subscribe import KuaiDi100 as KuaiDi100Subscribe | 
| 19 | 20 |  | 
| 20 | 21 |  | 
| 21 | 22 | @logit | 
| 22 | 23 | def shot_list(request): | 
| 23 | -    page = request.POST.get('page', 1) | |
| 24 | -    num = request.POST.get('num', 20) | |
| 25 | - | |
| 26 | -    shots = TenancyShotInfo.objects.filter(tenancy_status=0, status=True).order_by('-pk') | |
| 27 | - shots = [shot.data for shot in shots] | |
| 28 | - shots, left = pagination(shots, page, num) | |
| 24 | +    shots = TenancyShotInfo.objects.values('model_id').filter(tenancy_status=0, status=True).order_by('model_id') | |
| 25 | + shots = [shot['model_id'] for shot in shots] | |
| 26 | + shots = ModelInfo.objects.filter(model_id__in=shots) | |
| 27 | + shots = [shot.admindata for shot in shots] | |
| 29 | 28 |  | 
| 30 | 29 |      return response(data={ | 
| 31 | 30 | 'shots': shots, | 
| 32 | - 'left': left, | |
| 33 | 31 | }) | 
| 34 | 32 |  | 
| 35 | 33 |  | 
| @@ -49,7 +47,7 @@ def shot_detail(request): | ||
| 49 | 47 |  | 
| 50 | 48 | @logit | 
| 51 | 49 | def shot_request_create(request): | 
| 52 | -    shot_id = request.POST.get('shot_id', '') | |
| 50 | +    model_id = request.POST.get('model_id', '') | |
| 53 | 51 |      user_id = request.POST.get('user_id', '') | 
| 54 | 52 |      name = request.POST.get('name', '') | 
| 55 | 53 |      phone = request.POST.get('phone', '') | 
| @@ -59,7 +57,7 @@ def shot_request_create(request): | ||
| 59 | 57 |      return_date = tc.to_date(request.POST.get('return_date', '') or settings.DEFAULT_START_DATE) | 
| 60 | 58 |  | 
| 61 | 59 | req = TenancyShotRequestInfo.objects.create( | 
| 62 | - shot_id=shot_id, | |
| 60 | + model_id=model_id, | |
| 63 | 61 | user_id=user_id, | 
| 64 | 62 | name=name, | 
| 65 | 63 | phone=phone, | 
| @@ -0,0 +1,74 @@ | ||
| 1 | +# -*- coding: utf-8 -*- | |
| 2 | +# Generated by Django 3.2.16 on 2022-11-15 10:36 | |
| 3 | + | |
| 4 | +from django.db import migrations, models | |
| 5 | + | |
| 6 | + | |
| 7 | +class Migration(migrations.Migration): | |
| 8 | + | |
| 9 | + dependencies = [ | |
| 10 | +        ('tenancy', '0003_auto_20221108_2326'), | |
| 11 | + ] | |
| 12 | + | |
| 13 | + operations = [ | |
| 14 | + migrations.AddField( | |
| 15 | + model_name='tenancyshotrequestinfo', | |
| 16 | + name='admin_id', | |
| 17 | + field=models.CharField(blank=True, db_index=True, help_text='经手人唯一标识', max_length=32, null=True, verbose_name='admin_id'), | |
| 18 | + ), | |
| 19 | + migrations.AddField( | |
| 20 | + model_name='tenancyshotrequestinfo', | |
| 21 | + name='appearance_performance_status', | |
| 22 | + field=models.BooleanField(default=False, help_text='外观性能状态', verbose_name='appearance_performance_status'), | |
| 23 | + ), | |
| 24 | + migrations.AddField( | |
| 25 | + model_name='tenancyshotrequestinfo', | |
| 26 | + name='front_cap_status', | |
| 27 | + field=models.BooleanField(default=False, help_text='前盖状态', verbose_name='front_cap_status'), | |
| 28 | + ), | |
| 29 | + migrations.AddField( | |
| 30 | + model_name='tenancyshotrequestinfo', | |
| 31 | + name='lens_hood_status', | |
| 32 | + field=models.BooleanField(default=False, help_text='遮光罩状态', verbose_name='lens_hood_status'), | |
| 33 | + ), | |
| 34 | + migrations.AddField( | |
| 35 | + model_name='tenancyshotrequestinfo', | |
| 36 | + name='model_id', | |
| 37 | + field=models.CharField(blank=True, db_index=True, help_text='镜头型号唯一标识', max_length=32, null=True, verbose_name='model_id'), | |
| 38 | + ), | |
| 39 | + migrations.AddField( | |
| 40 | + model_name='tenancyshotrequestinfo', | |
| 41 | + name='rear_cap_status', | |
| 42 | + field=models.BooleanField(default=False, help_text='后盖状态', verbose_name='rear_cap_status'), | |
| 43 | + ), | |
| 44 | + migrations.AddField( | |
| 45 | + model_name='tenancyshotrequestinfo', | |
| 46 | + name='tripod_ring_status', | |
| 47 | + field=models.BooleanField(default=False, help_text='脚架环状态', verbose_name='tripod_ring_status'), | |
| 48 | + ), | |
| 49 | + migrations.AlterField( | |
| 50 | + model_name='tenancyshotinfo', | |
| 51 | + name='appearance_performance_status', | |
| 52 | + field=models.BooleanField(default=False, help_text='外观性能状态', verbose_name='appearance_performance_status'), | |
| 53 | + ), | |
| 54 | + migrations.AlterField( | |
| 55 | + model_name='tenancyshotinfo', | |
| 56 | + name='front_cap_status', | |
| 57 | + field=models.BooleanField(default=False, help_text='前盖状态', verbose_name='front_cap_status'), | |
| 58 | + ), | |
| 59 | + migrations.AlterField( | |
| 60 | + model_name='tenancyshotinfo', | |
| 61 | + name='lens_hood_status', | |
| 62 | + field=models.BooleanField(default=False, help_text='遮光罩状态', verbose_name='lens_hood_status'), | |
| 63 | + ), | |
| 64 | + migrations.AlterField( | |
| 65 | + model_name='tenancyshotinfo', | |
| 66 | + name='rear_cap_status', | |
| 67 | + field=models.BooleanField(default=False, help_text='后盖状态', verbose_name='rear_cap_status'), | |
| 68 | + ), | |
| 69 | + migrations.AlterField( | |
| 70 | + model_name='tenancyshotinfo', | |
| 71 | + name='tripod_ring_status', | |
| 72 | + field=models.BooleanField(default=False, help_text='脚架环状态', verbose_name='tripod_ring_status'), | |
| 73 | + ), | |
| 74 | + ] | 
| @@ -7,7 +7,7 @@ from jsonfield import JSONField | ||
| 7 | 7 | from shortuuidfield import ShortUUIDField | 
| 8 | 8 | from TimeConvert import TimeConvert as tc | 
| 9 | 9 |  | 
| 10 | -from mch.models import ModelInfo | |
| 10 | +from mch.models import ModelInfo, AdministratorInfo | |
| 11 | 11 |  | 
| 12 | 12 |  | 
| 13 | 13 | class TenancyShotInfo(BaseModelMixin): | 
| @@ -20,11 +20,11 @@ class TenancyShotInfo(BaseModelMixin): | ||
| 20 | 20 | model_id = models.CharField(_(u'model_id'), max_length=32, blank=True, null=True, help_text=u'型号唯一标识', db_index=True) | 
| 21 | 21 | model_name = models.CharField(_(u'model_name'), max_length=255, blank=True, null=True, help_text=u'型号名称') | 
| 22 | 22 | sn = models.CharField(_(u'sn'), max_length=32, blank=True, null=True, help_text=u'序列号', db_index=True) | 
| 23 | - front_cap_status = models.BooleanField(_(u'front_cap_status'), default=True, help_text=u'前盖状态') | |
| 24 | - rear_cap_status = models.BooleanField(_(u'rear_cap_status'), default=True, help_text=u'后盖状态') | |
| 25 | - lens_hood_status = models.BooleanField(_(u'lens_hood_status'), default=True, help_text=u'遮光罩状态') | |
| 26 | - tripod_ring_status = models.BooleanField(_(u'tripod_ring_status'), default=True, help_text=u'脚架环状态') | |
| 27 | - appearance_performance_status = models.BooleanField(_(u'appearance_performance_status'), default=True, help_text=u'外观性能状态') | |
| 23 | + front_cap_status = models.BooleanField(_(u'front_cap_status'), default=False, help_text=u'前盖状态') | |
| 24 | + rear_cap_status = models.BooleanField(_(u'rear_cap_status'), default=False, help_text=u'后盖状态') | |
| 25 | + lens_hood_status = models.BooleanField(_(u'lens_hood_status'), default=False, help_text=u'遮光罩状态') | |
| 26 | + tripod_ring_status = models.BooleanField(_(u'tripod_ring_status'), default=False, help_text=u'脚架环状态') | |
| 27 | + appearance_performance_status = models.BooleanField(_(u'appearance_performance_status'), default=False, help_text=u'外观性能状态') | |
| 28 | 28 | tenancy_status = models.IntegerField(_(u'tenancy_status'), choices=TENANCY_STATUS, default=0, help_text=u'租借状态') | 
| 29 | 29 |  | 
| 30 | 30 | class Meta: | 
| @@ -70,10 +70,20 @@ class TenancyShotRequestInfo(BaseModelMixin): | ||
| 70 | 70 | ) | 
| 71 | 71 |  | 
| 72 | 72 | request_id = ShortUUIDField(_(u'request_id'), max_length=32, blank=True, null=True, help_text=u'申请唯一标识', db_index=True, unique=True) | 
| 73 | + admin_id = models.CharField(_(u'admin_id'), max_length=32, blank=True, null=True, help_text=u'经手人唯一标识', db_index=True) | |
| 74 | + | |
| 73 | 75 | shot_id = models.CharField(_(u'shot_id'), max_length=32, blank=True, null=True, help_text=u'镜头唯一标识', db_index=True) | 
| 76 | + model_id = models.CharField(_(u'model_id'), max_length=32, blank=True, null=True, help_text=u'镜头型号唯一标识', db_index=True) | |
| 74 | 77 |  | 
| 75 | 78 | user_id = models.CharField(_(u'user_id'), max_length=32, blank=True, null=True, help_text=u'用户唯一标识', db_index=True) | 
| 76 | 79 |  | 
| 80 | + #镜头配件信息 | |
| 81 | + front_cap_status = models.BooleanField(_(u'front_cap_status'), default=False, help_text=u'前盖状态') | |
| 82 | + rear_cap_status = models.BooleanField(_(u'rear_cap_status'), default=False, help_text=u'后盖状态') | |
| 83 | + lens_hood_status = models.BooleanField(_(u'lens_hood_status'), default=False, help_text=u'遮光罩状态') | |
| 84 | + tripod_ring_status = models.BooleanField(_(u'tripod_ring_status'), default=False, help_text=u'脚架环状态') | |
| 85 | + appearance_performance_status = models.BooleanField(_(u'appearance_performance_status'), default=False, help_text=u'外观性能状态') | |
| 86 | + | |
| 77 | 87 | # 身份证信息 | 
| 78 | 88 | identity_card_number = models.CharField(_(u'identity_card_number'), max_length=32, blank=True, null=True, help_text=u'身份证号') | 
| 79 | 89 | identity_card_name = models.CharField(_(u'identity_card_name'), max_length=32, blank=True, null=True, help_text=u'身份证姓名') | 
| @@ -132,6 +142,11 @@ class TenancyShotRequestInfo(BaseModelMixin): | ||
| 132 | 142 | 'request_id': self.request_id, | 
| 133 | 143 | 'shot_id': self.shot_id, | 
| 134 | 144 |              'shot_info': shot.data if shot else {}, | 
| 145 | + 'front_cap_status': self.front_cap_status, | |
| 146 | + 'rear_cap_status': self.rear_cap_status, | |
| 147 | + 'lens_hood_status': self.lens_hood_status, | |
| 148 | + 'tripod_ring_status': self.tripod_ring_status, | |
| 149 | + 'appearance_performance_status': self.appearance_performance_status, | |
| 135 | 150 | 'user_id': self.user_id, | 
| 136 | 151 | 'name': self.name, | 
| 137 | 152 | 'phone': self.phone, | 
| @@ -159,14 +174,26 @@ class TenancyShotRequestInfo(BaseModelMixin): | ||
| 159 | 174 | @property | 
| 160 | 175 | def admindata(self): | 
| 161 | 176 | try: | 
| 162 | - shot = TenancyShotInfo.objects.get(shot_id=self.shot_id) | |
| 177 | + admin = AdministratorInfo.objects.get(admin_=self.admin) | |
| 178 | + except AdministratorInfo.DoesNotExist: | |
| 179 | + admin = None | |
| 180 | + | |
| 181 | + try: | |
| 182 | + shot = TenancyShotInfo.objects.get(shot_id=self.shot_id, status=True) | |
| 163 | 183 | except TenancyShotInfo.DoesNotExist: | 
| 164 | 184 | shot = None | 
| 185 | + | |
| 186 | + try: | |
| 187 | + model = ModelInfo.objects.get(model_id=self.model_id, status=True) | |
| 188 | + except ModelInfo.DoesNotExist: | |
| 189 | + model = None | |
| 190 | + | |
| 165 | 191 |          return { | 
| 166 | 192 | 'req_id': self.request_id, | 
| 167 | 193 | 'request_id': self.request_id, | 
| 168 | 194 | 'shot_id': self.shot_id, | 
| 169 | 195 |              'shot_info': shot.data if shot else {}, | 
| 196 | + 'model_info': model.admindata, | |
| 170 | 197 | 'user_id': self.user_id, | 
| 171 | 198 | 'name': self.name, | 
| 172 | 199 | 'phone': self.phone, | 
| @@ -189,4 +216,11 @@ class TenancyShotRequestInfo(BaseModelMixin): | ||
| 189 | 216 | 'request_status': self.request_status, | 
| 190 | 217 |              'request_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.request_status_at.items()}, | 
| 191 | 218 | 'created_at': tc.local_string(utc_dt=self.created_at), | 
| 219 | + 'admin_id': self.admin_id, | |
| 220 | +            'admin_data': admin.admindata if admin else {}, | |
| 221 | + 'front_cap_status': self.front_cap_status, | |
| 222 | + 'rear_cap_status': self.rear_cap_status, | |
| 223 | + 'lens_hood_status': self.lens_hood_status, | |
| 224 | + 'tripod_ring_status': self.tripod_ring_status, | |
| 225 | + 'appearance_performance_status': self.appearance_performance_status, | |
| 192 | 226 | } |