HomeApe.js 6.1 KB
//*
// 首页模块
// */

import Loger from "../Loger";
import Ape from "./Ape";
import $ from "jquery";
import ClassDataProxy from "proxy/ClassDataProxy";
import MessageTypes from "../MessageTypes";
const classifyList = `<div class="classifyList {_classifyListR}" 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>`;

const teacherList = `<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>`;
let loger = Loger.getLoger('PC-HomeApe');
class HomeApe extends Ape {
    constructor() {
        super();
        this.classDateList = {};//课堂的所有数据
        //判断列表在右侧时取消边距
        this._judgeListPlace();
        this.isLocalStorage();
        this.addEvent();
        this.init();
    }

    init() {
        $('#defaultBtn').on('click',this._lanclassBtnHandler.bind(this));

    }

    addEvent() {

    }
    isLocalStorage(){
        $('#myCenterBox').hide();
        this.detailPage();
    }
    _judgeListPlace(){
        let i;
        let curriculumList = document.getElementsByClassName('curriculumList');
        for(i=0;i<curriculumList.length;i++){
            if((i%4) == 3){
                $(curriculumList[i]).addClass('classifyListR');
            }
        }
    }
    _lanclassBtnHandler(evt){
        loger.log('首页',ClassDataProxy.userType)
        $(evt.target).addClass('header_listMsgCheck').siblings().removeClass('header_listMsgCheck');
        this.studentClick();
    }
    detailPage(){
        let that = this;
        let _url = ClassDataProxy.locationProtocol + ClassDataProxy.locationProt + '/meeting/getMeeting';
        $.ajax({
            type: "POST",
            url: _url,
            data:{siteId:ClassDataProxy.siteId},
            headers: {siteId:ClassDataProxy.siteId,
                'token':'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6IlhXQnJlRU00T0swYTVqUUIyUTFicGtObHlxOUFWbXZkIiwibmFtZSI6ImFkbWluIiwiY29kZSI6MSwiaWF0IjoxNTAzNDUxODU0LCJleHAiOjIyODEwNTE4NTR9.3kTVzKd_jbP7l69nxOpNaFeSjVnnjZkagYMzRB8fjNo'},
            success:function(_data){
                // loger.log(_data,'成功')
                //获取课堂数据
                if(_data && _data.code == 200){
                    that._gainClassData(_data.returnData.data);
                }
            },
            error:function(error){
                //alert('首页数据获取失败')
                that._gainClassDataErr();
                console.log(error,'首页数据获取失败')
            }
        })
    }
    studentClick(){
        $('#slideshow').show();
        $('#defaultBox').show();
        $('.curriculumBox').show();
        $('#classifyListBox').hide();
        $('#teacherDetailBox').hide();
        $('#lanclassBox').hide();
        $('#myCenterBox').hide();
    }
    _gainClassData(_data){
        let liveList = $('#liveList');
        let lanclassList = $('#lanclassList');
        let teacherIntro = $('#teacherIntro');
        liveList.empty();
        lanclassList.empty();
        teacherIntro.empty();
        if(_data){
        let _dataList = _data.meetingInfo;
            //直播互动
            for(let i = 0;i<_dataList.length;i++){
                if(i<8){
                    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 : _dataList[i].reservationNumber+'人预约'
                    })
                    liveList.append(_classifyList);
                    lanclassList.append(_classifyList);
                }
            }
            //老师
            for(let i = 0;i<_dataList.length;i++){
                if(i<8){
                    let j = (i%4)==3;
                    let _getTime = ClassDataProxy.getTimeDifference(_dataList[i].beginTime,_dataList[i].endTime)
                    let _classifyList = this._format(teacherList,{
                        _classifyListR : j?'classifyListR':'',
                        _id : _dataList[i].id,
                        _msgImg :'../images/u373.png',
                        _classroomTitle : _dataList[i].create_user,
                        _schoolTime :  _getTime,
                        _subscribeNum : _dataList[i].reservationNumber+'人预约'
                    })
                    teacherIntro.append(_classifyList);
                }
            }
        }

    }
    _gainClassDataErr(){
        let liveList = $('#liveList');
        let lanclassList = $('#lanclassList');
        let teacherIntro = $('#teacherIntro');
        liveList.empty();
        lanclassList.empty();
        teacherIntro.empty();

        let _classifyList = '<div class="dataHomeErrorTitle">数据获取失败~</div>'
        liveList.append(_classifyList)
        lanclassList.append(_classifyList)
        teacherIntro.append(_classifyList)
    }
    //工具类
    _format(str, obj) {
        return str.replace(/\{(\w+)\}/g, function (match, group, index) {
            return obj[group];
        });
    };
}
export default HomeApe;