hasrepaired.vue 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. <template>
  2. <view class="OutermostLayer">
  3. <h3 class="baoxiu">报修信息</h3>
  4. <u-cell-group>
  5. <u-cell icon="integral-fill" title="报修时间" :value="details.shijian" >
  6. <u-icon slot="icon" size="40" name="calendar"></u-icon>
  7. </u-cell>
  8. <u-cell icon="integral-fill" title="报修位置" :value="details.weizhi" >
  9. <u-icon slot="icon" size="40" name="map"></u-icon>
  10. </u-cell>
  11. <u-cell icon="integral-fill" title="报修区域" :value="details.quyu" >
  12. <u-icon slot="icon" size="40" name="grid"></u-icon>
  13. </u-cell>
  14. <u-cell icon="integral-fill" title="报修类型" :value="details.leixing" >
  15. <u-icon slot="icon" size="40" name="pushpin"></u-icon>
  16. </u-cell>
  17. <u-cell icon="integral-fill" title="联系人" :value="details.lxr" >
  18. <u-icon slot="icon" size="40" name="man-add"></u-icon>
  19. </u-cell>
  20. <u-cell icon="integral-fill" title="联系电话" :value="details.lxdh">
  21. <u-icon slot="icon" size="40" name="phone"></u-icon>
  22. </u-cell>
  23. <u-cell icon="integral-fill" title="故障描述" :value="details.gzms" >
  24. <u-icon slot="icon" size="40" name="order"></u-icon>
  25. </u-cell>
  26. <u-cell icon="integral-fill" title="故障照片" >
  27. <u-icon slot="icon" size="40" name="photo"></u-icon>
  28. <view
  29. slot="title"
  30. class="guzhang"
  31. >
  32. <view class="">
  33. 故障照片
  34. </view>
  35. <view class="albumcontent">
  36. <u-album :urls="details.gzimg"></u-album>
  37. </view>
  38. </view>
  39. </u-cell>
  40. </u-cell-group>
  41. <h3 class="baoxiu">维修信息</h3>
  42. <u-cell-group>
  43. <u-cell icon="integral-fill" title="紧急程度" :value="details.jinji" >
  44. <u-icon slot="icon" size="40" name="bell"></u-icon>
  45. </u-cell>
  46. <u-cell icon="integral-fill" title="维修人员" :value="details.weixiury" >
  47. <u-icon slot="icon" size="40" name="man-add"></u-icon>
  48. </u-cell>
  49. <u-cell icon="integral-fill" title="联系电话" :value="details.weixiudh" >
  50. <u-icon slot="icon" size="40" name="phone"></u-icon>
  51. </u-cell>
  52. <u-cell icon="integral-fill" title="维修完成时间" :value="details.repairFinishTime" >
  53. <u-icon slot="icon" size="40" name="bell"></u-icon>
  54. </u-cell>
  55. </u-cell-group>
  56. <view class="returndata">
  57. <!--<view>-->
  58. <!--<u-button type="primary" text="维修完成" @click="returndata"></u-button>-->
  59. <!--</view>-->
  60. <!--<view class="Maintenancepersonnel">-->
  61. <!--<u-button type="primary" text="指派维修人员" @click="Maintenancepersonnel"></u-button>-->
  62. <!--</view>-->
  63. </view>
  64. <!--确定弹窗-->
  65. <u-modal :show="showqd" title="提示" content='请问是否确定维修完成?' :showCancelButton="true"
  66. @confirm="weixiuyes" @cancel="weixiuno"
  67. ></u-modal>
  68. <u-notify ref="uNotify" message="" ></u-notify>
  69. </view>
  70. </template>
  71. <script>
  72. export default {
  73. data() {
  74. return {
  75. columnsrenyuan:[],
  76. columnsrenjinji:[],
  77. model1: {
  78. userInfo: {
  79. repairPersonId: '',
  80. urgency:'',
  81. },
  82. },
  83. rules: {
  84. 'userInfo.repairPersonId': {
  85. type: 'string',
  86. required: true,
  87. message: '请选择维修人员',
  88. trigger: ['blur', 'change']
  89. },
  90. 'userInfo.urgency': {
  91. type: 'string',
  92. required: true,
  93. message: '请选择紧急程度',
  94. trigger: ['blur', 'change']
  95. },
  96. },
  97. showjinji:false,
  98. showSex:false,
  99. showqd:false,
  100. showweixiu:false,
  101. companyOrgId:'',
  102. renyuanid:'',
  103. jjcd:'',
  104. src: 'https://cdn.uviewui.com/uview/album/1.jpg',
  105. details:{
  106. shijian:'',
  107. weizhi:'',
  108. quyu:'',
  109. leixing:'',
  110. lxr:'',
  111. lxdh:'',
  112. gzms:'',
  113. gzimg:[],
  114. repairFinishTime:'',
  115. jinji:'',
  116. weixiury:'',
  117. weixiudh:''
  118. },
  119. albumWidth: 0,
  120. }
  121. },
  122. onReady() {
  123. //如果需要兼容微信小程序,并且校验规则中含有方法等,只能通过setRules方法设置规则。
  124. //this.$refs.uForm.setRules(this.rules)
  125. },
  126. onLoad(options) {
  127. this.companyOrgId = options.id;
  128. // console.log(options.id);
  129. // let getDictDataList = uni.getStorageSync('getDictDataList');
  130. this.getUserList();
  131. this.getdata();
  132. },
  133. methods: {
  134. getUserList() {
  135. this.$api.get('/user/list',{ page: 1,
  136. limit: 100,})
  137. .then(res=>{
  138. // console.log('111111111111111111',res.data.data)
  139. this.columnsrenyuan=res.data.data;
  140. })
  141. },
  142. getdata(){
  143. this.$api.get('/repairorder/'+this.companyOrgId,{})
  144. .then(res=>{
  145. this.details.shijian=res.data.data.createDate;
  146. this.details.weizhi=res.data.data.repairPosition;
  147. this.details.lxr=res.data.data.contactPerson;
  148. this.details.lxdh=res.data.data.contactPhone;
  149. this.details.gzms=res.data.data.faultDes;
  150. this.details.weixiury=res.data.data.repairPersonName;
  151. this.details.repairFinishTime=res.data.data.repairFinishTime;
  152. res.data.data.faultPics=res.data.data.faultPics.split(",");
  153. this.details.gzimg=res.data.data.faultPics;
  154. // console.log('111111111111111111', this.details.gzimg)
  155. if(res.data.data.repairRegion==1){
  156. this.details.quyu='公共区域';
  157. }else if(res.data.data.repairRegion==2){
  158. this.details.quyu='室内';
  159. }
  160. if(res.data.data.repairType==1){
  161. this.details.leixing='水';
  162. }else if(res.data.data.repairType==2){
  163. this.details.leixing='电';
  164. }else if(res.data.data.repairType==3){
  165. this.details.leixing='其他';
  166. }
  167. if(res.data.data.urgency==1){
  168. this.details.jinji='非常紧急';
  169. }else if(res.data.data.urgency==2){
  170. this.details.jinji='紧急';
  171. }else if(res.data.data.urgency==3){
  172. this.details.jinji='普通';
  173. }
  174. for(let i=0;i<this.columnsrenyuan.length;i++){
  175. if(this.columnsrenyuan[i].id==res.data.data.repairPersonId){
  176. console.log('111111111111111111',this.columnsrenyuan[i])
  177. this.details.weixiudh=this.columnsrenyuan[i].mobile
  178. }
  179. }
  180. })
  181. },
  182. quxiao(){
  183. this.showweixiu=false;
  184. },
  185. queding(){
  186. this.$refs.uForm.validate().then(res => {
  187. // uni.$u.toast('校验通过')
  188. // jjcd renyuanid companyOrgId
  189. //console.log('111111111111111111',this.jjcd,this.renyuanid,this.companyOrgId)
  190. this.$api.put('/repairorder',{
  191. id: this.companyOrgId,
  192. repairPersonId: this.renyuanid,
  193. urgency: this.jjcd,
  194. })
  195. .then(res=>{
  196. //console.log('111111111111111111',res)
  197. if(res.data.code==0){
  198. this.$refs.uNotify.success('指派成功')
  199. setTimeout(function(){uni.navigateTo({
  200. url: '/pages/index/Workordertodone/Workordertodone'
  201. })},1000);
  202. }else{
  203. this.$refs.uNotify.error(res.data.msg)
  204. // uni.navigateBack({
  205. // delta: 1
  206. // });
  207. }
  208. })
  209. }).catch(errors => {
  210. uni.$u.toast('校验失败')
  211. })
  212. },
  213. returndata(){
  214. this.showqd=true;
  215. },
  216. weixiuyes(){
  217. this.$api.post('/repairorder/finish/'+this.companyOrgId,{})
  218. .then(res=>{
  219. //console.log('111111111111111111',res)
  220. if(res.data.code==0){
  221. this.$refs.uNotify.success('维修成功')
  222. setTimeout(function(){uni.navigateTo({
  223. url: '/pages/index/Workordertodone/Workordertodone'
  224. })},1000);
  225. }else{
  226. this.$refs.uNotify.error(res.data.msg)
  227. }
  228. })
  229. this.showqd=false;
  230. },
  231. weixiuno(){
  232. this.showqd=false;
  233. },
  234. }
  235. }
  236. </script>
  237. <style lang="scss">
  238. .guidang{
  239. display: flex;
  240. align-items: center;
  241. justify-content: space-around;
  242. margin-top: 80rpx;
  243. }
  244. .queding{
  245. width: 300rpx;
  246. }
  247. .baoxiu{
  248. padding: 30rpx;
  249. }
  250. .albumcontent{
  251. display: flex;
  252. .u-album{
  253. display: flex;
  254. flex-direction: row;
  255. flex-wrap: wrap;
  256. }
  257. }
  258. .guzhang{
  259. display: flex;
  260. justify-content: space-between;
  261. align-items: center;
  262. }
  263. .returndata{
  264. padding: 30rpx;
  265. }
  266. .Maintenancepersonnel{
  267. margin-top: 15rpx;
  268. }
  269. .weixiudc{
  270. width: 750rpx;
  271. height: 450rpx;
  272. h3{
  273. font-size: 30rpx;
  274. font-weight: bold;
  275. width: 750rpx;
  276. height: 80rpx;
  277. line-height: 80rpx;
  278. text-align: center;
  279. }
  280. }
  281. </style>