123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787 |
- <template>
- <div class="pb_content" style="background: unset">
- <div class="pb_content_body" style="
- background: #fff;
- padding: 0px 25px;
- box-sizing: border-box;
- border-radius: 5px;
- ">
- <div class="pb_head">
- <span>教师资源</span>
- <div class="student_button">
- <el-button type="primary" class="bgColor" @click="addSource" v-show="false">添加资源</el-button>
- </div>
- </div>
- <div class="reBox">
- <div class="reTop">
- <div>分类筛选</div>
- <div>
- <!-- @click="getCourse" -->
- <div class="search" @click="getSource">
- <img src="../../../assets/icon/search.png" alt="" />
- </div>
- <input class="sInput" type="text" placeholder="请输入关键字" v-model="sourceName"
- @keyup.enter="getSource" />
- </div>
- </div>
- <div class="choose">
- <div class="all_choose" v-for="(item, index) in CourseType[0]" :key="index"
- :style="{ margin: !CourseTypeJson[item.id].length && 0 }" v-if="(item.name != '类型') || typea != '' || typeE.indexOf('e4cb3395-5602-4441-801c-f380e8935a74') != -1">
- <span v-if="CourseTypeJson[item.id].length">{{ item.name }}:</span>
- <div class="typeCss" v-if="CourseTypeJson[item.id].length">
- <div class="cName" @click="getCourse2(item.name, '', item.id, 1)"
- :class="typeE.indexOf(item.id) != -1 ? 'isCType' : ''">
- 全部
- </div>
- <div v-for="(item1, index1) in ctype(item.id)" :key="index + '-' + index1"
- :label="item1.id" @click="getCourse2(item.name, item.id, item1.id, 2)">
- <div class="cName" :class="typea == item1.id || typeb == item1.id
- ? 'isCType'
- : ''
- ">
- {{ item1.name }}
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </div>
- <div class="pb_content_body">
- <div class="student_table" v-loading="loading">
- <div class="source-box" v-for="(item, index) in res" :key="index">
- <!-- <div class="iamge"><img src="../../../assets/icon/source/image.png" alt=""></div>
- <div class="title"><span>{{ item.name }}</span></div> -->
- <div class="fengmian">
- <img src="../../../assets/icon/source/fengmian.jpg" alt="">
- <div class="ftitle"><span>{{ item.name }}</span></div>
- </div>
- <div class="detail">{{ item.detail }}</div>
- <div class="label"><span v-for="(k, ki) in item.label.split(',')" :key="index + '-' + ki">{{ k ? k : "无" }}</span>
- </div>
- <div class="button"><span @click="check(item.url)">查看</span><span @click="updateSource(item)" v-show="false">修改</span></div>
- </div>
- <div v-if="!res.length" style="text-align: center; width: 100%;">暂无数据</div>
- </div>
- <div class="student_page">
- <el-pagination background layout="prev, pager, next" :page-size="pageSize" :total="total" v-if="page && total"
- @current-change="handleCurrentChange">
- </el-pagination>
- </div>
- </div>
- <el-dialog title="添加资源" :visible.sync="dialogVisible" :append-to-body="true" width="800px"
- :before-close="handleClose" class="dialog_diy">
- <div class="add-box">
- <div class="span-box">
- <span><span style="color: red">*</span>工具名称</span><el-input class="input" v-model="s_title"
- placeholder="请输入工具名称"></el-input>
- </div>
- <div class="type-box">
- <div class="both">
- <div class="choose2">
- <div class="all_choose2" v-for="(item, index) in CourseType[0]" :key="index">
- <span v-if="CourseTypeJson[item.id].length > 0
- ">{{ item.name }}</span>
- <el-checkbox-group v-model="courseTypeId2" v-if="CourseTypeJson[item.id].length > 0
- ">
- <el-checkbox v-for="item1 in ctype" :key="item1.id"
- :label="item1.id">{{ item1.name }}</el-checkbox>
- </el-checkbox-group>
- </div>
- </div>
- </div>
- </div>
- <div class="span-box">
- <span><span style="color: red">*</span>网址来源</span><el-input class="input" v-model="s_url"
- placeholder="请输入网址来源"></el-input>
- </div>
- <div class="span-box">
- <span><span style="color: red">*</span>工具描述</span><el-input class="input" type="textarea" resize="none"
- rows="5" v-model="s_detail" placeholder="请输入工具描述"></el-input>
- </div>
- <div class="span-box">
- <span>标签</span><el-select class="input" v-model="s_label" multiple placeholder="请选择标签">
- <el-option label="无需登录" value="无需登录"></el-option>
- <el-option label="扫码登录" value="扫码登录"></el-option>
- <el-option label="注册登录" value="注册登录"></el-option>
- <el-option label="免费" value="免费"></el-option>
- <el-option label="付费" value="付费"></el-option>
- <el-option label="中文" value="中文"></el-option>
- <el-option label="英文" value="英文"></el-option>
- </el-select>
- </div>
- </div>
- <span slot="footer" class="dialog-footer">
- <el-button @click="dialogVisible = false">取 消</el-button>
- <el-button type="primary" @click="add()" v-if="updateType == 1">确定</el-button>
- <el-button type="primary" @click="update()" v-if="updateType == 2">确定</el-button>
- </span>
- </el-dialog>
- </div>
- </template>
-
- <script>
- export default {
- data() {
- return {
- page: 1,
- pageSize: 20,
- total: 0,
- isLoading: false,
- dialogVisible: false,
- title: "",
- tableData: [],
- res: [],
- userid: this.$route.query.userid,
- org: this.$route.query.org,
- oid: this.$route.query.oid,
- CourseType: [],
- CourseTypeJson: {},
- courseTypeId: {},
- courseTypeSon: [],
- isChoose: 0,
- sourceName: "",
- typea: "",
- typeb: "",
- typeE: [],
- courseTypeId2: [],
- s_title: "",
- s_url: "",
- s_detail: "",
- s_label: [],
- updateType:1,
- updateId:""
- };
- },
- mounted() {
- this.selectAllType();
- },
- computed: {
- ctype() {
- return function (tid) {
- if(tid == 'e4cb3395-5602-4441-801c-f380e8935a74'){
- return this.CourseTypeJson[tid]
- }else{
- if(this.typea == 'b107f98f-1dc4-4ede-80b4-178ba22b6a59'){
- return this.CourseTypeJson[tid].filter(e => {
- return ['备课资源','作业资源' ].indexOf(e.name) != -1
- })
- }else if(this.typea == '3b12e8d9-866f-46bb-aa22-76cb3b7788b3'){
- return this.CourseTypeJson[tid].filter(e => {
- return ['语文','科学','英语','历史','化学'].indexOf(e.name) != -1
- })
- }else if(this.typea == 'd760341a-5ab7-417f-bfc8-0fd3f183408a'){
- return this.CourseTypeJson[tid].filter(e => {
- return ['优质课例'].indexOf(e.name) != -1
- })
- }else{
- return this.CourseTypeJson[tid]
- }
- }
- };
- }
- },
- methods: {
- check(url){
- window.open(url)
- },
- handleCurrentChange(val) {
- this.page = val;
- this.getSource();
- },
- handleClose(done) {
- done();
- },
- selectAllType() {
- let params = {
- org: this.org && this.org != "" ? this.org : "",
- oid: this.oid && this.oid != "" ? this.oid : "",
- };
- this.ajax
- .get(this.$store.state.api + "selectAllSourceType", params)
- .then((res) => {
- this.CourseType = res.data;
- for (var i = 0; i < res.data[0].length; i++) {
- if (!this.cid) {
- this.courseTypeId[res.data[0][i].id] = [];
- }
- if (!this.CourseTypeJson[res.data[0][i].id]) {
- this.CourseTypeJson[res.data[0][i].id] = [];
- }
- if (res.data[2].length == 0 && res.data[3].length == 0) {
- for (var j = 0; j < res.data[1].length; j++) {
- if (res.data[0][i].id == res.data[1][j].pid) {
- this.CourseTypeJson[res.data[0][i].id].push(res.data[1][j]); // 去除公共分类
- }
- }
- } else {
- if (res.data[2].length > 0) {
- for (var j = 0; j < res.data[2].length; j++) {
- if (res.data[0][i].id == res.data[2][j].pid) {
- this.CourseTypeJson[res.data[0][i].id].push(res.data[2][j]); // 去除公共分类
- }
- }
- }
- if (res.data[3].length > 0) {
- for (var j = 0; j < res.data[3].length; j++) {
- if (res.data[0][i].id == res.data[3][j].pid) {
- this.CourseTypeJson[res.data[0][i].id].push(res.data[3][j]); // 去除公共分类
- }
- }
- }
- }
- }
- })
- .catch((err) => {
- console.error(err);
- });
- },
- getCourse2(typeName, ftypeId, typeid, type) {
- this.typeb = "";
- this.page = 1;
- if (typeName == "场景") {
- if (type == 1) {
- if (this.typeE.indexOf(typeid) != -1) {
- this.typeE.splice(this.typeE.indexOf(typeid), 1);
- } else {
- this.typeE.push(typeid);
- if (this.typea != "") {
- this.typea = "";
- }
- }
- } else {
- if (this.typea == typeid) {
- this.typea = "";
- } else {
- this.typea = typeid;
- if (this.typeE.indexOf(ftypeId) != -1) {
- this.typeE.splice(this.typeE.indexOf(ftypeId), 1);
- }
- }
- }
- } else if (typeName == "类型") {
- if (type == 1) {
- if (this.typeE.indexOf(typeid) != -1) {
- this.typeE.splice(this.typeE.indexOf(typeid), 1);
- } else {
- this.typeE.push(typeid);
- if (this.typeb != "") {
- this.typeb = "";
- }
- }
- } else {
- if (this.typeb == typeid) {
- this.typeb = "";
- } else {
- this.typeb = typeid;
- if (this.typeE.indexOf(ftypeId) != -1) {
- this.typeE.splice(this.typeE.indexOf(ftypeId), 1);
- }
- }
- }
- }
- if(this.typea == "" && this.typeE.indexOf('e4cb3395-5602-4441-801c-f380e8935a74') == -1){
- this.typeE = []
- }
- this.getSource();
- },
- getSource() {
- this.loading = true
- let params = {
- uid: this.userid,
- oid: this.oid,
- org: this.org,
- typea: this.typea != undefined ? this.typea : "",
- typeb: this.typeb != undefined ? this.typeb : "",
- typeE: this.typeE.join(","),
- cn: this.sourceName,
- page: this.page,
- pageSize: this.pageSize,
- };
- this.ajax
- .get(this.$store.state.api + "selectSource", params)
- .then((res) => {
- this.loading = false
- this.res = res.data[0];
- this.total = res.data[0].length ? res.data[0][0].num : 0;
- })
- .catch((err) => {
- console.error(err);
- });
- },
- addSource() {
- this.courseTypeId2 = []
- this.s_title = ""
- this.s_url = ""
- this.s_detail = ""
- this.s_label = []
- this.updateType = 1
- this.dialogVisible = true
- },
- updateSource(item) {
- this.courseTypeId2 = item.typeid ? item.typeid.split(",") : []
- this.s_title = item.name
- this.s_url = item.url
- this.s_detail = item.detail
- this.s_label = item.label.split(",")
- this.updateType = 2
- this.updateId = item.id
- this.dialogVisible = true
- },
- add() {
- if (this.s_title == '') {
- this.$message.error('请填写工具名称')
- return
- }
- if (this.s_url == '') {
- this.$message.error('请填写网址来源')
- return
- }
- if (this.s_detail == '') {
- this.$message.error('请填写工具描述')
- return
- }
- let params = [{
- name: this.s_title,
- url: this.s_url,
- detail: this.s_detail,
- label: this.s_label.join(","),
- userid: this.userid,
- courseType: JSON.stringify(this.courseTypeId2)
- }]
- this.ajax
- .post(this.$store.state.api + "addSource", params)
- .then((res) => {
- this.$message({
- message: "添加成功",
- type: "success",
- });
- this.dialogVisible = false
- this.getSource();
- })
- .catch((err) => {
- this.$message.error("网络不佳");
- console.error(err);
- });
- },
- update() {
- if (this.s_title == '') {
- this.$message.error('请填写工具名称')
- return
- }
- if (this.s_url == '') {
- this.$message.error('请填写网址来源')
- return
- }
- if (this.s_detail == '') {
- this.$message.error('请填写工具描述')
- return
- }
- let params = [{
- id:this.updateId,
- name: this.s_title,
- url: this.s_url,
- detail: this.s_detail,
- label: this.s_label.join(","),
- userid: this.userid,
- courseType: JSON.stringify(this.courseTypeId2)
- }]
- this.ajax
- .post(this.$store.state.api + "updateSource", params)
- .then((res) => {
- this.$message({
- message: "修改成功",
- type: "success",
- });
- this.dialogVisible = false
- this.getSource();
- })
- .catch((err) => {
- this.$message.error("网络不佳");
- console.error(err);
- });
- }
- },
- created() {
- this.getSource();
- },
- };
- </script>
-
- <style scoped>
- .pb_head {
- display: flex;
- justify-content: space-between;
- }
- .student_head {
- margin-bottom: 20px;
- }
- .student_page {
- margin-top: 10px;
- }
- .pb_head {
- margin: 0 !important;
- width: 100% !important;
- }
- .bgColor {
- background: #466b99;
- }
- .reBox {
- background: #fff;
- margin: 0 auto;
- padding: 10px 5px;
- box-sizing: border-box;
- }
- .reTop {
- padding: 0 0 5px;
- /* padding: 20px 0 0 0; */
- /* border-bottom: 1px solid #eee; */
- display: flex;
- flex-direction: row;
- flex-wrap: nowrap;
- align-items: center;
- justify-content: space-between;
- }
- .reTop>div:nth-child(1) {
- font-weight: bold;
- /* width: 40px; */
- /* border-bottom: 1px solid #205cc6; */
- /* padding-bottom: 20px; */
- color: #205cc6;
- /* font-size: 20px; */
- }
- .reTop>div:nth-child(2) {
- display: flex;
- flex-direction: row;
- align-items: center;
- border: 1px solid #ccced3;
- width: 300px;
- border-radius: 8px;
- padding: 5px 0;
- /* margin-bottom: 10px; */
- background: #fafafa;
- }
- .search {
- width: 20px;
- padding: 0 5px;
- }
- .search>img {
- width: 100%;
- height: 100%;
- }
- .sInput {
- border: none;
- width: 85%;
- background: #fafafa;
- }
- .sInput:focus-visible {
- outline: none;
- }
- .typeCss {
- display: flex;
- flex-direction: row;
- flex-wrap: wrap;
- justify-content: flex-start;
- align-items: center;
- }
- .choose {
- display: flex;
- flex-direction: column;
- flex-wrap: nowrap;
- height: 100%;
- justify-content: space-evenly;
- align-items: flex-start;
- padding: 10px 0;
- }
- .all_choose {
- display: flex;
- flex-direction: row;
- align-items: baseline;
- margin: 2px 0;
- width: 100%;
- }
- .all_choose>span {
- min-width: 80px;
- display: block;
- letter-spacing: 14px;
- }
- .all_choose>span:nth-child(1) {
- font-weight: bold;
- }
- .cName {
- cursor: pointer;
- margin: 0 10px 5px 0;
- color: #b9b6b9;
- min-width: 80px;
- width: 80px;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .isCType {
- color: #6282c2;
- }
- .dialog_diy>>>.el-dialog {
- height: 100% !important;
- margin: 0 auto !important;
- }
- .dialog_diy>>>.el-dialog__header {
- background: #3c3c3c !important;
- padding: 15px 20px;
- }
- .dialog_diy>>>.el-dialog__title {
- color: #fff;
- }
- .dialog_diy>>>.el-dialog__headerbtn {
- top: 19px;
- }
- .dialog_diy>>>.el-dialog__headerbtn .el-dialog__close {
- color: #fff;
- }
- .dialog_diy>>>.el-dialog__headerbtn .el-dialog__close:hover {
- color: #fff;
- }
- .dialog_diy>>>.el-dialog__body,
- .dialog_diy>>>.el-dialog__footer {
- background: #fafafa;
- }
- .dialog_diy>>>.el-dialog__body {
- height: calc(100% - 125px);
- box-sizing: border-box;
- }
- .both {
- display: flex;
- flex-direction: row;
- flex-wrap: wrap;
- width: 100%;
- align-items: center;
- justify-content: flex-start;
- margin: 15px 0;
- }
- .all_choose2 {
- display: flex;
- flex-direction: row;
- align-items: flex-start;
- width: 100%;
- }
- .all_choose2>span {
- min-width: 100px;
- display: block;
- letter-spacing: 14px;
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
- }
- .all_choose2>span:nth-child(1) {
- font-weight: bold;
- }
- .all_choose2>>>.el-checkbox-group {
- display: flex;
- flex-direction: row;
- width: 100%;
- flex-wrap: wrap;
- align-content: center;
- justify-content: flex-start;
- align-items: center;
- margin-top: 3px;
- }
- .all_choose2>.el-checkbox-group>>>.el-checkbox {
- margin-bottom: 10px;
- display: flex;
- flex-direction: row;
- align-items: center;
- }
- .all_choose2>.el-checkbox-group>.el-checkbox>>>.el-checkbox__label {
- min-width: 80px;
- overflow: hidden;
- width: 80px;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- .all_choose2>.el-checkbox-group>.el-checkbox>>>.el-checkbox__label:hover {
- width: auto;
- }
- .choose2 {
- display: flex;
- flex-direction: column;
- flex-wrap: nowrap;
- height: 100%;
- justify-content: space-evenly;
- align-items: flex-start;
- }
- .add-box {
- height: 100%;
- overflow: auto;
- width: 100%;
- background: #fff;
- border-radius: 10px;
- box-sizing: border-box;
- padding: 20px;
- }
- .span-box {
- display: flex;
- margin-bottom: 20px;
- }
- .span-box>span {
- font-weight: bold;
- min-width: 100px;
- }
- .span-box>.input {
- width: 100%;
- }
- .type-box {
- width: 100%;
- }
- .student_table {
- display: flex;
- flex-wrap: wrap;
- }
- .source-box {
- width: calc(100% / 4 - 15px);
- background: #fff;
- overflow: hidden;
- margin: 0 20px 20px 0;
- display: flex;
- flex-direction: column;
- }
- .source-box:nth-child(4n){
- margin-right: 0;
- }
- .source-box .iamge {
- width: 150px;
- height: 125px;
- margin: 0 auto;
- }
- .source-box .iamge>img {
- width: 100%;
- height: 100%;
- }
- .fengmian{
- width: 100%;
- position: relative;
- }
- .fengmian>img{
- width: 100%;
- }
- .fengmian>.ftitle{
- position: absolute;
- bottom: 10%;
- color: rgb(88, 121, 198);
- width: 90%;
- text-align: center;
- font-weight: 700;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- font-size: 24px;
- left: 50%;
- transform: translateX(-50%);
- }
- .source-box .title {
- width: 90%;
- font-size: 18px;
- text-align: center;
- margin: 5px auto;
- font-weight: 700;
- overflow: hidden;
- white-space: nowrap;
- text-overflow: ellipsis;
- height:24px;
- }
- .source-box .detail {
- text-align: center;
- width: 90%;
- margin: 5px auto;
- color: #acacac;
- display: block;
- overflow: hidden;
- text-overflow: ellipsis;
- -o-text-overflow: ellipsis;
- display: -webkit-box;
- -webkit-line-clamp: 2;
- -webkit-box-orient: vertical;
- height: 42px;
- font-size: 15px;
- }
- .source-box .label {
- width: 90%;
- margin: 10px auto 5px;
- display: flex;
- flex-wrap: wrap;
- }
- .source-box .label>span {
- padding: 5px 10px;
- background: rgb(98, 180, 238);
- color: #fff;
- border-radius: 5px;
- margin: 0 0 5px 5px;
- }
- .source-box .button {
- width: 100%;
- text-align: center;
- display: flex;
- height: 40px;
- background: rgb(244, 244, 244);
- margin-top: auto;
- }
- .source-box .button>span {
- width: 100%;
- cursor: pointer;
- height: 100%;
- line-height: 40px;
- }</style>
-
|