截流自动化的商城平台
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

stat.html 26KB

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