Interface SvelteReactive
get activeWindow(): Window;
set activeWindow(activeWindow: Window): void;
get draggable(): boolean;
set draggable(draggable: boolean): void;
get dragging(): boolean;
get focusAuto(): boolean;
set focusAuto(focusAuto: boolean): void;
get focusKeep(): boolean;
set focusKeep(focusKeep: boolean): void;
get focusTrap(): boolean;
set focusTrap(focusTrap: boolean): void;
get headerButtonNoClose(): boolean;
set headerButtonNoClose(headerButtonNoClose: boolean): void;
get headerButtonNoLabel(): boolean;
set headerButtonNoLabel(headerButtonNoLabel: boolean): void;
get headerIcon(): string;
set headerIcon(headerIcon: string): void;
get headerNoTitleMinimized(): boolean;
set headerNoTitleMinimized(headerNoTitleMinimized: boolean): void;
get minimizable(): boolean;
set minimizable(minimizable: boolean): void;
get minimized(): boolean;
get popOut(): boolean;
set popOut(popOut: boolean): void;
get positionable(): boolean;
set positionable(positionable: boolean): void;
get resizable(): boolean;
set resizable(resizable: boolean): void;
get resizing(): boolean;
get sessionStorage(): WebStorage;
get storeAppOptions(): StoreAppOptions;
get storeUIState(): StoreUIOptions;
get title(): string;
set title(title: string): void;
getOptions(accessor: string, defaultValue?: any): any;
mergeOptions(options: object): void;
setOptions(accessor: string, value: any): void;
toJSON(): SvelteReactiveData;
updateHeaderButtons(
opts?: { headerButtonNoClose?: boolean; headerButtonNoLabel?: boolean },
): void;
}
Index
Accessors
Methods
Accessors
activeWindow
- get activeWindow(): Window
Returns the current active Window / WindowProxy UI state.
Returns Window
Active window UI state.
- set activeWindow(activeWindow: Window): void
Sets the current active Window / WindowProxy UI state.
Note: This is protected usage and used internally.
Parameters
- activeWindow: Window
Active Window / WindowProxy UI state.
Returns void
- activeWindow: Window
draggable
- get draggable(): boolean
Returns the draggable app option.
Returns boolean
Draggable app option.
- set draggable(draggable: boolean): void
Sets
this.options.draggable
which is reactive for application shells.Parameters
- draggable: boolean
Sets the draggable option.
Returns void
- draggable: boolean
dragging
- get dragging(): boolean
Returns the current dragging UI state.
Returns boolean
Dragging UI state.
focusAuto
- get focusAuto(): boolean
Returns the focusAuto app option.
Returns boolean
When true auto-management of app focus is enabled.
- set focusAuto(focusAuto: boolean): void
Sets
this.options.focusAuto
which is reactive for application shells.Parameters
- focusAuto: boolean
Sets the focusAuto option.
Returns void
- focusAuto: boolean
focusKeep
- get focusKeep(): boolean
Returns the focusKeep app option.
Returns boolean
When
focusAuto
andfocusKeep
is true; keeps internal focus.- set focusKeep(focusKeep: boolean): void
Sets
this.options.focusKeep
which is reactive for application shells.Parameters
- focusKeep: boolean
Sets the focusKeep option.
Returns void
- focusKeep: boolean
focusTrap
- get focusTrap(): boolean
Returns the focusTrap app option.
Returns boolean
When true focus trapping / wrapping is enabled keeping focus inside app.
- set focusTrap(focusTrap: boolean): void
Sets
this.options.focusTrap
which is reactive for application shells.Parameters
- focusTrap: boolean
Sets the focusTrap option.
Returns void
- focusTrap: boolean
headerButtonNoClose
- get headerButtonNoClose(): boolean
Returns the headerButtonNoClose app option.
Returns boolean
Remove the close the button in header app option.
- set headerButtonNoClose(headerButtonNoClose: boolean): void
Sets
this.options.headerButtonNoClose
which is reactive for application shells.Parameters
- headerButtonNoClose: boolean
Sets the headerButtonNoClose option.
Returns void
- headerButtonNoClose: boolean
headerButtonNoLabel
- get headerButtonNoLabel(): boolean
Returns the headerButtonNoLabel app option.
Returns boolean
Remove the labels from buttons in header app option.
- set headerButtonNoLabel(headerButtonNoLabel: boolean): void
Sets
this.options.headerButtonNoLabel
which is reactive for application shells.Parameters
- headerButtonNoLabel: boolean
Sets the headerButtonNoLabel option.
Returns void
- headerButtonNoLabel: boolean
headerIcon
- get headerIcon(): string
Returns the headerIcon app option.
Returns string
URL for header app icon.
- set headerIcon(headerIcon: string): void
Sets
this.options.headerIcon
which is reactive for application shells.Parameters
- headerIcon: string
Sets the headerButtonNoLabel option.
Returns void
- headerIcon: string
headerNoTitleMinimized
- get headerNoTitleMinimized(): boolean
Returns the headerNoTitleMinimized app option.
Returns boolean
When true removes the header title when minimized.
- set headerNoTitleMinimized(headerNoTitleMinimized: boolean): void
Sets
this.options.headerNoTitleMinimized
which is reactive for application shells.Parameters
- headerNoTitleMinimized: boolean
Sets the headerNoTitleMinimized option.
Returns void
- headerNoTitleMinimized: boolean
minimizable
- get minimizable(): boolean
Returns the minimizable app option.
Returns boolean
Minimizable app option.
- set minimizable(minimizable: boolean): void
Sets
this.options.minimizable
which is reactive for application shells that are also pop out.Parameters
- minimizable: boolean
Sets the minimizable option.
Returns void
- minimizable: boolean
minimized
- get minimized(): boolean
Returns the current minimized UI state.
Returns boolean
Minimized UI state.
popOut
- get popOut(): boolean
Returns the Foundry popOut state; ApplicationOptions.popOut
Returns boolean
Positionable app option.
- set popOut(popOut: boolean): void
Sets
this.options.popOut
which is reactive for application shells. This will add / remove this application fromui.windows
.Parameters
- popOut: boolean
Sets the popOut option.
Returns void
- popOut: boolean
positionable
- get positionable(): boolean
Returns the positionable app option; SvelteApp.Options.positionable
Returns boolean
Positionable app option.
- set positionable(positionable: boolean): void
Sets
this.options.positionable
enabling / disabling SvelteApplication.position.Parameters
- positionable: boolean
Sets the positionable option.
Returns void
- positionable: boolean
resizable
- get resizable(): boolean
Returns the resizable option.
Returns boolean
Resizable app option.
- set resizable(resizable: boolean): void
Sets
this.options.resizable
which is reactive for application shells.Parameters
- resizable: boolean
Sets the resizable option.
Returns void
- resizable: boolean
resizing
- get resizing(): boolean
Returns the current resizing UI state.
Returns boolean
Resizing UI state.
sessionStorage
- get sessionStorage(): WebStorage
Returns WebStorage
Returns WebStorage (session) instance.
storeAppOptions
- get storeAppOptions(): StoreAppOptions
Returns the store for app options.
Returns StoreAppOptions
App options store.
storeUIState
- get storeUIState(): StoreUIOptions
Returns the store for UI options.
Returns StoreUIOptions
UI options store.
title
- get title(): string
Returns the title accessor from the parent Application class; ApplicationOptions.title
Returns string
Title.
- set title(title: string): void
Sets
this.options.title
which is reactive for application shells.Note: Will set empty string if title is undefined or null.
Parameters
- title: string
Application title; will be localized, so a translation key is fine.
Returns void
- title: string
Methods
getOptions
- getOptions(accessor: string, defaultValue?: any): any
Provides a way to safely get this applications options given an accessor string which describes the entries to walk. To access deeper entries into the object format the accessor string with
.
between entries to walk.Parameters
- accessor: string
The path / key to set. You can set multiple levels.
Optional
defaultValue: anyA default value returned if the accessor is not found.
Returns any
Value at the accessor.
- accessor: string
mergeOptions
setOptions
- setOptions(accessor: string, value: any): void
Provides a way to safely set this applications options given an accessor string which describes the entries to walk. To access deeper entries into the object format the accessor string with
.
between entries to walk.Additionally, if an application shell Svelte component is mounted and exports the
appOptions
property then the application options is set toappOptions
potentially updating the application shell / Svelte component.Parameters
- accessor: string
The path / key to set. You can set multiple levels.
- value: any
Value to set.
Returns void
- accessor: string
toJSON
- toJSON(): SvelteReactiveData
Serializes the main SvelteApp.Options for common application state.
Returns SvelteReactiveData
updateHeaderButtons
- updateHeaderButtons(
opts?: { headerButtonNoClose?: boolean; headerButtonNoLabel?: boolean },
): void Updates the UI Options store with the current header buttons. You may dynamically add / remove header buttons if using an application shell Svelte component. In either overriding
_getHeaderButtons
or responding to the Hooks fired return a new button array and the uiOptions store is updated and the application shell will render the new buttons.Optionally you can set in the SvelteApplication app options SvelteApp.Options.headerButtonNoClose to remove the close button and SvelteApp.Options.headerButtonNoLabel to true and labels will be removed from the header buttons.
Parameters
Returns void
Contains the reactive functionality / Svelte stores associated with SvelteApplication and retrievable by SvelteApplication.reactive.
There are several reactive getters for UI state such and for two-way bindings / stores see SvelteReactive.storeUIState:
There are also reactive getters / setters for SvelteApp.Options and Foundry ApplicationOptions. You can use the following as one way bindings and update the associated stores. For two-way bindings / stores see SvelteReactive.storeAppOptions.
An instance of TJSWebStorage (session) / TJSSessionStorage is accessible via SvelteReactive.sessionStorage. Optionally you can pass in an existing TJSWebStorage instance that can be shared across multiple SvelteApplications by setting SvelteApp.Options.sessionStorage.
This API is not sealed, and it is recommended that you extend it with accessors to get / set data that is reactive in your application. An example of setting an exported prop
document
from the main mounted application shell.Example