Auto select inserted row in table

Would be wonderful if there were an easy way to select the inserted row in a table. I have not figured out a reliable way to do this. Still on the hunt today, If I figure something out I'll post here.

@bradlymathews if you're sorting the table, you can run a JS query that executes table1.selectRow() and pass in the index you want to select.

Yes, that is the easy part. I need to wait until the insert is complete, read the ID of the new record, wait for the table to refresh with the new data, find the index of the inserted record and then select the row.

How one puts those pieces together will depend on the app's architecture. Seeing as you are shooting for low-code, maybe there is a way to pull much this off on your end?

Here is the latest version that seems to work for one of my apps where I use a modal form (as opposed to the Add Row button of the table) to add a simple record.

// jsInsertTemplate
const templateInsert = async () => {
  // Set the name of the template I am adding to a temp state var
  // which I will use later to find the row to select. This is a shortcut
  // to reading the ID returned from the insert - won't work for every situation.
  currentTemplate.setValue(txtAddTemplateName.value)
  await qryTemplateInsert.trigger()  // Insert record
  await qryTemplatesSelect.trigger() // requery the database
  // Note to Retool devs: Can we please, please simply update 
  // myTable.data instead of requiring we requery the back end?
}
if (txtAddTemplateName.value) {  // Only execute if form is filled in.
	templateInsert() // Now trigger the function
}

Then in the qryTemplatesSelect's onSuccess I call jsSelectTemplateRow

// jsSelectTemplateRow
const idx = tblTemplates.data.template_name.indexOf(txtAddTemplateName.value)
if (idx >= 0 ) {
  tblTemplates.selectRow(idx)
}
2 Likes

This is useful feedback @bradlymathews - definitely sharing with the team as we think more about improving general CRUD in Retool.

1 Like

CRUD in Retool needs some love. Any progress on this or other CRUD improvements (in particular I'm looking at issues with UPSERT for forms that can create new or edit).

Also, it's worth mentioning that you can get the database to return the ID of the inserted or modified row and use that instead of having to query the DB a second time. In postgres, for example, you'd use the keyword RETURNING

Hey @tradesorg_chris, at the moment we don't have any expected timeline, but as soon as we have any info we will update this post. If you are having other specific issues I would create a new POST for features you would like to see or have improved. Thank You!

I couldn't agree more! I relate to every single comment here.

I have a current use case for this feature. I need this for insert action as well as duplicate row action. in both cases I wish to have the new record selected so that the user is now working on the new record in case they want to perform additional edits after creating the record. This is more of a case for duplicating a record so they do not accidentally edit the original record.

Is there an update for this feature? I am using the self hosted version 3.75.6.

Hey @hexx! Thanks for reaching out. Our team has decided not to prioritize this as a built-in feature, in part because implementing a workaround is relatively straightforward. I put together an example that you can look at here (30.4 KB)!

The above solution takes advantage of the fact that the INSERT query returns the id of the newly created record, which we then use in order to programmatically select the proper table row. Let me know if you have any questions about this implementation!

Many thanks!

1 Like