GitHub Insights Plugin for Backstage
data:image/s3,"s3://crabby-images/9a1b9/9a1b9f0439def8592576b84cce384c3652d2f341" alt="a preview of the GitHub insights plugin"
Features
- Add GitHub Insights plugin tab.
- Show widgets about repository contributors, languages, readme, environments and release at overview page.
Plugin Setup
- Install the plugin:
cd packages/app
yarn add @roadiehq/backstage-plugin-github-insights
- Add plugin API to your Backstage instance:
import { EntityGithubInsightsContent } from '@roadiehq/backstage-plugin-github-insights';
...
const serviceEntityPage = (
<EntityLayoutWrapper>
...
<EntityLayout.Route
path="/code-insights"
title="Code Insights">
<EntityGithubInsightsContent />
</EntityLayout.Route>
...
</EntityLayoutWrapper>
);
- Run backstage app with
yarn start
and navigate to services tabs.
Widgets setup
-
You must install plugin by following the steps above to add widgets to your Overview. You might add only selected widgets or all of them.
-
Add widgets to your Overview tab:
import {
EntityGithubInsightsContent,
EntityGithubInsightsLanguagesCard,
EntityGithubInsightsReadmeCard,
EntityGithubInsightsReleasesCard,
isGithubInsightsAvailable,
} from '@roadiehq/backstage-plugin-github-insights';
...
const overviewContent = (
<Grid container spacing={3} alignItems="stretch">
<EntitySwitch>
<EntitySwitch.Case if={isGithubInsightsAvailable}>
<Grid item md={6}>
<EntityGithubInsightsLanguagesCard />
<EntityGithubInsightsReleasesCard />
</Grid>
<Grid item md={6}>
<EntityGithubInsightsReadmeCard maxHeight={350} />
</Grid>
</EntitySwitch.Case>
</EntitySwitch>
</Grid>
);
Readme path
By default the plugin will use the annotation github.com/project-slug
and get the root README.md
from the repository. You can use a specific path by using the annotation 'github.com/project-readme-path': 'packages/sub-module/README.md'
. It can be useful if you have a component inside a monorepos.
Widgets
Compliance Card
import { EntityGithubInsightsComplianceCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/d9fa2/d9fa27f5fc23c458e5ea5ef634b015b1aa940ab1" alt="a preview of the compliance widget"
Contributors Card
import { EntityGithubInsightsContributorsCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/70a11/70a1173220e2beb4e6e9bf67cd5fccc75dbdb7b7" alt="a preview of the contributors widget"
Languages Card
import { EntityGithubInsightsLanguagesCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/e8ae3/e8ae3920fb7c4ebc78d0c73554fb3d8da74940f8" alt="a preview of the languages widget"
ReadMeCard
import { EntityGithubInsightsReadmeCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/7071e/7071e4edbe939a8eed31967b3eb0f6f010e4a3c0" alt="a preview of the compliance widget"
Please note that the workflow status badge feature in GitHub will not work with the Readme plugin.
ReleasesCard
import { EntityGithubInsightsReleasesCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/f5c64/f5c64f94b1c702b8d75630c598c130277fc85149" alt="a preview of the releases widget"
EnvironmentsCard
import { EntityGithubInsightsEnvironmentsCard } from '@roadiehq/backstage-plugin-github-insights';
data:image/s3,"s3://crabby-images/503af/503afab84f10d377c4c1b4de8a1f4c130ec4f2af" alt="a preview of the releases widget"
Links
Roadie gives you a hassle-free, fully customisable SaaS Backstage. Find out more here: https://roadie.io.