/**
* Sample React Native App
* https://github.com/facebook/react-native
*
* @format
* @flow
*/
import React, { Component } from 'react';
import {
StyleSheet,
Text,
View,
Image,
TouchableOpacity,
ImageBackground,
ToastAndroid,
BackHandler,
StatusBar,
DeviceEventEmitter
} from 'react-native';
import BasePage from './BasePage';
import CourseTitle from '../pages/components/CourseTitle';
import ChosePhoto from '../pages/components/ChosePhoto';
import RegionModal from '../pages/components/RegionModal';
import BirthdayModal from '../pages/components/BirthdayModal';
import GradeSelectionModal from '../pages/components/GradeSelectionModal';
import PersonalInfoDialog from '../pages/components/PersonalInfoDialog';
import http_user from './services/user';
import wechat from './utils/wechat';
import commonutil from './utils/commonutil';
type Props = {};
export default class PersonalInfo extends BasePage {
state = {
ready: false,
file_user_data: new Map(),
user_nickName: '未设置',
schoolName: '未设置',
provinceName: '未设置',
citys: '',
grade_text: '七年级',
grade_index: 6,
birthday_year: 0,
birthday_month: 0,
birthday_day: 0,
birthday_time: 0,
photo_uri: require('./images/userInfo/default_photo.png'),
phone: '',
phone_bind_result: false,
phone_bind_type: 1, //1是绑定,2是修改
phone_bind_color: 'red',
wechat_nickName: '',
wechat_bind_color: 'red',
show_bind_phone: false
};
render() {
if (!this.state.ready) {
return null;
}
return (
(this.dialog = view)}
style={{ height: 10000 }}
updateParentState={this.updateState.bind(this)}
/>
(this.chosephoto = view)} photoback={this.photoback.bind(this)} />
(this.regionmodal = view)}
cityscommit={this.cityscommit.bind(this)}
provinceName={this.state.provinceName}
citys={this.state.citys}
/>
(this.gradeselectionModal = view)}
commitGrade={this.commitGrade.bind(this)}
grade_index={this.state.grade_index}
/>
(this.birthdaymodal = view)}
birthdaycommit={this.birthdaycommit.bind(this)}
year={this.state.birthday_year}
month={this.state.birthday_month}
day={this.state.birthday_day}
/>
this.arrowpress(0)}
>
修改头像
{this.getArraowImg(0)}
this.arrowpress(1)}
>
{this.choseheadericon(1)}
昵称
{this.state.user_nickName}
{this.getArraowImg(1)}
this.arrowpress(2)}
>
{this.choseheadericon(2)}
生日
{this.state.birthday_time}
{this.getArraowImg(2)}
this.arrowpress(3)}
>
{this.choseheadericon(3)}
所在地区
{this.state.provinceName}-{this.state.citys}
{this.getArraowImg(3)}
this.arrowpress(4)}
>
{this.choseheadericon(4)}
我的学校
{this.state.schoolName}
{this.getArraowImg(4)}
{/* this.arrowpress(5)}
>
{this.choseheadericon(5)}
我的年级
{this.state.grade_text}
{this.getArraowImg(5)}
*/}
this.arrowpress(6)}
>
{this.choseheadericon(6)}
我的手机号
{this.state.phone}
{this.getArraowImg(6)}
this.arrowpress(7)}
>
{this.choseheadericon(7)}
我的微信
{this.state.wechat_nickName}
{this.getArraowImg(4)}
this.logout()}
>
退出登录
{/* */}
);
}
componentWillMount() {
//获取用户信息
this.getUserInfo();
BackHandler.addEventListener('hardwareBackPress', this.onBackAndroid);
}
componentWillUnmount() {
BackHandler.removeEventListener('hardwareBackPress', this.onBackAndroid);
}
async getUserInfo() {
let userinfo = await global.storage
.load({
key: 'userInfo'
})
.then((result) => {
this.state.file_user_data = commonutil.jsonToMap(result);
var time = this.formaterDate(this.state.file_user_data.get('birthday'));
this.setState({
schoolName:
this.state.file_user_data.get('school') === ''
? '未设置'
: this.state.file_user_data.get('school'),
provinceName:
this.state.file_user_data.get('province') === ''
? '未设置'
: this.state.file_user_data.get('province'),
citys: this.state.file_user_data.get('city') === '' ? '未设置' : this.state.file_user_data.get('city'),
phone: this.state.file_user_data.get('mobile'),
wechat_nickName: this.state.file_user_data.get('wechat_nickName'),
user_nickName: this.state.file_user_data.get('nickName'),
birthday_time: time
});
if (this.state.file_user_data.get('avatar').length > 0) {
this.setState({
photo_uri: {
uri: this.state.file_user_data.get('avatar')
}
});
}
if (this.state.phone == null || this.state.phone === '') {
this.setState({
phone_bind_color: 'red',
phone_bind_type: 1,
phone: '未绑定'
});
} else {
this.setState({
phone_bind_color: 'rgba(113, 113, 113, 1)',
phone_bind_type: 2
});
}
if (this.state.wechat_nickName == null || this.state.wechat_nickName === '') {
this.setState({
wechat_bind_color: 'red',
wechat_nickName: '未绑定'
});
} else {
this.setState({
wechat_bind_color: 'rgba(113, 113, 113, 1)'
});
}
this.setState({
ready: true
});
})
.catch((err) => {
console.log('PersonalInfo:ERROR' + err.message);
});
}
onBackAndroid = () => {
if (this.state.show_bind_phone) {
this.setState({
show_bind_phone: false
});
} else {
this.goBack();
}
return true;
};
getArraowImg(type) {
return (
this.arrowpress(type)}
>
);
}
choseheadericon(type) {
let headerpath;
switch (type) {
case 0:
headerpath = require('./images/userInfo/headportrait.png');
break;
case 1:
headerpath = require('./images/userInfo/nickname.png');
break;
case 2:
headerpath = require('./images/userInfo/birthday.png');
break;
case 3:
headerpath = require('./images/userInfo/location.png');
break;
case 4:
headerpath = require('./images/userInfo/school.png');
break;
case 5:
headerpath = require('./images/userInfo/grade.png');
break;
case 6:
headerpath = require('./images/userInfo/phone.png');
break;
case 7:
headerpath = require('./images/userInfo/wechat.png');
break;
}
// alert(headerpath);
return (
);
}
arrowpress(type) {
switch (type) {
case 0:
this.chosephoto.setModalVisible(true);
break;
case 1:
this.dialog.setInfo('修改昵称', '昵称');
this.dialog.setModalVisible(true, 1);
break;
case 2:
// alert("生日");
this.birthdaymodal.setModalVisible(true);
break;
case 3:
this.regionmodal.setModalVisible(true);
break;
case 4:
this.dialog.setInfo('我的学校', '学校名称');
this.dialog.setModalVisible(true, 2);
break;
case 5:
this.gradeselectionModal.setModalVisible(true);
break;
//手机号
case 6:
if (this.state.phone === '未绑定') {
this.props.navigation.navigate('PhoneBind', {
type: this.state.phone_bind_type,
bind_phone_back: this.bind_phone_back.bind(this)
});
}
break;
//微信
case 7:
wechat.wechatLogin((result) => {
let opts = {
method: 'PUT',
body: {
openId: result['openid'],
unionId: result['unionid'],
avatar: '',
sex: result['sex'],
nickName: result['nickname']
}
};
http_user.bind_wechat(opts).then((res) => {
if (res.code == 200) {
this.setState({
wechat_nickName: res['nickname'],
wechat_bind_color: 'rgba(113, 113, 113, 1)'
});
} else {
ToastAndroid.show(res.message, ToastAndroid.SHORT);
}
});
});
break;
}
}
logout() {
//清空存储的用户信息
global.storage.remove({ key: 'userInfo' });
this.clearPageToNext('Login');
}
updateState(input_text, type) {
if (type == 1) {
this.setState({ user_nickName: input_text });
this.updateUserInfo({ nickName: input_text });
} else if (type == 2) {
this.setState({ schoolName: input_text });
this.updateUserInfo({ school: input_text });
}
}
cityscommit(provinces_name, citys_name) {
this.setState({
provinceName: provinces_name,
citys: citys_name
});
this.updateUserInfo({ province: provinces_name, city: citys_name });
}
commitGrade(text, index) {
this.setState({
grade_text: text,
grade_index: index
});
this.updateUserInfo({ grade: index + 1 });
}
birthdaycommit(year, month, day) {
this.setState({
birthday_time: year + '年' + month + '月' + day + '日'
});
var date = new Date(year + '-' + month + '-' + day);
this.updateUserInfo({ birthday: date });
}
photoback(photo_uri) {
if (photo_uri == undefined || photo_uri === '' || photo_uri == null) {
return;
}
this.upload_head(photo_uri);
}
updateUserInfo(object) {
let opts = {
method: 'PUT', //请求方法
body: object //请求体
};
http_user.update_UserInfo(opts).then((res) => {
this.update_file_userinfo(this.state.file_user_data, res);
this.saveUserInfo(commonutil.mapToJson(this.state.file_user_data));
});
}
bind_phone_back(phone_num, result) {
if (result == true) {
ToastAndroid.show('修改成功', ToastAndroid.SHORT);
this.setState({
phone: phone_num,
phone_bind_result: result,
show_bind_phone: true
});
} else {
// ToastAndroid.show('修改失败', ToastAndroid.SHORT);
}
}
personinfoback() {
// this.props.navigation.state.params.infoback();
DeviceEventEmitter.emit('infoback');
this.props.navigation.goBack();
}
formaterDate(date) {
var date = new Date(date);
var Y = date.getFullYear() + '';
var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '';
var D = (date.getDate() < 10 ? '0' + date.getDate() : date.getDate()) + ' ';
this.setState({
birthday_year: Y,
birthday_month: M,
birthday_day: D
});
return Y + '-' + M + '-' + D;
}
upload_head(file_path) {
//上传成功但是没拿到数据
http_user.uploadImage(file_path).then((res) => {
//请求成功
if (res.code == 200) {
this.setState({
photo_uri: { uri: res.data }
});
this.updateUserInfo({ avatar: res.data });
} else {
alert('上传失败:' + res.message);
}
});
}
update_file_userinfo(map, res) {
map.set('ageGroup', res.data.ageGroup);
map.set('avatar', res.data.avatar);
map.set('birthday', res.data.birthday);
map.set('channel', res.data.channel);
map.set('city', res.data.city);
map.set('country', res.data.country);
map.set('eid', res.data.eid);
map.set('gmtCreated', res.data.gmtCreated);
map.set('gmtModified', res.data.gmtModified);
map.set('mobile', res.data.mobile);
map.set('nickName', res.data.nickName);
map.set('province', res.data.province);
map.set('school', res.data.school);
map.set('sex', res.data.sex);
map.set('status', res.data.status);
map.set('uid', res.data.uid);
}
}
class BindPhoneSuccess extends BasePage {
render() {
if (this.props.show) {
return (
);
} else {
return null;
}
}
}
const styles = StyleSheet.create({
item: {
flex: 1,
width: '100%',
flexDirection: 'row',
backgroundColor: 'white',
marginTop: 1,
backgroundColor: 'red'
},
item_text: {
flex: 3,
textAlignVertical: 'center',
color: 'black',
fontSize: 16
}
});