mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-24 12:56:01 +00:00
refactor - simplified filters component
This commit is contained in:
60
packages/web/src/formview/CollectionJsonRow.svelte
Normal file
60
packages/web/src/formview/CollectionJsonRow.svelte
Normal 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'}
|
||||
/>
|
||||
Reference in New Issue
Block a user