@backstage/plugin-techdocs-react 1.2.14 → 1.2.15-next.0

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 CHANGED
@@ -1,5 +1,13 @@
1
1
  # @backstage/plugin-techdocs-react
2
2
 
3
+ ## 1.2.15-next.0
4
+
5
+ ### Patch Changes
6
+
7
+ - b5a8208: Added `TechDocsAddonsBlueprint` extension to allow adding of techdocs addons.
8
+ - Updated dependencies
9
+ - @backstage/frontend-plugin-api@0.9.6-next.0
10
+
3
11
  ## 1.2.14
4
12
 
5
13
  ### Patch Changes
@@ -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
@@ -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\nconst 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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"}
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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"}
@@ -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, { ComponentType, Dispatch, SetStateAction, ReactNode, PropsWithChildren } from '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 { Entity, CompoundEntityRef } from '@backstage/catalog-model';
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, type TechDocsAddonOptions, TechDocsAddons, type TechDocsApi, type TechDocsEntityMetadata, type TechDocsMetadata, TechDocsReaderPageProvider, type TechDocsReaderPageProviderProps, type TechDocsReaderPageProviderRenderFunction, type TechDocsReaderPageValue, TechDocsShadowDom, type TechDocsShadowDomProps, type TechDocsStorageApi, createTechDocsAddonExtension, techdocsApiRef, techdocsStorageApiRef, toLowercaseEntityRefMaybe, useShadowDomStylesLoading, useShadowRoot, useShadowRootElements, useShadowRootSelection, useTechDocsAddons, useTechDocsReaderPage };
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.14",
3
+ "version": "1.2.15-next.0",
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
- "main": "dist/index.esm.js",
34
- "types": "dist/index.d.ts",
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": "^1.7.3",
49
- "@backstage/config": "^1.3.2",
50
- "@backstage/core-components": "^0.16.4",
51
- "@backstage/core-plugin-api": "^1.10.4",
52
- "@backstage/version-bridge": "^1.0.11",
69
+ "@backstage/catalog-model": "1.7.3",
70
+ "@backstage/config": "1.3.2",
71
+ "@backstage/core-components": "0.16.4",
72
+ "@backstage/core-plugin-api": "1.10.4",
73
+ "@backstage/frontend-plugin-api": "0.9.6-next.0",
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": "^0.30.0",
62
- "@backstage/test-utils": "^1.7.5",
63
- "@backstage/theme": "^0.6.4",
83
+ "@backstage/cli": "0.30.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
  }