Allow stages to be swapped in flow

This commit is contained in:
Mel O'Hagan 2022-10-12 18:42:35 +01:00
parent 29f995256e
commit ac3d389163
1 changed files with 49 additions and 9 deletions

View File

@ -37,11 +37,16 @@
query.fields[schema.type] = detail.value query.fields[schema.type] = detail.value
} }
function updateEditors(deleteIndex) { function updateEditorsOnDelete(deleteIndex) {
for (let i = deleteIndex; i < query.fields.steps?.length - 1; i++) { for (let i = deleteIndex; i < query.fields.steps?.length - 1; i++) {
flowEditors[i].update(query.fields.steps[i + 1].value.value) flowEditors[i].update(query.fields.steps[i + 1].value.value)
} }
} }
function updateEditorsOnSwap(actionIndex, targetIndex) {
const target = query.fields.steps[targetIndex].value.value
flowEditors[targetIndex].update(query.fields.steps[actionIndex].value.value)
flowEditors[actionIndex].update(target)
}
function setEditorTemplate(fromKey, toKey, index) { function setEditorTemplate(fromKey, toKey, index) {
const currentValue = query.fields.steps[index].value.value const currentValue = query.fields.steps[index].value.value
@ -119,15 +124,45 @@
<div class="blockSection"> <div class="blockSection">
<div class="block-options"> <div class="block-options">
Stage {index + 1} Stage {index + 1}
<div class="block-actions">
<div style="margin-right: 24px;">
{#if index > 0}
<ActionButton
quiet
on:click={() => {
updateEditorsOnSwap(index, index - 1)
const target = query.fields.steps[index - 1].key
query.fields.steps[index - 1].key =
query.fields.steps[index].key
query.fields.steps[index].key = target
}}
icon="ChevronUp"
/>
{/if}
{#if index < query.fields.steps.length - 1}
<ActionButton
quiet
on:click={() => {
updateEditorsOnSwap(index, index + 1)
const target = query.fields.steps[index + 1].key
query.fields.steps[index + 1].key =
query.fields.steps[index].key
query.fields.steps[index].key = target
}}
icon="ChevronDown"
/>
{/if}
</div>
<ActionButton <ActionButton
on:click={() => { on:click={() => {
updateEditors(index) updateEditorsOnDelete(index)
query.fields.steps.splice(index, 1) query.fields.steps.splice(index, 1)
query.fields.steps = [...query.fields.steps] query.fields.steps = [...query.fields.steps]
}} }}
icon="DeleteOutline" icon="DeleteOutline"
/> />
</div> </div>
</div>
<Layout noPadding gap="S"> <Layout noPadding gap="S">
<div class="fields"> <div class="fields">
<div class="block-field"> <div class="block-field">
@ -209,6 +244,11 @@
align-items: center; align-items: center;
padding-bottom: 24px; padding-bottom: 24px;
} }
.block-actions {
justify-content: space-between;
display: flex;
align-items: right;
}
.fields { .fields {
display: flex; display: flex;