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

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