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.

import { hasSetter } from '#runtime/util/object';

// Note: make a normal comment.
// * @member {object} document - Adds accessors to SvelteReactive to get / set the document associated with
// * Document with the mounted application shell Svelte component.
// *
// * @memberof SvelteReactive#
// *
Object.defineProperty(this.reactive, 'document', {
get: () => this.svelte?.applicationShell?.document,
set: (document) =>
{
const component = this.svelte?.applicationShell;
if (hasSetter(component, 'document')) { component.document = document; }
}
});
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;
}

Accessors

  • 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

  • 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

  • get dragging(): boolean
  • Returns the current dragging UI state.

    Returns boolean

    Dragging UI state.

  • 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

  • get focusKeep(): boolean
  • Returns the focusKeep app option.

    Returns boolean

    When focusAuto and focusKeep 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

  • 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

  • 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

  • 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

  • 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

  • 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

  • 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

  • get minimized(): boolean
  • Returns the current minimized UI state.

    Returns boolean

    Minimized UI state.

  • 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 from ui.windows.

    Parameters

    • popOut: boolean

      Sets the popOut option.

    Returns void

  • 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

  • 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

  • get resizing(): boolean
  • Returns the current resizing UI state.

    Returns boolean

    Resizing UI state.

  • 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

Methods

  • 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.

    • OptionaldefaultValue: any

      A default value returned if the accessor is not found.

    Returns any

    Value at the accessor.

  • Provides a way to merge options into this applications options and update the appOptions store.

    Parameters

    • options: object

      The options object to merge with this.options.

    Returns 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 to appOptions 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

  • 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

    • Optionalopts: { headerButtonNoClose?: boolean; headerButtonNoLabel?: boolean }

      Optional parameters (for internal use)

      • OptionalheaderButtonNoClose?: boolean

        The value for headerButtonNoClose.

      • OptionalheaderButtonNoLabel?: boolean

        The value for headerButtonNoLabel.

    Returns void