2020-11-30 21:05:26 +01:00
|
|
|
/*
|
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2020-12-02 15:36:54 +01:00
|
|
|
import {isWebPlatform, Platform} from "../Platform.js";
|
2020-12-02 09:43:54 +01:00
|
|
|
import {Maturity} from "./types.js";
|
2020-11-30 21:05:26 +01:00
|
|
|
import {ClientViewModel} from "./ClientViewModel.js";
|
|
|
|
import {ViewModel} from "../utils/ViewModel.js";
|
|
|
|
|
|
|
|
export class ClientListViewModel extends ViewModel {
|
2021-07-23 13:25:21 +02:00
|
|
|
constructor(options) {
|
|
|
|
super(options);
|
|
|
|
const {clients, client, link} = options;
|
|
|
|
this._clients = clients;
|
|
|
|
this._link = link;
|
|
|
|
this.clientList = null;
|
|
|
|
this._showExperimental = false;
|
|
|
|
this._showUnsupportedPlatforms = false;
|
|
|
|
this._filterClients();
|
|
|
|
this.clientViewModel = null;
|
|
|
|
if (client) {
|
|
|
|
this._pickClient(client);
|
|
|
|
}
|
|
|
|
}
|
2020-12-01 19:01:15 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
get showUnsupportedPlatforms() {
|
|
|
|
return this._showUnsupportedPlatforms;
|
|
|
|
}
|
2020-12-02 12:13:06 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
get showExperimental() {
|
|
|
|
return this._showExperimental;
|
|
|
|
}
|
2020-12-02 12:13:06 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
set showUnsupportedPlatforms(enabled) {
|
|
|
|
this._showUnsupportedPlatforms = enabled;
|
|
|
|
this._filterClients();
|
|
|
|
}
|
2020-12-02 12:13:06 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
set showExperimental(enabled) {
|
|
|
|
this._showExperimental = enabled;
|
|
|
|
this._filterClients();
|
|
|
|
}
|
2020-12-02 12:13:06 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
_filterClients() {
|
|
|
|
const clientVMs = this._clients.filter(client => {
|
2020-12-04 19:35:01 +01:00
|
|
|
const platformMaturities = this.platforms.map(p => client.getMaturity(p));
|
2021-07-23 13:25:21 +02:00
|
|
|
const isStable = platformMaturities.includes(Maturity.Stable) || platformMaturities.includes(Maturity.Beta);
|
|
|
|
const isSupported = client.platforms.some(p => this.platforms.includes(p));
|
|
|
|
if (!this._showExperimental && !isStable) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (!this._showUnsupportedPlatforms && !isSupported) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}).map(client => new ClientViewModel(this.childOptions({
|
|
|
|
client,
|
|
|
|
link: this._link,
|
|
|
|
pickClient: client => this._pickClient(client)
|
|
|
|
})));
|
2021-02-04 17:07:55 +01:00
|
|
|
const preferredClientVMs = clientVMs.filter(c => c.hasPreferredWebInstance);
|
|
|
|
const otherClientVMs = clientVMs.filter(c => !c.hasPreferredWebInstance);
|
|
|
|
this.clientList = preferredClientVMs.concat(otherClientVMs);
|
2021-07-23 13:25:21 +02:00
|
|
|
this.emitChange();
|
|
|
|
}
|
2020-12-02 09:43:54 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
_pickClient(client) {
|
|
|
|
this.clientViewModel = this.clientList.find(vm => vm.clientId === client.id);
|
2020-12-07 13:34:22 +01:00
|
|
|
this.clientViewModel.pick(this);
|
2021-07-23 13:25:21 +02:00
|
|
|
this.emitChange();
|
|
|
|
}
|
2020-12-01 19:01:15 +01:00
|
|
|
|
2021-07-23 13:25:21 +02:00
|
|
|
showAll() {
|
|
|
|
this.clientViewModel = null;
|
|
|
|
this.emitChange();
|
|
|
|
}
|
2020-11-30 21:05:26 +01:00
|
|
|
}
|