截流自动化的商城平台
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.

trading.html 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484
  1. {layout name="layout1" /}
  2. <div class="wrapper">
  3. <div class="layui-form" lay-filter="">
  4. <div class="layui-card" >
  5. <div class="layui-card-body">
  6. <div class="layui-inline">
  7. <label class="layui-form-label">汇总时间:</label>
  8. <div class="layui-input-inline">
  9. <div class="layui-input-inline">
  10. <input type="text" name="start_time" class="layui-input" id="start_time"
  11. placeholder="" autocomplete="off">
  12. </div>
  13. </div>
  14. <div class="layui-input-inline" style="margin-right: 5px;width: 20px;">
  15. <label class="layui-form-mid">至</label>
  16. </div>
  17. <div class="layui-input-inline">
  18. <input type="text" name="end_time" class="layui-input" id="end_time"
  19. placeholder="" autocomplete="off">
  20. </div>
  21. </div>
  22. <div class="layui-inline">
  23. <button class="layui-btn layui-btn-sm layuiadmin-btn-ad {$view_theme_color}" lay-submit
  24. lay-filter="menber-search">查询
  25. </button>
  26. <button class="layui-btn layui-btn-sm layuiadmin-btn-ad layui-btn-primary " lay-submit
  27. lay-filter="menber-clear-search">重置
  28. </button>
  29. </div>
  30. </div>
  31. </div>
  32. <div class="layui-row layui-col-space15">
  33. <div class="layui-col-sm6 layui-col-md3" >
  34. <div class="layui-card" >
  35. <div class="layui-card-header" >
  36. 成交订单(笔)
  37. </div>
  38. <div class="layui-card-body layuiadmin-card-list" >
  39. <p class="layuiadmin-big-font" id="order_num">0</p>
  40. </div>
  41. </div>
  42. </div>
  43. <div class="layui-col-sm6 layui-col-md3">
  44. <div class="layui-card">
  45. <div class="layui-card-header">
  46. 营业额(元)
  47. </div>
  48. <div class="layui-card-body layuiadmin-card-list">
  49. <p class="layuiadmin-big-font" id="order_amount">¥0</p>
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. <!--成交订单分析图-->
  55. <div class="layui-card" style="margin-top:20px">
  56. <div class="layui-card-body">
  57. <div class="layui-form-item">
  58. <div class="layui-input-inline layui-card-header" style="">成交订单(笔)</div>
  59. </div>
  60. <div class="layui-form-item">
  61. <div id="tradingCharts" style="width: 100%;height: 80vh;"></div>
  62. </div>
  63. </div>
  64. </div>
  65. <!--营业额分析图-->
  66. <div class="layui-card" style="margin-top:20px">
  67. <div class="layui-card-body">
  68. <div class="layui-form-item">
  69. <div class="layui-input-inline layui-card-header" style="">营业额(元)</div>
  70. </div>
  71. <div class="layui-form-item">
  72. <div id="tradingViewCharts" style="width: 100%;height: 80vh;"></div>
  73. </div>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. <script>
  79. layui.config({
  80. version:"{$front_version}",
  81. base: '/static/plug/layui-admin/dist/layuiadmin/' //静态资源所在路径
  82. }).extend({
  83. index: 'lib/index' //主入口模块
  84. }).use(['index','table','like','echarts','form'], function(){
  85. var $ = layui.$
  86. ,form = layui.form
  87. ,like = layui.like
  88. ,echarts = layui.echarts
  89. ,laydate = layui.laydate;
  90. //日期时间范围
  91. laydate.render({
  92. elem: '#start_time'
  93. , type: 'datetime'
  94. });
  95. laydate.render({
  96. elem: '#end_time'
  97. , type: 'datetime'
  98. });
  99. //监听搜索
  100. form.on('submit(menber-search)', function (data) {
  101. graphData();
  102. });
  103. //清空查询
  104. form.on('submit(menber-clear-search)', function () {
  105. $('#start_time').val('');
  106. $('#end_time').val('');
  107. graphData();
  108. });
  109. const colorList = ["#9E87FF", '#73DDFF', '#fe9a8b', '#F56948', '#9E87FF'];
  110. graphData();
  111. function graphData(){
  112. var start_time = $('#start_time').val();
  113. var end_time = $('#end_time').val();
  114. like.ajax({
  115. url:'{:url("statistics/trading")}',
  116. data: {'start_time':start_time,'end_time':end_time},
  117. type: "post",
  118. success: function (res) {
  119. $('#order_num').text(res.data.order_num);
  120. $('#order_amount').text(res.data.order_amount);
  121. // 默认选中15天内时间
  122. $('#start_time').val(res.data.start_time);
  123. $('#end_time').val(res.data.end_time);
  124. start_time = res.data.start_time;
  125. end_time = res.data.end_time;
  126. var tradingNum = res.data.echarts_count;
  127. var newMember = res.data.echarts_order_num_add;
  128. var newAmountMember = res.data.echarts_order_amount_add;
  129. var xData = res.data.days;
  130. var option = setOption(tradingNum, newMember, xData);
  131. let chart = document.getElementById('tradingCharts');
  132. let tradingChart = echarts.init(chart);
  133. tradingChart.setOption(option, true);
  134. window.addEventListener('resize', function () {
  135. tradingChart.resize()
  136. });
  137. var optionView = setOptionView(tradingNum, newAmountMember, xData);
  138. let chartView = document.getElementById('tradingViewCharts');
  139. let tradingViewChart = echarts.init(chartView);
  140. tradingViewChart.setOption(optionView, true);
  141. window.addEventListener('resize', function () {
  142. tradingViewChart.resize()
  143. });
  144. }
  145. });
  146. }
  147. //成交订单-图标设置
  148. function setOption(tradingNum, newTrading, xData) {
  149. option = {
  150. backgroundColor: '#fff',
  151. legend: {
  152. icon: 'circle',
  153. top: '5%',
  154. right: '5%',
  155. itemWidth: 6,
  156. itemGap: 20,
  157. textStyle: {
  158. color: '#556677'
  159. }
  160. },
  161. tooltip: {
  162. trigger: 'axis',
  163. backgroundColor: '#fff',
  164. textStyle: {
  165. color: '#5c6c7c'
  166. },
  167. padding: [10, 10],
  168. extraCssText: 'box-shadow: 1px 0 2px 0 rgba(163,163,163,0.5)'
  169. },
  170. grid: {
  171. top: '15%'
  172. },
  173. xAxis: [{
  174. type: 'category',
  175. name: '(日期)',
  176. data: xData,
  177. axisLine: {
  178. lineStyle: {
  179. color: 'rgba(107,107,107,0.37)', //x轴颜色
  180. }
  181. },
  182. axisTick: {
  183. show: false
  184. },
  185. axisLabel: {
  186. interval: 0,
  187. textStyle: {
  188. color: '#999' //坐标轴字颜色
  189. },
  190. margin: 15
  191. },
  192. axisPointer: {
  193. label: {
  194. padding: [11, 5, 7],
  195. backgroundColor: {
  196. type: 'linear',
  197. x: 0,
  198. y: 0,
  199. x2: 0,
  200. y2: 1,
  201. colorStops: [{
  202. offset: 0,
  203. color: '#fff' // 0% 处的颜色
  204. }, {
  205. offset: 0.9,
  206. color: '#fff' // 0% 处的颜色
  207. }, {
  208. offset: 0.9,
  209. color: '#33c0cd' // 0% 处的颜色
  210. }, {
  211. offset: 1,
  212. color: '#33c0cd' // 100% 处的颜色
  213. }],
  214. global: false // 缺省为 false
  215. }
  216. }
  217. },
  218. boundaryGap: false
  219. }],
  220. yAxis: [{
  221. type: 'value',
  222. name: '(笔)',
  223. axisTick: {
  224. show: false
  225. },
  226. axisLine: {
  227. show: true,
  228. lineStyle: {
  229. color: 'rgba(107,107,107,0.37)', //y轴颜色
  230. }
  231. },
  232. axisLabel: {
  233. textStyle: {
  234. color: '#999'
  235. }
  236. },
  237. splitLine: {
  238. show: false
  239. }
  240. }],
  241. series: [{
  242. name: '成交订单',
  243. type: 'line',
  244. data: newTrading,
  245. symbolSize: 1,
  246. symbol: 'circle',
  247. smooth: true,
  248. yAxisIndex: 0,
  249. showSymbol: false,
  250. lineStyle: {
  251. width: 5,
  252. color: new echarts.graphic.LinearGradient(1, 1, 0, 0, [{
  253. offset: 0,
  254. color: '#73DD39'
  255. },
  256. {
  257. offset: 1,
  258. color: '#73DDFF'
  259. }
  260. ]),
  261. shadowColor: 'rgba(115,221,255, 0.3)',
  262. shadowBlur: 10,
  263. shadowOffsetY: 20
  264. },
  265. itemStyle: {
  266. normal: {
  267. color: colorList[1],
  268. borderColor: colorList[1]
  269. }
  270. }
  271. }]
  272. };
  273. return option;
  274. }
  275. //营业额-图标设置
  276. function setOptionView(tradingNum, newTrading, xData) {
  277. option = {
  278. backgroundColor: '#fff',
  279. legend: {
  280. icon: 'circle',
  281. top: '5%',
  282. right: '5%',
  283. itemWidth: 6,
  284. itemGap: 20,
  285. textStyle: {
  286. color: '#556677'
  287. }
  288. },
  289. tooltip: {
  290. trigger: 'axis',
  291. backgroundColor: '#fff',
  292. textStyle: {
  293. color: '#5c6c7c'
  294. },
  295. padding: [10, 10],
  296. extraCssText: 'box-shadow: 1px 0 2px 0 rgba(163,163,163,0.5)'
  297. },
  298. grid: {
  299. top: '15%'
  300. },
  301. xAxis: [{
  302. type: 'category',
  303. name: '(日期)',
  304. data: xData,
  305. axisLine: {
  306. lineStyle: {
  307. color: 'rgba(107,107,107,0.37)', //x轴颜色
  308. }
  309. },
  310. axisTick: {
  311. show: false
  312. },
  313. axisLabel: {
  314. interval: 0,
  315. textStyle: {
  316. color: '#999' //坐标轴字颜色
  317. },
  318. margin: 15
  319. },
  320. axisPointer: {
  321. label: {
  322. padding: [11, 5, 7],
  323. backgroundColor: {
  324. type: 'linear',
  325. x: 0,
  326. y: 0,
  327. x2: 0,
  328. y2: 1,
  329. colorStops: [{
  330. offset: 0,
  331. color: '#fff' // 0% 处的颜色
  332. }, {
  333. offset: 0.9,
  334. color: '#fff' // 0% 处的颜色
  335. }, {
  336. offset: 0.9,
  337. color: '#33c0cd' // 0% 处的颜色
  338. }, {
  339. offset: 1,
  340. color: '#33c0cd' // 100% 处的颜色
  341. }],
  342. global: false // 缺省为 false
  343. }
  344. }
  345. },
  346. boundaryGap: false
  347. }],
  348. yAxis: [{
  349. type: 'value',
  350. name: '(元)',
  351. axisTick: {
  352. show: false
  353. },
  354. axisLine: {
  355. show: true,
  356. lineStyle: {
  357. color: 'rgba(107,107,107,0.37)', //y轴颜色
  358. }
  359. },
  360. axisLabel: {
  361. textStyle: {
  362. color: '#999'
  363. }
  364. },
  365. splitLine: {
  366. show: false
  367. }
  368. }],
  369. series: [{
  370. name: '营业额',
  371. type: 'line',
  372. data: newTrading,
  373. symbolSize: 1,
  374. symbol: 'circle',
  375. smooth: true,
  376. yAxisIndex: 0,
  377. showSymbol: false,
  378. lineStyle: {
  379. width: 5,
  380. color: new echarts.graphic.LinearGradient(1, 1, 0, 0, [{
  381. offset: 0,
  382. color: '#73DD39'
  383. },
  384. {
  385. offset: 1,
  386. color: '#73DDFF'
  387. }
  388. ]),
  389. shadowColor: 'rgba(115,221,255, 0.3)',
  390. shadowBlur: 10,
  391. shadowOffsetY: 20
  392. },
  393. itemStyle: {
  394. normal: {
  395. color: colorList[1],
  396. borderColor: colorList[1]
  397. }
  398. }
  399. }]
  400. };
  401. return option;
  402. }
  403. });
  404. </script>
  405. <script type="text/javascript">
  406. (function(){
  407. var tab_tit = document.getElementById('think_page_trace_tab_tit').getElementsByTagName('span');
  408. var tab_cont = document.getElementById('think_page_trace_tab_cont').getElementsByTagName('div');
  409. var open = document.getElementById('think_page_trace_open');
  410. var close = document.getElementById('think_page_trace_close').children[0];
  411. var trace = document.getElementById('think_page_trace_tab');
  412. var cookie = document.cookie.match(/thinkphp_show_page_trace=(\d\|\d)/);
  413. var history = (cookie && typeof cookie[1] != 'undefined' && cookie[1].split('|')) || [0,0];
  414. open.onclick = function(){
  415. trace.style.display = 'block';
  416. this.style.display = 'none';
  417. close.parentNode.style.display = 'block';
  418. history[0] = 1;
  419. document.cookie = 'thinkphp_show_page_trace='+history.join('|')
  420. }
  421. close.onclick = function(){
  422. trace.style.display = 'none';
  423. this.parentNode.style.display = 'none';
  424. open.style.display = 'block';
  425. history[0] = 0;
  426. document.cookie = 'thinkphp_show_page_trace='+history.join('|')
  427. }
  428. for(var i = 0; i < tab_tit.length; i++){
  429. tab_tit[i].onclick = (function(i){
  430. return function(){
  431. for(var j = 0; j < tab_cont.length; j++){
  432. tab_cont[j].style.display = 'none';
  433. tab_tit[j].style.color = '#999';
  434. }
  435. tab_cont[i].style.display = 'block';
  436. tab_tit[i].style.color = '#000';
  437. history[1] = i;
  438. document.cookie = 'thinkphp_show_page_trace='+history.join('|')
  439. }
  440. })(i)
  441. }
  442. parseInt(history[0]) && open.click();
  443. tab_tit[history[1]].click();
  444. })();
  445. </script>
  446. </body>
  447. </html>