|
|
@ -224,6 +224,14 @@ export function useViewData( |
|
|
|
: await $api.dbView.galleryRead(viewMeta.value.id) |
|
|
|
: await $api.dbView.galleryRead(viewMeta.value.id) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const findIndexByPk = (pk: Record<string, string>) => { |
|
|
|
|
|
|
|
for (const [i, row] of Object.entries(formattedData.value)) { |
|
|
|
|
|
|
|
if (Object.keys(pk).every((k) => pk[k] === row.row[k])) { |
|
|
|
|
|
|
|
return parseInt(i) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
async function insertRow( |
|
|
|
async function insertRow( |
|
|
|
currentRow: Row, |
|
|
|
currentRow: Row, |
|
|
|
ltarState: Record<string, any> = {}, |
|
|
|
ltarState: Record<string, any> = {}, |
|
|
@ -253,33 +261,57 @@ export function useViewData( |
|
|
|
|
|
|
|
|
|
|
|
if (!undo) { |
|
|
|
if (!undo) { |
|
|
|
const id = extractPkFromRow(insertedData, metaValue?.columns as ColumnType[]) |
|
|
|
const id = extractPkFromRow(insertedData, metaValue?.columns as ColumnType[]) |
|
|
|
|
|
|
|
const pkData = rowPkData(insertedData, metaValue?.columns as ColumnType[]) |
|
|
|
|
|
|
|
const rowIndex = findIndexByPk(pkData) |
|
|
|
|
|
|
|
|
|
|
|
addUndo({ |
|
|
|
addUndo({ |
|
|
|
redo: { |
|
|
|
redo: { |
|
|
|
fn: async function redo(this: UndoRedoAction, row: Row, ltarState: Record<string, any>) { |
|
|
|
fn: async function redo( |
|
|
|
const pkData = rowPkData(row.row, metaValue?.columns as ColumnType[]) |
|
|
|
this: UndoRedoAction, |
|
|
|
|
|
|
|
row: Row, |
|
|
|
|
|
|
|
ltarState: Record<string, any>, |
|
|
|
|
|
|
|
pg: { page: number; pageSize: number }, |
|
|
|
|
|
|
|
) { |
|
|
|
row.row = { ...pkData, ...row.row } |
|
|
|
row.row = { ...pkData, ...row.row } |
|
|
|
await insertRow(row, ltarState, undefined, true) |
|
|
|
const insertedData = await insertRow(row, ltarState, undefined, true) |
|
|
|
loadData() |
|
|
|
if (rowIndex && pg.pageSize === paginationData.value.pageSize) { |
|
|
|
|
|
|
|
if (pg.page === paginationData.value.page) { |
|
|
|
|
|
|
|
formattedData.value.splice(rowIndex, 0, { |
|
|
|
|
|
|
|
row: { ...row, ...insertedData }, |
|
|
|
|
|
|
|
rowMeta: row.rowMeta, |
|
|
|
|
|
|
|
oldRow: row.oldRow, |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await changePage(pg.page) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await loadData() |
|
|
|
|
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [clone(currentRow), clone(ltarState)], |
|
|
|
args: [ |
|
|
|
|
|
|
|
clone(currentRow), |
|
|
|
|
|
|
|
clone(ltarState), |
|
|
|
|
|
|
|
{ page: paginationData.value.page, pageSize: paginationData.value.pageSize }, |
|
|
|
|
|
|
|
], |
|
|
|
}, |
|
|
|
}, |
|
|
|
undo: { |
|
|
|
undo: { |
|
|
|
fn: async function undo(this: UndoRedoAction, id: string) { |
|
|
|
fn: async function undo(this: UndoRedoAction, id: string) { |
|
|
|
await deleteRowById(id) |
|
|
|
await deleteRowById(id) |
|
|
|
loadData() |
|
|
|
const pk: Record<string, string> = rowPkData(row.row, meta?.value?.columns as ColumnType[]) |
|
|
|
|
|
|
|
const rowIndex = findIndexByPk(pk) |
|
|
|
|
|
|
|
if (rowIndex) formattedData.value.splice(rowIndex, 1) |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [id], |
|
|
|
args: [id], |
|
|
|
}, |
|
|
|
}, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Object.assign(currentRow, { |
|
|
|
Object.assign(currentRow, { |
|
|
|
row: { ...insertedData, ...row }, |
|
|
|
row: { ...insertedData, ...row }, |
|
|
|
rowMeta: { ...(currentRow.rowMeta || {}), new: undefined }, |
|
|
|
rowMeta: { ...(currentRow.rowMeta || {}), new: undefined }, |
|
|
|
oldRow: { ...insertedData }, |
|
|
|
oldRow: { ...insertedData }, |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
await syncCount() |
|
|
|
await syncCount() |
|
|
|
return insertedData |
|
|
|
return insertedData |
|
|
@ -330,21 +362,45 @@ export function useViewData( |
|
|
|
if (!undo) { |
|
|
|
if (!undo) { |
|
|
|
addUndo({ |
|
|
|
addUndo({ |
|
|
|
redo: { |
|
|
|
redo: { |
|
|
|
fn: async function redo(toUpdate: Row, property: string) { |
|
|
|
fn: async function redo(toUpdate: Row, property: string, pg: { page: number; pageSize: number }) { |
|
|
|
await updateRowProperty(toUpdate, property, undefined, true) |
|
|
|
const updatedData = await updateRowProperty(toUpdate, property, undefined, true) |
|
|
|
|
|
|
|
if (pg.page === paginationData.value.page && pg.pageSize === paginationData.value.pageSize) { |
|
|
|
|
|
|
|
const rowIndex = findIndexByPk(rowPkData(toUpdate.row, meta?.value?.columns as ColumnType[])) |
|
|
|
|
|
|
|
if (rowIndex) { |
|
|
|
|
|
|
|
const row = formattedData.value[rowIndex] |
|
|
|
|
|
|
|
Object.assign(row.row, updatedData) |
|
|
|
|
|
|
|
Object.assign(row.oldRow, updatedData) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await loadData() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await changePage(pg.page) |
|
|
|
|
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [clone(toUpdate), property], |
|
|
|
args: [clone(toUpdate), property, { page: paginationData.value.page, pageSize: paginationData.value.pageSize }], |
|
|
|
}, |
|
|
|
}, |
|
|
|
undo: { |
|
|
|
undo: { |
|
|
|
fn: async function undo(toUpdate: Row, property: string) { |
|
|
|
fn: async function undo(toUpdate: Row, property: string, pg: { page: number; pageSize: number }) { |
|
|
|
await updateRowProperty( |
|
|
|
const updatedData = await updateRowProperty( |
|
|
|
{ row: toUpdate.oldRow, oldRow: toUpdate.row, rowMeta: toUpdate.rowMeta }, |
|
|
|
{ row: toUpdate.oldRow, oldRow: toUpdate.row, rowMeta: toUpdate.rowMeta }, |
|
|
|
property, |
|
|
|
property, |
|
|
|
undefined, |
|
|
|
undefined, |
|
|
|
true, |
|
|
|
true, |
|
|
|
) |
|
|
|
) |
|
|
|
|
|
|
|
if (pg.page === paginationData.value.page && pg.pageSize === paginationData.value.pageSize) { |
|
|
|
|
|
|
|
const rowIndex = findIndexByPk(rowPkData(toUpdate.row, meta?.value?.columns as ColumnType[])) |
|
|
|
|
|
|
|
if (rowIndex) { |
|
|
|
|
|
|
|
const row = formattedData.value[rowIndex] |
|
|
|
|
|
|
|
Object.assign(row.row, updatedData) |
|
|
|
|
|
|
|
Object.assign(row.oldRow, updatedData) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await loadData() |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await changePage(pg.page) |
|
|
|
|
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [clone(toUpdate), property], |
|
|
|
args: [clone(toUpdate), property, { page: paginationData.value.page, pageSize: paginationData.value.pageSize }], |
|
|
|
}, |
|
|
|
}, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
}) |
|
|
|
}) |
|
|
@ -368,9 +424,9 @@ export function useViewData( |
|
|
|
}, {} as Record<string, any>), |
|
|
|
}, {} as Record<string, any>), |
|
|
|
) |
|
|
|
) |
|
|
|
Object.assign(toUpdate.oldRow, updatedRowData) |
|
|
|
Object.assign(toUpdate.oldRow, updatedRowData) |
|
|
|
} else { |
|
|
|
|
|
|
|
loadData() |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return updatedRowData |
|
|
|
} catch (e: any) { |
|
|
|
} catch (e: any) { |
|
|
|
message.error(`${t('msg.error.rowUpdateFailed')} ${await extractSdkResponseErrorMsg(e)}`) |
|
|
|
message.error(`${t('msg.error.rowUpdateFailed')} ${await extractSdkResponseErrorMsg(e)}`) |
|
|
|
} finally { |
|
|
|
} finally { |
|
|
@ -450,18 +506,33 @@ export function useViewData( |
|
|
|
redo: { |
|
|
|
redo: { |
|
|
|
fn: async function undo(this: UndoRedoAction, id: string) { |
|
|
|
fn: async function undo(this: UndoRedoAction, id: string) { |
|
|
|
await deleteRowById(id) |
|
|
|
await deleteRowById(id) |
|
|
|
loadData() |
|
|
|
const pk: Record<string, string> = rowPkData(row.row, meta?.value?.columns as ColumnType[]) |
|
|
|
|
|
|
|
const rowIndex = findIndexByPk(pk) |
|
|
|
|
|
|
|
if (rowIndex) formattedData.value.splice(rowIndex, 1) |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [id], |
|
|
|
args: [id], |
|
|
|
}, |
|
|
|
}, |
|
|
|
undo: { |
|
|
|
undo: { |
|
|
|
fn: async function redo(this: UndoRedoAction, row: Row, ltarState: Record<string, any>) { |
|
|
|
fn: async function redo( |
|
|
|
|
|
|
|
this: UndoRedoAction, |
|
|
|
|
|
|
|
row: Row, |
|
|
|
|
|
|
|
ltarState: Record<string, any>, |
|
|
|
|
|
|
|
pg: { page: number; pageSize: number }, |
|
|
|
|
|
|
|
) { |
|
|
|
const pkData = rowPkData(row.row, meta.value?.columns as ColumnType[]) |
|
|
|
const pkData = rowPkData(row.row, meta.value?.columns as ColumnType[]) |
|
|
|
row.row = { ...pkData, ...row.row } |
|
|
|
row.row = { ...pkData, ...row.row } |
|
|
|
await insertRow(row, ltarState, {}, true) |
|
|
|
await insertRow(row, ltarState, {}, true) |
|
|
|
loadData() |
|
|
|
if (pg.pageSize === paginationData.value.pageSize) { |
|
|
|
|
|
|
|
if (pg.page === paginationData.value.page) { |
|
|
|
|
|
|
|
formattedData.value.splice(rowIndex, 0, row) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await changePage(pg.page) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
await loadData() |
|
|
|
|
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
args: [clone(row), {}], |
|
|
|
args: [clone(row), {}, { page: paginationData.value.page, pageSize: paginationData.value.pageSize }], |
|
|
|
}, |
|
|
|
}, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
scope: viewMeta.value?.title, |
|
|
|
}) |
|
|
|
}) |
|
|
|