Topic: TableEditor add value after adding a row
Steven Deferme free asked 3 years ago
Hello,
I'm working with a mysql database table, where there is an id column which is filled in with auto-incremented number upon adding a row. So, when I add a row with a fetch POST request, I get a response, which gives me the id of the added row. This id I want to add to the mdb datatable instance.
I'm trying the code below, but the id is not added to the table, unless I update the instance, or if I insert the value manually (last tr of table > first td.innerHTML = unit.id).
Is there a way to modify a row value using TableEditor, without updating the instance ?
const unitsTable = document.getElementById('units-table')
const columns = [
{ label: 'ID', field: 'id', inputType: 'number', editable: false },
{ label: 'Name', field: 'unit_name', inputType: 'text' },
{ label: 'Description', field: 'description', inputType: 'text' }
]
const asyncUnitsTable = new TableEditor(
unitsTable,
{ columns },
{
loading: true,
loadingMessage: 'Loading Units...',
confirm: true,
confirmText: 'Delete Unit',
confirmMessage: 'Are you sure? This action cannot be undone!',
entries: 20,
entriesOptions: [20, 40, 60, 80, 100]
}
)
unitsTable.addEventListener('add.mdb.tableEditor', e => {
console.log(e.row)
const unit = {
name: e.row.unit_name,
description: e.row.description
}
fetch(`http://${ipAddress}:${port}/unit/add`, {
method: 'post',
body: JSON.stringify(unit),
headers: new Headers({
'Accept': 'application/json',
'Content-Type': 'application/json',
})
})
.then(response => response.json())
.then((unit) => {
console.log(unit.id)
e.row.id = unit.id
})
})
Grzegorz Bujański staff answered 3 years ago
Unfortunately there is no update option for a single row. You can simply update the data and use the update
method to pass new data to the table.
FREE CONSULTATION
Hire our experts to build a dedicated project. We'll analyze your business requirements, for free.
Answered
- ForumUser: Free
- Premium support: No
- Technology: MDB Standard
- MDB Version: MDB5 3.10.1
- Device: PC
- Browser: Mozilla Firefox
- OS: Windows 10
- Provided sample code: No
- Provided link: No