微信小程序
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

bankDraft.js 11 KiB

3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
3年前
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407
  1. // pages/bankDraft/bankDraft.js
  2. import * as UTIL from '../../utils/util.js';
  3. import * as API from '../../utils/API.js';
  4. let EVN_CONFIG = require('../../env/env');
  5. const DISTRIBUTE_ENVIROMENT = 'IMGURL';
  6. let {
  7. URL_PREFIX,
  8. } = EVN_CONFIG[DISTRIBUTE_ENVIROMENT];
  9. const app = getApp();
  10. Page({
  11. /**
  12. * 页面的初始数据
  13. */
  14. data: {
  15. isIPX: app.globalData.isIPX,
  16. option1: [
  17. { text: '汇票类型', value: '' },
  18. { text: '银行承兑', value: '1' },
  19. { text: '商业承兑', value: '2' },
  20. ],
  21. option2: [
  22. { text: '汇票状态', value: '' },
  23. { text: '在库', value: '1' },
  24. { text: '转付中', value: '2' },
  25. { text: '转付', value: '3' },
  26. { text: '承兑', value: '4' },
  27. ],
  28. value1: '',
  29. value2: '',
  30. moneyorderList:[],
  31. value:'',
  32. pageNums:1,
  33. showUpload:false,
  34. showPopupDel:false,
  35. uploadOptions:[],
  36. fileList:[],
  37. itemId:"",
  38. itemIndex:"",
  39. list:[],
  40. fileEvent:{},
  41. },
  42. /**
  43. * 生命周期函数--监听页面加载
  44. */
  45. onLoad(options) {
  46. var _this = this;
  47. let qu = wx.createSelectorQuery()
  48. qu.select("#top_view").boundingClientRect()
  49. qu.select("#top_ban").boundingClientRect()
  50. qu.select("#top_view1").boundingClientRect()
  51. qu.select("#top_view2").boundingClientRect()
  52. qu.exec(res => {
  53. _this.setData({
  54. scrollHeight:wx.getSystemInfoSync().windowHeight-res[3].top
  55. })
  56. })
  57. //获取附件字典
  58. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'common_attach', {method:'GET'}, {
  59. success: (res) => {
  60. this.setData({
  61. uploadOptions:res.data,
  62. })
  63. }
  64. })
  65. },
  66. goAdd(){
  67. wx.navigateTo({
  68. url: 'add/add',
  69. })
  70. },
  71. back:function(){
  72. wx.navigateBack({
  73. delta: 1
  74. })
  75. },
  76. /**
  77. * 生命周期函数--监听页面初次渲染完成
  78. */
  79. onReady() {
  80. },
  81. goUpdate(e){
  82. wx.navigateTo({
  83. url: 'add/add?id='+ e.currentTarget.dataset.id,
  84. })
  85. },
  86. goSearch(e){
  87. this.setData({'value':e.detail})
  88. this.onShow();
  89. },
  90. paging(){
  91. this.setData({
  92. pageNums:this.data.pageNums+1,
  93. })
  94. this.onShow();
  95. },
  96. /**
  97. * 生命周期函数--监听页面显示
  98. */
  99. onShow() {
  100. var that = this;
  101. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'order_type', {method:'GET'}, {
  102. success: (res) => {
  103. this.setData({
  104. orderTypeOptions:res.data
  105. });
  106. let param = {
  107. 'orderType':that.data.value1,
  108. 'orderStatus':that.data.value2,
  109. 'billPayUnit' : this.data.value,
  110. pageNum:this.data.pageNums,
  111. pageSize:10,
  112. }
  113. UTIL.httpRequest(API.URL_GET_GETMONEYORDERLIST, param,{
  114. success: (response) => {
  115. if (response.code == API.SUCCESS_CODE) {
  116. for (let i = 0; i < response.rows.length; i++) {
  117. response.rows[i].orderTypeText = UTIL.getTransform(response.rows[i].orderType,res.data);
  118. response.rows[i].orderAmount = Number(response.rows[i].orderAmount).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, ($0, $1) => {
  119. return $1 + ","; }).replace(/\.$/, "")
  120. }
  121. that.setData({
  122. moneyorderList:response.rows
  123. })
  124. }
  125. }
  126. })
  127. }
  128. })
  129. },
  130. delete(e){
  131. this.setData({
  132. 'itemId':e.currentTarget.dataset.id,
  133. 'itemIndex':e.currentTarget.dataset.index,
  134. "showPopupDel":true
  135. });
  136. },
  137. cancelTemDel:function(e){
  138. this.setData({
  139. "itemId":"",
  140. "itemIndex":"",
  141. "showPopupDel":false
  142. });
  143. },
  144. confirmTemDel:function(e){
  145. this.setData({
  146. "showPopupDel":false
  147. });
  148. UTIL.httpRequest(API.URL_GET_MONEYORDERDELETE + this.data.itemId , {method:'GET'}, {
  149. success: (res) => {
  150. if(res.code==200){
  151. let new_list = this.data.moneyorderList
  152. new_list.splice(this.data.index,1)
  153. this.setData({'moneyorderList':new_list})
  154. UTIL.showToastNoneIcon('删除成功!');
  155. }else{
  156. UTIL.showToastNoneIcon('删除失败!');
  157. }
  158. }
  159. })
  160. },
  161. changeTab(e){
  162. var that = this ;
  163. that.setData({value1:e.detail})
  164. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'order_type', {method:'GET'}, {
  165. success: (res) => {
  166. UTIL.httpRequest(API.URL_GET_GETMONEYORDERLIST, {method:'GET',orderType:that.data.value1,orderStatus:that.data.value2},{
  167. success: (response) => {
  168. if (response.code == API.SUCCESS_CODE) {
  169. for (let i = 0; i < response.rows.length; i++) {
  170. response.rows[i].orderTypeText = UTIL.getTransform(response.rows[i].orderType,res.data);
  171. response.rows[i].startTime = response.rows[i].startTime.replace(/-/g,".");
  172. response.rows[i].endTime = response.rows[i].endTime.replace(/-/g,".");
  173. response.rows[i].orderAmount = parseFloat(response.rows[i].orderAmount).toFixed(2);
  174. }
  175. that.setData({
  176. moneyorderList:response.rows
  177. })
  178. }
  179. }
  180. })
  181. }
  182. })
  183. },
  184. changeTab2(e){
  185. var that = this ;
  186. that.setData({value2:e.detail})
  187. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'order_type', {method:'GET'}, {
  188. success: (res) => {
  189. UTIL.httpRequest(API.URL_GET_GETMONEYORDERLIST, {method:'GET',orderType:that.data.value1,orderStatus:that.data.value2},{
  190. success: (response) => {
  191. if (response.code == API.SUCCESS_CODE) {
  192. for (let i = 0; i < response.rows.length; i++) {
  193. response.rows[i].orderTypeText = UTIL.getTransform(response.rows[i].orderType,res.data);
  194. response.rows[i].startTime = response.rows[i].startTime.replace(/-/g,".");
  195. response.rows[i].endTime = response.rows[i].endTime.replace(/-/g,".");
  196. response.rows[i].orderAmount = parseFloat(response.rows[i].orderAmount).toFixed(2);
  197. }
  198. that.setData({
  199. moneyorderList:response.rows
  200. })
  201. }
  202. }
  203. })
  204. }
  205. })
  206. },
  207. upload(e){
  208. this.setData({itemId:e.currentTarget.dataset.id});
  209. this.asyncFun(e.currentTarget.dataset.id)
  210. },
  211. asyncFun(id){
  212. this.setData({"fileList":[]})
  213. let uploadList = this.data.uploadOptions
  214. let newList = []
  215. let _this = this
  216. uploadList.map( res => {
  217. let oData = {
  218. tableId: id,
  219. tableName: "t_yinnong_moneyorder", //上传表
  220. bizPath: "yinnong",
  221. fileType: res.dictValue, //附件类型 1原始发票 2会议纪要 3会议照片 4 参会人员签字
  222. method:'GET'
  223. }
  224. UTIL.httpRequest(API.URL_GET_ATTACHMENTLIST, oData, {
  225. success: (rr) => {
  226. if(rr.code==200&&rr.rows.length>0){
  227. rr.rows.map((rrr,index) => {
  228. rrr.url = URL_PREFIX + rrr.fileUrl
  229. if(index==rr.rows.length-1){
  230. newList.push(Object.assign({},res,{"list":rr.rows}))
  231. _this.setData({"fileList":_this.data.fileList.concat(newList)});
  232. _this.setData({"showUpload":true})
  233. }
  234. })
  235. }else{
  236. let newuploadList = uploadList
  237. newuploadList.map(rd => {
  238. rd.list = newList
  239. })
  240. _this.setData({"fileList":newuploadList});
  241. _this.setData({"showUpload":true})
  242. }
  243. },
  244. fail:(rr) =>{
  245. },
  246. complete:(rr) => {
  247. }
  248. })
  249. })
  250. },
  251. closeBox(){
  252. this.setData({"showUpload":false})
  253. },
  254. deleteImg(event){
  255. this.setData({"fileEvent":event})
  256. this.setData({"showPopup":true});
  257. },
  258. cancelTem:function(e){
  259. this.setData({"fileEvent":"{}"});
  260. this.setData({"showPopup":false});
  261. },
  262. confirmTem:function(e){
  263. let event = this.data.fileEvent
  264. UTIL.httpRequest(API.URL_GET_GETFILEREMOVE+event.detail.file.id , {method:'GET'}, {
  265. success: (res) => {
  266. if(res.code==200){
  267. let ll = this.data.fileList
  268. var jsonlist = ll[event.target.dataset.idx].list;
  269. jsonlist.splice(event.detail.index, 1)
  270. ll[event.target.dataset.idx].list = jsonlist
  271. this.setData({"fileList":ll})
  272. this.setData({showPopup:false});
  273. wx.showToast({
  274. title: '删除成功!',
  275. icon: 'success',
  276. duration: 2000,
  277. })
  278. }
  279. }
  280. })
  281. },
  282. uploadFile(uploadFile,event) {
  283. let _this = this
  284. return new Promise((resolve, reject) => {
  285. wx.uploadFile({
  286. url: API.URL_GET_UPLOAD,
  287. filePath: uploadFile.file.file.url,
  288. name: 'file',
  289. header: {
  290. "Content-Type": "multipart/form-data",//记得设置
  291. "chartset":"utf-8",
  292. 'Authorization':'Bearer '+getApp().globalData.userInfo.token
  293. },
  294. formData:uploadFile,
  295. success: (res) => {
  296. res.data = JSON.parse(res.data);
  297. if(res.statusCode == 200){
  298. let files = _this.data.fileList
  299. let fName = res.data.fileUrl.split('/')
  300. let fLength = fName.length
  301. files[event.currentTarget.dataset.idx].list.push({
  302. "fileName": fName[fLength-1],
  303. "fileType": "0",
  304. "fileUrl":res.data.fileUrl ,
  305. "id": res.data.id,
  306. "tableId": 6,
  307. "url":URL_PREFIX+res.data.fileUrl
  308. })
  309. _this.setData({"fileList":files})
  310. wx.hideLoading()
  311. }
  312. },
  313. fail: (err) => {
  314. //上传失败:修改pedding为reject
  315. reject(err)
  316. }
  317. });
  318. })
  319. },
  320. afterRead(event) {
  321. let _this = this
  322. wx.showLoading({
  323. title: '上传中...'
  324. })
  325. let fileForm={
  326. file: event.detail,
  327. fileType:event.currentTarget.dataset.idx,
  328. tableName: "t_yinnong_moneyorder", //上传表
  329. bizPath: "yinnong",
  330. tableId:_this.data.itemId
  331. }
  332. this.uploadFile(fileForm,event)
  333. },
  334. lookDown(file,detail){
  335. // 获取指定字符串最后一次出现的位置,返回index
  336. var index1 = file.detail.url.lastIndexOf('.');
  337. // substr(start, length) 抽取从start下标开始的length个字符,返回新的字符串;
  338. var style = file.detail.url.substr(index1 + 1)
  339. //判断图片类型,不需要下载,不做处理
  340. if(style=='png'||style=='jpg'||style=='jpeg'||style=='bmp'||style=='gif'||style=='webp'||style=='psd'||style== 'svg'||style=='tiff'){
  341. //判断非图片类型
  342. }else{
  343. wx.downloadFile({
  344. url: file.detail.url,
  345. success(data){
  346. wx.openDocument({
  347. filePath: data.tempFilePath,
  348. fileType: style,
  349. showMenu:true,
  350. success(res){
  351. }
  352. })
  353. }
  354. })
  355. }
  356. },
  357. /**
  358. * 生命周期函数--监听页面隐藏
  359. */
  360. onHide() {
  361. },
  362. /**
  363. * 生命周期函数--监听页面卸载
  364. */
  365. onUnload() {
  366. },
  367. /**
  368. * 页面相关事件处理函数--监听用户下拉动作
  369. */
  370. onPullDownRefresh() {
  371. },
  372. /**
  373. * 页面上拉触底事件的处理函数
  374. */
  375. onReachBottom() {
  376. },
  377. /**
  378. * 用户点击右上角分享
  379. */
  380. onShareAppMessage() {
  381. }
  382. })