return.vue 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725
  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. if (!this.code) {
  302. return;
  303. }
  304. this.geteq.DEVID = this.code;
  305. if (this.list.length == 0) {
  306. console.log('getEq:1');
  307. this.getEq();
  308. } else {
  309. this.list.forEach(item => {
  310. if (item.items.__O1qcaazksjAzDcrvJLk.value == this.geteq
  311. .DEVID) {
  312. uni.showModal({
  313. title: '提示',
  314. content: '该设备已经选择过了',
  315. showCancel: false,
  316. success: res => {
  317. if (res.confirm) {
  318. // uni.navigateBack();
  319. }
  320. }
  321. });
  322. } else {
  323. console.log('getEq:2');
  324. this.getEq();
  325. }
  326. });
  327. }
  328. console.log('asd:' + r);
  329. this.$forceUpdate();
  330. };
  331. }
  332. });
  333. },
  334. //选择结果形式
  335. change(e) {
  336. this.current = e;
  337. console.log('aa:' + this.radio[this.current].name);
  338. },
  339. //选择实验类型
  340. bindChange(e, type) {
  341. this.item[type] = this.array1[e.target.value];
  342. this.$forceUpdate();
  343. },
  344. //选择审批人员
  345. select() {
  346. uni.navigateTo({
  347. url: '/pages/index/select'
  348. });
  349. },
  350. getEq() {
  351. this.http.request({
  352. url: this.http.urls.re_list +
  353. 'parentId=' +
  354. this.geteq.parentid,
  355. data: this.geteq,
  356. method: 'POST',
  357. success: res => {
  358. console.log('res2:' + JSON.stringify(res.data.data.data));
  359. if (res.data.errcode == 0) {
  360. res.data.data.data.forEach(item => {
  361. this.list.push(item);
  362. });
  363. }
  364. }
  365. });
  366. },
  367. empty() {
  368. this.http.request({
  369. url: this.http.urls.return_empty,
  370. data: this.item,
  371. success: res => {
  372. //console.log('res2:' + JSON.stringify(res));
  373. this.item = res.data.data.items;
  374. this.bitem.id = res.data.data.id;
  375. this.bitem.formId = res.data.data.formid;
  376. this.bitem.versions = res.data.data.versions;
  377. this.geteq.parentid = res.data.data.id;
  378. //创建时组建提交流程面板请求数据
  379. this.iteml = res.data.data;
  380. this.items.applicationId = '__gAPYBW4YxB3UePM3lqO';
  381. this.items.docId = this.iteml.id;
  382. this.items.id = this.iteml.id;
  383. this.items.formId = this.iteml.formid;
  384. this.items.parentId = '';
  385. this.items.subSelects = [];
  386. this.items.templateForm = '';
  387. this.items.viewId = '';
  388. this.items.document.items = this.item;
  389. this.items.document.applicationId = '__gAPYBW4YxB3UePM3lqO';
  390. this.items.document.exparams = {};
  391. this.items.document.formId = this.iteml.formid;
  392. this.items.document.id = this.iteml.id;
  393. this.items.document.parentId = '';
  394. this.items.document.sign = '';
  395. this.items.document.stateId = this.iteml.stateid;
  396. this.items.document.subDocuments = [];
  397. this.items.document.templateForm = '';
  398. this.items.document.versions = '0';
  399. }
  400. });
  401. },
  402. //移除借用设备信息
  403. del(item) {
  404. this.list.splice(this.list.indexOf(item), 1);
  405. },
  406. //详情
  407. getDocuments() {
  408. this.http.request({
  409. url: this.http.urls.documents + this.id,
  410. data: this.item,
  411. success: res => {
  412. this.item = res.data.data.items;
  413. //this.p = res.data.data;
  414. this.ghlis_list();
  415. this.iteml = res.data.data;
  416. this.items.applicationId = '__gAPYBW4YxB3UePM3lqO';
  417. this.items.docId = this.iteml.id;
  418. this.items.id = this.iteml.id;
  419. this.items.formId = this.iteml.formid;
  420. this.items.parentId = '';
  421. this.items.subSelects = [];
  422. this.items.templateForm = '';
  423. this.items.viewId = '';
  424. this.items.document.items = this.item;
  425. this.items.document.applicationId = '__gAPYBW4YxB3UePM3lqO';
  426. this.items.document.exparams = {};
  427. this.items.document.formId = this.iteml.formid;
  428. this.items.document.id = this.iteml.id;
  429. this.items.document.parentId = '';
  430. this.items.document.sign = '';
  431. this.items.document.stateId = this.iteml.stateid;
  432. this.items.document.subDocuments = [];
  433. this.items.document.templateForm = '';
  434. this.items.document.versions = '0';
  435. }
  436. });
  437. },
  438. ghlis_list() {
  439. this.http.request({
  440. url: this.http.urls.ghlis_list +
  441. 'parentId=' +
  442. this.id,
  443. method: 'POST',
  444. success: res => {
  445. console.log('res2:' + JSON.stringify(res));
  446. if (res.data.errcode == 0) {
  447. res.data.data.data.forEach(item => {
  448. this.list.push(item);
  449. });
  450. }
  451. }
  452. });
  453. },
  454. ghls_empty() {
  455. this.list.forEach(item => {
  456. this.http.request({
  457. url: this.http.urls.ghls_empty,
  458. data: this.item,
  459. success: res => {
  460. //this.item = res.data.data.items;
  461. console.log('this.bitem:' + JSON.stringify(this.bitem));
  462. this.btitem.id = res.data.data.id;
  463. this.btitem.formId = res.data.data.formid;
  464. this.btitem.versions = res.data.data.versions;
  465. this.btitem.parentId = this.bitem.id;
  466. //this.btitem.parent=this.bitem.id;
  467. this.btitem.items = res.data.data.items;
  468. this.btitem.items.DEVID = item.items.__O1qcaazksjAzDcrvJLk.value; //1
  469. this.btitem.items.EQUNR = item.items.__Q0YnOcfMqiTpVsTiDEh.value; //1
  470. this.btitem.items.EQKTX = item.items.__khn9SQnzgWNPt0aHldp.value; //1
  471. this.btitem.items.TYPBZ = item.items.__fpUc5yOsHgSHeHPFHim.value; //1
  472. this.btitem.items.CLFW = item.items.__soGLIaAxvM0O0NTVt1c.value; //1
  473. this.btitem.items.NPLDA = item.items.__G47scKcbMDon7HgDiQ5.value; //1
  474. this.btitem.items.SERGE = item.items.__3mveBfEF1si9RCAp9Sv.value; //1
  475. this.btitem.items.HERST = item.items.__aPTYvYeakxz299A7Thk.value; //1
  476. this.btitem.items.return_date = this.util.getDate('time'); //借用日期
  477. this.btitem.items.returning_state = ""; //归还状态
  478. this.btitem.items.TPLNR = item.items.__8BoEUIvmeOIjLiAwO9R.value; //1
  479. this.btitem.items.INTNUM = item.items.__dRIZk7xLPVCO6rqJbs7.value; //1
  480. this.btitem.items.NUMBER = item.items.__hImw4lGXCFmwyAx4fD8.value; //1
  481. console.log('this.btitem1:' + JSON.stringify(this.btitem));
  482. this.validate();
  483. //console.log('res2:' + JSON.stringify(res.data.data));
  484. }
  485. });
  486. });
  487. },
  488. //保存
  489. validate() {
  490. this.http.request({
  491. url: this.http.urls.validate +
  492. '?parentId=' +
  493. this.btitem.parentId,
  494. data: this.btitem,
  495. method: 'POST',
  496. success: res => {
  497. console.log('validate1:' + JSON.stringify(res));
  498. this.updateparent(this.btitem.parentId, res.data.data.id);
  499. }
  500. });
  501. },
  502. updateparent(parent, id) {
  503. this.http.request({
  504. url: this.http.urls.update_parent + 'parent=' + parent + '&id=' + id + '&table=tlk_ghlsb',
  505. method: 'POST',
  506. success: res => {
  507. console.log('validate1:' + JSON.stringify(res));
  508. }
  509. });
  510. },
  511. //提交流程面板
  512. submission() {
  513. //this.validatet();
  514. this.http.request({
  515. url: this.http.urls.documents + this.bitem.id + '/panels/submission',
  516. data: this.items,
  517. method: 'POST',
  518. success: res => {
  519. //this.item=res.data.data;
  520. //console.log('zx22:' + JSON.stringify(res));
  521. this.show = true;
  522. this.title = res.data.data.name;
  523. this.nextNodes = res.data.data.nextNodes;
  524. this.itemt.flowId = res.data.data.flowId;
  525. this.itemt.flowType = '80';
  526. this.itemt.currentNodeId = res.data.data.currentNodeId;
  527. this.itemt.attitude = '';
  528. this.itemt.signature = '';
  529. this.itemt.submitTo = '';
  530. this.itemt.circulatorInfo = '';
  531. this.itemt.subFlowApproverInfo = '';
  532. this.itemt.subFlowApproverInfoAll = '';
  533. this.itemt.document = this.items.document;
  534. //this.content=res.data.data.formname;
  535. }
  536. });
  537. }, //提交流程
  538. submit() {
  539. //this.itemt.document.items.purpose="试验目的5656";
  540. //this.itemt.document.items.title="标题5656";
  541. if (this.itemt.document.items.ghz == '' || this.itemt.document.items.ghz == null) {
  542. uni.showModal({
  543. title: '提示',
  544. content: '请填写归还人',
  545. showCancel: false,
  546. success: res => {
  547. if (res.confirm) {
  548. //uni.navigateBack();
  549. }
  550. this.ghls_empty();
  551. }
  552. });
  553. return;
  554. }
  555. /*
  556. if (this.itemt.document.items.tel == '' || this.itemt.document.items.tel == null) {
  557. uni.showModal({
  558. title: '提示',
  559. content: '请填写手机号',
  560. showCancel: false,
  561. success: res => {
  562. if (res.confirm) {
  563. //uni.navigateBack();
  564. }
  565. }
  566. });
  567. return;
  568. }
  569. */
  570. this.itemt.applicationId = '__gAPYBW4YxB3UePM3lqO';
  571. this.itemt.docId = this.iteml.id;
  572. this.itemt.id = this.iteml.id;
  573. this.itemt.formId = this.iteml.formid;
  574. this.itemt.parentId = '';
  575. this.itemt.subFlowApprover = [];
  576. this.itemt.subSelects = [];
  577. this.itemt.submitTo = [];
  578. this.itemt.templateForm = '';
  579. this.itemt.viewId = '';
  580. this.http.request({
  581. url: this.http.urls.documents + this.id + '/workflows/submit',
  582. data: this.itemt,
  583. method: 'PUT',
  584. success: res => {
  585. //this.item=res.data.data;
  586. console.log('zx22:' + JSON.stringify(res));
  587. if (res.data.errcode == 0) {
  588. uni.showModal({
  589. title: '提示',
  590. content: res.data.data,
  591. showCancel: false,
  592. success: res => {
  593. if (res.confirm) {
  594. uni.navigateBack();
  595. }
  596. }
  597. });
  598. } else {
  599. uni.showModal({
  600. title: '提示',
  601. content: res.data.errmsg,
  602. showCancel: false,
  603. success: res => {
  604. if (res.confirm) {
  605. //uni.navigateBack();
  606. }
  607. }
  608. });
  609. }
  610. this.show = false;
  611. this.title = res.data.data.name;
  612. this.nextNodes = res.data.data.nextNodes;
  613. }
  614. });
  615. }, //刷新数据
  616. //提交
  617. add() {
  618. this.http.request({
  619. url: this.http.urls.user_task_add,
  620. data: this.item,
  621. method: 'POST',
  622. success: res => {
  623. uni.showModal({
  624. title: '提示',
  625. content: '提交成功',
  626. showCancel: false,
  627. success: res => {
  628. if (res.confirm) {
  629. uni.navigateBack();
  630. }
  631. }
  632. });
  633. }
  634. });
  635. }
  636. }
  637. };
  638. </script>
  639. <style lang="scss">
  640. .page {
  641. padding-bottom: 80px;
  642. }
  643. .item {
  644. margin-bottom: 10px;
  645. }
  646. .del {
  647. width: 70%;
  648. background-color: #e64340;
  649. }
  650. </style>