2020-11-27 17:05:20 +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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class EventEmitter {
|
|
|
|
constructor() {
|
|
|
|
this._handlersByName = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
emit(name, ...values) {
|
|
|
|
const handlers = this._handlersByName[name];
|
|
|
|
if (handlers) {
|
|
|
|
for(const h of handlers) {
|
|
|
|
h(...values);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
on(name, callback) {
|
|
|
|
let handlers = this._handlersByName[name];
|
|
|
|
if (!handlers) {
|
|
|
|
this._handlersByName[name] = handlers = new Set();
|
|
|
|
}
|
|
|
|
handlers.add(callback);
|
|
|
|
return () => {
|
|
|
|
this.off(name, callback);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
off(name, callback) {
|
|
|
|
const handlers = this._handlersByName[name];
|
|
|
|
if (handlers) {
|
|
|
|
handlers.delete(callback);
|
|
|
|
if (handlers.length === 0) {
|
|
|
|
delete this._handlersByName[name];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export class ViewModel extends EventEmitter {
|
2020-11-30 10:57:39 +01:00
|
|
|
constructor(options) {
|
|
|
|
super();
|
|
|
|
this._options = options;
|
|
|
|
}
|
|
|
|
|
2020-11-27 17:05:20 +01:00
|
|
|
emitChange() {
|
|
|
|
this.emit("change");
|
|
|
|
}
|
2020-11-30 10:57:39 +01:00
|
|
|
|
2020-11-30 21:05:26 +01:00
|
|
|
get request() { return this._options.request; }
|
2020-12-02 15:39:33 +01:00
|
|
|
get origin() { return this._options.origin; }
|
2020-11-30 21:05:26 +01:00
|
|
|
get openLink() { return this._options.openLink; }
|
|
|
|
get platforms() { return this._options.platforms; }
|
2020-12-01 12:06:37 +01:00
|
|
|
get preferences() { return this._options.preferences; }
|
2020-11-30 10:57:39 +01:00
|
|
|
|
|
|
|
childOptions(options = {}) {
|
2020-11-30 21:05:26 +01:00
|
|
|
return Object.assign({
|
|
|
|
request: this.request,
|
2020-12-02 15:39:33 +01:00
|
|
|
origin: this.origin,
|
2020-11-30 21:05:26 +01:00
|
|
|
openLink: this.openLink,
|
|
|
|
platforms: this.platforms,
|
2020-12-01 12:06:37 +01:00
|
|
|
preferences: this.preferences,
|
2020-11-30 21:05:26 +01:00
|
|
|
}, options);
|
2020-11-30 10:57:39 +01:00
|
|
|
}
|
2020-12-03 11:07:38 +01:00
|
|
|
}
|