50ba8dea96
add methods to callback.js automatically reconnect js client on disconnection mixer-demo do not recreate UI on reconnection NO-OP: indentation in message.js make client JS reconnection optional fix mixer-demo scrolling minor JS client refactor improve mixer-demo readability
150 lines
3.3 KiB
JavaScript
150 lines
3.3 KiB
JavaScript
/*
|
|
* Copyright (C) 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 '/shared/message.js';
|
|
|
|
export class Widget {
|
|
|
|
constructor (html) {
|
|
const template = document.createElement('template');
|
|
template.innerHTML = html;
|
|
this.el = template.content.firstChild;
|
|
}
|
|
|
|
appendTo (parent) {
|
|
parent.appendChild(this.el);
|
|
}
|
|
|
|
callback (value) {
|
|
// do nothing by default
|
|
}
|
|
|
|
}
|
|
|
|
export class Switch extends Widget {
|
|
|
|
constructor () {
|
|
super (`<input type="checkbox" class="widget-switch">`);
|
|
this.el.addEventListener('input', (ev) => this.callback(this.value));
|
|
}
|
|
|
|
get value () {
|
|
return this.el.checked;
|
|
}
|
|
|
|
set value (val) {
|
|
this.el.checked = val;
|
|
}
|
|
|
|
}
|
|
|
|
export class Slider extends Widget {
|
|
|
|
constructor (min, max, step) {
|
|
const html = `<input type="range" class="widget-slider"
|
|
min="${min}" max="${max}" step="${step}">`;
|
|
super(html);
|
|
this.min = min;
|
|
this.max = max;
|
|
this.el.addEventListener('input', (ev) => this.callback(this.value));
|
|
}
|
|
|
|
get value () {
|
|
return parseFloat(this.el.value)
|
|
}
|
|
|
|
set value (val) {
|
|
this.el.value = val;
|
|
}
|
|
|
|
}
|
|
|
|
export class DiscreteSlider extends Slider {
|
|
|
|
constructor (min, max, step) {
|
|
super(min, max, step || 1);
|
|
}
|
|
|
|
}
|
|
|
|
export class ContinuousSlider extends Slider {
|
|
|
|
constructor (min, max) {
|
|
super(min, max, 0.001);
|
|
}
|
|
|
|
}
|
|
|
|
export class LogarithmicSlider extends ContinuousSlider {
|
|
|
|
constructor (min, max) {
|
|
super(0, 1.0);
|
|
this.minVal = Math.log(min);
|
|
this.maxVal = Math.log(max);
|
|
this.scale = this.maxVal - this.minVal;
|
|
}
|
|
|
|
get value () {
|
|
return Math.exp(this.minVal + this.scale * super.value);
|
|
}
|
|
|
|
set value (val) {
|
|
this.el.value = (Math.log(val) - this.minVal) / this.scale;
|
|
}
|
|
|
|
}
|
|
|
|
export class StripPanSlider extends ContinuousSlider {
|
|
|
|
constructor () {
|
|
super(-1.0, 1.0);
|
|
}
|
|
|
|
}
|
|
|
|
export class StripGainSlider extends ContinuousSlider {
|
|
|
|
constructor () {
|
|
super(0, 1.0)
|
|
this.minVal = -58.0;
|
|
this.maxVal = 6.0;
|
|
this.scale = (this.maxVal - this.minVal);
|
|
}
|
|
|
|
get value () {
|
|
return this.maxVal + Math.log10(super.value) * this.scale;
|
|
}
|
|
|
|
set value (val) {
|
|
this.el.value = Math.pow(10.0, (val - this.maxVal) / this.scale);
|
|
}
|
|
|
|
}
|
|
|
|
export class StripMeter extends Widget {
|
|
|
|
constructor () {
|
|
super(`<label></label>`);
|
|
}
|
|
|
|
set value (val) {
|
|
this.el.innerHTML = val == -Infinity ? '-∞' : `${Math.round(val)} dB`;
|
|
}
|
|
|
|
}
|