微信小程序
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

410 line
11 KiB

  1. // pages/paymentManager/paymentManager.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. list:[],
  17. isLoading:false,
  18. pageNums:1,
  19. scrollHeight:"",
  20. name:"",
  21. showUpload:false,
  22. uploadOptions:[],
  23. fileList:[],
  24. showPopup:false,
  25. fileEvent:{},
  26. itemId:"",
  27. assetTypeOptions:[],
  28. option1: [
  29. { text: '支付状态', value: '' },
  30. { text: '待支付', value: '1' },
  31. { text: '银行受理', value: '3' },
  32. { text: '支付失败', value: '4' },
  33. { text: '部分失败', value: '5' },
  34. ],
  35. option2: [
  36. { text: '支出类别', value: '' },
  37. { text: '结算类', value: '1' },
  38. { text: '工程项目类', value: '2' },
  39. { text: '合同类', value: '4' },
  40. { text: '其他', value: '5' },
  41. ],
  42. option3: [
  43. { text: '申请类别', value: '' },
  44. { text: '银行卡转账', value: '1' },
  45. { text: '信用卡还款', value: '2' },
  46. ],
  47. value1: '',
  48. value2: '',
  49. value3: '',
  50. },
  51. goAdd(){
  52. wx.navigateTo({
  53. url: 'add/add',
  54. })
  55. },
  56. back:function(){
  57. wx.navigateBack({
  58. delta: 1
  59. })
  60. },
  61. assetTypeDict(val){
  62. this.data.assetTypeOptions.map(res => {
  63. if(res.dictValue == val){
  64. return res.dictLabel
  65. }
  66. })
  67. },
  68. /**
  69. * 生命周期函数--监听页面加载
  70. */
  71. onLoad(options) {
  72. var that = this;
  73. let qu = wx.createSelectorQuery()
  74. qu.select("#top_view1").boundingClientRect()
  75. qu.select("#top_ban").boundingClientRect()
  76. qu.exec(res => {
  77. that.setData({
  78. scrollHeight:wx.getSystemInfoSync().windowHeight-res[0].height-res[0].top
  79. })
  80. })
  81. this.getList();
  82. },
  83. /**
  84. * 生命周期函数--监听页面初次渲染完成
  85. */
  86. onReady() {
  87. //获取附件字典
  88. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'bookkeeping_type', {method:'GET'}, {
  89. success: (res) => {
  90. if(res.data.length>0){
  91. this.setData({
  92. uploadOptions:res.data,
  93. })
  94. }
  95. }
  96. })
  97. },
  98. getList:function(){
  99. let params = {
  100. pageNum:this.data.pageNums,
  101. pageSize:10,
  102. name:this.data.name,
  103. paymentState:this.data.value1,
  104. capitalExpenditureType:this.data.value2,
  105. transferType:this.data.value3
  106. }
  107. UTIL.httpRequest(API.URL_GET_TRANSFERPAYLIST,params,{
  108. success: (res) => {
  109. let _this = this
  110. if(res.code == 200){
  111. if(this.data.pageNums!=1&&this.data.list.length<res.total){
  112. let lists = []
  113. res.rows.map((rr,index) => {
  114. rr.expenditureAmount = Number(rr.expenditureAmount ).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, ($0, $1) => {
  115. return $1 + ","; }).replace(/\.$/, "")
  116. if(index==(res.rows.length-1)){
  117. lists = _this.data.list.concat(res.rows)
  118. }
  119. })
  120. //获取资产类别
  121. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'asset_type', {method:'GET'}, {
  122. success: (r) => {
  123. if(r.data.length>0){
  124. let li = lists.map( res => {
  125. r.data.map(rr => {
  126. if(res.assetType == rr.dictValue){
  127. res.assetType = rr.dictLabel
  128. }
  129. })
  130. return res
  131. })
  132. _this.setData({list:li})
  133. }else{
  134. _this.setData({list:lists})
  135. }
  136. }
  137. })
  138. }else if(this.data.pageNums==1){
  139. //获取资产类别
  140. UTIL.httpRequest(API.URL_GET_GETDICTTYPE + 'asset_type', {method:'GET'}, {
  141. success: (r) => {
  142. if(r.data.length>0){
  143. let li = res.rows.map( ress => {
  144. ress.originalValue = Number(ress.originalValue ).toFixed(2).replace(/(\d)(?=(\d{3})+\.)/g, ($0, $1) => {
  145. return $1 + ","; }).replace(/\.$/, "")
  146. r.data.map(rr => {
  147. if(ress.assetType == rr.dictValue){
  148. ress.assetType = rr.dictLabel
  149. }
  150. })
  151. return ress
  152. })
  153. _this.setData({list:li})
  154. }else{
  155. _this.setData({list:res.rows})
  156. }
  157. }
  158. })
  159. }
  160. }else{
  161. UTIL.showToastNoneIcon(res.msg);
  162. }
  163. }
  164. })
  165. },
  166. paging(){
  167. this.setData({
  168. pageNums:this.data.pageNums+1,
  169. })
  170. this.getList();
  171. },
  172. goSearch(e){
  173. this.setData({name:e.detail});
  174. this.setData({pageNums:1});
  175. this.getList();
  176. },
  177. toPay(e){
  178. wx.navigateTo({
  179. url: '/pages/paymentManager/toPay/toPay?id='+e.currentTarget.dataset.id,
  180. })
  181. },
  182. scrap(e){
  183. console.log(e.currentTarget.dataset.data.id,e.currentTarget.dataset.data.index);
  184. if(e.currentTarget.dataset.data.assetStatus != 1){
  185. UTIL.showToastNoneIcon('只允许修改资产状态为正常的资产!');
  186. return false;
  187. }else if(e.currentTarget.dataset.data.useType == 3){
  188. UTIL.showToastNoneIcon('使用状态为出租或出借不允许操作!');
  189. return false;
  190. }else{
  191. UTIL.httpRequest(API.URL_GET_UPDATERSCRAP + e.currentTarget.dataset.data.id , {method:'GET'}, {
  192. success: (res) => {
  193. if(res.code==200){
  194. let new_list = this.data.list
  195. new_list.splice(e.currentTarget.dataset.data.index,1)
  196. this.setData({'list':new_list})
  197. UTIL.showToastNoneIcon('报废成功!');
  198. }else{
  199. UTIL.showToastNoneIcon('报废失败!:'+res.msg);
  200. }
  201. }
  202. })
  203. }
  204. },
  205. sell(e){
  206. console.log(e.currentTarget.dataset.data.id,e.currentTarget.dataset.data.index);
  207. if(e.currentTarget.dataset.data.assetStatus != 1){
  208. UTIL.showToastNoneIcon('只允许修改资产状态为正常的资产!');
  209. return false;
  210. }else if(e.currentTarget.dataset.data.useType == 3){
  211. UTIL.showToastNoneIcon('使用状态为出租或出借不允许操作!');
  212. return false;
  213. }else{
  214. UTIL.httpRequest(API.URL_GET_UPDATERSALE + e.currentTarget.dataset.data.id , {method:'GET'}, {
  215. success: (res) => {
  216. if(res.code==200){
  217. let new_list = this.data.list
  218. new_list.splice(e.currentTarget.dataset.data.index,1)
  219. this.setData({'list':new_list})
  220. UTIL.showToastNoneIcon('出售成功!');
  221. }else{
  222. UTIL.showToastNoneIcon('出售失败!:'+res.msg);
  223. }
  224. }
  225. })
  226. }
  227. },
  228. change(e){
  229. var that = this ;
  230. that.setData({value:e.detail,pageNum:1})
  231. this.getList()
  232. },
  233. changeTab(e){
  234. var that = this ;
  235. that.setData({value1:e.detail,pageNum:1})
  236. this.getList()
  237. },
  238. changeTab2(e){
  239. var that = this ;
  240. that.setData({value2:e.detail,pageNum:1})
  241. this.getList()
  242. },
  243. upload(e){
  244. this.setData({itemId:e.currentTarget.dataset.id});
  245. this.asyncFun(e.currentTarget.dataset.id)
  246. },
  247. asyncFun(id){
  248. this.setData({"fileList":[]})
  249. let uploadList = this.data.uploadOptions
  250. let _this = this
  251. uploadList.map( (res,idx) => {
  252. res.list=[]
  253. console.log(res);
  254. let oData = {
  255. tableId: id,
  256. tableName: "t_yinnong_transfer", //上传表
  257. bizPath: "transfer",
  258. fileType: res.dictValue, //附件类型 1原始发票 2会议纪要 3会议照片 4 参会人员签字
  259. method:'GET'
  260. }
  261. UTIL.httpRequest(API.URL_GET_ATTACHMENTLIST, oData, {
  262. success: (rr) => {
  263. if(rr.rows.length>0){
  264. rr.rows.map((rrr,index) => {
  265. rrr.url = URL_PREFIX + rrr.fileUrl
  266. rrr.name = rrr.fileName
  267. if(index==rr.rows.length-1){
  268. res.list = rr.rows
  269. let lis = uploadList
  270. lis[idx] = res
  271. _this.setData({"fileList":lis});
  272. _this.setData({"showUpload":true})
  273. }
  274. })
  275. }
  276. else{
  277. _this.setData({"showUpload":true})
  278. }
  279. }
  280. })
  281. })
  282. },
  283. closeBox(){
  284. this.setData({"showUpload":false})
  285. },
  286. uploadFile(uploadFile,event) {
  287. let _this = this
  288. return new Promise((resolve, reject) => {
  289. wx.uploadFile({
  290. url: API.URL_GET_UPLOAD,
  291. filePath: uploadFile.file.file.url,
  292. name: 'file',
  293. header: {
  294. "Content-Type": "multipart/form-data",//记得设置
  295. "chartset":"utf-8",
  296. 'Authorization':'Bearer '+getApp().globalData.userInfo.token
  297. },
  298. formData:uploadFile,
  299. success: (res) => {
  300. res.data = JSON.parse(res.data);
  301. if(res.statusCode == 200){
  302. let files = _this.data.fileList
  303. let fName = res.data.fileUrl.split('/')
  304. let fLength = fName.length
  305. files[event.currentTarget.dataset.idx].list.push({
  306. "fileName": fName[fLength-1],
  307. "name":fName[fLength-1],
  308. "fileType": "0",
  309. "fileUrl":res.data.fileUrl ,
  310. "id": res.data.id,
  311. "tableId": 6,
  312. "url":URL_PREFIX+res.data.fileUrl
  313. })
  314. _this.setData({"fileList":files})
  315. wx.hideLoading()
  316. }
  317. },
  318. fail: (err) => {
  319. //上传失败:修改pedding为reject
  320. reject(err)
  321. }
  322. });
  323. })
  324. },
  325. afterRead(event) {
  326. let _this = this
  327. wx.showLoading({
  328. title: '上传中...'
  329. })
  330. let fileForm={
  331. file: event.detail,
  332. fileType:event.currentTarget.dataset.idx,
  333. tableName: "t_yinnong_transfer", //上传表
  334. bizPath: "transfer",
  335. tableId:_this.data.itemId
  336. }
  337. this.uploadFile(fileForm,event)
  338. },
  339. lookDown(e){
  340. let file =e
  341. // 获取指定字符串最后一次出现的位置,返回index
  342. var index1 = file.detail.url.lastIndexOf('.');
  343. // substr(start, length) 抽取从start下标开始的length个字符,返回新的字符串;
  344. var style = file.detail.url.substr(index1 + 1)
  345. //判断图片类型,不需要下载,不做处理
  346. if(style=='png'||style=='jpg'||style=='jpeg'||style=='bmp'||style=='gif'||style=='webp'||style=='psd'||style== 'svg'||style=='tiff'){
  347. //判断非图片类型
  348. }else{
  349. wx.downloadFile({
  350. url: file.detail.url,
  351. success(data){
  352. wx.openDocument({
  353. filePath: data.tempFilePath,
  354. fileType: style,
  355. showMenu:true,
  356. success(res){
  357. }
  358. })
  359. }
  360. })
  361. }
  362. },
  363. /**
  364. * 生命周期函数--监听页面显示
  365. */
  366. onShow() {
  367. this.setData({'pageNums':1})
  368. this.getList();
  369. },
  370. /**
  371. * 生命周期函数--监听页面隐藏
  372. */
  373. onHide() {
  374. },
  375. /**
  376. * 生命周期函数--监听页面卸载
  377. */
  378. onUnload() {
  379. },
  380. /**
  381. * 页面相关事件处理函数--监听用户下拉动作
  382. */
  383. onPullDownRefresh() {
  384. },
  385. /**
  386. * 页面上拉触底事件的处理函数
  387. */
  388. onReachBottom() {
  389. },
  390. /**
  391. * 用户点击右上角分享
  392. */
  393. onShareAppMessage() {
  394. }
  395. })