@backstage/plugin-scaffolder 1.19.3 → 1.19.4-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 +39 -0
- package/alpha/package.json +1 -1
- package/dist/alpha.esm.js +3 -8
- package/dist/alpha.esm.js.map +1 -1
- package/dist/{esm/routes-BvToNy4N.esm.js → api.esm.js} +2 -46
- package/dist/api.esm.js.map +1 -0
- package/dist/components/ActionsPage/ActionsPage.esm.js +186 -0
- package/dist/components/ActionsPage/ActionsPage.esm.js.map +1 -0
- package/dist/components/FileBrowser/FileBrowser.esm.js +90 -0
- package/dist/components/FileBrowser/FileBrowser.esm.js.map +1 -0
- package/dist/components/ListTasksPage/ListTasksPage.esm.js +120 -0
- package/dist/components/ListTasksPage/ListTasksPage.esm.js.map +1 -0
- package/dist/components/ListTasksPage/OwnerListPicker.esm.js +88 -0
- package/dist/components/ListTasksPage/OwnerListPicker.esm.js.map +1 -0
- package/dist/components/ListTasksPage/columns/CreatedAtColumn.esm.js +13 -0
- package/dist/components/ListTasksPage/columns/CreatedAtColumn.esm.js.map +1 -0
- package/dist/components/ListTasksPage/columns/OwnerEntityColumn.esm.js +31 -0
- package/dist/components/ListTasksPage/columns/OwnerEntityColumn.esm.js.map +1 -0
- package/dist/components/ListTasksPage/columns/TaskStatusColumn.esm.js +17 -0
- package/dist/components/ListTasksPage/columns/TaskStatusColumn.esm.js.map +1 -0
- package/dist/components/ListTasksPage/columns/TemplateTitleColumn.esm.js +21 -0
- package/dist/components/ListTasksPage/columns/TemplateTitleColumn.esm.js.map +1 -0
- package/dist/components/OngoingTask/ContextMenu.esm.js +86 -0
- package/dist/components/OngoingTask/ContextMenu.esm.js.map +1 -0
- package/dist/components/OngoingTask/OngoingTask.esm.js +173 -0
- package/dist/components/OngoingTask/OngoingTask.esm.js.map +1 -0
- package/dist/components/Router/Router.esm.js +105 -0
- package/dist/components/Router/Router.esm.js.map +1 -0
- package/dist/components/Router/index.esm.js +2 -0
- package/dist/components/Router/index.esm.js.map +1 -0
- package/dist/components/TemplateTypePicker/TemplateTypePicker.esm.js +70 -0
- package/dist/components/TemplateTypePicker/TemplateTypePicker.esm.js.map +1 -0
- package/dist/components/fields/EntityNamePicker/EntityNamePicker.esm.js +34 -0
- package/dist/components/fields/EntityNamePicker/EntityNamePicker.esm.js.map +1 -0
- package/dist/components/fields/EntityNamePicker/schema.esm.js +8 -0
- package/dist/components/fields/EntityNamePicker/schema.esm.js.map +1 -0
- package/dist/components/fields/EntityNamePicker/validation.esm.js +12 -0
- package/dist/components/fields/EntityNamePicker/validation.esm.js.map +1 -0
- package/dist/components/fields/EntityPicker/EntityPicker.esm.js +151 -0
- package/dist/components/fields/EntityPicker/EntityPicker.esm.js.map +1 -0
- package/dist/components/fields/EntityPicker/schema.esm.js +29 -0
- package/dist/components/fields/EntityPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/EntityTagsPicker/EntityTagsPicker.esm.js +84 -0
- package/dist/components/fields/EntityTagsPicker/EntityTagsPicker.esm.js.map +1 -0
- package/dist/components/fields/EntityTagsPicker/schema.esm.js +15 -0
- package/dist/components/fields/EntityTagsPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/MultiEntityPicker/MultiEntityPicker.esm.js +168 -0
- package/dist/components/fields/MultiEntityPicker/MultiEntityPicker.esm.js.map +1 -0
- package/dist/components/fields/MultiEntityPicker/schema.esm.js +23 -0
- package/dist/components/fields/MultiEntityPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/MyGroupsPicker/MyGroupsPicker.esm.js +83 -0
- package/dist/components/fields/MyGroupsPicker/MyGroupsPicker.esm.js.map +1 -0
- package/dist/components/fields/MyGroupsPicker/schema.esm.js +14 -0
- package/dist/components/fields/MyGroupsPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/OwnedEntityPicker/OwnedEntityPicker.esm.js +68 -0
- package/dist/components/fields/OwnedEntityPicker/OwnedEntityPicker.esm.js.map +1 -0
- package/dist/components/fields/OwnedEntityPicker/schema.esm.js +24 -0
- package/dist/components/fields/OwnedEntityPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/OwnerPicker/OwnerPicker.esm.js +37 -0
- package/dist/components/fields/OwnerPicker/OwnerPicker.esm.js.map +1 -0
- package/dist/components/fields/OwnerPicker/schema.esm.js +24 -0
- package/dist/components/fields/OwnerPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/AzureRepoPicker.esm.js +75 -0
- package/dist/components/fields/RepoUrlPicker/AzureRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/BitbucketRepoPicker.esm.js +80 -0
- package/dist/components/fields/RepoUrlPicker/BitbucketRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/GerritRepoPicker.esm.js +38 -0
- package/dist/components/fields/RepoUrlPicker/GerritRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/GiteaRepoPicker.esm.js +44 -0
- package/dist/components/fields/RepoUrlPicker/GiteaRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/GithubRepoPicker.esm.js +42 -0
- package/dist/components/fields/RepoUrlPicker/GithubRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/GitlabRepoPicker.esm.js +44 -0
- package/dist/components/fields/RepoUrlPicker/GitlabRepoPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPicker.esm.js +200 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPicker.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPickerHost.esm.js +56 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPickerHost.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPickerRepoName.esm.js +48 -0
- package/dist/components/fields/RepoUrlPicker/RepoUrlPickerRepoName.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/schema.esm.js +32 -0
- package/dist/components/fields/RepoUrlPicker/schema.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/utils.esm.js +46 -0
- package/dist/components/fields/RepoUrlPicker/utils.esm.js.map +1 -0
- package/dist/components/fields/RepoUrlPicker/validation.esm.js +43 -0
- package/dist/components/fields/RepoUrlPicker/validation.esm.js.map +1 -0
- package/dist/components/fields/SecretInput/SecretInput.esm.js +48 -0
- package/dist/components/fields/SecretInput/SecretInput.esm.js.map +1 -0
- package/dist/components/fields/utils.esm.js +15 -0
- package/dist/components/fields/utils.esm.js.map +1 -0
- package/dist/deprecated.esm.js +13 -0
- package/dist/deprecated.esm.js.map +1 -0
- package/dist/extensions/default.esm.js +72 -0
- package/dist/extensions/default.esm.js.map +1 -0
- package/dist/index.esm.js +13 -214
- package/dist/index.esm.js.map +1 -1
- package/dist/lib/download/helpers.esm.js +11 -0
- package/dist/lib/download/helpers.esm.js.map +1 -0
- package/dist/lib/filesystem/WebFileSystemAccess.esm.js +56 -0
- package/dist/lib/filesystem/WebFileSystemAccess.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/CustomFieldExplorer.esm.js +151 -0
- package/dist/next/TemplateEditorPage/CustomFieldExplorer.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DirectoryEditorContext.esm.js +186 -0
- package/dist/next/TemplateEditorPage/DirectoryEditorContext.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunContext.esm.js +110 -0
- package/dist/next/TemplateEditorPage/DryRunContext.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResults.esm.js +70 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResults.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsList.esm.js +98 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsList.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsSplitView.esm.js +31 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsSplitView.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsView.esm.js +145 -0
- package/dist/next/TemplateEditorPage/DryRunResults/DryRunResultsView.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/IconLink.esm.js +25 -0
- package/dist/next/TemplateEditorPage/DryRunResults/IconLink.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/TaskPageLinks.esm.js +40 -0
- package/dist/next/TemplateEditorPage/DryRunResults/TaskPageLinks.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/DryRunResults/TaskStatusStepper.esm.js +135 -0
- package/dist/next/TemplateEditorPage/DryRunResults/TaskStatusStepper.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditor.esm.js +52 -0
- package/dist/next/TemplateEditorPage/TemplateEditor.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditorBrowser.esm.js +74 -0
- package/dist/next/TemplateEditorPage/TemplateEditorBrowser.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditorForm.esm.js +174 -0
- package/dist/next/TemplateEditorPage/TemplateEditorForm.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditorIntro.esm.js +93 -0
- package/dist/next/TemplateEditorPage/TemplateEditorIntro.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditorPage.esm.js +82 -0
- package/dist/next/TemplateEditorPage/TemplateEditorPage.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateEditorTextArea.esm.js +120 -0
- package/dist/next/TemplateEditorPage/TemplateEditorTextArea.esm.js.map +1 -0
- package/dist/next/TemplateEditorPage/TemplateFormPreviewer.esm.js +160 -0
- package/dist/next/TemplateEditorPage/TemplateFormPreviewer.esm.js.map +1 -0
- package/dist/next/TemplateListPage/RegisterExistingButton.esm.js +35 -0
- package/dist/next/TemplateListPage/RegisterExistingButton.esm.js.map +1 -0
- package/dist/next/TemplateListPage/TemplateListPage.esm.js +101 -0
- package/dist/next/TemplateListPage/TemplateListPage.esm.js.map +1 -0
- package/dist/next/TemplateWizardPage/TemplateWizardPage.esm.js +67 -0
- package/dist/next/TemplateWizardPage/TemplateWizardPage.esm.js.map +1 -0
- package/dist/next/TemplateWizardPage/TemplateWizardPageContextMenu.esm.js +60 -0
- package/dist/next/TemplateWizardPage/TemplateWizardPageContextMenu.esm.js.map +1 -0
- package/dist/plugin.esm.js +125 -0
- package/dist/plugin.esm.js.map +1 -0
- package/dist/routes.esm.js +47 -0
- package/dist/routes.esm.js.map +1 -0
- package/package.json +18 -18
- package/dist/esm/OngoingTask-ClfJCJcE.esm.js +0 -1575
- package/dist/esm/OngoingTask-ClfJCJcE.esm.js.map +0 -1
- package/dist/esm/index-UcPid-q1.esm.js +0 -2553
- package/dist/esm/index-UcPid-q1.esm.js.map +0 -1
- package/dist/esm/routes-BvToNy4N.esm.js.map +0 -1
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import React, { useEffect } from 'react';
|
|
2
|
+
import { Progress, Select } from '@backstage/core-components';
|
|
3
|
+
import FormControl from '@material-ui/core/FormControl';
|
|
4
|
+
import FormHelperText from '@material-ui/core/FormHelperText';
|
|
5
|
+
import { useApi } from '@backstage/core-plugin-api';
|
|
6
|
+
import { scaffolderApiRef } from '@backstage/plugin-scaffolder-react';
|
|
7
|
+
import useAsync from 'react-use/esm/useAsync';
|
|
8
|
+
|
|
9
|
+
const RepoUrlPickerHost = (props) => {
|
|
10
|
+
const { host, hosts, onChange, rawErrors } = props;
|
|
11
|
+
const scaffolderApi = useApi(scaffolderApiRef);
|
|
12
|
+
const { value: { integrations } = { integrations: [] }, loading } = useAsync(
|
|
13
|
+
async () => {
|
|
14
|
+
return await scaffolderApi.getIntegrationsList({
|
|
15
|
+
allowedHosts: hosts != null ? hosts : []
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (!host) {
|
|
21
|
+
if (hosts == null ? void 0 : hosts.length) {
|
|
22
|
+
onChange(hosts[0]);
|
|
23
|
+
} else if (integrations == null ? void 0 : integrations.length) {
|
|
24
|
+
onChange(integrations[0].host);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}, [hosts, host, onChange, integrations]);
|
|
28
|
+
const hostsOptions = integrations ? integrations.filter((i) => (hosts == null ? void 0 : hosts.length) ? hosts == null ? void 0 : hosts.includes(i.host) : true).map((i) => ({ label: i.title, value: i.host })) : [{ label: "Loading...", value: "loading" }];
|
|
29
|
+
if (loading) {
|
|
30
|
+
return /* @__PURE__ */ React.createElement(Progress, null);
|
|
31
|
+
}
|
|
32
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
33
|
+
FormControl,
|
|
34
|
+
{
|
|
35
|
+
margin: "normal",
|
|
36
|
+
required: true,
|
|
37
|
+
error: (rawErrors == null ? void 0 : rawErrors.length) > 0 && !host
|
|
38
|
+
},
|
|
39
|
+
/* @__PURE__ */ React.createElement(
|
|
40
|
+
Select,
|
|
41
|
+
{
|
|
42
|
+
native: true,
|
|
43
|
+
disabled: (hosts == null ? void 0 : hosts.length) === 1,
|
|
44
|
+
label: "Host",
|
|
45
|
+
onChange: (s) => onChange(String(Array.isArray(s) ? s[0] : s)),
|
|
46
|
+
selected: host,
|
|
47
|
+
items: hostsOptions,
|
|
48
|
+
"data-testid": "host-select"
|
|
49
|
+
}
|
|
50
|
+
),
|
|
51
|
+
/* @__PURE__ */ React.createElement(FormHelperText, null, "The host where the repository will be created")
|
|
52
|
+
));
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
export { RepoUrlPickerHost };
|
|
56
|
+
//# sourceMappingURL=RepoUrlPickerHost.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoUrlPickerHost.esm.js","sources":["../../../../src/components/fields/RepoUrlPicker/RepoUrlPickerHost.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 */\nimport React, { useEffect } from 'react';\nimport { Progress, Select, SelectItem } from '@backstage/core-components';\nimport FormControl from '@material-ui/core/FormControl';\nimport FormHelperText from '@material-ui/core/FormHelperText';\nimport { useApi } from '@backstage/core-plugin-api';\nimport { scaffolderApiRef } from '@backstage/plugin-scaffolder-react';\nimport useAsync from 'react-use/esm/useAsync';\n\nexport const RepoUrlPickerHost = (props: {\n host?: string;\n hosts?: string[];\n onChange: (host: string) => void;\n rawErrors: string[];\n}) => {\n const { host, hosts, onChange, rawErrors } = props;\n const scaffolderApi = useApi(scaffolderApiRef);\n\n const { value: { integrations } = { integrations: [] }, loading } = useAsync(\n async () => {\n return await scaffolderApi.getIntegrationsList({\n allowedHosts: hosts ?? [],\n });\n },\n );\n\n useEffect(() => {\n // If there is no host chosen currently\n if (!host) {\n // Set the first of the allowedHosts option if that available\n if (hosts?.length) {\n onChange(hosts[0]);\n // if there's no hosts provided, fallback to using the first integration\n } else if (integrations?.length) {\n onChange(integrations[0].host);\n }\n }\n }, [hosts, host, onChange, integrations]);\n\n // If there are no allowedHosts provided, then show all integrations. Otherwise, only show integrations\n // that are provided in the dropdown for the user to choose from.\n const hostsOptions: SelectItem[] = integrations\n ? integrations\n .filter(i => (hosts?.length ? hosts?.includes(i.host) : true))\n .map(i => ({ label: i.title, value: i.host }))\n : [{ label: 'Loading...', value: 'loading' }];\n\n if (loading) {\n return <Progress />;\n }\n\n return (\n <>\n <FormControl\n margin=\"normal\"\n required\n error={rawErrors?.length > 0 && !host}\n >\n <Select\n native\n disabled={hosts?.length === 1}\n label=\"Host\"\n onChange={s => onChange(String(Array.isArray(s) ? s[0] : s))}\n selected={host}\n items={hostsOptions}\n data-testid=\"host-select\"\n />\n\n <FormHelperText>\n The host where the repository will be created\n </FormHelperText>\n </FormControl>\n </>\n );\n};\n"],"names":[],"mappings":";;;;;;;;AAuBa,MAAA,iBAAA,GAAoB,CAAC,KAK5B,KAAA;AACJ,EAAA,MAAM,EAAE,IAAA,EAAM,KAAO,EAAA,QAAA,EAAU,WAAc,GAAA,KAAA,CAAA;AAC7C,EAAM,MAAA,aAAA,GAAgB,OAAO,gBAAgB,CAAA,CAAA;AAE7C,EAAM,MAAA,EAAE,KAAO,EAAA,EAAE,YAAa,EAAA,GAAI,EAAE,YAAA,EAAc,EAAC,EAAK,EAAA,OAAA,EAAY,GAAA,QAAA;AAAA,IAClE,YAAY;AACV,MAAO,OAAA,MAAM,cAAc,mBAAoB,CAAA;AAAA,QAC7C,YAAA,EAAc,wBAAS,EAAC;AAAA,OACzB,CAAA,CAAA;AAAA,KACH;AAAA,GACF,CAAA;AAEA,EAAA,SAAA,CAAU,MAAM;AAEd,IAAA,IAAI,CAAC,IAAM,EAAA;AAET,MAAA,IAAI,+BAAO,MAAQ,EAAA;AACjB,QAAS,QAAA,CAAA,KAAA,CAAM,CAAC,CAAC,CAAA,CAAA;AAAA,OAEnB,MAAA,IAAW,6CAAc,MAAQ,EAAA;AAC/B,QAAS,QAAA,CAAA,YAAA,CAAa,CAAC,CAAA,CAAE,IAAI,CAAA,CAAA;AAAA,OAC/B;AAAA,KACF;AAAA,KACC,CAAC,KAAA,EAAO,IAAM,EAAA,QAAA,EAAU,YAAY,CAAC,CAAA,CAAA;AAIxC,EAAA,MAAM,YAA6B,GAAA,YAAA,GAC/B,YACG,CAAA,MAAA,CAAO,CAAM,CAAA,KAAA,CAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,MAAS,IAAA,KAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,KAAA,CAAO,QAAS,CAAA,CAAA,CAAE,IAAQ,CAAA,GAAA,IAAK,EAC5D,GAAI,CAAA,CAAA,CAAA,MAAM,EAAE,KAAA,EAAO,CAAE,CAAA,KAAA,EAAO,KAAO,EAAA,CAAA,CAAE,IAAK,EAAA,CAAE,CAC/C,GAAA,CAAC,EAAE,KAAA,EAAO,YAAc,EAAA,KAAA,EAAO,WAAW,CAAA,CAAA;AAE9C,EAAA,IAAI,OAAS,EAAA;AACX,IAAA,2CAAQ,QAAS,EAAA,IAAA,CAAA,CAAA;AAAA,GACnB;AAEA,EAAA,uBAEI,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,WAAA;AAAA,IAAA;AAAA,MACC,MAAO,EAAA,QAAA;AAAA,MACP,QAAQ,EAAA,IAAA;AAAA,MACR,KAAO,EAAA,CAAA,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAW,MAAS,IAAA,CAAA,IAAK,CAAC,IAAA;AAAA,KAAA;AAAA,oBAEjC,KAAA,CAAA,aAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,MAAM,EAAA,IAAA;AAAA,QACN,QAAA,EAAA,CAAU,+BAAO,MAAW,MAAA,CAAA;AAAA,QAC5B,KAAM,EAAA,MAAA;AAAA,QACN,QAAU,EAAA,CAAA,CAAA,KAAK,QAAS,CAAA,MAAA,CAAO,KAAM,CAAA,OAAA,CAAQ,CAAC,CAAA,GAAI,CAAE,CAAA,CAAC,CAAI,GAAA,CAAC,CAAC,CAAA;AAAA,QAC3D,QAAU,EAAA,IAAA;AAAA,QACV,KAAO,EAAA,YAAA;AAAA,QACP,aAAY,EAAA,aAAA;AAAA,OAAA;AAAA,KACd;AAAA,oBAEA,KAAA,CAAA,aAAA,CAAC,sBAAe,+CAEhB,CAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React, { useEffect } from 'react';
|
|
2
|
+
import { Select } from '@backstage/core-components';
|
|
3
|
+
import FormControl from '@material-ui/core/FormControl';
|
|
4
|
+
import FormHelperText from '@material-ui/core/FormHelperText';
|
|
5
|
+
import Input from '@material-ui/core/Input';
|
|
6
|
+
import InputLabel from '@material-ui/core/InputLabel';
|
|
7
|
+
|
|
8
|
+
const RepoUrlPickerRepoName = (props) => {
|
|
9
|
+
const { repoName, allowedRepos, onChange, rawErrors } = props;
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
if (!repoName) {
|
|
12
|
+
if (allowedRepos == null ? void 0 : allowedRepos.length) {
|
|
13
|
+
onChange(allowedRepos[0]);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
}, [allowedRepos, repoName, onChange]);
|
|
17
|
+
const repoItems = allowedRepos ? allowedRepos.map((i) => ({ label: i, value: i })) : [{ label: "Loading...", value: "loading" }];
|
|
18
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
19
|
+
FormControl,
|
|
20
|
+
{
|
|
21
|
+
margin: "normal",
|
|
22
|
+
required: true,
|
|
23
|
+
error: (rawErrors == null ? void 0 : rawErrors.length) > 0 && !repoName
|
|
24
|
+
},
|
|
25
|
+
(allowedRepos == null ? void 0 : allowedRepos.length) ? /* @__PURE__ */ React.createElement(
|
|
26
|
+
Select,
|
|
27
|
+
{
|
|
28
|
+
native: true,
|
|
29
|
+
label: "Repositories Available",
|
|
30
|
+
onChange: (selected) => onChange(String(Array.isArray(selected) ? selected[0] : selected)),
|
|
31
|
+
disabled: allowedRepos.length === 1,
|
|
32
|
+
selected: repoName,
|
|
33
|
+
items: repoItems
|
|
34
|
+
}
|
|
35
|
+
) : /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(InputLabel, { htmlFor: "repoNameInput" }, "Repository"), /* @__PURE__ */ React.createElement(
|
|
36
|
+
Input,
|
|
37
|
+
{
|
|
38
|
+
id: "repoNameInput",
|
|
39
|
+
onChange: (e) => onChange(String(e.target.value)),
|
|
40
|
+
value: repoName
|
|
41
|
+
}
|
|
42
|
+
)),
|
|
43
|
+
/* @__PURE__ */ React.createElement(FormHelperText, null, "The name of the repository")
|
|
44
|
+
));
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { RepoUrlPickerRepoName };
|
|
48
|
+
//# sourceMappingURL=RepoUrlPickerRepoName.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RepoUrlPickerRepoName.esm.js","sources":["../../../../src/components/fields/RepoUrlPicker/RepoUrlPickerRepoName.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 */\nimport React, { useEffect } from 'react';\nimport { Select, SelectItem } from '@backstage/core-components';\nimport FormControl from '@material-ui/core/FormControl';\nimport FormHelperText from '@material-ui/core/FormHelperText';\nimport Input from '@material-ui/core/Input';\nimport InputLabel from '@material-ui/core/InputLabel';\n\nexport const RepoUrlPickerRepoName = (props: {\n repoName?: string;\n allowedRepos?: string[];\n onChange: (host: string) => void;\n rawErrors: string[];\n}) => {\n const { repoName, allowedRepos, onChange, rawErrors } = props;\n\n useEffect(() => {\n // If there is no repoName chosen currently\n if (!repoName) {\n // Set the first of the allowedRepos option if that available\n if (allowedRepos?.length) {\n onChange(allowedRepos[0]);\n }\n }\n }, [allowedRepos, repoName, onChange]);\n\n const repoItems: SelectItem[] = allowedRepos\n ? allowedRepos.map(i => ({ label: i, value: i }))\n : [{ label: 'Loading...', value: 'loading' }];\n\n return (\n <>\n <FormControl\n margin=\"normal\"\n required\n error={rawErrors?.length > 0 && !repoName}\n >\n {allowedRepos?.length ? (\n <Select\n native\n label=\"Repositories Available\"\n onChange={selected =>\n onChange(String(Array.isArray(selected) ? selected[0] : selected))\n }\n disabled={allowedRepos.length === 1}\n selected={repoName}\n items={repoItems}\n />\n ) : (\n <>\n <InputLabel htmlFor=\"repoNameInput\">Repository</InputLabel>\n <Input\n id=\"repoNameInput\"\n onChange={e => onChange(String(e.target.value))}\n value={repoName}\n />\n </>\n )}\n <FormHelperText>The name of the repository</FormHelperText>\n </FormControl>\n </>\n );\n};\n"],"names":[],"mappings":";;;;;;;AAsBa,MAAA,qBAAA,GAAwB,CAAC,KAKhC,KAAA;AACJ,EAAA,MAAM,EAAE,QAAA,EAAU,YAAc,EAAA,QAAA,EAAU,WAAc,GAAA,KAAA,CAAA;AAExD,EAAA,SAAA,CAAU,MAAM;AAEd,IAAA,IAAI,CAAC,QAAU,EAAA;AAEb,MAAA,IAAI,6CAAc,MAAQ,EAAA;AACxB,QAAS,QAAA,CAAA,YAAA,CAAa,CAAC,CAAC,CAAA,CAAA;AAAA,OAC1B;AAAA,KACF;AAAA,GACC,EAAA,CAAC,YAAc,EAAA,QAAA,EAAU,QAAQ,CAAC,CAAA,CAAA;AAErC,EAAA,MAAM,YAA0B,YAC5B,GAAA,YAAA,CAAa,IAAI,CAAM,CAAA,MAAA,EAAE,OAAO,CAAG,EAAA,KAAA,EAAO,CAAE,EAAA,CAAE,IAC9C,CAAC,EAAE,OAAO,YAAc,EAAA,KAAA,EAAO,WAAW,CAAA,CAAA;AAE9C,EAAA,uBAEI,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,kBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,WAAA;AAAA,IAAA;AAAA,MACC,MAAO,EAAA,QAAA;AAAA,MACP,QAAQ,EAAA,IAAA;AAAA,MACR,KAAO,EAAA,CAAA,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAW,MAAS,IAAA,CAAA,IAAK,CAAC,QAAA;AAAA,KAAA;AAAA,IAAA,CAEhC,6CAAc,MACb,oBAAA,KAAA,CAAA,aAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,MAAM,EAAA,IAAA;AAAA,QACN,KAAM,EAAA,wBAAA;AAAA,QACN,QAAU,EAAA,CAAA,QAAA,KACR,QAAS,CAAA,MAAA,CAAO,KAAM,CAAA,OAAA,CAAQ,QAAQ,CAAA,GAAI,QAAS,CAAA,CAAC,CAAI,GAAA,QAAQ,CAAC,CAAA;AAAA,QAEnE,QAAA,EAAU,aAAa,MAAW,KAAA,CAAA;AAAA,QAClC,QAAU,EAAA,QAAA;AAAA,QACV,KAAO,EAAA,SAAA;AAAA,OAAA;AAAA,wBAIP,KAAA,CAAA,aAAA,CAAA,KAAA,CAAA,QAAA,EAAA,IAAA,kBAAA,KAAA,CAAA,aAAA,CAAC,cAAW,OAAQ,EAAA,eAAA,EAAA,EAAgB,YAAU,CAC9C,kBAAA,KAAA,CAAA,aAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,EAAG,EAAA,eAAA;AAAA,QACH,UAAU,CAAK,CAAA,KAAA,QAAA,CAAS,OAAO,CAAE,CAAA,MAAA,CAAO,KAAK,CAAC,CAAA;AAAA,QAC9C,KAAO,EAAA,QAAA;AAAA,OAAA;AAAA,KAEX,CAAA;AAAA,oBAEF,KAAA,CAAA,aAAA,CAAC,sBAAe,4BAA0B,CAAA;AAAA,GAE9C,CAAA,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { makeFieldSchemaFromZod } from '../utils.esm.js';
|
|
3
|
+
|
|
4
|
+
const RepoUrlPickerFieldSchema = makeFieldSchemaFromZod(
|
|
5
|
+
z.string(),
|
|
6
|
+
z.object({
|
|
7
|
+
allowedHosts: z.array(z.string()).optional().describe("List of allowed SCM platform hosts"),
|
|
8
|
+
allowedOrganizations: z.array(z.string()).optional().describe("List of allowed organizations in the given SCM platform"),
|
|
9
|
+
allowedOwners: z.array(z.string()).optional().describe("List of allowed owners in the given SCM platform"),
|
|
10
|
+
allowedProjects: z.array(z.string()).optional().describe("List of allowed projects in the given SCM platform"),
|
|
11
|
+
allowedRepos: z.array(z.string()).optional().describe("List of allowed repos in the given SCM platform"),
|
|
12
|
+
requestUserCredentials: z.object({
|
|
13
|
+
secretsKey: z.string().describe(
|
|
14
|
+
"Key used within the template secrets context to store the credential"
|
|
15
|
+
),
|
|
16
|
+
additionalScopes: z.object({
|
|
17
|
+
gitea: z.array(z.string()).optional().describe("Additional Gitea scopes to request"),
|
|
18
|
+
gerrit: z.array(z.string()).optional().describe("Additional Gerrit scopes to request"),
|
|
19
|
+
github: z.array(z.string()).optional().describe("Additional GitHub scopes to request"),
|
|
20
|
+
gitlab: z.array(z.string()).optional().describe("Additional GitLab scopes to request"),
|
|
21
|
+
bitbucket: z.array(z.string()).optional().describe("Additional BitBucket scopes to request"),
|
|
22
|
+
azure: z.array(z.string()).optional().describe("Additional Azure scopes to request")
|
|
23
|
+
}).optional().describe("Additional permission scopes to request")
|
|
24
|
+
}).optional().describe(
|
|
25
|
+
"If defined will request user credentials to auth against the given SCM platform"
|
|
26
|
+
)
|
|
27
|
+
})
|
|
28
|
+
);
|
|
29
|
+
const RepoUrlPickerSchema = RepoUrlPickerFieldSchema.schema;
|
|
30
|
+
|
|
31
|
+
export { RepoUrlPickerFieldSchema, RepoUrlPickerSchema };
|
|
32
|
+
//# sourceMappingURL=schema.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.esm.js","sources":["../../../../src/components/fields/RepoUrlPicker/schema.ts"],"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 */\nimport { z } from 'zod';\nimport { makeFieldSchemaFromZod } from '../utils';\n\n/**\n * @public\n */\nexport const RepoUrlPickerFieldSchema = makeFieldSchemaFromZod(\n z.string(),\n z.object({\n allowedHosts: z\n .array(z.string())\n .optional()\n .describe('List of allowed SCM platform hosts'),\n allowedOrganizations: z\n .array(z.string())\n .optional()\n .describe('List of allowed organizations in the given SCM platform'),\n allowedOwners: z\n .array(z.string())\n .optional()\n .describe('List of allowed owners in the given SCM platform'),\n allowedProjects: z\n .array(z.string())\n .optional()\n .describe('List of allowed projects in the given SCM platform'),\n allowedRepos: z\n .array(z.string())\n .optional()\n .describe('List of allowed repos in the given SCM platform'),\n requestUserCredentials: z\n .object({\n secretsKey: z\n .string()\n .describe(\n 'Key used within the template secrets context to store the credential',\n ),\n additionalScopes: z\n .object({\n gitea: z\n .array(z.string())\n .optional()\n .describe('Additional Gitea scopes to request'),\n gerrit: z\n .array(z.string())\n .optional()\n .describe('Additional Gerrit scopes to request'),\n github: z\n .array(z.string())\n .optional()\n .describe('Additional GitHub scopes to request'),\n gitlab: z\n .array(z.string())\n .optional()\n .describe('Additional GitLab scopes to request'),\n bitbucket: z\n .array(z.string())\n .optional()\n .describe('Additional BitBucket scopes to request'),\n azure: z\n .array(z.string())\n .optional()\n .describe('Additional Azure scopes to request'),\n })\n .optional()\n .describe('Additional permission scopes to request'),\n })\n .optional()\n .describe(\n 'If defined will request user credentials to auth against the given SCM platform',\n ),\n }),\n);\n\n/**\n * The input props that can be specified under `ui:options` for the\n * `RepoUrlPicker` field extension.\n *\n * @public\n */\nexport type RepoUrlPickerUiOptions =\n typeof RepoUrlPickerFieldSchema.uiOptionsType;\n\nexport type RepoUrlPickerProps = typeof RepoUrlPickerFieldSchema.type;\n\n// NOTE: There is a bug with this failing validation in the custom field explorer due\n// to https://github.com/rjsf-team/react-jsonschema-form/issues/675 even if\n// requestUserCredentials is not defined\nexport const RepoUrlPickerSchema = RepoUrlPickerFieldSchema.schema;\n"],"names":[],"mappings":";;;AAqBO,MAAM,wBAA2B,GAAA,sBAAA;AAAA,EACtC,EAAE,MAAO,EAAA;AAAA,EACT,EAAE,MAAO,CAAA;AAAA,IACP,YAAA,EAAc,CACX,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,oCAAoC,CAAA;AAAA,IAChD,oBAAA,EAAsB,CACnB,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,yDAAyD,CAAA;AAAA,IACrE,aAAA,EAAe,CACZ,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,kDAAkD,CAAA;AAAA,IAC9D,eAAA,EAAiB,CACd,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,oDAAoD,CAAA;AAAA,IAChE,YAAA,EAAc,CACX,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,iDAAiD,CAAA;AAAA,IAC7D,sBAAA,EAAwB,EACrB,MAAO,CAAA;AAAA,MACN,UAAA,EAAY,CACT,CAAA,MAAA,EACA,CAAA,QAAA;AAAA,QACC,sEAAA;AAAA,OACF;AAAA,MACF,gBAAA,EAAkB,EACf,MAAO,CAAA;AAAA,QACN,KAAA,EAAO,CACJ,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,oCAAoC,CAAA;AAAA,QAChD,MAAA,EAAQ,CACL,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,qCAAqC,CAAA;AAAA,QACjD,MAAA,EAAQ,CACL,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,qCAAqC,CAAA;AAAA,QACjD,MAAA,EAAQ,CACL,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,qCAAqC,CAAA;AAAA,QACjD,SAAA,EAAW,CACR,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,wCAAwC,CAAA;AAAA,QACpD,KAAA,EAAO,CACJ,CAAA,KAAA,CAAM,CAAE,CAAA,MAAA,EAAQ,CAChB,CAAA,QAAA,EACA,CAAA,QAAA,CAAS,oCAAoC,CAAA;AAAA,OACjD,CAAA,CACA,QAAS,EAAA,CACT,SAAS,yCAAyC,CAAA;AAAA,KACtD,CACA,CAAA,QAAA,EACA,CAAA,QAAA;AAAA,MACC,iFAAA;AAAA,KACF;AAAA,GACH,CAAA;AACH,EAAA;AAgBO,MAAM,sBAAsB,wBAAyB,CAAA;;;;"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
function serializeRepoPickerUrl(data) {
|
|
2
|
+
if (!data.host) {
|
|
3
|
+
return void 0;
|
|
4
|
+
}
|
|
5
|
+
const params = new URLSearchParams();
|
|
6
|
+
if (data.owner) {
|
|
7
|
+
params.set("owner", data.owner);
|
|
8
|
+
}
|
|
9
|
+
if (data.repoName) {
|
|
10
|
+
params.set("repo", data.repoName);
|
|
11
|
+
}
|
|
12
|
+
if (data.organization) {
|
|
13
|
+
params.set("organization", data.organization);
|
|
14
|
+
}
|
|
15
|
+
if (data.workspace) {
|
|
16
|
+
params.set("workspace", data.workspace);
|
|
17
|
+
}
|
|
18
|
+
if (data.project) {
|
|
19
|
+
params.set("project", data.project);
|
|
20
|
+
}
|
|
21
|
+
return `${data.host}?${params.toString()}`;
|
|
22
|
+
}
|
|
23
|
+
function parseRepoPickerUrl(url) {
|
|
24
|
+
let host = "";
|
|
25
|
+
let owner = "";
|
|
26
|
+
let repoName = "";
|
|
27
|
+
let organization = "";
|
|
28
|
+
let workspace = "";
|
|
29
|
+
let project = "";
|
|
30
|
+
try {
|
|
31
|
+
if (url) {
|
|
32
|
+
const parsed = new URL(`https://${url}`);
|
|
33
|
+
host = parsed.host;
|
|
34
|
+
owner = parsed.searchParams.get("owner") || "";
|
|
35
|
+
repoName = parsed.searchParams.get("repo") || "";
|
|
36
|
+
organization = parsed.searchParams.get("organization") || "";
|
|
37
|
+
workspace = parsed.searchParams.get("workspace") || "";
|
|
38
|
+
project = parsed.searchParams.get("project") || "";
|
|
39
|
+
}
|
|
40
|
+
} catch {
|
|
41
|
+
}
|
|
42
|
+
return { host, owner, repoName, organization, workspace, project };
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export { parseRepoPickerUrl, serializeRepoPickerUrl };
|
|
46
|
+
//# sourceMappingURL=utils.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.esm.js","sources":["../../../../src/components/fields/RepoUrlPicker/utils.ts"],"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 { RepoUrlPickerState } from './types';\n\nexport function serializeRepoPickerUrl(data: RepoUrlPickerState) {\n if (!data.host) {\n return undefined;\n }\n\n const params = new URLSearchParams();\n if (data.owner) {\n params.set('owner', data.owner);\n }\n if (data.repoName) {\n params.set('repo', data.repoName);\n }\n if (data.organization) {\n params.set('organization', data.organization);\n }\n if (data.workspace) {\n params.set('workspace', data.workspace);\n }\n if (data.project) {\n params.set('project', data.project);\n }\n\n return `${data.host}?${params.toString()}`;\n}\n\nexport function parseRepoPickerUrl(\n url: string | undefined,\n): RepoUrlPickerState {\n let host = '';\n let owner = '';\n let repoName = '';\n let organization = '';\n let workspace = '';\n let project = '';\n\n try {\n if (url) {\n const parsed = new URL(`https://${url}`);\n host = parsed.host;\n owner = parsed.searchParams.get('owner') || '';\n repoName = parsed.searchParams.get('repo') || '';\n organization = parsed.searchParams.get('organization') || '';\n workspace = parsed.searchParams.get('workspace') || '';\n project = parsed.searchParams.get('project') || '';\n }\n } catch {\n /* ok */\n }\n return { host, owner, repoName, organization, workspace, project };\n}\n"],"names":[],"mappings":"AAkBO,SAAS,uBAAuB,IAA0B,EAAA;AAC/D,EAAI,IAAA,CAAC,KAAK,IAAM,EAAA;AACd,IAAO,OAAA,KAAA,CAAA,CAAA;AAAA,GACT;AAEA,EAAM,MAAA,MAAA,GAAS,IAAI,eAAgB,EAAA,CAAA;AACnC,EAAA,IAAI,KAAK,KAAO,EAAA;AACd,IAAO,MAAA,CAAA,GAAA,CAAI,OAAS,EAAA,IAAA,CAAK,KAAK,CAAA,CAAA;AAAA,GAChC;AACA,EAAA,IAAI,KAAK,QAAU,EAAA;AACjB,IAAO,MAAA,CAAA,GAAA,CAAI,MAAQ,EAAA,IAAA,CAAK,QAAQ,CAAA,CAAA;AAAA,GAClC;AACA,EAAA,IAAI,KAAK,YAAc,EAAA;AACrB,IAAO,MAAA,CAAA,GAAA,CAAI,cAAgB,EAAA,IAAA,CAAK,YAAY,CAAA,CAAA;AAAA,GAC9C;AACA,EAAA,IAAI,KAAK,SAAW,EAAA;AAClB,IAAO,MAAA,CAAA,GAAA,CAAI,WAAa,EAAA,IAAA,CAAK,SAAS,CAAA,CAAA;AAAA,GACxC;AACA,EAAA,IAAI,KAAK,OAAS,EAAA;AAChB,IAAO,MAAA,CAAA,GAAA,CAAI,SAAW,EAAA,IAAA,CAAK,OAAO,CAAA,CAAA;AAAA,GACpC;AAEA,EAAA,OAAO,GAAG,IAAK,CAAA,IAAI,CAAI,CAAA,EAAA,MAAA,CAAO,UAAU,CAAA,CAAA,CAAA;AAC1C,CAAA;AAEO,SAAS,mBACd,GACoB,EAAA;AACpB,EAAA,IAAI,IAAO,GAAA,EAAA,CAAA;AACX,EAAA,IAAI,KAAQ,GAAA,EAAA,CAAA;AACZ,EAAA,IAAI,QAAW,GAAA,EAAA,CAAA;AACf,EAAA,IAAI,YAAe,GAAA,EAAA,CAAA;AACnB,EAAA,IAAI,SAAY,GAAA,EAAA,CAAA;AAChB,EAAA,IAAI,OAAU,GAAA,EAAA,CAAA;AAEd,EAAI,IAAA;AACF,IAAA,IAAI,GAAK,EAAA;AACP,MAAA,MAAM,MAAS,GAAA,IAAI,GAAI,CAAA,CAAA,QAAA,EAAW,GAAG,CAAE,CAAA,CAAA,CAAA;AACvC,MAAA,IAAA,GAAO,MAAO,CAAA,IAAA,CAAA;AACd,MAAA,KAAA,GAAQ,MAAO,CAAA,YAAA,CAAa,GAAI,CAAA,OAAO,CAAK,IAAA,EAAA,CAAA;AAC5C,MAAA,QAAA,GAAW,MAAO,CAAA,YAAA,CAAa,GAAI,CAAA,MAAM,CAAK,IAAA,EAAA,CAAA;AAC9C,MAAA,YAAA,GAAe,MAAO,CAAA,YAAA,CAAa,GAAI,CAAA,cAAc,CAAK,IAAA,EAAA,CAAA;AAC1D,MAAA,SAAA,GAAY,MAAO,CAAA,YAAA,CAAa,GAAI,CAAA,WAAW,CAAK,IAAA,EAAA,CAAA;AACpD,MAAA,OAAA,GAAU,MAAO,CAAA,YAAA,CAAa,GAAI,CAAA,SAAS,CAAK,IAAA,EAAA,CAAA;AAAA,KAClD;AAAA,GACM,CAAA,MAAA;AAAA,GAER;AACA,EAAA,OAAO,EAAE,IAAM,EAAA,KAAA,EAAO,QAAU,EAAA,YAAA,EAAc,WAAW,OAAQ,EAAA,CAAA;AACnE;;;;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { scmIntegrationsApiRef } from '@backstage/integration-react';
|
|
2
|
+
|
|
3
|
+
const repoPickerValidation = (value, validation, context) => {
|
|
4
|
+
var _a, _b;
|
|
5
|
+
try {
|
|
6
|
+
const { host, searchParams } = new URL(`https://${value}`);
|
|
7
|
+
const integrationApi = context.apiHolder.get(scmIntegrationsApiRef);
|
|
8
|
+
if (!host) {
|
|
9
|
+
validation.addError(
|
|
10
|
+
"Incomplete repository location provided, host not provided"
|
|
11
|
+
);
|
|
12
|
+
} else {
|
|
13
|
+
if (((_a = integrationApi == null ? void 0 : integrationApi.byHost(host)) == null ? void 0 : _a.type) === "bitbucket") {
|
|
14
|
+
if (host === "bitbucket.org" && !searchParams.get("workspace")) {
|
|
15
|
+
validation.addError(
|
|
16
|
+
"Incomplete repository location provided, workspace not provided"
|
|
17
|
+
);
|
|
18
|
+
}
|
|
19
|
+
if (!searchParams.get("project")) {
|
|
20
|
+
validation.addError(
|
|
21
|
+
"Incomplete repository location provided, project not provided"
|
|
22
|
+
);
|
|
23
|
+
}
|
|
24
|
+
} else if (((_b = integrationApi == null ? void 0 : integrationApi.byHost(host)) == null ? void 0 : _b.type) !== "gerrit") {
|
|
25
|
+
if (!searchParams.get("owner")) {
|
|
26
|
+
validation.addError(
|
|
27
|
+
"Incomplete repository location provided, owner not provided"
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
if (!searchParams.get("repo")) {
|
|
32
|
+
validation.addError(
|
|
33
|
+
"Incomplete repository location provided, repo not provided"
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
} catch {
|
|
38
|
+
validation.addError("Unable to parse the Repository URL");
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
export { repoPickerValidation };
|
|
43
|
+
//# sourceMappingURL=validation.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.esm.js","sources":["../../../../src/components/fields/RepoUrlPicker/validation.ts"],"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 { FieldValidation } from '@rjsf/utils';\nimport { ApiHolder } from '@backstage/core-plugin-api';\nimport { scmIntegrationsApiRef } from '@backstage/integration-react';\n\n/**\n * The validation function for the `repoUrl` that is returned from the\n * field extension. Ensures that you have all the required fields filled for\n * the different providers that exist.\n *\n * @public\n */\nexport const repoPickerValidation = (\n value: string,\n validation: FieldValidation,\n context: { apiHolder: ApiHolder },\n) => {\n try {\n const { host, searchParams } = new URL(`https://${value}`);\n\n const integrationApi = context.apiHolder.get(scmIntegrationsApiRef);\n\n if (!host) {\n validation.addError(\n 'Incomplete repository location provided, host not provided',\n );\n } else {\n if (integrationApi?.byHost(host)?.type === 'bitbucket') {\n // workspace is only applicable for bitbucket cloud\n if (host === 'bitbucket.org' && !searchParams.get('workspace')) {\n validation.addError(\n 'Incomplete repository location provided, workspace not provided',\n );\n }\n\n if (!searchParams.get('project')) {\n validation.addError(\n 'Incomplete repository location provided, project not provided',\n );\n }\n }\n // For anything other than bitbucket and gerrit\n else if (integrationApi?.byHost(host)?.type !== 'gerrit') {\n if (!searchParams.get('owner')) {\n validation.addError(\n 'Incomplete repository location provided, owner not provided',\n );\n }\n }\n\n // Do this for all hosts\n if (!searchParams.get('repo')) {\n validation.addError(\n 'Incomplete repository location provided, repo not provided',\n );\n }\n }\n } catch {\n validation.addError('Unable to parse the Repository URL');\n }\n};\n"],"names":[],"mappings":";;AA2BO,MAAM,oBAAuB,GAAA,CAClC,KACA,EAAA,UAAA,EACA,OACG,KAAA;AA/BL,EAAA,IAAA,EAAA,EAAA,EAAA,CAAA;AAgCE,EAAI,IAAA;AACF,IAAM,MAAA,EAAE,MAAM,YAAa,EAAA,GAAI,IAAI,GAAI,CAAA,CAAA,QAAA,EAAW,KAAK,CAAE,CAAA,CAAA,CAAA;AAEzD,IAAA,MAAM,cAAiB,GAAA,OAAA,CAAQ,SAAU,CAAA,GAAA,CAAI,qBAAqB,CAAA,CAAA;AAElE,IAAA,IAAI,CAAC,IAAM,EAAA;AACT,MAAW,UAAA,CAAA,QAAA;AAAA,QACT,4DAAA;AAAA,OACF,CAAA;AAAA,KACK,MAAA;AACL,MAAA,IAAA,CAAA,CAAI,EAAgB,GAAA,cAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,cAAA,CAAA,MAAA,CAAO,IAAvB,CAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAA8B,UAAS,WAAa,EAAA;AAEtD,QAAA,IAAI,SAAS,eAAmB,IAAA,CAAC,YAAa,CAAA,GAAA,CAAI,WAAW,CAAG,EAAA;AAC9D,UAAW,UAAA,CAAA,QAAA;AAAA,YACT,iEAAA;AAAA,WACF,CAAA;AAAA,SACF;AAEA,QAAA,IAAI,CAAC,YAAA,CAAa,GAAI,CAAA,SAAS,CAAG,EAAA;AAChC,UAAW,UAAA,CAAA,QAAA;AAAA,YACT,+DAAA;AAAA,WACF,CAAA;AAAA,SACF;AAAA,mBAGO,EAAgB,GAAA,cAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,cAAA,CAAA,MAAA,CAAO,IAAvB,CAAA,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAA8B,UAAS,QAAU,EAAA;AACxD,QAAA,IAAI,CAAC,YAAA,CAAa,GAAI,CAAA,OAAO,CAAG,EAAA;AAC9B,UAAW,UAAA,CAAA,QAAA;AAAA,YACT,6DAAA;AAAA,WACF,CAAA;AAAA,SACF;AAAA,OACF;AAGA,MAAA,IAAI,CAAC,YAAA,CAAa,GAAI,CAAA,MAAM,CAAG,EAAA;AAC7B,QAAW,UAAA,CAAA,QAAA;AAAA,UACT,4DAAA;AAAA,SACF,CAAA;AAAA,OACF;AAAA,KACF;AAAA,GACM,CAAA,MAAA;AACN,IAAA,UAAA,CAAW,SAAS,oCAAoC,CAAA,CAAA;AAAA,GAC1D;AACF;;;;"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useTemplateSecrets } from '@backstage/plugin-scaffolder-react';
|
|
3
|
+
import { ScaffolderField } from '@backstage/plugin-scaffolder-react/alpha';
|
|
4
|
+
import Input from '@material-ui/core/Input';
|
|
5
|
+
import InputLabel from '@material-ui/core/InputLabel';
|
|
6
|
+
|
|
7
|
+
const SecretInput = (props) => {
|
|
8
|
+
var _a;
|
|
9
|
+
const { setSecrets, secrets } = useTemplateSecrets();
|
|
10
|
+
const {
|
|
11
|
+
name,
|
|
12
|
+
onChange,
|
|
13
|
+
schema: { title, description },
|
|
14
|
+
rawErrors,
|
|
15
|
+
disabled,
|
|
16
|
+
errors,
|
|
17
|
+
required
|
|
18
|
+
} = props;
|
|
19
|
+
return /* @__PURE__ */ React.createElement(
|
|
20
|
+
ScaffolderField,
|
|
21
|
+
{
|
|
22
|
+
rawErrors,
|
|
23
|
+
rawDescription: description,
|
|
24
|
+
disabled,
|
|
25
|
+
errors,
|
|
26
|
+
required
|
|
27
|
+
},
|
|
28
|
+
/* @__PURE__ */ React.createElement(InputLabel, { htmlFor: title }, title),
|
|
29
|
+
/* @__PURE__ */ React.createElement(
|
|
30
|
+
Input,
|
|
31
|
+
{
|
|
32
|
+
id: title,
|
|
33
|
+
"aria-describedby": title,
|
|
34
|
+
onChange: (e) => {
|
|
35
|
+
var _a2, _b;
|
|
36
|
+
onChange(Array((_a2 = e.target) == null ? void 0 : _a2.value.length).fill("*").join(""));
|
|
37
|
+
setSecrets({ [name]: (_b = e.target) == null ? void 0 : _b.value });
|
|
38
|
+
},
|
|
39
|
+
value: (_a = secrets[name]) != null ? _a : "",
|
|
40
|
+
type: "password",
|
|
41
|
+
autoComplete: "off"
|
|
42
|
+
}
|
|
43
|
+
)
|
|
44
|
+
);
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { SecretInput };
|
|
48
|
+
//# sourceMappingURL=SecretInput.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SecretInput.esm.js","sources":["../../../../src/components/fields/SecretInput/SecretInput.tsx"],"sourcesContent":["/*\n * Copyright 2023 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 React from 'react';\nimport { useTemplateSecrets } from '@backstage/plugin-scaffolder-react';\nimport { ScaffolderRJSFFieldProps } from '@backstage/plugin-scaffolder-react';\nimport { ScaffolderField } from '@backstage/plugin-scaffolder-react/alpha';\nimport Input from '@material-ui/core/Input';\nimport InputLabel from '@material-ui/core/InputLabel';\n\nexport const SecretInput = (props: ScaffolderRJSFFieldProps) => {\n const { setSecrets, secrets } = useTemplateSecrets();\n const {\n name,\n onChange,\n schema: { title, description },\n rawErrors,\n disabled,\n errors,\n required,\n } = props;\n\n return (\n <ScaffolderField\n rawErrors={rawErrors}\n rawDescription={description}\n disabled={disabled}\n errors={errors}\n required={required}\n >\n <InputLabel htmlFor={title}>{title}</InputLabel>\n <Input\n id={title}\n aria-describedby={title}\n onChange={e => {\n onChange(Array(e.target?.value.length).fill('*').join(''));\n setSecrets({ [name]: e.target?.value });\n }}\n value={secrets[name] ?? ''}\n type=\"password\"\n autoComplete=\"off\"\n />\n </ScaffolderField>\n );\n};\n"],"names":["_a"],"mappings":";;;;;;AAsBa,MAAA,WAAA,GAAc,CAAC,KAAoC,KAAA;AAtBhE,EAAA,IAAA,EAAA,CAAA;AAuBE,EAAA,MAAM,EAAE,UAAA,EAAY,OAAQ,EAAA,GAAI,kBAAmB,EAAA,CAAA;AACnD,EAAM,MAAA;AAAA,IACJ,IAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA,EAAQ,EAAE,KAAA,EAAO,WAAY,EAAA;AAAA,IAC7B,SAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA;AAAA,IACA,QAAA;AAAA,GACE,GAAA,KAAA,CAAA;AAEJ,EACE,uBAAA,KAAA,CAAA,aAAA;AAAA,IAAC,eAAA;AAAA,IAAA;AAAA,MACC,SAAA;AAAA,MACA,cAAgB,EAAA,WAAA;AAAA,MAChB,QAAA;AAAA,MACA,MAAA;AAAA,MACA,QAAA;AAAA,KAAA;AAAA,oBAEC,KAAA,CAAA,aAAA,CAAA,UAAA,EAAA,EAAW,OAAS,EAAA,KAAA,EAAA,EAAQ,KAAM,CAAA;AAAA,oBACnC,KAAA,CAAA,aAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,EAAI,EAAA,KAAA;AAAA,QACJ,kBAAkB,EAAA,KAAA;AAAA,QAClB,UAAU,CAAK,CAAA,KAAA;AA9CvB,UAAA,IAAAA,GAAA,EAAA,EAAA,CAAA;AA+CU,UAAA,QAAA,CAAS,KAAMA,CAAAA,CAAAA,GAAAA,GAAA,CAAE,CAAA,MAAA,KAAF,gBAAAA,GAAU,CAAA,KAAA,CAAM,MAAM,CAAA,CAAE,IAAK,CAAA,GAAG,CAAE,CAAA,IAAA,CAAK,EAAE,CAAC,CAAA,CAAA;AACzD,UAAW,UAAA,CAAA,EAAE,CAAC,IAAI,GAAA,CAAG,OAAE,MAAF,KAAA,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAU,OAAO,CAAA,CAAA;AAAA,SACxC;AAAA,QACA,KAAO,EAAA,CAAA,EAAA,GAAA,OAAA,CAAQ,IAAI,CAAA,KAAZ,IAAiB,GAAA,EAAA,GAAA,EAAA;AAAA,QACxB,IAAK,EAAA,UAAA;AAAA,QACL,YAAa,EAAA,KAAA;AAAA,OAAA;AAAA,KACf;AAAA,GACF,CAAA;AAEJ;;;;"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import zodToJsonSchema from 'zod-to-json-schema';
|
|
2
|
+
|
|
3
|
+
function makeFieldSchemaFromZod(returnSchema, uiOptionsSchema) {
|
|
4
|
+
return {
|
|
5
|
+
schema: {
|
|
6
|
+
returnValue: zodToJsonSchema(returnSchema),
|
|
7
|
+
uiOptions: uiOptionsSchema ? zodToJsonSchema(uiOptionsSchema) : void 0
|
|
8
|
+
},
|
|
9
|
+
type: null,
|
|
10
|
+
uiOptionsType: null
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export { makeFieldSchemaFromZod };
|
|
15
|
+
//# sourceMappingURL=utils.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.esm.js","sources":["../../../src/components/fields/utils.ts"],"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 */\nimport { JSONSchema7 } from 'json-schema';\nimport { z } from 'zod';\nimport zodToJsonSchema from 'zod-to-json-schema';\nimport {\n CustomFieldExtensionSchema,\n FieldExtensionComponentProps,\n} from '@backstage/plugin-scaffolder-react';\n\n/**\n * @public\n * FieldSchema encapsulates a JSONSchema7 along with the\n * matching FieldExtensionComponentProps type for a field extension.\n */\nexport interface FieldSchema<TReturn, TUiOptions> {\n readonly schema: CustomFieldExtensionSchema;\n readonly type: FieldExtensionComponentProps<TReturn, TUiOptions>;\n readonly uiOptionsType: TUiOptions;\n}\n\n/**\n * @public\n * Utility function to convert zod return and UI options schemas to a\n * CustomFieldExtensionSchema with FieldExtensionComponentProps type inference\n */\nexport function makeFieldSchemaFromZod<\n TReturnSchema extends z.ZodType,\n TUiOptionsSchema extends z.ZodType = z.ZodType<any, any, {}>,\n>(\n returnSchema: TReturnSchema,\n uiOptionsSchema?: TUiOptionsSchema,\n): FieldSchema<\n TReturnSchema extends z.ZodType<any, any, infer IReturn> ? IReturn : never,\n TUiOptionsSchema extends z.ZodType<any, any, infer IUiOptions>\n ? IUiOptions\n : never\n> {\n return {\n schema: {\n returnValue: zodToJsonSchema(returnSchema) as JSONSchema7,\n uiOptions: uiOptionsSchema\n ? (zodToJsonSchema(uiOptionsSchema) as JSONSchema7)\n : undefined,\n },\n type: null as any,\n uiOptionsType: null as any,\n };\n}\n"],"names":[],"mappings":";;AAuCgB,SAAA,sBAAA,CAId,cACA,eAMA,EAAA;AACA,EAAO,OAAA;AAAA,IACL,MAAQ,EAAA;AAAA,MACN,WAAA,EAAa,gBAAgB,YAAY,CAAA;AAAA,MACzC,SAAW,EAAA,eAAA,GACN,eAAgB,CAAA,eAAe,CAChC,GAAA,KAAA,CAAA;AAAA,KACN;AAAA,IACA,IAAM,EAAA,IAAA;AAAA,IACN,aAAe,EAAA,IAAA;AAAA,GACjB,CAAA;AACF;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { createScaffolderFieldExtension as createScaffolderFieldExtension$1, ScaffolderFieldExtensions as ScaffolderFieldExtensions$1, useTemplateSecrets as useTemplateSecrets$1, scaffolderApiRef as scaffolderApiRef$1, createScaffolderLayout as createScaffolderLayout$1, ScaffolderLayouts as ScaffolderLayouts$1 } from '@backstage/plugin-scaffolder-react';
|
|
2
|
+
import { rootRouteRef as rootRouteRef$1 } from './routes.esm.js';
|
|
3
|
+
|
|
4
|
+
const rootRouteRef = rootRouteRef$1;
|
|
5
|
+
const createScaffolderFieldExtension = createScaffolderFieldExtension$1;
|
|
6
|
+
const ScaffolderFieldExtensions = ScaffolderFieldExtensions$1;
|
|
7
|
+
const useTemplateSecrets = useTemplateSecrets$1;
|
|
8
|
+
const scaffolderApiRef = scaffolderApiRef$1;
|
|
9
|
+
const createScaffolderLayout = createScaffolderLayout$1;
|
|
10
|
+
const ScaffolderLayouts = ScaffolderLayouts$1;
|
|
11
|
+
|
|
12
|
+
export { ScaffolderFieldExtensions, ScaffolderLayouts, createScaffolderFieldExtension, createScaffolderLayout, rootRouteRef, scaffolderApiRef, useTemplateSecrets };
|
|
13
|
+
//# sourceMappingURL=deprecated.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deprecated.esm.js","sources":["../src/deprecated.ts"],"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\n/*\n * This file is here to re-export exports from the `@backage/plugin-scaffolder-react` package to keep backwards compatibility.\n * But mark them as deprecated so that any import that is using these exports will be notified that they should use the `-react` package instead.\n * It's a little awkward to get the deprecated notice to show up in the API report, which is why it's all been extracted out to this file.\n */\n\nimport {\n createScaffolderFieldExtension as createScaffolderFieldExtensionTemp,\n ScaffolderFieldExtensions as ScaffolderFieldExtensionsTemp,\n useTemplateSecrets as useTemplateSecretsTemp,\n scaffolderApiRef as scaffolderApiRefTemp,\n createScaffolderLayout as createScaffolderLayoutTemp,\n ScaffolderLayouts as ScaffolderLayoutsTemp,\n type LayoutOptions as LayoutOptionsTemp,\n type LayoutTemplate as LayoutTemplateTemp,\n type ScaffolderApi as ScaffolderApiTemp,\n type ScaffolderUseTemplateSecrets as ScaffolderUseTemplateSecretsTemp,\n type TemplateParameterSchema as TemplateParameterSchemaTemp,\n type CustomFieldExtensionSchema as CustomFieldExtensionSchemaTemp,\n type CustomFieldValidator as CustomFieldValidatorTemp,\n type FieldExtensionOptions as FieldExtensionOptionsTemp,\n type FieldExtensionComponentProps as FieldExtensionComponentPropsTemp,\n type FieldExtensionComponent as FieldExtensionComponentTemp,\n type ListActionsResponse as ListActionsResponseTemp,\n type LogEvent as LogEventTemp,\n type ScaffolderDryRunOptions as ScaffolderDryRunOptionsTemp,\n type ScaffolderDryRunResponse as ScaffolderDryRunResponseTemp,\n type ScaffolderGetIntegrationsListOptions as ScaffolderGetIntegrationsListOptionsTemp,\n type ScaffolderGetIntegrationsListResponse as ScaffolderGetIntegrationsListResponseTemp,\n type ScaffolderOutputLink as ScaffolderOutputLinkTemp,\n type ScaffolderScaffoldOptions as ScaffolderScaffoldOptionsTemp,\n type ScaffolderScaffoldResponse as ScaffolderScaffoldResponseTemp,\n type ScaffolderStreamLogsOptions as ScaffolderStreamLogsOptionsTemp,\n type ScaffolderTask as ScaffolderTaskTemp,\n type ScaffolderTaskOutput as ScaffolderTaskOutputTemp,\n type ScaffolderTaskStatus as ScaffolderTaskStatusTemp,\n} from '@backstage/plugin-scaffolder-react';\n\nimport { rootRouteRef as rootRouteRefTemp } from './routes';\n\n/**\n * @public\n * @deprecated use import from `{@link @backstage/plugin-scaffolder#scaffolderPlugin}.routes.root` instead.\n */\nexport const rootRouteRef = rootRouteRefTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#createScaffolderFieldExtension} instead as this has now been moved.\n */\nexport const createScaffolderFieldExtension =\n createScaffolderFieldExtensionTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderFieldExtensions} instead as this has now been moved.\n */\nexport const ScaffolderFieldExtensions = ScaffolderFieldExtensionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#useTemplateSecrets} instead as this has now been moved.\n */\nexport const useTemplateSecrets = useTemplateSecretsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#scaffolderApiRef} instead as this has now been moved.\n */\nexport const scaffolderApiRef = scaffolderApiRefTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderApi} instead as this has now been moved.\n */\nexport type ScaffolderApi = ScaffolderApiTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderUseTemplateSecrets} instead as this has now been moved.\n */\nexport type ScaffolderUseTemplateSecrets = ScaffolderUseTemplateSecretsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#TemplateParameterSchema} instead as this has now been moved.\n */\nexport type TemplateParameterSchema = TemplateParameterSchemaTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#CustomFieldExtensionSchema} instead as this has now been moved.\n */\nexport type CustomFieldExtensionSchema = CustomFieldExtensionSchemaTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#CustomFieldValidator} instead as this has now been moved.\n */\nexport type CustomFieldValidator<TReturnFieldData> =\n CustomFieldValidatorTemp<TReturnFieldData>;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#FieldExtensionOptions} instead as this has now been moved.\n */\nexport type FieldExtensionOptions = FieldExtensionOptionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#FieldExtensionComponentProps} instead as this has now been moved.\n */\nexport type FieldExtensionComponentProps<\n TFieldReturnValue,\n TUiOptions extends {} = {},\n> = FieldExtensionComponentPropsTemp<TFieldReturnValue, TUiOptions>;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#FieldExtensionComponent} instead as this has now been moved.\n */\nexport type FieldExtensionComponent<_TReturnValue, _TInputProps> =\n FieldExtensionComponentTemp<_TReturnValue, _TInputProps>;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ListActionsResponse} instead as this has now been moved.\n */\nexport type ListActionsResponse = ListActionsResponseTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#LogEvent} instead as this has now been moved.\n */\nexport type LogEvent = LogEventTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderDryRunOptions} instead as this has now been moved.\n */\nexport type ScaffolderDryRunOptions = ScaffolderDryRunOptionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderDryRunResponse} instead as this has now been moved.\n */\nexport type ScaffolderDryRunResponse = ScaffolderDryRunResponseTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderGetIntegrationsListOptions} instead as this has now been moved.\n */\nexport type ScaffolderGetIntegrationsListOptions =\n ScaffolderGetIntegrationsListOptionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderGetIntegrationsListResponse} instead as this has now been moved.\n */\nexport type ScaffolderGetIntegrationsListResponse =\n ScaffolderGetIntegrationsListResponseTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderOutputlink} instead as this has now been moved.\n */\nexport type ScaffolderOutputlink = ScaffolderOutputLinkTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderScaffoldOptions} instead as this has now been moved.\n */\nexport type ScaffolderScaffoldOptions = ScaffolderScaffoldOptionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderScaffoldResponse} instead as this has now been moved.\n */\nexport type ScaffolderScaffoldResponse = ScaffolderScaffoldResponseTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderStreamLogsOptions} instead as this has now been moved.\n */\nexport type ScaffolderStreamLogsOptions = ScaffolderStreamLogsOptionsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderTask} instead as this has now been moved.\n */\nexport type ScaffolderTask = ScaffolderTaskTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderTaskOutput} instead as this has now been moved.\n */\nexport type ScaffolderTaskOutput = ScaffolderTaskOutputTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderTaskStatus} instead as this has now been moved.\n */\nexport type ScaffolderTaskStatus = ScaffolderTaskStatusTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#createScaffolderLayout} instead as this has now been moved.\n */\nexport const createScaffolderLayout = createScaffolderLayoutTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#ScaffolderLayouts} instead as this has now been moved.\n */\nexport const ScaffolderLayouts = ScaffolderLayoutsTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#LayoutTemplate} instead as this has now been moved.\n */\nexport type LayoutTemplate = LayoutTemplateTemp;\n/**\n * @public\n * @deprecated use import from {@link @backstage/plugin-scaffolder-react#LayoutOptions} instead as this has now been moved.\n */\nexport type LayoutOptions = LayoutOptionsTemp;\n\n/**\n * TaskPageProps for constructing a TaskPage\n * @public\n * @deprecated - this is a useless type that is no longer used.\n */\nexport type TaskPageProps = {\n // Optional loading text shown before a task begins executing.\n loadingText?: string;\n};\n"],"names":["rootRouteRefTemp","createScaffolderFieldExtensionTemp","ScaffolderFieldExtensionsTemp","useTemplateSecretsTemp","scaffolderApiRefTemp","createScaffolderLayoutTemp","ScaffolderLayoutsTemp"],"mappings":";;;AA4DO,MAAM,YAAe,GAAAA,eAAA;AAKrB,MAAM,8BACX,GAAAC,iCAAA;AAKK,MAAM,yBAA4B,GAAAC,4BAAA;AAKlC,MAAM,kBAAqB,GAAAC,qBAAA;AAK3B,MAAM,gBAAmB,GAAAC,mBAAA;AAqHzB,MAAM,sBAAyB,GAAAC,yBAAA;AAK/B,MAAM,iBAAoB,GAAAC;;;;"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { EntityPicker } from '../components/fields/EntityPicker/EntityPicker.esm.js';
|
|
2
|
+
import { EntityNamePicker } from '../components/fields/EntityNamePicker/EntityNamePicker.esm.js';
|
|
3
|
+
import { entityNamePickerValidation } from '../components/fields/EntityNamePicker/validation.esm.js';
|
|
4
|
+
import { EntityTagsPicker } from '../components/fields/EntityTagsPicker/EntityTagsPicker.esm.js';
|
|
5
|
+
import { OwnerPicker } from '../components/fields/OwnerPicker/OwnerPicker.esm.js';
|
|
6
|
+
import { RepoUrlPicker } from '../components/fields/RepoUrlPicker/RepoUrlPicker.esm.js';
|
|
7
|
+
import { repoPickerValidation } from '../components/fields/RepoUrlPicker/validation.esm.js';
|
|
8
|
+
import { OwnedEntityPicker } from '../components/fields/OwnedEntityPicker/OwnedEntityPicker.esm.js';
|
|
9
|
+
import { MyGroupsPicker } from '../components/fields/MyGroupsPicker/MyGroupsPicker.esm.js';
|
|
10
|
+
import { SecretInput } from '../components/fields/SecretInput/SecretInput.esm.js';
|
|
11
|
+
import { MultiEntityPicker, validateMultiEntityPickerValidation } from '../components/fields/MultiEntityPicker/MultiEntityPicker.esm.js';
|
|
12
|
+
import { EntityPickerSchema } from '../components/fields/EntityPicker/schema.esm.js';
|
|
13
|
+
import { EntityNamePickerSchema } from '../components/fields/EntityNamePicker/schema.esm.js';
|
|
14
|
+
import { EntityTagsPickerSchema } from '../components/fields/EntityTagsPicker/schema.esm.js';
|
|
15
|
+
import { RepoUrlPickerSchema } from '../components/fields/RepoUrlPicker/schema.esm.js';
|
|
16
|
+
import { OwnerPickerSchema } from '../components/fields/OwnerPicker/schema.esm.js';
|
|
17
|
+
import { OwnedEntityPickerSchema } from '../components/fields/OwnedEntityPicker/schema.esm.js';
|
|
18
|
+
import { MyGroupsPickerSchema } from '../components/fields/MyGroupsPicker/schema.esm.js';
|
|
19
|
+
import { MultiEntityPickerSchema } from '../components/fields/MultiEntityPicker/schema.esm.js';
|
|
20
|
+
|
|
21
|
+
const DEFAULT_SCAFFOLDER_FIELD_EXTENSIONS = [
|
|
22
|
+
{
|
|
23
|
+
component: EntityPicker,
|
|
24
|
+
name: "EntityPicker",
|
|
25
|
+
schema: EntityPickerSchema
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
component: EntityNamePicker,
|
|
29
|
+
name: "EntityNamePicker",
|
|
30
|
+
validation: entityNamePickerValidation,
|
|
31
|
+
schema: EntityNamePickerSchema
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
component: EntityTagsPicker,
|
|
35
|
+
name: "EntityTagsPicker",
|
|
36
|
+
schema: EntityTagsPickerSchema
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
component: RepoUrlPicker,
|
|
40
|
+
name: "RepoUrlPicker",
|
|
41
|
+
validation: repoPickerValidation,
|
|
42
|
+
schema: RepoUrlPickerSchema
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
component: OwnerPicker,
|
|
46
|
+
name: "OwnerPicker",
|
|
47
|
+
schema: OwnerPickerSchema
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
component: OwnedEntityPicker,
|
|
51
|
+
name: "OwnedEntityPicker",
|
|
52
|
+
schema: OwnedEntityPickerSchema
|
|
53
|
+
},
|
|
54
|
+
{
|
|
55
|
+
component: MyGroupsPicker,
|
|
56
|
+
name: "MyGroupsPicker",
|
|
57
|
+
schema: MyGroupsPickerSchema
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
component: SecretInput,
|
|
61
|
+
name: "Secret"
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
component: MultiEntityPicker,
|
|
65
|
+
name: "MultiEntityPicker",
|
|
66
|
+
schema: MultiEntityPickerSchema,
|
|
67
|
+
validation: validateMultiEntityPickerValidation
|
|
68
|
+
}
|
|
69
|
+
];
|
|
70
|
+
|
|
71
|
+
export { DEFAULT_SCAFFOLDER_FIELD_EXTENSIONS };
|
|
72
|
+
//# sourceMappingURL=default.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"default.esm.js","sources":["../../src/extensions/default.ts"],"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 */\nimport {\n EntityPicker,\n EntityPickerSchema,\n} from '../components/fields/EntityPicker/EntityPicker';\nimport {\n EntityNamePicker,\n EntityNamePickerSchema,\n} from '../components/fields/EntityNamePicker/EntityNamePicker';\nimport { entityNamePickerValidation } from '../components/fields/EntityNamePicker/validation';\nimport {\n EntityTagsPicker,\n EntityTagsPickerSchema,\n} from '../components/fields/EntityTagsPicker/EntityTagsPicker';\nimport {\n OwnerPicker,\n OwnerPickerSchema,\n} from '../components/fields/OwnerPicker/OwnerPicker';\nimport {\n RepoUrlPicker,\n RepoUrlPickerSchema,\n} from '../components/fields/RepoUrlPicker/RepoUrlPicker';\nimport { repoPickerValidation } from '../components/fields/RepoUrlPicker/validation';\nimport {\n OwnedEntityPicker,\n OwnedEntityPickerSchema,\n} from '../components/fields/OwnedEntityPicker/OwnedEntityPicker';\nimport {\n MyGroupsPicker,\n MyGroupsPickerSchema,\n} from '../components/fields/MyGroupsPicker/MyGroupsPicker';\n\nimport { SecretInput } from '../components/fields/SecretInput';\nimport {\n MultiEntityPicker,\n MultiEntityPickerSchema,\n validateMultiEntityPickerValidation,\n} from '../components/fields/MultiEntityPicker/MultiEntityPicker';\n\nexport const DEFAULT_SCAFFOLDER_FIELD_EXTENSIONS = [\n {\n component: EntityPicker,\n name: 'EntityPicker',\n schema: EntityPickerSchema,\n },\n {\n component: EntityNamePicker,\n name: 'EntityNamePicker',\n validation: entityNamePickerValidation,\n schema: EntityNamePickerSchema,\n },\n {\n component: EntityTagsPicker,\n name: 'EntityTagsPicker',\n schema: EntityTagsPickerSchema,\n },\n {\n component: RepoUrlPicker,\n name: 'RepoUrlPicker',\n validation: repoPickerValidation,\n schema: RepoUrlPickerSchema,\n },\n {\n component: OwnerPicker,\n name: 'OwnerPicker',\n schema: OwnerPickerSchema,\n },\n {\n component: OwnedEntityPicker,\n name: 'OwnedEntityPicker',\n schema: OwnedEntityPickerSchema,\n },\n {\n component: MyGroupsPicker,\n name: 'MyGroupsPicker',\n schema: MyGroupsPickerSchema,\n },\n {\n component: SecretInput,\n name: 'Secret',\n },\n {\n component: MultiEntityPicker,\n name: 'MultiEntityPicker',\n schema: MultiEntityPickerSchema,\n validation: validateMultiEntityPickerValidation,\n },\n];\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAqDO,MAAM,mCAAsC,GAAA;AAAA,EACjD;AAAA,IACE,SAAW,EAAA,YAAA;AAAA,IACX,IAAM,EAAA,cAAA;AAAA,IACN,MAAQ,EAAA,kBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,gBAAA;AAAA,IACX,IAAM,EAAA,kBAAA;AAAA,IACN,UAAY,EAAA,0BAAA;AAAA,IACZ,MAAQ,EAAA,sBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,gBAAA;AAAA,IACX,IAAM,EAAA,kBAAA;AAAA,IACN,MAAQ,EAAA,sBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,aAAA;AAAA,IACX,IAAM,EAAA,eAAA;AAAA,IACN,UAAY,EAAA,oBAAA;AAAA,IACZ,MAAQ,EAAA,mBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,WAAA;AAAA,IACX,IAAM,EAAA,aAAA;AAAA,IACN,MAAQ,EAAA,iBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,iBAAA;AAAA,IACX,IAAM,EAAA,mBAAA;AAAA,IACN,MAAQ,EAAA,uBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,cAAA;AAAA,IACX,IAAM,EAAA,gBAAA;AAAA,IACN,MAAQ,EAAA,oBAAA;AAAA,GACV;AAAA,EACA;AAAA,IACE,SAAW,EAAA,WAAA;AAAA,IACX,IAAM,EAAA,QAAA;AAAA,GACR;AAAA,EACA;AAAA,IACE,SAAW,EAAA,iBAAA;AAAA,IACX,IAAM,EAAA,mBAAA;AAAA,IACN,MAAQ,EAAA,uBAAA;AAAA,IACR,UAAY,EAAA,mCAAA;AAAA,GACd;AACF;;;;"}
|