Browse Source

keep the chat enabled on timer (#1313)

* keep the chat enabled on timer

* fix chat deactivation of stream stop

* simplify the chat status logic

* Use strict inequality

Co-authored-by: gingervitis <omqmail@gmail.com>

* Use strict inequality

Co-authored-by: gingervitis <omqmail@gmail.com>

Co-authored-by: gingervitis <omqmail@gmail.com>
pull/1326/head
Meisam 4 years ago committed by GitHub
parent
commit
4cd7b254da
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 39
      webroot/js/app-standalone-chat.js
  2. 21
      webroot/js/app.js

39
webroot/js/app-standalone-chat.js

@ -33,7 +33,7 @@ export default class StandaloneChat extends Component {
accessToken: null, accessToken: null,
username: null, username: null,
isRegistering: false, isRegistering: false,
streamOnline: false, // stream is active/online streamOnline: null, // stream is active/online
lastDisconnectTime: null, lastDisconnectTime: null,
configData: { configData: {
loading: true, loading: true,
@ -126,27 +126,36 @@ export default class StandaloneChat extends Component {
} }
const { online, lastDisconnectTime } = status; const { online, lastDisconnectTime } = status;
if (status.online && !curStreamOnline) {
// stream has just come online.
this.handleOnlineMode();
} else if (!status.online && curStreamOnline) {
// stream has just flipped offline.
this.handleOfflineMode();
}
this.setState({ this.setState({
lastDisconnectTime, lastDisconnectTime,
streamOnline: online, streamOnline: online,
}); });
if (status.online !== curStreamOnline) {
if (status.online) {
// stream has just come online.
this.handleOnlineMode();
} else {
// stream has just flipped offline or app just got loaded and stream is offline.
this.handleOfflineMode(lastDisconnectTime);
}
}
} }
// stop status timer and disable chat after some time. // stop status timer and disable chat after some time.
handleOfflineMode() { handleOfflineMode(lastDisconnectTime) {
const remainingChatTime = if (lastDisconnectTime) {
TIMER_DISABLE_CHAT_AFTER_OFFLINE - const remainingChatTime =
(Date.now() - new Date(this.state.lastDisconnectTime)); TIMER_DISABLE_CHAT_AFTER_OFFLINE -
const countdown = remainingChatTime < 0 ? 0 : remainingChatTime; (Date.now() - new Date(lastDisconnectTime));
this.disableChatInputTimer = setTimeout(this.disableChatInput, countdown); const countdown = remainingChatTime < 0 ? 0 : remainingChatTime;
if (countdown > 0) {
this.setState({
chatInputEnabled: true,
});
}
this.disableChatInputTimer = setTimeout(this.disableChatInput, countdown);
}
this.setState({ this.setState({
streamOnline: false, streamOnline: false,
}); });

21
webroot/js/app.js

@ -76,7 +76,7 @@ export default class App extends Component {
extraPageContent: '', extraPageContent: '',
playerActive: false, // player object is active playerActive: false, // player object is active
streamOnline: false, // stream is active/online streamOnline: null, // stream is active/online
isPlaying: false, // player is actively playing video isPlaying: false, // player is actively playing video
// status // status
@ -259,12 +259,14 @@ export default class App extends Component {
lastDisconnectTime, lastDisconnectTime,
}); });
if (status.online && !curStreamOnline) { if (status.online !== curStreamOnline) {
// stream has just come online. if (status.online) {
this.handleOnlineMode(); // stream has just come online.
} else if (!status.online && curStreamOnline) { this.handleOnlineMode();
// stream has just flipped offline. } else {
this.handleOfflineMode(lastDisconnectTime); // stream has just flipped offline or app just got loaded and stream is offline.
this.handleOfflineMode(lastDisconnectTime);
}
} }
} }
@ -304,6 +306,11 @@ export default class App extends Component {
TIMER_DISABLE_CHAT_AFTER_OFFLINE - TIMER_DISABLE_CHAT_AFTER_OFFLINE -
(Date.now() - new Date(lastDisconnectTime)); (Date.now() - new Date(lastDisconnectTime));
const countdown = remainingChatTime < 0 ? 0 : remainingChatTime; const countdown = remainingChatTime < 0 ? 0 : remainingChatTime;
if (countdown > 0) {
this.setState({
chatInputEnabled: true,
});
}
this.disableChatInputTimer = setTimeout(this.disableChatInput, countdown); this.disableChatInputTimer = setTimeout(this.disableChatInput, countdown);
} }

Loading…
Cancel
Save