windmill-components 1.13.25 → 1.22.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/common.js +1 -5
- package/components/AppConnect.svelte +281 -0
- package/components/AppConnect.svelte.d.ts +22 -0
- package/components/ArgInfo.svelte +11 -16
- package/components/ArgInput.svelte +73 -70
- package/components/ArgInput.svelte.d.ts +6 -1
- package/components/AutosizedTextarea.svelte +6 -8
- package/components/Badge.svelte +4 -10
- package/components/Button.svelte +22 -18
- package/components/ButtonAndDropdown.svelte +6 -12
- package/components/CenteredModal.svelte +30 -0
- package/components/CenteredModal.svelte.d.ts +19 -0
- package/components/ChevronButton.svelte +4 -9
- package/components/DisplayResult.svelte +58 -57
- package/components/Dropdown.svelte +8 -13
- package/components/Editor.svelte +108 -149
- package/components/Editor.svelte.d.ts +3 -1
- package/components/FieldHeader.svelte +7 -12
- package/components/FlowBuilder.svelte +72 -121
- package/components/FlowBuilder.svelte.d.ts +0 -2
- package/components/FlowEditor.svelte +185 -73
- package/components/FlowEditor.svelte.d.ts +4 -4
- package/components/FlowJobResult.svelte +23 -0
- package/components/FlowJobResult.svelte.d.ts +17 -0
- package/components/FlowPreview.svelte +36 -51
- package/components/FlowPreview.svelte.d.ts +7 -1
- package/components/FlowStatusViewer.svelte +66 -40
- package/components/FlowStatusViewer.svelte.d.ts +1 -1
- package/components/FlowViewer.svelte +100 -0
- package/components/FlowViewer.svelte.d.ts +24 -0
- package/components/GroupModal.svelte +13 -20
- package/components/IconedResourceType.svelte +15 -18
- package/components/InviteGlobalUser.svelte +8 -15
- package/components/InviteUser.svelte +9 -16
- package/components/ItemPicker.svelte +11 -14
- package/components/JobStatus.svelte +6 -11
- package/components/Modal.svelte +14 -17
- package/components/ModuleStep.svelte +125 -64
- package/components/ModuleStep.svelte.d.ts +4 -8
- package/components/ObjectResourceInput.svelte +15 -20
- package/components/ObjectTypeNarrowing.svelte +7 -12
- package/components/PageHeader.svelte +4 -9
- package/components/Password.svelte +6 -8
- package/components/Path.svelte +78 -38
- package/components/Path.svelte.d.ts +2 -0
- package/components/RadioButton.svelte +7 -8
- package/components/RadioButtonV2.svelte +33 -0
- package/components/RadioButtonV2.svelte.d.ts +20 -0
- package/components/Required.svelte +2 -4
- package/components/ResourceEditor.svelte +44 -48
- package/components/ResourcePicker.svelte +6 -7
- package/components/ResourcePicker.svelte.d.ts +2 -2
- package/components/ResourceTypePicker.svelte +8 -13
- package/components/RunForm.svelte +15 -20
- package/components/SchemaEditor.svelte +31 -61
- package/components/SchemaForm.svelte +126 -134
- package/components/SchemaForm.svelte.d.ts +6 -4
- package/components/SchemaModal.svelte +25 -40
- package/components/SchemaModal.svelte.d.ts +1 -1
- package/components/SchemaViewer.svelte +6 -12
- package/components/ScriptBuilder.svelte +76 -101
- package/components/ScriptEditor.svelte +55 -60
- package/components/ScriptPicker.svelte +28 -34
- package/components/ScriptPicker.svelte.d.ts +1 -0
- package/components/ScriptSchema.svelte +13 -17
- package/components/ShareModal.svelte +23 -29
- package/components/SharedBadge.svelte +11 -16
- package/components/StringTypeNarrowing.svelte +8 -11
- package/components/Switch.svelte.d.ts +2 -2
- package/components/TableCustom.svelte +5 -8
- package/components/TableSimple.svelte +9 -8
- package/components/Tabs.svelte +6 -8
- package/components/Toggle.svelte +34 -0
- package/components/Toggle.svelte.d.ts +28 -0
- package/components/Tooltip.svelte +56 -89
- package/components/Tooltip.svelte.d.ts +1 -5
- package/components/VariableEditor.svelte +30 -29
- package/components/flows/CopyFirstStepSchema.svelte +10 -0
- package/components/flows/CopyFirstStepSchema.svelte.d.ts +14 -0
- package/components/flows/DynamicInputHelpBox.svelte +72 -0
- package/components/flows/DynamicInputHelpBox.svelte.d.ts +14 -0
- package/components/flows/FlowInputs.svelte +27 -0
- package/components/flows/FlowInputs.svelte.d.ts +19 -0
- package/components/flows/FlowModuleHeader.svelte +91 -0
- package/components/flows/FlowModuleHeader.svelte.d.ts +22 -0
- package/components/flows/flowStore.d.ts +17 -0
- package/components/flows/flowStore.js +161 -0
- package/components/flows/pickers/FlowScriptPicker.svelte +11 -0
- package/components/flows/pickers/FlowScriptPicker.svelte.d.ts +22 -0
- package/components/flows/pickers/PickHubScript.svelte +30 -0
- package/components/flows/pickers/PickHubScript.svelte.d.ts +18 -0
- package/components/flows/pickers/PickScript.svelte +38 -0
- package/components/flows/pickers/PickScript.svelte.d.ts +18 -0
- package/components/flows/utils.d.ts +21 -0
- package/components/flows/utils.js +164 -0
- package/components/icons/DbIcon.svelte +2 -5
- package/components/icons/Mail.svelte +2 -5
- package/components/icons/Mysql.svelte +2 -5
- package/components/icons/PostgresIcon.svelte +2 -5
- package/components/icons/Slack.svelte +2 -5
- package/components/propertyPicker/ObjectViewer.svelte +113 -0
- package/components/propertyPicker/ObjectViewer.svelte.d.ts +21 -0
- package/components/propertyPicker/OverlayPropertyPicker.svelte +69 -0
- package/components/propertyPicker/OverlayPropertyPicker.svelte.d.ts +21 -0
- package/components/propertyPicker/PropPicker.svelte +24 -0
- package/components/propertyPicker/PropPicker.svelte.d.ts +18 -0
- package/components/propertyPicker/WarningMessage.svelte +43 -0
- package/components/propertyPicker/WarningMessage.svelte.d.ts +16 -0
- package/components/propertyPicker/utils.d.ts +2 -0
- package/components/propertyPicker/utils.js +40 -0
- package/gen/core/ApiError.d.ts +3 -1
- package/gen/core/ApiError.js +4 -6
- package/gen/core/ApiRequestOptions.js +1 -2
- package/gen/core/ApiResult.js +1 -2
- package/gen/core/CancelablePromise.js +2 -7
- package/gen/core/OpenAPI.js +2 -5
- package/gen/core/request.js +8 -13
- package/gen/index.d.ts +3 -0
- package/gen/index.js +28 -58
- package/gen/models/AuditLog.js +2 -5
- package/gen/models/CompletedJob.d.ts +3 -1
- package/gen/models/CompletedJob.js +3 -5
- package/gen/models/ContextualVariable.js +1 -2
- package/gen/models/CreateResource.d.ts +1 -0
- package/gen/models/CreateResource.js +1 -2
- package/gen/models/CreateVariable.d.ts +2 -0
- package/gen/models/CreateVariable.js +1 -2
- package/gen/models/CreateWorkspace.js +1 -2
- package/gen/models/EditResource.js +1 -2
- package/gen/models/EditResourceType.js +1 -2
- package/gen/models/EditSchedule.js +1 -2
- package/gen/models/EditVariable.js +1 -2
- package/gen/models/EditWorkspaceUser.js +1 -2
- package/gen/models/Flow.js +1 -2
- package/gen/models/FlowModule.d.ts +2 -0
- package/gen/models/FlowModule.js +1 -2
- package/gen/models/FlowModuleValue.d.ts +14 -2
- package/gen/models/FlowModuleValue.js +9 -5
- package/gen/models/FlowPreview.js +1 -2
- package/gen/models/FlowStatus.js +1 -2
- package/gen/models/FlowStatusModule.d.ts +6 -0
- package/gen/models/FlowStatusModule.js +2 -5
- package/gen/models/FlowValue.js +1 -2
- package/gen/models/GlobalUserInfo.js +2 -5
- package/gen/models/Group.js +1 -2
- package/gen/models/InputTransform.js +2 -5
- package/gen/models/Job.js +2 -5
- package/gen/models/ListableVariable.d.ts +2 -0
- package/gen/models/ListableVariable.js +1 -2
- package/gen/models/Login.js +1 -2
- package/gen/models/MainArgSignature.js +1 -2
- package/gen/models/NewSchedule.js +1 -2
- package/gen/models/NewToken.js +1 -2
- package/gen/models/NewUser.js +1 -2
- package/gen/models/Preview.js +2 -5
- package/gen/models/QueuedJob.d.ts +2 -1
- package/gen/models/QueuedJob.js +3 -5
- package/gen/models/Resource.d.ts +1 -0
- package/gen/models/Resource.js +1 -2
- package/gen/models/ResourceType.js +1 -2
- package/gen/models/Schedule.js +1 -2
- package/gen/models/Script.d.ts +1 -0
- package/gen/models/Script.js +2 -5
- package/gen/models/ScriptArgs.js +1 -2
- package/gen/models/SlackToken.d.ts +8 -0
- package/gen/models/SlackToken.js +4 -0
- package/gen/models/TokenResponse.d.ts +6 -0
- package/gen/models/TokenResponse.js +4 -0
- package/gen/models/TruncatedToken.js +1 -2
- package/gen/models/User.js +1 -2
- package/gen/models/UserWorkspaceList.js +1 -2
- package/gen/models/WorkerPing.js +1 -2
- package/gen/models/Workspace.js +1 -2
- package/gen/models/WorkspaceInvite.js +1 -2
- package/gen/services/AdminService.d.ts +6 -2
- package/gen/services/AdminService.js +6 -10
- package/gen/services/AuditService.d.ts +24 -8
- package/gen/services/AuditService.js +5 -9
- package/gen/services/FlowService.d.ts +37 -10
- package/gen/services/FlowService.js +23 -12
- package/gen/services/GranularAclService.d.ts +6 -2
- package/gen/services/GranularAclService.js +6 -10
- package/gen/services/GroupService.d.ts +18 -6
- package/gen/services/GroupService.js +11 -15
- package/gen/services/JobService.d.ts +167 -46
- package/gen/services/JobService.js +42 -22
- package/gen/services/OauthService.d.ts +104 -0
- package/gen/services/OauthService.js +133 -0
- package/gen/services/ResourceService.d.ts +39 -7
- package/gen/services/ResourceService.js +44 -18
- package/gen/services/ScheduleService.d.ts +36 -6
- package/gen/services/ScheduleService.js +39 -13
- package/gen/services/ScriptService.d.ts +66 -19
- package/gen/services/ScriptService.js +32 -20
- package/gen/services/SettingsService.js +5 -9
- package/gen/services/UserService.d.ts +49 -11
- package/gen/services/UserService.js +42 -29
- package/gen/services/VariableService.d.ts +19 -4
- package/gen/services/VariableService.js +24 -13
- package/gen/services/WorkerService.d.ts +6 -2
- package/gen/services/WorkerService.js +4 -8
- package/gen/services/WorkspaceService.d.ts +29 -24
- package/gen/services/WorkspaceService.js +23 -42
- package/infer.js +5 -9
- package/logout.js +20 -18
- package/package.json +51 -24
- package/script_helpers.d.ts +4 -0
- package/script_helpers.js +70 -0
- package/scripts.d.ts +2 -1
- package/scripts.js +11 -15
- package/stores.d.ts +6 -0
- package/stores.js +30 -22
- package/user.js +10 -15
- package/utils.d.ts +15 -1
- package/utils.js +191 -52
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
const
|
|
7
|
-
const dispatch = (0, svelte_1.createEventDispatcher)();
|
|
1
|
+
<script>export let label = '';
|
|
2
|
+
export let options;
|
|
3
|
+
export let value;
|
|
4
|
+
export let small = false;
|
|
5
|
+
import { createEventDispatcher } from 'svelte';
|
|
6
|
+
const dispatch = createEventDispatcher();
|
|
8
7
|
</script>
|
|
9
8
|
|
|
10
9
|
<fieldset>
|
|
@@ -83,7 +82,7 @@ label:focus {
|
|
|
83
82
|
|
|
84
83
|
border-width: 1px;
|
|
85
84
|
|
|
86
|
-
background-color: rgb(59 130 246 / 0.
|
|
85
|
+
background-color: rgb(59 130 246 / 0.7);
|
|
87
86
|
|
|
88
87
|
padding-left: 0.75rem;
|
|
89
88
|
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
<script>export let options;
|
|
2
|
+
export let value;
|
|
3
|
+
import { createEventDispatcher } from 'svelte';
|
|
4
|
+
import Tooltip from './Tooltip.svelte';
|
|
5
|
+
$: dispatch('change', value);
|
|
6
|
+
const dispatch = createEventDispatcher();
|
|
7
|
+
</script>
|
|
8
|
+
|
|
9
|
+
<div class="flex flex-row gap-x-4 m-4 reveal flex-wrap ">
|
|
10
|
+
{#each options as [label, val]}
|
|
11
|
+
<button
|
|
12
|
+
type="button"
|
|
13
|
+
on:click={() => {
|
|
14
|
+
value = val
|
|
15
|
+
}}
|
|
16
|
+
class="flex flex-col default-secondary-button-v2 mb-2 grow"
|
|
17
|
+
class:selected={value == val}
|
|
18
|
+
>
|
|
19
|
+
<h2 class="mb-2 whitespace-nowrap">{label.title} <Tooltip>{label.desc}</Tooltip></h2>
|
|
20
|
+
</button>
|
|
21
|
+
{/each}
|
|
22
|
+
</div>
|
|
23
|
+
|
|
24
|
+
<style>
|
|
25
|
+
.selected {
|
|
26
|
+
background-color: rgb(59 130 246 / 0.7);
|
|
27
|
+
--tw-text-opacity: 1;
|
|
28
|
+
color: rgb(255 255 255 / var(--tw-text-opacity))
|
|
29
|
+
}
|
|
30
|
+
.selected > h2 {
|
|
31
|
+
--tw-text-opacity: 1;
|
|
32
|
+
color: rgb(255 255 255 / var(--tw-text-opacity))
|
|
33
|
+
}</style>
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { SvelteComponentTyped } from "svelte";
|
|
2
|
+
declare const __propDef: {
|
|
3
|
+
props: {
|
|
4
|
+
options: [{
|
|
5
|
+
title: string;
|
|
6
|
+
desc?: string;
|
|
7
|
+
}, string][];
|
|
8
|
+
value: any;
|
|
9
|
+
};
|
|
10
|
+
events: {
|
|
11
|
+
[evt: string]: CustomEvent<any>;
|
|
12
|
+
};
|
|
13
|
+
slots: {};
|
|
14
|
+
};
|
|
15
|
+
export declare type RadioButtonV2Props = typeof __propDef.props;
|
|
16
|
+
export declare type RadioButtonV2Events = typeof __propDef.events;
|
|
17
|
+
export declare type RadioButtonV2Slots = typeof __propDef.slots;
|
|
18
|
+
export default class RadioButtonV2 extends SvelteComponentTyped<RadioButtonV2Props, RadioButtonV2Events, RadioButtonV2Slots> {
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
@@ -1,23 +1,18 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
const AutosizedTextarea_svelte_1 = __importDefault(require("./AutosizedTextarea.svelte"));
|
|
14
|
-
const ItemPicker_svelte_1 = __importDefault(require("./ItemPicker.svelte"));
|
|
15
|
-
const VariableEditor_svelte_1 = __importDefault(require("./VariableEditor.svelte"));
|
|
16
|
-
const Required_svelte_1 = __importDefault(require("./Required.svelte"));
|
|
17
|
-
const stores_1 = require("$lib/stores");
|
|
18
|
-
const ResourceTypePicker_svelte_1 = __importDefault(require("./ResourceTypePicker.svelte"));
|
|
1
|
+
<script>import { ResourceService, VariableService } from '../gen';
|
|
2
|
+
import { allTrue, emptySchema, sendUserToast } from '../utils';
|
|
3
|
+
import { createEventDispatcher } from 'svelte';
|
|
4
|
+
import Modal from './Modal.svelte';
|
|
5
|
+
import Path from './Path.svelte';
|
|
6
|
+
import ArgInput from './ArgInput.svelte';
|
|
7
|
+
import AutosizedTextarea from './AutosizedTextarea.svelte';
|
|
8
|
+
import ItemPicker from './ItemPicker.svelte';
|
|
9
|
+
import VariableEditor from './VariableEditor.svelte';
|
|
10
|
+
import Required from './Required.svelte';
|
|
11
|
+
import { workspaceStore } from '../stores';
|
|
12
|
+
import ResourceTypePicker from './ResourceTypePicker.svelte';
|
|
19
13
|
let path = '';
|
|
20
14
|
let initialPath = '';
|
|
15
|
+
let pathError = '';
|
|
21
16
|
let step = 1;
|
|
22
17
|
let resourceToEdit;
|
|
23
18
|
let description = '';
|
|
@@ -32,49 +27,47 @@ let pickForField;
|
|
|
32
27
|
let itemPicker;
|
|
33
28
|
let variableEditor;
|
|
34
29
|
let modal;
|
|
35
|
-
const dispatch =
|
|
36
|
-
async function initNew() {
|
|
30
|
+
const dispatch = createEventDispatcher();
|
|
31
|
+
export async function initNew() {
|
|
37
32
|
selectedResourceType = undefined;
|
|
38
33
|
step = 1;
|
|
39
34
|
args = {};
|
|
40
35
|
path = '';
|
|
41
36
|
description = '';
|
|
42
37
|
initialPath = '';
|
|
43
|
-
resourceSchema =
|
|
38
|
+
resourceSchema = emptySchema();
|
|
44
39
|
resourceToEdit = undefined;
|
|
45
40
|
modal.openModal();
|
|
46
41
|
}
|
|
47
|
-
|
|
48
|
-
async function initEdit(p) {
|
|
42
|
+
export async function initEdit(p) {
|
|
49
43
|
initialPath = p;
|
|
50
44
|
path = p;
|
|
51
45
|
step = 2;
|
|
52
|
-
resourceToEdit = await
|
|
46
|
+
resourceToEdit = await ResourceService.getResource({ workspace: $workspaceStore, path: p });
|
|
53
47
|
description = resourceToEdit.description ?? '';
|
|
54
48
|
selectedResourceType = resourceToEdit.resource_type;
|
|
55
49
|
await loadResourceType();
|
|
56
50
|
args = resourceToEdit.value;
|
|
57
51
|
modal.openModal();
|
|
58
52
|
}
|
|
59
|
-
exports.initEdit = initEdit;
|
|
60
53
|
async function createResource() {
|
|
61
|
-
await
|
|
54
|
+
await ResourceService.createResource({
|
|
62
55
|
workspace: $workspaceStore,
|
|
63
56
|
requestBody: { path, value: args, description, resource_type: resourceType.name }
|
|
64
57
|
});
|
|
65
|
-
|
|
58
|
+
sendUserToast(`Successfully created resource at ${path}`);
|
|
66
59
|
dispatch('refresh');
|
|
67
60
|
modal.closeModal();
|
|
68
61
|
}
|
|
69
62
|
async function editResource() {
|
|
70
63
|
try {
|
|
71
64
|
if (resourceToEdit) {
|
|
72
|
-
await
|
|
65
|
+
await ResourceService.updateResource({
|
|
73
66
|
workspace: $workspaceStore,
|
|
74
67
|
path: resourceToEdit.path,
|
|
75
68
|
requestBody: { path, value: args, description }
|
|
76
69
|
});
|
|
77
|
-
|
|
70
|
+
sendUserToast(`Successfully updated resource at ${path}`);
|
|
78
71
|
dispatch('refresh');
|
|
79
72
|
modal.closeModal();
|
|
80
73
|
}
|
|
@@ -83,12 +76,12 @@ async function editResource() {
|
|
|
83
76
|
}
|
|
84
77
|
}
|
|
85
78
|
catch (err) {
|
|
86
|
-
|
|
79
|
+
sendUserToast(`${err}`, true);
|
|
87
80
|
}
|
|
88
81
|
}
|
|
89
82
|
async function loadResourceType() {
|
|
90
83
|
if (selectedResourceType) {
|
|
91
|
-
resourceType = await
|
|
84
|
+
resourceType = await ResourceService.getResourceType({
|
|
92
85
|
workspace: $workspaceStore,
|
|
93
86
|
path: selectedResourceType
|
|
94
87
|
});
|
|
@@ -97,11 +90,11 @@ async function loadResourceType() {
|
|
|
97
90
|
}
|
|
98
91
|
}
|
|
99
92
|
else {
|
|
100
|
-
|
|
93
|
+
sendUserToast(`ResourceType cannot be undefined.`, true);
|
|
101
94
|
}
|
|
102
95
|
}
|
|
103
96
|
let inputCheck = {};
|
|
104
|
-
$: isValid =
|
|
97
|
+
$: isValid = allTrue(inputCheck) ?? false;
|
|
105
98
|
</script>
|
|
106
99
|
|
|
107
100
|
<Modal
|
|
@@ -118,8 +111,14 @@ $: isValid = (0, utils_1.allTrue)(inputCheck) ?? false;
|
|
|
118
111
|
<div>
|
|
119
112
|
<span class="text-purple-500 text-2xs grow">{error ?? ''}</span>
|
|
120
113
|
<span class="mb-1 font-semibold text-gray-700">Path</span>
|
|
121
|
-
<Path
|
|
122
|
-
|
|
114
|
+
<Path
|
|
115
|
+
bind:error={pathError}
|
|
116
|
+
bind:path
|
|
117
|
+
{initialPath}
|
|
118
|
+
namePlaceholder="my/resource"
|
|
119
|
+
kind="resource"
|
|
120
|
+
>
|
|
121
|
+
<div slot="ownerToolkit">
|
|
123
122
|
Resource permissions depend on their path. Select the group <span class="font-mono"
|
|
124
123
|
>all</span
|
|
125
124
|
>
|
|
@@ -187,19 +186,16 @@ $: isValid = (0, utils_1.allTrue)(inputCheck) ?? false;
|
|
|
187
186
|
</div>
|
|
188
187
|
<span slot="submission">
|
|
189
188
|
{#if step === 1}
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
{:else}
|
|
201
|
-
<button class="default-button-disabled px-4 py-2 font-semibold">Next</button>
|
|
202
|
-
{/if}
|
|
189
|
+
<button
|
|
190
|
+
class="default-button px-4 py-2 font-semibold"
|
|
191
|
+
on:click={async () => {
|
|
192
|
+
await loadResourceType()
|
|
193
|
+
step = 2
|
|
194
|
+
}}
|
|
195
|
+
disabled={selectedResourceType == undefined || pathError != ''}
|
|
196
|
+
>
|
|
197
|
+
Next
|
|
198
|
+
</button>
|
|
203
199
|
{:else}
|
|
204
200
|
<button
|
|
205
201
|
class="default-button-secondary px-4 py-2 font-semibold"
|
|
@@ -1,15 +1,14 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
exports.resourceType = exports.value = void 0;
|
|
4
|
-
const gen_1 = require("$lib/gen");
|
|
5
|
-
const stores_1 = require("$lib/stores");
|
|
1
|
+
<script>import { ResourceService } from '../gen';
|
|
2
|
+
import { workspaceStore } from '../stores';
|
|
6
3
|
let resources = [];
|
|
4
|
+
export let value = undefined;
|
|
5
|
+
export let resourceType = undefined;
|
|
7
6
|
async function loadResources(resourceType) {
|
|
8
|
-
resources = await
|
|
7
|
+
resources = await ResourceService.listResource({ workspace: $workspaceStore, resourceType });
|
|
9
8
|
}
|
|
10
9
|
$: {
|
|
11
10
|
if ($workspaceStore) {
|
|
12
|
-
loadResources(
|
|
11
|
+
loadResources(resourceType);
|
|
13
12
|
}
|
|
14
13
|
}
|
|
15
14
|
</script>
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { SvelteComponentTyped } from "svelte";
|
|
2
2
|
declare const __propDef: {
|
|
3
3
|
props: {
|
|
4
|
-
value
|
|
5
|
-
resourceType
|
|
4
|
+
value?: string | undefined;
|
|
5
|
+
resourceType?: string | undefined;
|
|
6
6
|
};
|
|
7
7
|
events: {
|
|
8
8
|
[evt: string]: CustomEvent<any>;
|
|
@@ -1,19 +1,14 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.notPickable = exports.value = void 0;
|
|
7
|
-
const svelte_1 = require("svelte");
|
|
8
|
-
const gen_1 = require("$lib/gen");
|
|
9
|
-
const stores_1 = require("$lib/stores");
|
|
10
|
-
const IconedResourceType_svelte_1 = __importDefault(require("./IconedResourceType.svelte"));
|
|
1
|
+
<script>import { createEventDispatcher } from 'svelte';
|
|
2
|
+
import { ResourceService } from '../gen';
|
|
3
|
+
import { workspaceStore } from '../stores';
|
|
4
|
+
import IconedResourceType from './IconedResourceType.svelte';
|
|
11
5
|
let resources = [];
|
|
12
|
-
|
|
6
|
+
export let value;
|
|
7
|
+
export let notPickable = false;
|
|
13
8
|
async function loadResources() {
|
|
14
|
-
resources = await
|
|
9
|
+
resources = await ResourceService.listResourceTypeNames({ workspace: $workspaceStore });
|
|
15
10
|
}
|
|
16
|
-
const dispatch =
|
|
11
|
+
const dispatch = createEventDispatcher();
|
|
17
12
|
$: {
|
|
18
13
|
if ($workspaceStore) {
|
|
19
14
|
loadResources();
|
|
@@ -1,21 +1,17 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
exports.buttonText = 'Run';
|
|
16
|
-
exports.schedulable = true;
|
|
17
|
-
exports.detailed = true;
|
|
18
|
-
exports.args = {};
|
|
1
|
+
<script>import { page } from '$app/stores';
|
|
2
|
+
import { getToday } from '../utils';
|
|
3
|
+
import { slide } from 'svelte/transition';
|
|
4
|
+
import { faChevronDown, faChevronUp } from '@fortawesome/free-solid-svg-icons';
|
|
5
|
+
import Icon from 'svelte-awesome';
|
|
6
|
+
import Tooltip from './Tooltip.svelte';
|
|
7
|
+
import SvelteMarkdown from 'svelte-markdown';
|
|
8
|
+
import SchemaForm from './SchemaForm.svelte';
|
|
9
|
+
export let runnable;
|
|
10
|
+
export let runAction;
|
|
11
|
+
export let buttonText = 'Run';
|
|
12
|
+
export let schedulable = true;
|
|
13
|
+
export let detailed = true;
|
|
14
|
+
export let args = {};
|
|
19
15
|
let isValid = true;
|
|
20
16
|
let queryArgs = $page.url.searchParams.get('args');
|
|
21
17
|
if (queryArgs) {
|
|
@@ -25,8 +21,7 @@ if (queryArgs) {
|
|
|
25
21
|
parsed[k] = undefined;
|
|
26
22
|
}
|
|
27
23
|
});
|
|
28
|
-
|
|
29
|
-
exports.args = parsed;
|
|
24
|
+
args = parsed;
|
|
30
25
|
}
|
|
31
26
|
// Run later
|
|
32
27
|
let viewOptions = false;
|
|
@@ -1,130 +1,100 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.getSchema = exports.schema = void 0;
|
|
30
|
-
const SchemaModal_svelte_1 = __importStar(require("./SchemaModal.svelte"));
|
|
31
|
-
const Editor_svelte_1 = __importDefault(require("./Editor.svelte"));
|
|
32
|
-
const utils_1 = require("$lib/utils");
|
|
33
|
-
const Tooltip_svelte_1 = __importDefault(require("./Tooltip.svelte"));
|
|
34
|
-
const TableCustom_svelte_1 = __importDefault(require("./TableCustom.svelte"));
|
|
35
|
-
exports.schema = (0, utils_1.emptySchema)();
|
|
1
|
+
<script>import SchemaModal, { DEFAULT_PROPERTY, modalToSchema, schemaToModal } from './SchemaModal.svelte';
|
|
2
|
+
import Editor from './Editor.svelte';
|
|
3
|
+
import { emptySchema, sendUserToast } from '../utils';
|
|
4
|
+
import Tooltip from './Tooltip.svelte';
|
|
5
|
+
import TableCustom from './TableCustom.svelte';
|
|
6
|
+
export let schema = emptySchema();
|
|
36
7
|
let schemaModal;
|
|
37
8
|
let schemaString = '';
|
|
38
9
|
// Internal state: bound to args builder modal
|
|
39
|
-
let modalProperty = Object.assign({},
|
|
10
|
+
let modalProperty = Object.assign({}, DEFAULT_PROPERTY);
|
|
40
11
|
let argError = '';
|
|
41
12
|
let editing = false;
|
|
42
13
|
let oldArgName; // when editing argument and changing name
|
|
43
14
|
let viewJsonSchema = false;
|
|
44
15
|
// Binding is not enough because monaco Editor does not support two-way binding
|
|
45
|
-
function getSchema() {
|
|
16
|
+
export function getSchema() {
|
|
46
17
|
try {
|
|
47
18
|
if (viewJsonSchema) {
|
|
48
|
-
|
|
49
|
-
return
|
|
19
|
+
schema = JSON.parse(schemaString);
|
|
20
|
+
return schema;
|
|
50
21
|
}
|
|
51
22
|
else {
|
|
52
|
-
schemaString = JSON.stringify(
|
|
53
|
-
return
|
|
23
|
+
schemaString = JSON.stringify(schema, null, '\t');
|
|
24
|
+
return schema;
|
|
54
25
|
}
|
|
55
26
|
}
|
|
56
27
|
catch (err) {
|
|
57
28
|
throw Error(`Error: input is not a valid schema: ${err}`);
|
|
58
29
|
}
|
|
59
30
|
}
|
|
60
|
-
exports.getSchema = getSchema;
|
|
61
31
|
function handleAddOrEditArgument() {
|
|
62
32
|
// If editing the arg's name, oldName containing the old argument name must be provided
|
|
63
33
|
argError = '';
|
|
64
34
|
if (modalProperty.name.length === 0) {
|
|
65
35
|
argError = 'Arguments need to have a name';
|
|
66
36
|
}
|
|
67
|
-
else if (Object.keys(
|
|
37
|
+
else if (Object.keys(schema.properties).includes(modalProperty.name) && !editing) {
|
|
68
38
|
argError = 'There is already an argument with this name';
|
|
69
39
|
}
|
|
70
40
|
else {
|
|
71
|
-
|
|
41
|
+
schema.properties[modalProperty.name] = modalToSchema(modalProperty);
|
|
72
42
|
if (modalProperty.required) {
|
|
73
|
-
|
|
43
|
+
schema.required = [...schema.required, modalProperty.name];
|
|
74
44
|
}
|
|
75
|
-
else if (
|
|
76
|
-
const index =
|
|
45
|
+
else if (schema.required.includes(modalProperty.name)) {
|
|
46
|
+
const index = schema.required.indexOf(modalProperty.name, 0);
|
|
77
47
|
if (index > -1) {
|
|
78
|
-
|
|
48
|
+
schema.required.splice(index, 1);
|
|
79
49
|
}
|
|
80
50
|
}
|
|
81
51
|
if (editing && oldArgName && oldArgName !== modalProperty.name) {
|
|
82
52
|
handleDeleteArgument(oldArgName);
|
|
83
53
|
}
|
|
84
|
-
modalProperty = Object.assign({},
|
|
54
|
+
modalProperty = Object.assign({}, DEFAULT_PROPERTY);
|
|
85
55
|
editing = false;
|
|
86
56
|
oldArgName = undefined;
|
|
87
57
|
schemaModal.closeModal();
|
|
88
58
|
}
|
|
89
|
-
|
|
90
|
-
schemaString = JSON.stringify(
|
|
59
|
+
schema = schema;
|
|
60
|
+
schemaString = JSON.stringify(schema, null, '\t');
|
|
91
61
|
}
|
|
92
62
|
function startEditArgument(argName) {
|
|
93
63
|
argError = '';
|
|
94
|
-
if (Object.keys(
|
|
64
|
+
if (Object.keys(schema.properties).includes(argName)) {
|
|
95
65
|
schemaModal.openModal();
|
|
96
66
|
editing = true;
|
|
97
|
-
modalProperty =
|
|
67
|
+
modalProperty = schemaToModal(schema.properties[argName], argName, schema.required.includes(argName));
|
|
98
68
|
oldArgName = argName;
|
|
99
69
|
}
|
|
100
70
|
else {
|
|
101
|
-
|
|
71
|
+
sendUserToast(`This argument does not exist and can't be edited`, true);
|
|
102
72
|
}
|
|
103
73
|
}
|
|
104
74
|
function handleDeleteArgument(argName) {
|
|
105
75
|
try {
|
|
106
|
-
if (Object.keys(
|
|
107
|
-
delete
|
|
108
|
-
|
|
109
|
-
schemaString = JSON.stringify(
|
|
76
|
+
if (Object.keys(schema.properties).includes(argName)) {
|
|
77
|
+
delete schema.properties[argName];
|
|
78
|
+
schema = schema;
|
|
79
|
+
schemaString = JSON.stringify(schema, null, '\t');
|
|
110
80
|
}
|
|
111
81
|
else {
|
|
112
82
|
throw Error('Argument not found!');
|
|
113
83
|
}
|
|
114
84
|
}
|
|
115
85
|
catch (err) {
|
|
116
|
-
|
|
86
|
+
sendUserToast(`Could not delete argument: ${err}`, true);
|
|
117
87
|
}
|
|
118
88
|
}
|
|
119
89
|
function switchTab() {
|
|
120
90
|
if (viewJsonSchema) {
|
|
121
91
|
if (schemaString === '') {
|
|
122
|
-
schemaString = JSON.stringify(
|
|
92
|
+
schemaString = JSON.stringify(emptySchema(), null, 4);
|
|
123
93
|
}
|
|
124
94
|
viewJsonSchema = false;
|
|
125
95
|
}
|
|
126
96
|
else {
|
|
127
|
-
schemaString = JSON.stringify(
|
|
97
|
+
schemaString = JSON.stringify(schema, null, '\t');
|
|
128
98
|
viewJsonSchema = true;
|
|
129
99
|
}
|
|
130
100
|
}
|