Extend the base Actor class to implement additional game system logic.

Hierarchy (View Summary)

Constructors

Properties

Accessors

Methods

_addSourceDetail _applyArmorPenalties _calculateCoinWeight _cleanItemLinksTo _computeEncumbrance _conditionToggleNotify _configure _finalizeTraits _generateSpellbookCache _getContextConditions _getInherentTotalsKeys _handleConditionTracks _initialize _onCreateDescendantDocuments _onDeleteDescendantDocuments _onUpdate _prepareArmorData _prepareChanges _prepareClassSkills _prepareContainerItems _prepareItemFlags _prepareNaturalReach _prepareOverlandSpeeds _prepareSenses _prepareTraits _prepareTypeChanges _preUpdate _resetInherentTotals _restingHeal _setSourceDetails _updateSpellBook addTempHP applyActiveEffects applyDamage convertCurrency createSpellbook displayDefenseCard enrichContextNotes expireActiveEffects getCarriedWeight getCarryCapacity getCombatants getConditionImmunities getContextNotes getContextNotesParsed getCurrency getDefenseHeaders getFeatCount getInitiativeOptions getItemByTag getLabels getLevelExp getQuickActions getRollData getSkillInfo getTokenDocument getTotalCurrency getWoundThresholdData getWoundThresholdMultiplier hasArmorProficiency hasCondition hasItemBooleanFlag hasWeaponProficiency modifyTokenAttribute parseResistances performRest prepareBaseData prepareCMB prepareConditions prepareDerivedData prepareItemLinks prepareSpecificDerivedData rechargeItems refreshAbilityModifiers refreshDerivedData reset resetSpellbookUsage rollAbilityTest rollAttack rollBAB rollCL rollConcentration rollInitiative rollSavingThrow rollSkill setCondition setConditions toggleCondition toggleStatusEffect updateItemResources updateSpellbookInfo updateTokenSize updateVision updateWoundThreshold _getSourceLabel applyDamage getDefaultArtwork getReach getReducedMovementSpeed getSpellSlotIncrease

Constructors

  • Parameters

    • data: undefined | ActorDataConstructorData

      Initial data provided to construct the Actor document

    • Optionalcontext: Context<TokenDocument>

      The document context, see foundry.abstract.Document

    Returns ActorPF

Properties

_initialized: undefined | boolean
_itemTypes: ItemTypesMap

Cached result of .itemTypes

_rollData: any
changeFlags: undefined | {}
changes: undefined | Collection<any>
classes: undefined | {}
containerItems: undefined | ItemPF[]
equipment:
    | undefined
    | { armor: { id: undefined; type: 0 }; shield: { id: undefined; type: 0 } }
sourceDetails: undefined | {}
sourceInfo: undefined | Record<string, SourceInfo>

Accessors

  • get activeOwner(): null | User
  • Returns first active owner, favoring players and GM as fallback.

    Returns null | User

Methods

  • Internal

    Parameters

    • conditions: Record<string, boolean> = {}

      Condition toggle state

    Returns void

    • The condition notification needs to be smarter.
  • Protected

    Finalize preparing armor, weapon, and language proficiencies and other traits.

    Called in prepareDerivedData()

    Returns void

  • Internal

    Collect some basic spellbook info so it doesn't need to be gathered again for each spellbook.

    Returns object

    Spellbook cache

  • Internal

    Get active conditions marked for context

    Parameters

    • context: string

      Context ID

    Returns model[]

    • Array of conditions
  • Internal

    Handle condition track toggling post active effect creation if there's still some issues.

    Parameters

    • documents: ActiveEffect[]

      Updated active effect documents

    Returns Promise<object>

  • Internal

    Parameters

    • parent: Actor | Item

      Parent document

    • collection: "effects" | "items"

      Collection name

    • documents: ActiveEffect[] | Item[]

      Created documents

    • result: object[]

      Creation data for the documents

    • context: object

      Create context options

    • userId: string

      Triggering user's ID

    • ...args: any

    Returns void

  • Internal

    Parameters

    • parent: any

      Parent document

    • collection: "effects" | "items"

      Collection name

    • documents: Item | ActiveEffect[]

      Document array

    • ids: string[]

      Document ID array

    • context: object

      Delete context

    • userId: string

      User ID

    Returns void

  • Parameters

    • changed: object

      Changed data

    • context: object

      Context

    • userId: string

      User ID

    Returns void

  • Internal

    Prepare armor/shield data for roll data

    Parameters

    • equipment: { id: string; type: string } = {}

      Equipment info

      • id: string

        Item ID

      • type: string

        Armor/Shield type

    • armorData: object

      Armor data object

    Returns void

  • Internal

    Parameters

    • changed: object

      Changed data

    • context: object

      Context

    • user: User

      Triggering user

    Returns Promise<void>

  • Protected

    Handler for character healing during rest.

    Parameters

    • options: object = {}

      Resting options.

    Returns object

    Update data object

  • Internal

    Update specific spellbook.

    Parameters

    • bookId: string

      Spellbook identifier

    • OptionalrollData: object

      Roll data instance

    • cache: object

      Pre-calculated data for re-use from _generateSpellbookCache

    Returns void

  • Adjust temporary hit points.

    Parameters

    • value: number

      Value to add to temp HP

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

      Additional options

      • Optionalset?: boolean

        If true, the temporary hit points are set to the provide value instead of added to existing.

    Returns Promise<undefined | ActorPF>

    • Updated document or undefined if no update occurred

    Gain 50 THP

    actor.addTempHP(50);
    

    Lose 10 THP

    actor.addTempHP(-10);
    

    Set THP to zero

    actor.addTempHP(0, { set: true });
    
  • Wrapper for the static function, taking this actor as the only target.

    Parameters

    • value: number

      Value to adjust health by. Positive values deal damage, negative values heal.

    • options: ApplyDamageOptions = {}

      Additional options.

    Returns Promise<false | Actor[]>

    • Updated actor array or false.

    Cause 10 damage

    await actor.applyDamage(10);
    

    Heal 10 damage

    await actor.applyDamage(-10);
    

    Apply 3 damage directly to Wounds instead of Vigor

    await actor.applyDamage(3, { asWounds: true });
    
  • Converts currencies of the given category to the given currency type

    Parameters

    • Optionalcategory: "currency" | "altCurrency" = "currency"

      Currency category, altCurrency is for weightless

    • Optionaltype: "pp" | "gp" | "sp" | "cp" = "pp"

      Target currency.

    Returns undefined | Promise<ActorPF>

    Updated document or undefined if no update occurred.

  • Enable and configure a new spellbook.

    Parameters

    • Optionalcasting: {
          ability?: string;
          cantrips?: boolean;
          class?: string;
          domain?: number;
          offset?: number;
          progression?: "low" | "high" | "med";
          spells?: "arcane" | "divine" | "psychic" | "alchemy";
          type?: "prepared" | "spontaneous" | "hybrid";
      } = {}

      Book casting configuration

      • Optionalability?: string

        Spellcasting ability score ID

      • Optionalcantrips?: boolean

        Has cantrips?

      • Optionalclass?: string

        Class tag

      • Optionaldomain?: number

        Domain/School slots

      • Optionaloffset?: number

        Level offset

      • Optionalprogression?: "low" | "high" | "med"

        Casting progression type

      • Optionalspells?: "arcane" | "divine" | "psychic" | "alchemy"

        Spell/spellcasting type

      • Optionaltype?: "prepared" | "spontaneous" | "hybrid"

        Spellbook type

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

      Additional options

      • Optionalcommit?: boolean

        Commit modifications. If false, update data is returned instead of committing.

    Returns Promise<ActorPF>

    • Promise to updated document

    Create spellbook for inquisitor

    actor.createSpellbook({
    type: "spontaneous",
    progression: "med",
    ability: "wis",
    spells: "divine",
    class: "inquisitor",
    cantrips: true,
    domain: 0
    });
  • Show defenses in chat

    Parameters

    • Optionaloptions: { rollMode?: null | string; token?: TokenDocument } = {}

      Additional options

      • OptionalrollMode?: null | string

        The roll mode to use for the roll; defaults to the user's current preference when null.

      • Optionaltoken?: TokenDocument

        Relevant token if any.

    Returns undefined | ChatMessage

    • Created message
  • Enrich context notes with item specific roll data.

    Adds enriched array to each note object.

    Parameters

    • notes: ItemContextNotes

      Context notes

    • OptionalrollData: object

      Roll data instance

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

      Additional options

      • Optionalroll?: boolean

        Handle rolls

    Returns Promise<void>

  • Deletes expired temporary active effects and disables linked expired buffs.

    Parameters

    • Optionaloptions: {
          combat?: Combat;
          event?: string;
          initiative?: number;
          timeOffset?: number;
          worldTime?: number;
      } = {}

      Additional options

      • Optionalcombat?: Combat

        Combat to expire data in, if relevant

      • Optionalevent?: string

        Expiration event

      • Optionalinitiative?: number

        Initiative based expiration marker

      • OptionaltimeOffset?: number

        Time offset from world time

      • OptionalworldTime?: number

        World time

    • Optionalcontext: DocumentModificationContext = {}

      Document update context

    Returns Promise<void>

    • With insufficient permissions to control the actor.
  • Calculate current carry capacity limits.

    Returns { heavy: number; light: number; medium: number }

    • Capacity info
  • Generates an array with all the active context-sensitive notes for the given context on this actor.

    Parameters

    • context: string

      The context to draw from.

    • Optionalall: boolean = true

      Retrieve notes meant for all, such as notes targeting all skills.

    Returns ItemContextNotes[]

    • Context notes
  • Returns a list of already parsed context notes.

    Parameters

    • context: string

      The context to draw notes from.

    • Optionaloptions: { all?: boolean; roll?: boolean } = {}

      Additional options

      • Optionalall?: boolean

        Option to pass to getContextNotes

      • Optionalroll?: boolean

        Whether to roll inline rolls or not.

    Returns Promise<ParsedContextNoteEntry[]>

    The resulting notes, already parsed.

  • Get total currency in category.

    Parameters

    • Optionalcategory: "currency" | "altCurrency" = "currency"

      Currency category.

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

      Additional options

      • OptionalinLowestDenomination?: boolean

        Return result in lowest denomination (default copper). If false, returns standard currency (default gold) instead.

    Returns number

    • Total currency in category.
  • Protected

    Parameters

    • Optionaloptions: { damageResistances?: boolean; damageVulnerabilities?: boolean } = {}

      Additional options

      • OptionaldamageResistances?: boolean

        If false, damage resistances (DR, ER) are omitted.

      • OptionaldamageVulnerabilities?: boolean

        If false, damage vulnerabilities are omitted.

    Returns any

    • Header data
  • Return the amount of experience required to gain a certain character level.

    Parameters

    • level: number

      The desired level

    Returns number

    • The XP required
  • Retrieve data used to fill in roll variables.

    Parameters

    • Optionaloptions: { cache?: boolean; refresh?: boolean } = ...

      Additional options

      • Optionalcache?: boolean

        Use cache. If set to false, new fresh copy is returned without caching it.

      • Optionalrefresh?: boolean

        Refresh cache

    Returns object

    • Roll data object
    await new Roll("1d20 + @abilities.wis.mod[Wis]", actor.getRollData()).toMessage();
    
  • Retrieve information about a skill.

    Parameters

    • skillId: string

      Skill ID

    • Optionaloptions: { rollData?: { skills: { [key: string]: SkillData } } } = {}

      Additional options

      • OptionalrollData?: { skills: { [key: string]: SkillData } }

        Roll data instance to use.

    Returns SkillInfo

    • Skill information
    actor.getSkillInfo("per"); // Perception skill info
    actor.getSkillInfo("crf.alchemy"); // Craft (Alchemy) subskill info
    • If defined skill is not found.
  • Create a new Token document, not yet saved to the database, which represents the Actor, and apply actor size to it.

    Parameters

    • Optionaldata: object = {}

      Additional data, such as x, y, rotation, etc. for the created token data

    • Optionaloptions: object = {}

      The options passed to the TokenDocument constructor

    Returns Promise<TokenDocumentPF>

    The created TokenDocument instance

  • Total coinage in both weighted and weightless.

    Parameters

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

      Additional options

      • OptionalinLowestDenomination?: boolean

        Use copper for calculations and return.

    Returns number

    • The total amount of currency, in copper pieces.
  • Protected

    Returns Wound Threshold relevant data.

    Parameters

    • Optionaloptions: { healthConfig?: object } = {}

      Additional options

      • OptionalhealthConfig?: object

        PC/NPC health config variant data

    Returns { level: number; multiplier: number; penalty: number; valid: boolean }

    • Wound threshold info
  • Protected

    Returns effective Wound Threshold multiplier with rules and overrides applied.

    Parameters

    • Optionaloptions: { healthConfig?: object } = {}

      Additional options

      • OptionalhealthConfig?: object

        PC/NPC health config variant data

    Returns number

    Multiplier

  • Checks if there's any matching proficiency

    Parameters

    • item: ItemEquipmentPF

      The item to check for.

    Returns boolean

    Whether the actor is proficient with that item.

  • Easy way to determine whether this actor has a condition.

    Parameters

    • conditionId: string

      A direct condition key, as per pf1.registry.conditions, such as shaken or dazed.

    Returns boolean

    Condition state

    Test if user is grappled

    actor.hasCondition("grappled");
    

    This is identical to actor.statuses.has("conditionId")

  • Check if actor has item with specified boolean flag.

    Parameters

    • flagName: string

      The name/key of the flag to search for.

    Returns boolean

    Whether this actor has any owned item with the given flag.

  • Test if actor is proficient with specified weapon.

    Parameters

    • item: ItemPF

      Item to test

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

      Additional options

      • Optionaloverride?: boolean

        Allow item's proficiency override to influence the result.

    Returns boolean

    • Proficiency state

    Natural attacks incorrectly do not count as proficient.

  • Protected

    Parameters

    • attribute: any
    • value: any
    • isDelta: boolean = false
    • isBar: boolean = true

    Returns Promise<undefined | ActorPF>

  • Protected

    Helper function for actor energy resistance and damage reduction feedback.

    Parameters

    • damage: string

      Value to check resistances for. Either "dr" or "eres".

    Returns object

    Entry to label mapping of resistances or reductions.

  • Recharge all owned items.

    Parameters

    • Optionaloptions: any = {}

      Additional options

    Returns Promise<object[] | Item[]>

    • Result of an update or the update data.

    Recharge items with default settings.

    await actor.rechargeItems();
    

    Recharge items as if week had passed.

    await actor.rechargeItems({ period: "week" });
    
  • Internal

    Called just before the first change is applied, and after every change is applied. Sets additional variables (such as spellbook range)

    Returns void

  • Restore spellbook used slots and spellpoints.

    Parameters

    • Optionaloptions: { commit?: boolean; rollData?: object } = {}

      Additional options

      • Optionalcommit?: boolean

        If false, return update data object instead of directly updating the actor.

      • OptionalrollData?: object

        Roll data

    Returns Promise<object | ActorPF>

    Result of update or the update data.

  • Roll an Ability Test Prompt the user for input regarding Advantage/Disadvantage and any Situational Bonus

    Parameters

    • abilityId: "str" | "dex" | "con" | "int" | "wis" | "cha"

      The ability ID (e.g. "str")

    • Optionaloptions: ActorRollOptions = {}

      Additional options

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    await actor.rollAbilityTest("str");
    
  • Roll a generic attack

    Parameters

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    Basic ranged attack

    await actor.rollAttack({ ranged: true });
    

    Basic melee maneuver

    await actor.rollAttack({ maneuver: true });
    
  • Roll a Caster Level check using a particular spellbook of this actor

    Parameters

    • bookId: string

      Spellbook identifier

    • Optionaloptions: ActorRollOptions = {}

      Roll options

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    Roll caster level check for primary spellbook.

    await actor.rollCL("primary");
    
  • Roll a concentration check using a particular spellbook of this actor

    Parameters

    • bookId: string

      Spellbook identifier

    • Optionaloptions: ActorRollOptions = {}

      Roll options

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    Add support for concentration check type, e.g. defensive casting

  • Roll initiative for one or multiple Combatants associated with this actor. If no combat exists, GMs have the option to create one. If viewing a full Actor document, all Tokens which map to that actor will be targeted for initiative rolls. If viewing a synthetic Token actor, only that particular Token will be targeted for an initiative roll.

    Parameters

    • Optionaloptions: {
          bonus?: null | string;
          createCombatants?: boolean;
          dice?: null | string;
          initiativeOptions?: object;
          rerollInitiative?: boolean;
          rollMode?: string;
          skipDialog?: boolean;
          token?: TokenDocumentPF;
      } = {}

      Options which configure how initiative is rolled

      • Optionalbonus?: null | string

        Formula for bonus to initiative

      • OptionalcreateCombatants?: boolean

        Create new Combatant entries for tokens associated with this actor.

      • Optionaldice?: null | string

        Formula override for dice to roll

      • OptionalinitiativeOptions?: object

        Options to pass to ()

      • OptionalrerollInitiative?: boolean

        Reroll initiative for existing Combatants

      • OptionalrollMode?: string

        Roll mode override

      • OptionalskipDialog?: boolean

        Skip roll dialog

      • Optionaltoken?: TokenDocumentPF

        For which token this initiative roll is for

    Returns Promise<null | CombatPF>

    The updated Combat document in which initiative was rolled, or null if no initiative was rolled

    await actor.rollInitiative({ dice: "2d20kh", createCombatants: true, skipDialog: true });
    
  • Roll a specific saving throw

    Parameters

    • savingThrowId: "fort" | "ref" | "will"

      Identifier for saving throw type.

    • Optionaloptions: ActorRollOptions = {}

      Roll options.

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    await actor.rollSavingThrow("ref", { skipDialog: true, dice: "2d20kh", bonus: "4" });
    
  • Roll a Skill Check

    Parameters

    • skillId: string

      The skill id (e.g. "per", "prf.prf1", or "crf.alchemy")

    • Optionaloptions: ActorRollOptions = {}

      Options which configure how the skill check is rolled

    Returns Promise<void | object | ChatMessage>

    The chat message if one was created, or its data if not. void if the roll was cancelled.

    await actor.rollSkill("per", { skipDialog: true, bonus: "1d6", dice: "2d20kh" });
    
  • Easy way to set a condition.

    Parameters

    • conditionId: string

      A direct condition key, as per pf1.registry.conditions, such as shaken or dazed.

    • enabled: boolean | object

      Whether to enable (true) the condition, or disable (false) it. Or object for merging into the active effect as part of enabling.

    • Optionalcontext: object

      Update context

    Returns object

    Condition ID to boolean mapping of actual updates.

    Enable Dazzled

    await actor.setCondition("dazzled", true);
    

    Enable Sleep for 10 rounds

    await actor.setCondition("sleep", { duration: { seconds: 60 } });
    
  • Set state of multiple conditions. Also handles condition tracks to minimize number of updates.

    Parameters

    • conditions: object = {}

      Condition ID to boolean (or update data) mapping of new condition states. See ()

    • Optionalcontext: object = {}

      Update context

    Returns Record<string, boolean>

    Condition ID to boolean mapping of actual updates.

    Enable Blinded and Shaken conditions but disable Sleeping

    await actor.setConditions({ blind: true, sleep: false, shaken:true });
    
  • Easy way to toggle a condition.

    Parameters

    • conditionId: boolean

      A direct condition key, as per pf1.registry.conditions, such as shaken or dazed.

    • OptionalaeData: object

      Extra data to add to the AE if it's being enabled

    Returns object

    Condition ID to boolean mapping of actual updates.

    Toggle Dazzled

    await actor.toggleCondition("dazzled");
    

    Toggle Blinded, set duration for 3 rounds if it's being enabled.

    await actor.toggleCondition("blinded", { duration: { seconds: 18 } });
    
  • Internal

    Parameters

    • item: ItemPF

      the item to add to the actor's resources

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

      extra options

      • OptionalwarnOnDuplicate?: boolean

        Skips warning if item tag already exists in dictionary flags

    Returns boolean

    True if resources were set

  • Internal

    Update all spellbooks

    Parameters

    • OptionalrollData: object

      Roll data instance

    • Optionalcache: object

      Spellbook cache

    Returns void

  • Internal

    Resize token sizes based on actor size.

    Ignores tokens with static size set.

    Parameters

    • OptionalsizeKey: string = undefined

      Size key to update to. If not provided, will use actor's current size.

    Returns null | Promise<TokenDocument[]>

    • Updated token documents, or null if no update was performed.

    Add option to update token size on all scenes.

    • On invalid parameters
  • Internal

    Synchronize actor and token vision

    Parameters

    • initializeVision: boolean = false

      Initialize vision

    • refreshLighting: boolean = false

      Refresh lightning

    Returns void

  • Apply damage to the token or tokens which are currently controlled.

    If Shift is held, will prompt for adjustments based on damage reduction and energy resistances.

    Parameters

    • value: number = 0

      The amount of damage to deal. Negative values heal instead.

    • Optionaloptions: ApplyDamageOptions = {}

      Object containing default settings for overriding

    Returns Promise<false | Actor[]>

    • False if cancelled or array of updated actors.
  • Get melee and reach maximum ranges.

    Parameters

    • size: number | "col" | "med" | "fine" | "dim" | "tiny" | "sm" | "lg" | "huge" | "grg" = "med"

      Actor size as size key or number

    • stature: "tall" | "long" = "tall"

      Actor stature

    Returns { melee: number; reach: number }

    • Ranges
  • Return reduced movement speed.

    Parameters

    • value: number

      The non-reduced movement speed.

    Returns number

    The reduced movement speed.

    pf1.documents.actor.ActorPF.getReducedMovementSpeed(30); // => 20
    
  • Return increased amount of spell slots by ability score modifier.

    Parameters

    • mod: number

      The associated ability modifier.

    • level: number

      Spell level.

    Returns number

    Amount of spell levels to increase.

    pf1.documents.actor.ActorPF.getSpellSlotIncrease(2, 1); // => 1
    pf1.documents.actor.ActorPF.getSpellSlotIncrease(6, 1); // => 2
    pf1.documents.actor.ActorPF.getSpellSlotIncrease(6, 7); // => 0