The default changelog renderer for nx release generates a changelog entry for each released project similar to the following:
## 7.9.0 (2024-05-13)
### 🚀 Features
- **rule-tester:** check for missing placeholder data in the message ([#9039](https://github.com/typescript-eslint/typescript-eslint/pull/9039))
### ❤️ Thank You
- Kirk Waiblinger- Sheetal Nandi- Vinccool96Include All Metadata
Section titled “Include All Metadata”There are a few options available to modify the default changelog renderer output. They can be applied to both workspaceChangelog and projectChangelogs in exactly the same way. All four options are true by default:
{  "release": {    "changelog": {      "projectChangelogs": {        "renderOptions": {          "authors": true,          "applyUsernameToAuthors": true,          "commitReferences": true,          "versionTitleDate": true        }      }    }  }}authors
Section titled “authors”Whether the commit authors should be added to the bottom of the changelog in a "Thank You" section. Defaults to true.
applyUsernameToAuthors
Section titled “applyUsernameToAuthors”If authors is enabled, controls whether or not to try to map the authors to their GitHub usernames using https://ungh.cc (from https://github.com/unjs/ungh) and the email addresses found in the commits. Defaults to true.
You should disable this option if you don't want to make any external requests to https://ungh.cc
NOTE: Prior to Nx v21, this option was named mapAuthorsToGitHubUsernames.
commitReferences
Section titled “commitReferences”Whether the commit references (such as commit and/or PR links) should be included in the changelog. Defaults to true.
versionTitleDate
Section titled “versionTitleDate”Whether to include the date in the version title. It can be set to false to disable it, or true to enable with the default of (YYYY-MM-DD). Defaults to true.
Remove All Metadata
Section titled “Remove All Metadata”If you prefer a more minimalist changelog, you can set all the options to false, like this:
{  "release": {    "changelog": {      "projectChangelogs": {        "renderOptions": {          "authors": false,          "applyUsernameToAuthors": false,          "commitReferences": false,          "versionTitleDate": false        }      }    }  }}Which will generate a changelog that looks similar to the following:
## 7.9.0
### 🚀 Features
- **rule-tester:** check for missing placeholder data in the messageCustom Changelog Renderer Nx 22+
Section titled “Custom Changelog Renderer Nx 22+”For complete control over changelog formatting, you can provide a custom changelog renderer implementation. The renderer can be specified as a path to a module that exports a class extending the base ChangelogRenderer.
{  "release": {    "changelog": {      "projectChangelogs": {        "renderer": "./tools/custom-changelog-renderer.ts"      }    }  }}Your custom renderer must extend the ChangelogRenderer class and implement the required methods:
import { ChangelogRenderer, ChangelogRenderOptions } from '@nx/js/release';
export default class CustomChangelogRenderer extends ChangelogRenderer {  async renderMarkdown(    changes: any[],    options: ChangelogRenderOptions  ): Promise<string> {    // Your custom changelog generation logic    return '# My Custom Changelog\n\n...';  }}