rechargeRecord.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. <template>
  2. <view>
  3. <u-navbar title="充值记录" title-color="#101010"></u-navbar>
  4. <!-- 折线图 -->
  5. <view class="chart-box">
  6. <view class="chart">
  7. <view id="pieEcharts" >
  8. </view>
  9. </view>
  10. </view>
  11. <!-- 标签 -->
  12. <view class="tabs">
  13. <u-picker v-model="tabsFrom.show1" :default-selector="[tabsFrom.show1Index]"
  14. mode="selector" :range="tabsFrom.selector1" range-key="label" @confirm="selector1confirm" ></u-picker>
  15. <u-picker-select title="日期选择" v-model="tabsFrom.show2"
  16. :defaultTime="tabsFrom.show2Index" :endYear="endYear"
  17. mode="time" :params="params" @confirm="selector2confirm" @reset="selector2reset" ></u-picker-select>
  18. <view class="tabsItem" @click="tabsFrom.show1=!tabsFrom.show1">{{tabsFrom.show1Text}} <u-icon name="arrow-up"
  19. v-if="tabsFrom.show1"></u-icon><u-icon v-else name="arrow-down"></u-icon></view>
  20. <view class="tabsItem" @click="tabsFrom.show2=!tabsFrom.show2">{{tabsFrom.show2Text}} <u-icon name="arrow-up"
  21. v-if="tabsFrom.show2"></u-icon><u-icon v-else name="arrow-down"></u-icon></view>
  22. </view>
  23. <!-- 记录 -->
  24. <view class="records" >
  25. <view class="time">
  26. {{queryMonth}} 充值 {{jpAmount(sumAmount)}}元
  27. </view>
  28. <view class="details" v-for="(item,i) in list" :key="i">
  29. <view class="details-title">
  30. <view class="name">
  31. {{item.remark}}-{{item.methodN}}
  32. </view>
  33. <view class="record-time" v-if="item.extraInfo" v-html="extraInfoText(item.extraInfo)" >
  34. </view>
  35. <view class="record-time">
  36. {{item.createTime}}
  37. </view>
  38. </view>
  39. <view class="sum">
  40. {{jpAmount(item.amount)}}
  41. </view>
  42. </view>
  43. <u-divider :isnone="list.length==0" nonetext="没有找到相关内容"
  44. border-color="#CFD2D5">已经到底了</u-divider>
  45. </view>
  46. </view>
  47. </template>
  48. <script>
  49. import * as API from '@/apis/pagejs/deduction.js'
  50. import {
  51. nextDay,
  52. nextMonth,
  53. } from '@/apis/utils'
  54. import * as echarts from "echarts";
  55. export default {
  56. data() {
  57. return {
  58. myChart:null,
  59. list:[],
  60. formData:{
  61. pageIndex:1,
  62. pageSize:9999,
  63. },
  64. endYear:'',
  65. queryMonth:"",
  66. params: {
  67. year: true,
  68. month: true,
  69. day: true,
  70. hour: false,
  71. minute: false,
  72. second: false
  73. },
  74. tabsFrom: {
  75. show1: false,
  76. show1Index:0,
  77. show2Index:'',
  78. show2: false,
  79. show1Text: "全部类型",
  80. show2Text: "全部时间",
  81. selector1:[
  82. {
  83. label: '全部类型',
  84. value: '',
  85. },
  86. {
  87. label: '线上充值',
  88. value: '1',
  89. },
  90. {
  91. label: '线下充值',
  92. value: '2',
  93. },
  94. ]
  95. },
  96. }
  97. },
  98. onLoad() {
  99. this.endYear=new Date().getFullYear()
  100. var date=new Date()
  101. this.formData.startDate=date.getFullYear()+"-"+(date.getMonth() + 1) +"-1"
  102. this.queryMonth=date.getFullYear()+"年"+(date.getMonth() + 1) +"月"
  103. this.rechargeRecord();
  104. this.rechargeRecordGraph();
  105. },
  106. computed:{
  107. sumAmount(){
  108. let totalAmount =0
  109. if(this.list){
  110. var amounts=this.list.map(item=>{
  111. return item.amount
  112. })
  113. totalAmount = amounts.reduce((accumulator, currentValue) => {
  114. return accumulator + currentValue;
  115. }, 0);
  116. }
  117. return totalAmount
  118. }
  119. },
  120. methods:{
  121. extraInfoText(extraInfo){
  122. var obj=JSON.parse(extraInfo)
  123. if(obj.outOrderNo){
  124. return `充值订单编号:${obj.outOrderNo}`
  125. }else{
  126. return ''
  127. }
  128. },
  129. selector2confirm(e){
  130. this.tabsFrom.show2Text=e.year+"年"+e.month+"月"
  131. this.tabsFrom.show2Index=e.year+"-"+e.month
  132. if(e.day){
  133. this.tabsFrom.show2Text+=e.day+"日"
  134. this.tabsFrom.show2Index+='-'+e.day
  135. }
  136. //this.tabsFrom.show2Index=this.tabsFrom.show2Text
  137. if(e.day){
  138. this.formData.startDate=e.year+"-"+e.month +"-"+e.day
  139. this.queryMonth=e.year+"年"+e.month+"月"+e.day+"日"
  140. this.formData.endDate=this.formData.startDate
  141. //nextDay(e.year,e.month, e.day)
  142. }else{
  143. this.queryMonth=e.year+"年"+e.month+"月"
  144. this.formData.startDate=e.year+"-"+e.month +"-1"
  145. this.formData.endDate=nextMonth(e.year,e.month, 1,1)
  146. }
  147. this.rechargeRecord()
  148. },
  149. selector2reset(e){
  150. this.tabsFrom.show2Text='全部时间'
  151. this.tabsFrom.show2Index='';
  152. this.formData.startDate=date.getFullYear()+"-"+(date.getMonth() + 1) +"-1"
  153. this.queryMonth=date.getFullYear()+"年"+(date.getMonth() + 1)+"月"
  154. this.rechargeRecord()
  155. },
  156. selector1confirm(e){
  157. var index=e[0]
  158. this.tabsFrom.show1Index=index
  159. this.tabsFrom.show1Text=this.tabsFrom.selector1[index].label
  160. this.formData.type=this.tabsFrom.selector1[index].value
  161. this.rechargeRecord()
  162. },
  163. rechargeRecordGraph(){
  164. API.rechargeRecordGraph().then((response) => {
  165. var list=response.data;
  166. // uni.getSystemInfo({
  167. // success: (res) => {
  168. // const screenWidth = res.windowWidth; // 屏幕宽度,单位为px
  169. // console.log('屏幕宽度:', screenWidth);
  170. // },
  171. // });
  172. this.getPle(list)
  173. //uni.upx2px(600)
  174. }).catch(error => {
  175. uni.showToast({
  176. title: error,
  177. icon: "none"
  178. })
  179. })
  180. },
  181. getPle(list){
  182. if (!this.myChart) {
  183. this.myChart = echarts.init(document.getElementById('pieEcharts'),null,{
  184. width:uni.upx2px(700),height:uni.upx2px(280)
  185. });
  186. }
  187. this.myChart.clear();
  188. var data1=list.map(item=>{
  189. return item.month.replace("-", "年")+"月"
  190. });
  191. var data2=list.map(item=>{
  192. return item.monthAmount
  193. });
  194. var headitemby=""
  195. var showkey = "";
  196. var option = {
  197. tooltip: {
  198. trigger: 'axis'
  199. },
  200. grid: {
  201. top: '6%',
  202. left: '3%',
  203. right: '8%',
  204. bottom: '8%',
  205. containLabel: true
  206. },
  207. xAxis: {
  208. type: 'category',
  209. data: data1,
  210. axisLabel: {
  211. formatter: (value) => {
  212. if (headitemby == "") {
  213. headitemby = value
  214. }
  215. var i = 0
  216. var showvalue = "";
  217. var key = value.substring(0, 5);
  218. if (showkey == "" || value == headitemby) {
  219. showkey = key
  220. showvalue = value
  221. showvalue = value.substring(2)
  222. } else {
  223. if (key != showkey) {
  224. showkey = key
  225. showvalue = value
  226. showvalue = value.substring(2)
  227. } else {
  228. showvalue = value.substring(5)
  229. }
  230. }
  231. return showvalue.replace("年", ".").replace("月", "");
  232. },
  233. textStyle: {
  234. color: "#333"
  235. }
  236. },
  237. },
  238. yAxis: {
  239. type: 'value'
  240. },
  241. series: [
  242. {
  243. name: '合计',
  244. data: data2,
  245. type: 'line'
  246. }
  247. ]
  248. }
  249. console.log(option)
  250. this.myChart.setOption(option);
  251. },
  252. rechargeRecord(){
  253. uni.showLoading({
  254. mask:true,title:'加载中...'
  255. })
  256. API.rechargeRecord(this.formData).then((response) => {
  257. uni.hideLoading();
  258. this.list=response.data.data;
  259. }).catch(error => {
  260. uni.hideLoading();
  261. uni.showToast({
  262. title: error,
  263. icon: "none"
  264. })
  265. })
  266. },
  267. }
  268. }
  269. </script>
  270. <style lang="scss" scoped>
  271. // 折线图
  272. .chart-box {
  273. padding: 24rpx 32rpx;
  274. background: linear-gradient(180deg, rgba(203, 234, 255, 1) 0%, rgba(255, 255, 255, 1) 100%);
  275. .title {
  276. color: rgb(16, 16, 16);
  277. }
  278. .sum {
  279. color: rgb(51, 51, 51);
  280. font-size: 64rpx;
  281. margin-top: 16rpx;
  282. .unit {
  283. color: rgb(16, 16, 16);
  284. font-size: 28rpx;
  285. margin-left: 8rpx;
  286. }
  287. }
  288. .chart {
  289. width: 100%;
  290. height: 240rpx;
  291. margin-top: 8rpx;
  292. .img {
  293. width: 100%;
  294. height: 100%;
  295. }
  296. }
  297. }
  298. // 标签
  299. .tabs {
  300. height: 96rpx;
  301. line-height: 96rpx;
  302. background-color: #fff;
  303. border-top: 1px solid rgba(241, 241, 241, 1);
  304. display: flex;
  305. justify-content: space-around;
  306. }
  307. // 记录
  308. .records {
  309. .time {
  310. padding: 24rpx 32rpx;
  311. color: rgba(119, 119, 119, 1);
  312. font-size: 32rpx;
  313. }
  314. .details {
  315. background-color: #fff;
  316. padding: 32rpx;
  317. display: flex;
  318. justify-content: space-between;
  319. align-items: center;
  320. .details-title {
  321. .title {
  322. color: rgba(51, 51, 51, 1);
  323. font-size: 32rpx;
  324. }
  325. .record-time {
  326. color: rgb(153, 153, 153);
  327. font-size: 24rpx;
  328. margin-top: 8rpx;
  329. }
  330. }
  331. .sum {
  332. color: rgb(16, 16, 16);
  333. font-size: 40rpx;
  334. }
  335. }
  336. }
  337. </style>