@pagerduty/backstage-plugin 0.12.1-next.4 → 0.12.1-next.41
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/dist/esm/{index-6fe701d0.esm.js → index-488de318.esm.js} +2 -2
- package/dist/esm/{index-6fe701d0.esm.js.map → index-488de318.esm.js.map} +1 -1
- package/dist/esm/index-56a508a0.esm.js +186 -0
- package/dist/esm/index-56a508a0.esm.js.map +1 -0
- package/dist/esm/{index-7d59d818.esm.js → index-b5179766.esm.js} +23 -5
- package/dist/esm/index-b5179766.esm.js.map +1 -0
- package/dist/index.d.ts +10 -4
- package/dist/index.esm.js +1 -1
- package/package.json +2 -3
- package/dist/esm/index-369bd887.esm.js +0 -165
- package/dist/esm/index-369bd887.esm.js.map +0 -1
- package/dist/esm/index-7d59d818.esm.js.map +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
|
-
import { P as PagerDutyCard } from './index-
|
|
2
|
+
import { P as PagerDutyCard } from './index-b5179766.esm.js';
|
|
3
3
|
import '@backstage/core-plugin-api';
|
|
4
4
|
import '@backstage/errors';
|
|
5
5
|
import '@backstage/plugin-home-react';
|
|
@@ -34,4 +34,4 @@ const Content = (props) => {
|
|
|
34
34
|
};
|
|
35
35
|
|
|
36
36
|
export { Content };
|
|
37
|
-
//# sourceMappingURL=index-
|
|
37
|
+
//# sourceMappingURL=index-488de318.esm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-
|
|
1
|
+
{"version":3,"file":"index-488de318.esm.js","sources":["../../src/components/HomePagePagerDutyCard/Content.tsx"],"sourcesContent":["/*\n * Copyright 2020 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// eslint-disable-next-line @backstage/no-undeclared-imports\nimport React from 'react';\n\nimport { PagerDutyEntity } from '../../types';\nimport { PagerDutyCard } from '../PagerDutyCard';\n\n/** @public */\nexport type HomePagePagerDutyCardProps = PagerDutyEntity & {\n readOnly?: boolean;\n};\n\n/** @public */\nexport const Content = (props: HomePagePagerDutyCardProps) => {\n return <PagerDutyCard {...props} />;\n};\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2Ba,MAAA,OAAA,GAAU,CAAC,KAAsC,KAAA;AAC5D,EAAO,uBAAA,KAAA,CAAA,aAAA,CAAC,aAAe,EAAA,EAAA,GAAG,KAAO,EAAA,CAAA,CAAA;AACnC;;;;"}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import React, { useState, useEffect } from 'react';
|
|
2
|
+
import { Typography, FormControl, Select, MenuItem, Button, Grid } from '@material-ui/core';
|
|
3
|
+
import { Table, Page, Header, Content } from '@backstage/core-components';
|
|
4
|
+
import { useApi } from '@backstage/core-plugin-api';
|
|
5
|
+
import { p as pagerDutyApiRef } from './index-b5179766.esm.js';
|
|
6
|
+
import { catalogApiRef } from '@backstage/plugin-catalog-react';
|
|
7
|
+
import '@backstage/errors';
|
|
8
|
+
import '@backstage/plugin-home-react';
|
|
9
|
+
import 'luxon';
|
|
10
|
+
import '@material-ui/icons/OpenInBrowser';
|
|
11
|
+
import '../assets/emptystate.svg';
|
|
12
|
+
import 'react-use/lib/useAsyncFn';
|
|
13
|
+
import '@material-ui/lab';
|
|
14
|
+
import '../assets/forbiddenstate.svg';
|
|
15
|
+
import '@material-ui/core/Avatar';
|
|
16
|
+
import '@material-ui/icons/Notifications';
|
|
17
|
+
import 'react-use/lib/useAsync';
|
|
18
|
+
import '@material-ui/icons/Link';
|
|
19
|
+
import '../assets/PD-Green.svg';
|
|
20
|
+
import '../assets/PD-White.svg';
|
|
21
|
+
import 'validate-color';
|
|
22
|
+
import '@material-ui/icons/Info';
|
|
23
|
+
import '@material-ui/icons/CheckCircle';
|
|
24
|
+
import '@material-ui/icons/RadioButtonUnchecked';
|
|
25
|
+
import '@material-ui/core/styles';
|
|
26
|
+
import 'react-use';
|
|
27
|
+
import '@material-ui/lab/Alert/Alert';
|
|
28
|
+
import '@backstage/catalog-model';
|
|
29
|
+
import '@material-ui/icons/AddAlert';
|
|
30
|
+
import '@material-ui/icons/ExpandMore';
|
|
31
|
+
|
|
32
|
+
function getColorFromStatus(status) {
|
|
33
|
+
switch (status) {
|
|
34
|
+
case "InSync":
|
|
35
|
+
return "green";
|
|
36
|
+
case "OutOfSync":
|
|
37
|
+
return "red";
|
|
38
|
+
case "NotMapped":
|
|
39
|
+
return "orange";
|
|
40
|
+
default:
|
|
41
|
+
return "gray";
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
const ServiceMappingComponent = () => {
|
|
45
|
+
const [tableData, setTableData] = useState([]);
|
|
46
|
+
const [isLoading, setIsLoading] = useState(true);
|
|
47
|
+
const pagerDutyApi = useApi(pagerDutyApiRef);
|
|
48
|
+
const catalogApi = useApi(catalogApiRef);
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
async function fetchEntities() {
|
|
51
|
+
const { items } = await catalogApi.getEntities({
|
|
52
|
+
filter: { kind: "Component" }
|
|
53
|
+
});
|
|
54
|
+
const backstageServices = [];
|
|
55
|
+
items.forEach((entity) => {
|
|
56
|
+
var _a, _b, _c, _d, _e, _f;
|
|
57
|
+
backstageServices.push({
|
|
58
|
+
name: (_a = entity.metadata) == null ? void 0 : _a.name,
|
|
59
|
+
id: (_c = (_b = entity.metadata) == null ? void 0 : _b.uid) != null ? _c : "",
|
|
60
|
+
system: JSON.stringify((_d = entity.spec) == null ? void 0 : _d.system) || "",
|
|
61
|
+
owner: JSON.stringify((_e = entity.spec) == null ? void 0 : _e.owner) || "",
|
|
62
|
+
lifecycle: JSON.stringify((_f = entity.spec) == null ? void 0 : _f.lifecycle) || ""
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
return backstageServices;
|
|
66
|
+
}
|
|
67
|
+
async function fetchServices() {
|
|
68
|
+
const { mappings: foundServices } = await pagerDutyApi.getEntityMappings();
|
|
69
|
+
return foundServices;
|
|
70
|
+
}
|
|
71
|
+
Promise.all([fetchEntities(), fetchServices()]).then(
|
|
72
|
+
([entities, mappings]) => {
|
|
73
|
+
const data = buildTableData(entities, mappings);
|
|
74
|
+
setTableData(data);
|
|
75
|
+
}
|
|
76
|
+
);
|
|
77
|
+
async function handleMappingChange(service, event) {
|
|
78
|
+
event.preventDefault();
|
|
79
|
+
const updatedData = [...tableData];
|
|
80
|
+
updatedData.findIndex((item) => item.name === service.serviceName);
|
|
81
|
+
await pagerDutyApi.storeServiceMapping(service.serviceId, event.target.value);
|
|
82
|
+
}
|
|
83
|
+
function buildTableData(entities, mappings) {
|
|
84
|
+
const data = mappings.map((service) => {
|
|
85
|
+
return {
|
|
86
|
+
name: service.serviceName,
|
|
87
|
+
team: service.team,
|
|
88
|
+
escalationPolicy: service.escalationPolicy,
|
|
89
|
+
// status of mapping
|
|
90
|
+
mappingStatus: /* @__PURE__ */ React.createElement(
|
|
91
|
+
Typography,
|
|
92
|
+
{
|
|
93
|
+
variant: "body2",
|
|
94
|
+
style: {
|
|
95
|
+
color: getColorFromStatus(service.status)
|
|
96
|
+
}
|
|
97
|
+
},
|
|
98
|
+
service.status
|
|
99
|
+
),
|
|
100
|
+
mapping: (
|
|
101
|
+
// dropdown menu with static options. If service.mapping is defined select that option
|
|
102
|
+
/* @__PURE__ */ React.createElement(FormControl, { variant: "standard" }, /* @__PURE__ */ React.createElement(
|
|
103
|
+
Select,
|
|
104
|
+
{
|
|
105
|
+
displayEmpty: true,
|
|
106
|
+
onChange: async (selection) => {
|
|
107
|
+
handleMappingChange(service, selection);
|
|
108
|
+
},
|
|
109
|
+
value: service.entityRef
|
|
110
|
+
},
|
|
111
|
+
/* @__PURE__ */ React.createElement(MenuItem, { value: "" }, /* @__PURE__ */ React.createElement("em", null, "None")),
|
|
112
|
+
entities.map((backstageService) => {
|
|
113
|
+
return /* @__PURE__ */ React.createElement(
|
|
114
|
+
MenuItem,
|
|
115
|
+
{
|
|
116
|
+
key: backstageService.id,
|
|
117
|
+
value: backstageService.id
|
|
118
|
+
},
|
|
119
|
+
backstageService.name
|
|
120
|
+
);
|
|
121
|
+
})
|
|
122
|
+
))
|
|
123
|
+
),
|
|
124
|
+
actions: /* @__PURE__ */ React.createElement(
|
|
125
|
+
Button,
|
|
126
|
+
{
|
|
127
|
+
variant: "contained",
|
|
128
|
+
color: "primary",
|
|
129
|
+
href: service.serviceUrl
|
|
130
|
+
},
|
|
131
|
+
"Open in PagerDuty"
|
|
132
|
+
)
|
|
133
|
+
};
|
|
134
|
+
});
|
|
135
|
+
return data;
|
|
136
|
+
}
|
|
137
|
+
setIsLoading(false);
|
|
138
|
+
}, [catalogApi, pagerDutyApi, tableData]);
|
|
139
|
+
const DenseTable = ({ items }) => {
|
|
140
|
+
const [data, setData] = useState([]);
|
|
141
|
+
useEffect(() => {
|
|
142
|
+
setData(items);
|
|
143
|
+
}, [items]);
|
|
144
|
+
const columns = [
|
|
145
|
+
{ title: "PagerDuty Service", field: "name" },
|
|
146
|
+
{ title: "Team", field: "team" },
|
|
147
|
+
{ title: "Escalation Policy", field: "escalationPolicy" },
|
|
148
|
+
{ title: "Mapping", field: "mapping" },
|
|
149
|
+
{ title: "Status", field: "mappingStatus" },
|
|
150
|
+
{ title: "Actions", field: "actions" }
|
|
151
|
+
];
|
|
152
|
+
return /* @__PURE__ */ React.createElement(
|
|
153
|
+
Table,
|
|
154
|
+
{
|
|
155
|
+
isLoading,
|
|
156
|
+
title: "PagerDuty Service Import",
|
|
157
|
+
subtitle: "Use this page to import services from PagerDuty and map them to existing Backstage services. Only 1:1 mapping is allowed.",
|
|
158
|
+
options: {
|
|
159
|
+
search: true,
|
|
160
|
+
paging: true,
|
|
161
|
+
pageSize: 10,
|
|
162
|
+
pageSizeOptions: [10, 25, 50],
|
|
163
|
+
sorting: true,
|
|
164
|
+
emptyRowsWhenPaging: false,
|
|
165
|
+
showFirstLastPageButtons: true,
|
|
166
|
+
columnResizable: true,
|
|
167
|
+
columnsButton: true,
|
|
168
|
+
rowStyle: {
|
|
169
|
+
height: "10px"
|
|
170
|
+
},
|
|
171
|
+
padding: "dense"
|
|
172
|
+
},
|
|
173
|
+
columns,
|
|
174
|
+
data
|
|
175
|
+
}
|
|
176
|
+
);
|
|
177
|
+
};
|
|
178
|
+
return /* @__PURE__ */ React.createElement(DenseTable, { items: tableData });
|
|
179
|
+
};
|
|
180
|
+
|
|
181
|
+
const PagerDutyPage = () => {
|
|
182
|
+
return /* @__PURE__ */ React.createElement(Page, { themeId: "home" }, /* @__PURE__ */ React.createElement(Header, { title: "PagerDuty", subtitle: "Advanced configurations" }), /* @__PURE__ */ React.createElement(Content, null, /* @__PURE__ */ React.createElement(Grid, { container: true, spacing: 3, direction: "column" }, /* @__PURE__ */ React.createElement(Grid, { item: true }, /* @__PURE__ */ React.createElement(ServiceMappingComponent, null)))));
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
export { PagerDutyPage };
|
|
186
|
+
//# sourceMappingURL=index-56a508a0.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-56a508a0.esm.js","sources":["../../src/components/PagerDutyPage/ServiceMappingComponent.tsx","../../src/components/PagerDutyPage/index.tsx"],"sourcesContent":["import React, { ChangeEvent, useEffect, useState } from \"react\";\nimport { Table, TableColumn } from \"@backstage/core-components\";\nimport {\n Button,\n FormControl,\n MenuItem,\n Select,\n Typography,\n} from \"@material-ui/core\";\nimport { PagerDutyEntityMapping } from \"@pagerduty/backstage-plugin-common\";\nimport { useApi } from \"@backstage/core-plugin-api\";\nimport { pagerDutyApiRef } from \"../../api\";\nimport { catalogApiRef } from \"@backstage/plugin-catalog-react\";\nimport { Entity } from \"@backstage/catalog-model\";\n\ntype Service = {\n name: string; // \"Ads\"\n id: string; // \"QWe1j283n12j132\"\n system: string; // \"Production\"\n owner: string; // \"Mapped\"\n lifecycle: string; // \"Ads\"\n};\n\ntype TableItem = {\n name: string | undefined;\n team: string | undefined;\n escalationPolicy: string | undefined;\n mappingStatus: JSX.Element;\n mapping: JSX.Element;\n actions: JSX.Element;\n};\n\ntype DenseTableProps = {\n items: TableItem[];\n};\n\nfunction getColorFromStatus(status?: string) {\n switch (status) {\n case \"InSync\":\n return \"green\";\n case \"OutOfSync\":\n return \"red\";\n case \"NotMapped\":\n return \"orange\";\n default:\n return \"gray\";\n }\n}\n\nexport const ServiceMappingComponent = () => {\n // const [catalogEntities, setCatalogEntities] = useState<Service[]>([]);\n // const [serviceMappings, setServiceMappings] = useState<\n // PagerDutyEntityMapping[]\n // >([]);\n const [tableData, setTableData] = useState<TableItem[]>([]);\n const [isLoading, setIsLoading] = useState(true);\n\n const pagerDutyApi = useApi(pagerDutyApiRef);\n const catalogApi = useApi(catalogApiRef);\n\n useEffect(() => {\n async function fetchEntities(): Promise<Service[]> {\n const { items } = await catalogApi.getEntities({\n filter: { kind: \"Component\" },\n });\n\n const backstageServices: Service[] = [];\n items.forEach((entity: Entity) => {\n backstageServices.push({\n name: entity.metadata?.name,\n id: entity.metadata?.uid ?? \"\",\n system: JSON.stringify(entity.spec?.system) || \"\",\n owner: JSON.stringify(entity.spec?.owner) || \"\",\n lifecycle: JSON.stringify(entity.spec?.lifecycle) || \"\",\n });\n });\n\n return backstageServices;\n }\n\n async function fetchServices(): Promise<PagerDutyEntityMapping[]> {\n const { mappings: foundServices } =\n await pagerDutyApi.getEntityMappings();\n\n return foundServices;\n }\n\n Promise.all([fetchEntities(), fetchServices()]).then(\n ([entities, mappings]) => {\n // setCatalogEntities(entities);\n // setServiceMappings(mappings);\n\n const data: TableItem[] = buildTableData(entities, mappings);\n setTableData(data);\n }\n );\n\n async function handleMappingChange(\n service: PagerDutyEntityMapping,\n event: ChangeEvent<{\n name?: string | undefined;\n value: unknown;\n }>\n ) {\n event.preventDefault();\n const updatedData = [...tableData];\n\n // find the service in updatedData\n updatedData.findIndex((item) => item.name === service.serviceName);\n // updatedData[serviceIndex].mappingStatus = (\n // <Typography\n // variant=\"body2\"\n // style={{\n // color: getColorFromStatus(\"OutOfSync\"),\n // }}\n // >\n // \"OutOfSync\"\n // </Typography>\n // );\n\n // update the mapping status\n // service.status = \"OutOfSync\";\n\n // // update the mapping\n // service.entityRef = entityId;\n\n // store the mapping in the database\n await pagerDutyApi.storeServiceMapping(service.serviceId, event.target.value as string);\n // setTableData(updatedData);\n }\n\n function buildTableData(\n entities: Service[],\n mappings: PagerDutyEntityMapping[]\n ): TableItem[] {\n const data: TableItem[] = mappings.map((service) => {\n return {\n name: service.serviceName,\n team: service.team,\n escalationPolicy: service.escalationPolicy,\n // status of mapping\n mappingStatus: (\n <Typography\n variant=\"body2\"\n style={{\n color: getColorFromStatus(service.status),\n }}\n >\n {service.status}\n </Typography>\n ),\n mapping: (\n // dropdown menu with static options. If service.mapping is defined select that option\n <FormControl variant=\"standard\">\n <Select\n displayEmpty\n onChange={async (selection) => {\n handleMappingChange(service, selection);\n }}\n value={service.entityRef}\n >\n <MenuItem value=\"\">\n <em>None</em>\n </MenuItem>\n {entities.map((backstageService) => {\n return (\n <MenuItem\n key={backstageService.id}\n value={backstageService.id}\n >\n {backstageService.name}\n </MenuItem>\n );\n })}\n </Select>\n </FormControl>\n ),\n actions: (\n <Button\n variant=\"contained\"\n color=\"primary\"\n href={service.serviceUrl}\n >\n Open in PagerDuty\n </Button>\n ),\n };\n });\n\n return data;\n }\n\n setIsLoading(false);\n }, [catalogApi, pagerDutyApi, tableData]);\n\n const DenseTable = ({ items }: DenseTableProps) => {\n const [data, setData] = useState<TableItem[]>([]);\n\n useEffect(() => {\n setData(items);\n }, [items]);\n\n const columns: TableColumn[] = [\n { title: \"PagerDuty Service\", field: \"name\" },\n { title: \"Team\", field: \"team\" },\n { title: \"Escalation Policy\", field: \"escalationPolicy\" },\n { title: \"Mapping\", field: \"mapping\" },\n { title: \"Status\", field: \"mappingStatus\" },\n { title: \"Actions\", field: \"actions\" },\n ];\n\n return (\n <Table\n isLoading={isLoading}\n title=\"PagerDuty Service Import\"\n subtitle=\"Use this page to import services from PagerDuty and map them to existing Backstage services. Only 1:1 mapping is allowed.\"\n options={{\n search: true,\n paging: true,\n pageSize: 10,\n pageSizeOptions: [10, 25, 50],\n sorting: true,\n emptyRowsWhenPaging: false,\n showFirstLastPageButtons: true,\n columnResizable: true,\n columnsButton: true,\n rowStyle: {\n height: \"10px\",\n },\n padding: \"dense\",\n }}\n columns={columns}\n data={data}\n />\n );\n };\n\n return <DenseTable items={tableData} />;\n};\n","import React from \"react\";\nimport { Grid } from \"@material-ui/core\";\nimport { Header, Page, Content } from \"@backstage/core-components\";\nimport { ServiceMappingComponent } from \"./ServiceMappingComponent\";\n\n/** @public */\nexport const PagerDutyPage = () => {\n // const [toggleImport, setToggleImport] = useState(false);\n // const [toggleSave, setToggleSave] = useState(false);\n\n // const handleImport = () => {\n // setToggleImport(!toggleImport);\n // };\n\n // const handleSave = () => {\n // setToggleSave(!toggleSave);\n // }\n\n return (\n <Page themeId=\"home\">\n <Header title=\"PagerDuty\" subtitle=\"Advanced configurations\" />\n <Content>\n {/* <Grid container spacing={3} direction=\"column\">\n <Grid item alignContent=\"flex-end\">\n <Button variant=\"contained\" color=\"primary\" onClick={() => {handleImport()}}>\n Import\n </Button>\n <Button variant=\"outlined\" color=\"primary\" onClick={() => {handleSave()}}>\n Save\n </Button>\n </Grid>\n </Grid> */}\n <Grid container spacing={3} direction=\"column\">\n <Grid item>\n <ServiceMappingComponent />\n </Grid>\n </Grid>\n </Content>\n </Page>\n );\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -83,12 +83,30 @@ class PagerDutyClient {
|
|
|
83
83
|
}
|
|
84
84
|
return response;
|
|
85
85
|
}
|
|
86
|
-
async
|
|
86
|
+
async getEntityMappings() {
|
|
87
87
|
const url = `${await this.config.discoveryApi.getBaseUrl(
|
|
88
88
|
"pagerduty"
|
|
89
|
-
)}/
|
|
89
|
+
)}/mapping/entity`;
|
|
90
90
|
return await this.findByUrl(url);
|
|
91
91
|
}
|
|
92
|
+
async storeServiceMapping(serviceId, backstageEntityId) {
|
|
93
|
+
const body = JSON.stringify({
|
|
94
|
+
entityRef: backstageEntityId,
|
|
95
|
+
serviceId
|
|
96
|
+
});
|
|
97
|
+
const options = {
|
|
98
|
+
method: "POST",
|
|
99
|
+
headers: {
|
|
100
|
+
"Content-Type": "application/json; charset=UTF-8",
|
|
101
|
+
Accept: "application/json, text/plain, */*"
|
|
102
|
+
},
|
|
103
|
+
body
|
|
104
|
+
};
|
|
105
|
+
const url = `${await this.config.discoveryApi.getBaseUrl(
|
|
106
|
+
"pagerduty"
|
|
107
|
+
)}/mapping/entity`;
|
|
108
|
+
return this.request(url, options);
|
|
109
|
+
}
|
|
92
110
|
async getServiceByEntity(entity) {
|
|
93
111
|
return await this.getServiceByPagerDutyEntity(getPagerDutyEntity(entity));
|
|
94
112
|
}
|
|
@@ -211,7 +229,7 @@ const pagerDutyPlugin = createPlugin({
|
|
|
211
229
|
const PagerDutyPage = pagerDutyPlugin.provide(
|
|
212
230
|
createRoutableExtension({
|
|
213
231
|
name: "PagerDutyPage",
|
|
214
|
-
component: () => import('./index-
|
|
232
|
+
component: () => import('./index-56a508a0.esm.js').then((m) => m.PagerDutyPage),
|
|
215
233
|
mountPoint: rootRouteRef
|
|
216
234
|
})
|
|
217
235
|
);
|
|
@@ -239,7 +257,7 @@ const HomePagePagerDutyCard = pagerDutyPlugin.provide(
|
|
|
239
257
|
createCardExtension({
|
|
240
258
|
name: "HomePagePagerDutyCard",
|
|
241
259
|
title: "PagerDuty Homepage Card",
|
|
242
|
-
components: () => import('./index-
|
|
260
|
+
components: () => import('./index-488de318.esm.js'),
|
|
243
261
|
settings: {
|
|
244
262
|
schema: {
|
|
245
263
|
title: "PagerDuty",
|
|
@@ -1605,4 +1623,4 @@ function TriggerButton(props) {
|
|
|
1605
1623
|
const PagerDutyCard = EntityPagerDutyCard;
|
|
1606
1624
|
|
|
1607
1625
|
export { EntityPagerDutyCard$1 as E, HomePagePagerDutyCard as H, PagerDutyCard$1 as P, TriggerButton as T, UnauthorizedError as U, pagerDutyPlugin as a, PagerDutyPage as b, EntityPagerDutySmallCard$1 as c, isPluginApplicableToEntity as d, PagerDutyClient as e, PagerDutyCard as f, isPluginApplicableToEntity$1 as i, pagerDutyApiRef as p };
|
|
1608
|
-
//# sourceMappingURL=index-
|
|
1626
|
+
//# sourceMappingURL=index-b5179766.esm.js.map
|