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

stat.html 26KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654
  1. {layout name="layout1" /}
  2. <link rel="stylesheet" href="/static/plug/layui-admin/dist/layuiadmin/layui/css/layui.css?v={$front_version}" media="all">
  3. <link rel="stylesheet" href="/static/plug/layui-admin/dist/layuiadmin/style/admin.css?v={$front_version}" media="all">
  4. <link rel="stylesheet" href="/static/plug/layui-admin/dist/layuiadmin/style/like.css?v={$front_version}" media="all">
  5. <script src="__PUBLIC__/static/lib/layui/layui.js"></script>
  6. <script src="__PUBLIC__/static/admin/js/app.js"></script>
  7. <style>
  8. .header-font{
  9. font-size: 20px
  10. }
  11. .layui-card .data-all {
  12. display: flex;
  13. justify-content: space-between;
  14. margin-top: 20px;
  15. }
  16. .layui-card .text-style {
  17. font-size: 16px;
  18. }
  19. .header-time{
  20. margin-left: 20px
  21. }
  22. .layadmin-shortcut .shortcut-list {
  23. padding: 30px 0;
  24. display: flex;
  25. flex-wrap: wrap;
  26. }
  27. .layadmin-shortcut .shortcut-list li {
  28. min-width: 100px;
  29. margin-bottom: 20px;
  30. width: 12.5%;
  31. }
  32. .layadmin-shortcut .shortcut-list .icon{
  33. width: 62px;
  34. height: 62px;
  35. margin-bottom: 5px;
  36. }
  37. .tips {
  38. float: right;
  39. padding: 0 10px;
  40. margin-top: 10px;
  41. height: 20px;
  42. line-height: 20px;
  43. font-size: 12px;
  44. color: #3A91FB;
  45. border-radius: 30px;
  46. border: 1px #3A91FB solid;
  47. background: #eaf3ff;
  48. }
  49. .header-font{
  50. font-size: 20px
  51. }
  52. .layui-card .data-all {
  53. display: flex;
  54. justify-content: space-between;
  55. margin-top: 20px;
  56. }
  57. .layui-card .text-style {
  58. font-size: 16px;
  59. }
  60. .header-time{
  61. margin-left: 20px
  62. }
  63. .layadmin-shortcut .shortcut-list {
  64. padding: 30px 0;
  65. display: flex;
  66. flex-wrap: wrap;
  67. }
  68. .layadmin-shortcut .shortcut-list li {
  69. min-width: 100px;
  70. margin-bottom: 20px;
  71. width: 12.5%;
  72. }
  73. .layadmin-shortcut .shortcut-list .icon{
  74. width: 62px;
  75. height: 62px;
  76. margin-bottom: 5px;
  77. }
  78. .tips {
  79. float: right;
  80. padding: 0 10px;
  81. margin-top: 10px;
  82. height: 20px;
  83. line-height: 20px;
  84. font-size: 12px;
  85. color: #3A91FB;
  86. border-radius: 30px;
  87. border: 1px #3A91FB solid;
  88. background: #eaf3ff;
  89. }
  90. .red{
  91. color:red;
  92. }
  93. .green{
  94. color:green;
  95. }
  96. .laytable-cell-1-0-1,.laytable-cell-2-0-1 {
  97. width: 280px;
  98. height: auto;
  99. }
  100. </style>
  101. <div class="wrapper" style="margin-bottom: 100px">
  102. <div class="layui-card" >
  103. <div class="layui-card-header">
  104. <span class="header-font">运营数据</span>
  105. <span class="header-time">更新时间:{$res.time}</span>
  106. </div>
  107. </div>
  108. <div class="layui-row layui-col-space15">
  109. <div class="layui-col-sm3">
  110. <div class="layui-card">
  111. <div class="layui-card-header">
  112. 成交订单(笔)
  113. <span class="tips">今日</span>
  114. </div>
  115. <div class="layui-card-body layuiadmin-card-list">
  116. <p class="layuiadmin-big-font">{$res.data.order_num.today}</p>
  117. <p>昨日:<span class="text-style">{$res.data.order_num.yesterday}</span>
  118. &nbsp;&nbsp;
  119. {if ($res.data.order_num.change_red > 0) }
  120. <span class="green">降:<span class="text-style">{$res.data.order_num.change_red}</span>
  121. {else/}
  122. <span class="red">涨:<span class="text-style">{$res.data.order_num.change_add}</span>
  123. {/if}
  124. </span> </p>
  125. <div class="data-all">累计成交订单<div class="text-style">{$res.data.order_num.all_num}</div></div>
  126. </div>
  127. </div>
  128. </div>
  129. <div class="layui-col-sm3 ">
  130. <div class="layui-card">
  131. <div class="layui-card-header">
  132. 营业额(元)
  133. <span class="tips">今日</span>
  134. </div>
  135. <div class="layui-card-body layuiadmin-card-list">
  136. <p class="layuiadmin-big-font">{$res.data.order_price.today}</p>
  137. <p>昨日:<span class="text-style">{$res.data.order_price.yesterday}</span>
  138. &nbsp;&nbsp;
  139. {if ($res.data.order_price.change_red > 0) }
  140. <span class="green">降:<span class="text-style">{$res.data.order_price.change_red}</span>
  141. {else/}
  142. <span class="red">涨:<span class="text-style">{$res.data.order_price.change_add}</span>
  143. {/if}
  144. </span> </p>
  145. <div class="data-all">累计营业额<div class="text-style">{$res.data.order_price.all_price}</div></div>
  146. </div>
  147. </div>
  148. </div>
  149. <div class="layui-col-sm3 ">
  150. <div class="layui-card">
  151. <div class="layui-card-header">
  152. 新增会员(人)
  153. <span class="tips">今日</span>
  154. </div>
  155. <div class="layui-card-body layuiadmin-card-list">
  156. <p class="layuiadmin-big-font">{$res.data.add_user_num.today}</p>
  157. <p >昨日:<span class="text-style">{$res.data.add_user_num.yesterday}</span>
  158. &nbsp;&nbsp;
  159. {if ($res.data.add_user_num.change_red > 0) }
  160. <span class="green">降:<span class="text-style">{$res.data.add_user_num.change_red}</span>
  161. {else/}
  162. <span class="red">涨:<span class="text-style">{$res.data.add_user_num.change_add}</span>
  163. {/if}
  164. </span> </p>
  165. <div class="data-all">会员人数<div class="text-style">{$res.data.add_user_num.all_num}</div></div>
  166. </div>
  167. </div>
  168. </div>
  169. <div class="layui-col-sm3 ">
  170. <div class="layui-card">
  171. <div class="layui-card-header">
  172. 会员访问量(人)
  173. <span class="tips">今日</span>
  174. </div>
  175. <div class="layui-card-body layuiadmin-card-list">
  176. <p class="layuiadmin-big-font">{$res.data.visit_user_num.today}</p>
  177. <p>昨日:<span class="text-style">{$res.data.visit_user_num.yesterday}</span>
  178. &nbsp;&nbsp;
  179. {if ($res.data.visit_user_num.change_red > 0) }
  180. <span class="green">降:<span class="text-style">{$res.data.visit_user_num.change_red}</span>
  181. {else/}
  182. <span class="red">涨:<span class="text-style">{$res.data.visit_user_num.change_add}</span>
  183. {/if}
  184. </span> </p>
  185. <div class="data-all">累计会员访问量<div class="text-style">{$res.data.visit_user_num.all_num}</div></div>
  186. </div>
  187. </div>
  188. </div>
  189. <!--快捷功能-->
  190. <div class="layui-col-sm12" style="display:none;">
  191. <div class="layui-card">
  192. <div class="layui-card-header">快捷功能</div>
  193. <div class="layui-card-body">
  194. <div class="layadmin-shortcut">
  195. <ul class="shortcut-list">
  196. <li class="shop-item">
  197. <a target="view_frame" lay-href="{:url('goods.goods/lists')}" data-id="29">
  198. <img class="icon" src="__PUBLIC__/static/common/image/workbench/goods.png" alt="">
  199. <cite>商品</cite>
  200. </a>
  201. </li>
  202. <li class="shop-item">
  203. <a target="view_frame" lay-href="{:url('order.order/lists')}" data-id="37">
  204. <img class="icon" src="__PUBLIC__/static/common/image/workbench/order.png" alt="">
  205. <cite>订单</cite>
  206. </a>
  207. </li>
  208. <li class="shop-item">
  209. <a target="view_frame" lay-href="{:url('user.user/lists')}" data-id="33">
  210. <img class="icon" src="__PUBLIC__/static/common/image/workbench/user.png" alt="">
  211. <cite>会员</cite>
  212. </a>
  213. </li>
  214. <li class="shop-item">
  215. <a target="view_frame" lay-href="{:url('coupon.shop_coupon/lists')}" data-id="39" data-txt="优惠券">
  216. <img class="icon" src="__PUBLIC__/static/common/image/workbench/coupon.png" alt="">
  217. <cite>优惠券</cite>
  218. </a>
  219. </li>
  220. <li class="shop-item">
  221. <a target="view_frame" lay-href="{:url('seckill.seckill_goods/lists')}" data-id="36" data-txt="限时秒杀">
  222. <img class="icon" src="__PUBLIC__/static/common/image/workbench/seckill.png" alt="">
  223. <cite>限时秒杀</cite>
  224. </a>
  225. </li>
  226. <li class="shop-item">
  227. <a target="view_frame" lay-href="{:url('distribution.member/index')}" data-id="81" data-txt="分销">
  228. <img class="icon" src="__PUBLIC__/static/common/image/workbench/distribution.png" alt="">
  229. <cite>分销</cite>
  230. </a>
  231. </li>
  232. <li class="shop-item">
  233. <a target="view_frame" lay-href="{:url('content.help/lists')}" data-id="65" data-txt="'帮助管理">
  234. <img class="icon" src="__PUBLIC__/static/common/image/workbench/content.png" alt="">
  235. <cite>内容</cite>
  236. </a>
  237. </li>
  238. <li class="shop-item">
  239. <a target="view_frame" lay-href="{:url('finance.finance/center')}" data-id="82" data-txt="财务">
  240. <img class="icon" src="__PUBLIC__/static/common/image/workbench/finance.png" alt="">
  241. <cite>财务</cite>
  242. </a>
  243. </li>
  244. </ul>
  245. </div>
  246. </div>
  247. </div>
  248. </div>
  249. <!-- 销冠商家 -->
  250. <div class="layui-col-sm6 ">
  251. <div class="layui-card">
  252. <div class="layui-card-header">
  253. 销冠商家(前5名)
  254. </div>
  255. <div class="layui-card-body layuiadmin-card-list">
  256. <div class="layui-tab-content" style="padding: 0 15px;">
  257. <table id="goods-lists" lay-filter="goods-lists"></table>
  258. <script type="text/html" id="goods-info">
  259. <div style="text-align: left;">
  260. <img src="{{ d.logo }}" style="height:50px;width: 50px" class="image-show layui-col-md4">
  261. <p>商家名称:{{d.name}}</p>
  262. </div>
  263. </script>
  264. </div>
  265. </div>
  266. </div>
  267. </div>
  268. <!-- 人气商家 -->
  269. <div class="layui-col-sm6 ">
  270. <div class="layui-card">
  271. <div class="layui-card-header">
  272. 人气商家(前5名)
  273. </div>
  274. <div class="layui-card-body layuiadmin-card-list">
  275. <div class="layui-tab-content" style="padding: 0 15px;">
  276. <table id="goods-lists2" lay-filter="goods-lists2"></table>
  277. <script type="text/html" id="goods-info">
  278. <div style="text-align: left;">
  279. <img src="{{ d.logo }}" style="height:50px;width: 50px" class="image-show layui-col-md4">
  280. <p>商家名称:{{d.name}}</p>
  281. </div>
  282. </script>
  283. </div>
  284. </div>
  285. </div>
  286. </div>
  287. <!--表格-->
  288. <div class="layui-col-sm12">
  289. <div class="layui-card">
  290. <div class="layui-card-body">
  291. <div class="layui-row">
  292. 近15天营业额(元)
  293. <div class="layadmin-dataview">
  294. <div id="sale-charts" style="width: 100%;height: 100%">
  295. <div><i class="layui-icon layui-icon-loading1 layadmin-loading"></i></div>
  296. </div>
  297. </div>
  298. </div>
  299. </div>
  300. </div>
  301. </div>
  302. <div class="layui-col-sm12">
  303. <div class="layui-card">
  304. <div class="layui-card-body">
  305. <div class="layui-row">
  306. 近15天会员访问量(人)
  307. <div class="layadmin-dataview">
  308. <div id="user-charts" style="width: 100%;height: 100%;">
  309. <div><i class="layui-icon layui-icon-loading1 layadmin-loading"></i></div>
  310. </div>
  311. </div>
  312. </div>
  313. </div>
  314. </div>
  315. </div>
  316. </div>
  317. </div>
  318. <footer class="info_footer">
  319. {$company_name}&nbsp;&nbsp;|&nbsp;&nbsp;版本号:{$version}
  320. <br><br>
  321. </footer>
  322. <script>
  323. layui.config({
  324. version:"{$front_version}",
  325. base: '/static/lib/'
  326. }).extend({
  327. echarts: 'echarts/echarts',
  328. echartsTheme: 'echarts/echartsTheme',
  329. }).use(['echarts','form','element', 'echartsTheme'], function () {
  330. var $ = layui.$
  331. ,echarts = layui.echarts;
  332. let bgColor = "#fff";
  333. let color = [
  334. "#0090FF",
  335. "#36CE9E",
  336. "#FFC005",
  337. "#FF515A",
  338. "#8B5CFF",
  339. "#00CA69"
  340. ];
  341. const hexToRgba = (hex, opacity) => {
  342. let rgbaColor = "";
  343. let reg = /^#[\da-f]{6}$/i;
  344. if (reg.test(hex)) {
  345. rgbaColor = `rgba(${parseInt("0x" + hex.slice(1, 3))},${parseInt(
  346. "0x" + hex.slice(3, 5)
  347. )},${parseInt("0x" + hex.slice(5, 7))},${opacity})`;
  348. }
  349. return rgbaColor;
  350. }
  351. // $(".shop-item").click(function(){
  352. //
  353. // var url = $(this).children('a').attr('lay-href');
  354. // var id = $(this).children('a').attr('data-id');
  355. //
  356. // top.refreshHighlight(url,id);
  357. // console.log(url);
  358. // });
  359. like.ajax({
  360. url: '{:url("index/stat")}',
  361. type: "get",
  362. success: function (res) {
  363. var dates = res.data.dates,
  364. echarts_order_amount = res.data.echarts_order_amount,
  365. echarts_user_visit = res.data.echarts_user_visit;
  366. var sale_option = {
  367. backgroundColor: bgColor,
  368. color: color,
  369. legend: {
  370. right: 10,
  371. top: 10
  372. },
  373. tooltip: {
  374. trigger: "axis",
  375. formatter: function(params) {
  376. let html = '';
  377. params.forEach(v => {
  378. html += `<div style="color: #666;font-size: 14px;line-height: 24px">
  379. <span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${color[v.componentIndex]};"></span>
  380. ${v.name}
  381. <span style="color:${color[v.componentIndex]};font-weight:700;font-size: 18px">${v.value}</span>
  382. 元`;
  383. })
  384. return html
  385. },
  386. extraCssText: 'background: #fff; border-radius: 0;box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);color: #333;',
  387. axisPointer: {
  388. type: 'shadow',
  389. shadowStyle: {
  390. color: '#ffffff',
  391. shadowColor: 'rgba(225,225,225,1)',
  392. shadowBlur: 5
  393. }
  394. }
  395. },
  396. grid: {
  397. top: 100,
  398. containLabel: true
  399. },
  400. xAxis: [{
  401. type: "category",
  402. boundaryGap: false,
  403. axisLabel: {
  404. formatter: '{value}',
  405. textStyle: {
  406. color: "#333"
  407. }
  408. },
  409. axisLine: {
  410. lineStyle: {
  411. color: "#D9D9D9"
  412. }
  413. },
  414. data: dates
  415. }],
  416. yAxis: [{
  417. type: "value",
  418. name: '营业额',
  419. axisLabel: {
  420. textStyle: {
  421. color: "#666"
  422. }
  423. },
  424. nameTextStyle: {
  425. color: "#666",
  426. fontSize: 12,
  427. lineHeight: 40
  428. },
  429. splitLine: {
  430. lineStyle: {
  431. type: "dashed",
  432. color: "#E9E9E9"
  433. }
  434. },
  435. axisLine: {
  436. show: false
  437. },
  438. axisTick: {
  439. show: false
  440. }
  441. }],
  442. series: [{
  443. type: "line",
  444. smooth: true,
  445. symbolSize: 8,
  446. zlevel: 3,
  447. lineStyle: {
  448. normal: {
  449. color: color[0],
  450. shadowBlur: 3,
  451. shadowColor: hexToRgba(color[0], 0.5),
  452. shadowOffsetY: 8
  453. }
  454. },
  455. areaStyle: {
  456. normal: {
  457. color: new echarts.graphic.LinearGradient(
  458. 0,
  459. 0,
  460. 0,
  461. 1,
  462. [{
  463. offset: 0,
  464. color: hexToRgba(color[0], 0.3)
  465. },
  466. {
  467. offset: 1,
  468. color: hexToRgba(color[0], 0.1)
  469. }
  470. ],
  471. false
  472. ),
  473. shadowColor: hexToRgba(color[0], 0.1),
  474. shadowBlur: 10
  475. }
  476. },
  477. data: echarts_order_amount
  478. }]
  479. };
  480. var user_option = {
  481. backgroundColor: bgColor,
  482. color: color,
  483. legend: {
  484. right: 10,
  485. top: 10
  486. },
  487. tooltip: {
  488. trigger: "axis",
  489. formatter: function(params) {
  490. let html = '';
  491. params.forEach(v => {
  492. html += `<div style="color: #666;font-size: 14px;line-height: 24px">
  493. <span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:${color[v.componentIndex]};"></span>
  494. ${v.name}
  495. <span style="color:${color[v.componentIndex]};font-weight:700;font-size: 18px">${v.value}</span>
  496. 人`;
  497. })
  498. return html
  499. },
  500. extraCssText: 'background: #fff; border-radius: 0;box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);color: #333;',
  501. axisPointer: {
  502. type: 'shadow',
  503. shadowStyle: {
  504. color: '#ffffff',
  505. shadowColor: 'rgba(225,225,225,1)',
  506. shadowBlur: 5
  507. }
  508. }
  509. },
  510. grid: {
  511. top: 100,
  512. containLabel: true
  513. },
  514. xAxis: [{
  515. type: "category",
  516. boundaryGap: false,
  517. axisLabel: {
  518. formatter: '{value}',
  519. textStyle: {
  520. color: "#333"
  521. }
  522. },
  523. axisLine: {
  524. lineStyle: {
  525. color: "#D9D9D9"
  526. }
  527. },
  528. data: dates
  529. }],
  530. yAxis: [{
  531. type: "value",
  532. name: '会员访问量',
  533. axisLabel: {
  534. textStyle: {
  535. color: "#666"
  536. }
  537. },
  538. nameTextStyle: {
  539. color: "#666",
  540. fontSize: 12,
  541. lineHeight: 40
  542. },
  543. splitLine: {
  544. lineStyle: {
  545. type: "dashed",
  546. color: "#E9E9E9"
  547. }
  548. },
  549. axisLine: {
  550. show: false
  551. },
  552. axisTick: {
  553. show: false
  554. }
  555. }],
  556. series: [{
  557. type: "line",
  558. smooth: true,
  559. symbolSize: 8,
  560. zlevel: 3,
  561. lineStyle: {
  562. normal: {
  563. color: color[0],
  564. shadowBlur: 3,
  565. shadowColor: hexToRgba(color[0], 0.5),
  566. shadowOffsetY: 8
  567. }
  568. },
  569. areaStyle: {
  570. normal: {
  571. color: new echarts.graphic.LinearGradient(
  572. 0,
  573. 0,
  574. 0,
  575. 1,
  576. [{
  577. offset: 0,
  578. color: hexToRgba(color[0], 0.3)
  579. },
  580. {
  581. offset: 1,
  582. color: hexToRgba(color[0], 0.1)
  583. }
  584. ],
  585. false
  586. ),
  587. shadowColor: hexToRgba(color[0], 0.1),
  588. shadowBlur: 10
  589. }
  590. },
  591. data: echarts_user_visit
  592. }]
  593. };
  594. var sale_charts= echarts.init(document.getElementById('sale-charts'));
  595. sale_charts.setOption(sale_option, true);
  596. var user_charts = echarts.init(document.getElementById('user-charts'));
  597. user_charts.setOption(user_option, true);
  598. }
  599. });
  600. getList(); // 初始加载
  601. function getList() {
  602. var type = 1;
  603. like.tableLists('#goods-lists', '{:url("index/shop")}?type='+type, [
  604. {field: 'number',title: '排名',width:'15%'}
  605. ,{title: '商家',width:'55%', align: 'center', templet: '#goods-info'}
  606. ,{field: 'order_amount', title: '销售金额',width:'30%'}
  607. ]);
  608. var type = 2;
  609. like.tableLists('#goods-lists2', '{:url("index/shop")}?type='+type, [
  610. {field: 'number',title: '排名',width:'15%'}
  611. ,{title: '商家',width:'55%', align: 'center', templet: '#goods-info'}
  612. ,{field: 'visited_num', title: '进店人数',width:'30%'}
  613. ]);
  614. }
  615. });
  616. </script>