Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
@brisk-docs/react-changelogs
Advanced tools
This package is used for displaying changelogs from your projects
This library is designed to help you display changelogs and changelog information, as well as filtering a complete changelog to the relevant subset of changes.
We have two exports:
import Changelog from 'package-name'
which is a react component, and
import { divideChangelog, filterChangelogs } from 'package-name'
which are function.
The changelog component is designed to display changelog entries in react. A base use-case would look something like:
import Changelog from `package-name`
const stubChangelog = `# This package itself
## 1.0.0
- [major] 24601
## 0.5.0
- [minor] Who am I?
## 0.4.3
- [patch] And so, Honor, you see it's true,
- [minor] That man bears no more guilt than you!
## 0.4.2
- [patch] Who am I?
- [patch] I am Jean Valjean!
You see, I decided for these changelogs that I wanted to demonstrate how it renders a bunch of different content.
We convert and render *whatever* markdown is in a changelog entry.`
export default () => (
<Changelog changelog={stubChangelog} />
)
Note that we can also filter changelogs using the range
prop, so if we modified the above component to be:
<Changelog changelog={stubChangelog} range="^0.5.0" />
We would only see the changelog for 0.5.0
as it is the only one that matches that semver range.
The range property accepts any semver function for its filter comparison
For an example you can check out this codesandbox
We also export a couple of utility functions if you want to use these features but want to write your own renderer (or are not using react). We'll talk you through what they are doing so you can easily understand this package.
Divide changelog is the function that takes in a string, and return an array of changelogEntry objects. Its pattern looks something like this:
divideChangelog(stubChangelog)
// outputs
[
{
version: '1.0.0',
text: `## 1.0.0
- [major] 24601`,
},
{
version: '0.5.0',
text: `## 0.5.0
- [minor] Who am I?`,
},
{
version: '0.4.3',
text: `## 0.4.3
- [patch] And so, Honor, you see it's true,
- [minor] That man bears no more guilt than you!
`,
},
{
version: '0.4.2',
text: `## 0.4.2
- [patch] Who am I?
- [patch] I am Jean Valjean!`,
},
];
The logic to divide the changelog is relatively simple, splitting the markdown file on the start of every h2
(##
in markdown). We then parse out the version being discussed (assuming it immediately follows the h2
).
We also assume that we can find the version on the h2
line to give each object a version number.
This allows you to map your changelog entries to a react component, or otherwise display, filter and analyse this information.
Check out this sandbox to explore using the functions.
filterChangelog takes in an array of changelogs in the format output by divideChangelog
, and a semver range, and returns only changelog version that match that semver range.
const narrowedChangelogs = filterChangelog(arrayOfEntries, "^0.4.0")
The functions use a file import to ensure easy code splitting if you are not using react, but want this feature.
When using this tool, it is going to work best if you can use your actual changelog from your git repository. Here are several strategies for reading this information in:
fs
to read it in and expose it server-sideFAQs
This package is used for displaying changelogs from your projects
We found that @brisk-docs/react-changelogs demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.