Documentação sobre como estender o Discourse com plugins, temas e componentes de tema, trabalhando com o código principal e usando a API do Discourse.
Introdução
- Introdução: Introdução ao Desenvolvimento do Discourse
Ambientes de Desenvolvimento
- Dev Container: Desenvolvendo o Discourse usando um Dev Container
- GitHub Codespaces: Desenvolvendo o Discourse no GitHub Codespaces
- Configuração do Docker: Instalar o Discourse para desenvolvimento usando Docker
- Configuração do macOS: Instalar o Discourse no macOS para desenvolvimento
- Configuração do Ubuntu/Debian: Instalar o Discourse no Ubuntu ou Debian para Desenvolvimento
- Configuração do Windows: Instalar o Discourse no Windows para desenvolvimento
- Plugins sem Docker: Instalar plugins no seu ambiente de desenvolvimento sem Docker
- Configuração local: Configurar um Ambiente de Desenvolvimento Discourse local?
- Configuração multi-site: Configurar um ambiente de desenvolvimento multi-site
- Configuração do Fedora: Configurar o Discourse para desenvolvimento no Fedora Linux
Código e Internos
- Componentes Ember: Adicionar Componentes Ember ao Discourse
- Lint e formatação: Automaticamente fazer lint e formatar o código antes dos commits
- Testes de aceitação: Escrever testes de aceitação e testes de componente para código Ember no Discourse
- Executar suítes de teste: Como executar as suítes de teste QUnit do core do Discourse, plugins e temas
- Compatibilidade de versão: Fixando versões de plugins e temas para instalações mais antigas do Discourse (.discourse-compatibility)
- Propriedade de objetos Ember: Propriedade de objetos Ember (getOwner, injeções de serviço, etc.)
- Desempenho JS: Usando o ‘tachometer’ do Google para medir mudanças de desempenho JS no Discourse
- CI com GitHub Actions: Configurar Integração Contínua usando GitHub Actions
- Extensões Markdown: Guia do desenvolvedor para extensões Markdown
- Conversão de modais: Convertendo modais de controladores legados para a nova API de componente DModal
- API DModal: Usando a API DModal para renderizar janelas modais (também conhecidas como popups/diálogos) no Discourse
- API JS: Usando a API JS
- Conectores de plugin outlet: Usando Conectores de Plugin Outlet de um Tema ou Plugin
- modifyClass: Usando modifyClass para alterar o comportamento do core
- Criação de rotas: Criando Rotas no Discourse e Exibindo Dados
- Método de autenticação: Adicionando um novo método de autenticação ‘gerenciado’ ao Discourse
- Serialização acidental de modelos ActiveRecord: Prevenindo a serialização acidental de modelos ActiveRecord
- Sobrescrevendo templates: (não recomendado) Sobrescrevendo templates do Discourse a partir de um Tema ou Plugin
- Objetos de serviço: Usando objetos de serviço no Discourse
- Especificações do sistema: Escrever especificações de sistema de ponta a ponta para a interface do usuário do Discourse
- FormKit: Toolkit do Discourse para renderizar formulários.
- Disparadores AppEvents: Referência de Disparadores AppEvents
- Transformers: Usando Transformers para personalizar valores e comportamento do lado do cliente
- Customização da Lista de Tópicos: Personalizando a lista de tópicos
- Diretrizes de CSS: Diretrizes para classes CSS usando BEM
- Projetando para Dispositivos: Projetando para Diferentes Dispositivos (Tamanho de Viewport, Toque/Hover, etc.)
Plugins
- Plugin básico: Desenvolvendo Plugins do Discourse - Parte 1 - Criar um plugin básico
- Plugin outlet: Desenvolvendo Plugins do Discourse - Parte 2 - Conectar a um plugin outlet
- Configurações do site: Desenvolvendo Plugins do Discourse - Parte 3 - Adicionar configurações personalizadas do site
- Configuração git: Desenvolvendo Plugins do Discourse - Parte 4 - Configurar git
- Interface de administração: Desenvolvendo Plugins do Discourse - Parte 5 - Adicionar uma interface de administração
- Testes de aceitação: Desenvolvendo Plugins do Discourse - Parte 6 - Adicionar testes de aceitação
- Publicar seu plugin: Desenvolvendo Plugins do Discourse - Parte 7 - Publicar seu plugin
- Novos locais: Adicionar um novo local a partir de um plugin
- Integração de chat: Adicionar um novo provedor ao discourse-chat-integration
- Extensão markdown-it: Reempacotando uma extensão markdown-it como um plugin do Discourse
- Autoloading do Rails: Estruturando um plugin para autoloading do Rails
Temas e Componentes
- Desenvolvendo Temas: Desenvolvendo Temas e Componentes de Tema do Discourse
- Referência rápida: Guia de Referência Rápida para Desenvolvedores de Temas
- Guia do designer: Guia do Designer para começar com temas no Discourse
- Theme Creator: Comece com o Theme Creator e o Theme CLI
- Theme CLI: Instalar o aplicativo de console Theme CLI do Discourse para ajudar você a construir temas
- Estrutura do tema: Estrutura de temas e componentes de tema
- Múltiplos arquivos JS: Dividir o Javascript do tema em múltiplos arquivos
- Múltiplos arquivos SCSS: Dividir o SCSS do tema em múltiplos arquivos
- Configurações do tema: Adicionar configurações ao seu tema do Discourse
- Objetos para configurações de tema: Tipo de objeto para configuração de tema
- Migrar configurações: Migrar configurações de tema do Discourse
- Metadados do tema: Adicionando metadados e capturas de tela a um Tema
- Variáveis do Core: Usar Variáveis do Core do Discourse no seu Tema
- Strings localizáveis: Adicionar strings localizáveis a temas e componentes de tema
- Teste E2E: Testes de sistema de ponta a ponta para temas e componentes de tema
- Minimizando manutenção: Minimizando a Manutenção em Customizações de Tema
- Tamanhos de fonte: Alterar tamanhos de fonte nos seus temas
- Incluir assets: Incluir assets (ex: imagens, fontes) em temas e componentes
- Ícones personalizados: Substituir ícones SVG padrão do Discourse por ícones personalizados em um tema
- Modo escuro: Atualizar temas e plugins para suportar modo escuro automático
- Modificadores de tema: Modificadores de tema: Uma breve introdução
- Pseudo-elementos: Inserir texto ou imagens em qualquer lugar do seu site usando pseudo-elementos CSS
- Componente de fonte: Criar e compartilhar um componente de tema de fonte
- Linguagem Highlight.JS: Instalar uma nova linguagem para Highlight.JS via um componente de tema
- Conteúdo da página inicial: Adicionar conteúdo personalizado que aparece apenas na sua página inicial
- Formato de mensagem: Suporte ao Formato de Mensagem para localização
- Mudanças globais de ícones: Alterar ícones globalmente
- Ícones alternativos: Ícones alternativos
- Estilo de postagem wiki: Alterar o estilo de uma postagem wiki
- Esquema de cores: Criar e compartilhar um esquema de cores
- Menu de navegação: Usar o parâmetro de consulta
navigation_menupara pré-visualizar a barra lateral ou outras opções - Estilos de conteúdo de postagem: Personalizar o conteúdo das postagens com seus próprios estilos
- Capturas de tela do tema: Adicionando capturas de tela de pré-visualização a temas do Discourse
- Configurações de site temáveis: Controlando configurações do site com temas
Guias Gerais
- White-labelling de aplicativos móveis: Coisas a considerar antes de decidir fazer white-label dos aplicativos móveis do Discourse
- Automações personalizadas: Criar Automações personalizadas
- Dump de dados públicos: Dump de Dados Públicos do Discourse
- Avaliações de IA: Executar avaliações de IA do Discourse
Tutorial de Desenvolvimento de Temas
- 1 - Introdução: Tutorial do Desenvolvedor de Temas: 1. Introdução
- 2 - Tema Remoto: Tutorial do Desenvolvedor de Temas: 2. Criando um tema remoto
- 3 - CSS: Tutorial do Desenvolvedor de Temas: 3. CSS em Temas
- 4 - Outlets: Tutorial do Desenvolvedor de Temas: 4. Usando Outlets para inserir e substituir conteúdo
- 5 - Componentes: Tutorial do Desenvolvedor de Temas: 5. Construindo e usando componentes
- 6 - API JS: Tutorial do Desenvolvedor de Temas: 6. Usando a API JS
- 7 - Conclusão: Tutorial do Desenvolvedor de Temas: 7. Conclusão