@backstage/plugin-techdocs 1.6.1-next.0 → 1.6.1-next.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +24 -0
- package/dist/esm/{index/TechDocsCustomHome-b21cee4c.esm.js → TechDocsCustomHome-cd6edd4b.esm.js} +3 -3
- package/dist/esm/TechDocsCustomHome-cd6edd4b.esm.js.map +1 -0
- package/dist/esm/{index/index-dcf4e38c.esm.js → index-27835b1e.esm.js} +19 -6
- package/dist/esm/index-27835b1e.esm.js.map +1 -0
- package/dist/esm/{index/index-cc28b47f.esm.js → index-4901a4ac.esm.js} +3 -3
- package/dist/esm/index-4901a4ac.esm.js.map +1 -0
- package/dist/index.esm.js +2 -2
- package/package.json +17 -16
- package/dist/esm/index/TechDocsCustomHome-b21cee4c.esm.js.map +0 -1
- package/dist/esm/index/index-cc28b47f.esm.js.map +0 -1
- package/dist/esm/index/index-dcf4e38c.esm.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,29 @@
|
|
|
1
1
|
# @backstage/plugin-techdocs
|
|
2
2
|
|
|
3
|
+
## 1.6.1-next.1
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- 6c809d1a41c: Minor visual tweaks to adapt to changes in mkdocs-material v9
|
|
8
|
+
- 847a1eee3da: Change anchor links color in Techdocs content
|
|
9
|
+
|
|
10
|
+
With the color (mkdocs supplied) used for anchor links the background and foreground colors do not have a sufficient contrast ratio. Using the link color from theme palette.
|
|
11
|
+
|
|
12
|
+
- e0c6e8b9c3c: Update peer dependencies
|
|
13
|
+
- Updated dependencies
|
|
14
|
+
- @backstage/core-components@0.12.6-next.1
|
|
15
|
+
- @backstage/integration-react@1.1.12-next.1
|
|
16
|
+
- @backstage/core-plugin-api@1.5.1-next.0
|
|
17
|
+
- @backstage/plugin-techdocs-react@1.1.5-next.1
|
|
18
|
+
- @backstage/plugin-catalog-react@1.4.1-next.1
|
|
19
|
+
- @backstage/integration@1.4.4-next.0
|
|
20
|
+
- @backstage/plugin-search-react@1.5.2-next.1
|
|
21
|
+
- @backstage/theme@0.2.19-next.0
|
|
22
|
+
- @backstage/catalog-model@1.2.1
|
|
23
|
+
- @backstage/config@1.0.7
|
|
24
|
+
- @backstage/errors@1.1.5
|
|
25
|
+
- @backstage/plugin-search-common@1.2.3-next.0
|
|
26
|
+
|
|
3
27
|
## 1.6.1-next.0
|
|
4
28
|
|
|
5
29
|
### Patch Changes
|
package/dist/esm/{index/TechDocsCustomHome-b21cee4c.esm.js → TechDocsCustomHome-cd6edd4b.esm.js}
RENAMED
|
@@ -2,7 +2,7 @@ import React, { useState } from 'react';
|
|
|
2
2
|
import useAsync from 'react-use/lib/useAsync';
|
|
3
3
|
import { makeStyles } from '@material-ui/core';
|
|
4
4
|
import { catalogApiRef, CATALOG_FILTER_EXISTS, useEntityOwnership } from '@backstage/plugin-catalog-react';
|
|
5
|
-
import { T as TechDocsPageWrapper, D as DocsTable, a as DocsCardGrid } from './index-
|
|
5
|
+
import { T as TechDocsPageWrapper, D as DocsTable, a as DocsCardGrid } from './index-27835b1e.esm.js';
|
|
6
6
|
import { Content, Progress, WarningPanel, CodeSnippet, HeaderTabs, ContentHeader, SupportButton } from '@backstage/core-components';
|
|
7
7
|
import { useApi } from '@backstage/core-plugin-api';
|
|
8
8
|
import '@backstage/errors';
|
|
@@ -21,7 +21,7 @@ import '@material-ui/icons/FeedbackOutlined';
|
|
|
21
21
|
import 'react-dom';
|
|
22
22
|
import 'git-url-parse';
|
|
23
23
|
import '@material-ui/icons/Menu';
|
|
24
|
-
import '@material-ui/core/
|
|
24
|
+
import '@material-ui/core/IconButton';
|
|
25
25
|
import 'react-use/lib/useCopyToClipboard';
|
|
26
26
|
import 'react-helmet';
|
|
27
27
|
import '@material-ui/core/styles';
|
|
@@ -126,4 +126,4 @@ const TechDocsCustomHome = (props) => {
|
|
|
126
126
|
};
|
|
127
127
|
|
|
128
128
|
export { TechDocsCustomHome };
|
|
129
|
-
//# sourceMappingURL=TechDocsCustomHome-
|
|
129
|
+
//# sourceMappingURL=TechDocsCustomHome-cd6edd4b.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TechDocsCustomHome-cd6edd4b.esm.js","sources":["../../src/home/components/TechDocsCustomHome.tsx"],"sourcesContent":["/*\n * Copyright 2021 The Backstage Authors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport React, { useState } from 'react';\nimport useAsync from 'react-use/lib/useAsync';\nimport { makeStyles } from '@material-ui/core';\nimport { CSSProperties } from '@material-ui/styles';\nimport {\n CATALOG_FILTER_EXISTS,\n catalogApiRef,\n CatalogApi,\n useEntityOwnership,\n} from '@backstage/plugin-catalog-react';\nimport { Entity } from '@backstage/catalog-model';\nimport { DocsTable } from './Tables';\nimport { DocsCardGrid } from './Grids';\nimport { TechDocsPageWrapper } from './TechDocsPageWrapper';\n\nimport {\n CodeSnippet,\n Content,\n HeaderTabs,\n Progress,\n WarningPanel,\n SupportButton,\n ContentHeader,\n} from '@backstage/core-components';\nimport { useApi } from '@backstage/core-plugin-api';\n\nconst panels = {\n DocsTable: DocsTable,\n DocsCardGrid: DocsCardGrid,\n};\n\n/**\n * Available panel types\n *\n * @public\n */\nexport type PanelType = 'DocsCardGrid' | 'DocsTable';\n\n/**\n * Type representing a TechDocsCustomHome panel.\n *\n * @public\n */\nexport interface PanelConfig {\n title: string;\n description: string;\n panelType: PanelType;\n panelCSS?: CSSProperties;\n filterPredicate: ((entity: Entity) => boolean) | string;\n}\n\n/**\n * Type representing a TechDocsCustomHome tab.\n *\n * @public\n */\nexport interface TabConfig {\n label: string;\n panels: PanelConfig[];\n}\n\n/**\n * Type representing a list of TechDocsCustomHome tabs.\n *\n * @public\n */\nexport type TabsConfig = TabConfig[];\n\nconst CustomPanel = ({\n config,\n entities,\n index,\n}: {\n config: PanelConfig;\n entities: Entity[];\n index: number;\n}) => {\n const useStyles = makeStyles({\n panelContainer: {\n marginBottom: '2rem',\n ...(config.panelCSS ? config.panelCSS : {}),\n },\n });\n const classes = useStyles();\n const { loading: loadingOwnership, isOwnedEntity } = useEntityOwnership();\n\n const Panel = panels[config.panelType];\n\n const shownEntities = entities.filter(entity => {\n if (config.filterPredicate === 'ownedByUser') {\n if (loadingOwnership) {\n return false;\n }\n return isOwnedEntity(entity);\n }\n\n return (\n typeof config.filterPredicate === 'function' &&\n config.filterPredicate(entity)\n );\n });\n\n return (\n <>\n <ContentHeader title={config.title} description={config.description}>\n {index === 0 ? (\n <SupportButton>\n Discover documentation in your ecosystem.\n </SupportButton>\n ) : null}\n </ContentHeader>\n <div className={classes.panelContainer}>\n <Panel data-testid=\"techdocs-custom-panel\" entities={shownEntities} />\n </div>\n </>\n );\n};\n\n/**\n * Props for {@link TechDocsCustomHome}\n *\n * @public\n */\nexport type TechDocsCustomHomeProps = {\n tabsConfig: TabsConfig;\n};\n\nexport const TechDocsCustomHome = (props: TechDocsCustomHomeProps) => {\n const { tabsConfig } = props;\n const [selectedTab, setSelectedTab] = useState<number>(0);\n const catalogApi: CatalogApi = useApi(catalogApiRef);\n\n const {\n value: entities,\n loading,\n error,\n } = useAsync(async () => {\n const response = await catalogApi.getEntities({\n filter: {\n 'metadata.annotations.backstage.io/techdocs-ref': CATALOG_FILTER_EXISTS,\n },\n fields: [\n 'apiVersion',\n 'kind',\n 'metadata',\n 'relations',\n 'spec.owner',\n 'spec.type',\n ],\n });\n return response.items.filter((entity: Entity) => {\n return !!entity.metadata.annotations?.['backstage.io/techdocs-ref'];\n });\n });\n\n const currentTabConfig = tabsConfig[selectedTab];\n\n if (loading) {\n return (\n <TechDocsPageWrapper>\n <Content>\n <Progress />\n </Content>\n </TechDocsPageWrapper>\n );\n }\n\n if (error) {\n return (\n <TechDocsPageWrapper>\n <Content>\n <WarningPanel\n severity=\"error\"\n title=\"Could not load available documentation.\"\n >\n <CodeSnippet language=\"text\" text={error.toString()} />\n </WarningPanel>\n </Content>\n </TechDocsPageWrapper>\n );\n }\n\n return (\n <TechDocsPageWrapper>\n <HeaderTabs\n selectedIndex={selectedTab}\n onChange={index => setSelectedTab(index)}\n tabs={tabsConfig.map(({ label }, index) => ({\n id: index.toString(),\n label,\n }))}\n />\n <Content data-testid=\"techdocs-content\">\n {currentTabConfig.panels.map((config, index) => (\n <CustomPanel\n key={index}\n config={config}\n entities={!!entities ? entities : []}\n index={index}\n />\n ))}\n </Content>\n </TechDocsPageWrapper>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -19,7 +19,7 @@ import FeedbackOutlinedIcon from '@material-ui/icons/FeedbackOutlined';
|
|
|
19
19
|
import ReactDOM from 'react-dom';
|
|
20
20
|
import parseGitUrl from 'git-url-parse';
|
|
21
21
|
import MenuIcon from '@material-ui/icons/Menu';
|
|
22
|
-
import
|
|
22
|
+
import IconButton$1 from '@material-ui/core/IconButton';
|
|
23
23
|
import useCopyToClipboard from 'react-use/lib/useCopyToClipboard';
|
|
24
24
|
import Helmet from 'react-helmet';
|
|
25
25
|
import { useTheme as useTheme$1 } from '@material-ui/core/styles';
|
|
@@ -892,7 +892,7 @@ var variables = ({ theme }) => `
|
|
|
892
892
|
/* TYPESET */
|
|
893
893
|
--md-typeset-font-size: 1rem;
|
|
894
894
|
--md-typeset-color: var(--md-default-fg-color);
|
|
895
|
-
--md-typeset-a-color:
|
|
895
|
+
--md-typeset-a-color: ${theme.palette.link};
|
|
896
896
|
--md-typeset-table-color: ${theme.palette.text.primary};
|
|
897
897
|
--md-typeset-del-color: ${theme.palette.type === "dark" ? alpha(theme.palette.error.dark, 0.5) : alpha(theme.palette.error.light, 0.5)};
|
|
898
898
|
--md-typeset-ins-color: ${theme.palette.type === "dark" ? alpha(theme.palette.success.dark, 0.5) : alpha(theme.palette.success.light, 0.5)};
|
|
@@ -930,6 +930,11 @@ const SIDEBAR_WIDTH = "224px";
|
|
|
930
930
|
var layout = ({ theme, sidebar }) => `
|
|
931
931
|
/*================== Layout ==================*/
|
|
932
932
|
|
|
933
|
+
/* mkdocs material v9 compat */
|
|
934
|
+
.md-nav__title {
|
|
935
|
+
color: var(--md-default-fg-color);
|
|
936
|
+
}
|
|
937
|
+
|
|
933
938
|
.md-grid {
|
|
934
939
|
max-width: 100%;
|
|
935
940
|
margin: 0;
|
|
@@ -1530,7 +1535,15 @@ const CopyToClipboardButton = ({ text }) => {
|
|
|
1530
1535
|
onClose: handleClose,
|
|
1531
1536
|
leaveDelay: 1e3
|
|
1532
1537
|
},
|
|
1533
|
-
/* @__PURE__ */ React.createElement(
|
|
1538
|
+
/* @__PURE__ */ React.createElement(
|
|
1539
|
+
IconButton$1,
|
|
1540
|
+
{
|
|
1541
|
+
style: { color: "inherit" },
|
|
1542
|
+
className: "md-clipboard md-icon",
|
|
1543
|
+
onClick: handleClick
|
|
1544
|
+
},
|
|
1545
|
+
/* @__PURE__ */ React.createElement(CopyToClipboardIcon, null)
|
|
1546
|
+
)
|
|
1534
1547
|
);
|
|
1535
1548
|
};
|
|
1536
1549
|
const copyToClipboard = (theme) => {
|
|
@@ -2463,7 +2476,7 @@ const EntityTechdocsContent = techdocsPlugin.provide(
|
|
|
2463
2476
|
const TechDocsCustomHome = techdocsPlugin.provide(
|
|
2464
2477
|
createRoutableExtension({
|
|
2465
2478
|
name: "TechDocsCustomHome",
|
|
2466
|
-
component: () => import('./TechDocsCustomHome-
|
|
2479
|
+
component: () => import('./TechDocsCustomHome-cd6edd4b.esm.js').then(
|
|
2467
2480
|
(m) => m.TechDocsCustomHome
|
|
2468
2481
|
),
|
|
2469
2482
|
mountPoint: rootRouteRef
|
|
@@ -2481,7 +2494,7 @@ const TechDocsIndexPage$2 = techdocsPlugin.provide(
|
|
|
2481
2494
|
const TechDocsReaderPage = techdocsPlugin.provide(
|
|
2482
2495
|
createRoutableExtension({
|
|
2483
2496
|
name: "TechDocsReaderPage",
|
|
2484
|
-
component: () => import('./index-
|
|
2497
|
+
component: () => import('./index-4901a4ac.esm.js').then(
|
|
2485
2498
|
(m) => m.TechDocsReaderPage
|
|
2486
2499
|
),
|
|
2487
2500
|
mountPoint: rootDocsRouteRef
|
|
@@ -2557,4 +2570,4 @@ var Router$1 = /*#__PURE__*/Object.freeze({
|
|
|
2557
2570
|
});
|
|
2558
2571
|
|
|
2559
2572
|
export { DocsTable as D, EntityTechdocsContent as E, Reader as R, TechDocsPageWrapper as T, DocsCardGrid as a, TechDocsReaderPage$1 as b, TechDocsReaderLayout as c, TechDocsCustomHome as d, TechDocsIndexPage$2 as e, TechdocsPage as f, TechDocsReaderPage as g, TechDocsSearchResultListItem as h, techdocsStorageApiRef as i, techdocsApiRef as j, TechDocsClient as k, TechDocsStorageClient as l, TechDocsReaderProvider as m, TechDocsReaderPageHeader as n, TechDocsReaderPageContent as o, TechDocsReaderPageSubheader as p, TechDocsSearch as q, EntityListDocsGrid as r, EntityListDocsTable as s, techdocsPlugin as t, DefaultTechDocsHome as u, TechDocsPicker as v, isTechDocsAvailable as w, Router as x, EmbeddedDocsRouter as y };
|
|
2560
|
-
//# sourceMappingURL=index-
|
|
2573
|
+
//# sourceMappingURL=index-27835b1e.esm.js.map
|