Skip to content

A community effort to create type definitions for the dnd5e system in Foundry VTT

License

Notifications You must be signed in to change notification settings

League-of-Foundry-Developers/foundry-vtt-dnd5e-types

Repository files navigation

foundry-vtt-dnd5e-types

A community effort to create type definitions for the dnd5e system in Foundry VTT

Objective

Provide a third party typescript definition library for the Foundry VTT D&D 5e System which can be installed and used alongside foundry-vtt-types to bring typescript support to dnd5e related modules.

Supported dnd5e versions

  • 1.2.4
  • 1.3.6

Installation

You can install foundry-vtt-dnd5e-types from the npm registry. We provide distribution tags for the different supported Foundry VTT versions that have the form dnd5e-<system-version>. For example, the distribution tag for dnd5e 1.3.6 is dnd5e-1.3.6.

In order to install the desired version, run

npm install --save-dev @league-of-foundry-developers/foundry-vtt-dnd5e-types@dnd5e-<dnd5e-version>

For example, to install the type definitions for dnd5e 1.3.6, run

npm install --save-dev @league-of-foundry-developers/[email protected]

You can then update foundry-vtt-dnd5e-types using the regular update mechanism for npm (see npm update).

Usage

Add foundry-vtt-dnd5e-types to your types section in your tsconfig.json:

{
  "compilerOptions": {
    "types": ["@league-of-foundry-developers/foundry-vtt-types", "@league-of-foundry-developers/foundry-vtt-dnd5e-types"],
    "moduleResolution": "Node",
    "strictNullChecks": true
  }
}

This will make the type definitions available globally in your project.

Make sure you are using "moduleResolution": "Node" and "strictNullChecks": true as they are required for some dependencies to be resolved correctly (per foundry-vtt-types guidelines).

Contributing

Contributions are very welcome in order to decrease the individual workload. Filing issues for wrong / missing types is also a great way to help us improve the type definitions.

There are individual branches for the different supported dnd5e system versions that are being worked on. They are named according to the system version, e.g. the branch for dnd5e 1.3.6 is called dnd5e-1.3.6. All work to improve the type definitions for a specific version needs to be done through Pull Requests to the corresponding branch.

Please read CONTRIBUTING.md for more details on how to contribute.

If you have any specific questions, feel free to contact us in the League of Extraordinary Foundry Developers Discord.

Type-Checking, Linting, Testing

When contributing, make sure sure that the type checks pass, the linter is green and the tests are green. We do have checks in the CI but running this locally also helps you while developing and saves you time as you don't have to wait for the CI.

You can run type checking and linting with the following command:

npm run lint

License

This project is licensed under the MIT license. You can find a copy at LICENSE.

About

A community effort to create type definitions for the dnd5e system in Foundry VTT

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published