export contentModal and make docsLinkTitle

Signed-off-by: Reyna Nikolayev <reyna.nikolayev@autodesk.com>
This commit is contained in:
Reyna Nikolayev
2025-04-08 12:30:40 -07:00
parent 32cbef5b4c
commit 16eb4bf98f
9 changed files with 138 additions and 5 deletions
+8
View File
@@ -0,0 +1,8 @@
---
'@backstage/plugin-home-react': patch
'@backstage/plugin-home': patch
---
Export ContentModal from @backstage/plugin-home-react so people can use this in other scenarios.
Make QuickStartCard docsLinkTitle prop more flexible to allow for any React.JSX.Element instead of just a string
+27
View File
@@ -5,9 +5,22 @@
```ts
import { Extension } from '@backstage/core-plugin-api';
import { JSX as JSX_2 } from 'react/jsx-runtime';
import { JSX as JSX_3 } from 'react';
import { Overrides } from '@material-ui/core/styles/overrides';
import { RJSFSchema } from '@rjsf/utils';
import { StyleRules } from '@material-ui/core/styles/withStyles';
import { UiSchema } from '@rjsf/utils';
// @public (undocumented)
export type BackstageContentModalClassKey = 'contentModal' | 'linkText';
// @public (undocumented)
export type BackstageOverrides = Overrides & {
[Name in keyof CatalogReactComponentsNameToClassKey]?: Partial<
StyleRules<CatalogReactComponentsNameToClassKey[Name]>
>;
};
// @public (undocumented)
export type CardConfig = {
layout?: CardLayout;
@@ -39,6 +52,11 @@ export type CardSettings = {
uiSchema?: UiSchema;
};
// @public (undocumented)
export type CatalogReactComponentsNameToClassKey = {
BackstageContentModal: BackstageContentModalClassKey;
};
// @public (undocumented)
export type ComponentParts = {
Content: (props?: any) => JSX.Element;
@@ -52,6 +70,15 @@ export type ComponentRenderer = {
Renderer?: (props: RendererProps) => JSX.Element;
};
// @public
export const ContentModal: (props: ContentModalProps) => JSX_2.Element;
// @public
export type ContentModalProps = {
modalContent: JSX_3.Element;
linkContent: string | JSX_3.Element;
};
// @public
export function createCardExtension<T>(options: {
title?: string;
@@ -1,5 +1,5 @@
/*
* Copyright 2022 The Backstage Authors
* Copyright 2025 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -18,14 +18,43 @@ import { JSX, useState } from 'react';
import { Link } from '@backstage/core-components';
import Modal from '@material-ui/core/Modal';
import Box from '@material-ui/core/Box';
import { makeStyles, Theme } from '@material-ui/core/styles';
import { useStyles } from './styles';
/** @public */
export type BackstageContentModalClassKey = 'contentModal' | 'linkText';
export const useStyles = makeStyles(
(theme: Theme) => ({
contentModal: {
position: 'absolute',
top: '50%',
left: '50%',
transform: 'translate(-50%, -50%)',
width: '80%',
height: 'auto',
},
linkText: {
marginBottom: theme.spacing(1.5),
},
}),
{ name: 'BackstageContentModal' },
);
/**
* Props customizing the <ContentModal/> component.
*
* @public
*/
export type ContentModalProps = {
modalContent: JSX.Element;
linkContent: string | JSX.Element;
};
/**
* A component to expand given content into a full screen modal.
*
* @public
*/
export const ContentModal = (props: ContentModalProps) => {
const { modalContent, linkContent } = props;
const styles = useStyles();
@@ -15,3 +15,7 @@
*/
export { SettingsModal } from './SettingsModal';
export { ContentModal } from './ContentModal';
export type { BackstageContentModalClassKey } from './ContentModal';
export type { ContentModalProps } from './ContentModal';
+1
View File
@@ -30,3 +30,4 @@ export type {
CardSettings,
CardConfig,
} from './extensions';
export * from './overridableComponents';
@@ -0,0 +1,36 @@
/*
* Copyright 2025 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Overrides } from '@material-ui/core/styles/overrides';
import { StyleRules } from '@material-ui/core/styles/withStyles';
import { BackstageContentModalClassKey } from './';
/** @public */
export type CatalogReactComponentsNameToClassKey = {
BackstageContentModal: BackstageContentModalClassKey;
};
/** @public */
export type BackstageOverrides = Overrides & {
[Name in keyof CatalogReactComponentsNameToClassKey]?: Partial<
StyleRules<CatalogReactComponentsNameToClassKey[Name]>
>;
};
declare module '@backstage/theme' {
interface OverrideComponentNameToClassKeys
extends CatalogReactComponentsNameToClassKey {}
}
+1 -1
View File
@@ -194,7 +194,7 @@ export const QuickStartCard: (
// @public
export type QuickStartCardProps = {
modalTitle?: string | JSX_3.Element;
docsLinkTitle?: string;
docsLinkTitle?: string | React.JSX.Element;
docsLink?: string;
video?: JSX_3.Element;
image: JSX_3.Element;
@@ -18,7 +18,7 @@ import { JSX } from 'react';
import { Link } from '@backstage/core-components';
import Typography from '@material-ui/core/Typography';
import Grid from '@material-ui/core/Grid';
import { ContentModal } from './ContentModal';
import { ContentModal } from '@backstage/plugin-home-react';
import { useStyles } from './styles';
/**
@@ -30,7 +30,7 @@ export type QuickStartCardProps = {
/** The modal link title */
modalTitle?: string | JSX.Element;
/** The link to docs title */
docsLinkTitle?: string;
docsLinkTitle?: string | JSX.Element;
/** The link to docs */
docsLink?: string;
/** The video to play on the card */
@@ -18,6 +18,7 @@ import { QuickStartCard } from '../../plugin';
import { ComponentType, PropsWithChildren } from 'react';
import { wrapInTestApp } from '@backstage/test-utils';
import Grid from '@material-ui/core/Grid';
import OpenInNewIcon from '@material-ui/icons/OpenInNew';
import ContentImage from './static/backstageSystemModel.png';
export default {
@@ -65,3 +66,30 @@ export const Customized = () => {
</Grid>
);
};
export const CustomDocLink = () => {
return (
<Grid item xs={12} md={6}>
<QuickStartCard
title="Onboarding to the Catalog"
modalTitle="Onboarding Quick Start"
docsLinkTitle={
<>
<OpenInNewIcon fontSize="small" />
Learn more with getting started docs
</>
}
docsLink="https://backstage.io/docs/getting-started"
image={
<img
src={ContentImage}
alt="quick start"
width="100%"
height="100%"
/>
}
cardDescription="Backstage system model will help you create new entities"
/>
</Grid>
);
};