Add validation to duplicating rows

This commit is contained in:
Andrew Kingston 2023-04-11 16:46:17 +01:00
parent 4a6713e9d3
commit 361ab9e3cd
2 changed files with 32 additions and 8 deletions

View File

@ -25,16 +25,12 @@
}
const duplicate = async () => {
let clone = { ...$focusedRow }
delete clone._id
delete clone._rev
delete clone.__idx
const newRow = await rows.actions.addRow(clone, $focusedRow.__idx + 1)
const newRow = await rows.actions.duplicateRow($focusedRow)
if (newRow) {
const column = $stickyColumn?.name || $columns[0].name
$focusedCellId = `${newRow._id}-${column}`
menu.actions.close()
}
menu.actions.close()
}
</script>

View File

@ -185,7 +185,7 @@ export const deriveStores = context => {
}
// Adds a new row
const addRow = async (row, idx) => {
const addRow = async (row, idx, bubble = false) => {
try {
// Create row
const newRow = await API.saveRow({ ...row, tableId: get(tableId) })
@ -203,9 +203,36 @@ export const deriveStores = context => {
notifications.success("Row created successfully")
return newRow
} catch (error) {
if (bubble) {
throw error
} else {
handleValidationError("new", error)
}
}
}
const duplicateRow = async row => {
let clone = { ...row }
delete clone._id
delete clone._rev
delete clone.__idx
try {
const newRow = await addRow(clone, row.__idx + 1, true)
// We deliberately re-use the majority of the existing row as the API
// returns different metadata for relationships when saving a row compared
// to using the search endpoint. We always want data in the shape that the
// search endpoint returns it.
return {
...row,
__idx: row.__idx + 1,
_id: newRow._id,
_rev: newRow._rev,
}
} catch (error) {
handleValidationError(row._id, error)
}
}
// Refreshes a specific row, handling updates, addition or deletion
const refreshRow = async id => {
@ -378,6 +405,7 @@ export const deriveStores = context => {
...rows,
actions: {
addRow,
duplicateRow,
getRow,
updateRow,
deleteRows,