Existe uma chamada ou promessa para Aurelia show.bind?

No meu modelo, tenho uma div que quero usar como uma dica de ferramenta. Quando tenho um modelo selecionado, a dica de ferramenta é exibida e, em seguida, uso o tether para colocá-lo no local correto. Se eu definir o tether imediatamente após definir o modelo que mostra o elemento, seu tamanho não será calculado corretamente e o Tether não limitará adequadamente as restrições. Se eu rejeitá-lo com um setTimeout, posso encontrá-lo no lugar certo, mas isso parece hokey. Minha pergunta:

Existe algum tipo de mecanismo de retorno de chamada que eu possa anexar chamado depois que show.bind tornou o elemento visível?

Meu modelo:

<div ref="tooltip" show.bind="selectedAlert" class="homepage-stats-tooltip panel panel-default">
    <div class="panel-body">
        <h1>${selectedAlert.Name}</h1>
        <dl>
            <dt>Normal</dt>
            <dd>${selectedAlert.NormalVolume}</dd>
            <dt>Current</dt>
            <dd>${selectedAlert.CurrentVolume}</dd>
        </dl>
    </div>
</div>

A função que define o modelo e chama Tether:

showTip(event, state) {
    if (!state) {
        return;
    }

    console.log(`Show tip for ${state.Name}.`);
    this.selectedAlert = state;

    setTimeout(() => {
        new Tether({
            element: this.tooltip,
            target: event.target,
            attachment: "top left",
            targetAttachment: "top right",
            constraints: [
                {
                    to: this.usMap,
                    pin: true,
                    attachment: 'together'
                }
            ]
        });
    }, 10);
}

Obrigado!

questionAnswers(1)

yourAnswerToTheQuestion