twister-react/jsx/common/ProfileMixin.js

103 lines
2.6 KiB
JavaScript
Raw Normal View History

2015-04-30 11:22:58 +02:00
var AppSettingsMixin = require('../common/AppSettingsMixin.js');
2016-01-06 13:12:24 +01:00
var EventListenerMixin = require('../common/EventListenerMixin.js');
2015-04-30 11:22:58 +02:00
2015-04-29 11:19:10 +02:00
module.exports = ProfileMixin = {
2016-01-06 13:12:24 +01:00
mixins: [
AppSettingsMixin,
EventListenerMixin('profileupdatebyuser'),
EventListenerMixin('avatarupdatebyuser'),
],
onprofileupdatebyuser: function(event){
//console.log("catched event",this.state.username,event.detail)
var profile =event.detail;
if(profile.getUsername()==this.state.username){
this.setState(function(state){
state.fullname = profile.getField("fullname");
state.bio = profile.getField("bio");
state.location = profile.getField("location");
state.url = profile.getField("url");
return state;
})
}
},
onavatarupdatebyuser: function(event){
//console.log("catched event",this.state.username,event.detail)
var avatar =event.detail;
if(avatar.getUsername()==this.state.username){
this.setState(function(state){
state.avatar = avatar.getUrl();
return state;
})
}
},
2015-04-29 11:19:10 +02:00
getInitialState: function() {
2016-01-23 15:44:15 +01:00
2015-04-29 11:19:10 +02:00
var username = this.props.username;
if (!username) {
2016-01-23 15:44:15 +01:00
username = (this.props.params.username ? this.props.params.username : this.props.activeAccount);
2015-04-29 11:19:10 +02:00
}
var state = {
username: username,
avatar: "img/genericPerson.png",
fullname: "",
bio: "",
location: "",
url: ""
};
var profile = Twister.getUser(username).getProfile();
if (profile.inCache()) {
state.fullname = profile.getField("fullname");
state.bio = profile.getField("bio");
state.location = profile.getField("location");
state.url = profile.getField("url");
}
var avatar = Twister.getUser(username).getAvatar();
if (avatar.inCache()) {
state.avatar = avatar.getUrl();
}
return state;
},
updateProfile: function () {
var thisComponent = this;
Twister.getUser(this.state.username).doAvatar(function(avatar){
if (avatar.getUrl()) {
thisComponent.setStateSafe({avatar: avatar.getUrl()});
}
});
Twister.getUser(this.state.username).doProfile(function(profile){
thisComponent.setStateSafe({
fullname: profile.getField("fullname"),
bio: profile.getField("bio"),
location: profile.getField("location"),
url: profile.getField("url"),
});
});
},
componentDidMount: function () {
this.updateProfile();
2015-04-30 11:22:58 +02:00
this.setInterval(this.updateProfile,this.state.appSettings.pollIntervalProfile*1000);
2015-04-29 11:19:10 +02:00
}
};