mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-08 15:54:57 +01:00
WebSockets: implement a JavaScript object-oriented client API
Replace previous callback based basic client with an easier to use object-oriented API that further abstracts the low level details of the WebSockets Server surface messaging protocol. All built-in web surface demos were updated to use the new API.
This commit is contained in:
parent
5296ed141f
commit
ae4df127ad
18 changed files with 812 additions and 361 deletions
93
share/web_surfaces/shared/base/component.js
Normal file
93
share/web_surfaces/shared/base/component.js
Normal file
|
|
@ -0,0 +1,93 @@
|
|||
/*
|
||||
* Copyright © 2020 Luciano Iam <lucianito@gmail.com>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or modify
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 2 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License along
|
||||
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
*/
|
||||
|
||||
import { Message } from './protocol.js';
|
||||
import { Observable } from './observable.js';
|
||||
|
||||
export class Component extends Observable {
|
||||
|
||||
constructor (parent) {
|
||||
super();
|
||||
this._parent = parent;
|
||||
}
|
||||
|
||||
get channel () {
|
||||
return this._parent.channel;
|
||||
}
|
||||
|
||||
on (property, callback) {
|
||||
this.addObserver(property, (self) => callback(self[property]));
|
||||
}
|
||||
|
||||
send (node, addr, val) {
|
||||
this.channel.send(new Message(node, addr, val));
|
||||
}
|
||||
|
||||
handle (node, addr, val) {
|
||||
return false;
|
||||
}
|
||||
|
||||
handleMessage (msg) {
|
||||
return this.handle(msg.node, msg.addr, msg.val);
|
||||
}
|
||||
|
||||
updateLocal (property, value) {
|
||||
this['_' + property] = value;
|
||||
this.notifyObservers(property);
|
||||
}
|
||||
|
||||
updateRemote (property, value, node, addr) {
|
||||
this['_' + property] = value;
|
||||
this.send(node, addr || [], [value]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
export class RootComponent extends Component {
|
||||
|
||||
constructor (channel) {
|
||||
super(null);
|
||||
this._channel = channel;
|
||||
}
|
||||
|
||||
get channel () {
|
||||
return this._channel;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
export class AddressableComponent extends Component {
|
||||
|
||||
constructor (parent, addr) {
|
||||
super(parent);
|
||||
this._addr = addr;
|
||||
}
|
||||
|
||||
get addr () {
|
||||
return this._addr;
|
||||
}
|
||||
|
||||
get addrId () {
|
||||
return this._addr.join('-');
|
||||
}
|
||||
|
||||
updateRemote (property, value, node) {
|
||||
super.updateRemote(property, value, node, this.addr);
|
||||
}
|
||||
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue