Container item

Bags, backpacks, chests, etc.

Hierarchy (View Summary)

Constructors

Properties

Accessors

Methods

_addTypeRollData _canCreateItemLink _configure _containedItemUpdate _generateLinkData _getArmorWeightMultiplier _initialize _onCreate _onDelete _onMemorizedUpdate _onUpdate _preCreate _prepareActions _prepareChanges _prepareDependentData _prepareIdentifier _prepareScriptCalls _prepareTraits _preUpdate _preUpdateNumericValueGuard _rechargeActions _rechargeUses _resetChargesOnQuantityUpdate _sizeAdjustedHealth _transformContainerUpdateData _updateInheritedCharges _updateMaxUses addCharges addItemBooleanFlag adjustContained convertCurrency createContainerContent createItemLink deleteContainerContent displayCard executeScriptCalls getAllDamageSources getAllLinkedItems getAttackSources getChangeTargets getChatData getConditionalTargets getContextChanges getDefaultChargeCost getDefaultChargeFormula getDescription getDescriptionData getEmbeddedDocument getFlag getItemBooleanFlags getItemDictionaryFlag getItemDictionaryFlags getLabels getLinkedItems getLinkedItemsSync getName getProficiency getRawEffectData getRollData getScriptCalls getTotalCurrency getTypeChatData getValue getWeightMultiplier hasItemBooleanFlag memorizeVariables prepareBaseData prepareDerivedData prepareDurability prepareLinks prepareWeight recharge removeItemBooleanFlag removeItemDictionaryFlag removeItemLink setActive setItemDictionaryFlag update updateContainerContents use _adjustNewItem _createSupplements _hasSizeUpdate _hasVisionUpdate _onCreateOperation _onDeleteOperation _onUpdateOperation createDialog defaultName getDefaultArtwork

Constructors

  • Parameters

    • ...args: [data?: ItemDataConstructorData, context?: Context<ActorPF>]

    Returns ItemContainerPF

Properties

_memoryVariables: undefined | null | {}
actions: undefined | Collection<ItemAction>

A Collection of ItemActions.

changes: undefined | Collection<any>
items: undefined | Collection<any>
links: undefined | Record<string, ItemPF>

An object containing links to other items.

scriptCalls: any
system: Readonly<
    {
        hasActions: false;
        hasChanges: true;
        hasIdentifier: true;
        isPhysical: boolean;
        subtypeName: false;
    },
> = ...

Accessors

  • get alignments(): null | string
  • The item's alignment attributes, or null if the item has no alignment attributes

    Returns null | string

  • get allDamageSources(): undefined | ItemChange[]
  • Generic damage source retrieval for default action, includes default conditionals and other item specific modifiers.

    Returns undefined | ItemChange[]

    All relevant changes, or undefined if action was not found.

  • get attackSources(): undefined | object[]
  • Return attack sources for default action.

    Returns undefined | object[]

    Array of value and label pairs for attack bonus sources on the main attack.

  • get effect(): null | ActiveEffect
  • An active effect associated with this item.

    Returns null | ActiveEffect

    • Most item types don't have associated effect.
  • get hasChanges(): any
  • Whether the item is tangible physical object in reality.

    Returns any

    • You can utilize this with raw data via CONFIG.Item.documentClasses[type]?.isPhysical
  • get isActive(): any
  • Is the item is fully functional.

    This returns composite result of if the item is equipped, has quantity, is not disabled, is not out of charges, etc. and is not representative if the item can be set active or not via setActive.

    Returns any

  • get isPhysical(): any
  • Whether the item is tangible physical object in reality.

    Returns any

    • You can utilize this with raw data via CONFIG.Item.documentClasses[type]?.isPhysical
  • get isProficient(): boolean
  • Is the owning actor proficiency at using this as weapon.

    Returns boolean

    PF1 v10

  • get maxCharges(): number
  • Maximum possible charges this item can have.

    Returns number

    • Can return zero. Usually signifying something has reduced the potential uses below usability.
    • Can return infinity, signifying lack of limits.
  • get memoryVariables(): string[]
  • Returns string[]

    The keys of data variables to memorize between updates, for e.g. determining the difference in update.

  • get rootItem(): Item
  • Internal

    Root item.

    Specifically the item at bottom of the container tree.

    Returns Item

  • get subType(): null | string
  • The item's subtype, or null if the item has no subtype

    Returns null | string

  • get isPhysical(): boolean
  • Whether the item is tangible physical object in reality.

    Returns boolean

    • You can utilize this with raw data via CONFIG.Item.documentClasses[type]?.isPhysical

Methods

  • Internal

    Handle contained item CRUD

    Parameters

    • itemId: string

      Item ID

    • itemData: null | object

      Item's update data

    • items: object

      Parent's items update object

    • context: object

      Context

    Returns Promise<void>

  • Internal

    Parameters

    • type: string

      The type of link.

    • item: object

      The target item to link to.

    • uuid: string

      The link identifier for the item.

    Returns any[]

    An array to insert into this item's link data.

  • Perform one-time initialization tasks which only occur when the Document is first constructed.

    Returns void

  • Prepare data potentially dependent on other items.

    This should be run at in Item.prepareDerivedData() if no actor is present, or in actor's prepareDerivedData after document preparation is done.

    Parameters

    • final: boolean = false

      Is this final call to this?

    Returns void

  • Internal

    Recharges item's uses, if any.

    Parameters

    • options: { exact: boolean; period?: string; rollData?: object } = {}

      Options

      • exact: boolean

        Exact time period only

      • Optionalperiod?: string

        Recharge only if matching this time period

      • OptionalrollData?: object

        Roll data

    Returns undefined | object

    • Update data or undefined if no update is needed.
  • Internal

    Parameters

    • options: {
          exact?: boolean;
          maximize?: boolean;
          period?: string;
          rollData?: object;
          value?: number;
      } = {}

      Options

      • Optionalexact?: boolean

        Match only exact time period

      • Optionalmaximize?: boolean

        Maximize instead of using recharge formula

      • Optionalperiod?: string

        Recharge only if it matches this time period

      • OptionalrollData?: object

        Roll data instance

      • Optionalvalue?: number

        Set charges to specific value

    Returns Promise<undefined | object>

    • Update data or undefined if no update is necessary.

    This item type can not be recharged.

  • Internal

    Transform given data so it becomes valid update data within parent item.

    This can, for example, be used to generate batched update to the real item.

    Parameters

    • data: object

      Update data

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

      Additional options

      • Optionalrecursive?: boolean

        Create data recursively, meant for the real item document.

    Returns object

    • Transformed update data
    _transformContainerUpdateData({ name: "new name" })
    // => { system: { items: { [itemID]: { name: "new name" } } } }
  • Sets a boolean flag on this item.

    Parameters

    • flagName: string

      The name/key of the flag to set.

    • context: object = {}

      Update context

    Returns Promise<boolean>

    Whether something was changed.

  • Creates a link to another item.

    Parameters

    • type: "children" | "charges" | "classAssociations" | "supplement"

      The type of link.

    • item: Item

      The target item to link into this.

    • OptionalextraData: object

      Additional data to store int he link

    Returns boolean

    • Whether a link was created.
  • Display the chat card for an Item as a message in chat

    Parameters

    • OptionalaltChatData: object = {}

      Optional data that will be merged into the chat data object.

    • Optionaloptions: { token?: TokenDocument } = {}

      Additional options.

      • Optionaltoken?: TokenDocument

        Relevant token if any.

    Returns Promise<void | ChatMessage>

    Chat message instance if one was created.

  • Executes all script calls on this item of a specified category.

    Parameters

    • category: string

      The category of script calls to call.

    • OptionalextraParams: Record<string, any> = {}

      A dictionary of extra parameters to pass as variables for use in the script.

    • Optionalshared: object = {}

      Shared data object

    Returns Promise<object>

    The shared object between calls which may have been given data.

  • Attack sources for a specific action.

    Parameters

    • actionId: string

      Action ID

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

      Additional options

      • OptionalrollData?: object

        Roll data instance

    Returns undefined | object[]

    Array of value and label pairs for attack bonus sources on the main attack, or undefined if the action is missing.

  • Finds, filters and alters changes relevant to a context, and returns the result (as an array)

    Parameters

    • context:
          | "mattack"
          | "nattack"
          | "rattack"
          | "tattack"
          | "wdamage"
          | "mwdamage"
          | "rwdamage"
          | "twdamage"
          | "rdamage"
          | "mdamage"
          | "ndamage"
          | "sdamage"
          | "tdamage" = ...

      The given context.

    Returns ItemChange[]

    • The matching changes.
    • Always returns empty array if no actor is present.
  • Get default charge cost for all actions.

    Parameters

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

      Additional options

      • OptionalrollData?: object

        Roll data instance

    Returns number

    Number for default cost.

  • Get full description.

    Parameters

    • options: {
          body?: boolean;
          chatcard?: boolean;
          data?: object;
          header?: boolean;
          isolated?: boolean;
          rollData?: object;
      } = {}

      Item type dependant options for rendering the description.

      • Optionalbody?: boolean

        Include main description body if such exists.

      • Optionalchatcard?: boolean

        Instruct template to render chat card in mind.

      • Optionaldata?: object

        Template data for rendering

      • Optionalheader?: boolean

        Include header if such exists.

      • Optionalisolated?: boolean
      • OptionalrollData?: object

        Roll data for transforming description

    Returns string

    • Full description.
  • Description Data

    Parameters

    • options: { isolated?: boolean; rollData?: object } = {}

      Additional options

      • Optionalisolated?: boolean

        Include extra data to reflect it not being so easily available in context.

      • OptionalrollData?: object

        Roll data instance

    Returns object

    • Description context data
  • Get item links of type

    Parameters

    • type: string

      Link type

    • includeLinkData: boolean = false

      Include link data, return value changes from item array to object array

    • Optionaloptions: { _results?: Set<any>; recursive?: boolean } = {}

      Additional options

      • Optional_results?: Set<any>

        Internal use only.

      • Optionalrecursive?: boolean

        Retrieved linked items recursively.

    Returns object[] | Item[]

    • Linked items, or objects with linked items and additional data
  • Retrieve list of linked items for a type, synchronously. Intended mainly for fetching child or charge links quickly.

    Parameters

    • type: string

      Link type, e.g. "children", "charges", or "classAssociations"

    • Optionaloptions: { _results?: Set<string>; recursive?: boolean } = {}

      Additional options

      • Optional_results?: Set<string>

        Internal use only

      • Optionalrecursive?: boolean

        Retrieve links recursively.

    Returns object[] | Item[]

    Linked items or their compendium index data

    const childItems = item.getLinkedItemsSync("children");
    
  • Parameters

    • Optionalweapon: boolean = true

      Get proficiency as a weapon. Armor otherwise.

    Returns boolean

    • Whether or not the owner of the item is proficient.
    • If item type does not support proficiency.

    PF1 v10

  • Determines the starting data for an ActiveEffect based off this item.

    Parameters

    • options: { rollData: object } = {}

      Additional options

      • rollData: object

        Roll data

    Returns object

    • Active Effect creation data
  • Returns the currency this item contains

    Parameters

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

      Additional options affecting how the value is returned

      • OptionalinLowestDenomination?: boolean

        Whether to return the value in copper, or in gold (default)

    Returns number

    The total amount of currency this item contains, in gold pieces

  • Per item type chat data.

    Parameters

    • data: ChatData

      A partial of a chat data object that can be modified to add per item type data.

    • labels: Record<string, any>

      The labels for this item.

    • props: string[]

      Additional property strings

    • rollData: object

      A rollData object to be used for checks

    • Optionaloptions: { actionId?: string; chatcard?: boolean } = {}

      Additional options

      • OptionalactionId?: string

        Action this pertains to, if any.

      • Optionalchatcard?: boolean

        Is this for a chat card?

    Returns void

  • Returns the displayed value of an item according to multiple options

    Parameters

    • __namedParameters: { inLowestDenomination?: boolean; recursive?: boolean } = {}

      Various optional parameters affecting value calculations

    Returns number

    The item's value

  • Removes a boolean flag from this item.

    Parameters

    • flagName: string

      The name/key of the flag to remove.

    • context: object = {}

      Update context

    Returns Promise<boolean>

    Whether something was changed.

  • Removes all link references to an item.

    Parameters

    • uuid: string

      The UUID of the item to remove links to.

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

      Additional options

      • Optionalcommit?: boolean

        Commit changes to database. If false, resulting update data is returned instead.

    Returns Promise<undefined | object | Item>

    • Updated document, update data, or undefined
  • Set item's active state.

    Parameters

    • active: any

      Active state

    • context: any

      Optional update context

    Returns Promise<Item>

    • Update promise if item type supports the operation.
    • If item does not support the operation.
  • Sets a dictionary flag value on this item.

    Parameters

    • flagName: string

      The name/key of the flag to set.

    • value: string | number

      The flag's new value.

    • context: object = {}

      Update context

    Returns Promise<boolean>

    Whether something was changed.

  • Use an attack, using SharedActionData

    Parameters

    • options: {
          actionId?: string;
          chatMessage?: boolean;
          cost?: number;
          dice?: string;
          ev?: null | Event;
          options?: UseOptions;
          rollMode?: string;
          skipDialog?: boolean;
          token?: TokenDocument;
      } = {}

      Options

      • OptionalactionId?: string

        The ID of the action to use, defaults to the first action

      • OptionalchatMessage?: boolean

        Whether to send a chat message for this action

      • Optionalcost?: number

        Cost override. Replaces charge cost or slot cost as appropriate.

      • Optionaldice?: string

        The base dice to roll for this action

      • Optionalev?: null | Event

        The event that triggered the use, if any

      • Optionaloptions?: UseOptions

        Additional use options.

      • OptionalrollMode?: string

        The roll mode to use for the chat message

      • OptionalskipDialog?: boolean

        Whether to skip the dialog for this action

      • Optionaltoken?: TokenDocument

        Token this action is for, if any.

    Returns Promise<void | ActionUse | SharedActionData>

    • Action use, shared data, or nothing.
    • On some invalid inputs.
  • On-Create Operation

    Post-create processing so awaiting the original operation has all secondary updates completed when it returns.

    Parameters

    • documents: Document[]

      Documents

    • operation: any

      Operations and context data

    • user: User

      Triggering user

    Returns Promise<void>

  • On-Delete Operation

    Post-delete processing so awaiting the original operation has all secondary updates completed when it returns.

    Parameters

    • documents: Document[]

      Documents

    • operation: any

      Operations and context data

    • user: User

      Triggering user

    Returns Promise<void>

  • On-Update Operation

    Post-update processing so awaiting the original operation has all secondary updates completed when it returns.

    Parameters

    • documents: Document[]

      Documents

    • operation: any

      Operations and context data

    • user: User

      Triggering user

    Returns Promise<void>

  • Item create dialog.

    Parameters

    • data: object = {}

      Initial form data

    • Optionalcontext: {
          options?: object;
          pack?: null | string;
          parent?: null | Actor;
          types?: string[];
      } = {}

      Additional options.

      • Optionaloptions?: object

        Dialog context options.

      • Optionalpack?: null | string

        Pack ID parameter passed to Item.create() options

      • Optionalparent?: null | Actor

        Parent parameter passed to Item.create() options

      • Optionaltypes?: string[]

        Item types to limit creation choices to.

    Returns Promise<null | Item>

    Synchronized with Foundry VTT v12.331

  • Override to provide naming by subType potential.

    Parameters

    • context: {
          pack?: null | string;
          parent?: null | Document;
          subType?: string;
          type?: string;
      } = {}

      Context where the name would be used

      • Optionalpack?: null | string

        Pack this would be within

      • Optionalparent?: null | Document

        Parent document

      • OptionalsubType?: string

        Document subtype. Nonstandard option.

      • Optionaltype?: string

        Type

    Returns string

    Synced with Foundry v12.331