@backstage/plugin-techdocs-react 1.2.14 → 1.2.15-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 +20 -0
- package/dist/addons.esm.js +1 -1
- package/dist/addons.esm.js.map +1 -1
- package/dist/alpha.d.ts +28 -0
- package/dist/alpha.esm.js +26 -0
- package/dist/alpha.esm.js.map +1 -0
- package/dist/index.d.ts +4 -67
- package/dist/types/types.d-BooYUMWM.d.ts +68 -0
- package/package.json +36 -21
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,25 @@
|
|
|
1
1
|
# @backstage/plugin-techdocs-react
|
|
2
2
|
|
|
3
|
+
## 1.2.15-next.1
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- Updated dependencies
|
|
8
|
+
- @backstage/core-components@0.16.5-next.0
|
|
9
|
+
- @backstage/catalog-model@1.7.3
|
|
10
|
+
- @backstage/config@1.3.2
|
|
11
|
+
- @backstage/core-plugin-api@1.10.4
|
|
12
|
+
- @backstage/frontend-plugin-api@0.9.6-next.1
|
|
13
|
+
- @backstage/version-bridge@1.0.11
|
|
14
|
+
|
|
15
|
+
## 1.2.15-next.0
|
|
16
|
+
|
|
17
|
+
### Patch Changes
|
|
18
|
+
|
|
19
|
+
- b5a8208: Added `TechDocsAddonsBlueprint` extension to allow adding of techdocs addons.
|
|
20
|
+
- Updated dependencies
|
|
21
|
+
- @backstage/frontend-plugin-api@0.9.6-next.0
|
|
22
|
+
|
|
3
23
|
## 1.2.14
|
|
4
24
|
|
|
5
25
|
### Patch Changes
|
package/dist/addons.esm.js
CHANGED
|
@@ -68,5 +68,5 @@ const useTechDocsAddons = () => {
|
|
|
68
68
|
return { renderComponentByName, renderComponentsByLocation };
|
|
69
69
|
};
|
|
70
70
|
|
|
71
|
-
export { TECHDOCS_ADDONS_KEY, TECHDOCS_ADDONS_WRAPPER_KEY, TechDocsAddons, createTechDocsAddonExtension, useTechDocsAddons };
|
|
71
|
+
export { TECHDOCS_ADDONS_KEY, TECHDOCS_ADDONS_WRAPPER_KEY, TechDocsAddons, createTechDocsAddonExtension, getDataKeyByName, useTechDocsAddons };
|
|
72
72
|
//# sourceMappingURL=addons.esm.js.map
|
package/dist/addons.esm.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addons.esm.js","sources":["../src/addons.tsx"],"sourcesContent":["/*\n * Copyright 2022 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, { useCallback } from 'react';\nimport { useOutlet } from 'react-router-dom';\n\nimport {\n attachComponentData,\n createReactExtension,\n ElementCollection,\n Extension,\n useElementFilter,\n} from '@backstage/core-plugin-api';\n\nimport { TechDocsAddonLocations, TechDocsAddonOptions } from './types';\n\n/**\n * Key for each addon.\n * @public\n */\nexport const TECHDOCS_ADDONS_KEY = 'techdocs.addons.addon.v1';\n\n/**\n * Marks the `<TechDocsAddons>` registry component.\n * @public\n */\nexport const TECHDOCS_ADDONS_WRAPPER_KEY = 'techdocs.addons.wrapper.v1';\n\n/**\n * TechDocs Addon registry.\n * @public\n */\nexport const TechDocsAddons: React.ComponentType<\n React.PropsWithChildren<{}>\n> = () => null;\n\nattachComponentData(TechDocsAddons, TECHDOCS_ADDONS_WRAPPER_KEY, true);\n\
|
|
1
|
+
{"version":3,"file":"addons.esm.js","sources":["../src/addons.tsx"],"sourcesContent":["/*\n * Copyright 2022 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, { useCallback } from 'react';\nimport { useOutlet } from 'react-router-dom';\n\nimport {\n attachComponentData,\n createReactExtension,\n ElementCollection,\n Extension,\n useElementFilter,\n} from '@backstage/core-plugin-api';\n\nimport { TechDocsAddonLocations, TechDocsAddonOptions } from './types';\n\n/**\n * Key for each addon.\n * @public\n */\nexport const TECHDOCS_ADDONS_KEY = 'techdocs.addons.addon.v1';\n\n/**\n * Marks the `<TechDocsAddons>` registry component.\n * @public\n */\nexport const TECHDOCS_ADDONS_WRAPPER_KEY = 'techdocs.addons.wrapper.v1';\n\n/**\n * TechDocs Addon registry.\n * @public\n */\nexport const TechDocsAddons: React.ComponentType<\n React.PropsWithChildren<{}>\n> = () => null;\n\nattachComponentData(TechDocsAddons, TECHDOCS_ADDONS_WRAPPER_KEY, true);\n\nexport const getDataKeyByName = (name: string) => {\n return `${TECHDOCS_ADDONS_KEY}.${name.toLocaleLowerCase('en-US')}`;\n};\n\n/**\n * Create a TechDocs addon overload signature without props.\n * @public\n */\nexport function createTechDocsAddonExtension(\n options: TechDocsAddonOptions,\n): Extension<() => JSX.Element | null>;\n\n/**\n * Create a TechDocs addon overload signature with props.\n * @public\n */\nexport function createTechDocsAddonExtension<TComponentProps>(\n options: TechDocsAddonOptions<TComponentProps>,\n): Extension<(props: TComponentProps) => JSX.Element | null>;\n\n/**\n * Create a TechDocs addon implementation.\n * @public\n */\nexport function createTechDocsAddonExtension<\n TComponentProps extends React.PropsWithChildren<{}>,\n>(\n options: TechDocsAddonOptions<TComponentProps>,\n): Extension<(props: TComponentProps) => JSX.Element | null> {\n const { name, component: TechDocsAddon } = options;\n return createReactExtension({\n name,\n component: {\n sync: (props: TComponentProps) => <TechDocsAddon {...props} />,\n },\n data: {\n [TECHDOCS_ADDONS_KEY]: options,\n [getDataKeyByName(name)]: true,\n },\n });\n}\n\nconst getTechDocsAddonByName = (\n collection: ElementCollection,\n key: string,\n): JSX.Element | undefined => {\n return collection.selectByComponentData({ key }).getElements()[0];\n};\n\nconst getAllTechDocsAddons = (collection: ElementCollection) => {\n return collection\n .selectByComponentData({\n key: TECHDOCS_ADDONS_WRAPPER_KEY,\n })\n .selectByComponentData({\n key: TECHDOCS_ADDONS_KEY,\n });\n};\n\nconst getAllTechDocsAddonsData = (collection: ElementCollection) => {\n return collection\n .selectByComponentData({\n key: TECHDOCS_ADDONS_WRAPPER_KEY,\n })\n .findComponentData<TechDocsAddonOptions>({\n key: TECHDOCS_ADDONS_KEY,\n });\n};\n\n/**\n * hook to use addons in components\n * @public\n */\nexport const useTechDocsAddons = () => {\n const node = useOutlet();\n const collection = useElementFilter(node, getAllTechDocsAddons);\n const options = useElementFilter(node, getAllTechDocsAddonsData);\n\n const findAddonByData = useCallback(\n (data: TechDocsAddonOptions | undefined) => {\n if (!collection || !data) return null;\n const nameKey = getDataKeyByName(data.name);\n return getTechDocsAddonByName(collection, nameKey) ?? null;\n },\n [collection],\n );\n\n const renderComponentByName = useCallback(\n (name: string) => {\n const data = options.find(option => option.name === name);\n return data ? findAddonByData(data) : null;\n },\n [options, findAddonByData],\n );\n\n const renderComponentsByLocation = useCallback(\n (location: keyof typeof TechDocsAddonLocations) => {\n const data = options.filter(option => option.location === location);\n return data.length ? data.map(findAddonByData) : null;\n },\n [options, findAddonByData],\n );\n\n return { renderComponentByName, renderComponentsByLocation };\n};\n"],"names":[],"mappings":"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"}
|
package/dist/alpha.d.ts
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import * as _backstage_frontend_plugin_api from '@backstage/frontend-plugin-api';
|
|
2
|
+
import { T as TechDocsAddonOptions } from './types/types.d-BooYUMWM.js';
|
|
3
|
+
export { a as TechDocsAddonLocations } from './types/types.d-BooYUMWM.js';
|
|
4
|
+
import { ComponentType } from 'react';
|
|
5
|
+
import '@backstage/catalog-model';
|
|
6
|
+
|
|
7
|
+
/** @alpha */
|
|
8
|
+
declare const techDocsAddonDataRef: _backstage_frontend_plugin_api.ConfigurableExtensionDataRef<TechDocsAddonOptions, "techdocs.addon", {}>;
|
|
9
|
+
/**
|
|
10
|
+
* Creates an extension to add addons to the TechDocs standalone reader and entity pages.
|
|
11
|
+
* @alpha
|
|
12
|
+
*/
|
|
13
|
+
declare const AddonBlueprint: _backstage_frontend_plugin_api.ExtensionBlueprint<{
|
|
14
|
+
kind: "addon";
|
|
15
|
+
name: undefined;
|
|
16
|
+
params: TechDocsAddonOptions;
|
|
17
|
+
output: _backstage_frontend_plugin_api.ConfigurableExtensionDataRef<TechDocsAddonOptions, "techdocs.addon", {}>;
|
|
18
|
+
inputs: {};
|
|
19
|
+
config: {};
|
|
20
|
+
configInput: {};
|
|
21
|
+
dataRefs: {
|
|
22
|
+
addon: _backstage_frontend_plugin_api.ConfigurableExtensionDataRef<TechDocsAddonOptions, "techdocs.addon", {}>;
|
|
23
|
+
};
|
|
24
|
+
}>;
|
|
25
|
+
/** @alpha */
|
|
26
|
+
declare const attachTechDocsAddonComponentData: <P>(techDocsAddon: ComponentType<P>, data: TechDocsAddonOptions) => void;
|
|
27
|
+
|
|
28
|
+
export { AddonBlueprint, TechDocsAddonOptions, attachTechDocsAddonComponentData, techDocsAddonDataRef };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { attachComponentData } from '@backstage/core-plugin-api';
|
|
2
|
+
import { TECHDOCS_ADDONS_KEY, getDataKeyByName } from './addons.esm.js';
|
|
3
|
+
import { createExtensionDataRef, createExtensionBlueprint } from '@backstage/frontend-plugin-api';
|
|
4
|
+
|
|
5
|
+
const techDocsAddonDataRef = createExtensionDataRef().with({
|
|
6
|
+
id: "techdocs.addon"
|
|
7
|
+
});
|
|
8
|
+
const AddonBlueprint = createExtensionBlueprint({
|
|
9
|
+
kind: "addon",
|
|
10
|
+
attachTo: [
|
|
11
|
+
{ id: "page:techdocs/reader", input: "addons" },
|
|
12
|
+
{ id: "entity-content:techdocs", input: "addons" }
|
|
13
|
+
],
|
|
14
|
+
output: [techDocsAddonDataRef],
|
|
15
|
+
factory: (params) => [techDocsAddonDataRef(params)],
|
|
16
|
+
dataRefs: {
|
|
17
|
+
addon: techDocsAddonDataRef
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
const attachTechDocsAddonComponentData = (techDocsAddon, data) => {
|
|
21
|
+
attachComponentData(techDocsAddon, TECHDOCS_ADDONS_KEY, data);
|
|
22
|
+
attachComponentData(techDocsAddon, getDataKeyByName(data.name), true);
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
export { AddonBlueprint, attachTechDocsAddonComponentData, techDocsAddonDataRef };
|
|
26
|
+
//# sourceMappingURL=alpha.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alpha.esm.js","sources":["../src/alpha.ts"],"sourcesContent":["/*\n * Copyright 2025 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 */\nimport { TechDocsAddonOptions } from './types';\nimport { attachComponentData } from '@backstage/core-plugin-api';\nimport { ComponentType } from 'react';\nimport { getDataKeyByName, TECHDOCS_ADDONS_KEY } from './addons';\nimport {\n createExtensionBlueprint,\n createExtensionDataRef,\n} from '@backstage/frontend-plugin-api';\n\n/** @alpha */\nexport type { TechDocsAddonOptions, TechDocsAddonLocations } from './types';\n\n/** @alpha */\nexport const techDocsAddonDataRef =\n createExtensionDataRef<TechDocsAddonOptions>().with({\n id: 'techdocs.addon',\n });\n\n/**\n * Creates an extension to add addons to the TechDocs standalone reader and entity pages.\n * @alpha\n */\nexport const AddonBlueprint = createExtensionBlueprint({\n kind: 'addon',\n attachTo: [\n { id: 'page:techdocs/reader', input: 'addons' },\n { id: 'entity-content:techdocs', input: 'addons' },\n ],\n output: [techDocsAddonDataRef],\n factory: (params: TechDocsAddonOptions) => [techDocsAddonDataRef(params)],\n dataRefs: {\n addon: techDocsAddonDataRef,\n },\n});\n\n/** @alpha */\nexport const attachTechDocsAddonComponentData = <P>(\n techDocsAddon: ComponentType<P>,\n data: TechDocsAddonOptions,\n) => {\n attachComponentData(techDocsAddon, TECHDOCS_ADDONS_KEY, data);\n attachComponentData(techDocsAddon, getDataKeyByName(data.name), true);\n};\n"],"names":[],"mappings":";;;;AA4Ba,MAAA,oBAAA,GACX,sBAA6C,EAAA,CAAE,IAAK,CAAA;AAAA,EAClD,EAAI,EAAA;AACN,CAAC;AAMI,MAAM,iBAAiB,wBAAyB,CAAA;AAAA,EACrD,IAAM,EAAA,OAAA;AAAA,EACN,QAAU,EAAA;AAAA,IACR,EAAE,EAAA,EAAI,sBAAwB,EAAA,KAAA,EAAO,QAAS,EAAA;AAAA,IAC9C,EAAE,EAAA,EAAI,yBAA2B,EAAA,KAAA,EAAO,QAAS;AAAA,GACnD;AAAA,EACA,MAAA,EAAQ,CAAC,oBAAoB,CAAA;AAAA,EAC7B,SAAS,CAAC,MAAA,KAAiC,CAAC,oBAAA,CAAqB,MAAM,CAAC,CAAA;AAAA,EACxE,QAAU,EAAA;AAAA,IACR,KAAO,EAAA;AAAA;AAEX,CAAC;AAGY,MAAA,gCAAA,GAAmC,CAC9C,aAAA,EACA,IACG,KAAA;AACH,EAAoB,mBAAA,CAAA,aAAA,EAAe,qBAAqB,IAAI,CAAA;AAC5D,EAAA,mBAAA,CAAoB,aAAe,EAAA,gBAAA,CAAiB,IAAK,CAAA,IAAI,GAAG,IAAI,CAAA;AACtE;;;;"}
|
package/dist/index.d.ts
CHANGED
|
@@ -1,74 +1,11 @@
|
|
|
1
|
-
import React, {
|
|
1
|
+
import React, { Dispatch, SetStateAction, ReactNode, PropsWithChildren } from 'react';
|
|
2
2
|
import * as _backstage_core_plugin_api from '@backstage/core-plugin-api';
|
|
3
3
|
import { Extension } from '@backstage/core-plugin-api';
|
|
4
|
-
import {
|
|
4
|
+
import { T as TechDocsAddonOptions, a as TechDocsAddonLocations, b as TechDocsMetadata, c as TechDocsEntityMetadata } from './types/types.d-BooYUMWM.js';
|
|
5
|
+
import { CompoundEntityRef } from '@backstage/catalog-model';
|
|
5
6
|
import { AsyncState } from 'react-use/esm/useAsync';
|
|
6
7
|
import { Config } from '@backstage/config';
|
|
7
8
|
|
|
8
|
-
/**
|
|
9
|
-
* Metadata for TechDocs page
|
|
10
|
-
*
|
|
11
|
-
* @public
|
|
12
|
-
*/
|
|
13
|
-
type TechDocsMetadata = {
|
|
14
|
-
site_name: string;
|
|
15
|
-
site_description: string;
|
|
16
|
-
};
|
|
17
|
-
/**
|
|
18
|
-
* Metadata for TechDocs Entity
|
|
19
|
-
*
|
|
20
|
-
* @public
|
|
21
|
-
*/
|
|
22
|
-
type TechDocsEntityMetadata = Entity & {
|
|
23
|
-
locationMetadata?: {
|
|
24
|
-
type: string;
|
|
25
|
-
target: string;
|
|
26
|
-
};
|
|
27
|
-
};
|
|
28
|
-
/**
|
|
29
|
-
* Locations for which TechDocs addons may be declared and rendered.
|
|
30
|
-
* @public
|
|
31
|
-
*/
|
|
32
|
-
declare const TechDocsAddonLocations: Readonly<{
|
|
33
|
-
/**
|
|
34
|
-
* These addons fill up the header from the right, on the same line as the
|
|
35
|
-
* title.
|
|
36
|
-
*/
|
|
37
|
-
readonly Header: "Header";
|
|
38
|
-
/**
|
|
39
|
-
* These addons appear below the header and above all content; tooling addons
|
|
40
|
-
* can be inserted for convenience.
|
|
41
|
-
*/
|
|
42
|
-
readonly Subheader: "Subheader";
|
|
43
|
-
/**
|
|
44
|
-
* These addons are items added to the settings menu list and are designed to make
|
|
45
|
-
* the reader experience customizable, for example accessibility options
|
|
46
|
-
*/
|
|
47
|
-
readonly Settings: "Settings";
|
|
48
|
-
/**
|
|
49
|
-
* These addons appear left of the content and above the navigation.
|
|
50
|
-
*/
|
|
51
|
-
readonly PrimarySidebar: "PrimarySidebar";
|
|
52
|
-
/**
|
|
53
|
-
* These addons appear right of the content and above the table of contents.
|
|
54
|
-
*/
|
|
55
|
-
readonly SecondarySidebar: "SecondarySidebar";
|
|
56
|
-
/**
|
|
57
|
-
* A virtual location which allows mutation of all content within the shadow
|
|
58
|
-
* root by transforming DOM nodes. These addons should return null on render.
|
|
59
|
-
*/
|
|
60
|
-
readonly Content: "Content";
|
|
61
|
-
}>;
|
|
62
|
-
/**
|
|
63
|
-
* Options for creating a TechDocs addon.
|
|
64
|
-
* @public
|
|
65
|
-
*/
|
|
66
|
-
type TechDocsAddonOptions<TAddonProps = {}> = {
|
|
67
|
-
name: string;
|
|
68
|
-
location: keyof typeof TechDocsAddonLocations;
|
|
69
|
-
component: ComponentType<TAddonProps>;
|
|
70
|
-
};
|
|
71
|
-
|
|
72
9
|
/**
|
|
73
10
|
* Key for each addon.
|
|
74
11
|
* @public
|
|
@@ -330,4 +267,4 @@ declare const useShadowRootSelection: (waitMillis?: number) => Selection | null;
|
|
|
330
267
|
*/
|
|
331
268
|
declare function toLowercaseEntityRefMaybe(entityRef: CompoundEntityRef, config: Config): CompoundEntityRef;
|
|
332
269
|
|
|
333
|
-
export { SHADOW_DOM_STYLE_LOAD_EVENT, type SyncResult, TECHDOCS_ADDONS_KEY, TECHDOCS_ADDONS_WRAPPER_KEY, TechDocsAddonLocations,
|
|
270
|
+
export { SHADOW_DOM_STYLE_LOAD_EVENT, type SyncResult, TECHDOCS_ADDONS_KEY, TECHDOCS_ADDONS_WRAPPER_KEY, TechDocsAddonLocations, TechDocsAddonOptions, TechDocsAddons, type TechDocsApi, TechDocsEntityMetadata, TechDocsMetadata, TechDocsReaderPageProvider, type TechDocsReaderPageProviderProps, type TechDocsReaderPageProviderRenderFunction, type TechDocsReaderPageValue, TechDocsShadowDom, type TechDocsShadowDomProps, type TechDocsStorageApi, createTechDocsAddonExtension, techdocsApiRef, techdocsStorageApiRef, toLowercaseEntityRefMaybe, useShadowDomStylesLoading, useShadowRoot, useShadowRootElements, useShadowRootSelection, useTechDocsAddons, useTechDocsReaderPage };
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { ComponentType } from 'react';
|
|
2
|
+
import { Entity } from '@backstage/catalog-model';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Metadata for TechDocs page
|
|
6
|
+
*
|
|
7
|
+
* @public
|
|
8
|
+
*/
|
|
9
|
+
type TechDocsMetadata = {
|
|
10
|
+
site_name: string;
|
|
11
|
+
site_description: string;
|
|
12
|
+
};
|
|
13
|
+
/**
|
|
14
|
+
* Metadata for TechDocs Entity
|
|
15
|
+
*
|
|
16
|
+
* @public
|
|
17
|
+
*/
|
|
18
|
+
type TechDocsEntityMetadata = Entity & {
|
|
19
|
+
locationMetadata?: {
|
|
20
|
+
type: string;
|
|
21
|
+
target: string;
|
|
22
|
+
};
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Locations for which TechDocs addons may be declared and rendered.
|
|
26
|
+
* @public
|
|
27
|
+
*/
|
|
28
|
+
declare const TechDocsAddonLocations: Readonly<{
|
|
29
|
+
/**
|
|
30
|
+
* These addons fill up the header from the right, on the same line as the
|
|
31
|
+
* title.
|
|
32
|
+
*/
|
|
33
|
+
readonly Header: "Header";
|
|
34
|
+
/**
|
|
35
|
+
* These addons appear below the header and above all content; tooling addons
|
|
36
|
+
* can be inserted for convenience.
|
|
37
|
+
*/
|
|
38
|
+
readonly Subheader: "Subheader";
|
|
39
|
+
/**
|
|
40
|
+
* These addons are items added to the settings menu list and are designed to make
|
|
41
|
+
* the reader experience customizable, for example accessibility options
|
|
42
|
+
*/
|
|
43
|
+
readonly Settings: "Settings";
|
|
44
|
+
/**
|
|
45
|
+
* These addons appear left of the content and above the navigation.
|
|
46
|
+
*/
|
|
47
|
+
readonly PrimarySidebar: "PrimarySidebar";
|
|
48
|
+
/**
|
|
49
|
+
* These addons appear right of the content and above the table of contents.
|
|
50
|
+
*/
|
|
51
|
+
readonly SecondarySidebar: "SecondarySidebar";
|
|
52
|
+
/**
|
|
53
|
+
* A virtual location which allows mutation of all content within the shadow
|
|
54
|
+
* root by transforming DOM nodes. These addons should return null on render.
|
|
55
|
+
*/
|
|
56
|
+
readonly Content: "Content";
|
|
57
|
+
}>;
|
|
58
|
+
/**
|
|
59
|
+
* Options for creating a TechDocs addon.
|
|
60
|
+
* @public
|
|
61
|
+
*/
|
|
62
|
+
type TechDocsAddonOptions<TAddonProps = {}> = {
|
|
63
|
+
name: string;
|
|
64
|
+
location: keyof typeof TechDocsAddonLocations;
|
|
65
|
+
component: ComponentType<TAddonProps>;
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
export { type TechDocsAddonOptions as T, TechDocsAddonLocations as a, type TechDocsMetadata as b, type TechDocsEntityMetadata as c };
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@backstage/plugin-techdocs-react",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.15-next.1",
|
|
4
4
|
"description": "Shared frontend utilities for TechDocs and Addons",
|
|
5
5
|
"backstage": {
|
|
6
6
|
"role": "web-library",
|
|
@@ -14,9 +14,7 @@
|
|
|
14
14
|
]
|
|
15
15
|
},
|
|
16
16
|
"publishConfig": {
|
|
17
|
-
"access": "public"
|
|
18
|
-
"main": "dist/index.esm.js",
|
|
19
|
-
"types": "dist/index.d.ts"
|
|
17
|
+
"access": "public"
|
|
20
18
|
},
|
|
21
19
|
"keywords": [
|
|
22
20
|
"backstage",
|
|
@@ -30,8 +28,31 @@
|
|
|
30
28
|
},
|
|
31
29
|
"license": "Apache-2.0",
|
|
32
30
|
"sideEffects": false,
|
|
33
|
-
"
|
|
34
|
-
|
|
31
|
+
"exports": {
|
|
32
|
+
".": {
|
|
33
|
+
"import": "./dist/index.esm.js",
|
|
34
|
+
"types": "./dist/index.d.ts",
|
|
35
|
+
"default": "./dist/index.esm.js"
|
|
36
|
+
},
|
|
37
|
+
"./alpha": {
|
|
38
|
+
"import": "./dist/alpha.esm.js",
|
|
39
|
+
"types": "./dist/alpha.d.ts",
|
|
40
|
+
"default": "./dist/alpha.esm.js"
|
|
41
|
+
},
|
|
42
|
+
"./package.json": "./package.json"
|
|
43
|
+
},
|
|
44
|
+
"main": "./dist/index.esm.js",
|
|
45
|
+
"types": "./dist/index.d.ts",
|
|
46
|
+
"typesVersions": {
|
|
47
|
+
"*": {
|
|
48
|
+
"index": [
|
|
49
|
+
"dist/index.d.ts"
|
|
50
|
+
],
|
|
51
|
+
"alpha": [
|
|
52
|
+
"dist/alpha.d.ts"
|
|
53
|
+
]
|
|
54
|
+
}
|
|
55
|
+
},
|
|
35
56
|
"files": [
|
|
36
57
|
"dist"
|
|
37
58
|
],
|
|
@@ -45,11 +66,12 @@
|
|
|
45
66
|
"test": "backstage-cli package test"
|
|
46
67
|
},
|
|
47
68
|
"dependencies": {
|
|
48
|
-
"@backstage/catalog-model": "
|
|
49
|
-
"@backstage/config": "
|
|
50
|
-
"@backstage/core-components": "
|
|
51
|
-
"@backstage/core-plugin-api": "
|
|
52
|
-
"@backstage/
|
|
69
|
+
"@backstage/catalog-model": "1.7.3",
|
|
70
|
+
"@backstage/config": "1.3.2",
|
|
71
|
+
"@backstage/core-components": "0.16.5-next.0",
|
|
72
|
+
"@backstage/core-plugin-api": "1.10.4",
|
|
73
|
+
"@backstage/frontend-plugin-api": "0.9.6-next.1",
|
|
74
|
+
"@backstage/version-bridge": "1.0.11",
|
|
53
75
|
"@material-ui/core": "^4.12.2",
|
|
54
76
|
"@material-ui/styles": "^4.11.0",
|
|
55
77
|
"jss": "~10.10.0",
|
|
@@ -58,9 +80,9 @@
|
|
|
58
80
|
"react-use": "^17.2.4"
|
|
59
81
|
},
|
|
60
82
|
"devDependencies": {
|
|
61
|
-
"@backstage/cli": "
|
|
62
|
-
"@backstage/test-utils": "
|
|
63
|
-
"@backstage/theme": "
|
|
83
|
+
"@backstage/cli": "0.30.1-next.0",
|
|
84
|
+
"@backstage/test-utils": "1.7.5",
|
|
85
|
+
"@backstage/theme": "0.6.4",
|
|
64
86
|
"@testing-library/jest-dom": "^6.0.0",
|
|
65
87
|
"@testing-library/react": "^16.0.0",
|
|
66
88
|
"@types/react": "^18.0.0",
|
|
@@ -79,12 +101,5 @@
|
|
|
79
101
|
"optional": true
|
|
80
102
|
}
|
|
81
103
|
},
|
|
82
|
-
"typesVersions": {
|
|
83
|
-
"*": {
|
|
84
|
-
"index": [
|
|
85
|
-
"dist/index.d.ts"
|
|
86
|
-
]
|
|
87
|
-
}
|
|
88
|
-
},
|
|
89
104
|
"module": "./dist/index.esm.js"
|
|
90
105
|
}
|