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 Local do Discourse?
- Configuração de múltiplos sites: Configurar um ambiente de desenvolvimento de múltiplos sites
- 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 componentes para código Ember no Discourse
- Executar suítes de teste: Como executar as suítes de teste QUnit do núcleo do Discourse, plugins e temas
- Compatibilidade de versão: Fixar 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: Converter modais de controladores legados para a nova API de componentes 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 outlet de plugin: Usando Conectores de Outlet de Plugin de um Tema ou Plugin
- modifyClass: Usando modifyClass para alterar o comportamento do núcleo
- 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
- Sobrescrever templates: (não recomendado) Sobrescrever templates do Discourse 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
- Personalização da Lista de Tópicos: Personalizando a lista de tópicos
- Diretrizes de CSS: Diretrizes para classes CSS usando BEM
- Design para Dispositivos: Projetando para Diferentes Dispositivos (Tamanho da Viewport, Toque/Hover, etc.)
- Dicas de tipo e validação JS: Dicas de tipo e validação JavaScript (typescript)
Plugins
- Plugin básico: Desenvolvendo Plugins do Discourse - Parte 1 - Criar um plugin básico
- Outlet de plugin: Desenvolvendo Plugins do Discourse - Parte 2 - Conectar a um outlet de plugin
- Configurações do site: Desenvolvendo Plugins do Discourse - Parte 3 - Adicionar configurações personalizadas do site
- Configuração do 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: Reempacotar 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
- Tipos de objeto 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: Adicionar metadados e capturas de tela a um Tema
- Variáveis do núcleo: Usar Variáveis do Núcleo 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 em 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 o 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 da 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: Adicionar capturas de tela de pré-visualização a temas do Discourse
- Configurações do site temáveis: Controlar as 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 Tema
- 1 - Introdução: Tutorial para Desenvolvedores de Temas: 1. Introdução
- 2 - Tema Remoto: Tutorial para Desenvolvedores de Temas: 2. Criando um tema remoto
- 3 - CSS: Tutorial para Desenvolvedores de Temas: 3. CSS em Temas
- 4 - Outlets: Tutorial para Desenvolvedores de Temas: 4. Usando Outlets para inserir e substituir conteúdo
- 5 - Componentes: Tutorial para Desenvolvedores de Temas: 5. Construindo e usando componentes
- 6 - API JS: Tutorial para Desenvolvedores de Temas: 6. Usando a API JS
- 7 - Conclusão: Tutorial para Desenvolvedores de Temas: 7. Conclusão