index.vue 49 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588
  1. <template>
  2. <div class="body1" v-loading="isLoading">
  3. <!-- 课程数据 -->
  4. <div class="left">
  5. <div class="top">
  6. <div class="titleBox" style="justify-content: space-between">
  7. <div class="title">基础概况</div>
  8. <!-- <el-select v-model="cType7" class="selectBox" style="width: 110px">
  9. <el-option label="全部课程" value="全部课程"></el-option>
  10. </el-select> -->
  11. </div>
  12. <div class="dataBox">
  13. <div class="info_box">
  14. <div class="info blueBG">
  15. <span>课程总数</span>
  16. <!-- <span>{{ count }}</span> -->
  17. <span>{{ allCourse }}</span>
  18. </div>
  19. <div class="info blueBG">
  20. <span>本月新增课程环比</span>
  21. <!-- <span>{{ weekCount }}</span> -->
  22. <span v-if="loginCountMonthArray.length">{{
  23. loginCountMonthArray[loginCountMonthArray.length - 1].course -
  24. loginCountMonthArray[loginCountMonthArray.length - 2].course <
  25. 0
  26. ? 0
  27. : (
  28. ((loginCountMonthArray[loginCountMonthArray.length - 1]
  29. .course -
  30. loginCountMonthArray[loginCountMonthArray.length - 2]
  31. .course) /
  32. (allCourse -
  33. loginCountMonthArray[loginCountMonthArray.length - 1]
  34. .course)) *
  35. 100
  36. ).toFixed(2) + "%"
  37. }}</span>
  38. </div>
  39. <div class="info blueBG">
  40. <span>模板课程总数</span>
  41. <!-- <span>{{ weekCount }}</span> -->
  42. <span>{{ courseTemplate }}</span>
  43. </div>
  44. <div class="info blueBG">
  45. <span>本月新增课程总数</span>
  46. <!-- <span>{{ weekCount }}</span> -->
  47. <span v-if="loginCountMonthArray.length">{{
  48. loginCountMonthArray[loginCountMonthArray.length - 1].course
  49. }}</span>
  50. </div>
  51. </div>
  52. <TeaFre
  53. style="height: calc(100% - 140px)"
  54. :monthArray="loginCountMonthArray"
  55. ></TeaFre>
  56. </div>
  57. </div>
  58. <div class="bottom">
  59. <div class="titleBox">
  60. <div
  61. class="title"
  62. :class="{ isClick: skType == 0 }"
  63. @click="skType = 0"
  64. style="cursor: pointer; padding: 0 0 5px 0"
  65. >
  66. 授课时长
  67. </div>
  68. <div
  69. class="title"
  70. :class="{ isClick: skType == 1 }"
  71. @click="skType = 1"
  72. style="cursor: pointer; padding: 0 0 5px 0"
  73. >
  74. 作业数量
  75. </div>
  76. <el-select
  77. v-if="skType == 0"
  78. v-model="lType"
  79. @change="typeChange1"
  80. class="selectBox"
  81. style="margin-left: auto"
  82. >
  83. <el-option label="全部" value="all"></el-option>
  84. <el-option label="年级" value="grade"></el-option>
  85. <el-option label="主题" value="theme"></el-option>
  86. <el-option label="学科" value="subject"></el-option>
  87. </el-select>
  88. <el-select
  89. v-if="skType == 1"
  90. v-model="lType1"
  91. @change="typeChange2"
  92. class="selectBox"
  93. style="margin-left: auto"
  94. >
  95. <el-option label="全部" value="all"></el-option>
  96. <el-option label="年级" value="grade"></el-option>
  97. <el-option label="主题" value="theme"></el-option>
  98. <el-option label="学科" value="subject"></el-option>
  99. </el-select>
  100. <!-- <el-select v-model="cType" class="selectBox" style="width: 110px">
  101. <el-option label="全部年级" value="全部年级"></el-option>
  102. <el-option label="一年级" value="一年级"></el-option>
  103. <el-option label="二年级" value="二年级"></el-option>
  104. <el-option label="三年级" value="三年级"></el-option>
  105. </el-select>
  106. <div class="timeDiv">
  107. <div @click="tType = 0" :class="{ isClick: tType == 0 }">周</div>
  108. <div @click="tType = 1" :class="{ isClick: tType == 1 }">月</div>
  109. <div @click="tType = 2" :class="{ isClick: tType == 2 }">学期</div>
  110. </div> -->
  111. </div>
  112. <div class="dataBox">
  113. <div class="info_box" style="width: 96%" v-if="skType == 0">
  114. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  115. <span>累计时长</span>
  116. <!-- <span>{{ count }}</span> -->
  117. <span>{{ allTime }}</span>
  118. </div>
  119. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  120. <span>课程实施总数</span>
  121. <!-- <span>{{ weekCount }}</span> -->
  122. <span>{{ courseLength }}</span>
  123. </div>
  124. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  125. <span>课程平均时长</span>
  126. <!-- <span>{{ weekCount }}</span> -->
  127. <span>{{
  128. allTime == 0 ? 0 : (allTime / courseLength).toFixed(0)
  129. }}</span>
  130. </div>
  131. </div>
  132. <div class="info_box" style="width: 96%" v-if="skType == 1">
  133. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  134. <span>作业数量</span>
  135. <!-- <span>{{ count }}</span> -->
  136. <span>{{ worksCount }}</span>
  137. </div>
  138. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  139. <span>课程开展总数</span>
  140. <!-- <span>{{ weekCount }}</span> -->
  141. <span>{{ haveWorksCourse }}</span>
  142. </div>
  143. <div class="info blueBG" style="width: calc(100% / 3 - 10px)">
  144. <span>课程平均作业数量</span>
  145. <!-- <span>{{ weekCount }}</span> -->
  146. <span>{{
  147. worksCount == 0 ? 0 : (worksCount / haveWorksCourse).toFixed(0)
  148. }}</span>
  149. </div>
  150. </div>
  151. <Bar
  152. style="height: calc(100% - 70px)"
  153. v-if="skType == 0"
  154. :workList="tedurArray"
  155. ></Bar>
  156. <ToolUse
  157. style="height: calc(100% - 70px)"
  158. v-if="skType == 1"
  159. :yearArray="courseWorksCountYearArray"
  160. ></ToolUse>
  161. <!-- <div class="otherCss">
  162. <div v-if="!oType">切换为柱状图</div>
  163. <div v-if="oType">切换为热力图</div>
  164. <div class="otherImg" @click="otherEchart">
  165. <img src="../../../../assets/icon/other.png" alt="" />
  166. </div>
  167. </div> -->
  168. </div>
  169. </div>
  170. </div>
  171. <div class="center">
  172. <div class="top">
  173. <div class="titleBox">
  174. <div
  175. class="title"
  176. :class="{ isClick: courseType == 0 }"
  177. @click="courseType = 0"
  178. style="cursor: pointer; padding: 0 0 5px 0"
  179. >
  180. 课程分布
  181. </div>
  182. <div
  183. class="title"
  184. :class="{ isClick: courseType == 1 }"
  185. @click="courseType = 1"
  186. style="cursor: pointer; padding: 0 0 5px 0"
  187. >
  188. 课程总数变化
  189. </div>
  190. </div>
  191. <div class="dataBox">
  192. <CateRank
  193. v-if="courseType == 0"
  194. style="height: calc(100%)"
  195. :courseArray="courseArray"
  196. ></CateRank>
  197. <CourseNum
  198. v-if="courseType == 1"
  199. style="height: calc(100%)"
  200. :weekCourse2="weekCourse2"
  201. ></CourseNum>
  202. </div>
  203. </div>
  204. <div class="bottom">
  205. <div class="titleBox" style="justify-content: space-between">
  206. <div class="title">课程实施程度</div>
  207. </div>
  208. <div class="dataBox">
  209. <div class="allBox" v-if="!shType" style="height: calc(100% - 30px)">
  210. <div class="allBox_left">
  211. <CourseTime v-if="!shType" :pusaDep="pusaDep"></CourseTime>
  212. </div>
  213. <div class="allBox_right">
  214. <div class="depth">
  215. <span>设置评价</span>
  216. <div>
  217. <el-progress
  218. :width="80"
  219. type="circle"
  220. :percentage="
  221. allCourse
  222. ? parseInt(((evaCount / allCourse) * 100).toFixed(0))
  223. : 0
  224. "
  225. :stroke-width="5"
  226. :format="format"
  227. color="#106BFF"
  228. ></el-progress>
  229. </div>
  230. </div>
  231. <div class="depth">
  232. <span>已提交作业</span>
  233. <div>
  234. <el-progress
  235. :width="80"
  236. type="circle"
  237. :percentage="
  238. allCourse
  239. ? parseInt(
  240. ((haveWorksCourse / allCourse) * 100).toFixed(0)
  241. )
  242. : 0
  243. "
  244. :stroke-width="5"
  245. :format="format"
  246. color="#106BFF"
  247. ></el-progress>
  248. </div>
  249. </div>
  250. <div class="depth">
  251. <span>已评价课程</span>
  252. <div>
  253. <el-progress
  254. :width="80"
  255. type="circle"
  256. :percentage="
  257. allCourse
  258. ? parseInt(
  259. ((evaWorksCount / allCourse) * 100).toFixed(0)
  260. )
  261. : 0
  262. "
  263. :stroke-width="5"
  264. :format="format"
  265. color="#106BFF"
  266. ></el-progress>
  267. </div>
  268. </div>
  269. <div class="depth">
  270. <span>教学评一体化</span>
  271. <div>
  272. <el-progress
  273. :width="80"
  274. type="circle"
  275. :percentage="
  276. allCourse
  277. ? parseInt(
  278. ((evaWorksCount / allCourse) * 100).toFixed(0)
  279. )
  280. : 0
  281. "
  282. :stroke-width="5"
  283. :format="format"
  284. color="#106BFF"
  285. ></el-progress>
  286. </div>
  287. </div>
  288. </div>
  289. </div>
  290. <div class="info_box" v-if="shType">
  291. <div class="info blueBG" style="width: calc(100% / 4 - 10px)">
  292. <span>平台实施课程总数</span>
  293. <!-- <span>{{ count }}</span> -->
  294. <span>{{ isCourseCount }}</span>
  295. </div>
  296. <div class="info blueBG" style="width: calc(100% / 4 - 10px)">
  297. <span>平台实施课程占比</span>
  298. <!-- <span>{{ weekCount }}</span> -->
  299. <span>{{
  300. isCourseCount
  301. ? ((isCourseCount / allCourseCount) * 100).toFixed(0) + "%"
  302. : "0%"
  303. }}</span>
  304. </div>
  305. <div class="info blueBG" style="width: calc(100% / 4 - 10px)">
  306. <span>课程平均任务数量</span>
  307. <!-- <span>{{ weekCount }}</span> -->
  308. <span>{{
  309. isCourseCount ? (taskCount / isCourseCount).toFixed(0) : 0
  310. }}</span>
  311. </div>
  312. <div class="info blueBG" style="width: calc(100% / 4 - 10px)">
  313. <span>课程平均作业数量</span>
  314. <!-- <span>{{ weekCount }}</span> -->
  315. <span>{{
  316. isCourseCount ? (workCount / isCourseCount).toFixed(0) : 0
  317. }}</span>
  318. </div>
  319. </div>
  320. <WorkNum
  321. style="height: calc(100% - 95px)"
  322. :workNumList="workNumList"
  323. v-if="shType"
  324. ></WorkNum>
  325. <div class="otherCss">
  326. <div v-if="!shType">转换为散点图</div>
  327. <div v-if="shType">转换为漏斗图</div>
  328. <div class="otherImg" @click="shEchart">
  329. <img src="../../../../assets/icon/other.png" alt="" />
  330. </div>
  331. </div>
  332. </div>
  333. </div>
  334. </div>
  335. <div class="right">
  336. <div class="top" style="border-radius: 5px">
  337. <div class="titleBox" style="justify-content: space-between">
  338. <div
  339. style="
  340. display: flex;
  341. flex-direction: row;
  342. flex-wrap: nowrap;
  343. align-items: center;
  344. "
  345. >
  346. <div
  347. class="title"
  348. :class="{ isClick: toolType == 0 }"
  349. @click="toolType = 0"
  350. style="cursor: pointer; padding: 0 0 5px 0"
  351. >
  352. 课程占比
  353. </div>
  354. <div
  355. class="title"
  356. :class="{ isClick: toolType == 1 }"
  357. @click="toolType = 1"
  358. style="cursor: pointer; padding: 0 0 5px 0"
  359. >
  360. 工具使用
  361. </div>
  362. </div>
  363. <el-select
  364. v-model="cType4"
  365. @change="typeChange"
  366. class="selectBox"
  367. v-if="toolType == 0"
  368. >
  369. <el-option label="全部" value=""></el-option>
  370. <el-option label="年级" value="grade"></el-option>
  371. <el-option label="主题" value="theme"></el-option>
  372. <el-option label="学科" value="subject"></el-option>
  373. </el-select>
  374. </div>
  375. <div class="dataBox">
  376. <CourseAna
  377. style="height: calc(100%)"
  378. :courseNumberArray="courseNumberArray"
  379. v-if="toolType == 0"
  380. ></CourseAna>
  381. <ToolChart
  382. style="height: calc(100%)"
  383. :toolArray="toolList"
  384. v-if="toolType == 1"
  385. ></ToolChart>
  386. </div>
  387. </div>
  388. <div class="bottom">
  389. <div class="titleBox">
  390. <div class="title">课程协同情况</div>
  391. </div>
  392. <div class="dataBox">
  393. <WorkTime
  394. style="height: calc(100% - 25px)"
  395. :personArray="personList"
  396. v-if="xtType"
  397. ></WorkTime>
  398. <Subjuect style="height: calc(100% - 25px)" v-if="!xtType"></Subjuect>
  399. <div class="otherCss">
  400. <div v-if="!xtType">转换为人员协同</div>
  401. <div v-if="xtType">转换为学科协同</div>
  402. <div class="otherImg" @click="xtEchart">
  403. <img src="../../../../assets/icon/other.png" alt="" />
  404. </div>
  405. </div>
  406. </div>
  407. </div>
  408. </div>
  409. </div>
  410. </template>
  411. <script>
  412. import TeaFre from "./chartList/teaFre.vue";
  413. import ToolUse from "./chartList/toolUse.vue";
  414. import CateRank from "./chartList/cateRank.vue";
  415. import WorkNum from "./chartList/workNum.vue";
  416. import CourseTime from "./chartList/courseTime.vue";
  417. import CourseAna from "./chartList/courseAna.vue";
  418. import WorkTime from "./chartList/workTime.vue";
  419. import Bar from "./chartList/bar.vue";
  420. import CourseNum from "./chartList/courseNum.vue";
  421. import ToolChart from "./chartList/toolChart.vue";
  422. import Subjuect from "./chartList/subjuect.vue";
  423. export default {
  424. components: {
  425. TeaFre,
  426. ToolUse,
  427. CateRank,
  428. WorkNum,
  429. CourseTime,
  430. CourseAna,
  431. WorkTime,
  432. Bar,
  433. CourseNum,
  434. ToolChart,
  435. Subjuect,
  436. },
  437. props: {
  438. oid: {
  439. type: String,
  440. },
  441. org: {
  442. type: String,
  443. },
  444. },
  445. data() {
  446. return {
  447. isLoading: false,
  448. cType: "全部年级",
  449. cType4: "",
  450. cType7: "全部课程",
  451. toolType: 0,
  452. tType: 0,
  453. skType: 0,
  454. courseType: 0,
  455. sType: 0,
  456. oType: false,
  457. shType: false,
  458. xtType: false,
  459. allCourse: 0,
  460. courseTemplate: 0,
  461. loginCountMonthArray: [],
  462. lType: "all",
  463. lType1: "all",
  464. tedurArray: [],
  465. classList: [],
  466. subjectList: [],
  467. themeList: [],
  468. allTime: 0,
  469. gradeLength: 0,
  470. subjectLength: 0,
  471. themeLength: 0,
  472. courseTList: [],
  473. courseLength: 0,
  474. courseWorksCountYearArray: [],
  475. allCourseWorks: [],
  476. gradeList: [],
  477. subjectList: [],
  478. thList: [],
  479. worksCount: 0,
  480. haveWorksCourse: 0,
  481. courseNumberArray: [],
  482. gradeArray: [],
  483. subjectArray: [],
  484. themeArray: [],
  485. allArray: [],
  486. toolList: [],
  487. personList: [],
  488. workNumList: [],
  489. taskCount: 0,
  490. workCount: 0,
  491. isCourseCount: 0,
  492. allCourseCount: 0,
  493. courseArray: [],
  494. evaCount: 0,
  495. evaWorksCount: 0,
  496. pusaDep: [
  497. { value: 0, name: "课程总数" },
  498. { value: 0, name: "设置评价课程" },
  499. { value: 0, name: "已提交作业课程" },
  500. { value: 0, name: "已评价课程" },
  501. { value: 0, name: "教学评一体化课程" },
  502. ],
  503. weekCourse2: [],
  504. };
  505. },
  506. mounted() {
  507. this.getData();
  508. },
  509. methods: {
  510. otherEchart() {
  511. this.oType = !this.oType;
  512. },
  513. shEchart() {
  514. this.shType = !this.shType;
  515. },
  516. xtEchart() {
  517. this.xtType = !this.xtType;
  518. },
  519. format(percentage) {
  520. return percentage + "%";
  521. },
  522. typeChange1() {
  523. var a = [];
  524. if (this.lType == "all") {
  525. a = this.classList.concat(this.subjectList, this.themeList);
  526. this.courseLength =
  527. this.gradeLength + this.subjectLength + this.themeLength;
  528. } else if (this.lType == "grade") {
  529. a = this.classList;
  530. this.courseLength = this.gradeLength;
  531. } else if (this.lType == "subject") {
  532. a = this.subjectList;
  533. this.courseLength = this.subjectLength;
  534. } else {
  535. a = this.themeList;
  536. this.courseLength = this.themeLength;
  537. }
  538. this.tedurArray = a;
  539. var time = 0;
  540. for (var i = 0; i < a.length; i++) {
  541. if (a[i].time) {
  542. time += a[i].time;
  543. }
  544. }
  545. this.allTime = time;
  546. this.$forceUpdate();
  547. },
  548. typeChange2() {
  549. const date = new Date();
  550. var Month = date.getMonth() + 1;
  551. var Year = date.getFullYear();
  552. let courseWorksCountYearArray = [];
  553. for (var i = Month; i > Month - 12; i--) {
  554. if (i <= 0) {
  555. courseWorksCountYearArray.push({
  556. Year: Year - 1,
  557. Month: 12 + i,
  558. mon: 0,
  559. tue: 0,
  560. wed: 0,
  561. thur: 0,
  562. fri: 0,
  563. sat: 0,
  564. sun: 0,
  565. });
  566. } else {
  567. courseWorksCountYearArray.push({
  568. Month: i,
  569. Year: Year,
  570. mon: 0,
  571. tue: 0,
  572. wed: 0,
  573. thur: 0,
  574. fri: 0,
  575. sat: 0,
  576. sun: 0,
  577. });
  578. }
  579. }
  580. courseWorksCountYearArray = courseWorksCountYearArray.reverse();
  581. for (var i = 0; i < this.allCourseWorks.length; i++) {
  582. let _date = new Date(this.allCourseWorks[i].create_at);
  583. let _type = this.allCourseWorks[i].typeid;
  584. var _month = _date.getMonth() + 1;
  585. var _year = _date.getFullYear();
  586. var _day = _date.getDay();
  587. let dayArray = ["sun", "mon", "tue", "wed", "thur", "fri", "sat"];
  588. for (var j = 0; j < courseWorksCountYearArray.length; j++) {
  589. if (this.lType1 == "all") {
  590. if (
  591. _month == courseWorksCountYearArray[j].Month &&
  592. _year == courseWorksCountYearArray[j].Year
  593. ) {
  594. courseWorksCountYearArray[j][dayArray[_day]]++;
  595. break;
  596. }
  597. } else if (this.lType1 == "grade") {
  598. if (
  599. _month == courseWorksCountYearArray[j].Month &&
  600. _year == courseWorksCountYearArray[j].Year &&
  601. this.gradeList.indexOf(_type) != -1
  602. ) {
  603. courseWorksCountYearArray[j][dayArray[_day]]++;
  604. break;
  605. }
  606. } else if (this.lType1 == "subject") {
  607. if (
  608. _month == courseWorksCountYearArray[j].Month &&
  609. _year == courseWorksCountYearArray[j].Year &&
  610. this.subjectList.indexOf(_type) != -1
  611. ) {
  612. courseWorksCountYearArray[j][dayArray[_day]]++;
  613. break;
  614. }
  615. } else {
  616. if (
  617. _month == courseWorksCountYearArray[j].Month &&
  618. _year == courseWorksCountYearArray[j].Year &&
  619. this.thList.indexOf(_type) != -1
  620. ) {
  621. courseWorksCountYearArray[j][dayArray[_day]]++;
  622. break;
  623. }
  624. }
  625. }
  626. }
  627. var worksCount = 0,
  628. haveWorksCourse = [];
  629. for (var i = 0; i < this.allCourseWorks.length; i++) {
  630. if (this.lType1 == "all") {
  631. if (this.allCourseWorks[i].id) {
  632. worksCount++;
  633. }
  634. if (haveWorksCourse.length == 0) {
  635. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  636. } else {
  637. if (
  638. haveWorksCourse.indexOf(this.allCourseWorks[i].courseid) == -1
  639. ) {
  640. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  641. }
  642. }
  643. } else if (this.lType1 == "grade") {
  644. if (this.gradeList.indexOf(this.allCourseWorks[i].typeid)) {
  645. if (this.allCourseWorks[i].id) {
  646. worksCount++;
  647. }
  648. if (haveWorksCourse.length == 0) {
  649. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  650. } else {
  651. if (
  652. haveWorksCourse.indexOf(this.allCourseWorks[i].courseid) == -1
  653. ) {
  654. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  655. }
  656. }
  657. }
  658. } else if (this.lType1 == "subject") {
  659. if (this.subjectList.indexOf(this.allCourseWorks[i].typeid)) {
  660. if (this.allCourseWorks[i].id) {
  661. worksCount++;
  662. }
  663. if (haveWorksCourse.length == 0) {
  664. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  665. } else {
  666. if (
  667. haveWorksCourse.indexOf(this.allCourseWorks[i].courseid) == -1
  668. ) {
  669. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  670. }
  671. }
  672. }
  673. } else {
  674. if (this.thList.indexOf(this.allCourseWorks[i].typeid)) {
  675. if (this.allCourseWorks[i].id) {
  676. worksCount++;
  677. }
  678. if (haveWorksCourse.length == 0) {
  679. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  680. } else {
  681. if (
  682. haveWorksCourse.indexOf(this.allCourseWorks[i].courseid) == -1
  683. ) {
  684. haveWorksCourse.push(this.allCourseWorks[i].courseid);
  685. }
  686. }
  687. }
  688. }
  689. }
  690. this.courseWorksCountYearArray = courseWorksCountYearArray;
  691. this.worksCount = worksCount;
  692. this.haveWorksCourse = haveWorksCourse.length;
  693. this.$forceUpdate();
  694. },
  695. typeChange() {
  696. if (this.cType4 === "") {
  697. this.courseNumberArray = this.allArray;
  698. } else if (this.cType4 === "grade") {
  699. this.courseNumberArray = this.gradeArray;
  700. } else if (this.cType4 === "theme") {
  701. this.courseNumberArray = this.themeArray;
  702. } else if (this.cType4 === "subject") {
  703. this.courseNumberArray = this.subjectArray;
  704. }
  705. this.$forceUpdate();
  706. },
  707. getData() {
  708. this.isLoading = true;
  709. let params = [
  710. {
  711. oid: this.oid,
  712. org: this.org,
  713. },
  714. ];
  715. this.ajax
  716. .post(this.$store.state.api + "selectDataBoardCourseNew", params)
  717. .then((res) => {
  718. this.isLoading = false;
  719. let _grade = res.data[0]; //年级
  720. let _subject = res.data[1]; //学科
  721. let _themeList = res.data[2]; //主题
  722. this.allCourse = res.data[3][0].count; //课程总数
  723. let _timeCourse = res.data[4]; //查询半年内全部课程
  724. this.courseTemplate = res.data[5][0].count; //查询模板课程总数
  725. let tList = res.data[6]; //授课时长
  726. // let countCourseWorks = res.data[8][0].count; //获取有作业的课程
  727. this.courseTList = tList;
  728. //将数据根据time里面的月份分成多个数组
  729. let loginCountMonthArray = [];
  730. const date = new Date();
  731. var Month = date.getMonth() + 1;
  732. var Year = date.getFullYear();
  733. for (var i = Month; i > Month - 6; i--) {
  734. if (i <= 0) {
  735. loginCountMonthArray.push({
  736. Year: Year - 1,
  737. Month: 12 + i,
  738. course: 0,
  739. });
  740. } else {
  741. loginCountMonthArray.push({
  742. Month: i,
  743. Year: Year,
  744. course: 0,
  745. });
  746. }
  747. }
  748. loginCountMonthArray = loginCountMonthArray.reverse();
  749. for (var i = 0; i < _timeCourse.length; i++) {
  750. let _date = new Date(_timeCourse[i].time);
  751. var _month = _date.getMonth() + 1;
  752. var _year = _date.getFullYear();
  753. for (var j = 0; j < loginCountMonthArray.length; j++) {
  754. if (
  755. _month == loginCountMonthArray[j].Month &&
  756. _year == loginCountMonthArray[j].Year
  757. ) {
  758. loginCountMonthArray[j].course++;
  759. break;
  760. }
  761. }
  762. }
  763. this.loginCountMonthArray = loginCountMonthArray;
  764. var courseJson = Object.values(
  765. tList.reduce(function (acc, obj) {
  766. if (!acc[obj.courseid]) {
  767. acc[obj.courseid] = { ...obj };
  768. acc[obj.courseid].typeid = [acc[obj.courseid].typeid];
  769. } else {
  770. if (!acc[obj.courseid].typeid.includes(obj.typeid)) {
  771. acc[obj.courseid].typeid.push(obj.typeid);
  772. }
  773. acc[obj.courseid].text =
  774. parseInt(acc[obj.courseid].text) + parseInt(obj.text);
  775. }
  776. return acc;
  777. }, {})
  778. ).map(function (obj) {
  779. var totalTime = parseInt(obj.text);
  780. obj.text = (totalTime / (60 * 60)).toFixed(2);
  781. return obj;
  782. });
  783. for (var i = 0; i < courseJson.length; i++) {
  784. for (var j = 0; j < _grade.length; j++) {
  785. if (courseJson[i].typeid.indexOf(_grade[j].id) != -1) {
  786. if (_grade[j].time && courseJson[i].text) {
  787. _grade[j].time += parseInt(courseJson[i].text);
  788. } else if (courseJson[i].text) {
  789. _grade[j].time = parseInt(courseJson[i].text);
  790. }
  791. }
  792. }
  793. for (var k = 0; k < _subject.length; k++) {
  794. if (courseJson[i].typeid.indexOf(_subject[k].id) != -1) {
  795. if (_subject[k].time && courseJson[i].text) {
  796. _subject[k].time += parseInt(courseJson[i].text);
  797. } else if (courseJson[i].text) {
  798. _subject[k].time = parseInt(courseJson[i].text);
  799. }
  800. }
  801. }
  802. for (var l = 0; l < _themeList.length; l++) {
  803. if (courseJson[i].typeid.indexOf(_themeList[l].id) != -1) {
  804. if (_themeList[l].time && courseJson[i].text) {
  805. _themeList[l].time += parseInt(courseJson[i].text);
  806. } else if (courseJson[i].text) {
  807. _themeList[l].time = parseInt(courseJson[i].text);
  808. }
  809. }
  810. }
  811. }
  812. this.classList = _grade;
  813. this.subjectList = _subject;
  814. this.themeList = _themeList;
  815. var _gradeList = [],
  816. _subjectList = [],
  817. _thList = [];
  818. for (var i = 0; i < _grade.length; i++) {
  819. _gradeList.push(_grade[i].id);
  820. }
  821. for (var i = 0; i < _subject.length; i++) {
  822. _subjectList.push(_subject[i].id);
  823. }
  824. for (var i = 0; i < _themeList.length; i++) {
  825. _thList.push(_themeList[i].id);
  826. }
  827. var _courseTypeList = this.courseTList;
  828. var _gList = [],
  829. _sList = [],
  830. _tList = [];
  831. for (var i = 0; i < _courseTypeList.length; i++) {
  832. if (_gradeList.indexOf(_courseTypeList[i].typeid) != -1) {
  833. if (_gList.length == 0) {
  834. _gList.push(_courseTypeList[i].courseid);
  835. } else {
  836. if (_gList.indexOf(_courseTypeList[i].courseid) == -1) {
  837. _gList.push(_courseTypeList[i].courseid);
  838. }
  839. }
  840. }
  841. if (_subjectList.indexOf(_courseTypeList[i].typeid) != -1) {
  842. if (_sList.length == 0) {
  843. _sList.push(_courseTypeList[i].courseid);
  844. } else {
  845. if (_sList.indexOf(_courseTypeList[i].courseid) == -1) {
  846. _sList.push(_courseTypeList[i].courseid);
  847. }
  848. }
  849. }
  850. if (_thList.indexOf(_courseTypeList[i].typeid) != -1) {
  851. if (_tList.length == 0) {
  852. _tList.push(_courseTypeList[i].courseid);
  853. } else {
  854. if (_tList.indexOf(_courseTypeList[i].courseid) == -1) {
  855. _tList.push(_courseTypeList[i].courseid);
  856. }
  857. }
  858. }
  859. }
  860. this.gradeLength = _gList.length;
  861. this.subjectLength = _sList.length;
  862. this.themeLength = _tList.length;
  863. var a = [];
  864. if (this.lType == "all") {
  865. this.tedurArray = _grade.concat(_subject, _themeList);
  866. this.courseLength = _gList.length + _sList.length + _tList.length;
  867. } else if (this.lType == "grade") {
  868. this.tedurArray = _grade;
  869. this.courseLength = _gList.length;
  870. } else if (this.lType == "subject") {
  871. this.tedurArray = _subject;
  872. this.courseLength = _sList.length;
  873. } else {
  874. this.tedurArray = _themeList;
  875. this.courseLength = _tList.length;
  876. }
  877. var time = 0;
  878. a = this.tedurArray;
  879. for (var i = 0; i < a.length; i++) {
  880. if (a[i].time) {
  881. time += a[i].time;
  882. }
  883. }
  884. this.allTime = time;
  885. let allCourseWorks = res.data[7]; //作业总数量
  886. this.allCourseWorks = allCourseWorks;
  887. this.gradeList = _gradeList;
  888. this.subjectList = _subjectList;
  889. this.thList = _thList;
  890. this.typeChange2();
  891. let _course = res.data[8]; //课程
  892. let _gradeArray = [];
  893. let _subjectArray = [];
  894. let _themeArray = [];
  895. for (var i = 0; i < _grade.length; i++) {
  896. _gradeArray.push({
  897. name: _grade[i].name,
  898. typeid: _grade[i].id,
  899. course: 0,
  900. array: [],
  901. });
  902. for (var z = 0; z < _course.length; z++) {
  903. if (_course[z].typeid == _grade[i].id) {
  904. _gradeArray[i].course++;
  905. _gradeArray[i].array.push(_course[z].courseid);
  906. }
  907. }
  908. }
  909. for (var i = 0; i < _subject.length; i++) {
  910. _subjectArray.push({
  911. name: _subject[i].name,
  912. typeid: _subject[i].id,
  913. course: 0,
  914. array: [],
  915. });
  916. for (var z = 0; z < _course.length; z++) {
  917. if (_course[z].typeid == _subject[i].id) {
  918. _subjectArray[i].course++;
  919. _subjectArray[i].array.push(_course[z].courseid);
  920. }
  921. }
  922. }
  923. for (var i = 0; i < _themeList.length; i++) {
  924. _themeArray.push({
  925. name: _themeList[i].name,
  926. typeid: _themeList[i].id,
  927. course: 0,
  928. array: [],
  929. });
  930. for (var z = 0; z < _course.length; z++) {
  931. if (_course[z].typeid == _themeList[i].id) {
  932. _themeArray[i].course++;
  933. _themeArray[i].array.push(_course[z].courseid);
  934. }
  935. }
  936. }
  937. this.gradeArray = _gradeArray;
  938. this.subjectArray = _subjectArray;
  939. this.themeArray = _themeArray;
  940. this.allArray = [..._gradeArray, ..._subjectArray, ..._themeArray];
  941. this.typeChange();
  942. var courseList = res.data[9];
  943. var cList = [];
  944. for (var i = 0; i < courseList.length; i++) {
  945. cList.push(JSON.parse(courseList[i].chapters));
  946. }
  947. var toolList = [
  948. [10, 65], //互动类
  949. [7, 1, 52, 3, 48], //思维类
  950. [49], //协作类
  951. [4, 45, 15, 16, 50, 41, 47], //测评类
  952. [40], //评价类
  953. [18, 21, 22, 23, 24, 32, 57, 63], //编程类
  954. [28, 31, 39, 66, 67, 68], //学科类
  955. ];
  956. var toolAllArray = [
  957. { name: "互动类", value: 0 },
  958. { name: "思维类", value: 0 },
  959. { name: "协作类", value: 0 },
  960. { name: "测评类", value: 0 },
  961. { name: "评价类", value: 0 },
  962. { name: "编程类", value: 0 },
  963. { name: "学科类", value: 0 },
  964. ];
  965. for (var p = 0; p < toolList.length; p++) {
  966. for (var i = 0; i < cList.length; i++) {
  967. for (var j = 0; j < cList[i].length; j++) {
  968. for (
  969. var k = 0;
  970. k < cList[i][j].chapterInfo[0].taskJson.length;
  971. k++
  972. ) {
  973. for (
  974. var q = 0;
  975. q <
  976. cList[i][j].chapterInfo[0].taskJson[k].toolChoose.length;
  977. q++
  978. ) {
  979. if (
  980. toolList[p].indexOf(
  981. cList[i][j].chapterInfo[0].taskJson[k].toolChoose[q]
  982. .tool[0]
  983. ) != -1
  984. ) {
  985. toolAllArray[p].value++;
  986. }
  987. }
  988. }
  989. }
  990. }
  991. }
  992. this.toolList = toolAllArray;
  993. var twoPerson = 0,
  994. threePerson = 0,
  995. fivePerson = 0,
  996. sevenPerson = 0;
  997. var personList = [];
  998. for (var i = 0; i < courseList.length; i++) {
  999. if (courseList[i].course_teacher) {
  1000. if (courseList[i].course_teacher.split(",").length <= 2) {
  1001. twoPerson++;
  1002. } else if (
  1003. 4 >= courseList[i].course_teacher.split(",").length &&
  1004. courseList[i].course_teacher.split(",").length > 2
  1005. ) {
  1006. threePerson++;
  1007. } else if (
  1008. 6 >= courseList[i].course_teacher.split(",").length &&
  1009. courseList[i].course_teacher.split(",").length > 4
  1010. ) {
  1011. fivePerson++;
  1012. } else if (courseList[i].course_teacher.split(",").length > 7) {
  1013. sevenPerson++;
  1014. }
  1015. }
  1016. }
  1017. personList.push(
  1018. { name: "2人以下", value: twoPerson },
  1019. { name: "3-4人", value: threePerson },
  1020. { name: "5-6人", value: fivePerson },
  1021. { name: "7人以上", value: sevenPerson }
  1022. );
  1023. this.personList = personList;
  1024. let _workCourse = res.data[10]; //带作业的课程
  1025. let _taskCount = 0; //任务数量
  1026. var wList = [];
  1027. for (var i = 0; i < _workCourse.length; i++) {
  1028. if (!wList[_workCourse[i].courseId]) {
  1029. wList[_workCourse[i].courseId] = {
  1030. cid: _workCourse[i].courseId,
  1031. title: _workCourse[i].title,
  1032. task: 0,
  1033. work: 0,
  1034. };
  1035. let chapters = JSON.parse(_workCourse[i].chapters);
  1036. for (var j = 0; j < chapters.length; j++) {
  1037. if (wList[_workCourse[i].courseId].task == 0) {
  1038. wList[_workCourse[i].courseId].task =
  1039. chapters[j].chapterInfo[0].taskJson.length;
  1040. } else {
  1041. wList[_workCourse[i].courseId].task +=
  1042. chapters[j].chapterInfo[0].taskJson.length;
  1043. }
  1044. _taskCount += chapters[j].chapterInfo[0].taskJson.length;
  1045. }
  1046. }
  1047. }
  1048. for (var i = 0; i < _workCourse.length; i++) {
  1049. let a = Object.keys(wList);
  1050. for (var j = 0; j < Object.keys(wList).length; j++) {
  1051. if (
  1052. _workCourse[i].courseId == wList[a[j]].cid &&
  1053. _workCourse[i].id
  1054. ) {
  1055. wList[a[j]].work++;
  1056. }
  1057. }
  1058. }
  1059. var workNumList = Object.values(wList).map((item) => [
  1060. item.task,
  1061. item.work,
  1062. item.title,
  1063. item.cid,
  1064. ]);
  1065. this.workNumList = workNumList;
  1066. this.taskCount = _taskCount;
  1067. this.workCount = _workCourse.length;
  1068. this.isCourseCount = res.data[11][0].count; //课程开展总数
  1069. this.allCourseCount = res.data[9].length; //课程总数
  1070. let _gradeCourse = 0; //各年级上传课程
  1071. let _subjectCourse = 0; //各学科上传课程
  1072. let _courseArray = [];
  1073. _subject.push({ name: "其他" });
  1074. for (var i = 0; i < _grade.length; i++) {
  1075. _courseArray.push({
  1076. name: _grade[i].name,
  1077. id: _grade[i].id,
  1078. courseid: [],
  1079. subject: [],
  1080. });
  1081. for (var z = 0; z < _course.length; z++) {
  1082. if (_course[z].typeid == _grade[i].id) {
  1083. _gradeCourse++;
  1084. if (
  1085. _courseArray[i].courseid.indexOf(_course[z].courseid) === -1
  1086. ) {
  1087. _courseArray[i].courseid.push(_course[z].courseid);
  1088. }
  1089. }
  1090. }
  1091. for (var j = 0; j < _subject.length; j++) {
  1092. _courseArray[i].subject.push({
  1093. name: _subject[j].name,
  1094. id: _subject[j].id,
  1095. course: 0,
  1096. });
  1097. for (var z = 0; z < _course.length; z++) {
  1098. if (
  1099. _course[z].typeid == _subject[j].id &&
  1100. _courseArray[i].courseid.indexOf(_course[z].courseid) !== -1
  1101. ) {
  1102. _courseArray[i].subject[j].course++;
  1103. }
  1104. }
  1105. }
  1106. let sum = 0;
  1107. for (var j = 0; j < _courseArray[i].subject.length - 1; j++) {
  1108. sum += _courseArray[i].subject[j].course;
  1109. }
  1110. _courseArray[i].subject[_courseArray[i].subject.length - 1].course =
  1111. _courseArray[i].courseid.length - sum < 0
  1112. ? 0
  1113. : _courseArray[i].courseid.length - sum;
  1114. }
  1115. for (var j = 0; j < _subject.length; j++) {
  1116. for (var z = 0; z < _course.length; z++) {
  1117. if (_course[z].typeid == _subject[j].id) {
  1118. _subjectCourse++;
  1119. }
  1120. }
  1121. }
  1122. this.courseArray = _courseArray;
  1123. this.evaCount = res.data[12][0].count; //设置评价
  1124. this.evaWorksCount = res.data[13][0].count; //查询有目标并且有评价的作业
  1125. for (var i = 0; i < this.pusaDep.length; i++) {
  1126. if (this.pusaDep[i].name == "课程总数") {
  1127. this.pusaDep[i].value = (
  1128. (this.allCourse / this.allCourse) *
  1129. 100
  1130. ).toFixed(0);
  1131. } else if (this.pusaDep[i].name == "设置评价课程") {
  1132. this.pusaDep[i].value = (
  1133. (this.evaCount / this.allCourse) *
  1134. 100
  1135. ).toFixed(0);
  1136. } else if (this.pusaDep[i].name == "已提交作业课程") {
  1137. this.pusaDep[i].value = (
  1138. (this.haveWorksCourse / this.allCourse) *
  1139. 100
  1140. ).toFixed(0);
  1141. } else if (this.pusaDep[i].name == "已评价课程") {
  1142. this.pusaDep[i].value = (
  1143. (this.evaWorksCount / this.allCourse) *
  1144. 100
  1145. ).toFixed(0);
  1146. } else if (this.pusaDep[i].name == "教学评一体化课程") {
  1147. this.pusaDep[i].value = (
  1148. (this.evaWorksCount / this.allCourse) *
  1149. 100
  1150. ).toFixed(0);
  1151. }
  1152. }
  1153. var today = new Date();
  1154. var lastDayOfWeek = new Date(
  1155. today.setDate(today.getDate() - today.getDay() + 7)
  1156. ); //本周周日
  1157. let weekArray = {
  1158. lastWeek: [], //上周
  1159. toWeek: [], //本周
  1160. };
  1161. for (var i = 0; i < 14; i++) {
  1162. let time = JSON.parse(JSON.stringify(lastDayOfWeek));
  1163. let time2 = new Date(time);
  1164. var a = new Date(time2.setDate(time2.getDate() - i));
  1165. if (i > 6) {
  1166. weekArray.lastWeek.push(
  1167. a.getFullYear() + "-" + (a.getMonth() + 1) + "-" + a.getDate()
  1168. );
  1169. } else {
  1170. weekArray.toWeek.push(
  1171. a.getFullYear() + "-" + (a.getMonth() + 1) + "-" + a.getDate()
  1172. );
  1173. }
  1174. }
  1175. let weekCourse = [];
  1176. let weekCourse2 = [];
  1177. let lastWeekCouseCount = 0;
  1178. let toWeekCouseCount = 0;
  1179. for (var z = 0; z < _course.length; z++) {
  1180. let _date = new Date(
  1181. weekArray.lastWeek[weekArray.lastWeek.length - 1]
  1182. );
  1183. if (
  1184. new Date(_course[z].create_at) > _date &&
  1185. _course[z].pid == "34628934-d02f-11ec-8c78-005056b86db5"
  1186. ) {
  1187. weekCourse.push(_course[z]);
  1188. var a = new Date(_course[z].create_at);
  1189. var string =
  1190. a.getFullYear() + "-" + (a.getMonth() + 1) + "-" + a.getDate();
  1191. if (weekArray.lastWeek.indexOf(string) != -1) {
  1192. lastWeekCouseCount++;
  1193. } else {
  1194. toWeekCouseCount++;
  1195. }
  1196. }
  1197. }
  1198. let lastCourseidWeek = [];
  1199. let toCourseidWeek = [];
  1200. for (var i = 0; i < _grade.length; i++) {
  1201. weekCourse2.push({
  1202. name: _grade[i].name,
  1203. id: _grade[i].id,
  1204. lastCourse: 0,
  1205. toCourse: 0,
  1206. });
  1207. for (var z = 0; z < weekCourse.length; z++) {
  1208. if (weekCourse[z].typeid == _grade[i].id) {
  1209. var a = new Date(weekCourse[z].create_at);
  1210. var string =
  1211. a.getFullYear() +
  1212. "-" +
  1213. (a.getMonth() + 1) +
  1214. "-" +
  1215. a.getDate();
  1216. if (weekArray.lastWeek.indexOf(string) != -1) {
  1217. weekCourse2[i].lastCourse++;
  1218. if (lastCourseidWeek.indexOf(weekCourse[z].courseid) === -1) {
  1219. lastCourseidWeek.push(weekCourse[z].courseid);
  1220. }
  1221. } else {
  1222. weekCourse2[i].toCourse++;
  1223. if (toCourseidWeek.indexOf(weekCourse[z].courseid) === -1) {
  1224. toCourseidWeek.push(weekCourse[z].courseid);
  1225. }
  1226. }
  1227. }
  1228. }
  1229. }
  1230. weekCourse2.push({
  1231. name: "其他",
  1232. id: "",
  1233. lastCourse:
  1234. lastWeekCouseCount - lastCourseidWeek.length > 0
  1235. ? lastWeekCouseCount - lastCourseidWeek.length
  1236. : 0,
  1237. toCourse:
  1238. toWeekCouseCount - toCourseidWeek.length > 0
  1239. ? toWeekCouseCount - toCourseidWeek.length
  1240. : 0,
  1241. });
  1242. this.weekCourse2 = weekCourse2;
  1243. this.$forceUpdate();
  1244. })
  1245. .catch((err) => {
  1246. this.isLoading = false;
  1247. console.error(err);
  1248. });
  1249. },
  1250. },
  1251. };
  1252. </script>
  1253. <style scoped>
  1254. .body1 {
  1255. width: 100%;
  1256. height: 100%;
  1257. display: flex;
  1258. padding: 20px;
  1259. box-sizing: border-box;
  1260. overflow: hidden;
  1261. }
  1262. .left {
  1263. width: calc(100% / 4 * 1);
  1264. height: 100%;
  1265. }
  1266. .left > .top {
  1267. width: 100%;
  1268. height: calc(100% / 2 - 10px);
  1269. background: #fff;
  1270. border-radius: 5px;
  1271. margin: 0 0 20px 0;
  1272. }
  1273. .left > .bottom {
  1274. width: 100%;
  1275. height: calc(100% / 2 - 10px);
  1276. background: #fff;
  1277. border-radius: 5px;
  1278. }
  1279. .center {
  1280. width: calc(100% / 4 * 2 - 40px);
  1281. height: 100%;
  1282. margin: 0 20px;
  1283. }
  1284. .center > .top {
  1285. width: 100%;
  1286. height: calc(100% / 5 * 3 - 10px);
  1287. background: #fff;
  1288. border-radius: 5px;
  1289. margin: 0 0 20px 0;
  1290. }
  1291. .center > .bottom {
  1292. width: 100%;
  1293. height: calc(100% / 5 * 2 - 10px);
  1294. background: #fff;
  1295. border-radius: 5px;
  1296. }
  1297. .right {
  1298. width: calc(100% / 4 * 1);
  1299. height: 100%;
  1300. }
  1301. .right > .top {
  1302. width: 100%;
  1303. height: calc(100% / 2 - 10px);
  1304. background: #fff;
  1305. border-radius: 16px;
  1306. margin: 0 0 20px 0;
  1307. }
  1308. .right > .bottom {
  1309. width: 100%;
  1310. height: calc(100% / 2 - 10px);
  1311. background: #fff;
  1312. border-radius: 5px;
  1313. }
  1314. .titleBox {
  1315. height: 40px;
  1316. display: flex;
  1317. align-items: center;
  1318. padding: 0 15px;
  1319. box-sizing: border-box;
  1320. width: 100%;
  1321. }
  1322. .dataBox {
  1323. height: calc(100% - 40px);
  1324. width: 100%;
  1325. }
  1326. .middleBox {
  1327. display: flex;
  1328. flex-direction: row;
  1329. flex-wrap: nowrap;
  1330. align-items: flex-start;
  1331. }
  1332. .title {
  1333. color: #060e17;
  1334. margin-right: 10px;
  1335. }
  1336. .teaMiddle {
  1337. width: calc(100% / 2 - 10px);
  1338. height: 60px;
  1339. border-radius: 8px;
  1340. /* border: 1px solid #e0eafb; */
  1341. display: flex;
  1342. flex-direction: column;
  1343. align-items: flex-start;
  1344. justify-content: center;
  1345. padding: 0 10px;
  1346. margin: 0 10px;
  1347. }
  1348. .teaMiddle {
  1349. width: calc(100% / 3 - 10px);
  1350. }
  1351. .cNum {
  1352. background: linear-gradient(
  1353. 180deg,
  1354. rgb(125, 227, 174, 0.2) 0%,
  1355. rgb(23, 196, 105, 0.3) 100%
  1356. ) !important;
  1357. }
  1358. .tNum {
  1359. background: linear-gradient(
  1360. 180deg,
  1361. rgb(174, 204, 254, 0.2) 0%,
  1362. rgb(54, 129, 252, 0.3) 100%
  1363. ) !important;
  1364. }
  1365. .tSum {
  1366. background: linear-gradient(
  1367. 180deg,
  1368. rgb(125, 227, 174, 0.2) 0%,
  1369. rgb(23, 196, 105, 0.3) 100%
  1370. ) !important;
  1371. }
  1372. .teaLeft > div:first-child,
  1373. .teaMiddle > div:first-child {
  1374. font-size: 12px;
  1375. font-weight: 400;
  1376. color: #565e6a;
  1377. }
  1378. .teaLeft > div:last-child,
  1379. .teaMiddle > div:last-child {
  1380. font-size: 22px;
  1381. font-weight: bold;
  1382. color: #060e17;
  1383. }
  1384. .halfBox {
  1385. width: 50%;
  1386. height: 100%;
  1387. }
  1388. .selectBox {
  1389. width: 80px;
  1390. margin-left: 10px;
  1391. }
  1392. .selectBox >>> .el-input__inner {
  1393. height: 30px;
  1394. line-height: 30px;
  1395. }
  1396. .selectBox >>> .el-input__icon {
  1397. line-height: 30px;
  1398. }
  1399. .timeDiv {
  1400. display: flex;
  1401. flex-direction: row;
  1402. flex-wrap: nowrap;
  1403. align-items: center;
  1404. margin: 0 0 0 15px;
  1405. }
  1406. .timeDiv > div {
  1407. margin-right: 10px;
  1408. cursor: pointer;
  1409. }
  1410. .isClick {
  1411. color: #1684fc;
  1412. border-bottom: 2px solid #1684fc;
  1413. box-sizing: border-box;
  1414. }
  1415. .otherCss {
  1416. display: flex;
  1417. flex-direction: row;
  1418. flex-wrap: nowrap;
  1419. align-items: center;
  1420. justify-content: flex-end;
  1421. }
  1422. .otherImg {
  1423. width: 20px;
  1424. height: 20px;
  1425. margin: 0 10px;
  1426. cursor: pointer;
  1427. }
  1428. .otherImg > img {
  1429. width: 100%;
  1430. height: 100%;
  1431. }
  1432. .allBox {
  1433. width: 100%;
  1434. height: 100%;
  1435. display: flex;
  1436. flex-direction: row;
  1437. flex-wrap: nowrap;
  1438. align-items: center;
  1439. }
  1440. .allBox_left {
  1441. width: 30%;
  1442. height: 100%;
  1443. }
  1444. .allBox_right {
  1445. display: flex;
  1446. flex-wrap: wrap;
  1447. height: 100%;
  1448. width: 70%;
  1449. margin: 0 auto;
  1450. overflow: hidden;
  1451. justify-content: space-between;
  1452. }
  1453. .depth {
  1454. width: calc(100% / 4 - 10px);
  1455. display: flex;
  1456. flex-direction: column;
  1457. align-items: center;
  1458. justify-content: center;
  1459. }
  1460. .depth > span:nth-child(1) {
  1461. font-size: 14px;
  1462. font-weight: 700;
  1463. margin: 0 0 10px;
  1464. }
  1465. .depth > div:nth-child(1) {
  1466. }
  1467. .info_box {
  1468. display: flex;
  1469. flex-wrap: wrap;
  1470. align-items: center;
  1471. justify-content: space-between;
  1472. width: 90%;
  1473. margin: 0 auto;
  1474. }
  1475. .info_box > .info2,
  1476. .info_box > .info3,
  1477. .info_box > .info {
  1478. width: calc(50% - 10px);
  1479. display: flex;
  1480. flex-direction: row;
  1481. flex-wrap: nowrap;
  1482. height: 60px;
  1483. justify-content: space-between;
  1484. align-items: center;
  1485. padding: 0 10px;
  1486. box-sizing: border-box;
  1487. margin-bottom: 10px;
  1488. border-radius: 5px;
  1489. }
  1490. .info_box > .info2 {
  1491. width: calc(100% / 4 - 10px);
  1492. /* align-items: flex-end; */
  1493. }
  1494. .info_box > .info3 {
  1495. width: 100%;
  1496. margin-bottom: 5px;
  1497. }
  1498. .info_box > .info2 > span:nth-child(1),
  1499. .info_box > .info3 > span:nth-child(1),
  1500. .info_box > .info > span:nth-child(1) {
  1501. font-size: 14px;
  1502. /* margin: 0 0 0 20px; */
  1503. color: #565e6a;
  1504. width: 60px;
  1505. white-space: pre-wrap;
  1506. word-break: break-all;
  1507. }
  1508. .info_box > .info2 > span:nth-child(2),
  1509. .info_box > .info3 > span:nth-child(2),
  1510. .info_box > .info > span:nth-child(2) {
  1511. font-size: 24px;
  1512. /* font-weight: 700; */
  1513. }
  1514. .blueBG {
  1515. background: rgb(243, 248, 253);
  1516. border: 2px solid rgb(234, 246, 255);
  1517. }
  1518. </style>