2016-11-02 23:10:21 +08:00
|
|
|
/*
|
|
|
|
Copyright 2016 OpenMarket Ltd
|
2020-07-03 05:42:28 +08:00
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
2016-11-02 23:10:21 +08: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.
|
|
|
|
*/
|
|
|
|
|
2020-07-03 05:42:28 +08:00
|
|
|
import BasePlatform from "./BasePlatform";
|
2022-06-30 22:48:21 +08:00
|
|
|
import defaultDispatcher from "./dispatcher/dispatcher";
|
|
|
|
import { Action } from "./dispatcher/actions";
|
|
|
|
import { PlatformSetPayload } from "./dispatcher/payloads/PlatformSetPayload";
|
2020-07-03 05:42:28 +08:00
|
|
|
|
2016-11-02 23:10:21 +08:00
|
|
|
/*
|
2022-05-10 10:34:27 +08:00
|
|
|
* Holds the current instance of the `Platform` to use across the codebase.
|
|
|
|
* Looking for an `Platform`? Just look for the `PlatformPeg` on the peg board.
|
|
|
|
* "Peg" is the literal meaning of something you hang something on. So you'll
|
|
|
|
* find a `Platform` hanging on the `PlatformPeg`.
|
|
|
|
*
|
|
|
|
* Used by the code to do anything specific to the platform we're running on
|
|
|
|
* (eg. web, electron). Platforms are provided by the app layer. This allows the
|
|
|
|
* app layer to set a Platform without necessarily having to have a MatrixChat
|
|
|
|
* object.
|
2016-11-02 23:10:21 +08:00
|
|
|
*/
|
2020-07-03 05:42:28 +08:00
|
|
|
export class PlatformPeg {
|
2023-01-12 21:25:14 +08:00
|
|
|
private platform: BasePlatform | null = null;
|
2016-11-02 23:10:21 +08:00
|
|
|
|
|
|
|
/**
|
2016-11-03 00:15:35 +08:00
|
|
|
* Returns the current Platform object for the application.
|
2016-11-02 23:10:21 +08:00
|
|
|
* This should be an instance of a class extending BasePlatform.
|
|
|
|
*/
|
2023-01-12 21:25:14 +08:00
|
|
|
public get(): BasePlatform | null {
|
2016-11-02 23:10:21 +08:00
|
|
|
return this.platform;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2022-06-30 22:48:21 +08:00
|
|
|
* Sets the current platform handler object to use for the application.
|
|
|
|
* @param {BasePlatform} platform an instance of a class extending BasePlatform.
|
2016-11-02 23:10:21 +08:00
|
|
|
*/
|
2023-01-12 21:25:14 +08:00
|
|
|
public set(platform: BasePlatform): void {
|
2022-06-30 22:48:21 +08:00
|
|
|
this.platform = platform;
|
|
|
|
defaultDispatcher.dispatch<PlatformSetPayload>({
|
|
|
|
action: Action.PlatformSet,
|
|
|
|
platform,
|
|
|
|
});
|
2016-11-02 23:10:21 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-03 05:42:28 +08:00
|
|
|
if (!window.mxPlatformPeg) {
|
|
|
|
window.mxPlatformPeg = new PlatformPeg();
|
2016-11-02 23:10:21 +08:00
|
|
|
}
|
2020-07-03 05:42:28 +08:00
|
|
|
export default window.mxPlatformPeg;
|