index.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737
  1. <style type="text/css">
  2. body {
  3. font-family: Source Han Sans SC;
  4. }
  5. .row {
  6. margin: 0;
  7. }
  8. .theme-color-1 {
  9. color: #333333;
  10. }
  11. .theme-color-2 {
  12. color: #555555;
  13. }
  14. .theme-color-3 {
  15. color: #18BC9C;
  16. }
  17. .theme-color-4 {
  18. color: #627EFC;
  19. }
  20. .theme-color-5 {
  21. color: #666666;
  22. }
  23. .theme-color-6 {
  24. color: #753ECD;
  25. }
  26. .margin-20 {
  27. margin-right: 20px;
  28. }
  29. .row-padding {
  30. padding-left: 29px;
  31. padding-bottom: 29px;
  32. }
  33. /* .#F5F5F5 */
  34. .header-box {
  35. width: 100%;
  36. /* height:236px; */
  37. background: #fff;
  38. border-radius: 20px;
  39. margin-bottom: 10px;
  40. }
  41. .header-title,
  42. .main-title,
  43. .top5-title {
  44. height: 78px;
  45. padding: 0 40px 0 30px;
  46. display: flex;
  47. align-items: center;
  48. justify-content: space-between;
  49. }
  50. .main-title,
  51. .top5-title {
  52. height: 58px;
  53. }
  54. .title-left {
  55. font-size: 16px;
  56. font-weight: 500;
  57. }
  58. .title-right {
  59. display: flex;
  60. }
  61. .header-con {
  62. padding: 20px 2.0% 0 0px;
  63. }
  64. .header-conBox {
  65. /* display: flex; */
  66. background: #fff;
  67. padding: 16px 14px;
  68. border-radius: 14px;
  69. position: relative;
  70. height: 120px;
  71. border: 2px solid;
  72. }
  73. .header-con-tip {
  74. display: flex;
  75. align-items: flex-start;
  76. justify-content: space-between;
  77. }
  78. .header-con-tip-left {
  79. flex: 1;
  80. display: flex;
  81. align-items: center;
  82. font-size: 14px;
  83. font-weight: 500;
  84. }
  85. .detail {
  86. cursor: pointer;
  87. font-size: 12px;
  88. }
  89. .header-con-unit {
  90. font-size: 12px;
  91. }
  92. .header-con-tip-i {
  93. margin-left: 2px;
  94. }
  95. .img-position {
  96. position: absolute;
  97. right: 22px;
  98. top: 22px;
  99. display: none;
  100. border-radius: 50%;
  101. }
  102. .header-conBox-back1 {
  103. background: #FEF6DE;
  104. }
  105. .header-conBox-back2 {
  106. background: #E2F7E9;
  107. }
  108. .header-conBox-back3 {
  109. background: #EBEEFE;
  110. }
  111. .header-conBox-back4 {
  112. background: #FFEDEB;
  113. }
  114. .header-conBox-back5 {
  115. background: #E4F0FF;
  116. }
  117. .header-conBox-back6 {
  118. background: #F6E9FE;
  119. }
  120. .header-conBox-back7 {
  121. background: #FEF6DE;
  122. }
  123. .header-conBox-back8 {
  124. background: #E4F0FF;
  125. }
  126. .header-conBox-active {
  127. /* background: #E1F6F2; */
  128. border: 2px solid #18BC9C;
  129. box-sizing: border-box;
  130. }
  131. .header-conBox-active .img-position {
  132. display: block;
  133. }
  134. .header-con-img {
  135. width: 42px;
  136. height: 42px;
  137. margin-right: 12px;
  138. flex-shrink: 1;
  139. }
  140. .header-con-msg {
  141. padding-top: 10px;
  142. width: 100%;
  143. }
  144. .header-con-msg-num {
  145. font-size: 22px;
  146. font-weight: 600;
  147. line-height: 30px;
  148. text-align: center;
  149. }
  150. .main {
  151. border-radius: 20px;
  152. margin-bottom: 10px;
  153. }
  154. .main-1 {
  155. position: relative;
  156. }
  157. .main-chart-tip-con {
  158. position: absolute;
  159. left: 50%;
  160. top: 50%;
  161. width: 120px;
  162. height: 40px;
  163. margin-top: -20px;
  164. margin-left: -60px;
  165. }
  166. .main-position {
  167. /* width: 100%; */
  168. position: absolute;
  169. top: 10px;
  170. display: flex;
  171. justify-content: space-between;
  172. padding: 0 40px 0 20px;
  173. }
  174. .main-position-right {
  175. display: flex;
  176. align-items: center;
  177. }
  178. .main-refresh {
  179. display: flex;
  180. align-items: center;
  181. /* cursor: pointer; */
  182. }
  183. .main-refresh-tip {
  184. margin: 0 30px 0 2px;
  185. }
  186. .main-chart-tip {
  187. display: flex;
  188. }
  189. .main-chart-tip-msg {
  190. margin: 0 20px 0 4px;
  191. }
  192. #main-chart {
  193. padding: 40px 32px 10px 16px;
  194. margin-right: 20px;
  195. background: #fff;
  196. border-radius: 10px;
  197. margin-bottom: 10px;
  198. }
  199. .main-title .title-right {
  200. display: flex;
  201. align-items: center;
  202. justify-content: space-between;
  203. }
  204. .header-right-btn {
  205. display: block;
  206. width: 50px;
  207. height: 32px;
  208. border: 1px solid #E3E2E5;
  209. color: #666666;
  210. font-size: 14px;
  211. border-radius: 4px;
  212. line-height: 32px;
  213. text-align: center;
  214. cursor: pointer;
  215. }
  216. .header-right-btn-active {
  217. border: 1px solid #627EFC;
  218. color: #627EFC;
  219. }
  220. .top5 {
  221. height: 400px;
  222. /* background: #fff; */
  223. border-radius: 20px;
  224. }
  225. .top-more {
  226. color: #999999;
  227. align-items: center;
  228. margin-left: 6px;
  229. }
  230. .selects {
  231. padding: 5px 10px;
  232. display: block;
  233. border: 1px solid #eee;
  234. }
  235. .selects-active {
  236. border: 1px solid #f00;
  237. }
  238. #antv-con {
  239. background: #f1f4f6;
  240. }
  241. .time-position {
  242. position: relative;
  243. /* margin-right: 300px; */
  244. }
  245. .ranges {
  246. display: none;
  247. }
  248. .col-lg-8,
  249. .col-lg-4 {
  250. padding: 0;
  251. }
  252. .el-dropdown {
  253. width: 70px;
  254. height: 30px;
  255. border: 1px solid #753ECD;
  256. border-radius: 4px;
  257. line-height: 30px;
  258. text-align: center;
  259. cursor: pointer;
  260. color: #753ECD !important;
  261. margin-right: 14px;
  262. }
  263. .el-icon-arrow-right,
  264. .el-range__icon {
  265. display: none !important;
  266. }
  267. .el-input__inner {
  268. height: 30px !important;
  269. line-height: 30px !important;
  270. }
  271. .top5-heght {
  272. height: 100%;
  273. padding: 0;
  274. margin-bottom: 20px;
  275. /* background: #fff;
  276. border-radius:10px; */
  277. }
  278. .top5-right {
  279. height: 100%;
  280. background: #fff;
  281. border-radius: 10px;
  282. position: relative;
  283. padding-top: 10px;
  284. }
  285. .top5-left {
  286. height: 100%;
  287. background: #fff;
  288. border-radius: 10px;
  289. /* margin-right: 20px; */
  290. padding: 10px 26px;
  291. }
  292. .top5-left .top5-title {
  293. padding: 0;
  294. font-size: 16px;
  295. /* line-height: 16px;
  296. height: 16px; */
  297. }
  298. #ring-right {
  299. margin-top: 6px;
  300. }
  301. .ring-right-position {
  302. /* background: #f00; */
  303. width: 246px;
  304. height: 246px;
  305. border: 41px solid rgba(255, 255, 255, 1);
  306. box-shadow: 0px 10px 30px 0px rgba(73, 111, 253, 0.12);
  307. border-radius: 50%;
  308. left: 50%;
  309. top: 50%;
  310. margin-top: -123px;
  311. margin-left: -123px;
  312. position: absolute;
  313. }
  314. .ring-right-position-inner {
  315. width: 140px;
  316. height: 140px;
  317. background: #f3f6fe;
  318. border-radius: 50%;
  319. left: 50%;
  320. top: 50%;
  321. margin-top: -70px;
  322. margin-left: -70px;
  323. position: absolute;
  324. }
  325. .position-background {
  326. width: 90px;
  327. height: 90px;
  328. border: 14px solid #fff;
  329. box-shadow: 0px 8px 20px 0px rgba(117, 62, 205, 0.12);
  330. border-radius: 50%;
  331. position: relative;
  332. }
  333. .position-background-inner {
  334. position: absolute;
  335. width: 62px;
  336. height: 62px;
  337. background: #f6f2fc;
  338. border-radius: 50%;
  339. left: 50%;
  340. top: 50%;
  341. margin-left: -31px;
  342. margin-top: -31px;
  343. }
  344. .top5-center-top {
  345. height: 190px;
  346. background: #fff;
  347. /* display: flex;
  348. justify-content: space-between; */
  349. padding: 20px 28px 30px;
  350. border-radius: 10px;
  351. }
  352. .top5-center-top-ring {
  353. display: flex;
  354. justify-content: space-between;
  355. }
  356. .top5-center-title {
  357. margin-bottom: 50px;
  358. font-size: 14px;
  359. color: #666;
  360. font-weight: 600;
  361. }
  362. .top5-center-num {
  363. font-size: 24px;
  364. font-weight: bold;
  365. margin-top: 10px;
  366. }
  367. .top5-center-tip {
  368. font-size: 14px;
  369. font-weight: 500;
  370. color: #666;
  371. }
  372. .top5-center {
  373. margin: 0 18px 0 20px;
  374. }
  375. .top5-center-top-margin {
  376. margin-bottom: 20px;
  377. }
  378. .el-table .gray-row {
  379. background: #F9F9F9;
  380. }
  381. .el-table td {
  382. height: 48px;
  383. padding: 0 !important;
  384. }
  385. .el-table th {
  386. height: 60px;
  387. padding: 0 !important;
  388. }
  389. .cell {
  390. text-align: center;
  391. }
  392. .el-date-editor .el-range__close-icon {
  393. display: none !important;
  394. width: 0 !important;
  395. }
  396. .el-range-editor.el-input__inner {
  397. padding: 3px 0 !important;
  398. }
  399. .el-date-editor .el-range-input {
  400. width: 45% !important;
  401. }
  402. .el-date-editor--datetimerange.el-input__inner {
  403. justify-content: center !important;
  404. width: 326px !important;
  405. }
  406. .el-date-editor .el-range-separator {
  407. height: 32px !important;
  408. }
  409. .popover-item {
  410. font-size: 24px;
  411. color: #d5d5d5;
  412. margin-left: 10px;
  413. position: relative;
  414. top: 4px;
  415. }
  416. .ellipsis-item {
  417. overflow: hidden;
  418. text-overflow: ellipsis;
  419. display: -webkit-box;
  420. -webkit-line-clamp: 1;
  421. -webkit-box-orient: vertical;
  422. }
  423. @media screen and (max-width: 1430px) {
  424. .top5-center {
  425. /* margin-left: 0; */
  426. }
  427. #main-chart {
  428. /* margin-right: 0; */
  429. }
  430. }
  431. @media screen and (max-width: 750px) {
  432. .main-position {
  433. padding: 0 20px;
  434. }
  435. .refresh-btn {
  436. display: none;
  437. }
  438. .picker-hide {
  439. display: none !important;
  440. }
  441. .top5-center {
  442. margin-right: 0;
  443. margin-left: 0;
  444. }
  445. #main-chart {
  446. margin-right: 0;
  447. }
  448. }
  449. .header-con-tip-left-1 {
  450. display: flex;
  451. align-items: center;
  452. justify-content: space-between;
  453. flex: 1;
  454. }
  455. [v-cloak] {
  456. display: none
  457. }
  458. </style>
  459. <link rel="stylesheet" href="__CDN__/assets/addons/shopro/libs/element/element.css">
  460. <script src="__CDN__/assets/addons/shopro/libs/vue.js"></script>
  461. <script src="__CDN__/assets/addons/shopro/libs/element/element.js"></script>
  462. <script src="__CDN__/assets/addons/shopro/libs/moment.js"></script>
  463. <div id="antv-con" v-cloak v-loading="loading">
  464. <el-row class="row main">
  465. <el-col :xs="24" :sm="24" :md="24" :lg="16" :xl="16" class="main-1">
  466. <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24" class="main-position">
  467. <div class="main-refresh">
  468. <div class="refresh-btn" @click="getDataInfo">
  469. <i class="el-icon-refresh-right"></i>
  470. <span class="main-refresh-tip theme-color-1">刷新</span>
  471. </div>
  472. <div class="main-chart-tip">
  473. <div v-for="item in selectInputs">
  474. <div v-if="item.checked">
  475. <img style="width: 18px;height: 10px;" :src="'/assets/addons/shopro/img/dashboard/'+item.type+'-icon.png'">
  476. <span class="main-chart-tip-msg">{{item.title}}</span>
  477. </div>
  478. </div>
  479. </div>
  480. </div>
  481. <div class="main-position-right">
  482. <el-dropdown>
  483. <span class="el-dropdown-link">
  484. {{dropdownName}}<i class="fa fa-angle-down theme-color-6 top-more"></i>
  485. </span>
  486. <el-dropdown-menu slot="dropdown">
  487. <el-dropdown-item v-for="(item,index) in dropdownList" @click.native="changeTime(index)">
  488. {{item.name}}</el-dropdown-item>
  489. </el-dropdown-menu>
  490. </el-dropdown>
  491. <el-date-picker class="picker-hide" v-model="searchTime" type="datetimerange" range-separator="-"
  492. start-placeholder="开始日期" align="center" @change="getDataInfo" end-placeholder="结束日期">
  493. </el-date-picker>
  494. </div>
  495. </el-col>
  496. <div id="main-chart"></div>
  497. <div v-if="selectInputs.length==0" class="main-chart-tip-con">请选择查看数据</div>
  498. </el-col>
  499. <el-col :xs="24" :sm="24" :md="24" :lg="8" :xl="8" style="margin-top: -15px;">
  500. <el-row>
  501. <!-- :class="['header-conBox-back'+item.id,item.checked?'header-conBox-active':'']" -->
  502. <div v-for="(item,index) in dataList" @click="selectLine(index)">
  503. <el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12" class=" header-con">
  504. <div class="header-conBox"
  505. :style="{'border-color': item.checked?item.color:'#fff',color: item.color}">
  506. <div class="header-con-tip">
  507. <div class="header-con-tip-left">
  508. <img class="header-con-img"
  509. :src="'/assets/addons/shopro/img/dashboard/'+item.type+'.png'" />
  510. <div style="flex: 1;">
  511. <div class="header-con-tip-left-1">
  512. <span>{{item.title}}<span v-if="item.id==6">(累计)</span></span>
  513. <div class="detail" v-if="item.id<5" @click.stop="goDetail(item.id)">
  514. 详情<i class="fa fa-angle-right header-con-tip-i"></i>
  515. </div>
  516. </div>
  517. <div class="header-con-unit">单位/{{item.unit}}</div>
  518. </div>
  519. </div>
  520. </div>
  521. <div class="header-con-msg">
  522. <div class="header-con-msg-num">{{item.num}}</div>
  523. </div>
  524. </div>
  525. </el-col>
  526. </div>
  527. </el-row>
  528. </el-col>
  529. </el-row>
  530. <div class="row top5">
  531. <div class="col-xs-12 col-sm-12 col-md-12 col-lg-6 top5-heght">
  532. <div class="top5-left">
  533. <div class="top5-title">
  534. <div class="theme-color-5 title-left">
  535. TOP5
  536. </div>
  537. </div>
  538. <div v-if="tableData.length>0">
  539. <el-table :data="tableData" border style="width: 100%" :row-class-name="tableRowClassName">
  540. <el-table-column label="排名" width="64">
  541. <template slot-scope="scope">
  542.     <span>{{scope.$index+1}}</span>
  543.   </template>
  544. </el-table-column>
  545. <el-table-column label="商品图" width="80">
  546.   <template slot-scope="scope">
  547.     <img :src="Fast.api.cdnurl(scope.row.image)" width="34" height="34" />
  548.   </template>
  549. </el-table-column>
  550. <el-table-column prop="title" label="商品名称" width="380">
  551. <template slot-scope="scope">
  552. <div class="ellipsis-item">
  553. {{scope.row.title}}
  554. </div>
  555. </template>
  556. </el-table-column>
  557. <el-table-column prop="sales" label="商品销量" width="100">
  558. </el-table-column>
  559. <el-table-column prop="sale_total_money" label="销售额(元)" min-width="120">
  560. </el-table-column>
  561. </el-table>
  562. </div>
  563. <div v-else style="text-align: center;height: 320px;
  564. line-height: 320px;">
  565. 没有找到任何数据,您可以尝试刷新~
  566. </div>
  567. </div>
  568. </div>
  569. <div class="col-xs-12 col-sm-6 col-md-6 col-lg-3 top5-heght">
  570. <div class="top5-center">
  571. <div class="top5-center-top top5-center-top-margin">
  572. <div class="top5-center-top-ring">
  573. <div>
  574. <div class="top5-center-title">
  575. <span>支付单数/总单数</span>
  576. </div>
  577. <div>
  578. <div class="top5-center-tip">支付单数</div>
  579. </div>
  580. </div>
  581. <div class="position-background">
  582. <div class="position-background-inner"></div>
  583. <el-progress
  584. style="position: absolute;left: 50%;top: 50%;margin-top: -41px;margin-left: -41px;"
  585. type="circle" :percentage="(orderFinish.order_scale*100).toFixed(2)" color="#753ECD"
  586. width="82"></el-progress>
  587. </div>
  588. </div>
  589. <div class="top5-center-num theme-color-6">{{orderFinish.order_payed}}单</div>
  590. </div>
  591. <div class="top5-center-top">
  592. <div class="top5-center-top-ring">
  593. <div>
  594. <div class="top5-center-title">
  595. <span>支付金额/总金额</span>
  596. </div>
  597. <div>
  598. <div class="top5-center-tip">支付金额</div>
  599. </div>
  600. </div>
  601. <div class="position-background">
  602. <div class="position-background-inner"></div>
  603. <el-progress
  604. style="position: absolute;left: 50%;top: 50%;margin-top: -41px;margin-left: -41px;"
  605. type="circle" :percentage="(payedFinish.payed_scale*100).toFixed(2)" color="#753ECD"
  606. width="82"></el-progress>
  607. </div>
  608. </div>
  609. <div class="top5-center-num theme-color-6">{{payedFinish.payed_money}}元</div>
  610. </div>
  611. </div>
  612. </div>
  613. <div class="col-xs-12 col-sm-6 col-md-6 col-lg-3 top5-heght">
  614. <div class="top5-right" style="position: relative;">
  615. <div class="top5-title">
  616. <div class="theme-color-5 title-left">
  617. 支付渠道
  618. </div>
  619. </div>
  620. <div class="ring-right-position"></div>
  621. <div class="ring-right-position-inner"></div>
  622. <div id="ring-right"></div>
  623. </div>
  624. </div>
  625. </div>
  626. </div>