feat: Show refresh modal on action cable disconnect (#4010)

This commit is contained in:
Muhsin Keloth 2022-02-18 11:09:43 +05:30 committed by GitHub
parent ea3e011d3f
commit 80d83b401c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 12 additions and 0 deletions

View file

@ -30,6 +30,7 @@
<script>
import globalConfigMixin from 'shared/mixins/globalConfigMixin';
import { mapGetters } from 'vuex';
import { BUS_EVENTS } from 'shared/constants/busEvents';
export default {
mixins: [globalConfigMixin],
@ -46,6 +47,9 @@ export default {
mounted() {
window.addEventListener('offline', this.updateOnlineStatus);
window.bus.$on(BUS_EVENTS.WEBSOCKET_DISCONNECT, () => {
this.updateOnlineStatus({ type: 'offline' });
});
},
beforeDestroy() {

View file

@ -5,4 +5,5 @@ export const BUS_EVENTS = {
FOCUS_CUSTOM_ATTRIBUTE: 'FOCUS_CUSTOM_ATTRIBUTE',
SCROLL_TO_MESSAGE: 'SCROLL_TO_MESSAGE',
TOGGLE_SIDEMENU: 'TOGGLE_SIDEMENU',
WEBSOCKET_DISCONNECT: 'WEBSOCKET_DISCONNECT',
};

View file

@ -1,4 +1,5 @@
import { createConsumer } from '@rails/actioncable';
import { BUS_EVENTS } from 'shared/constants/busEvents';
const PRESENCE_INTERVAL = 20000;
@ -18,6 +19,7 @@ class BaseActionCableConnector {
this.perform('update_presence');
},
received: this.onReceived,
disconnected: this.onDisconnected,
}
);
this.app = app;
@ -33,6 +35,11 @@ class BaseActionCableConnector {
this.consumer.disconnect();
}
// eslint-disable-next-line class-methods-use-this
onDisconnected() {
window.bus.$emit(BUS_EVENTS.WEBSOCKET_DISCONNECT);
}
onReceived = ({ event, data } = {}) => {
if (this.isAValidEvent(data)) {
if (this.events[event] && typeof this.events[event] === 'function') {