CSS e Estilização
Você pode estilizar seu site Starlight com arquivos CSS customizados ou utilizar o plugin Starlight Tailwind.
Estilos CSS customizados
Customize os estilos aplicados ao seu site Starlight ao fornecer arquivos CSS adicionais para modificar ou estender os estilos padrões do Starlight.
-
Adicione um arquivo CSS ao seu diretório
src/
. Por exemplo, você poderia definir uma largura padrão de coluna mais larga e um tamanho de texto maior para títulos da página:/* src/styles/customizado.css */ :root { --sl-content-width: 50rem; --sl-text-5xl: 3.5rem; }
-
Adicione o caminho para seu arquivo CSS ao array
customCss
do Starlight emastro.config.mjs
:// astro.config.mjs import { defineConfig } from 'astro/config'; import starlight from '@astrojs/starlight'; export default defineConfig({ integrations: [ starlight({ title: 'Documentação com CSS Customizado', customCss: [ // Caminho relativo ao seu arquivo CSS customizado './src/styles/customizado.css', ], }), ], });
Você pode ver todas as propriedades CSS customizadas utilizadas pelo Starlight que você pode definir para customizar o seu site no arquivo props.css
no GitHub.
Tailwind CSS
Suporte para Tailwind CSS em projetos Astro é providenciado pela integração Astro Tailwind. Starlight providencia um plugin Tailwind complementar para ajudar a configurar o Tailwind de forma compatível com os estilos do Starlight.
O plugin Starlight Tailwind plugin aplica a seguinte configuração:
- Configura as variantes
dark:
do Tailwind para funcionarem com o modo escuro do Starlight. - Utiliza cores de tema e fontes do Tailwind na UI do Starlight.
- Desabilita os estilos de reset Preflight do Tailwind enquanto seletivamente restora partes essenciais do Preflight necessárias para o as classes utilitárias de borda do Tailwind.
Crie um novo projeto com Tailwind
Comece um novo projeto Starlight com Tailwind CSS pré-configurado utilizando create astro
:
npm create astro@latest -- --template starlight/tailwind
pnpm create astro --template starlight/tailwind
yarn create astro --template starlight/tailwind
Adicione Tailwind a um projeto existente
Se você já tem um site Starlight e quer adicionar Tailwind CSS, siga estes passos.
-
Adicione a integração Astro Tailwind:
npx astro add tailwind
pnpm astro add tailwind
yarn astro add tailwind
-
Instale o plugin Starlight Tailwind:
npm install @astrojs/starlight-tailwind
pnpm install @astrojs/starlight-tailwind
yarn add @astrojs/starlight-tailwind
-
Crie um arquivo CSS para os estilos base do Tailwind, por exemplo, em
src/tailwind.css
:/* src/tailwind.css */ @tailwind base; @tailwind components; @tailwind utilities;
-
Atualize seu arquivo de configuração do Astro para utilizar seus estilos base do Tailwind e desabilitar os estilos base padrões:
// astro.config.mjs import { defineConfig } from 'astro/config'; import starlight from '@astrojs/starlight'; import tailwind from '@astrojs/tailwind'; export default defineConfig({ integrations: [ starlight({ title: 'Documentação com Tailwind', customCss: [ // Caminho para seus estilos base do Tailwind: './src/tailwind.css', ], }), tailwind({ // Desabilita os estilos base padrões: applyBaseStyles: false, }), ], });
-
Adicione o plugin Starlight Tailwind em
tailwind.config.cjs
:// tailwind.config.cjs const starlightPlugin = require('@astrojs/starlight-tailwind'); /** @type {import('tailwindcss').Config} */ module.exports = { content: ['./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}'], plugins: [starlightPlugin()], };
Estilizando Starlight com Tailwind
Starlight irá utilizar os valores da sua configuração de tema do Tailwind em sua UI.
Se definidas, as seguintes opções irão sobrescrever os estilos padrões do Starlight:
colors.accent
— usado para os links e o item atualmente destacadocolors.gray
— usado para as cores de fundo e bordasfontFamily.sans
— usado para o texto da UI e conteúdofontFamily.mono
— usado para códigos de exemplo
// tailwind.config.cjs
const starlightPlugin = require('@astrojs/starlight-tailwind');
const colors = require('tailwindcss/colors');
/** @type {import('tailwindcss').Config} */
module.exports = {
content: ['./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}'],
theme: {
extend: {
colors: {
// Sua cor de destaque preferida. Indigo é o mais próximo do padrão do Starlight.
accent: colors.indigo,
// Sua escala de cinzas preferida. Zinc é o mais próximo do padrão do Starlight.
gray: colors.zinc,
},
fontFamily: {
// Sua fonte de texto preferida. Starlight utiliza um conjunto de fontes do sistema por padrão.
sans: ['"Atkinson Hyperlegible"'],
// Sua fonte de código preferida. Starlight utiliza fontes monospace do sistema por padrão.
mono: ['"IBM Plex Mono"'],
},
},
},
plugins: [starlightPlugin()],
};
Tema
O tema de cores do Starlight pode ser controlado ao sobreescrever suas propriedades customizada padrões. Essas variáveis são usadas na UI com uma variedade de tons de cinza usados como cores de texto e fundo e uma cor de destaque usada para links e para destacar itens atuais da navegação.
Editor de tema de cores
Use os controles deslizantes abaixo para modificar as paletas de cor de destaque e cinza do Starlight. As áreas de pré-visualização escura e clara irão mostrar as cores resultantes, e a página inteira também será atualizada para visualizar suas mudanças.
Quando você estiver feliz com as mudanças, copie o código CSS ou Tailwind abaixo e use-o no seu projeto.
Modo escuro
Texto de corpo é mostrado em um tom de cinza com alto contraste com o fundo. Links são coloridos. Algum texto, como o índice, tem um menor contraste. Código inline tem um fundo distinto.
Modo claro
Texto de corpo é mostrado em um tom de cinza com alto contraste com o fundo. Links são coloridos. Algum texto, como o índice, tem um menor contraste. Código inline tem um fundo distinto.
Adicione o seguinte CSS ao seu projeto em um arquivo CSS customizado para aplicar este tema ao seu site.
O arquivo de configuração do Tailwind
de exemplo abaixo inclui paletas de cor accent
e gray
para utilizar no
objeto da configuração theme.extend.colors
.