Foundry Virtual Tabletop - API Documentation - Version 14
    Preparing search index...

    Class RegionBehaviorTypeAbstract

    The data model for a behavior that receives Region events.

    Hierarchy (View Summary)

    Index

    Constructors

    Properties

    _source: object

    The source data object for this DataModel instance. Once constructed, the source object is sealed such that no keys may be added nor removed.

    events: Set<string> = ...

    The events that are handled by the behavior.

    parent: DataModel<object, DataModelConstructionContext> | null

    An immutable reverse-reference to a parent DataModel to which this model belongs.

    The defined and cached Data Schema for all instances of this DataModel.

    events: Record<
        string,
        (this: RegionBehaviorType, event: RegionEvent) => Promise<void>,
    > = {}

    The Region events that are handled by the behavior.

    LOCALIZATION_PREFIXES: any[] = []

    A set of localization prefix paths which are used by this DataModel. This provides an alternative to defining the label and hint property of each field by having foundry map the labels to a structure inside the path provided by the prefix.

    JavaScript class definition and localization call.

    class MyDataModel extends foundry.abstract.DataModel {
    static defineSchema() {
    return {
    foo: new foundry.data.fields.StringField(),
    bar: new foundry.data.fields.NumberField()
    };
    }
    static LOCALIZATION_PREFIXES = ["MYMODULE.MYDATAMODEL"];
    }

    Hooks.on("i18nInit", () => {
    // Foundry will attempt to automatically localize models registered for a document subtype, so this step is only
    // needed for other data model usage, e.g. for a Setting.
    Localization.localizeDataModel(MyDataModel);
    });

    JSON localization file

    {
    "MYMODULE": {
    "MYDATAMODEL": {
    "FIELDS" : {
    "foo": {
    "label": "Foo",
    "hint": "Instructions for foo"
    },
    "bar": {
    "label": "Bar",
    "hint": "Instructions for bar"
    }
    }
    }
    }
    }

    Accessors

    • get invalid(): boolean

      Is the current state of this DataModel invalid? The model is invalid if there is any unresolved failure.

      Returns boolean

    • get region(): RegionDocument | null

      A convenience reference to the RegionDocument which contains this behavior sub-type.

      Returns RegionDocument | null

    • get scene(): documents.Scene | null

      A convenience reference to the Scene which contains this behavior sub-type.

      Returns documents.Scene | null

    Methods

    • Traverse the data model instance, obtaining the DataField definition for a field of a particular property.

      Parameters

      • key: string | string[]

        A property key like ["abilities", "strength"] or "abilities.strength"

      Returns DataField | undefined

      The corresponding DataField definition for that field, or undefined

    • Specific callback actions to take when the embedded HTML for this Document has been added to the DOM.

      Parameters

      • element: HTMLDocumentEmbedElement

        The embedded document HTML

      Returns void

    • Prepare data related to this DataModel itself, before any derived data (including Active Effects) is computed. This is especially useful for initializing numbers, arrays, and sets you expect to be modified by active effects.

      Called before ClientDocument#prepareBaseData in ClientDocument#prepareData.

      Returns void

      prepareBaseData() {
      // Ensures an active effect of `system.encumbrance.max | ADD | 10` doesn't produce `NaN`
      this.encumbrance = {
      max: 0
      }
      // If you need to access the owning Document, `this.parent` provides a reference for properties like the name
      // or embedded collections, e.g. `this.parent.name` or `this.parent.items`
      }
    • Apply transformations or derivations to the values of the source data object. Compute data fields whose values are not stored to the database.

      Called before ClientDocument#prepareDerivedData in ClientDocument#prepareData.

      Returns void

      prepareDerivedData() {
      this.hp.bloodied = Math.floor(this.hp.max / 2);

      // this.parent accesses the Document, allowing access to embedded collections
      this.encumbrance.value = this.parent.items.reduce((total, item) => {
      total += item.system.weight;
      return total;
      }, 0)
      }
    • Reset the state of this data instance back to mirror the contained source data, erasing any changes.

      Returns void

    • Convert this Document to some HTML display for embedding purposes.

      Parameters

      • config: DocumentHTMLEmbedConfig

        Configuration for embedding behavior.

      • Optionaloptions: any = {}

        The original enrichment options for cases where the Document embed content also contains text that must be enriched.

      Returns Promise<any>

    • Extract the source data for the DataModel into a simple object format that can be serialized.

      Returns object

      The document source data expressed as a plain object

    • Copy and transform the DataModel into a plain object. Draw the values of the extracted object from the data source (by default) otherwise from its transformed values.

      Parameters

      • Optionalsource: boolean = true

        Draw values from the underlying data source rather than transformed values

      Returns object

      The extracted primitive object

    • Update the DataModel locally by applying an object of changes to its source data. The provided changes are expanded, cleaned, validated, and stored to the source data object for this model. The provided changes argument is mutated in this process. The source data is then re-initialized to apply those changes to the prepared data. The method returns an object of differential changes which modified the original data.

      Parameters

      • changes: object = {}

        New values which should be applied to the data model

      • options: DataModelUpdateOptions = {}

        Options which determine how the new data is merged

      Returns object

      An object containing differential keys and values that were changed

      An error if the requested data model changes were invalid

    • Validate the data contained in the document to check for type and content. This method is intended to validate complete model records, verifying both individual field validation as well as joint model validity.

      For validating sets of partial model changes, it is preferred to call DataModel#updateSource as a dryRun. This method provides a convenience alias for such a workflow if changes are provided.

      Warning: if fallback handling is allowed, this process will mutate provided changes or model source data.

      Parameters

      Returns boolean

      Whether the data source or proposed change is reported as valid. A boolean is always returned if validation is non-strict.

      An error thrown if validation is strict and a failure occurs.

    • Protected

      Configure the data model instance before validation and initialization workflows are performed.

      Parameters

      • Optionaloptions: object = {}

        Additional options modifying the configuration

      Returns void

    • Protected

      Get the terrain effects of this behavior for the movement of the given token. This function is called only for behaviors that are not disabled. The terrain data is created from the terrain effects (CONFIG.Token.movement.TerrainData.resolveTerrainEffects). Returns an empty array by default.

      Type Parameters

      • TerrainEffect

      Parameters

      • token: TokenDocument

        The token being or about to be moved within the region of this behavior

      • segment: Pick<TokenMovementWaypoint, "width" | "height" | "shape" | "level" | "action"> & {
            preview: boolean;
        }

        The segment data of the token's movement

      • Optionaloptions: Omit<TokenCreateTerrainMovementPathOptions, "preview">

        Additional options

      Returns TerrainEffect[]

      The terrain effects that apply to this token's movement

    • Protected

      Handle the Region event.

      Parameters

      Returns Promise<void>

    • Protected

      A generator that orders the DataFields in the DataSchema into an expected initialization order.

      Returns Generator<[string, DataField], any, any>

    • Protected

      Initialize the instance by copying data from the source object to instance attributes. This mirrors the workflow of SchemaField#initialize but with some added functionality.

      Parameters

      • Optionaloptions: object = {}

        Options provided to the model constructor

      Returns void

    • Protected

      Called by ClientDocument#_onCreate.

      Parameters

      • data: object

        The initial data object provided to the document creation request

      • options: object

        Additional options which modify the creation request

      • userId: string

        The id of the User requesting the document update

      Returns void

    • Protected

      Called by ClientDocumentMixin#_onDelete.

      Parameters

      • options: object

        Additional options which modify the deletion request

      • userId: string

        The id of the User requesting the document update

      Returns void

    • Protected

      Called by ClientDocumentMixin#_onUpdate.

      Parameters

      • changed: object

        The differential data that was changed relative to the documents prior values

      • options: object

        Additional options which modify the update request

      • userId: string

        The id of the User requesting the document update

      Returns void

    • Protected

      Called by ClientDocument#_preCreate.

      Parameters

      • data: object

        The initial data object provided to the document creation request

      • options: object

        Additional options which modify the creation request

      • user: BaseUser

        The User requesting the document creation

      Returns Promise<boolean | void>

      Return false to exclude this Document from the creation operation

    • Protected

      Called by ClientDocumentMixin#_preDelete.

      Parameters

      • options: object

        Additional options which modify the deletion request

      • user: BaseUser

        The User requesting the document deletion

      Returns Promise<boolean | void>

      A return value of false indicates the deletion operation should be cancelled.

    • Protected

      Called by ClientDocumentMixin#_preUpdate.

      Parameters

      • changes: object

        The candidate changes to the Document

      • options: object

        Additional options which modify the update request

      • user: BaseUser

        The User requesting the document update

      Returns Promise<boolean | void>

      A return value of false indicates the update operation should be cancelled.

    • Protected

      Perform the second step of the DataModel#_updateSource workflow which applies the prepared diff to the model.

      Parameters

      • copy: object

        The prepared copy of source data with changes applied

      • diff: object

        The differential changes that were applied to source

      • options: DataModelUpdateOptions

        Options which determine how the new data is merged

      • _state: data.types.DataModelUpdateState

        Data cleaning state which might include instructions for final commit

      Returns void

    • Protected

      Perform the first step of the DataModel#_updateSource workflow which applies changes to a copy of model source data and records the resulting diff.

      Parameters

      • copy: object

        A mutable copy of model source data

      • changes: object

        New values which should be applied to the data model

      • options: DataModelUpdateOptions

        Options which determine how the new data is merged

      • _state: data.types.DataModelUpdateState

        Data cleaning state

      Returns object

      The resulting difference applied to source data

      A failure if the proposed change is invalid

    • Define the data schema for models of this type. The schema is populated the first time it is accessed and cached for future reuse.

      The schema, through its fields, provide the essential cleaning, validation, and initialization methods to turn the _source values into direct properties of the data model. The schema is a static property of the model and is reused by all instances to perform validation.

      The schemas defined by the core software in classes like foundry.documents.BaseActor are validated by the server, where user code does not run. However, almost all documents have a flags field to store data, and many have a system field that can be configured to be a foundry.abstract.TypeDataModel instance. Those models are not constructed on the server and rely purely on client-side code, which means certain extra-sensitive fields must be also be registered through your package manifest. foundry.packages.types.ServerSanitizationFields

      Returns DataSchema

      class SomeModel extends foundry.abstract.DataModel {
      static defineSchema() {
      return {
      foo: new foundry.data.fields.StringField()
      }
      }
      }

      class AnotherModel extends SomeModel {
      static defineSchema() {
      // Inheritance and object oriented principles apply to schema definition
      const schema = super.defineSchema()

      schema.bar = new foundry.data.fields.NumberField()

      return schema;
      }
      }
    • Wrap data migration in a try/catch which attempts it safely.

      Parameters

      • source: object

        Candidate source data for the module, before further cleaning

      • Optionaloptions: Readonly<DataModelCleaningOptions> = {}

        Additional options for how the field is cleaned

      Returns object

      Migrated source data, ready for further cleaning

    • Take data which conforms to the current data schema and add backwards-compatible accessors to it in order to support older code which uses this data.

      Parameters

      • data: object

        Data which matches the current schema

      • Optionaloptions: { embedded?: boolean } = {}

        Additional shimming options

        • Optionalembedded?: boolean

          Apply shims to embedded models?

      Returns object

      Data with added backwards-compatible properties, which is the same object as the data argument

    • Evaluate joint validation rules which apply validation conditions across multiple fields of the model. Field-specific validation rules should be defined as part of the DataSchema for the model. This method allows for testing aggregate rules which impose requirements on the overall model.

      Parameters

      • data: object

        Candidate data for the model

      Returns void

      An error if a validation failure is detected

    • Protected

      Apply final custom model-specific cleaning rules after data schema fields are cleaned. Subclass models can implement this function as an ideal place to apply custom imputation or cleaning. Cleaning must be done in-place rather than returning a different object.

      Parameters

      Returns object

      The original data object, with cleaning performed inplace

    • Protected

      Create the events field.

      Parameters

      • options: { events?: string[]; initial?: string[] } = {}

        Options which configure how the events field is declared

        • Optionalevents?: string[]

          The event names to restrict to.

        • Optionalinitial?: string[]

          The initial set of events that should be default for the field

      Returns SetField