forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {Store, UIEventSource} from "../../Logic/UIEventSource";
 | |
| import BaseUIElement from "../BaseUIElement";
 | |
| import {VariableUiElement} from "../Base/VariableUIElement";
 | |
| import Lazy from "../Base/Lazy";
 | |
| 
 | |
| /**
 | |
|  * 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
 | |
|  */
 | |
| export default class Toggle extends VariableUiElement {
 | |
| 
 | |
|     public readonly isEnabled: Store<boolean>;
 | |
| 
 | |
|     constructor(showEnabled: string | BaseUIElement, showDisabled: string | BaseUIElement, isEnabled: Store<boolean>) {
 | |
|         super(
 | |
|             isEnabled?.map(isEnabled => isEnabled ? showEnabled : showDisabled)
 | |
|         );
 | |
|         this.isEnabled = isEnabled
 | |
|     }
 | |
| 
 | |
|     public static If(condition: Store<boolean>, constructor: () => BaseUIElement): BaseUIElement {
 | |
|         if (constructor === undefined) {
 | |
|             return undefined
 | |
|         }
 | |
|         return new Toggle(
 | |
|             new Lazy(constructor),
 | |
|             undefined,
 | |
|             condition
 | |
|         )
 | |
| 
 | |
|     }
 | |
|     
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Same as `Toggle`, but will swap on click
 | |
|  */
 | |
| export class ClickableToggle extends Toggle {
 | |
| 
 | |
|     public readonly isEnabled: UIEventSource<boolean>;
 | |
| 
 | |
|     constructor(showEnabled: string | BaseUIElement, showDisabled: string | BaseUIElement, isEnabled: UIEventSource<boolean> = new UIEventSource<boolean>(false)) {
 | |
|         super(
 | |
|           showEnabled, showDisabled, isEnabled
 | |
|         );
 | |
|         this.isEnabled = isEnabled
 | |
|     }
 | |
|     
 | |
|     public ToggleOnClick(): ClickableToggle {
 | |
|         const self = this;
 | |
|         this.onClick(() => {
 | |
|             self.isEnabled.setData(!self.isEnabled.data);
 | |
|         })
 | |
|         return this;
 | |
|     }
 | |
| } |