Discourse 3.1.0.beta6 vem com uma API totalmente nova baseada no componente <DModal>.
Isso substitui a antiga API baseada em controller, que agora está obsoleta. Se você tiver modais existentes usando as APIs antigas, confira o guia de migração aqui.
Renderizando um Modal
Modais são renderizados incluindo o componente <DModal> em um template handlebars. Se você ainda não tem um template adequado, confira Using Plugin Outlet Connectors from a Theme or Plugin.
Um modal simples seria algo assim:
<DButton
@translatedLabel="Show Modal"
@action={{fn (mut this.modalIsVisible) true}}
/>
{{#if this.modalIsVisible}}
<DModal @title="My Modal" @closeModal={{fn (mut this.modalIsVisible) false}}>
Hello world, this is some content in a modal
</DModal>
{{/if}}
O helper
muté usado aqui como uma forma exclusiva de hbs para definir um valor. Você também pode definirmodalIsVisibleusando qualquer outro método padrão do Ember.
Este exemplo criará um Modal simples como este:
Envolvendo em um componente
Antes de introduzir mais complexidade, geralmente é melhor envolver seu novo Modal em sua própria definição de Componente. Vamos mover as coisas do <DModal> para dentro de um novo componente <MyModal />
{{! components/my-modal.hbs }}
<DModal @title="My Modal" @closeModal={{@closeModal}}>
Hello world, this is some content in a modal
</DModal>
Introduzir um arquivo de componente .js complementar permitirá que você introduza lógica e estado mais complexos.
Para usar o novo componente, atualize o local de chamada para referenciá-lo, certificando-se de passar um argumento @closeModal.
<DButton
@translatedLabel="Show Modal"
@action={{fn (mut this.modalIsVisible) true}}
/>
{{#if this.modalIsVisible}}
<MyModal @closeModal={{fn (mut this.modalIsVisible) false}} />
{{/if}}
Adicionando um rodapé
Muitos modais têm algum tipo de chamada para ação. No Discourse, estes tendem a estar localizados na parte inferior do modal. Para tornar isso possível, DModal tem uma série de ‘blocos nomeados’ que podem ter conteúdo renderizado dentro deles. Aqui está o exemplo atualizado para incluir dois botões no rodapé, um dos quais é nosso botão padrão DModalCancel
<DModal @title="My Modal" @closeModal={{@closeModal}}>
<:body>
Hello world, this is some content in a modal
</:body>
<:footer>
<DButton class="btn-primary" @translatedLabel="Submit" />
<DModalCancel @close={{@closeModal}} />
</:footer>
</DModal>
Renderizando um modal de um contexto não-hbs
Idealmente, instâncias de <DModal> devem ser renderizadas de dentro de um template handlebars do Ember usando a técnica declarativa demonstrada acima. Se isso não for viável para o seu caso de uso (por exemplo, você precisa acionar um modal dos sistemas legados ‘raw-hbs’ ou ‘widget’ do Discourse), então isso pode ser feito injetando o serviço modal e chamando modal.show().
Certifique-se de ter envolvido seu modal em seu próprio componente, como descrito acima. Em seguida, acione o modal passando uma referência da sua classe de componente para modal.show():
import MyModal from "discourse/components/my-modal";
// (injete o serviço modal no local relevante)
// Adicione esta chamada sempre que quiser abrir o modal.
// Um argumento `@closeModal` será passado automaticamente para o seu componente.
this.modal.show(MyModal);
// Opcionalmente, passe um parâmetro 'model'. Passado como `@model` para o seu componente.
// Isso pode incluir dados e também ações/callbacks para o seu Modal usar.
this.modal.show(MyModal, {
model: { topic: this.topic, someAction: this.someAction },
});
// `modal.show()` retorna uma promessa, então você pode esperar que ela seja fechada
// Ela será resolvida com os dados passados para a ação `@closeModal`
const result = await this.modal.show(MyModal);
Mais customização!
<DModal> tem uma série de blocos nomeados e argumentos. Confira o styleguide interativo para argumentos e a implementação do template d-modal para blocos nomeados.
Este documento é versionado - sugira alterações no github.

