2022-06-05 02:24:14 +02:00
|
|
|
import { Store, UIEventSource } from "../../Logic/UIEventSource"
|
2021-06-10 01:36:20 +02:00
|
|
|
import BaseUIElement from "../BaseUIElement"
|
|
|
|
import { VariableUiElement } from "../Base/VariableUIElement"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The 'Toggle' is a UIElement showing either one of two elements, depending on the state.
|
|
|
|
* It can be used to implement e.g. checkboxes or collapsible elements
|
|
|
|
*/
|
2021-09-09 00:05:51 +02:00
|
|
|
export default class Toggle extends VariableUiElement {
|
2022-06-05 02:24:14 +02:00
|
|
|
public readonly isEnabled: Store<boolean>
|
2022-09-08 21:40:48 +02:00
|
|
|
|
2022-06-06 19:37:22 +02:00
|
|
|
constructor(
|
|
|
|
showEnabled: string | BaseUIElement,
|
|
|
|
showDisabled: string | BaseUIElement,
|
|
|
|
isEnabled: Store<boolean>
|
|
|
|
) {
|
2022-04-28 00:32:15 +02:00
|
|
|
super(isEnabled?.map((isEnabled) => (isEnabled ? showEnabled : showDisabled)))
|
2021-06-12 02:58:32 +02:00
|
|
|
this.isEnabled = isEnabled
|
2021-06-14 02:39:23 +02:00
|
|
|
}
|
2022-06-05 02:24:14 +02:00
|
|
|
}
|