forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			38 lines
		
	
	
		
			No EOL
		
	
	
		
			1,000 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
		
			No EOL
		
	
	
		
			1,000 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {UIElement} from "../UIElement";
 | |
| 
 | |
| export class Button extends UIElement {
 | |
|     private _text: UIElement;
 | |
|     private _onclick: () => void;
 | |
|     private _clss: string;
 | |
| 
 | |
|     constructor(text: UIElement, onclick: (() => void), clss: string = "") {
 | |
|         super(undefined);
 | |
|         this._text = text;
 | |
|         this._onclick = onclick;
 | |
|         if (clss !== "") {
 | |
| 
 | |
|             this._clss = "class='" + clss + "'";
 | |
|         }else{
 | |
|             this._clss = "";
 | |
|         }
 | |
|     }
 | |
| 
 | |
| 
 | |
|     protected InnerRender(): string {
 | |
| 
 | |
|         return "<form>" +
 | |
|             "<button id='button-"+this.id+"' type='button' "+this._clss+">" + this._text.Render() +  "</button>" +
 | |
|             "</form>";
 | |
|     }
 | |
| 
 | |
|     InnerUpdate(htmlElement: HTMLElement) {
 | |
|         super.InnerUpdate(htmlElement);
 | |
|         const self = this;
 | |
|         console.log("Update for ", htmlElement)
 | |
|         document.getElementById("button-"+this.id).onclick = function(){
 | |
|             console.log("Clicked");
 | |
|             self._onclick();
 | |
|         }
 | |
|     }
 | |
| 
 | |
| } |