You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
educoder/public/react/src/modules/user/InterestpageMax.js

283 lines
8.0 KiB

import React, { Component } from 'react';
import { Button, notification } from 'antd';
import { broadcastChannelPostMessage } from 'educoder';
import MyEduCoderModal from './MyEduCoderModal';
// import Notcompleted from '../../common/Notcompleted';
import axios from 'axios';
import './commontwo.css';
import mytc from './img/mytc.png';
import skzbdx from './img/skzbdx.png';
import zyrs1 from './img/zyrs1.png';
import gouxuan from './img/gouxuan.png';
import meigouxuan from './img/meigouxuan.png';
import qdkf from './img/qdkf.png';
import hdkf from './img/hdkf.png';
import ydkf from './img/ydkf.png';
import sjk from './img/sjk.png';
import ysj from './img/ysj.png';
import yunwei from './img/yunwei.png';
import rgzn from './img/rgzn.png';
import qita from './img/qita.png';
//父组件 EducoderLogin.js
class InterestpageMax extends Component {
constructor(props) {
super(props)
this.state = {
gouxuans: "",
gouxuans2: 0,
gouxuans4: [],
namezh: this.props.namezh,
passmm: this.props.passmm,
homedatalist: undefined,
hometypepvisible: undefined,
MyEduCoderModals: false
}
}
openNotification = (messge) => {
// type 1 成功提示绿色 2提醒颜色黄色 3错误提示红色
notification.open({
message: "提示",
description: messge,
onClick: () => {
console.log('Notification Clicked!');
},
});
}
componentDidMount() {
console.log("max");
let { gouxuans4 } = this.state;
let url = `/repertoires.json`;
axios.get(url).then((response) => {
if (response) {
console.log("53");
console.log(response.data);
for (var i = 0; i < response.data.repertoires.length; i++) {
var qdkfys = "";
if (response.data.repertoires[i].id === 1) {
qdkfys = qdkf;
} if (response.data.repertoires[i].id === 2) {
qdkfys = hdkf;
} if (response.data.repertoires[i].id === 3) {
qdkfys = ydkf;
} if (response.data.repertoires[i].id === 4) {
qdkfys = sjk;
} if (response.data.repertoires[i].id === 5) {
qdkfys = ysj;
} if (response.data.repertoires[i].id === 6) {
qdkfys = yunwei;
} if (response.data.repertoires[i].id === 8) {
qdkfys = qita;
} if (response.data.repertoires[i].id === 9) {
qdkfys = rgzn;
}
if (response.data.repertoires[i].id === 1) {
var datas = {
id: response.data.repertoires[i].id,
name: response.data.repertoires[i].name,
bool: true,
url: qdkfys
};
} else {
var datas = {
id: response.data.repertoires[i].id,
name: response.data.repertoires[i].name,
bool: false,
url: qdkfys
};
}
gouxuans4.push(datas);
this.setState({
gouxuans4: gouxuans4,
})
}
console.log("75");
console.log(gouxuans4);
}
}).catch((error) => {
console.log(error)
});
}
componentWillReceiveProps(nextProps) {
// console.log("46");
// console.log(nextProps);
// console.log(this.props);
if (nextProps.namezh != this.props.namezh) {
// console.log("50");
// console.log(nextProps.user);
if (nextProps.namezh !== undefined) {
// console.log("53");
// console.log(nextProps.user);
this.setState({
namezh: nextProps.namezh,
})
}
}
if (nextProps.passmm != this.props.passmm) {
// console.log("50");
// console.log(nextProps.user);
if (nextProps.passmm !== undefined) {
// console.log("53");
// console.log(nextProps.user);
this.setState({
passmm: nextProps.passmm,
})
}
}
}
Clickteacher = (e) => {
console.log(e);
if (e === "teacher") {
this.setState({
gouxuans: "teacher",
})
} else if (e === "student") {
this.setState({
gouxuans: "student",
})
} else if (e === "professional") {
this.setState({
gouxuans: "professional",
})
}
}
Clickteacher2 = (e) => {
console.log(e);
let { gouxuans4 } = this.state;
for (var i = 0; i < gouxuans4.length; i++) {
if (gouxuans4[i].id === e) {
console.log("51");
console.log(e);
if (gouxuans4[i].bool === true) {
gouxuans4[i].bool = false;
} else {
gouxuans4[i].bool = true;
}
}
}
console.log(gouxuans4);
this.setState({
gouxuans4: gouxuans4,
})
}
setMyEduCoderModals = () => {
this.setState({
MyEduCoderModals: true
})
}
//兴趣页面点击
Interestcompletionpage() {
if (this.state.gouxuans.length === 0) {
this.openNotification("请选择职业");
return
}
var ints = [];
for (var i = 0; i < this.state.gouxuans4.length; i++) {
if (this.state.gouxuans4[i].bool === true) {
ints.push(this.state.gouxuans4[i].id);
}
}
console.log("200200");
console.log(ints);
if (ints.length < 1) {
this.openNotification("请至少选择一个您感兴趣的内容");
return
}
var url = "/users/interest.json";
axios.post(url, {
identity: this.state.gouxuans,
interest_ids: ints,
}).then((response) => {
if (response !== undefined) {
// this.Jumptotheinterestpage();
// window.location.href = "/"
if (response.data.status === 0) {
this.setMyEduCoderModals()
}
}
}).catch((error) => {
console.log(error);
})
}
setNotcompleteds = () => {
this.setState({
Notcompleteds: true,
MyEduCoderModals: false
})
}
render() {
const {
gouxuans,
gouxuans4,
} = this.state
// height: 346px;
return (
<div className="ysllogin_register_contents2" style={{ width: "800px", height: "550px" }}>
<MyEduCoderModal
modalsType={this.state.MyEduCoderModals}
setNotcompleteds={() => { this.setNotcompleteds() }}
/>
<div className="ysllogin_section2">
<div className="mt15"><span className="yslspans12">请选择你的职业</span></div>
<div className="ysldivhome12" >
<div className="ysldivhomediv222" style={{ marginLeft: "30px" }} >
<div className="ysldivhomedivtxt2" onClick={() => this.Clickteacher("teacher")}>{gouxuans === "teacher" ? <img src={gouxuan} className="gouxuanimg2" /> : <img className="gouxuanimg2" src={meigouxuan} />}老师</div>
<div className="ysldivhomedivimg2" ><img onClick={() => this.Clickteacher("teacher")} src={skzbdx} className="ysldivhomedivimg2" /></div>
</div>
<div className="ysldivhomediv222" style={{ marginLeft: "101px", marginRight: "101px" }}>
<div className="ysldivhomedivtxt2" onClick={() => this.Clickteacher("student")}>{gouxuans === "student" ? <img src={gouxuan} className="gouxuanimg2" /> : <img className="gouxuanimg2" src={meigouxuan} />}学生</div>
<div className="ysldivhomedivimg2"><img onClick={() => this.Clickteacher("student")} src={mytc} className="ysldivhomedivimg2" /></div>
</div>
<div className="ysldivhomediv222" >
<div className="ysldivhomedivtxt2" onClick={() => this.Clickteacher("professional")}>{gouxuans === "professional" ? <img src={gouxuan} className="gouxuanimg2" /> : <img className="gouxuanimg2" src={meigouxuan} />}专业人士</div>
<div className="ysldivhomedivimg2"><img onClick={() => this.Clickteacher("professional")} src={zyrs1} className="ysldivhomedivimg2" /></div>
</div>
</div>
<div><span className="yslspans22">选择你可能感兴趣的内容</span></div>
<div ><span className="yslspans32">基于你关注的内容推荐</span></div>
<div className="ysldivhome22">
{gouxuans4 && gouxuans4.map((item, key) => {
return (
<div className={item.id < 5 ? "ysldivhomediv12" : "ysldivhomediv22"} onClick={() => this.Clickteacher2(item.id)}>
{item.bool === true ? <img src={gouxuan} className="yslgouxuanimg22x" /> : <div className="yslgouxuanimg22x"></div>}
<img className="div1img2" src={item.url} />
<span className="textall2">{item.name}</span>
</div>
)
})}
</div>
<Button className="yslbutton2" size={"large"} type="primary" onClick={() => this.Interestcompletionpage()} style={{ width: "255px", height: "35px", background: "#4CACFF", marginTop: "17px" }}>完成</Button>
</div>
</div>
);
}
}
export default (InterestpageMax);