Value sent on outgoing port not received on first render

Today, I posted a question about strange behavior related to input value updating. Before someone suggests a solution, I am trying to do a workaround. For this I thought that I will control this input completely from JS. To do so, however, I would prefer to send the initial value from Elm. So I wrote the following port code:

   port startTsPort : JE.Value -> Cmd msg

   app.ports.startTsPort.subscribe(function(val) {
        console.log("from startTsPort: ", val);
    })

When I first do a fresh load of the page (no cache) nothing is logged to the console. However, if I just refresh the page again, then the value startTsPort is logged as expected.

My question: How do I ensure that the value is received on the JS side on the first load?

On further trials, I figured that this is likely due to the fact that when Elm sends the value to JS, the JS is not yet ready. I think this might be the case because if I insert a wait (using Process.sleep) and then send the value, it is logged to the console on the initial fresh load.

Updated question: Is there a DOMContentLoaded on Elm, so that I can send the value after the DOM is loaded and ready to go? Using an arbitrary sleep does not seem like a good solution?

Not officially AFAIK. Could you give me a rework of your code with this new implementation?

If I understand what you’re saying I think its a similar problem to what I’ve come across already.
Take a read of this thread:

There’s currently no nice solution to this one either. I’ve kept the wait for element implementation in my solution. So that’s not too different from an arbitrary sleep.

This topic was automatically closed 10 days after the last reply. New replies are no longer allowed.