47 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {Store} from "../../Logic/UIEventSource"
 | |
| import Translations from "../i18n/Translations"
 | |
| import {OsmConnection} from "../../Logic/Osm/OsmConnection"
 | |
| import Toggle from "../Input/Toggle"
 | |
| import BaseUIElement from "../BaseUIElement"
 | |
| import Combine from "../Base/Combine"
 | |
| import Svg from "../../Svg"
 | |
| import {LoginToggle} from "./LoginButton";
 | |
| 
 | |
| export class EditButton extends Toggle {
 | |
|     constructor(osmConnection: OsmConnection, onClick: () => void) {
 | |
|         super(
 | |
|             new Combine([Svg.pencil_svg()])
 | |
|                 .SetClass("block relative h-10 w-10 p-2 float-right")
 | |
|                 .SetStyle("border: 1px solid black; border-radius: 0.7em")
 | |
|                 .onClick(onClick),
 | |
|             undefined,
 | |
|             osmConnection.isLoggedIn
 | |
|         )
 | |
|     }
 | |
| }
 | |
| 
 | |
| export class SaveButton extends LoginToggle {
 | |
|     constructor(
 | |
|         value: Store<any>,
 | |
|         state: {
 | |
|             readonly osmConnection?: OsmConnection
 | |
|             readonly featureSwitchUserbadge?: Store<boolean>
 | |
|         },
 | |
|         textEnabled?: BaseUIElement,
 | |
|         textDisabled?: BaseUIElement
 | |
|     ) {
 | |
|         if (value === undefined) {
 | |
|             throw "No event source for savebutton, something is wrong"
 | |
|         }
 | |
| 
 | |
|         const isSaveable = value.map((v) => v !== false && (v ?? "") !== "")
 | |
| 
 | |
|         const saveEnabled = (textEnabled ?? Translations.t.general.save.Clone()).SetClass(`btn`)
 | |
|         const saveDisabled = (textDisabled ?? Translations.t.general.save.Clone()).SetClass(
 | |
|             `btn btn-disabled`
 | |
|         )
 | |
| 
 | |
|         const save = new Toggle(saveEnabled, saveDisabled, isSaveable)
 | |
|         super(save, Translations.t.general.loginToStart, state)
 | |
|     }
 | |
| }
 |