First, thank you for contributing to DIM! We're a community-driven project and we appreciate improvements, large and small.
Here are some tips to make sure your Pull Request (PR) can be merged smoothly:
- If you want to add a feature or make some change to DIM, consider filing an issue describing your idea first. This will give the DIM community a chance to discuss the idea, offer suggestions and pointers, and make sure what you're thinking of fits with the style and direction of DIM. If you want a more free-form chat, join our Discord.
- Resist the temptation to change more than one thing in your PR. Keeping PRs focused on a single change makes them much easier to review and accept. If you want to change multiple things, or clean up/refactor the code, make a new branch and submit those changes as a separate PR.
- All of our code is written in TypeScript and uses React to build UI components.
- Be sure to run
pnpm fix
before submitting your PR - it'll catch most style problems and make things much easier to merge. - Don't forget to add a description of your change to docs/CHANGELOG.md so it'll be included in the release notes!
Note: It's often easier to use a package manager like Homebrew for Mac, or Chocolatey for Windows, and install the prerequisites through them.
- Homebrew:
brew install git nodejs corepack visual-studio-code
- Chocolatey:
choco install git nodejs-lts corepack vscode
- Install Git
- Install NodeJS
- It is highly recommended to use VSCode to work on DIM. When you open DIM in VSCode, accept the recommended plugins it suggests (find them manually by searching "@recommended" in the Extensions window).
- On Windows, restart your system after installing everything.
Corepack manages the version of pnpm, the package manager used by DIM. It comes with NodeJS and will automatically get the right version of pnpm for you.
To locally run a copy of DIM, you can simply clone the code repository:
git clone https://github.com/DestinyItemManager/DIM.git
To contribute changes to the project, you'll want to:
- Make an account on GitHub
- Create an SSH key and add it to your account
- Fork DIM to make your own copy of the repository
- Clone the forked repository to your local machine
- Edit the local files
- Commit and push your code changes to your fork
- Create a Pull Request from your forked repository to the original upstream repository, allowing DIM maintainers to accept and merge your changes
More detailed information on these steps is here.
Once you have cloned the repository or a fork of the repository to your local machine, in the root directory:
- Run
pnpm install
- If
pnpm
isn't installed, runcorepack enable
and try again, or install it manually.- If
corepack enable
fails, try running it with Administrator privileges. - If you're using PowerShell on Windows, you may need to run
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Unrestricted
to allow pnpm to run.
- If
- Linux-based developers will need to install
build-essential
(sudo apt-get install -y build-essential
) prior to runningpnpm install
.
- If
- Run
pnpm start
On Windows machines, this will also install SnoreToast to provide notifications for parts of the development process, like when a build completes.
- Go to Bungie's Developer Portal (you will have to be signed in)
- Click
Create New App
- Enter any application name
- Enter
https://github.com/YourGithubUsername/DIM
under website - For
Oauth Client type
, selectConfidential
- Set your redirect url to
https://localhost:8080/return.html
(or whatever the IP or hostname is of your dev server) - Select all scopes except the Administrate Groups/Clans
- Enter
https://localhost:8080
as theOrigin Header
- Check the box to agree to the Terms of Use and click Create New App
This step will need to be done each time you clear your browser cache. You will be automatically redirected to a screen to enter these credentials if the app can't load them from local storage when it starts.
- Open your browser and navigate to https://localhost:8080 (your browser will likely give a security warning, it is safe to continue anyways, see Overview below for details)
- Copy your API-key, Oauth Client_id, and OAuth client_secret from bungie.net into DIM developer settings panel when it is loaded
- Below the section for Bungie API credentials, follow the instructions to generate a DIM API key
Overview
The pnpm start
step will create a hot-loading web server and a TLS cert/key pair. You will access your local development site by visiting https://localhost:8080.
You will likely get a security warning about the certificate not being trusted. This is because it's a self-signed cert generated dynamically for your environment
and is not signed by a recognized authority. Dismiss/advance past this warning to view your local DIM application.
Check code Style
pnpm fix
will tell you if you're following the DIM code style (and automatically fix what it can). Check out the docs folder for more tips.
Translation
-
We use i18next for all our translated strings, so if you want to translate something that's currently English-only, take a look at that. Usually it's as simple as replacing some text with
<span>{t('KEY')}</span>
and then defining KEY in theconfig\i18n.json
file. -
pnpm i18n
will add, sort, and prunesrc/locale/en.json
. You should never manually editsrc/locale/en.json
. Some keys are obfuscated by code and will need to be added as comments into the code such as// t('LoadoutBuilder.ObfuscatedKey1')
. If you have any questions, ping @delphiactual via GitHub, Slack, or Discord.