forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			50 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			50 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | import {InputElement} from "./InputElement"; | ||
|  | import {UIEventSource} from "../../Logic/UIEventSource"; | ||
|  | 
 | ||
|  | export default class Slider extends InputElement<number> { | ||
|  | 
 | ||
|  |     private readonly _value: UIEventSource<number> | ||
|  |     private min: number; | ||
|  |     private max: number; | ||
|  |     private step: number; | ||
|  | 
 | ||
|  |     /** | ||
|  |      * Constructs a slider input element for natural numbers | ||
|  |      * @param min: the minimum value that is allowed, inclusive | ||
|  |      * @param max: the max value that is allowed, inclusive | ||
|  |      * @param options: value: injectable value; step: the step size of the slider | ||
|  |      */ | ||
|  |     constructor(min: number, max: number, options?: { | ||
|  |         value?: UIEventSource<number>, | ||
|  |         step?: 1 | number | ||
|  |     }) { | ||
|  |         super(); | ||
|  |         this.max = max; | ||
|  |         this.min = min; | ||
|  |         this._value = options?.value ?? new UIEventSource<number>(min) | ||
|  |         this.step = options?.step ?? 1; | ||
|  |     } | ||
|  | 
 | ||
|  |     GetValue(): UIEventSource<number> { | ||
|  |         return this._value; | ||
|  |     } | ||
|  | 
 | ||
|  |     protected InnerConstructElement(): HTMLElement { | ||
|  |         const el = document.createElement("input") | ||
|  |         el.type = "range" | ||
|  |         el.min = "" + this.min | ||
|  |         el.max = "" + this.max | ||
|  |         el.step = "" + this.step | ||
|  |         const valuestore = this._value | ||
|  |         el.oninput = () => { | ||
|  |             valuestore.setData(Number(el.value)) | ||
|  |         } | ||
|  |         valuestore.addCallbackAndRunD(v => el.value = ""+valuestore.data) | ||
|  |         return el; | ||
|  |     } | ||
|  | 
 | ||
|  |     IsValid(t: number): boolean { | ||
|  |         return Math.round(t) == t && t >= this.min && t <= this.max; | ||
|  |     } | ||
|  | 
 | ||
|  | } |