/** * 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 } 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)} 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.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: 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() { //清空存储的用户信息 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.setState({ photo_uri: { uri: photo_uri } }); } updateUserInfo(object) { let opts = { method: "PUT", //请求方法 body: object //请求体 }; http_user.update_UserInfo(opts).then(res => { this.state.file_user_data.set("ageGroup", res.data.ageGroup); this.state.file_user_data.set("avatar", res.data.avatar); this.state.file_user_data.set("birthday", res.data.birthday); this.state.file_user_data.set("channel", res.data.channel); this.state.file_user_data.set("city", res.data.city); this.state.file_user_data.set("country", res.data.country); this.state.file_user_data.set("eid", res.data.eid); this.state.file_user_data.set("gmtCreated", res.data.gmtCreated); this.state.file_user_data.set("gmtModified", res.data.gmtModified); this.state.file_user_data.set("mobile", res.data.mobile); this.state.file_user_data.set("nickName", res.data.nickName); this.state.file_user_data.set("province", res.data.province); this.state.file_user_data.set("school", res.data.school); this.state.file_user_data.set("sex", res.data.sex); this.state.file_user_data.set("status", res.data.status); this.state.file_user_data.set("uid", res.data.uid); 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(); 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; } } 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 } });