Order.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. <template>
  2. <div class="course">
  3. <el-card class="box-card">
  4. <div slot="header" class="clearfix topForm">
  5. <div class="leftForm">
  6. <div class="channelForm">
  7. 渠道选择:
  8. <el-select
  9. v-model="orderParams.channelCode"
  10. @change="channelChange"
  11. style="width:160px"
  12. placeholder="请选择渠道"
  13. >
  14. <el-option
  15. v-for="item in channeList.list"
  16. :key="item.code"
  17. :label="item.title"
  18. :value="item.code"
  19. ></el-option>
  20. </el-select>
  21. </div>
  22. <div class="pruductForm" v-if="orderParams.channelCode">
  23. 产品包选择:
  24. <el-select style="width:160px" v-model="orderParams.packageId" placeholder="请选择产品包">
  25. <el-option
  26. v-for="item in productList"
  27. :key="item.id"
  28. :label="item.title"
  29. :value="item.id"
  30. ></el-option>
  31. </el-select>
  32. </div>
  33. <div class="dateForm">
  34. 查询日期:
  35. <el-date-picker style="width:140px" v-model="orderParams.startDate" type="date" placeholder="起"></el-date-picker>
  36. <el-date-picker style="width:140px" v-model="orderParams.endDate" type="date" placeholder="止"></el-date-picker>
  37. </div>
  38. </div>
  39. <el-button type="primary" style="float: right;" @click="search">搜索</el-button>
  40. </div>
  41. <el-table :data="orderList" border style="width: 100%" :height="tableHeight">
  42. <el-table-column label="日期" fixed prop="day" align="left" header-align="center" min-width="120px"></el-table-column>
  43. <el-table-column label="流量与观看" header-align="center">
  44. <!-- <el-table-column label="产品包名称" prop="packageTitle" align="left" header-align="center"></el-table-column> -->
  45. <el-table-column
  46. label="UV"
  47. prop="uv"
  48. align="right"
  49. header-align="center"
  50. min-width="100px"
  51. ></el-table-column>
  52. <el-table-column
  53. label="VIP用户 | -UV1"
  54. align="right"
  55. header-align="center"
  56. :render-header="renderheader"
  57. prop="vipUv"
  58. min-width="120px"
  59. ></el-table-column>
  60. <el-table-column
  61. label="非VIP用户 | UV2=UV-UV1"
  62. align="right"
  63. header-align="center"
  64. :render-header="renderheader"
  65. prop="waitVipUv"
  66. min-width="140px"
  67. ></el-table-column>
  68. <el-table-column
  69. label="VIP用户占比 | =UV1/UV"
  70. align="right"
  71. header-align="center"
  72. :render-header="renderheader"
  73. prop="vipProportion"
  74. min-width="140px"
  75. ></el-table-column>
  76. <el-table-column
  77. label="VV"
  78. prop="pv"
  79. align="right"
  80. header-align="center"
  81. min-width="100px"
  82. ></el-table-column>
  83. <el-table-column
  84. label="人均播放 | =VV/UV"
  85. align="right"
  86. header-align="center"
  87. :render-header="renderheader"
  88. prop="perCapitaPlay"
  89. min-width="140px"
  90. ></el-table-column>
  91. </el-table-column>
  92. <el-table-column label="拉新,付费与转换率" header-align="center">
  93. <el-table-column
  94. label="连续包月 | -Qm1"
  95. align="right"
  96. header-align="center"
  97. :render-header="renderheader"
  98. prop="consecutiveMonthly"
  99. min-width="100px"
  100. ></el-table-column>
  101. <el-table-column
  102. label="月包 | -Qm2"
  103. align="right"
  104. header-align="center"
  105. :render-header="renderheader"
  106. prop="monthlyPayment"
  107. min-width="90px"
  108. ></el-table-column>
  109. <el-table-column
  110. label="年包 | -Qy"
  111. align="right"
  112. header-align="center"
  113. :render-header="renderheader"
  114. prop="yearlyPayment"
  115. min-width="90px"
  116. ></el-table-column>
  117. <el-table-column
  118. label="付费订单数量| Q=Qm1+Qm2+Qy"
  119. align="right"
  120. header-align="center"
  121. :render-header="renderheader"
  122. prop="totalPayment"
  123. min-width="160px"
  124. ></el-table-column>
  125. // 连续包月占比
  126. <el-table-column
  127. label="r1 | =Qm1/Q"
  128. align="right"
  129. header-align="center"
  130. :render-header="renderheader"
  131. prop="consecutiveConversion"
  132. min-width="130px"
  133. ></el-table-column>
  134. // 月包占比
  135. <el-table-column
  136. label="r2 | =Qm2/Q"
  137. align="right"
  138. header-align="center"
  139. :render-header="renderheader"
  140. prop="monthlyConversion"
  141. min-width="130px"
  142. ></el-table-column>
  143. // 年包占比
  144. <el-table-column
  145. label="r3 | =Qy/Q"
  146. align="right"
  147. header-align="center"
  148. :render-header="renderheader"
  149. prop="yearlyConversion"
  150. min-width="130px"
  151. ></el-table-column>
  152. <el-table-column
  153. label="R | =(Qm1+Qm2+Qy)/UV2"
  154. align="right"
  155. header-align="center"
  156. :render-header="renderheader"
  157. prop="totalConversion"
  158. min-width="190px"
  159. ></el-table-column>
  160. </el-table-column>
  161. </el-table>
  162. <!-- <el-pagination
  163. v-if="orderList.totalElements"
  164. background
  165. layout="prev, pager, next"
  166. :total="orderList.totalElements"
  167. @current-change="changePage">
  168. </el-pagination>-->
  169. </el-card>
  170. </div>
  171. </template>
  172. <script>
  173. import { mapGetters } from "vuex";
  174. import formatDate from "../../utils/formatTime";
  175. export default {
  176. data() {
  177. return {
  178. pickerOptions: {
  179. shortcuts: [
  180. {
  181. text: "最近一周",
  182. onClick(picker) {
  183. const end = new Date();
  184. const start = new Date();
  185. start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
  186. picker.$emit("pick", [start, end]);
  187. }
  188. },
  189. {
  190. text: "最近一个月",
  191. onClick(picker) {
  192. const end = new Date();
  193. const start = new Date();
  194. start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
  195. picker.$emit("pick", [start, end]);
  196. }
  197. },
  198. {
  199. text: "最近三个月",
  200. onClick(picker) {
  201. const end = new Date();
  202. const start = new Date();
  203. start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
  204. picker.$emit("pick", [start, end]);
  205. }
  206. }
  207. ]
  208. },
  209. tableHeight: 500,
  210. dateValue: "",
  211. orderParams: {
  212. channelCode: "",
  213. startDate: "",
  214. endDate: "",
  215. packageId: ""
  216. },
  217. formatTime: (row, column) => {
  218. let date = new Date(row.gmtCreated);
  219. let Y = date.getFullYear() + "-";
  220. let M =
  221. date.getMonth() + 1 < 10
  222. ? "0" + (date.getMonth() + 1) + "-"
  223. : date.getMonth() + 1 + "-";
  224. let D =
  225. date.getDate() < 10
  226. ? "0" + date.getDate() + " "
  227. : date.getDate() + " ";
  228. let h =
  229. date.getHours() < 10
  230. ? "0" + date.getHours() + ":"
  231. : date.getHours() + ":";
  232. let m =
  233. date.getMinutes() < 10
  234. ? "0" + date.getMinutes() + ":"
  235. : date.getMinutes() + ":";
  236. let s =
  237. date.getSeconds() < 10 ? "0" + date.getSeconds() : date.getSeconds();
  238. return Y + M + D + h + m + s;
  239. }
  240. // orderList:[]
  241. };
  242. },
  243. computed: {
  244. ...mapGetters({
  245. channeList: "channeList",
  246. orderList: "orderList",
  247. productList: "productList"
  248. })
  249. },
  250. created() {
  251. this.$store.dispatch("getChannelList", { pageNo: "", pageSize: "" });
  252. // this.$store.dispatch("getOrderList", this.orderParams);
  253. this.orderParams.startDate = this.getYesterDay();
  254. this.orderParams.endDate = this.getYesterDay();
  255. console.log(
  256. "document.documentElement.clientHeight",
  257. document.documentElement.clientHeight
  258. );
  259. this.tableHeight = document.documentElement.clientHeight * 0.75;
  260. },
  261. methods: {
  262. // 搜索
  263. search() {
  264. this.orderParams.startDate = this.orderParams.startDate
  265. ? formatDate(this.orderParams.startDate, 2)
  266. : "";
  267. this.orderParams.endDate = this.orderParams.endDate
  268. ? formatDate(this.orderParams.endDate, 2)
  269. : "";
  270. this.$store.dispatch("getOrderList", this.orderParams);
  271. },
  272. // 渠道下课程分页
  273. changePage(e) {
  274. this.orderParams.pageNo = e;
  275. this.$store.dispatch("getRelationList", this.orderParams);
  276. },
  277. channelChange(val) {
  278. // this.$store.dispatch("clearProductList");
  279. this.orderParams.packageId = "";
  280. this.$store.dispatch("getProductList", { channelCode: val });
  281. console.log(456464, this.productList);
  282. },
  283. // 表头折行
  284. renderheader(h, { column, $index }) {
  285. return h("span", {}, [
  286. h("span", {}, column.label.split("|")[0]),
  287. h("br"),
  288. h("span", {}, column.label.split("|")[1])
  289. ]);
  290. },
  291. getYesterDay() {
  292. let yesterday = new Date().getTime() - 86400000;
  293. return formatDate(yesterday, 2);
  294. }
  295. }
  296. };
  297. </script>
  298. <style lang="less" scoped>
  299. .el-pagination {
  300. text-align: center;
  301. margin-top: 20px;
  302. }
  303. .el-form-item__content {
  304. width: 50%;
  305. }
  306. .el-input {
  307. width: 217px;
  308. }
  309. .pruductForm {
  310. margin-left: 10px;
  311. }
  312. .topForm {
  313. display: flex;
  314. align-items: center;
  315. flex-direction: row;
  316. justify-content: space-between;
  317. }
  318. .leftForm {
  319. display: flex;
  320. align-items: center;
  321. flex-direction: row;
  322. justify-content: space-between;
  323. }
  324. .dateForm {
  325. margin-left: 18px;
  326. }
  327. </style>