> ## Documentation Index
> Fetch the complete documentation index at: https://docs.replit.com/llms.txt
> Use this file to discover all available pages before exploring further.

# O que é um Artifact?

> Artifacts são saídas publicáveis no Replit — web apps, apps móveis, apresentações de slides, animações, visualizações de dados, jogos 3D e designs que você pode implantar e compartilhar.

export const ArtifactGrid = () => {
  if (typeof document !== "undefined" && !document.getElementById("artifact-grid-styles")) {
    const style = document.createElement("style");
    style.id = "artifact-grid-styles";
    style.textContent = `
      .artifact-grid-wrap {
        --ag-bg: var(--replit-docs-bg, #F6F6F4);
        --ag-icon-bg: var(--replit-docs-bg-elevated, #F1F1EE);
        --ag-icon-border: var(--replit-docs-border, #DEDAD5);
        --ag-text: var(--replit-docs-text-muted, #5C5C5C);
        --ag-icon-color: var(--replit-docs-text-muted, #5C5C5C);
      }
      .dark .artifact-grid-wrap,
      html.dark .artifact-grid-wrap,
      [data-theme="dark"] .artifact-grid-wrap {
        --ag-bg: var(--replit-docs-bg, #1E1E1F);
        --ag-icon-bg: var(--replit-docs-bg-elevated, #222223);
        --ag-icon-border: var(--replit-docs-border, #39393D);
        --ag-text: var(--replit-docs-text-muted, #B8B8BE);
        --ag-icon-color: var(--replit-docs-text-muted, #B8B8BE);
      }
      @keyframes ag-fade-in {
        from { transform: translateY(8px); opacity: 0; }
        to { transform: translateY(0); opacity: 1; }
      }
      @media (hover: hover) {
        .artifact-grid-wrap .ag-icon-btn:hover {
          background: var(--ag-icon-border) !important;
        }
      }
    `;
    document.head.appendChild(style);
  }
  const types = [{
    name: "Web",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path fillRule="evenodd" d="M12 1.25c5.937 0 10.75 4.813 10.75 10.75S17.937 22.75 12 22.75 1.25 17.937 1.25 12 6.063 1.25 12 1.25Zm-9.217 11.5a9.25 9.25 0 0 0 7.468 8.333 15.25 15.25 0 0 1-2.982-8.333H2.783Zm13.948 0a15.249 15.249 0 0 1-2.983 8.333 9.25 9.25 0 0 0 7.469-8.333H16.73Zm-7.958 0A13.748 13.748 0 0 0 12 20.876a13.748 13.748 0 0 0 3.227-8.126H8.773Zm1.478-9.834a9.251 9.251 0 0 0-7.468 8.334H7.27a15.251 15.251 0 0 1 2.982-8.334ZM12 3.123a13.747 13.747 0 0 0-3.227 8.127h6.454A13.748 13.748 0 0 0 12 3.123Zm1.748-.207a15.25 15.25 0 0 1 2.983 8.334h4.486a9.251 9.251 0 0 0-7.469-8.334Z" clipRule="evenodd" />
        </svg>
  }, {
    name: "Mobile",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path fillRule="evenodd" d="M7 2.75c-.69 0-1.25.56-1.25 1.25v16c0 .69.56 1.25 1.25 1.25h10c.69 0 1.25-.56 1.25-1.25V4c0-.69-.56-1.25-1.25-1.25H7ZM4.25 4A2.75 2.75 0 0 1 7 1.25h10A2.75 2.75 0 0 1 19.75 4v16A2.75 2.75 0 0 1 17 22.75H7A2.75 2.75 0 0 1 4.25 20V4Zm7 14a.75.75 0 0 1 .75-.75h.01a.75.75 0 0 1 0 1.5H12a.75.75 0 0 1-.75-.75Z" clipRule="evenodd" />
        </svg>
  }, {
    name: "Slides",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path fillRule="evenodd" d="M20 2.25A2.75 2.75 0 0 1 22.75 5v14A2.75 2.75 0 0 1 20 21.75h-8A2.75 2.75 0 0 1 9.25 19V5A2.75 2.75 0 0 1 12 2.25h8Zm-8 1.5c-.69 0-1.25.56-1.25 1.25v14c0 .69.56 1.25 1.25 1.25h8c.69 0 1.25-.56 1.25-1.25V5c0-.69-.56-1.25-1.25-1.25h-8Z" clipRule="evenodd" />
          <path d="M6 4.25a.75.75 0 0 1 .75.75v14a.75.75 0 0 1-1.5 0V5A.75.75 0 0 1 6 4.25ZM2 6.25a.75.75 0 0 1 .75.75v10a.75.75 0 0 1-1.5 0V7A.75.75 0 0 1 2 6.25Z" />
        </svg>
  }, {
    name: "Design",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path d="M6.5 11.25a1.25 1.25 0 1 1 0 2.5 1.25 1.25 0 0 1 0-2.5ZM17.5 9.25a1.25 1.25 0 1 1 0 2.5 1.25 1.25 0 0 1 0-2.5ZM8.5 6.25a1.25 1.25 0 1 1 0 2.5 1.25 1.25 0 0 1 0-2.5ZM13.5 5.25a1.25 1.25 0 1 1 0 2.5 1.25 1.25 0 0 1 0-2.5Z" />
          <path fillRule="evenodd" d="M12 1.25c2.827 0 5.553 1.01 7.573 2.828C21.596 5.9 22.75 8.388 22.75 11A5.749 5.749 0 0 1 17 16.75h-2.25a1 1 0 0 0-.8 1.6l.3.4.1.143a2.5 2.5 0 0 1-2.1 3.857H12a10.75 10.75 0 1 1 0-21.5Zm0 1.5a9.25 9.25 0 1 0 0 18.5h.25a1 1 0 0 0 .8-1.6l-.3-.4a2.5 2.5 0 0 1 2-4H17l.21-.005A4.25 4.25 0 0 0 21.25 11c0-2.161-.953-4.252-2.68-5.807C16.84 3.636 14.476 2.75 12 2.75Z" clipRule="evenodd" />
        </svg>
  }, {
    name: "Animation",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path fillRule="evenodd" d="M10.024 7.25c.31.004.613.091.878.251l4.996 2.996a1.752 1.752 0 0 1 .625 2.367 1.75 1.75 0 0 1-.625.639v-.001l-4.995 2.995.001.001a1.75 1.75 0 0 1-2.654-1.505v-5.99a1.75 1.75 0 0 1 1.774-1.753Zm-.02 1.5a.252.252 0 0 0-.22.124.253.253 0 0 0-.034.127v5.998a.252.252 0 0 0 .127.219.253.253 0 0 0 .252-.004l.002-.001 4.997-2.997.002-.001a.252.252 0 0 0 .122-.215.25.25 0 0 0-.122-.215h-.002L10.13 8.786h-.002a.25.25 0 0 0-.125-.037Z" clipRule="evenodd" />
          <path fillRule="evenodd" d="M12 1.25c5.937 0 10.75 4.813 10.75 10.75S17.937 22.75 12 22.75 1.25 17.937 1.25 12 6.063 1.25 12 1.25Zm0 1.5a9.25 9.25 0 1 0 0 18.5 9.25 9.25 0 0 0 0-18.5Z" clipRule="evenodd" />
        </svg>
  }, {
    name: "Data Viz",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path d="M5 14.25a.75.75 0 0 1 .75.75v6a.75.75 0 0 1-1.5 0v-6a.75.75 0 0 1 .75-.75ZM12 8.25a.75.75 0 0 1 .75.75v12a.75.75 0 0 1-1.5 0V9a.75.75 0 0 1 .75-.75ZM19 2.25a.75.75 0 0 1 .75.75v18a.75.75 0 0 1-1.5 0V3a.75.75 0 0 1 .75-.75Z" />
        </svg>
  }, {
    name: "3D Game",
    icon: <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor">
          <path fillRule="evenodd" d="M11.25 9.675A3.751 3.751 0 0 1 12 2.25a3.75 3.75 0 0 1 .75 7.425v4.575H19A2.75 2.75 0 0 1 21.75 17v2A2.75 2.75 0 0 1 19 21.75H5A2.75 2.75 0 0 1 2.25 19v-2A2.75 2.75 0 0 1 5 14.25h.25V13a.75.75 0 0 1 1.5 0v1.25h4.5V9.675ZM9.75 6a2.25 2.25 0 1 0 4.5 0 2.25 2.25 0 0 0-4.5 0ZM4.116 16.116A1.25 1.25 0 0 1 5 15.75h14A1.25 1.25 0 0 1 20.25 17v2A1.25 1.25 0 0 1 19 20.25H5a1.25 1.25 0 0 1-1.244-1.126L3.75 19v-2c0-.331.132-.65.366-.884Z" clipRule="evenodd" />
        </svg>
  }];
  const rows = [types.slice(0, 4), types.slice(4, 7)];
  const iconBtnStyle = {
    display: "flex",
    alignItems: "center",
    justifyContent: "center",
    width: "48px",
    height: "48px",
    border: "1px solid var(--ag-icon-border)",
    borderRadius: "12px",
    background: "var(--ag-icon-bg)",
    cursor: "default",
    color: "var(--ag-icon-color)",
    padding: 0,
    transition: "background 120ms ease-out",
    flexShrink: 0
  };
  return <div className="artifact-grid-wrap" style={{
    fontFamily: "'IBM Plex Sans', sans-serif",
    display: "flex",
    flexDirection: "column",
    alignItems: "center",
    gap: "12px",
    padding: "32px",
    background: "var(--ag-bg)",
    borderRadius: "16px",
    width: "100%",
    maxWidth: "460px",
    margin: "32px auto",
    opacity: 0,
    animation: "ag-fade-in 300ms ease-out forwards"
  }}>
      {rows.map((row, ri) => <div key={ri} style={{
    display: "flex",
    gap: "12px",
    justifyContent: "center"
  }}>
          {row.map(type => <div key={type.name} style={{
    display: "flex",
    flexDirection: "column",
    alignItems: "center",
    gap: "6px"
  }}>
              <div className="ag-icon-btn" style={iconBtnStyle}>
                {type.icon}
              </div>
              <span style={{
    fontSize: "11px",
    color: "var(--ag-text)",
    textAlign: "center",
    lineHeight: "1.2"
  }}>
                {type.name}
              </span>
            </div>)}
        </div>)}
    </div>;
};

## O que são artefatos?

Artefatos são as coisas que você pode publicar no Replit, como: web apps, apps móveis, apresentações de slides, animações, apps de dados, jogos 3D e designs. Cada um é uma saída completa e independente que recebe seu próprio URL compartilhável quando você publica.

Todo o restante do seu project — arquivos, imagens, CSVs, código — suporta seus artefatos, mas não pode ser publicado por conta própria.

<ArtifactGrid />

## O que você pode criar

| Tipo                                                              | O que é                                                                         |
| ----------------------------------------------------------------- | ------------------------------------------------------------------------------- |
| **[Web app](/references/artifact-types/web-apps)**                | Sites bonitos e poderosos que gerenciam usuários, bancos de dados e muito mais. |
| **[Mobile app](/references/artifact-types/building-mobile-apps)** | Apps nativos para iPhones e telefones Android.                                  |
| **[Slide deck](/references/artifact-types/slide-decks)**          | Apresentações que você pode apresentar ou exportar.                             |
| **[Animation](/references/artifact-types/animated-videos)**       | Motion graphics e vídeos animados. Exporte como MP4.                            |
| **[Data Visualization](/references/artifact-types/data-apps)**    | Dashboards interativos e visualizações para explorar dados e criar gráficos.    |
| **3D game**                                                       | Jogos 3D, simulações e experiências interativas.                                |
| **[Design](/pt/learn/design/canvas)**                             | Explore direções visuais e prototipe ideias na tela de design.                  |

Para disponibilidade por plano, consulte a página dedicada de cada tipo.

## Primeiros passos

Há duas maneiras de criar a partir da página inicial do Replit:

* **Descreva**: Digite o que você quer — "build me a recipe app" ou "make a pitch deck for my startup." O Agent descobre qual tipo é adequado e o constrói.
* **Escolha um tipo**: Selecione o artefato que você quer — Web app, Mobile app, Data Visualization, Animation, 3D game ou outro tipo suportado — antes de descrever sua ideia.

Você também pode adicionar mais a um project existente a qualquer momento pedindo ao Agent no chat ou clicando no botão **+** no painel de preview.

## Alternando entre artefatos

Assim que você tiver múltiplos artefatos em um project, alterne entre eles no **painel de preview** ou na **barra lateral da Library**. Você também pode perguntar ao Agent — "show me the mobile app" ou "switch to the slides."

### Barra lateral da Library

A barra lateral da Library oferece um lugar central para navegar por tudo no seu project. Ela mostra seus artefatos, imagens que o Agent gerou ou baixou, e outros ativos do project. Abra a barra lateral da Library no painel esquerdo para encontrar e reutilizar qualquer ativo em todo o seu project.

<Frame>
  <video autoPlay muted loop playsInline src="https://cdn.replit.com/sanity/stock_image_library_compressed.mp4" />
</Frame>

## Múltiplos artefatos em um project

Um único project pode conter até **7 artefatos**, com no máximo **1 app móvel** por project. Por exemplo, você pode construir um web app para seus clientes, um app móvel para sua equipe e uma apresentação de slides para investidores — tudo no mesmo project.

<ArtifactGrid />

### Adicionando artefatos a um project

Há três maneiras de adicionar um artefato a um project existente:

* **Chat**: Pergunte ao Agent — "add a mobile app to this project" ou "create a slide deck for the investor pitch"
* **Botão de mais**: Clique no botão **+** no painel de preview e escolha o que você quer construir
* **Barra lateral da Library**: Navegue pelos seus artefatos existentes, imagens e outros ativos, e adicione novos artefatos a partir daí

### Dados e backend compartilhados

Quando os artefatos vivem no mesmo project, eles compartilham automaticamente os mesmos dados e lógica de backend. Se um cliente fizer um pedido pelo seu web app, seu app móvel e dashboard de dados também verão esse pedido. Você não precisa configurar conexões ou duplicar código — simplesmente funciona.

<Note>
  A publicação implanta todo o seu project de uma vez. Todos os artefatos entram no ar juntos, para que estejam sempre sincronizados.
</Note>

### Exemplos de combinações

* **Web app + app móvel**: Um restaurante com um web app voltado para o cliente e um app móvel para a equipe — ambos conectados à mesma API e banco de dados
* **App + dashboard de administração**: Um produto principal ao lado de um painel de administração interno para gerenciar conteúdo, usuários ou configurações
* **App + apresentação de slides**: Seu produto e um pitch deck no mesmo project, para que os slides sempre reflitam a versão mais recente
* **Dashboard de dados + vídeo**: Uma visualização de dados ao vivo combinada com um vídeo animado que percorre os destaques

## Publicação

Apps, slides e vídeos podem ser publicados e compartilhados. Cada um recebe seu próprio URL compartilhável quando você faz a implantação.

Arquivos e ativos que não são artefatos (como CSVs, imagens ou arquivos markdown) não podem ser publicados por conta própria. Para compartilhá-los, adicione-os a um app ou crie um novo artefato.

## Perguntas frequentes

<Accordion title="Posso ter mais de um artefato em um project?">
  Sim. Um único project pode conter até **7 artefatos no total**, com um limite de **1 app móvel por project**. Todos os artefatos em um project compartilham o mesmo backend e dados automaticamente.

  Se você atingir o limite de app móvel e quiser construir um segundo, crie-o em um novo project. Se atingir o total de 7 artefatos, remova um artefato existente antes de adicionar outro, ou divida seu trabalho entre projects.
</Accordion>

<Accordion title="Preciso escolher um tipo antes de começar?">
  Não. Basta descrever o que você quer e Agent escolhe o tipo certo para você. Você também pode escolher um tipo manualmente no menu suspenso, se preferir.
</Accordion>

<Accordion title="Posso publicar apenas um artefato de um project?">
  Não atualmente. A publicação implanta o project inteiro junto, para que todos os artefatos fiquem sincronizados. Se você precisar de implantação independente, use projects separados.
</Accordion>

<Accordion title="Os artefatos compartilham dados entre si?">
  Sim. Todos os artefatos em um project compartilham o mesmo banco de dados e serviços de backend. Se seu web app gravar dados, seu app móvel e dashboard de dados poderão lê-los imediatamente.
</Accordion>

<Accordion title="Qual é a diferença entre um artefato e um arquivo?">
  Artefatos são coisas que você pode publicar — apps, slides e vídeos. Arquivos (como CSVs, imagens ou código) são ativos dentro do seu project que suportam seus artefatos, mas não podem ser publicados por conta própria.
</Accordion>

<Accordion title="Meu app móvel está sem recursos do meu web app. O que aconteceu?">
  Quando Agent traduz recursos entre tipos de artefatos, algumas coisas podem não ser transferidas perfeitamente — especialmente interações ou layouts que funcionam de maneira diferente entre plataformas. Você pode continuar no chat para preencher as lacunas.
</Accordion>

Para uma lista completa do que você pode construir, veja a [visão geral de Projects](/references/projects-and-artifacts/projects).
