AppsDrawer: Populate apps from room state
This commit is contained in:
parent
e2759774fc
commit
a72cb794f2
1 changed files with 74 additions and 81 deletions
|
@ -17,107 +17,100 @@ limitations under the License.
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
const React = require('react');
|
const React = require('react');
|
||||||
|
const MatrixClientPeg = require('../../../MatrixClientPeg');
|
||||||
const AddAppDialog = require('../dialogs/AddAppDialog');
|
const AddAppDialog = require('../dialogs/AddAppDialog');
|
||||||
const AppTile = require('../elements/AppTile');
|
const AppTile = require('../elements/AppTile');
|
||||||
const Modal = require("../../../Modal");
|
const Modal = require("../../../Modal");
|
||||||
|
const dis = require('../../../dispatcher');
|
||||||
// FIXME -- Hard coded widget config
|
|
||||||
const roomWidgetConfig = {
|
|
||||||
// Cooking room
|
|
||||||
'!IAkkwswSrOSzPRWksX:matrix.org': [
|
|
||||||
{
|
|
||||||
id: "youtube",
|
|
||||||
url: "https://www.youtube.com/embed/ZJy1ajvMU1k?controls=0&enablejsapi=1&iv_load_policy=3&modestbranding=1&playsinline=1&autoplay=1",
|
|
||||||
name: "Live stream - Boeuf Bourguignon",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "recipie",
|
|
||||||
url: "http://10.9.64.55:8000/recepie.html",
|
|
||||||
name: "Ingredients - Boeuf Bourguignon",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
// Grafana room
|
|
||||||
'!JWeMRscvtWqfNuzmSf:matrix.org': [
|
|
||||||
{
|
|
||||||
id: "grafana",
|
|
||||||
url: "http://10.9.64.55:8000/grafana.html",
|
|
||||||
name: "Monitoring our Single-Point-Of-Failure DB",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
// Camgirl room - https://www.youtube.com/watch?v=ZfkwW4GgAiU
|
|
||||||
'!wQqrqwOipOOWALxJNe:matrix.org': [
|
|
||||||
{
|
|
||||||
id: "youtube",
|
|
||||||
url: "https://www.youtube.com/embed/ZfkwW4GgAiU?controls=0&enablejsapi=1&iv_load_policy=3&modestbranding=1&playsinline=1&autoplay=1",
|
|
||||||
name: "Live stream - ChatGirl86",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "thermometer",
|
|
||||||
url: "http://10.9.64.55:8000/index.html",
|
|
||||||
name: "Tip Me!!! -- Send me cash $$$",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
// Game room - https://www.youtube.com/watch?v=Dm2Ma1dOFO4
|
|
||||||
'!dYSCwtVljhTdBlgNxq:matrix.org': [
|
|
||||||
{
|
|
||||||
id: "youtube",
|
|
||||||
url: "https://www.youtube.com/embed/Dm2Ma1dOFO4?controls=0&enablejsapi=1&iv_load_policy=3&modestbranding=1&playsinline=1&autoplay=1",
|
|
||||||
name: "Live stream - Overwatch Balle Royale",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: "thermometer",
|
|
||||||
url: "http://10.9.64.55:8000/index.html",
|
|
||||||
name: "Tip Me!!! -- Send me cash $$$",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
// Game room - !BLQjREzUgbtIsgrvRn:matrix.org
|
|
||||||
'!BLQjREzUgbtIsgrvRn:matrix.org': [
|
|
||||||
{
|
|
||||||
id: "etherpad",
|
|
||||||
url: "http://10.9.64.55:8000/etherpad.html",
|
|
||||||
name: "Etherpad",
|
|
||||||
},
|
|
||||||
],
|
|
||||||
};
|
|
||||||
|
|
||||||
module.exports = React.createClass({
|
module.exports = React.createClass({
|
||||||
displayName: 'AppsDrawer',
|
displayName: 'AppsDrawer',
|
||||||
|
|
||||||
propTypes: {
|
propTypes: {
|
||||||
|
room: React.PropTypes.object.isRequired,
|
||||||
|
},
|
||||||
|
|
||||||
|
componentWillMount: function() {
|
||||||
|
MatrixClientPeg.get().on("RoomState.events", this.onRoomStateEvents);
|
||||||
},
|
},
|
||||||
|
|
||||||
componentDidMount: function() {
|
componentDidMount: function() {
|
||||||
},
|
},
|
||||||
|
|
||||||
initAppConfig: function(appConfig) {
|
componentWillUnmount: function() {
|
||||||
console.log("App props: ", this.props);
|
if (MatrixClientPeg.get()) {
|
||||||
appConfig = appConfig.map(
|
MatrixClientPeg.get().removeListener("RoomState.events", this.onRoomStateEvents);
|
||||||
(app, index, arr) => {
|
}
|
||||||
switch(app.id) {
|
},
|
||||||
case 'etherpad':
|
|
||||||
app.url = app.url + '?userName=' + this.props.userId +
|
|
||||||
'&padId=' + this.props.room.roomId;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return app;
|
_initAppConfig: function(appId, app) {
|
||||||
});
|
console.log("App props: ", this.props);
|
||||||
return appConfig;
|
app.id = appId;
|
||||||
|
app.name = app.type;
|
||||||
|
|
||||||
|
switch(app.type) {
|
||||||
|
case 'etherpad':
|
||||||
|
app.url = app.url + '?userName=' + this.props.userId +
|
||||||
|
'&padId=' + this.props.room.roomId;
|
||||||
|
break;
|
||||||
|
case 'jitsi': {
|
||||||
|
const user = MatrixClientPeg.get().getUser(this.props.userId);
|
||||||
|
app.url = app.url +
|
||||||
|
'?confId=' + app.data.confId +
|
||||||
|
'&displayName=' + encodeURIComponent(user.displayName) +
|
||||||
|
'&avatarUrl=' + encodeURIComponent(MatrixClientPeg.get().mxcUrlToHttp(user.avatarUrl)) +
|
||||||
|
'&email=' + encodeURIComponent(this.props.userId) +
|
||||||
|
'&isAudioConf=' + app.data.isAudioConf;
|
||||||
|
|
||||||
|
app.name += ' - ' + app.data.confId;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return app;
|
||||||
},
|
},
|
||||||
|
|
||||||
getInitialState: function() {
|
getInitialState: function() {
|
||||||
for (const key in roomWidgetConfig) {
|
|
||||||
if(key == this.props.room.roomId) {
|
|
||||||
return {
|
|
||||||
apps: this.initAppConfig(roomWidgetConfig[key]),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return {
|
return {
|
||||||
apps: [],
|
apps: this._getApps(),
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
|
onRoomStateEvents: function(ev, state) {
|
||||||
|
if (ev.getRoomId() !== this.props.room.roomId || ev.getType() !== 'im.vector.modular.widgets') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this._updateApps();
|
||||||
|
},
|
||||||
|
|
||||||
|
_getApps: function() {
|
||||||
|
const appsStateEvents = this.props.room.currentState.getStateEvents('im.vector.modular.widgets', '');
|
||||||
|
if (!appsStateEvents) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
const appsStateEvent = appsStateEvents.getContent();
|
||||||
|
if (Object.keys(appsStateEvent).length < 1) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
return Object.keys(appsStateEvent).map((appId) => {
|
||||||
|
return this._initAppConfig(appId, appsStateEvent[appId]);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
_updateApps: function() {
|
||||||
|
const apps = this._getApps();
|
||||||
|
if (apps.length < 1) {
|
||||||
|
dis.dispatch({
|
||||||
|
action: 'appsDrawer',
|
||||||
|
show: false,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
this.setState({
|
||||||
|
apps: this._getApps(),
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
onClickAddWidget: function() {
|
onClickAddWidget: function() {
|
||||||
Modal.createDialog(AddAppDialog, {
|
Modal.createDialog(AddAppDialog, {
|
||||||
onFinished: (proceed, reason) => {
|
onFinished: (proceed, reason) => {
|
||||||
|
@ -131,7 +124,7 @@ module.exports = React.createClass({
|
||||||
render: function() {
|
render: function() {
|
||||||
const apps = this.state.apps.map(
|
const apps = this.state.apps.map(
|
||||||
(app, index, arr) => <AppTile
|
(app, index, arr) => <AppTile
|
||||||
key={app.id}
|
key={app.name}
|
||||||
id={app.id}
|
id={app.id}
|
||||||
url={app.url}
|
url={app.url}
|
||||||
name={app.name}
|
name={app.name}
|
||||||
|
|
Loading…
Reference in a new issue