Documentação sobre a extensão do 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 Docker: Instalar o Discourse para desenvolvimento usando Docker
- Configuração macOS: Instalar o Discourse no macOS para desenvolvimento
- Configuração Ubuntu/Debian: Instalar o Discourse no Ubuntu ou Debian para desenvolvimento
- Configuração Windows: Instalar o Discourse no Windows para desenvolvimento
- Plugins não Docker: Instalar plugins no seu ambiente de desenvolvimento não Docker
- Configuração local: Configurar um ambiente de desenvolvimento local do Discourse?
- Configuração multisite: Configurar um ambiente de desenvolvimento multisite
- Configuração Fedora: Configurar o Discourse para desenvolvimento no Fedora Linux
Código e Internos
- Componentes Ember: Adicionar Componentes Ember ao Discourse
- Lint e formatação: Lintar e formatar código automaticamente antes dos commits
- Testes de aceitação: Escrever testes de aceitação e testes de componentes para código Ember no Discourse
- Executar suites de teste: Como executar as suites de teste QUnit do núcleo, plugins e temas do Discourse
- Compatibilidade de versão: Fixando versões de plugins e temas para instalações mais antigas do Discourse (ramos d-compat)
- 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 (aka popups/dialogos) no Discourse
- API JS: Usando a API JS
- Conectores de saída de plugin: Usando Conectores de Saída de Plugin a partir de um Tema ou Plugin
- modifyClass: Usando modifyClass para alterar o comportamento do núcleo
- Criando rotas: Criando Rotas no Discourse e Mostrando 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) Sobrescrever 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: Kit de ferramentas do Discourse para renderizar formulários.
- Gatilhos AppEvents: Referência de Gatilhos AppEvents
- Transformadores: Usando Transformadores para personalizar valores e comportamentos no lado do cliente
- Personalização da lista de tópicos: Personalizando a lista de tópicos
- Diretrizes CSS: Diretrizes para classes CSS usando BEM
- Design para dispositivos: Design para diferentes dispositivos (tamanho da viewport, toque/hover, etc.)
- Sugestão de tipos JS e validação: Sugestão de tipos JavaScript e validação (typescript)
Plugins
- Plugin básico: Desenvolvendo Plugins do Discourse - Parte 1 - Criar um plugin básico
- Saída de plugin: Desenvolvendo Plugins do Discourse - Parte 2 - Conectar a uma saída de plugin
- 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 administrativa: Desenvolvendo Plugins do Discourse - Parte 5 - Adicionar uma interface administrativa
- 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 do 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
- Carregamento automático Rails: Estruturando um plugin para carregamento automático Rails
Temas e Componentes
- Desenvolvendo Temas: Desenvolvendo Temas do Discourse e Componentes de Tema
- Referência rápida: Guia de Referência Rápida para Desenvolvedores de Temas
- Guia para designers: Guia do Designer para começar com temas no Discourse
- Criador de Temas: Comece com o Theme Creator e a CLI de Temas
- CLI de Temas: Instalar o aplicativo de console CLI de Temas do Discourse para ajudá-lo a construir temas
- Estrutura de temas: Estrutura de temas e componentes de tema
- Múltiplos arquivos JS: Dividir o JavaScript do tema em vários arquivos
- Múltiplos arquivos SCSS: Dividir o SCSS do tema em vários arquivos
- Configurações de 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 de tema: Adicionar metadados e capturas de tela a um Tema
- Variáveis principais: Usar Variáveis Principais do Discourse no seu Tema
- Strings localizáveis: Adicionar strings localizáveis a temas e componentes de tema
- Testes E2E: Testes de sistema de ponta a ponta para temas e componentes de tema
- Minimizar manutenção: Minimizando a manutenção de personalizações de tema
- Tamanhos de fonte: Alterar tamanhos de fonte em seus temas
- Incluir ativos: Incluir ativos (por exemplo, imagens, fontes) em temas e componentes
- Ícones personalizados: Substituir os í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
- Idioma Highlight.JS: Instalar um novo idioma 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
- Alterações globais de ícones: Alterar ícones globalmente
- Ícones alternativos: Ícones alternativos
- Estilo de post wiki: Alterar o estilo de um post wiki
- Esquema de cores: Criar e compartilhar um esquema de cores
- Menu de navegação: Usar o parâmetro de consulta
navigation_menupara visualizar a barra lateral ou outras opções - Estilos de conteúdo de post: Personalizar o conteúdo dos posts com seus próprios estilos
- Capturas de tela de tema: Adicionar capturas de tela de pré-visualização a temas do Discourse
- Configurações de site personalizáveis: Controlar configurações de 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 para Desenvolvedor de Temas: 1. Introdução
- 2 - Tema Remoto: Tutorial para Desenvolvedor de Temas: 2. Criando um tema remoto
- 3 - CSS: Tutorial para Desenvolvedor de Temas: 3. CSS em Temas
- 4 - Saídas: Tutorial para Desenvolvedor de Temas: 4. Usando Saídas para inserir e substituir conteúdo
- 5 - Componentes: Tutorial para Desenvolvedor de Temas: 5. Construindo e usando componentes
- 6 - API JS: Tutorial para Desenvolvedor de Temas: 6. Usando a API JS
- 7 - Conclusão: Tutorial para Desenvolvedor de Temas: 7. Encerrando