Page 1 of 1
					
				How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 1:04 am
				by stam
				Hi all,
i want to run an action 
after updating a field in a data grid, that incorporates the updated values of the data grid.
As far as i can tell, the message to react to is 
CloseFieldEditor - but this runs 
before the value in the field editor has been added to the dgData, so
Code: Select all
on CloseFieldEditor
   //do some action with new text
end  CloseFieldEditor
runs the action with text that was there before the edit, not with the updated text.Is there a different message to trap that can do this?
I know i can probably get the text of the fieldEditor but that would be a lot of extra work - i just need to know when the update of the data grid's data has completed, but can't seem to find a message to do this...
Grateful for some pointers...
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 2:24 am
				by stam
				As a follow up to this, i can update the data grid manually and then call the action, but i wonder if there is a better way to do this.
Having seen related posts on this forum and stackoverflow, i've added this code to the CloseFieldEditor handler:
Code: Select all
On CloseFieldEditor pFieldEditor
   local tText, tColumn, tLineA
   put the text of pFieldEditor into tText
   put the dgColumn of the target into tColumn
   put the dgDataOfLine[the dgHilitedLine of me] of me into tLineA
   put tText into tLineA[tColumn]
   set the dgDataOfLine[the dgHilitedLine of me] of me to tLineA
   RefreshList 
   
   //do some action with new text --> now works with updated text
end CloseFieldEditor
What i was looking for was a way to trigger a command on the entire data grid after the update had finished, but couldn't find this - this is a solution that works, but seems rather wordy/kludgy. 
Is there a better way?
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 8:36 am
				by SparkOut
				My first thought is to 
Code: Select all
send "updaterCommand" in <some milliseconds>
but I don't know how many milliseconds to leave after the closeFieldEditor handler to ensure it is always acting on clean data. It should just queue up behind the dg updates just by being "sent" rather than interrupting, but I don't know what other sending the dg may be doing that may cause overlap.
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 1:33 pm
				by stam
				yeh i did try increasing intervals up to 250 ms but it didn't do the trick.
Code: Select all
send <command> in 250 milliseconds
 was still processing the older data. I didn't try longer intervals and to be honest i wouldn't want to risk the data not being processed, so was hoping for some kind of handler i may have missed given how complex the data grid is.
As it is now, manually updating the dgData is quick enough and this works, it's just more code to maintain and duplicate to other similar instances...
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 3:58 pm
				by dunbarx
				Hi.
I always send
Code: Select all
dispatch "refreshList" to group "myDataGrid"
whenever I, er, refresh my dataGrid. Couldn't you start your "action" right afterwards? Or do I misunderstand, and a line of code executed right after that command is executed "too soon", that is, you are really wanting a "dataGridFinallyRefreshed" message?
Trevor?
Craig
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 4:26 pm
				by stam
				HI Craig,
just to clarify this isn't a script-driven update (that would be easy); in this case, the user will double-click in a cell to edit a value. 
After the dgData of the data grid has updated to contain the user's edits, i want to run a command.
Not sure how to trap the event other than what i've put in the 
code above, where i manually update the dgData so i know it's done, then run the command (which ends in a 
refreshList btw) - just wondering if there is a shortcut...
As you say, if there is some kind of 
dataGridFinallyRefreshed handler, that would be sweet. 
Or if the approach i link to above is correct then at least i know and will apply this to all instances...
 
			
					
				Re: How to trigger an action *after* updating a data grid field?
				Posted: Tue Dec 08, 2020 8:23 pm
				by dunbarx
				Have you checked the message watcher while doing the double-click/data entry thing? Maybe something is in there...
Craig