robotRanking.vue 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884
  1. <template>
  2. <div class="robotRanking flex-col">
  3. <div class="box1 flex-col">
  4. <s-header :name="$t('robotRanking.machineSalesRanking')" :noback="true" :isFixed="false"></s-header>
  5. <div class="box3 flex-col">
  6. <div class="main1 flex-col">
  7. <div class="mod1 flex-col">
  8. <div class="section1 flex-row justify-between">
  9. <div class="ImageText1 flex-col">
  10. <div class="group4 flex-row justify-between">
  11. <div class="layer3 flex-col"></div>
  12. <span class="word3 flex-col">
  13. {{ $t("robotRanking.machineSalesRanking") }}
  14. </span>
  15. </div>
  16. </div>
  17. <div class="flex-col">
  18. <div @click="noticeClk" class="main5 flex-row justify-between">
  19. <img class="label2" src="@/assets/device/searchIcon.png" />
  20. </div>
  21. </div>
  22. </div>
  23. </div>
  24. <img class="img1" referrerpolicy="no-referrer" src="../assets/line.png" />
  25. <div class="l-f l-flex-e o-plr-15">
  26. <span class="robotLabelName l-in c-text-13" style="color: #404d74">{{ $t("robotRanking.dailySalesRanking")
  27. }}:</span>
  28. <kTabs @tabclk="(e) => tabclk(e, 'day')" :tabList="tabDayList"></kTabs>
  29. </div>
  30. <div v-if="!totalNoData('day')" ref="dayChartBox" class="mod3 flex-col"></div>
  31. <kNoData v-else></kNoData>
  32. <div class="groove"></div>
  33. <div class="l-f l-flex-e o-plr-15">
  34. <span class="robotLabelName l-in o-mr-6 c-text-13" style="color: #404d74">{{
  35. $t("robotRanking.salesRankingThisWeek") }}:</span>
  36. <kTabs @tabclk="(e) => tabclk(e, 'week')" :tabList="tabWeekList"></kTabs>
  37. </div>
  38. <div v-if="!totalNoData('week')" ref="weekChartBox" class="mod5 flex-col"></div>
  39. <kNoData v-else></kNoData>
  40. <div class="groove"></div>
  41. <div class="l-f l-flex-e o-plr-15">
  42. <span class="robotLabelName l-in o-mr-6 c-text-13" style="color: #404d74">{{
  43. $t("robotRanking.salesRankingThisMonth") }}:</span>
  44. <kTabs @tabclk="(e) => tabclk(e, 'month')" :tabList="tabMonthList"></kTabs>
  45. </div>
  46. <div v-if="!totalNoData('month')" ref="monthChartBox" class="mod9 flex-col"></div>
  47. <kNoData v-else></kNoData>
  48. <div class="groove"></div>
  49. <div class="l-f l-flex-e o-plr-15">
  50. <span class="robotLabelName l-in o-mr-6 c-text-13" style="color: #404d74">{{
  51. $t("robotRanking.salesRankingThisYear") }}:</span>
  52. <kTabs @tabclk="(e) => tabclk(e, 'year')" :tabList="tabYearList"></kTabs>
  53. </div>
  54. <div v-if="!totalNoData('year')" ref="yearChartBox" class="mod11 flex-col"></div>
  55. <kNoData v-else></kNoData>
  56. <div class="groove"></div>
  57. </div>
  58. </div>
  59. </div>
  60. <!-- 筛选弹窗 -->
  61. <kDialog :dialogTitle="$t('subLedgerManage.search.title')" :confirmBtnTxt="$t('subLedgerManage.search.screen')"
  62. ref="kDialogRef" @confirmclk="confirmClk">
  63. <template #content>
  64. <div class="cust_vantBorder">
  65. <!-- <van-field @click-input="busiInpClk" readonly clearable v-model="searchForm.businessName"
  66. :placeholder="$t('subLedgerManage.search.busiPlaceholder')" :label="$t('subLedgerManage.search.business')">
  67. <template #right-icon>
  68. <div class="l-flex-RC">
  69. <van-icon v-if="searchForm.businessName" @click="searchForm.businessName = ''" class="o-mr-6"
  70. name="clear" />
  71. <van-icon @click="busiInpClk" name="arrow-down" />
  72. </div>
  73. </template>
  74. </van-field> -->
  75. <van-field @click-input="changeTypeInpClk" readonly clearable v-model="searchForm.changeTypeName"
  76. :placeholder="$t('robotRanking.changeTypePlace')" :label="$t('robotRanking.changeType')">
  77. <template #right-icon>
  78. <div class="l-flex-RC">
  79. <van-icon v-if="searchForm.changeTypeName" @click="
  80. searchForm.changeTypeName = '';
  81. searchForm.changeType = '';
  82. " class="o-mr-6" name="clear" />
  83. <van-icon @click="changeTypeInpClk" name="arrow-down" />
  84. </div>
  85. </template>
  86. </van-field>
  87. <van-field @click-input="machineTypeInpClk" readonly clearable v-model="searchForm.machineTypeName"
  88. :placeholder="$t('robotRanking.machineTypePlace')" :label="$t('robotRanking.machineType')">
  89. <template #right-icon>
  90. <div class="l-flex-RC">
  91. <van-icon v-if="searchForm.machineTypeName" @click="
  92. searchForm.machineTypeName = '';
  93. searchForm.machineType = '';
  94. " class="o-mr-6" name="clear" />
  95. <van-icon @click="machineTypeInpClk" name="arrow-down" />
  96. </div>
  97. </template>
  98. </van-field>
  99. <van-field v-if="isAdmin()" @click-input="companyTypeInpClk" readonly clearable
  100. v-model="searchForm.companyTypeName" :placeholder="$t('robotRanking.companyTypePlaceholder')"
  101. :label="$t('robotRanking.companyTypeLabel')">
  102. <template #right-icon>
  103. <div class="l-flex-RC">
  104. <van-icon v-if="searchForm.companyTypeName" @click="
  105. searchForm.companyTypeName = '';
  106. searchForm.companyType = '';
  107. " class="o-mr-6" name="clear" />
  108. <van-icon @click="companyTypeInpClk" name="arrow-down" />
  109. </div>
  110. </template>
  111. </van-field>
  112. </div>
  113. </template>
  114. </kDialog>
  115. <!-- 商家选择框 -->
  116. <van-popup v-model:show="busiPopShow" position="bottom">
  117. <van-picker :title="$t('subLedgerManage.search.busiPlaceholder')" :columns="busiPopList"
  118. :columns-field-names="busiPopFieldName" @confirm="busiPopConfirm" @cancel="busiPopShow = false" />
  119. </van-popup>
  120. <!-- 统计方式弹窗 -->
  121. <van-popup v-model:show="changeTypeShow" position="bottom">
  122. <van-picker :default-index="chgTypeDefaIdx" :title="$t('robotRanking.changeTypePlace')" :columns="changeTypePopList"
  123. :columns-field-names="yearPopFieldName" @confirm="changeTypePopConfirm" @cancel="changeTypeShow = false" />
  124. </van-popup>
  125. <!-- 设备类型弹窗 -->
  126. <van-popup v-model:show="machineTypeShow" position="bottom">
  127. <van-picker :default-index="maTypeDefaIdx" :title="$t('robotRanking.machineTypePlace')"
  128. :columns="machineTypePopList" :columns-field-names="yearPopFieldName" @confirm="machineTypePopConfirm"
  129. @cancel="machineTypeShow = false" />
  130. </van-popup>
  131. <!-- 公司平台弹窗 -->
  132. <van-popup v-model:show="companyTypeShow" position="bottom">
  133. <van-picker :default-index="maTypeDefaIdx" :title="$t('robotRanking.companyTypePlaceholder')"
  134. :columns="companyTypePopList" :columns-field-names="yearPopFieldName" @confirm="companyTypePopConfirm"
  135. @cancel="companyTypeShow = false" />
  136. </van-popup>
  137. <!-- 日的日期选择弹窗 -->
  138. <van-calendar @confirm="calendarDayConfirm" v-model:show="dayShow" color="#4d6add" :min-date="minDate"
  139. :show-confirm="false" />
  140. <!-- 周的日期选择弹窗 -->
  141. <van-calendar @confirm="(e) => {
  142. calendarWeekOrMonConfirm(e, 1);
  143. }
  144. " v-model:show="weekShow" :allow-same-day="true" color="#4d6add" :min-date="minDate" type="range" />
  145. <!-- 月的日期选择弹窗 -->
  146. <van-calendar @confirm="(e) => {
  147. calendarWeekOrMonConfirm(e, 2);
  148. }
  149. " v-model:show="monthShow" :allow-same-day="true" color="#4d6add" :min-date="minDate" type="range" />
  150. <!-- 年的日期选择弹窗 -->
  151. <van-popup v-model:show="yearShow" position="bottom">
  152. <van-picker :title="$t('robotRanking.yearPopTitle')" :columns="yearPopList" :columns-field-names="yearPopFieldName"
  153. @confirm="yearPopConfirm" @cancel="yearShow = false" />
  154. </van-popup>
  155. <!-- <nav-bar></nav-bar> -->
  156. </div>
  157. </template>
  158. <script>
  159. // 导入无数据组件
  160. import kNoData from "../components/commom/kNoData/index.vue";
  161. import { onMounted, ref, reactive, computed, nextTick } from "vue";
  162. import sHeader from "../components/SimpleHeader";
  163. // import navBar from "../components/NavBar";
  164. import { getRankingList } from "../service/robotRanking";
  165. import { getLoginUser, styleUrl } from "../common/js/utils";
  166. import kTabs from "../components/commom/kTabs/index.vue";
  167. import kDialog from "../components/commom/kDialog/index.vue";
  168. import moment from "moment";
  169. import { showToast } from "vant";
  170. import { useI18n } from "vue-i18n";
  171. export default {
  172. setup() {
  173. // 引入语言
  174. const { t } = useI18n();
  175. // 日周月年的数据
  176. const totalObj = reactive({
  177. dayData: {},
  178. weekData: {},
  179. monthData: {},
  180. yearData: {},
  181. });
  182. // 日周月年图表没有数据
  183. const totalNoData = computed(() => (idx) => {
  184. let dataObj;
  185. switch (idx) {
  186. case "day":
  187. dataObj = totalObj.dayData;
  188. break;
  189. case "week":
  190. dataObj = totalObj.weekData;
  191. break;
  192. case "month":
  193. dataObj = totalObj.monthData;
  194. break;
  195. case "year":
  196. dataObj = totalObj.yearData;
  197. break;
  198. }
  199. if (!dataObj || dataObj?.categories?.length === 0) {
  200. return true;
  201. }
  202. return false;
  203. });
  204. // 统计方式弹窗
  205. const changeTypeInpClk = () => {
  206. changeTypeShow.value = true;
  207. };
  208. // 是否管理员
  209. const isAdmin = () => { return (user && user.type === 0); }
  210. // 公司平台弹窗
  211. const companyTypeInpClk = () => {
  212. companyTypeShow.value = true;
  213. };
  214. // 设备类型弹窗
  215. const machineTypeInpClk = () => {
  216. machineTypeShow.value = true;
  217. };
  218. const changeTypeShow = ref(false);
  219. const machineTypeShow = ref(false);
  220. const companyTypeShow = ref(false);
  221. // 默认选中
  222. const chgTypeDefaIdx = ref(1);
  223. const maTypeDefaIdx = ref("");
  224. const changeTypePopList = [
  225. {
  226. name: t("robotRanking.patternStatistics"),
  227. id: 1,
  228. },
  229. {
  230. name: t("robotRanking.salesStatistics"),
  231. id: 0,
  232. },
  233. ];
  234. const machineTypePopList = [
  235. {
  236. name: t("robotRanking.whole"),
  237. id: "",
  238. },
  239. {
  240. name: t("robotRanking.MG"),
  241. id: "0",
  242. },
  243. {
  244. name: t("robotRanking.POP"),
  245. id: "1",
  246. },
  247. ];
  248. const companyTypePopList = [
  249. {
  250. name: t("robotRanking.whole"),
  251. id: "",
  252. },
  253. {
  254. name: t("robotRanking.sz"),
  255. id: "0",
  256. },
  257. {
  258. name: t("robotRanking.sc"),
  259. id: "1",
  260. },
  261. ];
  262. const changeTypePopConfirm = ({ selectedOptions }) => {
  263. searchForm.changeType = selectedOptions[0].id;
  264. searchForm.changeTypeName = selectedOptions[0].name;
  265. changeTypeShow.value = false;
  266. };
  267. const machineTypePopConfirm = ({ selectedOptions }) => {
  268. searchForm.machineType = selectedOptions[0].id;
  269. searchForm.machineTypeName = selectedOptions[0].name;
  270. machineTypeShow.value = false;
  271. };
  272. const companyTypePopConfirm = ({ selectedOptions }) => {
  273. searchForm.companyType = selectedOptions[0].id;
  274. searchForm.companyTypeName = selectedOptions[0].name;
  275. companyTypeShow.value = false;
  276. };
  277. // 年的日期选择弹窗
  278. // 点击确定
  279. const yearPopConfirm = ({ selectedOptions }) => {
  280. const year = selectedOptions[0].id;
  281. const startDate =
  282. moment().year(year).startOf("year").format("YYYY-MM-DD") + " 00:00:00";
  283. const endDate =
  284. moment().year(year).endOf("year").format("YYYY-MM-DD") + " 23:59:59";
  285. console.log("startDate", startDate);
  286. console.log("endDate", endDate);
  287. getEquipRankList("year", startDate, endDate);
  288. yearShow.value = false;
  289. };
  290. // 获取当前年前4年后1年
  291. let yearPopList = [];
  292. for (let i = 0; i < 4; i++) {
  293. const year = moment().subtract(i, "years").format("YYYY");
  294. yearPopList.push({
  295. name: year,
  296. id: year,
  297. });
  298. }
  299. const yearPopFieldName = reactive({
  300. text: "name",
  301. value: "id",
  302. });
  303. const yearShow = ref(false);
  304. const currentDate = ref(new Date());
  305. const yearFormatter = (type, val) => {
  306. if (type === "year") {
  307. return val;
  308. }
  309. return val;
  310. };
  311. // 周和月的日期选择弹窗
  312. const weekShow = ref(false);
  313. const monthShow = ref(false);
  314. const calendarWeekOrMonConfirm = (e, idx) => {
  315. const startDate = e[0];
  316. const endDate = e[1];
  317. let weekOrMont = "month";
  318. // 如果是周计算开始和结束日期相差多少天,因为周不能超过7天
  319. if (idx === 1) {
  320. weekOrMont = "week";
  321. const differDays = moment(endDate).diff(moment(startDate), "days");
  322. if (differDays >= 7) {
  323. showToast(t("robotRanking.seleWeekDateRangeNotSeveDays"));
  324. return;
  325. }
  326. }
  327. const startTime = moment(e[0]).format("YYYY-MM-DD") + " 00:00:00";
  328. const endTime = moment(e[1]).format("YYYY-MM-DD") + " 23:59:59";
  329. getEquipRankList(weekOrMont, startTime, endTime);
  330. if (idx === 1) {
  331. weekShow.value = false;
  332. } else {
  333. monthShow.value = false;
  334. }
  335. };
  336. // 日的日期选择弹窗
  337. // 日历选择触发
  338. const calendarDayConfirm = (e) => {
  339. const startDate = moment(e).format("YYYY-MM-DD") + " 00:00:00";
  340. const endDate = moment(e).format("YYYY-MM-DD") + " 23:59:59";
  341. getEquipRankList("day", startDate, endDate);
  342. dayShow.value = false;
  343. };
  344. // 最小日期选择
  345. const minDate = new Date(2018, 1, 1);
  346. const dayShow = ref(false);
  347. // 日,周,月,年的tab栏数据
  348. const tabDayList = ref([
  349. {
  350. name: t("robotRanking.today"),
  351. icon: "",
  352. id: 1,
  353. },
  354. {
  355. name: t("robotRanking.yesterday"),
  356. icon: "",
  357. id: 2,
  358. },
  359. {
  360. name: t("robotRanking.other"),
  361. icon: "arrow-down",
  362. id: 3,
  363. },
  364. ]);
  365. const tabWeekList = ref([
  366. {
  367. name: t("robotRanking.thisWeek"),
  368. icon: "",
  369. id: 1,
  370. },
  371. {
  372. name: t("robotRanking.lastWeek"),
  373. icon: "",
  374. id: 2,
  375. },
  376. {
  377. name: t("robotRanking.other"),
  378. icon: "arrow-down",
  379. id: 3,
  380. },
  381. ]);
  382. const tabMonthList = ref([
  383. {
  384. name: t("robotRanking.thisMonth"),
  385. icon: "",
  386. id: 1,
  387. },
  388. {
  389. name: t("robotRanking.lastMonth"),
  390. icon: "",
  391. id: 2,
  392. },
  393. {
  394. name: t("robotRanking.other"),
  395. icon: "arrow-down",
  396. id: 3,
  397. },
  398. ]);
  399. const tabYearList = ref([
  400. {
  401. name: t("robotRanking.thisYear"),
  402. icon: "",
  403. id: 1,
  404. },
  405. {
  406. name: t("robotRanking.lastYear"),
  407. icon: "",
  408. id: 2,
  409. },
  410. {
  411. name: t("robotRanking.other"),
  412. icon: "arrow-down",
  413. id: 3,
  414. },
  415. ]);
  416. // 默认进来的时间
  417. const defaultTime = reactive({
  418. // 今日
  419. todayStart: moment().format("YYYY-MM-DD") + " 00:00:00",
  420. todayEnd: moment().format("YYYY-MM-DD") + " 23:59:59",
  421. // 昨日
  422. colastdayStart:
  423. moment()
  424. .day(moment().day() - 1)
  425. .format("YYYY-MM-DD") + " 00:00:00",
  426. colastdayEnd:
  427. moment()
  428. .day(moment().day() - 1)
  429. .format("YYYY-MM-DD") + " 23:59:59",
  430. // 这周
  431. weekStart: moment().weekday(1).format("YYYY-MM-DD") + " 00:00:00",
  432. weekEnd: moment().weekday(7).format("YYYY-MM-DD") + " 23:59:59",
  433. // 上周
  434. lastWeekStart: moment().week(moment().week() - 1).startOf('week').add(1, 'days').format("YYYY-MM-DD") + " 00:00:00",
  435. // moment()
  436. // .week(moment().week() - 1)
  437. // .startOf("week")
  438. // .format("YYYY-MM-DD") + " 00:00:00",
  439. lastWeekEnd: moment().week(moment().week() - 1).endOf('week').add(1, 'days').format("YYYY-MM-DD") + " 23:59:59",
  440. // moment()
  441. // .week(moment().week() - 1)
  442. // .endOf("week")
  443. // .format("YYYY-MM-DD") + " 23:59:59",
  444. // 这个月
  445. monthStart: moment().startOf("month").format("YYYY-MM-DD") + " 00:00:00",
  446. monthEnd: moment().endOf("month").format("YYYY-MM-DD") + " 23:59:59",
  447. // 上个月
  448. lastmonthStart:
  449. moment()
  450. .month(moment().month() - 1)
  451. .startOf("month")
  452. .format("YYYY-MM-DD") + " 00:00:00",
  453. lastmonthEnd:
  454. moment()
  455. .month(moment().month() - 1)
  456. .endOf("month")
  457. .format("YYYY-MM-DD") + " 23:59:59",
  458. // 今年
  459. yearStart: moment().startOf("year").format("YYYY-MM-DD") + " 00:00:00",
  460. yearEnd: moment().endOf("year").format("YYYY-MM-DD") + " 23:59:59",
  461. // 上年
  462. lastYearStart:
  463. moment()
  464. .year(moment().year() - 1)
  465. .startOf("year")
  466. .format("YYYY-MM-DD") + " 00:00:00",
  467. lastYearEnd:
  468. moment()
  469. .year(moment().year() - 1)
  470. .endOf("year")
  471. .format("YYYY-MM-DD") + " 23:59:59",
  472. });
  473. // 点击tab
  474. const tabclk = (e, type) => {
  475. let startDate = "";
  476. let endDate = "";
  477. switch (type) {
  478. case "day":
  479. switch (e.name) {
  480. case 0:
  481. startDate = defaultTime.todayStart;
  482. endDate = defaultTime.todayEnd;
  483. break;
  484. case 1:
  485. startDate = defaultTime.colastdayStart;
  486. endDate = defaultTime.colastdayEnd;
  487. break;
  488. case 2:
  489. // 打开日历弹窗
  490. dayShow.value = true;
  491. break;
  492. }
  493. break;
  494. case "week":
  495. switch (e.name) {
  496. case 0:
  497. startDate = defaultTime.weekStart;
  498. endDate = defaultTime.weekEnd;
  499. break;
  500. case 1:
  501. startDate = defaultTime.lastWeekStart;
  502. endDate = defaultTime.lastWeekEnd;
  503. break;
  504. case 2:
  505. // 打开周的日期选择弹窗
  506. weekShow.value = true;
  507. break;
  508. }
  509. break;
  510. case "month":
  511. switch (e.name) {
  512. case 0:
  513. startDate = defaultTime.monthStart;
  514. endDate = defaultTime.monthEnd;
  515. break;
  516. case 1:
  517. startDate = defaultTime.lastmonthStart;
  518. endDate = defaultTime.lastmonthEnd;
  519. break;
  520. case 2:
  521. // 打开月的日期选择弹窗
  522. monthShow.value = true;
  523. break;
  524. }
  525. break;
  526. case "year":
  527. switch (e.name) {
  528. case 0:
  529. startDate = defaultTime.yearStart;
  530. endDate = defaultTime.yearEnd;
  531. break;
  532. case 1:
  533. startDate = defaultTime.lastYearStart;
  534. endDate = defaultTime.lastYearEnd;
  535. break;
  536. case 2:
  537. // 打开年的日期弹窗
  538. yearShow.value = true;
  539. break;
  540. }
  541. break;
  542. }
  543. // 如果是点击其他,不用请求
  544. if (e.name !== 2) {
  545. // 获取日、周、月、年的排行数据
  546. getEquipRankList(type, startDate, endDate);
  547. }
  548. };
  549. const changeType = ref(0);
  550. const companyType = ref(""); // 公司平台
  551. const machineType = ref(""); // 设备类型
  552. let chartObj = {
  553. day: null,
  554. week: null,
  555. month: null,
  556. year: null,
  557. };
  558. // 获取日、周、月、年的排行数据
  559. const getEquipRankList = (chartType, startDate, endDate) => {
  560. let param = {
  561. adminId: user.id,
  562. ifForeign: user.ifForeign,
  563. changeType: changeType.value, //必填,默认为一0:销售额统计,1:花型统计
  564. companyType: companyType.value,
  565. machineType: machineType.value,
  566. chartType,
  567. startDate,
  568. endDate,
  569. };
  570. getRankingList(param).then(async (res) => {
  571. const { data } = res;
  572. switch (chartType) {
  573. case "day":
  574. totalObj.dayData = data.data;
  575. // console.log("日返回值", data);
  576. break;
  577. case "week":
  578. totalObj.weekData = data.data;
  579. // console.log("周返回值", data);
  580. break;
  581. case "month":
  582. totalObj.monthData = data.data;
  583. // console.log("月返回值", data);
  584. break;
  585. case "year":
  586. totalObj.yearData = data.data;
  587. // console.log("年返回值", data);
  588. break;
  589. }
  590. // 有数据返回则处理
  591. if (data.code && data.data) {
  592. // echarts的配置
  593. const chartOption = {
  594. tooltip: {
  595. trigger: "axis",
  596. axisPointer: {
  597. type: "shadow",
  598. },
  599. },
  600. // 固定屏幕显示多少个,其余的滑动
  601. dataZoom: [
  602. // {
  603. // type: 'slider',
  604. // xAxisIndex: 0,
  605. // filterMode: 'none',
  606. // // 开始的值
  607. // startValue: null,
  608. // // 结束的值
  609. // endValue: null,
  610. // // 锁定滑动的区域
  611. // // zoomLock:true,
  612. // },
  613. {
  614. type: "inside",
  615. xAxisIndex: 0,
  616. filterMode: "none",
  617. startValue: null,
  618. endValue: null,
  619. zoomLock: true,
  620. },
  621. ],
  622. grid: {
  623. left: "3%",
  624. right: "4%",
  625. bottom: "10%",
  626. containLabel: true,
  627. },
  628. legend: {
  629. bottom: 0,
  630. right: 10,
  631. itemWidth: 10,
  632. itemHeight: 10,
  633. icon: "rect",
  634. },
  635. yAxis: { type: "value" },
  636. xAxis: {
  637. type: "category",
  638. axisLabel: {
  639. rotate: 45,
  640. },
  641. data: [],
  642. },
  643. series: [],
  644. };
  645. await nextTick();
  646. let chartBox;
  647. switch (chartType) {
  648. case "day":
  649. chartBox = dayChartBox.value;
  650. break;
  651. case "week":
  652. chartBox = weekChartBox.value;
  653. break;
  654. case "month":
  655. chartBox = monthChartBox.value;
  656. break;
  657. case "year":
  658. chartBox = yearChartBox.value;
  659. break;
  660. }
  661. if (chartBox) {
  662. const dayChartOption = Object.assign({}, chartOption);
  663. dayChartOption.xAxis.data = data.data.categories;
  664. dayChartOption.series = [
  665. {
  666. ...data.data.series[0],
  667. type: "bar",
  668. itemStyle: { color: "#e59a6d" },
  669. name: t("home.productNum"),
  670. label: {
  671. show: true,
  672. position: "top",
  673. },
  674. },
  675. {
  676. ...data.data.series[1],
  677. type: "bar",
  678. itemStyle: { color: "#4d6add" },
  679. name: t("home.salesAmount"),
  680. label: {
  681. show: true,
  682. position: "top",
  683. },
  684. },
  685. ];
  686. dayChartOption.dataZoom[0]["startValue"] =
  687. data.data.categories[0];
  688. dayChartOption.dataZoom[0]["endValue"] =
  689. data.data.categories[3];
  690. // 解决resize不起作用,配合onMounted里的方法使用
  691. switch (chartType) {
  692. case "day":
  693. chartObj.day = window.echarts.init(chartBox, null, {
  694. renderer: "canvas",
  695. useDirtyRect: false,
  696. });
  697. chartObj.day && chartObj.day.setOption(dayChartOption);
  698. break;
  699. case "week":
  700. chartObj.week = window.echarts.init(chartBox, null, {
  701. renderer: "canvas",
  702. useDirtyRect: false,
  703. });
  704. chartObj.week && chartObj.week.setOption(dayChartOption);
  705. break;
  706. case "month":
  707. chartObj.month = window.echarts.init(chartBox, null, {
  708. renderer: "canvas",
  709. useDirtyRect: false,
  710. });
  711. chartObj.month && chartObj.month.setOption(dayChartOption);
  712. break;
  713. case "year":
  714. chartObj.year = window.echarts.init(chartBox, null, {
  715. renderer: "canvas",
  716. useDirtyRect: false,
  717. });
  718. chartObj.year && chartObj.year.setOption(dayChartOption);
  719. break;
  720. }
  721. }
  722. }
  723. });
  724. };
  725. const user = getLoginUser();
  726. // 日、周、月、年的图表
  727. const dayChartBox = ref();
  728. const weekChartBox = ref();
  729. const monthChartBox = ref();
  730. const yearChartBox = ref();
  731. // 初始化页面获取列表
  732. onMounted(async () => {
  733. // 加载样式
  734. styleUrl('robotRanking');
  735. // 默认筛选选中
  736. searchForm.changeTypeName = t("robotRanking.salesStatistics");
  737. searchForm.changeType = 0;
  738. searchForm.companyTypeName = t("robotRanking.whole");
  739. searchForm.machineTypeName = t("robotRanking.whole");
  740. // 查询是否有订单数据权限
  741. const isOrderData = user.menuCodeList.some((item) => {
  742. return item === "M4";
  743. })
  744. // 如果是type为admin或者商家或者是有订单数据权限M4的子商家才可以查看
  745. if (user.type === 0 || user.type === 2 || isOrderData) {
  746. init();
  747. }
  748. window.addEventListener("resize", () => {
  749. chartObj.day && chartObj.day.resize();
  750. chartObj.week && chartObj.week.resize();
  751. chartObj.month && chartObj.month.resize();
  752. chartObj.year && chartObj.year.resize();
  753. });
  754. });
  755. // 刚进页面获取
  756. const init = () => {
  757. // 获取日的排行数据
  758. getEquipRankList("day", defaultTime.todayStart, defaultTime.todayEnd);
  759. // 获取周的排行数据
  760. getEquipRankList("week", defaultTime.weekStart, defaultTime.weekEnd);
  761. // 获取月的排行数据
  762. getEquipRankList("month", defaultTime.monthStart, defaultTime.monthEnd);
  763. // 获取年的排行数据
  764. getEquipRankList("year", defaultTime.yearStart, defaultTime.yearEnd);
  765. };
  766. const searchForm = reactive({
  767. businessName: "",
  768. changeTypeName: "",
  769. changeType: "",
  770. machineTypeName: "",
  771. machineType: "",
  772. companyTypeName: "",
  773. companyType: ""
  774. });
  775. const kDialogRef = ref(null);
  776. const busiPopShow = ref(false);
  777. const busiPopList = reactive([
  778. {
  779. name: "商户1",
  780. id: "1",
  781. },
  782. {
  783. name: "商户2",
  784. id: "2",
  785. },
  786. ]);
  787. const busiPopFieldName = reactive({
  788. text: "name",
  789. value: "id",
  790. });
  791. // 点击筛选
  792. const noticeClk = () => {
  793. kDialogRef.value.openDialog();
  794. };
  795. // 点击右侧按钮
  796. const confirmClk = () => {
  797. if (searchForm.changeType === "") {
  798. changeType.value = 1;
  799. } else {
  800. changeType.value = searchForm.changeType;
  801. }
  802. companyType.value = searchForm.companyType;
  803. machineType.value = searchForm.machineType;
  804. init();
  805. };
  806. // 筛选弹窗
  807. // 点击商家输入框
  808. const busiInpClk = () => {
  809. // console.log(111111111);
  810. busiPopShow.value = true;
  811. };
  812. const busiPopConfirm = (e) => {
  813. // console.log("e的值是", e);
  814. busiPopShow.value = false;
  815. searchForm.businessName = e.name;
  816. };
  817. const busiPopCancel = () => {
  818. busiPopShow.value = false;
  819. };
  820. return {
  821. dayChartBox,
  822. weekChartBox,
  823. monthChartBox,
  824. yearChartBox,
  825. tabclk,
  826. tabDayList,
  827. tabWeekList,
  828. tabMonthList,
  829. tabYearList,
  830. noticeClk,
  831. kDialogRef,
  832. busiInpClk,
  833. busiPopShow,
  834. busiPopConfirm,
  835. busiPopList,
  836. busiPopFieldName,
  837. busiPopCancel,
  838. confirmClk,
  839. searchForm,
  840. dayShow,
  841. minDate,
  842. calendarDayConfirm,
  843. weekShow,
  844. monthShow,
  845. calendarWeekOrMonConfirm,
  846. yearFormatter,
  847. currentDate,
  848. yearShow,
  849. yearPopList,
  850. yearPopConfirm,
  851. yearPopFieldName,
  852. changeTypeShow,
  853. changeTypePopList,
  854. changeTypePopConfirm,
  855. changeTypeInpClk,
  856. companyTypeInpClk,
  857. companyTypePopConfirm,
  858. companyTypePopList,
  859. companyTypeShow,
  860. machineTypeInpClk,
  861. machineTypePopConfirm,
  862. machineTypePopList,
  863. machineTypeShow,
  864. totalNoData,
  865. maTypeDefaIdx,
  866. chgTypeDefaIdx,
  867. isAdmin,
  868. };
  869. },
  870. components: { sHeader, kTabs, kDialog, kNoData },
  871. };
  872. </script>
  873. <style lang="less" scoped>
  874. @import "../styles/robotRanking/index";
  875. </style>