I'm using purescript-halogen to build a spreadsheet-like table (similar to Handsontable). If you double-click a cell, an html input element is rendered as a child of the respective table cell (and no such element is rendered for all the other cells).
This works really well with halogen, except that I don't know how to automatically set the focus to the newly created input element.
I tried the autofocus
attribute, but this only works for the first cell that is double-clicked. The JavaScript way to do it is by calling the focus()
method on the new element, but I don't know how to call it after the DOM has been updated in halogen. Any ideas?
Ok, here is how I did it using Phil's
Initializer
hint:Write a JavaScript function that actually focuses the element.
FFI it.
And then use the
setFocus
function in the initializer.Note that I'm using an old version of halogen where the signature is still the old one (definition of
Initializer
in 30e8b2c7).