seimin 11 kuukautta sitten
vanhempi
commit
fca84af681

+ 15 - 0
http/api.js

@@ -167,3 +167,18 @@ export function api_listAttachment(type, id){
167 167
 export function api_incidentLog(data){
168 168
   return post("/simple/data/fetchDataList/incidentLog", data);
169 169
 }
170
+
171
+/**
172
+ * 获取报修科室列表
173
+ */
174
+export function api_department(data){
175
+  return post("/user/data/fetchDataList/department", data);
176
+}
177
+
178
+/**
179
+ * 获取地点列表
180
+ */
181
+export function api_place(data){
182
+  return post("/user/data/fetchDataList/place", data);
183
+}
184
+

+ 25 - 0
pages.json

@@ -134,6 +134,31 @@
134 134
           "titleNView": false
135 135
         }
136 136
       }
137
+    },
138
+    {
139
+      "path": "pages/searchDept/searchDept",
140
+      "style": {
141
+        "h5": {
142
+          "titleNView": false
143
+        },
144
+        "enablePullDownRefresh": true
145
+      }
146
+    },
147
+    {
148
+      "path" : "pages/searchArea/searchArea",
149
+      "style" : 
150
+      {
151
+        "navigationBarTitleText" : "",
152
+        "enablePullDownRefresh" : false
153
+      }
154
+    },
155
+    {
156
+      "path" : "pages/searchPlace/searchPlace",
157
+      "style" : 
158
+      {
159
+        "navigationBarTitleText" : "",
160
+        "enablePullDownRefresh" : false
161
+      }
137 162
     }
138 163
   ],
139 164
   "globalStyle": {

+ 295 - 300
pages/buildIncident/buildIncident.vue

@@ -3,16 +3,72 @@
3 3
     <scroll-view scroll-y class="body">
4 4
       <view class="form_item">
5 5
         <view class="title select"><text class="required newicon newicon-bitian"></text>院区:</view>
6
-        <uni-data-select class="value" v-model="dataInfo.groupId" :localdata="dataInfo.groupList" :clear="false" placeholder="请选择院区" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}"></uni-data-select>
6
+        <uni-data-select class="value" v-model="incidentData.branch" :localdata="dataInfo.branchList" :clear="false" placeholder="请选择院区" :class="{formRed: isSubmit && !incidentData.branch}" @change="changeBranch"></uni-data-select>
7 7
       </view>
8 8
       <view class="form_item">
9
-        <view class="title select"><text class="required newicon newicon-bitian"></text>报修科室:</view>
10
-        <uni-data-select class="value" v-model="dataInfo.groupId" :localdata="dataInfo.groupList" :clear="false" placeholder="请选择报修科室" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}"></uni-data-select>
9
+        <view class="title"><text class="required newicon newicon-bitian"></text>报修科室:</view>
10
+        <view class="value category" @click="selectDepartment">
11
+          <text class="categoryName ellipsis-multiline">{{incidentData.department ? incidentData.department.dept : ''}}</text>
12
+          <text class="newicon newicon-weibiaoti2010104"></text>
13
+        </view>
11 14
       </view>
12 15
       <view class="form_item">
13 16
         <view class="title select"><text class="required newicon newicon-bitian transparent"></text>报修人:</view>
14
-        <uni-data-select class="value" v-model="dataInfo.groupId" :localdata="dataInfo.groupList" :clear="false" placeholder="请选择报修人" @change="changeGroup" :class="{formRed: isSubmit && !dataInfo.groupId}"></uni-data-select>
17
+        <uni-data-select readonly class="value" v-model="incidentData.requester" :localdata="dataInfo.requesterList" placeholder="请选择报修人"></uni-data-select>
15 18
       </view>
19
+      <view class="form_item">
20
+        <view class="title select"><text class="required newicon newicon-bitian transparent"></text>联系人:</view>
21
+        <uni-easyinput class="value" v-model="incidentData.contacts" placeholder="请输入联系人" />
22
+      </view>
23
+      <view class="form_item">
24
+        <view class="title select"><text class="required newicon newicon-bitian"></text>联系电话:</view>
25
+        <uni-easyinput class="value" v-model="incidentData.contactsInformation" placeholder="请输入联系电话" :class="{formRed: isSubmit && !incidentData.contactsInformation.trim()}" />
26
+      </view>
27
+      <view class="form_item">
28
+        <view class="title"><text class="required newicon newicon-bitian transparent"></text>楼栋楼层:</view>
29
+        <view class="value category" @click="selectAreaPlace">
30
+          <text class="categoryName ellipsis-multiline">{{incidentData.place ? incidentData.place.area.area + ' ' + incidentData.place.place : ''}}</text>
31
+          <text class="newicon newicon-weibiaoti2010104"></text>
32
+        </view>
33
+      </view>
34
+      <view class="form_item">
35
+        <view class="title select"><text class="required newicon newicon-bitian transparent"></text>详细地址:</view>
36
+        <uni-easyinput class="value" v-model="incidentData.houseNumber" placeholder="请输入详细地址" />
37
+      </view>
38
+      <view class="form_item">
39
+        <view class="title"><text class="required newicon newicon-bitian"></text>故障现象:</view>
40
+        <view class="value category" @click="selectCategory">
41
+          <text class="categoryName ellipsis-multiline">{{incidentData.category ? incidentData.category.mutiCategory : ''}}</text>
42
+          <text class="newicon newicon-weibiaoti2010104"></text>
43
+        </view>
44
+      </view>
45
+      <view class="form_item">
46
+        <view class="title select"><text class="required newicon newicon-bitian transparent"></text>故障来源:</view>
47
+        <uni-data-select readonly class="value" v-model="incidentData.source" :localdata="dataInfo.sourceList" placeholder="请选择故障来源"></uni-data-select>
48
+      </view>
49
+      <view class="form_item">
50
+        <view class="title select"><text class="required newicon newicon-bitian transparent"></text>优先级:</view>
51
+        <uni-data-select placement="top" readonly class="value" v-model="incidentData.priority" :localdata="dataInfo.priorityList" placeholder="请选择优先级"></uni-data-select>
52
+      </view>
53
+      <view class="form_item column">
54
+        <view class="title select"><text class="required newicon newicon-bitian"></text>故障描述:</view>
55
+        <uni-easyinput class="value" type="textarea" v-model="incidentData.description" placeholder="请输入故障描述" :class="{formRed: isSubmit && !incidentData.description.trim()}" />
56
+      </view>
57
+      <view class="form_item_column">
58
+        <view class="form_item">
59
+          <view class="title"><text class="required newicon newicon-bitian transparent"></text>处理图片:</view>
60
+          <view class="value">
61
+            <uni-file-picker ref="handlerImgRef" v-model="incidentData.handlerImgList" limit="3" @success="handlerImgSuccess" @fail="handlerImgFail" @select="handlerImgSelect" @delete="handlerImgDelete"></uni-file-picker>
62
+          </view>
63
+        </view>
64
+        <view class="form_item">
65
+          <view class="title transparent"><text class="required newicon newicon-bitian transparent"></text>处理图片:</view>
66
+          <view class="value">
67
+            <text class="imgTips ellipsis">(支持JPG/PNG格式图片,单张大小10M以内)</text>
68
+          </view>
69
+        </view>
70
+      </view>
71
+      
16 72
     </scroll-view>
17 73
     <view class="foot_common_btns">
18 74
       <button @click="goBack" type="default" class="cancelButton btn">返回</button>
@@ -24,82 +80,136 @@
24 80
 <script setup>
25 81
   import { ref, reactive } from 'vue'
26 82
   import { onLoad } from '@dcloudio/uni-app'
27
-  import { api_group, api_incidentDetail, api_user, api_incidentTask, api_branch, api_dutyDepartment } from "@/http/api.js"
83
+  import { api_user, api_branch, api_getDictionary, api_incidentTask } from "@/http/api.js"
28 84
   import { defaultColor } from '@/static/js/theme.js'
29 85
   import { useSetTitle } from '@/share/useSetTitle.js'
30
-  import { useMakePhoneCall } from '@/share/useMakePhoneCall.js'
31 86
   import { useGoBack } from '@/share/useGoBack.js'
32 87
   import { useLoginUserStore } from '@/stores/loginUser'
88
+  import { useIncidentBuildStore } from '@/stores/incidentBuild'
89
+  import { useUploadFile } from '@/share/useUploadFile.js'
33 90
   
34 91
   useSetTitle();
35 92
   const loginUserStore = useLoginUserStore();
36
-  const { makePhoneCall }  = useMakePhoneCall();
93
+  const incidentBuildStore = useIncidentBuildStore();
94
+  const { uploadFile }  = useUploadFile();
37 95
   const { goBack }  = useGoBack();
38 96
   
39 97
   // 主题颜色
40 98
   const primaryColor = ref(defaultColor)
41 99
   
100
+  // 工单对象
101
+  const incidentData = reactive({
102
+    "deleteFlag": 0,
103
+    "duty": undefined,
104
+    "department": undefined,
105
+    "contactsInformation": '',
106
+    "contacts": '',
107
+    "branch": undefined,
108
+    "area": undefined,
109
+    "place": undefined,
110
+    "houseNumber": '',
111
+    "category": undefined,
112
+    "priority": undefined,
113
+    "source": undefined,
114
+    "title": '',
115
+    "description": '',
116
+    "repairType": undefined,
117
+    "requester":undefined,
118
+    "acceptUser": loginUserStore.loginUser.user,
119
+    handlerImgList: [],//处理图片列表
120
+  })
121
+  
122
+  // 处理图片
123
+  const handlerImgRef = ref(null)
124
+  
42 125
   // 数据
43 126
   const dataInfo = reactive({
44
-    incidentId: undefined,//事件ID
45
-    incidentData: {},//事件对象
46
-    groupList: [], //工作组列表
47
-    groupId: undefined, //工作组ID
48
-    userList: [], //用户列表
49
-    userId: undefined, //用户ID
50 127
     branchList: [], //院区列表
51
-    branchId: undefined, //院区ID
52
-    dutyList: [], //责任科室列表
53
-    dutyId: undefined, //责任科室ID
54
-    isAssignUser: 1, //工作组是否转派到人
55
-    isAssignUserList: [
56
-      { text: '是', value: 1 },
57
-      { text: '否', value: 0 },
58
-    ], //工作组是否转派到人选项
59
-    reassignRemark: '',//退回原因
128
+    requesterList: [], //报修人列表
129
+    sourceList: [], //故障来源列表
130
+    priorityList: [], //优先级列表
60 131
   })
61 132
   
62 133
   // 是否提交
63 134
   const isSubmit = ref(false)
64 135
   
65
-  // 重置
66
-  function reset(){
67
-    dataInfo.branchId = undefined;
68
-    dataInfo.branchList = [];
69
-    
70
-    dataInfo.dutyId = undefined;
71
-    dataInfo.dutyList = [];
72
-    
73
-    dataInfo.groupId = undefined;
74
-    dataInfo.groupList = [];
75
-    
76
-    dataInfo.userId = undefined;
77
-    dataInfo.userList = [];
78
-    
79
-    dataInfo.isAssignUser = 1;
136
+  // 上传处理图片成功
137
+  function handlerImgSuccess(e){
138
+    dataInfo.handlerImgList.forEach(v => {
139
+      v.url = v.path;
140
+    })
141
+    console.log(dataInfo.handlerImgList);
142
+    // let handlerOrder$ = handlerOrder();
143
+    // let requestList = [handlerOrder$];
144
+    // dataInfo.handlerImgList.forEach(v => {
145
+    //   let handlerOrderImg$ = handlerOrderImg(v);
146
+    //   requestList.push(handlerOrderImg$);
147
+    // })
80 148
     
81
-    dataInfo.reassignRemark = '';
149
+    // Promise.all(requestList).then(resList => {
150
+    //   uni.hideLoading();
151
+    //   console.log(resList);
152
+    //   if(resList[0].state == 200){
153
+    //     uni.showToast({
154
+    //     	icon: 'none',
155
+    //       title: '处理成功',
156
+    //       mask: true,
157
+    //     });
158
+    //     setTimeout(() => {
159
+    //       uni.reLaunch({
160
+    //         url: '/pages/incidentList/incidentList',
161
+    //       })
162
+    //     }, 1500)
163
+    //   }else{
164
+    //     uni.showToast({
165
+    //       icon: 'none',
166
+    //       title: resList[0].msg || '请求数据失败!'
167
+    //     });
168
+    //   }
169
+    // })
82 170
   }
83 171
   
84
-  // 获取事件详情
85
-  function getIncidentDetail(){
86
-    uni.showLoading({
87
-      title: "加载中",
88
-      mask: true,
89
-    });
90
-
91
-    api_incidentDetail(dataInfo.incidentId).then(res => {
92
-      uni.hideLoading();
93
-      if(res.status == 200){
94
-        dataInfo.incidentData = res.data || {};
95
-        
96
-        initForm()
97
-      }else{
98
-        uni.showToast({
99
-          icon: 'none',
100
-          title: res.msg || '请求数据失败!'
101
-        });
102
-      }
172
+  // 上传处理图片失败
173
+  function handlerImgFail(e){
174
+    dataInfo.handlerImgList.forEach(v => {
175
+      v.url = v.path;
176
+    })
177
+    console.log(dataInfo.handlerImgList);
178
+  }
179
+  
180
+  // 选择上传图片
181
+  function handlerImgSelect(e){
182
+    dataInfo.handlerImgList = dataInfo.handlerImgList.concat(e.tempFiles);
183
+    console.log(dataInfo.handlerImgList);
184
+  }
185
+  
186
+  // 删除上传图片
187
+  function handlerImgDelete(e){
188
+    dataInfo.handlerImgList = dataInfo.handlerImgList.filter(v => e.tempFile.uuid != v.uuid);
189
+    console.log(dataInfo.handlerImgList);
190
+  }
191
+  
192
+  // 选择故障现象
193
+  function selectCategory(){
194
+    incidentBuildStore.setIncidentBuildData(incidentData, 'buildIncident');
195
+    uni.navigateTo({
196
+      url: `/pages/categoryOne/categoryOne`
197
+    })
198
+  }
199
+  
200
+  // 选择楼栋楼层
201
+  function selectAreaPlace(){
202
+    incidentBuildStore.setIncidentBuildData(incidentData, 'buildIncident');
203
+    uni.navigateTo({
204
+      url: `/pages/searchArea/searchArea`
205
+    })
206
+  }
207
+  
208
+  // 跳转到搜索报修科室
209
+  function selectDepartment(){
210
+    incidentBuildStore.setIncidentBuildData(incidentData, 'buildIncident');
211
+    uni.navigateTo({
212
+      url: `/pages/searchDept/searchDept`
103 213
     })
104 214
   }
105 215
   
@@ -124,15 +234,12 @@
124 234
         
125 235
         if(loginUserStore.loginUser.user.duty){
126 236
           // 当前的所属责任科室
127
-          dataInfo.branchId = loginUserStore.loginUser.user.duty.branch;
128
-          changeBranch();
129
-          
130
-          dataInfo.dutyId = loginUserStore.loginUser.user.duty.id;
131
-          changeDuty();
237
+          incidentData.branch = loginUserStore.loginUser.user.duty.branch;
132 238
         }else if(loginUserStore.loginUser.user.branch){
133 239
           // 当前的所属院区
134
-          dataInfo.branchId = loginUserStore.loginUser.user.branch.id;
240
+          incidentData.branch = loginUserStore.loginUser.user.branch.id;
135 241
         }
242
+        
136 243
       }else{
137 244
         uni.showToast({
138 245
           icon: 'none',
@@ -142,8 +249,8 @@
142 249
     })
143 250
   }
144 251
   
145
-  // 获取责任科室列表
146
-  function getDutys(){
252
+  // 获取报修人列表
253
+  function getRequesters(){
147 254
     uni.showLoading({
148 255
       title: "加载中",
149 256
       mask: true,
@@ -151,18 +258,19 @@
151 258
     let postData = {
152 259
       "idx": 0,
153 260
       "sum": 9999,
154
-      "dutyDepartment": {
155
-        "branch": dataInfo.branchId,
261
+      "user": {
262
+        "engineer": undefined,
156 263
       }
157 264
     };
158
-    api_dutyDepartment(postData).then(res => {
265
+    api_user(postData).then(res => {
159 266
       uni.hideLoading();
160 267
       if(res.status == 200){
161 268
         res.list = res.list || [];
162
-        dataInfo.dutyList = res.list.map(v => ({
163
-          text: v.dept,
269
+        dataInfo.requesterList = res.list.map(v => ({
270
+          text: v.name,
164 271
           value: v.id,
165 272
         }));
273
+        
166 274
       }else{
167 275
         uni.showToast({
168 276
           icon: 'none',
@@ -172,183 +280,74 @@
172 280
     })
173 281
   }
174 282
   
175
-  // 获取工作组列表
176
-  function getGroups(){
283
+  // 获取故障来源列表
284
+  function getSources(){
177 285
     uni.showLoading({
178 286
       title: "加载中",
179 287
       mask: true,
180 288
     });
181
-    
182
-    let duty = undefined;
183
-    
184 289
     let postData = {
185
-      "idx": 0,
186
-      "sum": 9999,
187
-      "group": {
188
-          "duty": duty,
189
-          "selectType": "nouser"
190
-      }
290
+      "key": 'incident_source',
291
+      "type": "list",
191 292
     };
192
-    api_group(postData).then(res => {
293
+    api_getDictionary(postData).then(res => {
193 294
       uni.hideLoading();
194
-      if(res.status == 200){
195
-        res.list = res.list || [];
196
-        dataInfo.groupList = res.list.map(v => ({
197
-          text: v.groupName,
198
-          value: v.id,
199
-        }));
200
-      }else{
201
-        uni.showToast({
202
-          icon: 'none',
203
-          title: res.msg || '请求数据失败!'
204
-        });
205
-      }
295
+      res = res || [];
296
+      dataInfo.sourceList = res.map(v => ({
297
+        text: v.name,
298
+        value: v.id,
299
+      }));
206 300
     })
207 301
   }
208 302
   
209
-  // 获取用户列表
210
-  function getUsers(){
303
+  // 获取优先级列表
304
+  function getPrioritys(){
211 305
     uni.showLoading({
212 306
       title: "加载中",
213 307
       mask: true,
214 308
     });
215 309
     let postData = {
216
-      "idx": 0,
217
-      "sum": 9999,
218
-      "user": {
219
-          "groupdata":{
220
-            "id": dataInfo.groupId,
221
-          },
222
-          "roledata": {
223
-              "rolecode": "first-line support"
224
-          },
225
-          "roledata2": {
226
-              "rolecode": "second-line support"
227
-          },
228
-          "selectType": "1",
229
-          "selectDetails": 1,
230
-          "simple": true,
231
-          "engineer": 1
232
-      }
310
+      "key": 'incident_priority',
311
+      "type": "list",
233 312
     };
234
-    api_user(postData).then(res => {
313
+    api_getDictionary(postData).then(res => {
235 314
       uni.hideLoading();
236
-      if(res.status == 200){
237
-        res.list = res.list || [];
238
-        dataInfo.userList = res.list.map(v => ({
239
-          text: v.name,
240
-          value: v.id,
241
-        }));
242
-      }else{
243
-        uni.showToast({
244
-          icon: 'none',
245
-          title: res.msg || '请求数据失败!'
246
-        });
247
-      }
315
+      res = res || [];
316
+      dataInfo.priorityList = res.map(v => ({
317
+        text: v.name,
318
+        value: v.id,
319
+      }));
248 320
     })
249 321
   }
250 322
   
251 323
   // 选择院区
252
-  function changeBranch(){
253
-    dataInfo.dutyId = undefined;
254
-    dataInfo.dutyList = [];
255
-    
256
-    dataInfo.groupId = undefined;
257
-    dataInfo.groupList = [];
258
-    
259
-    dataInfo.userId = undefined;
260
-    dataInfo.userList = [];
261
-    getDutys();
262
-  }
324
+  function changeBranch(){}
263 325
   
264
-  // 选择责任科室
265
-  function changeDuty(){
266
-    dataInfo.groupId = undefined;
267
-    dataInfo.groupList = [];
326
+  // 处理提交事件
327
+  function handlerOrder(){
328
+    let postData = {
329
+      incident: dataInfo.incidentData,
330
+    }
268 331
     
269
-    dataInfo.userId = undefined;
270
-    dataInfo.userList = [];
271
-    getGroups();
272
-  }
273
-  
274
-  // 选择工作组
275
-  function changeGroup(){
276
-    dataInfo.userId = undefined;
277
-    dataInfo.userList = [];
278
-    getUsers();
332
+    postData.incident.handleDescription = dataInfo.handleDescription;
333
+    postData.incident.handleCategory = {id: dataInfo.handleCategory};
334
+    postData.incident.closecode = {id: dataInfo.closecode};
335
+    postData.incident.category = dataInfo.category;
336
+    postData.incident.synergetic = dataInfo.synergetic;
337
+    
338
+    return api_incidentTask('accept', postData);
279 339
   }
280 340
   
281
-  // 选择是否转派到人
282
-  function changeIsAssignUser(){
283
-    dataInfo.userId = undefined;
341
+  // 处理图片
342
+  function handlerOrderImg(imgObj){
343
+    return uploadFile(imgObj, 'incident', dataInfo.incidentId)
284 344
   }
285 345
   
286 346
   // 提交
287 347
   function submit(){
288 348
     isSubmit.value = true;
289
-    
290
-  }
291
-  
292
-  // 转派提交
293
-  function submitRedeploy(){
294
-    if(!dataInfo.groupId){
295
-      uni.showToast({
296
-      	icon: 'none',
297
-        title: '请选择工作组'
298
-      });
299
-      return;
300
-    }
301
-    
302
-    if(dataInfo.isAssignUser == 1 && !dataInfo.userId){
303
-      uni.showToast({
304
-      	icon: 'none',
305
-        title: '请选择指派对象'
306
-      });
307
-      return;
308
-    }
309
-    
310
-    uni.showLoading({
311
-      title: "加载中",
312
-      mask: true,
313
-    });
314
-    
315
-    let postData = {
316
-      incident: dataInfo.incidentData,
317
-    }
318
-    
319
-    if(dataInfo.userId){
320
-      // 派人
321
-      postData.incident.assignee = dataInfo.userId;
322
-    } else {
323
-      // 派组
324
-      postData.incident.candidateGroups = dataInfo.groupId;
325
-    }
326
-    
327
-    // api_incidentTask('' postData).then(res => {
328
-    //   uni.hideLoading();
329
-    //   if(res.state == 200){
330
-    //     uni.showToast({
331
-    //     	icon: 'none',
332
-    //       title: '转派成功',
333
-    //       mask: true,
334
-    //     });
335
-    //     setTimeout(() => {
336
-    //       uni.reLaunch({
337
-    //         url: '/pages/incidentList/incidentList',
338
-    //       })
339
-    //     }, 1500)
340
-    //   }else{
341
-    //     uni.showToast({
342
-    //       icon: 'none',
343
-    //       title: res.msg || '请求数据失败!'
344
-    //     });
345
-    //   }
346
-    // })
347
-  }
348
-  
349
-  // 指派提交
350
-  function submitAssign(){
351
-    if(!dataInfo.branchId){
349
+    console.log(dataInfo);
350
+    if(!dataInfo.branch){
352 351
       uni.showToast({
353 352
       	icon: 'none',
354 353
         title: '请选择院区'
@@ -356,115 +355,89 @@
356 355
       return;
357 356
     }
358 357
     
359
-    if(!dataInfo.dutyId){
358
+    if(!dataInfo.department){
360 359
       uni.showToast({
361 360
       	icon: 'none',
362
-        title: '请选择责任科室'
361
+        title: '请选择报修科室'
363 362
       });
364 363
       return;
365 364
     }
366 365
     
367
-    if(!dataInfo.groupId){
366
+    if(!dataInfo.contactsInformation.trim()){
368 367
       uni.showToast({
369 368
       	icon: 'none',
370
-        title: '请选择工作组'
369
+        title: '请填写联系电话'
371 370
       });
372 371
       return;
373 372
     }
374 373
     
375
-    if(dataInfo.isAssignUser == 1 && !dataInfo.userId){
374
+    if(!dataInfo.category){
376 375
       uni.showToast({
377 376
       	icon: 'none',
378
-        title: '请选择指派对象'
377
+        title: '请选择故障现象'
379 378
       });
380 379
       return;
381 380
     }
382 381
     
383
-    uni.showLoading({
384
-      title: "加载中",
385
-      mask: true,
386
-    });
387
-    
388
-    let postData = {
389
-      incident: dataInfo.incidentData,
390
-    }
391
-    
392
-    if(dataInfo.userId){
393
-      // 派人
394
-      postData.incident.assignee = dataInfo.userId;
395
-    } else {
396
-      // 派组
397
-      postData.incident.candidateGroups = dataInfo.groupId;
398
-    }
399
-    
400
-    // api_incidentTask('', postData).then(res => {
401
-    //   uni.hideLoading();
402
-    //   if(res.state == 200){
403
-    //     uni.showToast({
404
-    //     	icon: 'none',
405
-    //       title: '指派成功',
406
-    //       mask: true,
407
-    //     });
408
-    //     setTimeout(() => {
409
-    //       uni.reLaunch({
410
-    //         url: '/pages/incidentList/incidentList',
411
-    //       })
412
-    //     }, 1500)
413
-    //   }else{
414
-    //     uni.showToast({
415
-    //       icon: 'none',
416
-    //       title: res.msg || '请求数据失败!'
417
-    //     });
418
-    //   }
419
-    // })
420
-  }
421
-  
422
-  // 退回提交
423
-  function submitReassign(){
424
-    if(!dataInfo.reassignRemark.trim()){
382
+    if(!dataInfo.handleDescription.trim()){
425 383
       uni.showToast({
426 384
       	icon: 'none',
427
-        title: '请填写退回原因'
385
+        title: '请填写故障描述'
428 386
       });
429 387
       return;
430 388
     }
389
+    console.log(dataInfo.handlerImgList)
390
+    incidentBuildStore.setIncidentBuildData(dataInfo, 'buildIncident');
431 391
     
432
-    uni.showLoading({
433
-      title: "加载中",
434
-      mask: true,
435
-    });
436
-    
437
-    let postData = {
438
-      incident: dataInfo.incidentData,
439
-    }
440
-    
441
-    postData.incident.reassignRemark = dataInfo.reassignRemark;
442
-    
443
-    // api_incidentTask('', postData).then(res => {
444
-    //   uni.hideLoading();
445
-    //   if(res.state == 200){
446
-    //     uni.showToast({
447
-    //     	icon: 'none',
448
-    //       title: '退回成功',
449
-    //       mask: true,
450
-    //     });
451
-    //     setTimeout(() => {
452
-    //       uni.reLaunch({
453
-    //         url: '/pages/incidentList/incidentList',
454
-    //       })
455
-    //     }, 1500)
456
-    //   }else{
457
-    //     uni.showToast({
458
-    //       icon: 'none',
459
-    //       title: res.msg || '请求数据失败!'
460
-    //     });
461
-    //   }
462
-    // })
392
+    // uni.showLoading({
393
+    //   title: "加载中",
394
+    //   mask: true,
395
+    // });
396
+    // if(dataInfo.handlerImgList.length){
397
+    //   // 有图片
398
+    //   handlerImgRef.value.upload();
399
+    // }else{
400
+    //   // 没有图片
401
+    //   let handlerOrder$ = handlerOrder();
402
+    //   let requestList = [handlerOrder$];
403
+    //   Promise.all(requestList).then(resList => {
404
+    //     uni.hideLoading();
405
+    //     console.log(resList);
406
+    //     if(resList[0].state == 200){
407
+    //       uni.showToast({
408
+    //       	icon: 'none',
409
+    //         title: '处理成功',
410
+    //         mask: true,
411
+    //       });
412
+    //       setTimeout(() => {
413
+    //         uni.reLaunch({
414
+    //           url: '/pages/incidentList/incidentList',
415
+    //         })
416
+    //       }, 1500)
417
+    //     }else{
418
+    //       uni.showToast({
419
+    //         icon: 'none',
420
+    //         title: resList[0].msg || '请求数据失败!'
421
+    //       });
422
+    //     }
423
+    //   })
424
+    // }
463 425
   }
464 426
   
465 427
   onLoad((option) => {
466
-    dataInfo.incidentId = option.incidentId;
467
-    getIncidentDetail();
428
+    if(incidentBuildStore.incidentBuild.data){
429
+      Object.assign(incidentData, incidentBuildStore.incidentBuild.data);
430
+      incidentBuildStore.clearIncidentBuildData();
431
+      
432
+      // 修改报修科室,则回显楼栋,楼层,详细地址,联系电话
433
+      incidentData.place = incidentData.department.place || undefined;
434
+      incidentData.houseNumber = incidentData.department.address || '';
435
+      incidentData.contactsInformation = incidentData.department.phone || '';
436
+    }
437
+    getBranchs();
438
+    getRequesters();
439
+    getSources();
440
+    getPrioritys();
468 441
   })
469 442
 </script>
470 443
 
@@ -475,7 +448,6 @@
475 448
   flex-direction: column;
476 449
   justify-content: space-between;
477 450
   .body{
478
-    margin-top: 88rpx;
479 451
     padding: 0 24rpx;
480 452
     box-sizing: border-box;
481 453
     flex: 1;
@@ -511,10 +483,33 @@
511 483
         display: flex;
512 484
         align-items: center;
513 485
         margin-right: 12rpx;
486
+        flex-shrink: 0;
514 487
         &.select{
515 488
           width: calc(5em + 20rpx);
516 489
         }
517 490
       }
491
+      .value{
492
+        width: 100%;
493
+        &.category{
494
+          width: 100%;
495
+          display: flex;
496
+          justify-content: space-between;
497
+          align-items: center;
498
+          .categoryName{
499
+            font-size: 26rpx;
500
+            color: #555;
501
+            flex: 1;
502
+          }
503
+          .newicon-weibiaoti2010104{
504
+            color: $uni-primary;
505
+            margin-left: 24rpx;
506
+          }
507
+        }
508
+        .imgTips{
509
+          color: #909399;
510
+          font-size: 22rpx;
511
+        }
512
+      }
518 513
     }
519 514
   }
520 515
 }

+ 19 - 5
pages/categoryThree/categoryThree.vue

@@ -25,11 +25,13 @@
25 25
   import { useSetTitle } from '@/share/useSetTitle.js'
26 26
   import { useLoginUserStore } from '@/stores/loginUser'
27 27
   import { useHandlerStore } from '@/stores/handler'
28
+  import { useIncidentBuildStore } from '@/stores/incidentBuild'
28 29
   import { useGoBack } from '@/share/useGoBack.js'
29 30
   
30 31
   useSetTitle();
31 32
   const loginUserStore = useLoginUserStore();
32 33
   const handlerStore = useHandlerStore();
34
+  const incidentBuildStore = useIncidentBuildStore();
33 35
   const { goBack }  = useGoBack();
34 36
   
35 37
   // 主题颜色
@@ -64,15 +66,27 @@
64 66
       return;
65 67
     }
66 68
     dataInfo.paramData.category = dataInfo.categoryThreeObj;
67
-    handlerStore.setHandlerData(dataInfo.paramData);
68
-    uni.navigateTo({
69
-      url: `/pages/handler/handler?incidentId=${dataInfo.incidentId}`,
70
-    })
69
+    if(handlerStore.handler.type){
70
+      handlerStore.setHandlerData(dataInfo.paramData, handlerStore.handler.type);
71
+      uni.navigateTo({
72
+        url: `/pages/${handlerStore.handler.type}/${handlerStore.handler.type}?incidentId=${dataInfo.incidentId}`,
73
+      })
74
+    } else if(incidentBuildStore.incidentBuild.type){
75
+      incidentBuildStore.setIncidentBuildData(dataInfo.paramData, incidentBuildStore.incidentBuild.type);
76
+      uni.navigateTo({
77
+        url: `/pages/${incidentBuildStore.incidentBuild.type}/${incidentBuildStore.incidentBuild.type}?incidentId=${dataInfo.incidentId}`,
78
+      })
79
+    }
80
+    
71 81
   }
72 82
   
73 83
   // 获取传递的数据
74 84
   function getParamData(){
75
-    dataInfo.paramData = handlerStore.handler.data || {};
85
+    if(handlerStore.handler.type){
86
+      dataInfo.paramData = handlerStore.handler.data || {};
87
+    } else if(incidentBuildStore.incidentBuild.type){
88
+      dataInfo.paramData = incidentBuildStore.incidentBuild.data || {};
89
+    }
76 90
     dataInfo.categoryThree = dataInfo.paramData.category ? dataInfo.paramData.category.id : undefined;
77 91
     dataInfo.categoryThreeObj =  dataInfo.paramData.category || {};
78 92
     getList(0);

+ 3 - 3
pages/handler/handler.vue

@@ -143,7 +143,7 @@
143 143
   import NumberModal from '@/components/NumberModal.vue';
144 144
   import { onLoad } from '@dcloudio/uni-app'
145 145
   import { generateNumberArray } from '@/utils/index.js'
146
-  import { api_group, api_incidentDetail, api_user, api_incidentTask, api_branch, api_dutyDepartment, api_getDictionary, api_querySummaryDoc, api_addSummaryDoc, api_uploadAttachment } from "@/http/api.js"
146
+  import { api_group, api_incidentDetail, api_user, api_incidentTask, api_branch, api_dutyDepartment, api_getDictionary, api_querySummaryDoc, api_addSummaryDoc } from "@/http/api.js"
147 147
   import { defaultColor } from '@/static/js/theme.js'
148 148
   import { useSetTitle } from '@/share/useSetTitle.js'
149 149
   import { useMakePhoneCall } from '@/share/useMakePhoneCall.js'
@@ -265,7 +265,7 @@
265 265
   
266 266
   // 添加协同人员
267 267
   function synergeticAdd(){
268
-    handlerStore.setHandlerData(dataInfo);
268
+    handlerStore.setHandlerData(dataInfo, 'handler');
269 269
     uni.navigateTo({
270 270
       url: `/pages/synergeticAdd/synergeticAdd?incidentId=${dataInfo.incidentId}`
271 271
     })
@@ -273,7 +273,7 @@
273 273
   
274 274
   // 选择故障现象
275 275
   function selectCategory(){
276
-    handlerStore.setHandlerData(dataInfo);
276
+    handlerStore.setHandlerData(dataInfo, 'handler');
277 277
     uni.navigateTo({
278 278
       url: `/pages/categoryOne/categoryOne?incidentId=${dataInfo.incidentId}`
279 279
     })

+ 163 - 0
pages/searchArea/searchArea.vue

@@ -0,0 +1,163 @@
1
+<template>
2
+  <view class="categoryOne">
3
+    <view class="head">
4
+      请选择楼栋
5
+    </view>
6
+    <view class="body" v-if="dataInfo.list.length">
7
+      <view class="body_item ellipsis" v-for="data in dataInfo.list" :key="data.id" @click="toPlace(data)">
8
+        {{data.area}}
9
+      </view>
10
+    </view>
11
+    <view class="zanwu" v-else>
12
+      <text class="newicon newicon-zanwu"></text>
13
+    </view>
14
+    <view class="foot_common_btns">
15
+      <button @click="goBack" type="default" class="primaryButton btn">返回</button>
16
+    </view>
17
+  </view>
18
+</template>
19
+
20
+<script setup>
21
+  import { ref, reactive} from 'vue'
22
+  import { onLoad, onPullDownRefresh, onReachBottom } from '@dcloudio/uni-app'
23
+  import { api_area } from "@/http/api.js"
24
+  import { defaultColor } from '@/static/js/theme.js'
25
+  import { useSetTitle } from '@/share/useSetTitle.js'
26
+  import { useLoginUserStore } from '@/stores/loginUser'
27
+  import { useIncidentBuildStore } from '@/stores/incidentBuild'
28
+  import { useGoBack } from '@/share/useGoBack.js'
29
+  
30
+  useSetTitle();
31
+  const loginUserStore = useLoginUserStore();
32
+  const incidentBuildStore = useIncidentBuildStore();
33
+  const { goBack }  = useGoBack();
34
+  
35
+  // 主题颜色
36
+  const primaryColor = ref(defaultColor)
37
+  
38
+  // 数据
39
+  const dataInfo = reactive({
40
+    list: [],//列表
41
+    idx: 0,//页码
42
+    hasMore: true,//是否有更多数据
43
+    incidentId: undefined,//事件ID
44
+  })
45
+  
46
+  // 跳转地点列表
47
+  function toPlace(data){
48
+    uni.navigateTo({
49
+      url: `/pages/searchPlace/searchPlace?incidentId=${dataInfo.incidentId}&parentId=${data.id}&parentName=${data.area}`
50
+    })
51
+  }
52
+  
53
+  // 获取列表信息
54
+  function getList(idx){
55
+    if(!incidentBuildStore.incidentBuild.data.branch){
56
+      dataInfo.list = [];
57
+      uni.stopPullDownRefresh();
58
+      dataInfo.hasMore = false;
59
+      return;
60
+    }
61
+    uni.showLoading({
62
+      title: "加载中",
63
+      mask: true,
64
+    });
65
+    
66
+    dataInfo.idx = idx === undefined ? dataInfo.idx : idx;
67
+    if(dataInfo.idx === 0){
68
+      dataInfo.list = [];
69
+    }
70
+
71
+    let postData = {
72
+      "idx": 0,
73
+      "sum": 9999,
74
+      "area": {
75
+        "branch": incidentBuildStore.incidentBuild.data.branch,
76
+        "searchType": "quickStart",
77
+      }
78
+    };
79
+    
80
+    api_area(postData).then(res => {
81
+      uni.hideLoading();
82
+      uni.stopPullDownRefresh();
83
+      if(res.status == 200){
84
+        let list = res.list || [];
85
+        if(list.length){
86
+          dataInfo.hasMore = true;
87
+          dataInfo.list = dataInfo.idx === 0 ? list : dataInfo.list.concat(list);
88
+        }else{
89
+          dataInfo.hasMore = false;
90
+        }
91
+      }else{
92
+        uni.showToast({
93
+          icon: 'none',
94
+          title: res.msg || '请求数据失败!'
95
+        });
96
+      }
97
+    })
98
+  }
99
+  
100
+  onLoad((option) => {
101
+    dataInfo.incidentId = option.incidentId;
102
+    getList(0);
103
+  })
104
+  
105
+  onPullDownRefresh(() => {
106
+    getList(0)
107
+  })
108
+  
109
+  onReachBottom(() => {
110
+    dataInfo.idx += 1;
111
+    if (dataInfo.hasMore) {
112
+      getList(); // 当触底时加载更多数据
113
+    }
114
+  })
115
+</script>
116
+
117
+<style lang="scss" scoped>
118
+.categoryOne{
119
+  display: flex;
120
+  flex-direction: column;
121
+  justify-content: space-between;
122
+  .head{
123
+    height: 88rpx;
124
+    display: flex;
125
+    align-items: center;
126
+    padding: 0 24rpx;
127
+    position: fixed;
128
+    z-index: 99;
129
+    width: 100%;
130
+    box-sizing: border-box;
131
+    background: #fff;
132
+    font-size: 26rpx;
133
+    color: $uni-primary;
134
+  }
135
+  .body{
136
+    border-top: 1rpx solid #DEDEDE;
137
+    margin-bottom: 140rpx;
138
+    margin-top: 88rpx;
139
+    font-size: 26rpx;
140
+    .body_item{
141
+      border-bottom: 1rpx solid #DEDEDE;
142
+      padding: 24rpx;
143
+    }
144
+  }
145
+  .zanwu{
146
+    margin-bottom: 140rpx;
147
+    margin-top: 88rpx;
148
+    display: flex;
149
+    justify-content: center;
150
+    .newicon-zanwu{
151
+      font-size: 256rpx;
152
+      color: #D6D6D6;
153
+      margin-top: 140rpx;
154
+    }
155
+  }
156
+  .foot_common_btns{
157
+    position: fixed;
158
+    left: 0;
159
+    bottom: 0;
160
+    background-color: #fff;
161
+  }
162
+}
163
+</style>

+ 172 - 0
pages/searchDept/searchDept.vue

@@ -0,0 +1,172 @@
1
+<template>
2
+  <view class="consumableList">
3
+    <view class="head">
4
+      <uni-search-bar v-model="dataInfo.keyWord" placeholder="请搜索报修科室" bgColor="#F8F8F8" @input="search" cancelButton="none" focus :radius="18" />
5
+    </view>
6
+    <view class="body" v-if="dataInfo.list.length">
7
+      <view class="body_item ellipsis" v-for="data in dataInfo.list" :key="data.id" @click="clickItem(data)">
8
+        {{data.dept}}
9
+      </view>
10
+    </view>
11
+    <view class="zanwu" v-else>
12
+      <text class="newicon newicon-zanwu"></text>
13
+    </view>
14
+    <view class="foot_common_btns">
15
+      <button @click="goBack" type="default" class="primaryButton btn">返回</button>
16
+    </view>
17
+  </view>
18
+</template>
19
+
20
+<script setup>
21
+  import { debounce } from 'lodash-es'
22
+  import { ref, reactive} from 'vue'
23
+  import { onLoad, onPullDownRefresh, onReachBottom } from '@dcloudio/uni-app'
24
+  import { api_department, api_incidentDetail, api_addSummaryDoc } from "@/http/api.js"
25
+  import { defaultColor } from '@/static/js/theme.js'
26
+  import { useSetTitle } from '@/share/useSetTitle.js'
27
+  import { useLoginUserStore } from '@/stores/loginUser'
28
+  import { useIncidentBuildStore } from '@/stores/incidentBuild'
29
+  import { useGoBack } from '@/share/useGoBack.js'
30
+  
31
+  useSetTitle();
32
+  const loginUserStore = useLoginUserStore();
33
+  const incidentBuildStore = useIncidentBuildStore();
34
+  const { goBack }  = useGoBack();
35
+  
36
+  // 主题颜色
37
+  const primaryColor = ref(defaultColor)
38
+  
39
+  // 数据
40
+  const dataInfo = reactive({
41
+    list: [],//工单列表
42
+    idx: 0,//页码
43
+    hasMore: true,//是否有更多数据
44
+    incidentData: {},//事件对象
45
+    keyWord: '',//搜索的关键词
46
+  })
47
+  
48
+  // 搜索
49
+  const search = debounce(getList.bind(null, 0), 500);
50
+  
51
+  // 获取列表信息
52
+  function getList(idx){
53
+    if(dataInfo.keyWord.trim() === ''){
54
+      dataInfo.list = [];
55
+      uni.stopPullDownRefresh();
56
+      return;
57
+    }
58
+    
59
+    uni.showLoading({
60
+      title: "加载中",
61
+      mask: true,
62
+    });
63
+    
64
+    dataInfo.idx = idx === undefined ? dataInfo.idx : idx;
65
+    if(dataInfo.idx === 0){
66
+      dataInfo.list = [];
67
+    }
68
+
69
+    let postData = {
70
+      idx: dataInfo.idx,
71
+      sum: 20,
72
+      department: {
73
+        branch: dataInfo.incidentData.branch,
74
+        searchType: 'quickStart',
75
+        selectType: 'pinyin_qs',
76
+        dept: dataInfo.keyWord,
77
+      }
78
+    }
79
+    
80
+    api_department(postData).then(res => {
81
+      uni.hideLoading();
82
+      uni.stopPullDownRefresh();
83
+      if(res.status == 200){
84
+        let list = res.list || [];
85
+        if(list.length){
86
+          dataInfo.hasMore = true;
87
+          dataInfo.list = dataInfo.idx === 0 ? list : dataInfo.list.concat(list);
88
+        }else{
89
+          dataInfo.hasMore = false;
90
+        }
91
+      }else{
92
+        uni.showToast({
93
+          icon: 'none',
94
+          title: res.msg || '请求数据失败!'
95
+        });
96
+      }
97
+    })
98
+  }
99
+  
100
+  // 点击
101
+  function clickItem(data){
102
+    dataInfo.incidentData.department = data;
103
+    incidentBuildStore.setIncidentBuildData(dataInfo.incidentData, incidentBuildStore.incidentBuild.type);
104
+    uni.navigateTo({
105
+      url: '/pages/buildIncident/buildIncident'
106
+    })
107
+  }
108
+  
109
+  onLoad((option) => {
110
+    if(incidentBuildStore.incidentBuild.data){
111
+      dataInfo.incidentData = incidentBuildStore.incidentBuild.data;
112
+    }
113
+    getList(0);
114
+  })
115
+  
116
+  onPullDownRefresh(() => {
117
+    getList(0)
118
+  })
119
+  
120
+  onReachBottom(() => {
121
+    dataInfo.idx += 1;
122
+    if (dataInfo.hasMore) {
123
+      getList(); // 当触底时加载更多数据
124
+    }
125
+  })
126
+</script>
127
+
128
+<style lang="scss" scoped>
129
+.consumableList{
130
+  display: flex;
131
+  flex-direction: column;
132
+  justify-content: space-between;
133
+  .head{
134
+    height: 88rpx;
135
+    display: flex;
136
+    align-items: center;
137
+    justify-content: center;
138
+    padding: 0 24rpx;
139
+    position: fixed;
140
+    z-index: 99;
141
+    width: 100%;
142
+    box-sizing: border-box;
143
+    background: linear-gradient( 90deg, #58CF66 0%, #DDE9FC 100%);
144
+  }
145
+  .body{
146
+    margin-bottom: 140rpx;
147
+    margin-top: 88rpx;
148
+    font-size: 26rpx;
149
+    .body_item{
150
+      border-bottom: 1rpx solid #DEDEDE;
151
+      padding: 24rpx;
152
+    }
153
+  }
154
+  .zanwu{
155
+    margin-bottom: 140rpx;
156
+    margin-top: 88rpx;
157
+    display: flex;
158
+    justify-content: center;
159
+    .newicon-zanwu{
160
+      font-size: 256rpx;
161
+      color: #D6D6D6;
162
+      margin-top: 140rpx;
163
+    }
164
+  }
165
+  .foot_common_btns{
166
+    position: fixed;
167
+    left: 0;
168
+    bottom: 0;
169
+    background-color: #fff;
170
+  }
171
+}
172
+</style>

+ 193 - 0
pages/searchPlace/searchPlace.vue

@@ -0,0 +1,193 @@
1
+<template>
2
+  <view class="searchPlace">
3
+    <view class="head">
4
+      <view class="one">{{dataInfo.parentName}}<uni-icons class="right" type="right" :size="16" :color="primaryColor"></uni-icons></view>
5
+      <text class="two ellipsis">{{dataInfo.placeObj.place}}</text>
6
+    </view>
7
+    <view class="body" v-if="dataInfo.list.length">
8
+      <uni-data-checkbox v-model="dataInfo.place" :localdata="dataInfo.list" mode="list" wrap icon="right" :map="{text:'place',value:'id'}" @change="selectItem"></uni-data-checkbox>
9
+    </view>
10
+    <view class="zanwu" v-else>
11
+      <text class="newicon newicon-zanwu"></text>
12
+    </view>
13
+    <view class="foot_common_btns">
14
+      <button @click="goBack" type="default" class="primaryButton btn">上一级</button>
15
+      <button @click="confirm" type="default" class="primaryButton btn">确认</button>
16
+    </view>
17
+  </view>
18
+</template>
19
+
20
+<script setup>
21
+  import { ref, reactive} from 'vue'
22
+  import { onLoad, onPullDownRefresh, onReachBottom } from '@dcloudio/uni-app'
23
+  import { api_place } from "@/http/api.js"
24
+  import { defaultColor } from '@/static/js/theme.js'
25
+  import { useSetTitle } from '@/share/useSetTitle.js'
26
+  import { useLoginUserStore } from '@/stores/loginUser'
27
+  import { useHandlerStore } from '@/stores/handler'
28
+  import { useIncidentBuildStore } from '@/stores/incidentBuild'
29
+  import { useGoBack } from '@/share/useGoBack.js'
30
+  
31
+  useSetTitle();
32
+  const loginUserStore = useLoginUserStore();
33
+  const handlerStore = useHandlerStore();
34
+  const incidentBuildStore = useIncidentBuildStore();
35
+  const { goBack }  = useGoBack();
36
+  
37
+  // 主题颜色
38
+  const primaryColor = ref(defaultColor)
39
+  
40
+  // 数据
41
+  const dataInfo = reactive({
42
+    list: [],//工单列表
43
+    idx: 0,//页码
44
+    hasMore: true,//是否有更多数据
45
+    incidentId: undefined,//事件ID
46
+    paramData: {},//传参
47
+    parentId: undefined,//区域id
48
+    parentName: '',//区域名称
49
+    place: undefined,//地点-回显
50
+    placeObj: {},//地点列表-已选择
51
+  })
52
+  
53
+  // 选择
54
+  function selectItem(e){
55
+    dataInfo.placeObj = e.detail.data;
56
+  }
57
+  
58
+  // 确认
59
+  function confirm(){
60
+    if(!dataInfo.place){
61
+      uni.showToast({
62
+      	icon: 'none',
63
+        title: '请选择地点'
64
+      });
65
+      return;
66
+    }
67
+    dataInfo.paramData.place = dataInfo.placeObj;
68
+    incidentBuildStore.setIncidentBuildData(dataInfo.paramData, incidentBuildStore.incidentBuild.type);
69
+    uni.navigateTo({
70
+      url: `/pages/${incidentBuildStore.incidentBuild.type}/${incidentBuildStore.incidentBuild.type}?incidentId=${dataInfo.incidentId}`,
71
+    })
72
+  }
73
+  
74
+  // 获取传递的数据
75
+  function getParamData(){
76
+    dataInfo.paramData = incidentBuildStore.incidentBuild.data || {};
77
+    dataInfo.place = dataInfo.paramData.place ? dataInfo.paramData.place.id : undefined;
78
+    dataInfo.placeObj =  dataInfo.paramData.place || {};
79
+    getList(0);
80
+  }
81
+  
82
+  // 获取列表信息
83
+  function getList(idx){
84
+    uni.showLoading({
85
+      title: "加载中",
86
+      mask: true,
87
+    });
88
+    
89
+    dataInfo.idx = idx === undefined ? dataInfo.idx : idx;
90
+    if(dataInfo.idx === 0){
91
+      dataInfo.list = [];
92
+    }
93
+
94
+    let postData = {
95
+      idx: dataInfo.idx,
96
+      sum: 20,
97
+      place: {
98
+        areaId: dataInfo.parentId,
99
+      }
100
+    }
101
+    
102
+    api_place(postData).then(res => {
103
+      uni.hideLoading();
104
+      uni.stopPullDownRefresh();
105
+      if(res.status == 200){
106
+        let list = res.list || [];
107
+        if(list.length){
108
+          dataInfo.hasMore = true;
109
+          dataInfo.list = dataInfo.idx === 0 ? list : dataInfo.list.concat(list);
110
+        }else{
111
+          dataInfo.hasMore = false;
112
+        }
113
+      }else{
114
+        uni.showToast({
115
+          icon: 'none',
116
+          title: res.msg || '请求数据失败!'
117
+        });
118
+      }
119
+    })
120
+  }
121
+  
122
+  onLoad((option) => {
123
+    dataInfo.incidentId = option.incidentId;
124
+    dataInfo.parentId = option.parentId;
125
+    dataInfo.parentName = option.parentName;
126
+    getParamData();
127
+  })
128
+  
129
+  onPullDownRefresh(() => {
130
+    getList(0)
131
+  })
132
+  
133
+  onReachBottom(() => {
134
+    dataInfo.idx += 1;
135
+    if (dataInfo.hasMore) {
136
+      getList(); // 当触底时加载更多数据
137
+    }
138
+  })
139
+</script>
140
+
141
+<style lang="scss" scoped>
142
+.searchPlace{
143
+  display: flex;
144
+  flex-direction: column;
145
+  justify-content: space-between;
146
+  .head{
147
+    height: 88rpx;
148
+    display: flex;
149
+    align-items: center;
150
+    padding: 0 24rpx;
151
+    position: fixed;
152
+    z-index: 99;
153
+    width: 100%;
154
+    box-sizing: border-box;
155
+    background: #fff;
156
+    font-size: 26rpx;
157
+    color: $uni-primary;
158
+    .right{
159
+      margin-top: 2rpx;
160
+    }
161
+    .two{
162
+      flex: 1;
163
+    }
164
+  }
165
+  .body{
166
+    border-top: 1rpx solid #DEDEDE;
167
+    margin-bottom: 140rpx;
168
+    margin-top: 88rpx;
169
+    font-size: 26rpx;
170
+    .body_item{
171
+      border-bottom: 1rpx solid #DEDEDE;
172
+      padding: 24rpx;
173
+    }
174
+  }
175
+  .zanwu{
176
+    margin-bottom: 140rpx;
177
+    margin-top: 88rpx;
178
+    display: flex;
179
+    justify-content: center;
180
+    .newicon-zanwu{
181
+      font-size: 256rpx;
182
+      color: #D6D6D6;
183
+      margin-top: 140rpx;
184
+    }
185
+  }
186
+  .foot_common_btns{
187
+    position: fixed;
188
+    left: 0;
189
+    bottom: 0;
190
+    background-color: #fff;
191
+  }
192
+}
193
+</style>

+ 2 - 2
pages/synergeticAdd/synergeticAdd.vue

@@ -59,9 +59,9 @@
59 59
       return;
60 60
     }
61 61
     dataInfo.paramData.synergetic = dataInfo.userSelectedList;
62
-    handlerStore.setHandlerData(dataInfo.paramData);
62
+    handlerStore.setHandlerData(dataInfo.paramData, handlerStore.handler.type);
63 63
     uni.navigateTo({
64
-      url: `/pages/handler/handler?incidentId=${dataInfo.incidentId}`,
64
+      url: `/pages/${handlerStore.handler.type}/${handlerStore.handler.type}?incidentId=${dataInfo.incidentId}`,
65 65
     })
66 66
   }
67 67
   

+ 33 - 0
static/scss/common.scss

@@ -167,3 +167,36 @@ uni-toast,
167 167
   border-top: none!important;
168 168
   border-bottom: 1rpx solid #DEDEDE!important;
169 169
 }
170
+
171
+// 清除按钮
172
+.content-clear-icon{
173
+  color: $uni-primary!important;
174
+}
175
+
176
+// flex1
177
+.flex1{
178
+  flex: 1;
179
+}
180
+
181
+// 表格控件遮罩
182
+.formMask{
183
+  position: relative;
184
+  &:after{
185
+    content: '';
186
+    position: absolute;
187
+    top: 0;
188
+    right: 0;
189
+    bottom: 0;
190
+    left: 0;
191
+  }
192
+}
193
+
194
+// 下拉框
195
+.uni-select__input-box{
196
+  width: 100%!important;
197
+}
198
+
199
+// 数据组合框
200
+.uni-data-checklist .checklist-group .checklist-box.is--list.is-checked .checklist-content .checkobx__list{
201
+  border-color: $uni-primary!important;
202
+}

+ 4 - 1
stores/handler.js

@@ -6,17 +6,20 @@ export const useHandlerStore = defineStore(
6 6
   () => {
7 7
     const handler = reactive({
8 8
       data: null,
9
+      type: '',
9 10
     });
10 11
 
11 12
     // 保存事件信息
12
-    function setHandlerData(data) {
13
+    function setHandlerData(data, type) {
13 14
       handler.data = data;
15
+      handler.type = type;
14 16
     }
15 17
     
16 18
     // 清空事件信息
17 19
     function clearHandlerData() {
18 20
       console.log(handler.data)
19 21
       handler.data = null;
22
+      handler.type = '';
20 23
     }
21 24
 
22 25
     return {

+ 34 - 0
stores/incidentBuild.js

@@ -0,0 +1,34 @@
1
+import { defineStore } from "pinia"
2
+import { reactive } from 'vue'
3
+
4
+export const useIncidentBuildStore = defineStore(
5
+  "incidentBuild",
6
+  () => {
7
+    const incidentBuild = reactive({
8
+      data: null,
9
+      type: '',
10
+    });
11
+
12
+    // 保存
13
+    function setIncidentBuildData(data, type) {
14
+      incidentBuild.data = data;
15
+      incidentBuild.type = type;
16
+    }
17
+    
18
+    // 清空
19
+    function clearIncidentBuildData() {
20
+      console.log(incidentBuild.data)
21
+      incidentBuild.data = null;
22
+      incidentBuild.type = '';
23
+    }
24
+
25
+    return {
26
+      incidentBuild,
27
+      setIncidentBuildData,
28
+      clearIncidentBuildData,
29
+    };
30
+  },
31
+  {
32
+    unistorage: true, // 开启后对 state 的数据读写都将持久化
33
+  },
34
+);