etherpad-lite/src/static/js/pad_connectionstatus.ts

103 lines
2.5 KiB
TypeScript
Raw Normal View History

'use strict';
/**
* This code is mostly from the old Etherpad. Please help us to comment this code.
* This helps other people to understand this code better and helps them to improve it.
* TL;DR COMMENTS ON THIS FILE ARE HIGHLY APPRECIATED
*/
2011-03-26 13:10:41 +00:00
/**
* Copyright 2009 Google Inc.
2011-07-07 18:59:34 +01:00
*
2011-03-26 13:10:41 +00:00
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
2011-07-07 18:59:34 +01:00
*
2011-03-26 13:10:41 +00:00
* http://www.apache.org/licenses/LICENSE-2.0
2011-07-07 18:59:34 +01:00
*
2011-03-26 13:10:41 +00:00
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS-IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
2024-07-19 19:22:04 +02:00
import {padModals} from "./pad_modals";
2024-07-19 19:22:04 +02:00
class PadConnectionStatus {
private status: {
what: string,
why?: string
} = {
2020-11-23 13:24:19 -05:00
what: 'connecting',
2024-07-19 19:22:04 +02:00
}
2011-03-26 13:10:41 +00:00
2024-07-19 19:22:04 +02:00
init = () => {
$('button#forcereconnect').on('click', () => {
window.location.reload();
});
}
2024-07-19 19:22:04 +02:00
connected = () => {
this.status = {
what: 'connected',
};
padModals.showModal('connected');
padModals.hideOverlay();
}
reconnecting = () => {
this.status = {
what: 'reconnecting',
};
2024-07-19 19:22:04 +02:00
padModals.showModal('reconnecting');
padModals.showOverlay();
}
disconnected
=
(msg: string) => {
if (this.status.what === 'disconnected') return;
2024-07-19 19:22:04 +02:00
this.status =
{
what: 'disconnected',
why: msg,
}
// These message IDs correspond to localized strings that are presented to the user. If a new
// message ID is added here then a new div must be added to src/templates/pad.html and the
// corresponding l10n IDs must be added to the language files in src/locales.
const knownReasons = [
'badChangeset',
'corruptPad',
'deleted',
'disconnected',
'initsocketfail',
'looping',
'rateLimited',
'rejected',
'slowcommit',
'unauth',
'userdup',
];
let k = String(msg);
if (knownReasons.indexOf(k) === -1) {
// Fall back to a generic message.
k = 'disconnected';
2011-03-26 13:10:41 +00:00
}
2024-07-19 19:22:04 +02:00
padModals.showModal(k);
padModals.showOverlay();
}
isFullyConnected
=
() => this.status.what === 'connected'
getStatus
=
() => this.status
}
2024-07-19 19:22:04 +02:00
export const padconnectionstatus = new PadConnectionStatus()
exports.padconnectionstatus = padconnectionstatus;