refactor - simplified filters component

This commit is contained in:
Jan Prochazka
2023-02-26 14:42:54 +01:00
parent 65c3ff8ec9
commit 1a28922a62
9 changed files with 66 additions and 111 deletions

View File

@@ -0,0 +1,60 @@
<script lang="ts" context="module">
export function editJsonRowDocument(grider, rowIndex) {
const rowData = grider.getRowData(rowIndex);
showModal(EditJsonModal, {
json: rowData,
onSave: value => {
if (
grider.getRowStatus(rowIndex).status != 'inserted' &&
rowData._id &&
stableStringify(value._id) != stableStringify(rowData._id)
) {
showModal(ErrorMessageModal, { message: '_id attribute cannot be changed' });
return false;
}
grider.setRowData(rowIndex, value);
return true;
},
});
}
</script>
<script lang="ts">
import JSONTree from '../jsontree/JSONTree.svelte';
import EditJsonModal from '../modals/EditJsonModal.svelte';
import ErrorMessageModal from '../modals/ErrorMessageModal.svelte';
import { showModal } from '../modals/modalTools';
import { copyTextToClipboard } from '../utility/clipboard';
import { getContextMenu, registerMenu } from '../utility/contextMenu';
import stableStringify from 'json-stable-stringify';
export let rowIndex;
export let grider;
$: rowData = grider.getRowData(rowIndex);
$: rowStatus = grider.getRowStatus(rowIndex);
function handleEditDocument() {
editJsonRowDocument(grider, rowIndex);
}
function handleCopyJsonDocument() {
const rowData = grider.getRowData(rowIndex);
copyTextToClipboard(JSON.stringify(rowData, undefined, 2));
}
registerMenu([
{ text: 'Copy JSON document', onClick: handleCopyJsonDocument },
{ text: 'Edit document', onClick: handleEditDocument },
{ text: 'Delete document', onClick: () => grider.deleteRow(rowIndex) },
{ text: 'Revert row changes', onClick: () => grider.revertRowChanges(rowIndex) },
]);
</script>
<JSONTree
value={rowData}
labelOverride="({rowIndex + 1}) "
isModified={rowStatus.status == 'updated'}
isInserted={rowStatus.status == 'inserted'}
isDeleted={rowStatus.status == 'deleted'}
/>