index.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617
  1. <!--学习资源-->
  2. <template>
  3. <div class="app-container el-course hardware">
  4. <div class="list-max-big-box" v-if="pageType === 1">
  5. <div class="top-max-box">
  6. <div class="left-max-box scrollbar-box" v-hasPermi="['exam:el_category:list']">
  7. <div class="classify_btn" @click="goPageEdit(5,'')">管理分类 >></div>
  8. <el-tree
  9. :data="treeData"
  10. :props="defaultProps"
  11. :highlight-current="true"
  12. :expand-on-click-node="false"
  13. :filter-node-method="filterNode"
  14. node-key="id"
  15. ref="tree"
  16. default-expand-all
  17. @node-click="handleNodeClick"
  18. />
  19. </div>
  20. <div class="center-max-box" v-hasPermi="['exam:el_category:list']"></div>
  21. <div class="right-max-box">
  22. <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch">
  23. <el-form-item label="课程名称" prop="title" label-width="90px">
  24. <el-input
  25. v-model="queryParams.title"
  26. placeholder="请输入课程名称"
  27. clearable
  28. size="small"
  29. />
  30. </el-form-item>
  31. <el-form-item label="" prop="title" style="float: right">
  32. <el-col :span="1.5">
  33. <p class="add-button-one-90"
  34. @click="goPageEdit(1)"
  35. v-hasPermi="['exam:el_course:add']"
  36. ><i class="el-icon-plus"></i>新增</p>
  37. </el-col>
  38. </el-form-item>
  39. <el-form-item >
  40. <p class="inquire-button-one" @click="handleQuery">查询</p>
  41. <p class="reset-button-one" @click="resetQuery">重置</p>
  42. </el-form-item>
  43. </el-form>
  44. <div class="min-list-box">
  45. <el-table v-loading="loading" border :data="el_courseList" :cell-style="cellStyle">
  46. <el-table-column label="课程名称" align="left" prop="title" :show-overflow-tooltip="true">
  47. <template slot-scope="scope">
  48. <el-button type="text" size="small" @click="goCourseDetails(scope.row)"
  49. style="padding:0;height:23px;width:320px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align: left;">{{scope.row.title}}</el-button>
  50. </template>
  51. </el-table-column>
  52. <el-table-column label="适用学院" align="left" prop="title" :show-overflow-tooltip="true" width="140"/>
  53. <el-table-column label="适用类型" align="left" prop="scopeType" :show-overflow-tooltip="true" width="140">
  54. <template slot-scope="scope">
  55. <span v-for="(bigItem,bigIndex) in scope.row.scopeType" :key="bigIndex">
  56. <span v-for="(item,index) in scopeTypes" :key="index" v-if="bigItem==item.type">{{bigIndex==0?item.value:'、'+item.value}}</span>
  57. </span>
  58. </template>
  59. </el-table-column>
  60. <el-table-column label="分类" align="left" prop="cateTitle" :show-overflow-tooltip="true" width="100"/>
  61. <el-table-column label="章节数" align="left" prop="chapters" width="80"/>
  62. <el-table-column label="有效时间" align="left" prop="createTime" width="120">
  63. <template slot-scope="scope">
  64. {{scope.row.ceType==0?'永久':(scope.row.ceType==1?scope.row.ceTime:'')}}
  65. </template>
  66. </el-table-column>
  67. <el-table-column label="学习人数" align="left" prop="learns" width="100"/>
  68. <el-table-column label="访问人数" align="left" prop="accessNum" width="100"/>
  69. <!--<el-table-column label="奖励积分" align="left" prop="points" width="100"/>-->
  70. <!--<el-table-column label="学习机积分" align="left" prop="machinePoints" width="120"/>-->
  71. <!-- <el-table-column label="状态" align="left" prop="createTime" width="80">
  72. <template slot-scope="scope">
  73. {{scope.row.status==1?'已上架':(scope.row.status==0?'下架':'')}}
  74. </template>
  75. </el-table-column>-->
  76. <el-table-column label="状态" align="left" prop="status" width="90">
  77. <template slot-scope="scope">
  78. <el-switch
  79. v-hasPermi="['exam:el_course:edit']"
  80. class="switch"
  81. @change="switchChange(scope.row)"
  82. v-model="scope.row.status+''"
  83. active-value="1"
  84. inactive-value="0"
  85. active-text="上架"
  86. inactive-text="下架"
  87. >
  88. </el-switch>
  89. </template>
  90. </el-table-column>
  91. <el-table-column label="操作" align="left" class-name="small-padding fixed-width" width="90">
  92. <template slot-scope="scope">
  93. <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)">
  94. <span class="table-min-button">
  95. 更多<i class="el-icon-d-arrow-right el-icon--right"></i>
  96. </span>
  97. <el-dropdown-menu slot="dropdown">
  98. <el-dropdown-item command="record">学习记录</el-dropdown-item>
  99. <el-dropdown-item command="edit" v-hasPermiAnd="['exam:el_course:query','exam:el_course:edit']">编辑</el-dropdown-item>
  100. <el-dropdown-item command="delete" v-hasPermi="['exam:el_course:remove']">删除</el-dropdown-item>
  101. </el-dropdown-menu>
  102. </el-dropdown>
  103. </template>
  104. </el-table-column>
  105. </el-table>
  106. </div>
  107. </div>
  108. </div>
  109. <div class="bottom-max-box">
  110. <pagination :page-sizes="[20, 30, 40, 50]"
  111. v-show="total>0"
  112. :total="total"
  113. layout="total, prev, pager, next, sizes, jumper"
  114. :page.sync="queryParams.pageNum"
  115. :limit.sync="queryParams.pageSize"
  116. @pagination="getList"
  117. />
  118. </div>
  119. </div>
  120. <!--编辑-->
  121. <edit-page v-if="pageType == 2" :infoId="infoId"></edit-page>
  122. <!--查看记录-->
  123. <detail-page v-if="pageType == 3" :infoId="infoId"></detail-page>
  124. <!-- 添加或修改学习资源对话框 -->
  125. <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
  126. <el-form ref="form" :model="form" :rules="rules" label-width="80px">
  127. <el-form-item label="备注" prop="remark">
  128. <el-input v-model="form.remark" placeholder="请输入备注" />
  129. </el-form-item>
  130. <el-form-item label="分类ID" prop="cateId">
  131. <el-input v-model="form.cateId" placeholder="请输入分类ID" />
  132. </el-form-item>
  133. <el-form-item label="标题" prop="title">
  134. <el-input v-model="form.title" placeholder="请输入标题" />
  135. </el-form-item>
  136. <el-form-item label="是否公开" prop="private">
  137. <el-input v-model="form.private" placeholder="请输入是否公开" />
  138. </el-form-item>
  139. <el-form-item label="等级" prop="level">
  140. <el-input v-model="form.level" placeholder="请输入等级" />
  141. </el-form-item>
  142. <el-form-item label="是否限制顺序" prop="orderRest">
  143. <el-input v-model="form.orderRest" placeholder="请输入是否限制顺序" />
  144. </el-form-item>
  145. <el-form-item label="课程时长" prop="duration">
  146. <el-input v-model="form.duration" placeholder="请输入课程时长" />
  147. </el-form-item>
  148. <el-form-item label="课程标签" prop="label">
  149. <el-input v-model="form.label" placeholder="请输入课程标签" />
  150. </el-form-item>
  151. <el-form-item label="PDF翻页有效时间" prop="effectiveTime">
  152. <el-input v-model="form.effectiveTime" placeholder="请输入PDF翻页有效时间" />
  153. </el-form-item>
  154. <el-form-item label="课程有效时间类型" prop="ceType">
  155. <el-select v-model="form.ceType" placeholder="请选择课程有效时间类型">
  156. <el-option label="请选择字典生成" value="" />
  157. </el-select>
  158. </el-form-item>
  159. <el-form-item label="课程有效时间" prop="ceTime">
  160. <el-input v-model="form.ceTime" placeholder="请输入课程有效时间" />
  161. </el-form-item>
  162. <el-form-item label="课程关键字" prop="keywords">
  163. <el-input v-model="form.keywords" placeholder="请输入课程关键字" />
  164. </el-form-item>
  165. <el-form-item label="封面图片" prop="img">
  166. <el-input v-model="form.img" placeholder="请输入封面图片" />
  167. </el-form-item>
  168. <el-form-item label="课程状态 1 下架,2 上架">
  169. <el-radio-group v-model="form.status">
  170. <el-radio label="1">请选择字典生成</el-radio>
  171. </el-radio-group>
  172. </el-form-item>
  173. <el-form-item label="是否显示课程拖拽进度" prop="videoDraggable">
  174. <el-input v-model="form.videoDraggable" placeholder="请输入是否显示课程拖拽进度" />
  175. </el-form-item>
  176. <el-form-item label="积分值" prop="points">
  177. <el-input v-model="form.points" placeholder="请输入积分值" />
  178. </el-form-item>
  179. <el-form-item label="设置选项" prop="settings">
  180. <el-input v-model="form.settings" type="textarea" placeholder="请输入内容" />
  181. </el-form-item>
  182. <el-form-item label="课程类型" prop="type">
  183. <el-select v-model="form.type" placeholder="请选择课程类型">
  184. <el-option label="请选择字典生成" value="" />
  185. </el-select>
  186. </el-form-item>
  187. </el-form>
  188. <div slot="footer" class="dialog-footer">
  189. <el-button type="primary" @click="submitForm">确 定</el-button>
  190. <el-button @click="cancel">取 消</el-button>
  191. </div>
  192. </el-dialog>
  193. <!--课程详情-->
  194. <course-details v-if="pageType == 4" :infoId="infoId"></course-details>
  195. <!--管理分类-->
  196. <add-classify v-if="pageType == 5" :pageData="pageData"></add-classify>
  197. </div>
  198. </template>
  199. <script>
  200. import { listDepartments } from "@/api/system/dept";
  201. import { listEl_category} from "@/api/exam/el_category";
  202. import { listEl_course, getEl_course, delEl_course, addEl_course, updateEl_course } from "@/api/exam/el_course";
  203. import editPage from "./edit.vue";
  204. import detailPage from "./detail.vue";
  205. import courseDetails from "./courseDetails.vue";
  206. import addClassify from "../el_category/index";
  207. export default {
  208. name: "El_course",
  209. components: {
  210. editPage,
  211. detailPage,
  212. courseDetails,
  213. addClassify
  214. },
  215. data() {
  216. return {
  217. //页面状态
  218. pageType:1,
  219. pageData:{
  220. type:2,//1资源管理2课程管理
  221. },
  222. //树数据
  223. treeData:[],
  224. defaultProps: {
  225. children: "children",
  226. label: "title"
  227. },
  228. //学院
  229. deptOptions:[],
  230. //适用范围
  231. scopeTypes: [
  232. {
  233. type: 1,
  234. value: "安全准入考试",
  235. },
  236. {
  237. type: 2,
  238. value: "负面清单考试",
  239. },
  240. {
  241. type: 3,
  242. value: "黑名单考试",
  243. },
  244. {
  245. type: 4,
  246. value: "模拟考试",
  247. },
  248. ],
  249. statusList:[
  250. {
  251. type: 1,
  252. value: "上架",
  253. },
  254. {
  255. type: 2,
  256. value: "下架",
  257. },
  258. ],
  259. // 遮罩层
  260. loading: true,
  261. // 选中数组
  262. ids: [],
  263. // 非单个禁用
  264. single: true,
  265. // 非多个禁用
  266. multiple: true,
  267. // 显示搜索条件
  268. showSearch: true,
  269. // 总条数
  270. total: 0,
  271. // 学习资源表格数据
  272. el_courseList: [],
  273. // 弹出层标题
  274. title: "",
  275. // 是否显示弹出层
  276. open: false,
  277. // 查询参数
  278. queryParams: {
  279. pageNum: 1,
  280. pageSize:20,
  281. title: '',
  282. },
  283. // 日期范围
  284. dateRange: [],
  285. // 表单参数
  286. form: {},
  287. // 表单校验
  288. rules: {
  289. title: [
  290. { required: true, message: "标题不能为空", trigger: "blur" },
  291. { required: true, message: "标题不能为空", validator: this.spaceJudgment, trigger: "blur" }
  292. ],
  293. },
  294. infoId:{},
  295. };
  296. },
  297. created() {
  298. this.getTreeData();
  299. this.getDeptList();
  300. },
  301. methods: {
  302. //课程状态
  303. switchChange(row){
  304. console.log(row.status)
  305. //1上架0下架
  306. this.$confirm('是否确定'+(row.status==0?'上架':'下架')+'?', '提示', {
  307. confirmButtonText: '确定',
  308. cancelButtonText: '取消',
  309. type: 'warning'
  310. }).then(() => {
  311. this.upDownShelf(row.id,row.status==0?1:0)
  312. }).catch(() => {
  313. this.$message({
  314. type: 'info',
  315. message: '已取消'
  316. });
  317. });
  318. },
  319. //上架下架
  320. upDownShelf(id,status){
  321. let obj = {
  322. id:id,
  323. status:status,//课程状态 0 下架,1 上架
  324. };
  325. updateEl_course(obj).then( response => {
  326. this.msgSuccess("修改成功");
  327. this.getList();
  328. });
  329. },
  330. //去课程详情页面
  331. goCourseDetails(row){
  332. console.log("row",row)
  333. this.pageType = 4;
  334. this.infoId.id = row.id;
  335. },
  336. //单元格样式
  337. cellStyle({row, column, rowIndex, columnIndex}) {//根据测试结果动态调整单元格样式,成功-绿色,失败-红色,不支持-黄色
  338. if(column.title) {
  339. return "color:red;"
  340. }
  341. },
  342. /* 查询学院列表 */
  343. getDeptList(){
  344. listDepartments().then(response => {
  345. // this.deptOptions = response.data;
  346. this.$set(this, 'deptOptions', response.data)
  347. });
  348. },
  349. // 更多操作触发
  350. handleCommand(command, row) {
  351. switch (command) {
  352. case "record":
  353. this.goPageEdit(3,row.id);
  354. break;
  355. case "edit":
  356. this.goPageEdit(2,row.id);
  357. break;
  358. case "delete":
  359. this.handleDelete(row);
  360. break;
  361. default:
  362. break;
  363. }
  364. },
  365. //新增/编辑按钮
  366. goPageEdit(type,id){
  367. console.log(type)
  368. if(type == 1){
  369. this.infoId = {};
  370. this.pageType = 2;
  371. }else if(type == 2){
  372. this.infoId.id = id;
  373. this.pageType = 2;
  374. }else if(type == 3){
  375. this.infoId.id = id;
  376. this.pageType = 3;
  377. }else if(type == 4){
  378. this.pageType = 1;
  379. this.getList();
  380. this.getTreeData();
  381. }else if(type==5){//管理分类
  382. this.pageType = 5;
  383. }
  384. },
  385. /** 查询分类树 */
  386. getTreeData() {
  387. this.loading = true;
  388. listEl_category({},2).then( response => {
  389. let list = [];
  390. let obj = {
  391. children:[],
  392. title:"所有分类",
  393. id:"",
  394. };
  395. list.push(obj);
  396. for(let i=0;i<response.data.length;i++){
  397. list.push(response.data[i]);
  398. }
  399. this.treeData = list;
  400. this.getList();
  401. });
  402. },
  403. // 筛选节点
  404. filterNode(value, data) {
  405. if (!value) return true;
  406. return data.label.indexOf(value) !== -1;
  407. },
  408. // 节点单击事件
  409. handleNodeClick(data) {
  410. this.queryParams.pageNum = 1;
  411. this.queryParams.pageSize = 20;
  412. this.queryParams.cateId = data.id;
  413. this.getList();
  414. },
  415. /** 查询学习资源列表 */
  416. getList() {
  417. let self = this;
  418. this.loading = true;
  419. if(this.dateRange&&this.dateRange.length>0) {
  420. this.queryParams.beginTime=this.dateRange[0]
  421. this.queryParams.endTime=this.dateRange[1]
  422. } else {
  423. this.queryParams.beginTime=null;
  424. this.queryParams.endTime=null
  425. }
  426. listEl_course(this.queryParams).then( response => {
  427. this.el_courseList = response.rows;
  428. for(let i=0;i<self.el_courseList.length;i++){
  429. if(self.el_courseList[i].scopeType){
  430. self.el_courseList[i].scopeType = self.el_courseList[i].scopeType.split(',');
  431. }
  432. }
  433. this.total = response.total;
  434. this.loading = false;
  435. });
  436. },
  437. // 取消按钮
  438. cancel() {
  439. this.open = false;
  440. this.reset();
  441. },
  442. // 表单重置
  443. reset() {
  444. this.form = {
  445. id: null,
  446. userId: null,
  447. createBy: null,
  448. updateBy: null,
  449. deptId: null,
  450. deptName: null,
  451. createTime: null,
  452. updateTime: null,
  453. remark: null,
  454. cateId: null,
  455. title: null,
  456. private: null,
  457. level: null,
  458. orderRest: null,
  459. duration: null,
  460. label: null,
  461. effectiveTime: null,
  462. ceType: null,
  463. ceTime: null,
  464. keywords: null,
  465. img: null,
  466. status: 0,
  467. videoDraggable: null,
  468. points: null,
  469. settings: null,
  470. type: null
  471. };
  472. this.resetForm("form");
  473. },
  474. /** 搜索按钮操作 */
  475. handleQuery() {
  476. this.queryParams.pageNum = 1;
  477. this.getList();
  478. },
  479. /** 重置按钮操作 */
  480. resetQuery() {
  481. // this.resetForm("queryForm");
  482. this.$set(this,'queryParams',{
  483. pageNum: 1,
  484. pageSize:20,
  485. cateId:"",
  486. title: '',
  487. });
  488. this.dateRange=[];
  489. this.$refs.tree.setCurrentKey();
  490. this.handleQuery();
  491. },
  492. /** 新增按钮操作 */
  493. handleAdd() {
  494. this.reset();
  495. this.open = true;
  496. this.title = "添加学习资源";
  497. },
  498. /** 修改按钮操作 */
  499. handleUpdate(row) {
  500. this.reset();
  501. const id = row.id || this.ids
  502. getEl_course(id).then( response => {
  503. this.form = response.data;
  504. this.open = true;
  505. this.title = "修改学习资源";
  506. });
  507. },
  508. /** 提交按钮 */
  509. submitForm() {
  510. this.$refs["form"].validate(valid => {
  511. if (valid) {
  512. if (this.form.id != null) {
  513. updateEl_course(this.form).then( response => {
  514. this.msgSuccess("修改成功");
  515. this.open = false;
  516. this.getList();
  517. });
  518. } else {
  519. addEl_course(this.form).then( response => {
  520. this.msgSuccess("新增成功");
  521. this.open = false;
  522. this.getList();
  523. });
  524. }
  525. }
  526. });
  527. },
  528. /** 删除按钮操作 */
  529. handleDelete(row) {
  530. if(row.status == 1){
  531. this.msgError('请先下架课程后再进行删除操作')
  532. return
  533. }
  534. const ids = row.id || this.ids;
  535. this.$confirm('是否确认删除?', "警告", {
  536. confirmButtonText: "确定",
  537. cancelButtonText: "取消",
  538. type: "warning"
  539. }).then(function() {
  540. return delEl_course(ids);
  541. }).then(() => {
  542. this.getList();
  543. this.msgSuccess("删除成功");
  544. }).catch(() => {});
  545. },
  546. /** 导出按钮操作 */
  547. handleExport() {
  548. this.download('exam/el_course/export', {
  549. ...this.queryParams
  550. }, `exam_el_course.xlsx`)
  551. }
  552. }
  553. };
  554. </script>
  555. <style scoped lang="scss">
  556. .el-course {
  557. display: flex!important;
  558. flex-direction: column;
  559. box-shadow: 0 0 8px 2px rgba(0, 0, 0, 0.1);
  560. overflow: hidden;
  561. .list-max-big-box{
  562. flex:1;
  563. display: flex!important;
  564. flex-direction: column;
  565. padding:20px!important;
  566. overflow: hidden;
  567. .top-max-box{
  568. flex:1;
  569. display: flex;
  570. overflow: hidden!important;
  571. .left-max-box{
  572. width:250px;
  573. .classify_btn{
  574. font-size: 14px;
  575. font-family: Microsoft YaHei;
  576. font-weight: 400;
  577. color: #0183FA;
  578. line-height: 70px;
  579. cursor: pointer;
  580. text-align: left;
  581. }
  582. }
  583. .center-max-box{
  584. border-right:2px dashed #E0E0E0;
  585. margin-right:30px;
  586. margin-top:20px;
  587. }
  588. .right-max-box{
  589. flex:1;
  590. display: flex;
  591. flex-direction: column;
  592. overflow: hidden!important;
  593. .min-list-box{
  594. flex: 1;
  595. overflow: hidden!important;
  596. display: flex;
  597. margin-bottom:15px;
  598. .button-box{
  599. width:300px;
  600. display: flex;
  601. }
  602. }
  603. }
  604. }
  605. .bottom-max-box{
  606. height:50px;
  607. }
  608. }
  609. }
  610. </style>