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

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