Welcome to the readme plugin!
The Readme-plugin
enables easy access and viewing of the README file. By having information such as the project's purpose, usage instructions, or installation details as a central part of the EntityPage, we hope to improve the onboarding and understanding of entities
.
The plugin supports all ScmIntegrations, like Gerrit & GitLab. This makes it possible for organizations with many Source Code Integrations to use the same plugin.
It also supports various file extentions such as README.md, README.MD, README.txt, README, and README.rst.
The README.md file is always retrieved from the same directory as the catalog-info.yaml file
, also known as the entity source location
. If you wish to view the path where the plugin looks for your README.md file, you can find it in the backstage.io/source-location annotation in the catalog-info.yaml file. This annotation is automatically added to your entity, so there is no need to add it manually.
The displays README files with one of the following file types: md, MD, rst, or txt. The plugin can also handle symlinks.
Currently, placing your README.md file elsewhere than in the same directory as the catalog-info.yaml file
repository is not supported.
You need to set up the Readme Backend plugin before you move forward with any of these steps if you haven't already.
- First, install the plugin into your app:
# From your Backstage root directory
yarn --cwd packages/app add @axis-backstage/plugin-readme
- Then, modify your entity page in
EntityPage.tsx
to include theReadmeCard
component that is exported from the plugin to `overviewContent``.
// In packages/app/src/components/catalog/EntityPage.tsx
import { ReadmeCard } from '@axis-backstage/plugin-readme';
const overviewContent = (
...
<Grid item md={6} xs={12}>
<ReadmeCard />
</Grid>
...
)
If you wish to only render the ReadmeCard if a README file can be found for the entity, you can use the exported function isReadmeAvailable. See example below:
import { ReadmeCard, isReadmeAvailable } from '@axis-backstage/plugin-readme';
const defaultEntityPage = (
...
<EntitySwitch>
<EntitySwitch.Case if={isReadmeAvailable}>
<Grid md={6} xs={12}>
<ReadmeCard maxHeight={350} />
</Grid>
</EntitySwitch.Case>
</EntitySwitch>
...
)
To use ReadmeCard
in a seperate page with full height:
import { ReadmeCard } from '@axis-backstage/plugin-readme';
const defaultEntityPage = (
...
<EntityLayout.Route path="/readme" title="README">
<ReadmeCard variant="fullHeight" />
</EntityLayout.Route>
...
)
The readme card is located in the overview page on the entity page. From the card header it is also possible to open a dialog displaying the full README.md.
This message indicates that the backend cannot find your README.md file. Ensure that the README.md file is indeed located in the same directory as the catalog-info.yaml file
. If you are still unable to locate it, try scheduling an entity refresh by clicking the "Schedule Entity Refresh" button in the AboutCard of the entity.
Addition to this; ensure that backstage:source-location
value has the trailing slash.
...
metadata:
annotations:
# This will not work
backstage:source-location: https://bitbucket.org/org-name/repo-id/src/master
# This value will work.
backstage:source-location: https://bitbucket.org/org-name/repo-id/src/master/
...