return.vue 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723
  1. <template>
  2. <view class="page">
  3. <view class="vtitle">归还信息</view>
  4. <view class="form_group">
  5. <view class="lable">扫码</view>
  6. <view class="tag" @click="qr()">
  7. <text class="span" style="width: 90%;">{{ code }}</text>
  8. <text class="icon code">&#xe60e;</text>
  9. </view>
  10. </view>
  11. <view class="form_group" v-if="op == '设备借用11'">
  12. <view class="lable">设备所属部门</view>
  13. <view class="tag">
  14. <view class="span">
  15. <picker @change="bindChange($event, 'dept')" :range="array1">
  16. <view class="picks">{{ item.dept ? item.dept : '选择2' }}</view>
  17. </picker>
  18. </view>
  19. <text class="icon more">&#xe631;</text>
  20. </view>
  21. </view>
  22. <view class="form_group">
  23. <view class="lable">归还者</view>
  24. <view class="tag">
  25. <input v-model="item.ghz" placeholder="归还者" />
  26. <text class="icon more">&#xe631;</text>
  27. </view>
  28. </view>
  29. <view class="form_group">
  30. <view class="lable">手机号</view>
  31. <view class="tag">
  32. <input v-model="item.tel" placeholder="输入手机号" />
  33. <text class="icon more">&#xe631;</text>
  34. </view>
  35. </view>
  36. <view class="vtitle">归还设备信息</view>
  37. <view v-if="id">
  38. <view v-for="(item, index) in list" :key="index" class="item">
  39. <view class="form_group">
  40. <view class="lable">序号</view>
  41. <view class="tag">
  42. <text class="span">{{ index + 1 }}</text>
  43. </view>
  44. </view>
  45. <view class="form_group">
  46. <view class="lable">计量编号</view>
  47. <view class="tag">
  48. <text class="span">{{ item.items.__1JzPv6GIMZUCGKYm2gx.value }}</text>
  49. </view>
  50. </view>
  51. <view class="form_group">
  52. <view class="lable">设备名称</view>
  53. <view class="tag">
  54. <text class="span">{{ item.items.__ngDKJEL3uIYQyjjFJMh.value }}</text>
  55. </view>
  56. </view>
  57. <view class="form_group">
  58. <view class="lable">型号规格</view>
  59. <view class="tag">
  60. <text class="span">{{ item.items.__apS4rWwLmvscx5ZUkLQ.value }}</text>
  61. </view>
  62. </view>
  63. <view class="form_group">
  64. <view class="lable">测量范围</view>
  65. <view class="tag">
  66. <text class="span">{{ item.items.__DjZGdE1GZEj1OUWhWuK.value }}</text>
  67. </view>
  68. </view>
  69. <view class="form_group">
  70. <view class="lable">制造商</view>
  71. <view class="tag">
  72. <text class="span">{{ item.items.__1yBwYFItXGQo6CoGTZs.value }}</text>
  73. </view>
  74. </view>
  75. <view class="form_group">
  76. <view class="lable">内部编号</view>
  77. <view class="tag">
  78. <text class="span">{{ item.items.__JjSPjH2TqMtxQjHcTY9.value }}</text>
  79. </view>
  80. </view>
  81. <view class="form_group">
  82. <!--<button class="btn del" @click="del(item)">移除</button>-->
  83. </view>
  84. </view>
  85. </view>
  86. <view v-else>
  87. <view v-for="(item, index) in list" :key="index" class="item" >
  88. <view class="form_group">
  89. <view class="lable">序号</view>
  90. <view class="tag">
  91. <text class="span">{{ index + 1 }}</text>
  92. </view>
  93. </view>
  94. <view class="form_group">
  95. <view class="lable">计量编号</view>
  96. <view class="tag">
  97. <text class="span">{{ item.items.__Q0YnOcfMqiTpVsTiDEh.value }}</text>
  98. </view>
  99. </view>
  100. <view class="form_group">
  101. <view class="lable">设备名称</view>
  102. <view class="tag">
  103. <text class="span">{{ item.items.__khn9SQnzgWNPt0aHldp.value }}</text>
  104. </view>
  105. </view>
  106. <view class="form_group">
  107. <view class="lable">型号规格</view>
  108. <view class="tag">
  109. <text class="span">{{ item.items.__fpUc5yOsHgSHeHPFHim.value }}</text>
  110. </view>
  111. </view>
  112. <view class="form_group">
  113. <view class="lable">测量范围</view>
  114. <view class="tag">
  115. <text class="span">{{ item.items.__soGLIaAxvM0O0NTVt1c.value }}</text>
  116. </view>
  117. </view>
  118. <view class="form_group">
  119. <view class="lable">制造商</view>
  120. <view class="tag">
  121. <text class="span">{{ item.items.__aPTYvYeakxz299A7Thk.value }}</text>
  122. </view>
  123. </view>
  124. <view class="form_group">
  125. <view class="lable">内部编号</view>
  126. <view class="tag">
  127. <text class="span">{{ item.items.__dRIZk7xLPVCO6rqJbs7.value }}</text>
  128. </view>
  129. </view>
  130. <view class="form_group">
  131. <button class="btn del" @click="del(item)">移除</button>
  132. </view>
  133. </view>
  134. </view>
  135. <u-empty v-if="list.length == 0"></u-empty>
  136. <view class="footer">
  137. <view class="flex">
  138. <view class="f"><button class="btn br" @click="submission()">提交</button></view>
  139. <!-- <view class="f" v-if="state == 1"><button class="btn br back" @click="back()">回退</button></view>
  140. <view class="f"><button class="btn" @click="validate()">保存</button></view>-->
  141. </view>
  142. </view>
  143. <u-popup :show="show" mode="bottom" @close="show = false" closeable round="15">
  144. <view class="popup">
  145. <u-divider text="提交流程面板"></u-divider>
  146. <scroll-view scroll-y="true" style="height: 300rpx;">
  147. <view v-for="(item, index) in nextNodes" :key="index" class="bitem"
  148. @click="bselect(item, 'nextNodes')">
  149. <view class="icon select check" v-if="item.check">&#xe600;</view>
  150. <view class="icon select" v-else>&#xe8bb;</view>
  151. <view class="title">{{ item.name }}</view>
  152. </view>
  153. </scroll-view>
  154. <view class="confrim-btn"><button class="btn" @click="submit()">确定</button></view>
  155. </view>
  156. </u-popup>
  157. <u-popup :show="bshow" mode="bottom" @close="bshow = false" closeable round="15">
  158. <view class="popup">
  159. <u-divider text="回退流程面板"></u-divider>
  160. <scroll-view scroll-y="true" style="height: 300rpx;">
  161. <view v-for="(item, index) in backNodes" :key="index" class="bitem"
  162. @click="bselect(item, 'backNodes')">
  163. <view class="icon select check" v-if="item.check">&#xe600;</view>
  164. <view class="icon select" v-else>&#xe8bb;</view>
  165. <view class="title">{{ item.name }}</view>
  166. </view>
  167. </scroll-view>
  168. <view class="confrim-btn"><button class="btn" @click="workflowsback()">确定</button></view>
  169. </view>
  170. </u-popup>
  171. </view>
  172. </template>
  173. <script>
  174. let qrcode = require('@/common/code.js');
  175. export default {
  176. data() {
  177. return {
  178. bitem: {
  179. applicationId: '__gAPYBW4YxB3UePM3lqO',
  180. exparams: {},
  181. formId: '__0FLGNncOS1lz0T9jsFn',
  182. id: '__79Wtw03ya4dJUDGPyAN',
  183. isRelate: 'true',
  184. parentId: '',
  185. sign: '',
  186. subDocuments: [],
  187. templateForm: '',
  188. versions: '0'
  189. },
  190. btitem: {
  191. applicationId: '__gAPYBW4YxB3UePM3lqO',
  192. exparams: {},
  193. formId: '__0FLGNncOS1lz0T9jsFn',
  194. id: '__79Wtw03ya4dJUDGPyAN',
  195. isRelate: 'true',
  196. parentId: '',
  197. sign: '',
  198. subDocuments: [],
  199. templateForm: '',
  200. versions: '0'
  201. },
  202. geteq: {
  203. DEVID: '',
  204. allow: 'false',
  205. appId: '__gAPYBW4YxB3UePM3lqO',
  206. datetime: '1670485443880',
  207. detp: '',
  208. fieldid: '__iLwKGJTxD89ZKnFzo2Y',
  209. formId: '__w9J1gxcIWgXmNw6pE1F',
  210. isEdit: 'true',
  211. mutil: 'true',
  212. parentId: '__NYI0rVs0LXbiW21z6Nv',
  213. searchForm: 'false',
  214. selectOne: 'false',
  215. viewId: '__ajlFXbohdIXtn7ErzZq'
  216. },
  217. item: {},
  218. op: '设备归还',
  219. current: 0,
  220. code: '',
  221. list: [],
  222. id: '',
  223. show: false,
  224. bshow: false,
  225. itemt: {},
  226. up: {},
  227. content: '标题',
  228. nextNodes: [],
  229. backNodes: [],
  230. items: {
  231. document: {
  232. items: {}
  233. }
  234. },
  235. runViewDialogConfirmScript: {
  236. docId: "__DIl607e1fsiknRgGRQj",
  237. document: {
  238. items: {
  239. group: "",
  240. depttool: "",
  241. UNIT: "柳工",
  242. borrower: "",
  243. tel: "",
  244. remarks: ""
  245. },
  246. },
  247. fieldId: "__0TQu1UrRbMZVX1UvtBL",
  248. formId: "__w9J1gxcIWgXmNw6pE1F",
  249. viewId: "__ajlFXbohdIXtn7ErzZq",
  250. _selects: "__sIJiL5GlxEYoL095Vo9",
  251. },
  252. };
  253. },
  254. onLoad(e) {
  255. this.op = e.op;
  256. this.id = e.id;
  257. if (e.ste == 1) {
  258. /* this.http.request({
  259. url: this.http.urls.xxxx + e.id,
  260. success: res => {
  261. this.item = res.data.data;
  262. }
  263. }); */
  264. this.getDocuments();
  265. } else{
  266. this.empty();
  267. }
  268. //选中审批人员监听函数,其它类型的参考这个
  269. uni.$on('select', res => {
  270. console.log('asd:' + JSON.stringify(res));
  271. });
  272. },
  273. onReady() {
  274. uni.setNavigationBarTitle({
  275. title: this.op
  276. });
  277. },
  278. methods: {
  279. //提交或回退
  280. bselect(e, tag) {
  281. this[tag].forEach(item => {
  282. item.check = false;
  283. });
  284. e.check = true;
  285. this.itemt.nextNodeIds = [];
  286. this.itemt.nextNodeIds.push(e.id);
  287. this.$forceUpdate();
  288. }, //详情
  289. qr() {
  290. // 调用uni提供的调用相机api
  291. uni.chooseImage({
  292. sizeType: ['original'],
  293. sourceType: ['camera'],
  294. count: 1,
  295. success: res => {
  296. const tempFilePaths = res.tempFilePaths[0]; // 获取到二维码图片的链接
  297. qrcode.decode(tempFilePaths); // 解析二维码图片
  298. qrcode.callback = r => {
  299. var r1=r.split('*')[1]
  300. this.code = r1;
  301. this.geteq.DEVID = this.code;
  302. if (this.list.length == 0) {
  303. console.log('getEq:1');
  304. this.getEq();
  305. } else {
  306. this.list.forEach(item => {
  307. if (item.items.__O1qcaazksjAzDcrvJLk.value == this.geteq
  308. .DEVID) {
  309. uni.showModal({
  310. title: '提示',
  311. content: '该设备已经选择过了',
  312. showCancel: false,
  313. success: res => {
  314. if (res.confirm) {
  315. // uni.navigateBack();
  316. }
  317. }
  318. });
  319. } else {
  320. console.log('getEq:2');
  321. this.getEq();
  322. }
  323. });
  324. }
  325. console.log('asd:' + r);
  326. this.$forceUpdate();
  327. };
  328. }
  329. });
  330. },
  331. //选择结果形式
  332. change(e) {
  333. this.current = e;
  334. console.log('aa:' + this.radio[this.current].name);
  335. },
  336. //选择实验类型
  337. bindChange(e, type) {
  338. this.item[type] = this.array1[e.target.value];
  339. this.$forceUpdate();
  340. },
  341. //选择审批人员
  342. select() {
  343. uni.navigateTo({
  344. url: '/pages/index/select'
  345. });
  346. },
  347. getEq() {
  348. this.http.request({
  349. url: this.http.urls.re_list +
  350. 'parentId=' +
  351. this.geteq.parentid,
  352. data: this.geteq,
  353. method: 'POST',
  354. success: res => {
  355. console.log('res2:' + JSON.stringify(res.data.data.data));
  356. if (res.data.errcode == 0) {
  357. res.data.data.data.forEach(item => {
  358. this.list.push(item);
  359. });
  360. }
  361. }
  362. });
  363. },
  364. empty() {
  365. this.http.request({
  366. url: this.http.urls.return_empty,
  367. data: this.item,
  368. success: res => {
  369. //console.log('res2:' + JSON.stringify(res));
  370. this.item = res.data.data.items;
  371. this.bitem.id = res.data.data.id;
  372. this.bitem.formId = res.data.data.formid;
  373. this.bitem.versions = res.data.data.versions;
  374. this.geteq.parentid = res.data.data.id;
  375. //创建时组建提交流程面板请求数据
  376. this.iteml = res.data.data;
  377. this.items.applicationId = '__gAPYBW4YxB3UePM3lqO';
  378. this.items.docId = this.iteml.id;
  379. this.items.id = this.iteml.id;
  380. this.items.formId = this.iteml.formid;
  381. this.items.parentId = '';
  382. this.items.subSelects = [];
  383. this.items.templateForm = '';
  384. this.items.viewId = '';
  385. this.items.document.items = this.item;
  386. this.items.document.applicationId = '__gAPYBW4YxB3UePM3lqO';
  387. this.items.document.exparams = {};
  388. this.items.document.formId = this.iteml.formid;
  389. this.items.document.id = this.iteml.id;
  390. this.items.document.parentId = '';
  391. this.items.document.sign = '';
  392. this.items.document.stateId = this.iteml.stateid;
  393. this.items.document.subDocuments = [];
  394. this.items.document.templateForm = '';
  395. this.items.document.versions = '0';
  396. }
  397. });
  398. },
  399. //移除借用设备信息
  400. del(item) {
  401. this.list.splice(this.list.indexOf(item), 1);
  402. },
  403. //详情
  404. getDocuments() {
  405. this.http.request({
  406. url: this.http.urls.documents + this.id,
  407. data: this.item,
  408. success: res => {
  409. this.item = res.data.data.items;
  410. //this.p = res.data.data;
  411. this.ghlis_list();
  412. this.iteml = res.data.data;
  413. this.items.applicationId = '__gAPYBW4YxB3UePM3lqO';
  414. this.items.docId = this.iteml.id;
  415. this.items.id = this.iteml.id;
  416. this.items.formId = this.iteml.formid;
  417. this.items.parentId = '';
  418. this.items.subSelects = [];
  419. this.items.templateForm = '';
  420. this.items.viewId = '';
  421. this.items.document.items = this.item;
  422. this.items.document.applicationId = '__gAPYBW4YxB3UePM3lqO';
  423. this.items.document.exparams = {};
  424. this.items.document.formId = this.iteml.formid;
  425. this.items.document.id = this.iteml.id;
  426. this.items.document.parentId = '';
  427. this.items.document.sign = '';
  428. this.items.document.stateId = this.iteml.stateid;
  429. this.items.document.subDocuments = [];
  430. this.items.document.templateForm = '';
  431. this.items.document.versions = '0';
  432. }
  433. });
  434. },
  435. ghlis_list() {
  436. this.http.request({
  437. url: this.http.urls.ghlis_list +
  438. 'parentId=' +
  439. this.id,
  440. method: 'POST',
  441. success: res => {
  442. console.log('res2:' + JSON.stringify(res));
  443. if (res.data.errcode == 0) {
  444. res.data.data.data.forEach(item => {
  445. this.list.push(item);
  446. });
  447. }
  448. }
  449. });
  450. },
  451. ghls_empty() {
  452. this.list.forEach(item => {
  453. this.http.request({
  454. url: this.http.urls.ghls_empty,
  455. data: this.item,
  456. success: res => {
  457. //this.item = res.data.data.items;
  458. console.log('this.bitem:' + JSON.stringify(this.bitem));
  459. this.btitem.id = res.data.data.id;
  460. this.btitem.formId = res.data.data.formid;
  461. this.btitem.versions = res.data.data.versions;
  462. this.btitem.parentId = this.bitem.id;
  463. //this.btitem.parent=this.bitem.id;
  464. this.btitem.items = res.data.data.items;
  465. this.btitem.items.DEVID = item.items.__O1qcaazksjAzDcrvJLk.value;//1
  466. this.btitem.items.EQUNR = item.items.__Q0YnOcfMqiTpVsTiDEh.value; //1
  467. this.btitem.items.EQKTX = item.items.__khn9SQnzgWNPt0aHldp.value; //1
  468. this.btitem.items.TYPBZ = item.items.__fpUc5yOsHgSHeHPFHim.value; //1
  469. this.btitem.items.CLFW = item.items.__soGLIaAxvM0O0NTVt1c.value; //1
  470. this.btitem.items.NPLDA = item.items.__G47scKcbMDon7HgDiQ5.value; //1
  471. this.btitem.items.SERGE = item.items.__3mveBfEF1si9RCAp9Sv.value; //1
  472. this.btitem.items.HERST = item.items.__aPTYvYeakxz299A7Thk.value; //1
  473. this.btitem.items.return_date = this.util.getDate('time'); //借用日期
  474. this.btitem.items.returning_state = ""; //归还状态
  475. this.btitem.items.TPLNR = item.items.__8BoEUIvmeOIjLiAwO9R.value; //1
  476. this.btitem.items.INTNUM = item.items.__dRIZk7xLPVCO6rqJbs7.value; //1
  477. this.btitem.items.NUMBER = item.items.__hImw4lGXCFmwyAx4fD8.value;//1
  478. console.log('this.btitem1:' + JSON.stringify(this.btitem));
  479. this.validate();
  480. //console.log('res2:' + JSON.stringify(res.data.data));
  481. }
  482. });
  483. });
  484. },
  485. //保存
  486. validate() {
  487. this.http.request({
  488. url: this.http.urls.validate +
  489. '?parentId=' +
  490. this.btitem.parentId,
  491. data: this.btitem,
  492. method: 'POST',
  493. success: res => {
  494. console.log('validate1:' + JSON.stringify(res));
  495. this.updateparent(this.btitem.parentId, res.data.data.id);
  496. }
  497. });
  498. },
  499. updateparent(parent, id) {
  500. this.http.request({
  501. url: this.http.urls.ip2 + '/liug/app?parent=' + parent + '&id=' + id + '&table=tlk_ghlsb',
  502. method: 'POST',
  503. success: res => {
  504. console.log('validate1:' + JSON.stringify(res));
  505. }
  506. });
  507. },
  508. //提交流程面板
  509. submission() {
  510. //this.validatet();
  511. this.http.request({
  512. url: this.http.urls.documents + this.bitem.id + '/panels/submission',
  513. data: this.items,
  514. method: 'POST',
  515. success: res => {
  516. //this.item=res.data.data;
  517. //console.log('zx22:' + JSON.stringify(res));
  518. this.show = true;
  519. this.title = res.data.data.name;
  520. this.nextNodes = res.data.data.nextNodes;
  521. this.itemt.flowId = res.data.data.flowId;
  522. this.itemt.flowType = '80';
  523. this.itemt.currentNodeId = res.data.data.currentNodeId;
  524. this.itemt.attitude = '';
  525. this.itemt.signature = '';
  526. this.itemt.submitTo = '';
  527. this.itemt.circulatorInfo = '';
  528. this.itemt.subFlowApproverInfo = '';
  529. this.itemt.subFlowApproverInfoAll = '';
  530. this.itemt.document = this.items.document;
  531. //this.content=res.data.data.formname;
  532. }
  533. });
  534. }, //提交流程
  535. submit() {
  536. //this.itemt.document.items.purpose="试验目的5656";
  537. //this.itemt.document.items.title="标题5656";
  538. if (this.itemt.document.items.ghz == '' || this.itemt.document.items.ghz == null) {
  539. uni.showModal({
  540. title: '提示',
  541. content: '请填写归还人',
  542. showCancel: false,
  543. success: res => {
  544. if (res.confirm) {
  545. //uni.navigateBack();
  546. }
  547. this.ghls_empty();
  548. }
  549. });
  550. return;
  551. }
  552. /*
  553. if (this.itemt.document.items.tel == '' || this.itemt.document.items.tel == null) {
  554. uni.showModal({
  555. title: '提示',
  556. content: '请填写手机号',
  557. showCancel: false,
  558. success: res => {
  559. if (res.confirm) {
  560. //uni.navigateBack();
  561. }
  562. }
  563. });
  564. return;
  565. }
  566. */
  567. this.itemt.applicationId = '__gAPYBW4YxB3UePM3lqO';
  568. this.itemt.docId = this.iteml.id;
  569. this.itemt.id = this.iteml.id;
  570. this.itemt.formId = this.iteml.formid;
  571. this.itemt.parentId = '';
  572. this.itemt.subFlowApprover = [];
  573. this.itemt.subSelects = [];
  574. this.itemt.submitTo = [];
  575. this.itemt.templateForm = '';
  576. this.itemt.viewId = '';
  577. this.http.request({
  578. url: this.http.urls.documents + this.id + '/workflows/submit',
  579. data: this.itemt,
  580. method: 'PUT',
  581. success: res => {
  582. //this.item=res.data.data;
  583. console.log('zx22:' + JSON.stringify(res));
  584. if (res.data.errcode == 0) {
  585. uni.showModal({
  586. title: '提示',
  587. content: res.data.data,
  588. showCancel: false,
  589. success: res => {
  590. if (res.confirm) {
  591. uni.navigateBack();
  592. }
  593. }
  594. });
  595. } else {
  596. uni.showModal({
  597. title: '提示',
  598. content: res.data.errmsg,
  599. showCancel: false,
  600. success: res => {
  601. if (res.confirm) {
  602. //uni.navigateBack();
  603. }
  604. }
  605. });
  606. }
  607. this.show = false;
  608. this.title = res.data.data.name;
  609. this.nextNodes = res.data.data.nextNodes;
  610. }
  611. });
  612. }, //刷新数据
  613. //提交
  614. add() {
  615. this.http.request({
  616. url: this.http.urls.user_task_add,
  617. data: this.item,
  618. method: 'POST',
  619. success: res => {
  620. uni.showModal({
  621. title: '提示',
  622. content: '提交成功',
  623. showCancel: false,
  624. success: res => {
  625. if (res.confirm) {
  626. uni.navigateBack();
  627. }
  628. }
  629. });
  630. }
  631. });
  632. }
  633. }
  634. };
  635. </script>
  636. <style lang="scss">
  637. .page {
  638. padding-bottom: 80px;
  639. }
  640. .item {
  641. margin-bottom: 10px;
  642. }
  643. .del {
  644. width: 70%;
  645. background-color: #e64340;
  646. }
  647. </style>