forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			87 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
	
		
			3.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { UIEventSource } from "../Logic/UIEventSource"
 | 
						|
import { QueryParameters } from "../Logic/Web/QueryParameters"
 | 
						|
import Hash from "../Logic/Web/Hash"
 | 
						|
 | 
						|
export class DefaultGuiState {
 | 
						|
    static state: DefaultGuiState
 | 
						|
    public readonly welcomeMessageIsOpened: UIEventSource<boolean>
 | 
						|
    public readonly downloadControlIsOpened: UIEventSource<boolean>
 | 
						|
    public readonly filterViewIsOpened: UIEventSource<boolean>
 | 
						|
    public readonly copyrightViewIsOpened: UIEventSource<boolean>
 | 
						|
    public readonly currentViewControlIsOpened: UIEventSource<boolean>
 | 
						|
    public readonly welcomeMessageOpenedTab: UIEventSource<number>
 | 
						|
    public readonly allFullScreenStates: UIEventSource<boolean>[] = []
 | 
						|
 | 
						|
    constructor() {
 | 
						|
        this.welcomeMessageOpenedTab = UIEventSource.asFloat(
 | 
						|
            QueryParameters.GetQueryParameter(
 | 
						|
                "tab",
 | 
						|
                "0",
 | 
						|
                `The tab that is shown in the welcome-message.`
 | 
						|
            )
 | 
						|
        )
 | 
						|
        this.welcomeMessageIsOpened = QueryParameters.GetBooleanQueryParameter(
 | 
						|
            "welcome-control-toggle",
 | 
						|
            false,
 | 
						|
            "Whether or not the welcome panel is shown"
 | 
						|
        )
 | 
						|
        this.downloadControlIsOpened = QueryParameters.GetBooleanQueryParameter(
 | 
						|
            "download-control-toggle",
 | 
						|
            false,
 | 
						|
            "Whether or not the download panel is shown"
 | 
						|
        )
 | 
						|
        this.filterViewIsOpened = QueryParameters.GetBooleanQueryParameter(
 | 
						|
            "filter-toggle",
 | 
						|
            false,
 | 
						|
            "Whether or not the filter view is shown"
 | 
						|
        )
 | 
						|
        this.copyrightViewIsOpened = QueryParameters.GetBooleanQueryParameter(
 | 
						|
            "copyright-toggle",
 | 
						|
            false,
 | 
						|
            "Whether or not the copyright view is shown"
 | 
						|
        )
 | 
						|
        this.currentViewControlIsOpened = QueryParameters.GetBooleanQueryParameter(
 | 
						|
            "currentview-toggle",
 | 
						|
            false,
 | 
						|
            "Whether or not the current view box is shown"
 | 
						|
        )
 | 
						|
        const states = {
 | 
						|
            download: this.downloadControlIsOpened,
 | 
						|
            filters: this.filterViewIsOpened,
 | 
						|
            copyright: this.copyrightViewIsOpened,
 | 
						|
            currentview: this.currentViewControlIsOpened,
 | 
						|
            welcome: this.welcomeMessageIsOpened,
 | 
						|
        }
 | 
						|
        Hash.hash.addCallbackAndRunD((hash) => {
 | 
						|
            hash = hash.toLowerCase()
 | 
						|
            states[hash]?.setData(true)
 | 
						|
        })
 | 
						|
 | 
						|
        if (Hash.hash.data === "" || Hash.hash.data === undefined) {
 | 
						|
            this.welcomeMessageIsOpened.setData(true)
 | 
						|
        }
 | 
						|
 | 
						|
        this.allFullScreenStates.push(
 | 
						|
            this.downloadControlIsOpened,
 | 
						|
            this.filterViewIsOpened,
 | 
						|
            this.copyrightViewIsOpened,
 | 
						|
            this.welcomeMessageIsOpened,
 | 
						|
            this.currentViewControlIsOpened
 | 
						|
        )
 | 
						|
 | 
						|
        for (let i = 0; i < this.allFullScreenStates.length; i++) {
 | 
						|
            const fullScreenState = this.allFullScreenStates[i]
 | 
						|
            for (let j = 0; j < this.allFullScreenStates.length; j++) {
 | 
						|
                if (i == j) {
 | 
						|
                    continue
 | 
						|
                }
 | 
						|
                const otherState = this.allFullScreenStates[j]
 | 
						|
                fullScreenState.addCallbackAndRunD((isOpened) => {
 | 
						|
                    if (isOpened) {
 | 
						|
                        otherState.setData(false)
 | 
						|
                    }
 | 
						|
                })
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |