2016-11-02 18:45:35 +01:00
|
|
|
|
// @flow
|
|
|
|
|
|
|
|
|
|
/*
|
2016-11-03 12:51:41 +01:00
|
|
|
|
Copyright 2016 Aviral Dasgupta
|
|
|
|
|
Copyright 2016 OpenMarket Ltd
|
2018-12-18 18:42:55 +01:00
|
|
|
|
Copyright 2018 New Vector Ltd
|
2019-06-26 22:08:04 +02:00
|
|
|
|
Copyright 2019 Michael Telatynski <7t3chguy@gmail.com>
|
2016-11-02 18:45:35 +01: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
|
|
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
*/
|
|
|
|
|
|
2019-12-20 02:47:40 +01:00
|
|
|
|
import BasePlatform from 'matrix-react-sdk/src/BasePlatform';
|
|
|
|
|
import { _t } from 'matrix-react-sdk/src/languageHandler';
|
|
|
|
|
import dis from 'matrix-react-sdk/src/dispatcher';
|
2019-06-26 22:08:04 +02:00
|
|
|
|
import {getVectorConfig} from "../getconfig";
|
2017-05-31 15:51:08 +02:00
|
|
|
|
|
2017-05-13 13:37:13 +02:00
|
|
|
|
import Favico from 'favico.js';
|
2016-11-02 18:45:35 +01:00
|
|
|
|
|
2017-06-11 20:19:17 +02:00
|
|
|
|
export const updateCheckStatusEnum = {
|
|
|
|
|
CHECKING: 'CHECKING',
|
2017-06-03 16:17:58 +02:00
|
|
|
|
ERROR: 'ERROR',
|
|
|
|
|
NOTAVAILABLE: 'NOTAVAILABLE',
|
|
|
|
|
DOWNLOADING: 'DOWNLOADING',
|
|
|
|
|
READY: 'READY',
|
2017-06-03 16:12:46 +02:00
|
|
|
|
};
|
|
|
|
|
|
2016-11-02 18:45:35 +01:00
|
|
|
|
/**
|
|
|
|
|
* Vector-specific extensions to the BasePlatform template
|
|
|
|
|
*/
|
|
|
|
|
export default class VectorBasePlatform extends BasePlatform {
|
2017-05-13 13:37:13 +02:00
|
|
|
|
constructor() {
|
|
|
|
|
super();
|
|
|
|
|
|
2017-06-11 20:19:17 +02:00
|
|
|
|
this.showUpdateCheck = false;
|
|
|
|
|
this.startUpdateCheck = this.startUpdateCheck.bind(this);
|
|
|
|
|
this.stopUpdateCheck = this.stopUpdateCheck.bind(this);
|
2017-05-13 13:37:13 +02:00
|
|
|
|
}
|
|
|
|
|
|
2019-06-26 22:08:04 +02:00
|
|
|
|
async getConfig(): Promise<{}> {
|
|
|
|
|
return getVectorConfig();
|
|
|
|
|
}
|
|
|
|
|
|
2017-05-29 21:03:21 +02:00
|
|
|
|
getHumanReadableName(): string {
|
2017-05-31 15:51:08 +02:00
|
|
|
|
return 'Vector Base Platform'; // no translation required: only used for analytics
|
2017-05-29 20:51:28 +02:00
|
|
|
|
}
|
|
|
|
|
|
2019-05-02 14:29:25 +02:00
|
|
|
|
/**
|
|
|
|
|
* Delay creating the `Favico` instance until first use (on the first notification) as
|
|
|
|
|
* it uses canvas, which can trigger a permission prompt in Firefox's resist
|
|
|
|
|
* fingerprinting mode.
|
|
|
|
|
* See https://github.com/vector-im/riot-web/issues/9605.
|
|
|
|
|
*/
|
|
|
|
|
get favicon() {
|
|
|
|
|
if (this._favicon) {
|
|
|
|
|
return this._favicon;
|
|
|
|
|
}
|
|
|
|
|
// The 'animations' are really low framerate and look terrible.
|
|
|
|
|
// Also it re-starts the animation every time you set the badge,
|
|
|
|
|
// and we set the state each time, even if the value hasn't changed,
|
|
|
|
|
// so we'd need to fix that if enabling the animation.
|
|
|
|
|
this._favicon = new Favico({ animation: 'none' });
|
|
|
|
|
return this._favicon;
|
|
|
|
|
}
|
|
|
|
|
|
2017-05-13 13:37:13 +02:00
|
|
|
|
_updateFavicon() {
|
|
|
|
|
try {
|
|
|
|
|
// This needs to be in in a try block as it will throw
|
|
|
|
|
// if there are more than 100 badge count changes in
|
|
|
|
|
// its internal queue
|
2018-11-22 19:25:55 +01:00
|
|
|
|
let bgColor = "#d00";
|
|
|
|
|
let notif = this.notificationCount;
|
2017-05-13 13:37:13 +02:00
|
|
|
|
|
|
|
|
|
if (this.errorDidOccur) {
|
|
|
|
|
notif = notif || "×";
|
|
|
|
|
bgColor = "#f00";
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-12 23:02:52 +01:00
|
|
|
|
const doUpdate = () => {
|
|
|
|
|
this.favicon.badge(notif, {
|
|
|
|
|
bgColor: bgColor,
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
doUpdate();
|
|
|
|
|
|
|
|
|
|
// HACK: Workaround for Chrome 78+ and dependency incompatibility.
|
|
|
|
|
// The library we use doesn't appear to work in Chrome 78, likely due to their
|
|
|
|
|
// changes surrounding tab behaviour. Tabs went through a bit of a redesign and
|
|
|
|
|
// restructuring in Chrome 78, so it's not terribly surprising that the library
|
|
|
|
|
// doesn't work correctly. The library we use hasn't been updated in years and
|
|
|
|
|
// does not look easy to fix/fork ourselves - we might as well write our own that
|
|
|
|
|
// doesn't include animation/webcam/etc support. However, that's a bit difficult
|
|
|
|
|
// so for now we'll just trigger the update twice.
|
|
|
|
|
//
|
|
|
|
|
// Note that trying to reproduce the problem in isolation doesn't seem to work:
|
|
|
|
|
// see https://gist.github.com/turt2live/5ab87919918adbfd7cfb8f1ad10f2409 for
|
|
|
|
|
// an example (you'll need your own web server to host that).
|
2019-11-12 23:04:56 +01:00
|
|
|
|
if (window.chrome) {
|
2019-11-12 23:02:52 +01:00
|
|
|
|
doUpdate();
|
|
|
|
|
}
|
2019-11-12 23:14:11 +01:00
|
|
|
|
} catch (e) {
|
2017-05-13 13:37:13 +02:00
|
|
|
|
console.warn(`Failed to set badge count: ${e.message}`);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
setNotificationCount(count: number) {
|
|
|
|
|
if (this.notificationCount === count) return;
|
|
|
|
|
super.setNotificationCount(count);
|
|
|
|
|
this._updateFavicon();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
setErrorStatus(errorDidOccur: boolean) {
|
|
|
|
|
if (this.errorDidOccur === errorDidOccur) return;
|
|
|
|
|
super.setErrorStatus(errorDidOccur);
|
|
|
|
|
this._updateFavicon();
|
|
|
|
|
}
|
|
|
|
|
|
2017-06-03 13:50:47 +02:00
|
|
|
|
/**
|
|
|
|
|
* Begin update polling, if applicable
|
|
|
|
|
*/
|
|
|
|
|
startUpdater() {
|
|
|
|
|
}
|
|
|
|
|
|
2017-06-03 16:12:46 +02:00
|
|
|
|
/**
|
|
|
|
|
* Whether we can call checkForUpdate on this platform build
|
|
|
|
|
*/
|
2018-12-18 18:42:55 +01:00
|
|
|
|
async canSelfUpdate(): boolean {
|
|
|
|
|
return false;
|
2017-06-03 16:12:46 +02:00
|
|
|
|
}
|
|
|
|
|
|
2017-06-11 20:19:17 +02:00
|
|
|
|
startUpdateCheck() {
|
|
|
|
|
this.showUpdateCheck = true;
|
|
|
|
|
dis.dispatch({
|
|
|
|
|
action: 'check_updates',
|
|
|
|
|
value: { status: updateCheckStatusEnum.CHECKING },
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
stopUpdateCheck() {
|
|
|
|
|
this.showUpdateCheck = false;
|
|
|
|
|
dis.dispatch({
|
|
|
|
|
action: 'check_updates',
|
|
|
|
|
value: false,
|
2018-11-22 19:25:55 +01:00
|
|
|
|
});
|
2017-06-11 20:19:17 +02:00
|
|
|
|
}
|
|
|
|
|
|
2018-04-13 02:25:00 +02:00
|
|
|
|
getUpdateCheckStatusEnum() {
|
|
|
|
|
return updateCheckStatusEnum;
|
|
|
|
|
}
|
|
|
|
|
|
2016-11-02 18:45:35 +01:00
|
|
|
|
/**
|
|
|
|
|
* Update the currently running app to the latest available
|
|
|
|
|
* version and replace this instance of the app with the
|
|
|
|
|
* new version.
|
|
|
|
|
*/
|
|
|
|
|
installUpdate() {
|
|
|
|
|
}
|
2016-11-24 17:46:15 +01:00
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Get a sensible default display name for the
|
|
|
|
|
* device Vector is running on
|
|
|
|
|
*/
|
2017-05-02 22:29:19 +02:00
|
|
|
|
getDefaultDeviceDisplayName(): string {
|
2017-05-31 15:51:08 +02:00
|
|
|
|
return _t("Unknown device");
|
2016-11-24 17:46:15 +01:00
|
|
|
|
}
|
2016-11-02 18:45:35 +01:00
|
|
|
|
}
|