No tutorial anterior mostrei como configurar as partes do lado do servidor e do lado do cliente do Discourse para responder a uma solicitação.
Agora recomendamos que você leia a documentação do componente Ember: Introducing Components - Components - Ember Guides
Tutorial antigo
Neste tutorial, vou criar um novo Componente Ember como uma forma de envolver JavaScript de terceiros. Isso será semelhante a um vídeo do YouTube que fiz há algum tempo, que você pode achar informativo, mas desta vez é específico para o Discourse e como organizamos os arquivos em nosso projeto.
Por que Componentes?
Handlebars é uma linguagem de template bastante simples. É apenas HTML comum junto com algumas partes dinâmicas. Isso é simples de aprender e ótimo para produtividade, mas não tão bom para reutilização de código. Se você estiver desenvolvendo uma aplicação grande como o Discourse, descobrirá que deseja reutilizar algumas das mesmas coisas repetidamente.
Componentes são a solução do Ember para esse problema. Vamos criar um componente que exibirá nosso lanche de uma maneira mais agradável.
Criando um novo Componente
Componentes precisam ter um hífen em seu nome. Vou escolher fancy-snack como nome para este. Vamos criar nosso template:
app/assets/javascripts/admin/templates/components/fancy-snack.hbs
<div class="fancy-snack-title">
<h1>{{snack.name}}</h1>
</div>
<div class="fancy-snack-description">
<p>{{snack.description}}</p>
</div>
Agora, para usar nosso componente, substituiremos nosso template admin/snack existente por este:
app/assets/javascripts/admin/templates/snack.hbs
{{fancy-snack snack=model}}
Agora podemos reutilizar nosso componente fancy-snack em qualquer outro template, apenas passando o modelo conforme necessário.
Adicionando Código Javascript Personalizado
Além da reutilização, os Componentes no Ember são ótimos para adicionar com segurança Javascript personalizado, jQuery e outro código externo. Isso lhe dá controle sobre quando o componente é inserido na página e quando é removido. Para fazer isso, definimos um Ember.Component com algum código:
app/assets/javascripts/admin/components/fancy-snack.js
export default Ember.Component.extend({
didInsertElement() {
this._super();
this.$().animate({ backgroundColor: "yellow" }, 2000);
},
willDestroyElement() {
this._super();
this.$().stop();
},
});
Se você adicionar o código acima e atualizar a página, verá que nosso lanche tem uma animação de um fundo amarelo desaparecendo lentamente.
Vamos explicar o que está acontecendo aqui:
-
Quando o componente é renderizado na página, ele chamará
didInsertElement -
A primeira linha de
didInsertElement(ewillDestroyElement) éthis._super()que é necessário porque estamos subclassificando Ember.Component. -
A animação é feita usando a função animate do jQuery .
-
Finalmente, a animação é cancelada no hook
willDestroyElement, que é chamado quando o componente é removido da página.
Você pode se perguntar por que nos importamos com willDestroyElement; o motivo é que em uma aplicação Javascript de longa duração como o Discourse é importante limpar o que usamos, para não vazar memória ou deixar coisas rodando. Neste caso, paramos a animação, o que diz a quaisquer temporizadores do jQuery que eles não precisam mais disparar, pois o componente não está mais visível na página.
Para onde ir a partir daqui
O tutorial final desta série cobre testes automatizados.
Este documento é controlado por versão - sugira alterações no github.