TeacherDetailApe.js 8.4 KB
//*
// 老师模块
// */

import Loger from "../Loger";
import Ape from "./Ape";
import $ from "jquery";
import ClassDataProxy from "proxy/ClassDataProxy";

let loger = Loger.getLoger('PC-TeacherDetailApe');

const classifyList = `<div class="classifyList {_classifyListR}" data="1" id="{_id}">
                            <img class="curriculumListImg" src="{_msgImg}" alt="">
                            <p class="curriculumListTit">{_classroomTitle}</p>
                            <p class="curriculumListInfo">
                                <span class="curriculumListTime">{_schoolTime}</span>
                                <span class="curriculumListNum">{_subscribeNum}</span>
                            </p>
                        </div>`;

class TeacherDetailApe extends Ape {
    constructor() {
        super();
        this.classDateList = {};//课堂的所有数据
        this.isLocalStorage();
        this.addEvent();
        this.init();
    }

    init() {
        $('#collectYes').hide();

        $('#teacherBtn').on('click',this._teacherBtnHandler.bind(this));//推荐老师
        $('#teacherBtnMove').on('click',this._teacherBtnHandler.bind(this));//推荐老师

        $('#classifyListBox').on('click','.pageNumBtn',this._pageNumBtnHandler.bind(this));//点击翻页

    }

    addEvent() {

    }
    isLocalStorage(){
        if(ClassDataProxy.userType == ClassDataProxy.USER_TYPE_1){
            $('#myCenterBox').show();
        }
    }
    _teacherBtnHandler(evt){
        this._clearListContent();
        this._showLoadingImg();
        let _ele = $(evt.target);
        if(_ele.attr('data')){
            $('.header_listMsg').eq(_ele.attr('data')).addClass('header_listMsgCheck').siblings().removeClass('header_listMsgCheck');
        }
        $(evt.target).addClass('header_listMsgCheck').siblings().removeClass('header_listMsgCheck');
        this.studentClickTeacher();//学生点击老师模块
        this.detailPage();
    }
    //点击翻页
    _pageNumBtnHandler(evt){
        loger.log('点击翻页')
        let _ele = $(evt.target);
        let _url = ClassDataProxy.locationProtocol + ClassDataProxy.locationProt + '/meeting/getMeeting';
        let that = this;
        if(_ele.siblings().length > 0 && _ele.text()!= '...' ){
            _ele.addClass('pageNumBtnCheck').siblings().removeClass('pageNumBtnCheck');
            $.ajax({
                type: "POST",
                url: _url,
                timeout:5000,
                headers: {'page':_ele.text(),
                    siteId:ClassDataProxy.siteId,
                    'token':'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IlhXQnJlRU00T0swYTVqUUIyUTFicGtObHlxOUFWbXZkIiwibmFtZSI6ImFkbWluIiwiY29kZSI6MSwiaWF0IjoxNTAzNDUxODU0LCJleHAiOjIyODEwNTE4NTR9.3kTVzKd_jbP7l69nxOpNaFeSjVnnjZkagYMzRB8fjNo',
                },
                data:{siteId:ClassDataProxy.siteId},
                success:function(_data){
                    loger.log('点击翻页返回数据',_data)
                    if(_data != 200 ){
                        loger.warn(_data.returnData.data.msg)
                    }
                    that.classDateList = _data.returnData.data;
                    //切换列表内容
                    that._classDateContent(that.classDateList);
                },
                error:function(error){
                    //alert('老师翻页数据获取失败')
                    loger.log(error,'老师翻页数据获取失败')
                }
            })
        }else{
            return;
        }
    }
    detailPage(){
        let that = this;
        let _url = ClassDataProxy.locationProtocol + ClassDataProxy.locationProt + '/meeting/getMeeting';
        $.ajax({
            type: "POST",
            url: _url,
            timeout:5000,
            headers: {siteId:ClassDataProxy.siteId,
                userType : 1,
                'token':'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IlhXQnJlRU00T0swYTVqUUIyUTFicGtObHlxOUFWbXZkIiwibmFtZSI6ImFkbWluIiwiY29kZSI6MSwiaWF0IjoxNTAzNDUxODU0LCJleHAiOjIyODEwNTE4NTR9.3kTVzKd_jbP7l69nxOpNaFeSjVnnjZkagYMzRB8fjNo'},
            data:{siteId:ClassDataProxy.siteId},
            success:function(_data){
                //获取课堂数据
                if(_data && _data.code == 200){
                    that._gainClassData(_data);
                }

            },
            error:function(error){
              //  alert('老师界面获取数据失败')
                that._gainClassDataErr();
                loger.log(error,'老师界面获取数据失败')
            }
        })
    }
    _gainClassDataErr(){
        let classifyListContent = $('#classifyListContent');
        classifyListContent.empty();
        let _classifyList = '<div class="dataErrorTitle">数据获取失败~</div>'
        classifyListContent.append(_classifyList)
    }
    //清除列表数据
    _clearListContent(){
        let classifyListContent = $('#classifyListContent');
        classifyListContent.empty();
        let classifyListTitle = $('#classifyListTitle');
        classifyListTitle.empty();
        let pageNumContentBox = $('#pageNumContentBox');
        pageNumContentBox.empty();
    }
    //列表显示loading
    _showLoadingImg(){
        let loadingImg = `<img class="loadingImg" src="images/loading.gif" alt="">`;
        $('#classifyListContent').append(loadingImg);
    }
    _gainClassData(_data){
        this.classDateList = _data.returnData.data;
        this._clearListContent();
        //切换列表分类的标题
        this._classDateTitle();
        //切换列表内容
        this._classDateContent(this.classDateList);
        //页码
        this._classDatepageNum(this.classDateList);
    }
    _classDateTitle(){
        $('#classifyListTitle').html($('#teacherTitle').html());
    }
    _classDateContent(_data){
        let classifyListContent = $('#classifyListContent');
        classifyListContent.empty();
        let _dataList = _data.meetingInfo;
        for(let i = 0;i<_dataList.length;i++){
            let j = (i%4)==3;
            let _getTime = ClassDataProxy.getTimeDifference(_dataList[i].beginTime,_dataList[i].endTime)
            let _classifyList = this._format(classifyList,{
                _classifyListR : j?'classifyListR':'',
                _id : _dataList[i].id,
                _msgImg :'../images/u373.png',
                _classroomTitle : _dataList[i].meetingName,
                _schoolTime : _getTime,
                _subscribeNum : '27人已预约'
            })
            classifyListContent.append(_classifyList);
        }
    }
    _classDatepageNum(_data){ //page
        let _pageContent = _data.count;
        let _pageNum = Math.ceil(_pageContent / _data.pageno);

        this.pagingConstruct(1,_pageNum);
    }
    pagingConstruct(paging,total){
        let pageNumContentBox = $('#pageNumContentBox');
        pageNumContentBox.empty();
        let pagingDivInnerHTML = '<div class="pageNumContent">';
        let isHiddenExist = 0;
        for(let i =1 ;i<=total;i++){
            if(i == paging){
                pagingDivInnerHTML +='<span class="pageNumBtn pageNumBtnCheck">'+i+'</span>';
            }else{
                if (i < 4 || i < (paging + 4) && i > (paging - 2) && i < (total / 2 + 2) || i > (total - 2)) {
                    pagingDivInnerHTML +='<span class="pageNumBtn">'+i+'</span>';
                    isHiddenExist = 0;
                }else{
                    if(isHiddenExist == 0){
                        pagingDivInnerHTML += '<span class="pageNumBtn">...</span>';
                        isHiddenExist = 1;
                    }
                }
            }
        }
        pagingDivInnerHTML += '</div>';
        pageNumContentBox.append(pagingDivInnerHTML);
    }
    _teacherHome(){
        $('#slideshow').hide();
        $('#defaultBox').hide();
        $('.curriculumBox').hide();
        $('#header_list').show();
        $('#header_seek').show();
        $('#androidDownload').show();
        $('#classManagementBox').hide();
        $('#classifyListBox').show();
    }
    //学生点击老师模块
    studentClickTeacher(){
        $('#slideshow').hide();
        $('#defaultBox').hide();
        $('.curriculumBox').hide();
        $('#classifyListBox').show();
        $('#teacherDetailBox').hide();
        $('#lanclassBox').hide();
        $('#myCenterBox').hide();
    }

    //工具类
    _format(str, obj) {
        return str.replace(/\{(\w+)\}/g, function (match, group, index) {
            return obj[group];
        });
    };
}
export default TeacherDetailApe;