Skip to content
This repository was archived by the owner on Oct 22, 2024. It is now read-only.

Commit 3a24061

Browse files
committed
Refactor MatrixClientBackedController.ts
Signed-off-by: Michael Telatynski <7t3chguy@gmail.com>
1 parent 39a0f6e commit 3a24061

File tree

2 files changed

+7
-9
lines changed

2 files changed

+7
-9
lines changed

src/settings/controllers/MatrixClientBackedController.ts

+4-4
Original file line numberDiff line numberDiff line change
@@ -18,15 +18,15 @@ import SettingController from "./SettingController";
1818
* This class performs no logic and should be overridden.
1919
*/
2020
export default abstract class MatrixClientBackedController extends SettingController {
21-
private static _matrixClient: MatrixClient;
21+
private static _matrixClient?: MatrixClient;
2222
private static instances: MatrixClientBackedController[] = [];
2323

2424
public static set matrixClient(client: MatrixClient) {
2525
const oldClient = MatrixClientBackedController._matrixClient;
2626
MatrixClientBackedController._matrixClient = client;
2727

2828
for (const instance of MatrixClientBackedController.instances) {
29-
instance.initMatrixClient(oldClient, client);
29+
instance.initMatrixClient(client, oldClient);
3030
}
3131
}
3232

@@ -36,9 +36,9 @@ export default abstract class MatrixClientBackedController extends SettingContro
3636
MatrixClientBackedController.instances.push(this);
3737
}
3838

39-
public get client(): MatrixClient {
39+
public get client(): MatrixClient | undefined {
4040
return MatrixClientBackedController._matrixClient;
4141
}
4242

43-
protected abstract initMatrixClient(oldClient: MatrixClient, newClient: MatrixClient): void;
43+
protected abstract initMatrixClient(newClient: MatrixClient, oldClient?: MatrixClient): void;
4444
}

src/settings/controllers/ServerSupportUnstableFeatureController.ts

+3-5
Original file line numberDiff line numberDiff line change
@@ -6,8 +6,6 @@ SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
66
Please see LICENSE files in the repository root for full details.
77
*/
88

9-
import { MatrixClient } from "matrix-js-sdk/src/matrix";
10-
119
import { SettingLevel } from "../SettingLevel";
1210
import MatrixClientBackedController from "./MatrixClientBackedController";
1311
import { WatchManager } from "../WatchManager";
@@ -53,9 +51,9 @@ export default class ServerSupportUnstableFeatureController extends MatrixClient
5351
this.watchers.notifyUpdate(this.settingName, null, level, settingValue);
5452
}
5553

56-
protected async initMatrixClient(oldClient: MatrixClient, newClient: MatrixClient): Promise<void> {
54+
protected async initMatrixClient(): Promise<void> {
5755
// Check for stable version support first
58-
if (this.stableVersion && (await this.client.isVersionSupported(this.stableVersion))) {
56+
if (this.stableVersion && (await this.client!.isVersionSupported(this.stableVersion))) {
5957
this.disabled = false;
6058
return;
6159
}
@@ -66,7 +64,7 @@ export default class ServerSupportUnstableFeatureController extends MatrixClient
6664
for (const featureGroup of this.unstableFeatureGroups) {
6765
const featureSupportList = await Promise.all(
6866
featureGroup.map(async (feature) => {
69-
const isFeatureSupported = await this.client.doesServerSupportUnstableFeature(feature);
67+
const isFeatureSupported = await this.client!.doesServerSupportUnstableFeature(feature);
7068
return isFeatureSupported;
7169
}),
7270
);

0 commit comments

Comments
 (0)