/**
* Sample React Native App
* https://github.com/facebook/react-native
*
* @format
* @flow
*/
import React, { Component } from 'react';
import {
Platform,
StyleSheet,
Text,
View,
Image,
TouchableOpacity,
ImageBackground,
ToastAndroid,
BackHandler,
StatusBar,
Modal
} 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 { NavigationActions, StackActions } from 'react-navigation';
import asyncStorage from './utils/asyncStorage';
import http_user from './services/user';
import wechat from './utils/wechat';
type Props = {};
export default class PersonalInfo extends BasePage {
state = {
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: '',
wechat_nickName: '',
wechat_bind_color: '',
show_bind_phone: false
};
render() {
return (
(this.dialog = view)}
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.goBack()}
/>
this.arrowpress(0)}
>
修改头像
{this.getArraowImg(0)}
this.arrowpress(1)}
>
{this.choseheadericon(1)}
昵称
{this.state.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() {
var date = new Date();
var year = date.getFullYear().toString();
var month = (date.getMonth() + 1).toString();
var day = date.getDate().toString();
this.setState({
birthday_year: year,
birthday_month: month,
birthday_day: day,
birthday_time: year + '年' + month + '月' + day + '日'
});
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)'
});
}
BackHandler.addEventListener('hardwareBackPress', this.onBackAndroid);
}
componentWillUnmount() {
BackHandler.removeEventListener('hardwareBackPress', this.onBackAndroid);
}
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:
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) => {
console.log('openid:' + result['openid']);
console.log('unionid:' + result['unionid']);
console.log('nickname:' + result['nickname']);
console.log('sex:' + result['sex']);
console.log('avatar:' + result['province'] + result['city']);
let opts = {
method: 'PUT',
body: {
openId: result['openid'],
unionId: result['unionid'],
avatar: result['province'] + result['city'],
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() {
const resetAction = StackActions.reset({
index: 0,
actions: [
NavigationActions.navigate({ routeName: 'Login' }) //要跳转到的页面名字
]
});
this.props.navigation.dispatch(resetAction);
}
updateState(input_text, type) {
if (type == 1) {
this.setState({ 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.setState({
photo_uri: { uri: photo_uri }
});
}
updateUserInfo(object) {
let opts = {
method: 'PUT', //请求方法
body: object //请求体
};
http_user.update_UserInfo(opts).then((res) => {
console.log(res);
});
}
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);
}
}
}
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
}
});