upload.js 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444
  1. // pages/upload/upload.js
  2. const app = getApp()
  3. const $api = require('../../utils/api.js').API;
  4. Page({
  5. /**
  6. * 页面的初始数据
  7. */
  8. data: {
  9. open:true,
  10. stock_date:'',
  11. stock:[{name:'',fund:''}],
  12. stockList:[],
  13. today_stock_img:[],
  14. value:[-1],
  15. is_markt:0,
  16. today_fund:'',
  17. change:0,
  18. experience:'',
  19. cur:0,
  20. freshen:true,
  21. disable:false,
  22. id:0,
  23. images:[],
  24. },
  25. /**
  26. * 生命周期函数--监听页面加载
  27. */
  28. onShow(){
  29. if (!this.data.freshen) {
  30. return;
  31. }
  32. this.setData({
  33. disable: false
  34. })
  35. $api.initUser()
  36. wx.getStorage({
  37. key: 'user',
  38. complete: res => {
  39. this.setData({
  40. role: res.data.role,
  41. })
  42. }
  43. })
  44. $api.getCurrecord().then(res=>{
  45. if (!res.data.data.id){return}
  46. let stock = res.data.data.today_stock
  47. this.setData({
  48. stock: stock.length > 0 ? stock : [{ name: '', fund: '' }],
  49. today_stock_img: res.data.data.today_stock_img,
  50. today_fund: res.data.data.today_fund,
  51. is_markt: res.data.data.is_markt,
  52. change: 1,
  53. experience: res.data.data.experience,
  54. id:res.data.data.id
  55. })
  56. })
  57. },
  58. onLoad: function (options) {
  59. var y=new Date().getFullYear()
  60. var m=Number(new Date().getMonth() + 1)
  61. var d = new Date().getDate()
  62. m=m>9?m:'0'+m;
  63. d=d>9?d:'0'+d
  64. this.setData({
  65. stock_date:y+'-'+m+'-'+d
  66. })
  67. },
  68. /**添加持股 */
  69. add(){
  70. var stock = this.data.stock;
  71. var value=this.data.value;
  72. stock.push({ name: '', fund: '' })
  73. value.push(-1)
  74. this.setData({
  75. stock: stock,
  76. value: value
  77. })
  78. },
  79. del(e){
  80. var i = e.target.dataset.id;
  81. var stock = this.data.stock;
  82. var value = this.data.value;
  83. stock.splice(i,1)
  84. value.splice(i,1)
  85. this.setData({
  86. stock: stock,
  87. value: value
  88. })
  89. },
  90. delToday(e){
  91. this.setData({
  92. today_fund: '',
  93. })
  94. },
  95. bindPickerChange(e){
  96. var i=this.data.cur;
  97. var v = e.target.dataset.name
  98. var stock=this.data.stock;
  99. stock[i].name = v
  100. stock[i].code = e.target.dataset.id
  101. this.setData({
  102. stock: stock
  103. })
  104. setTimeout(()=>{
  105. this.setData({
  106. stockList: []
  107. },50)
  108. })
  109. return;
  110. },
  111. stockSearch(e){
  112. if (e.detail.value == ''){
  113. this.setData({
  114. stockList: []
  115. })
  116. return
  117. }
  118. var i = e.target.dataset.id;
  119. var v = e.detail.value
  120. var stock = this.data.stock;
  121. stock[i].name = v;
  122. this.setData({
  123. stock: stock
  124. })
  125. $api.searchStock({ name: e.detail.value}).then(res=>{
  126. this.setData({
  127. stockList:res.data.data,
  128. cur:e.target.dataset.id
  129. })
  130. })
  131. },
  132. blur(){
  133. // console.log(233)
  134. this.setData({
  135. stockList: []
  136. })
  137. },
  138. nameChange(e){
  139. console.log(e)
  140. var i = e.target.dataset.id;
  141. var v = e.detail.value
  142. var stock = this.data.stock;
  143. stock[i].name = v;
  144. this.setData({
  145. stock: stock
  146. })
  147. },
  148. fundChange(e){
  149. var i = e.target.dataset.id;
  150. var v = e.detail.value
  151. var stock = this.data.stock;
  152. if (v.split('.').length > 1 && v.split('.')[1].length > 4) {
  153. v = Math.floor(Number(v) * 10000) / 10000
  154. }
  155. stock[i].fund = v;
  156. this.setData({
  157. stock: stock
  158. })
  159. },
  160. fundChange1(e) {
  161. var v = e.detail.value
  162. if (v.split('.').length > 1 && v.split('.')[1].length > 4){
  163. v = Math.floor(Number(v)*10000)/10000
  164. }
  165. this.setData({
  166. today_fund: v
  167. })
  168. },
  169. expChange(e){
  170. var v = e.detail.value
  171. this.setData({
  172. experience: v
  173. })
  174. },
  175. switch1Change(e){
  176. this.setData({
  177. is_markt: Number(e.detail.value)
  178. })
  179. },
  180. uploadImg() {
  181. var today_stock_img = this.data.today_stock_img;
  182. wx.chooseImage({
  183. success: res => {
  184. wx.showLoading({
  185. title: '正在上传',
  186. })
  187. const tempFilePaths = res.tempFiles
  188. for (let i = 0; i < tempFilePaths.length; i++) {
  189. $api.upload(tempFilePaths[i].path, 'file').then(res => {
  190. wx.hideLoading()
  191. if (res.code == 0) {
  192. console.log(res.data)
  193. today_stock_img.push(res.data.url)
  194. this.setData({
  195. today_stock_img: today_stock_img
  196. })
  197. console.log(this.data.today_stock_img,22222222222)
  198. if (i==0 && today_stock_img.length == 1){
  199. this.loadOcr(tempFilePaths[i].path,res.data.url)
  200. }
  201. } else {
  202. wx.showToast({
  203. title: '上传失败',
  204. })
  205. }
  206. })
  207. .catch(err => {
  208. wx.hideLoading()
  209. })
  210. }
  211. }
  212. })
  213. },
  214. loadOcr(path,url){
  215. var _this = this
  216. wx.getImageInfo({
  217. src:path,
  218. success:function(ires){
  219. _this.loadImageOcr(url,ires.width < ires.height ? 'phone':'pc')
  220. }
  221. })
  222. },
  223. loadImageOcr(img_url,source){
  224. var _this = this
  225. var param = {
  226. img_url:img_url.split('?')[0],
  227. source:source,
  228. }
  229. console.log('img_url',param['img_url'])
  230. console.log('source',param['source'])
  231. $api.imageOcr(param).then(res => {
  232. console.log('ocr',res)
  233. if(res.data.code == 0){
  234. _this.setData({
  235. today_fund:res.data.data.today,
  236. stock:res.data.data.list
  237. })
  238. }
  239. })
  240. },
  241. startOcr(e){
  242. var index = e.target.dataset.index;
  243. var img_url = this.data.today_stock_img[index]
  244. console.log('startocr',img_url)
  245. this.loadImageOcr(img_url,this.data.images[index].width < this.data.images[index].height ? 'phone':'pc')
  246. },
  247. imageLoad: function(e) {
  248. var width=e.detail.width; //获取图片真实宽度
  249. var height=e.detail.height;
  250. var image=this.data.images;
  251. //将图片的datadata-index作为image对象的key,然后存储图片的宽高值
  252. image[e.target.dataset.index]={
  253. width:width,
  254. height:height,
  255. }
  256. this.setData({
  257. images:image
  258. })
  259. },
  260. del1(e) {
  261. var i = e.target.dataset.id;
  262. var today_stock_img = this.data.today_stock_img;
  263. today_stock_img.splice(i, 1)
  264. this.setData({
  265. today_stock_img: today_stock_img
  266. })
  267. },
  268. prview(e){
  269. var src = e.target.dataset.src;
  270. wx.previewImage({
  271. current: src, // 当前显示图片的http链接
  272. urls: [src] // 需要预览的图片http链接列表
  273. })
  274. },
  275. post(){
  276. var stocks = []
  277. var slist = this.data.stock
  278. for(let i=0;i<slist.length;i++){
  279. if(slist[i].name.length <= 0){
  280. continue;
  281. }
  282. if(slist[i].fund > 5000){
  283. wx.showToast({
  284. icon: 'none',
  285. title: '持仓金额单位为万'
  286. })
  287. return;
  288. }
  289. stocks.push(slist[i])
  290. }
  291. var parm = {
  292. stock_date: this.data.stock_date,
  293. today_stock: stocks,
  294. is_markt: this.data.is_markt,
  295. today_stock_img: this.data.today_stock_img,
  296. today_fund: Number(this.data.today_fund),
  297. id:this.data.id,
  298. experience: this.data.experience
  299. }
  300. if (!parm.today_fund) {
  301. wx.showToast({
  302. icon: 'none',
  303. title: '请输入今日净资产'
  304. })
  305. return
  306. }
  307. if (parm.today_fund >= 10000) {
  308. wx.showToast({
  309. icon: 'none',
  310. title: '今日净资产单位为万'
  311. })
  312. return
  313. }
  314. // if (!parm.is_markt) {
  315. // // for (let i = 0; i < parm.today_stock.length;i++){
  316. // // if (!parm.today_stock[i].name || !parm.today_stock[i].fund) {
  317. // // wx.showToast({
  318. // // icon: 'none',
  319. // // title: '请选择股票并输入资金额'
  320. // // })
  321. // // return;
  322. // // break;
  323. // // }
  324. // // }
  325. // } else {
  326. // parm.today_stock = []
  327. // }
  328. console.log(parm)
  329. if (parm.today_stock_img.length <= 0) {
  330. wx.showToast({
  331. icon: 'none',
  332. title: '请上传截图'
  333. })
  334. return
  335. }
  336. wx.showLoading({
  337. title: '正在提交',
  338. })
  339. this.setData({
  340. disable: true
  341. })
  342. $api.updateRecord(parm).then(res => {
  343. wx.hideLoading()
  344. wx.showToast({
  345. title: '提交成功',
  346. })
  347. this.setData({
  348. freshen: true,
  349. disable: false
  350. })
  351. setTimeout(() => {
  352. this.setData({
  353. stock: [{ label: '', name: '', code: '', fund: '' }],
  354. stockList: [],
  355. today_stock_img: [],
  356. value: [-1],
  357. is_markt: 0,
  358. today_fund: ''
  359. })
  360. wx.switchTab({
  361. url: '../user/user',
  362. })
  363. }, 200)
  364. })
  365. .catch(
  366. this.setData({
  367. disable:false
  368. })
  369. )
  370. },
  371. /**
  372. * 生命周期函数--监听页面初次渲染完成
  373. */
  374. onReady: function () {
  375. },
  376. /**
  377. * 生命周期函数--监听页面隐藏
  378. */
  379. onHide: function () {
  380. },
  381. /**
  382. * 生命周期函数--监听页面卸载
  383. */
  384. onUnload: function () {
  385. },
  386. /**
  387. * 页面相关事件处理函数--监听用户下拉动作
  388. */
  389. onPullDownRefresh: function () {
  390. },
  391. /**
  392. * 页面上拉触底事件的处理函数
  393. */
  394. onReachBottom: function () {
  395. },
  396. /**
  397. * 用户点击右上角分享
  398. */
  399. onShareAppMessage: function () {
  400. }
  401. })