mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-17 21:26:00 +00:00
152 lines
3.9 KiB
Svelte
152 lines
3.9 KiB
Svelte
<script lang="ts">
|
|
import _ from 'lodash';
|
|
import TextField from '../forms/TextField.svelte';
|
|
import FormFieldTemplateLarge from '../forms/FormFieldTemplateLarge.svelte';
|
|
import FontIcon from '../icons/FontIcon.svelte';
|
|
|
|
export let dbKeyFields;
|
|
export let item;
|
|
export let onChangeItem = null;
|
|
export let keyColumn = null;
|
|
|
|
let records = [{ value: '' }];
|
|
let lastItem = null;
|
|
|
|
$: if (item !== lastItem) {
|
|
if (item?.records && Array.isArray(item.records)) {
|
|
records = [...item.records];
|
|
} else if (!item) {
|
|
records = [{ value: '' }];
|
|
}
|
|
lastItem = item;
|
|
}
|
|
|
|
$: console.log('DbKeyValueSetEdit', { item, dbKeyFields, keyColumn, onChangeItem: !!onChangeItem });
|
|
|
|
function handleFieldChange(index, fieldName, value) {
|
|
records = records.map((record, idx) =>
|
|
idx === index ? { ...record, [fieldName]: value } : record
|
|
);
|
|
|
|
if (onChangeItem && fieldName !== keyColumn) {
|
|
onChangeItem?.({
|
|
...item,
|
|
records: records,
|
|
});
|
|
}
|
|
}
|
|
|
|
function addRecord() {
|
|
records = [...records, { value: '' }];
|
|
if (onChangeItem) {
|
|
onChangeItem({
|
|
...item,
|
|
records: records,
|
|
});
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<div class="container">
|
|
{#each records as record, index}
|
|
<div class="props flex">
|
|
<div class="field-wrapper col-11">
|
|
<FormFieldTemplateLarge label="Value" type="text" noMargin>
|
|
<TextField
|
|
value={record.value}
|
|
on:change={e => handleFieldChange(index, 'value', e.target.value)}
|
|
disabled={keyColumn === 'value'}
|
|
/>
|
|
</FormFieldTemplateLarge>
|
|
</div>
|
|
<div class="delete-wrapper col-1">
|
|
<button class="delete-button" on:click={() => {
|
|
records = records.filter((_, idx) => idx !== index);
|
|
if (onChangeItem) {
|
|
onChangeItem({
|
|
...item,
|
|
records: records,
|
|
});
|
|
}
|
|
}}>
|
|
<FontIcon icon="icon delete" />
|
|
</button>
|
|
</div>
|
|
</div>
|
|
{/each}
|
|
|
|
<div class="add-button-wrapper">
|
|
<button class="add-button" on:click={addRecord}>
|
|
<FontIcon icon="icon add" />
|
|
</button>
|
|
</div>
|
|
</div>
|
|
|
|
<style>
|
|
.container {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
gap: 10px;
|
|
overflow-y: auto;
|
|
}
|
|
|
|
.props {
|
|
display: flex;
|
|
flex-direction: row;
|
|
gap: 10px;
|
|
}
|
|
|
|
.field-wrapper {
|
|
flex: 1;
|
|
min-width: 0;
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
.delete-wrapper {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.delete-button {
|
|
background: none;
|
|
border: none;
|
|
padding: 0;
|
|
cursor: pointer;
|
|
color: var(--theme-font-3);
|
|
transition: color 0.2s;
|
|
font-size: 24px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.delete-button:hover {
|
|
color: var(--theme-font-hover);
|
|
}
|
|
|
|
.add-button-wrapper {
|
|
display: flex;
|
|
justify-content: flex-end;
|
|
margin-top: 10px;
|
|
}
|
|
|
|
.add-button {
|
|
background: none;
|
|
border: none;
|
|
padding: 0;
|
|
cursor: pointer;
|
|
color: var(--theme-font-3);
|
|
transition: color 0.2s;
|
|
font-size: 24px;
|
|
}
|
|
|
|
.add-button:hover {
|
|
color: var(--theme-font-hover);
|
|
}
|
|
</style>
|