Is it possible to register an event handler for a tabletools button?
Is it possible to register an event handler for a tabletools button?
bitDoctor
Posts: 9Questions: 1Answers: 0
in TableTools
I am developing an SPA and would prefer not to have fnClick call a function to create and populate a new tab due to scoping issues in my application. I would prefer to register a JavaScript event handler for my sButtonText. Does anyone know if that is possible?
Thanks!
bD
This discussion has been closed.
Replies
You could attach a normal jQuery event handler to the button perhaps? That won't work with the Flash based buttons of course, but it will work plain old HTML buttons!
I'm working on a replacement for TableTools' buttons at the moment (called Buttons - full of imagination me... :-) ), and there you can access the node directly and attach an event handler to it. That might work well for you? It is very much in development atm though!
Allan
Thank you Allan. I am unsure how to differentiate between the flash and HTML buttons but I will give it a go and see what happens.
At least "Buttons" is descriptive ;-)
In truth, I am not altogether opposed to calling fnClick() but when I attempt to update the DOM (e.g. create and refresh a tab) from inside fnClick() it throws the exception "Uncaught TypeError: undefined is not a function" when this line is executed
oConfig.fnClick.call( that, nButton, oConfig, null, e );
in the oConfig Button configuration.
Your replacement work for TableTools' buttons sounds very nice. 2.x was a big step forward so I can only anticipate the work you are doing toward the next version.
Rgds,
bD
The copy to clipboard and save to file (CSV, Excel and PDF) buttons are all Flash.
Interesting the function call doesn't work, assuming
that
is the TableTools instance, it looks like it should, although it is an unusual way of doing it! How are you getting the configuration object?Allan
Sorry Allan. That is not my code. Simply where in tableTools the exception is occurs.
Here is my code:
plotLineChart() contains a few lines of housekeeping and then adds a new tab entry to the tab section. It throws the exception mentioned above calling .tabs( "refresh" ); .
I will try registering an event handler to my button and see if the exception is thrown.
Ryan
Thanks for the code - I would suggest adding
console.log( row_data )
between lines 7 and 8 above to ensure that it is what you are looking for. It is currently getting the first element from the selected row's data array (the code above assumes that you are using arrays for the table and not objects).Allan
Thank you Allan. Yes, the [0][0] bits are working perfectly. The data array is comprised of an array of strings so I am able to pull out the ID field using that syntax. The data array is essentially a SQL query result set.
Should I be treating all table data as objects? That thought had not occurred to me.
Arrays are fine. If it is read from the DOM, then it is automatically arrays (although you tell tell it to read into objects using
columns.data
). Otherwise you can give it either arrays or object - I mentioned it only because I've seen a bit of confusion about this in the past!There is a bit more information about it available in the manual if you are interested.
Allan
Many thanks Allen.
Ryan
BTW, I was able to find my error. My $( "#tabs" ).tabs(); was out of scope inside the fnClick() function. I am now using a reference which is scope. Thank you for all of your assistance!
Ryan