Desvendando a Conexão do React a uma API com Axios

drlegobox

Diego Viana

Posted on September 20, 2023

Desvendando a Conexão do React a uma API com Axios

_> Instagram - @diegovianagomes
_> Linkedin - @diegovianagomes
_> Github - @dvgba


OI pessoal! 🚀

Hoje, estou empolgado para compartilhar com vocês um exercicio da materia de Frameworks web I, usando react. A ideia por trás deste projeto era criar uma aplicação simples para gerenciar uma lista de números de telefone, a qual chamei de Telelista (Acho que entreguei a idade).

À medida que fui desenvolvendo este projeto, percebi que seria uma ótima oportunidade para dividir o passo a passo com outras pessos como eu, estão aprendendo. Afinal, quando estamos aprendendo algo novo, ter um exemplo prático e uma explicação detalhada pode ser incrivelmente útil para fixação.

Neste artigo, vou guiar vocês através do processo de criação deste aplicativo React passo a passo. Vamos explorar como definir componentes, trabalhar com estados, fazer solicitações HTTP para uma API simulada e até mesmo criar uma interface de usuário amigável usando o Material-UI.


Mockapi

Para começar construir nossa aplicação da lista telefônica, decidimos usar um serviço de API chamado 'https://mockapi.io/projects'. Este serviço nos permite criar e acessar uma API simulada com dados fictícios, o que é perfeito para fins de aprendizado e desenvolvimento.

Ao criar nossa API no 'https://mockapi.io/projects', definimos o esquema (schema) de dados que gostaríamos de usar para nossa lista telefônica. O esquema inclui os seguintes itens do banco de dados fictício:

id - Object ID: Este é um identificador único para cada registro em nossa lista telefônica. Cada contato terá um ID exclusivo que o diferencia dos outros.

name - FAKER.JS - NAME.FULLNAME: Para o nome dos contatos, usamos a biblioteca 'Faker.js' para gerar nomes fictícios completos. Isso nos permite ter nomes realistas para nossos contatos.

number - FAKER.JS - PHONE.NUMBER: Para os números de telefone, novamente utilizamos o 'Faker.js' para gerar números fictícios de telefone. Isso cria números de telefone fictícios para nossos contatos.

email - FAKER.JS - INTERNET.EMAIL: Para os endereços de e-mail, mais uma vez contamos com o 'Faker.js' para criar endereços de e-mail fictícios. Isso nos dá uma variedade de endereços de e-mail fictícios para nossos contatos.

Essa abordagem nos permite simular uma lista telefônica realista com dados fictícios, o que é ótimo para desenvolver e testar nosso aplicativo sem a necessidade de dados reais. Vamos continuar nossa jornada de aprendizado em React usando esses dados fictícios para construir nossa lista telefônica.


// Config.js
Aqui vamos armazenar informações de configuração, como URLs de API ou outras variáveis de ambiente. Vamos dar uma olhada no que está acontecendo:

Primeiro passo vai ser criar uma constante chamada API_URL e atribuindo a ela uma string que representa a URL da nossa API. Essa URL é usada para fazer solicitações HTTP para a API, como buscar ou enviar dados.

const API_URL = "Sua chave da API";
Enter fullscreen mode Exit fullscreen mode

Estamos exportando a constante API_URL para que outros arquivos do nosso aplicativo possam acessá-la. Isso significa que podemos usar essa URL em outros lugares do nosso código, como nos arquivos que fazem solicitações para a API.

export default API_URL;
Enter fullscreen mode Exit fullscreen mode

App.js

Imagine o arquivo App.js como o chefe de tudo em nossa aplicação React. É como o diretor de uma peça de teatro. Ele decide como tudo vai ser exibido no palco.

Aqui está o que ele está fazendo:

Barra de navegação: Pense na barra de navegação como um menu em um restaurante. Ela fica na parte de cima da nossa página e nos ajuda a navegar pelo nosso aplicativo. O App.js está dizendo: "Vamos ter uma barra de navegação ali em cima."

Formulário para adicionar números de telefone: Imagine que estamos criando um caderno de contatos. O App.js também está dizendo: "Vamos ter um lugar onde as pessoas podem escrever nomes, números de telefone e e-mails para adicioná-los ao caderno."

Tabela para listar os números de telefone: Agora, quando já temos alguns números de telefone no caderno, o App.js está dizendo: "Vamos mostrar esses números de telefone em uma tabela, para que possamos vê-los de forma organizada."

Imports e Estilos

Precisamos pensar nas importações e na definição de estilos como a preparação do cenário e dos figurinos para a peça:

Importações: Antes da peça começar, o diretor precisa trazer todos os atores, adereços e figurinos necessários para o palco. Da mesma forma, em App.js, estamos trazendo todas as "ferramentas" que precisamos para nossa peça, como o React (nossa equipe principal de atores), useState (um tipo de adereço para guardar informações), useEffect (uma técnica especial que usamos), axios (uma maneira de fazer perguntas para a API), e os componentes do Material-UI (nossos figurinos elegantes).

import React, { useState, useEffect } from "react";
import axios from "axios";
import TelefoneForm from "./Components/TelefoneForm";
import TelefoneTable from "./Components/TelefoneTable";
import { CssBaseline, Container, Typography, AppBar, Toolbar } from "@mui/material";
import API_URL from "./config";
Enter fullscreen mode Exit fullscreen mode

Definição de Estilos: Agora, para fazer a peça parecer incrível, o diretor decide como os atores devem estar vestidos e como o cenário deve ser montado. Da mesma forma, em App.js, estamos dizendo como queremos que a barra de navegação e o título da página sejam apresentados. Estamos escolhendo as cores, o tamanho das letras e o layout para garantir que a peça tenha uma aparência bonita.

const appBarStyle = {
    marginBottom: "16px"
    };

    const pageTitleStyle = {
        fontSize: "2rem",
        fontWeight: "bold",
        marginBottom: "20px"
        };
Enter fullscreen mode Exit fullscreen mode

Componente App

Nessa montagem temos uma parte que "Define o componente App como uma função."
Isso significa que estamos criando um bloco de código que chamamos de "componente", e esse componente é como uma caixa mágica que pode fazer coisas incríveis em nosso aplicativo.
A palavra-chave "function" nos diz que estamos criando uma função. Você pode pensar em uma função como um pequeno programa dentro do nosso grande programa. E essa função é chamada de App.

Então, o que essa função faz? Bem, ela é como o cérebro do nosso aplicativo. Ela controla como as coisas são mostradas na tela, como os dados são manipulados e como as diferentes partes do nosso aplicativo se comunicam.

function App() {}
Enter fullscreen mode Exit fullscreen mode

Na sequencia há uma parte que diz "Inicializa estados locais telefone e showForm usando o useState." Isso pode parecer um pouco complicado, mas vamos desvendar isso nos proximos passos.
Primeiro, o que são "estados locais"? Pense neles como caixas em nossa memória onde podemos guardar informações. Essas informações podem ser coisas como números, palavras ou qualquer outra coisa que queiramos lembrar enquanto nosso programa está rodando.

Agora, o useState é como uma ferramenta mágica que o JavaScript nos dá para criar essas caixas de memória. Quando usamos o useState, estamos basicamente dizendo: "Ei, JavaScript, crie para nós uma caixa de memória especial que podemos usar para guardar informações."

No nosso código, estamos criando duas dessas caixas de memória especiais: uma chamada telefone e outra chamada showForm. Elas são como nossas caixas de memória pessoais para guardar informações sobre os telefones e se o formulário (um tipo de caixa onde podemos digitar informações) deve ser mostrado ou não.

const [telefone, setTelefone] = useState([]);
const [showForm, setShowForm] = useState(false);
Enter fullscreen mode Exit fullscreen mode

Na sequencia que diz "Usa o useEffect para buscar os números de telefone quando o componente é montado." Vamos quebrar isso em pedaços menores para entender melhor.
Primeiro, o que é o useEffect? O useEffect é uma ferramenta muito útil que o React nos oferece. É como um assistente que nos ajuda a realizar tarefas especiais quando algo acontece em nosso aplicativo.
Aqui, estamos usando o useEffect quando o "componente é montado".

*Mas o que significa "componente montado"? *

Imagine que nosso aplicativo é como uma casa, e esse componente é uma sala dentro dessa casa. "Montar" significa que a sala está pronta para ser usada, como quando você entra em uma sala pela primeira vez.
Agora, o que estamos fazendo com o useEffect é dizer: "Ei, quando esta sala estiver pronta (ou seja, quando nosso componente estiver montado), quero que você faça algo muito específico." E o que estamos pedindo para fazer é "buscar os números de telefone".
Isso é útil porque, quando nosso aplicativo é aberto, queremos ter todos os números de telefone disponíveis para mostrar na tela. Portanto, o useEffect nos ajuda a buscar esses números de telefone assim que a sala (ou o componente) estiver pronta para ser usada.

useEffect(() => {
        fetchTelefone();
        }, []);
Enter fullscreen mode Exit fullscreen mode

A proxima função a ser chamada fetchTelefone. Esta função é como um conjunto de instruções que dizem ao nosso programa o que fazer. Vamos ver o que ela faz:

Solicitação HTTP GET: A função fetchTelefone realiza uma ação muito interessante. Ela faz uma espécie de pergunta a um lugar especial na internet, chamado API. A pergunta que ela faz é:

  • "Olá, API! Preciso dos números de telefone, pode me ajudar?"
  • Claro, claro! Tenho todos os números de telefone aqui, mas só vou te dar se você me pedir educadamente!"
  • "Por favor, API, você poderia gentilmente me dar os números de telefone?"
  • "Bem, já que você pediu com educação, aqui estão os números de telefone: 555-1234, 555-5678, 555-9876..."
  • "Ótimo! Agora, vou colocar esses números na minha 'caixa mágica' chamada telefone."
  • "Ah, a boa e velha 'caixa mágica'! Faça isso, e boa sorte com seus números de telefone."
  • "Obrigado, API! Você é um ótimo colega de equipe."

Atualizar o estado telefone: Depois que a função faz essa pergunta, ela fica atenta para receber uma resposta. Quando a resposta chega, a função pega os números de telefone que a API enviou de volta e coloca esses números em uma caixa de memória especial chamada telefone. Essa caixa de memória é como uma lista onde guardamos os números de telefone para uso futuro.

const fetchTelefone = async () => {
    try {
        const response = await axios.get(`${API_URL}/telefone`);
        setTelefone(response.data);
        } catch (error) {
        console.error("Erro ao buscar o número telefônico:", error);
        }
    };
Enter fullscreen mode Exit fullscreen mode

As proximas duas funções chamadas handleAddTelefone e handleDeleteTelefone. Essas são como as nossas instruções especiais para adicionar e excluir números de telefone.

Função handleAddTelefone:

-Vamos imaginar que estamos preparando uma festa de aniversário e alguém quer nos dar o número de telefone para confirmar a presença. A função handleAddTelefone é como um pedaço de papel em que escrevemos esse número para que não o esqueçamos. Quando alguém nos dá o número de telefone, usamos essa função para anotá-lo.

Função handleDeleteTelefone:

Agora, suponha que alguém tenha mudado de ideia e não queira mais vir à nossa festa. A função handleDeleteTelefone é como uma borracha mágica que usamos para apagar o número de telefone da pessoa que não vai mais. Assim, não ligaremos para ela acidentalmente.

const handleAddTelefone = async (newTelefone) => {
    try {
        await axios.post(`${API_URL}/telefone`, newTelefone);
        fetchTelefone();
        setShowForm(false);
        } catch (error) {
        console.error("Erro ao adicionar o número telefônico:", error);
        }
    };

    const handleDeleteTelefone = async (telefoneId) => {
        try {
            await axios.delete(`${API_URL}/telefone/${telefoneId}`);
            fetchTelefone();
        } catch (error) {
            console.error("Erro ao excluir o número telefônico:", error);
        }
    };
Enter fullscreen mode Exit fullscreen mode

Por fim vamos fazendo algo legal quando queremos mostrar coisas diferentes na tela com base em uma decisão. Vamos dar uma olhada em como isso funciona:

Renderiza a barra de navegação:

Imagine que nossa aplicação é como um site. Todo site tem uma barra no topo com um logotipo, um título ou algo parecido. Nossa aplicação também tem isso, e estamos dizendo ao nosso programa para mostrar essa barra de navegação.

Um título:

Logo abaixo da barra de navegação, queremos mostrar um título que diz o que nossa aplicação faz. Pode ser algo como "Lista de Telefones". Estamos pedindo ao nosso programa para mostrar esse título.

O formulário ou a tabela:

Agora, aqui está a parte interessante. Dependendo de uma decisão que tomamos, queremos mostrar algo diferente na tela. Se decidirmos que queremos adicionar um novo número de telefone, mostramos um formulário onde podemos digitar o nome, o número e o e-mail. Mas, se decidirmos que queremos ver a lista de números de telefone que já temos, mostramos uma tabela bonita com todos eles.

A decisão de mostrar o formulário ou a tabela é baseada em uma coisa chamada showForm. Se showForm for verdadeiro, mostramos o formulário. Se for falso, mostramos a tabela.

return (
        <div>
            <CssBaseline />
            <AppBar position="static" style={appBarStyle}>
                <Toolbar>
                <Typography variant="h6">TeleLista</Typography>
                </Toolbar>
            </AppBar>

            <Container maxWidth="lg">
                <Typography variant="h2" align="center" style={pageTitleStyle}>
                TeleLista
                </Typography>
                {showForm ? (
                <TelefoneForm handleAddTelefone={handleAddTelefone} setShowForm={setShowForm} />
                ) : (
                <TelefoneTable
                    telefone = {telefone}
                    handleDeleteTelefone={handleDeleteTelefone}
                    setShowForm={setShowForm}
                />
                )}
            </Container>
            </div>
        );
Enter fullscreen mode Exit fullscreen mode

TelefoneForm.js

No arquivo TelefoneForm.js, estamos criando uma parte especial do nosso aplicativo que é responsável por adicionar números de telefone. Vamos dar uma olhada no que está acontecendo:

Componente para adicionar números de telefone: Imagine que estamos construindo um formulário onde as pessoas podem escrever informações sobre um número de telefone, como o nome, o número em si e um endereço de e-mail (talvez até mesmo para colocar em nosso caderno de contatos). O TelefoneForm.js é como a equipe de produção desse formulário.

Estrutura do formulário: Dentro deste arquivo, estamos criando a estrutura visual do formulário. Isso inclui coisas como onde os campos de nome, número e e-mail devem ser mostrados na tela.

Funções para lidar com o formulário: Além disso, também estamos criando funções que ajudam a lidar com o que acontece quando alguém preenche o formulário e clica no botão "Adicionar". Essas funções são como as regras do jogo que dizem ao nosso aplicativo o que fazer com as informações inseridas no formulário.

Estilo do formulário: Também definimos como o formulário deve parecer visualmente, como as cores, o tamanho das letras e o espaçamento entre os elementos.

Imports e Estilos

Importação de Componentes do Material-UI e do React: No arquivo TelefoneForm.js, estamos trazendo para dentro do nosso componente duas coisas importantes. Primeiro, estamos importando os componentes do Material-UI, que são como as ferramentas visuais que usamos para construir nosso formulário de adição de números de telefone. Coisas como botões, campos de texto e caixas de diálogo estão incluídas aqui. Além disso, também importamos o React, que é a base fundamental para criar componentes em React. Pense no React como a linguagem que usamos para construir nossos componentes e tornar nosso aplicativo interativo.

Definição de Estilo para o Formulário: Também estamos definindo um estilo para o nosso formulário. Isso é como escolher as roupas que nossos atores usarão no palco. Estamos decidindo coisas como a cor de fundo, o espaçamento entre os elementos e o tamanho das fontes para tornar o formulário visualmente atraente e fácil de usar.

import React, { useState } from "react";
import { TextField, Button, Grid, Paper, Typography } from "@mui/material";

Enter fullscreen mode Exit fullscreen mode
const formStyle = {
    padding: "12px",
    maxWidth: "800px",
    margin: "auto"
};

const buttonStyle = {
    marginRight: "8px"
};
Enter fullscreen mode Exit fullscreen mode

Componente TelefoneForm

Definindo o Componente TelefoneForm como uma Função:

Estamos criando uma função chamada TelefoneForm que será o nosso componente. Esse componente é como um pedaço especial do nosso aplicativo que cuida do formulário para adicionar números de telefone. Ele recebe duas funções especiais, handleAddTelefone e setShowForm, como se fossem ferramentas que podem ser usadas dentro do componente.

function TelefoneForm({ handleAddTelefone, setShowForm })
Enter fullscreen mode Exit fullscreen mode

Inicializando o Estado Local newTelefone:

Estamos criando uma caixa de memória especial chamada newTelefone. Essa caixa irá armazenar as informações inseridas no formulário, como o nome, o número e o e-mail do novo número de telefone.

const [newTelefone, setNewTelefone] = useState({ name: "", number: "", age: "" });
Enter fullscreen mode Exit fullscreen mode

Definindo a Função handleInputChange:

Essa função é como um assistente que fica de olho nos campos do formulário. Quando alguém digita algo nos campos, como o nome ou o número, essa função pega essas informações e coloca na caixa de memória newTelefone. É como anotar as informações em um bloco de notas quando alguém fala.

const handleInputChange = (e) => {
        const { name, value } = e.target;
        setNewTelefone({ ...newTelefone, [name]: value });
    };
Enter fullscreen mode Exit fullscreen mode

Definindo a Função handleSubmit:

Essa função é chamada quando alguém clica no botão "Adicionar". Ela faz algo especial: chama a função handleAddTelefone, que é uma das ferramentas que recebemos lá no começo. Isso significa que quando alguém envia o formulário, estamos dizendo ao nosso aplicativo para adicionar o número de telefone usando a função handleAddTelefone. Depois disso, redefinimos o estado newTelefone para deixar o formulário pronto para receber um novo número.

const handleSubmit = (e) => {
        e.preventDefault();
        handleAddTelefone(newTelefone);
        setNewTelefone({ name: "", number: "", email: "" });
    };
Enter fullscreen mode Exit fullscreen mode

Renderizando o Formulário:

Aqui é onde realmente vemos o formulário na tela. Estamos criando campos onde as pessoas podem digitar o nome, o número e o e-mail. Também temos botões, um para "Adicionar" o número de telefone e outro para "Cancelar" e fechar o formulário.

return (
        <Paper elevation={4} style={formStyle}>
            <Typography variant="h7" gutterBottom>
                Adicionar Contato
            </Typography>
            <form onSubmit={handleSubmit}>
                <Grid container spacing={4}>
                <Grid item xs={8}>
                    <TextField
                    fullWidth
                    label="Nome"
                    name="name"
                    value={newTelefone.name}
                    onChange={handleInputChange}
                    />
                </Grid>
                <Grid item xs={8}>
                    <TextField
                    fullWidth
                    label="Numero"
                    name="number"
                    value={newTelefone.number}
                    onChange={handleInputChange}
                    />
                </Grid>
                <Grid item xs={8}>
                    <TextField
                    fullWidth
                    label="E-mail"
                    name="email"
                    value={newTelefone.email}
                    onChange={handleInputChange}
                    />
                </Grid>
                </Grid>
                <div style={{ marginTop: "8px" }}>
                <Button
                    variant="contained"
                    color="primary"
                    type="submit"
                    style={buttonStyle}
                >
                    Adicionar
                </Button>
                <Button onClick={() => setShowForm(false)} style={buttonStyle}>
                    Cancelar
                </Button>
                </div>
            </form>
            </Paper>
        );
Enter fullscreen mode Exit fullscreen mode

TelefoneTable.js

No arquivo TelefoneTable.js, estamos criando um componente que lida com a exibição de números de telefone em uma tabela. Vamos dar uma olhada no que está acontecendo:

Componente para Listar Números de Telefone: Imagine que temos uma lista de números de telefone que queremos mostrar de forma organizada, como uma lista telefônica. O TelefoneTable.js é o nosso "gerente" para organizar essa lista em uma tabela.

Estrutura da Tabela: Dentro deste arquivo, estamos criando a estrutura visual da tabela. Isso inclui coisas como definir as colunas da tabela (nome, número, e-mail) e como elas devem ser formatadas na tela.

Funções para Lidar com a Tabela: Também estamos criando funções que ajudam a lidar com o que acontece quando alguém interage com a tabela. Por exemplo, quando alguém clica no botão "Excluir", estamos definindo o que deve acontecer.

Estilo da Tabela: Da mesma forma que definimos o estilo para o formulário no TelefoneForm.js, também estamos definindo o estilo para a tabela aqui. Estamos escolhendo como a tabela deve parecer visualmente, como as cores de fundo, o espaçamento entre as células e o estilo dos botões.

Imports e Estilos

Importação de Componentes do Material-UI e do React:

Estamos trazendo para dentro do nosso componente duas coisas importantes. Primeiro, estamos importando os componentes do Material-UI, que são como as ferramentas visuais que usamos para construir nossa tabela de números de telefone. Coisas como tabelas, botões e caixas de diálogo estão incluídas aqui. Além disso, também estamos importando o React, que é a base fundamental para criar componentes em React. Pense no React como a linguagem que usamos para construir nossos componentes e tornar nosso aplicativo interativo.

Importação de Ícones para Exclusão e Adição:

Também estamos importando ícones especiais. Esses ícones são pequenas imagens que usamos para representar ações, como excluir um número de telefone ou adicionar um novo. É como ter pequenas imagens que indicam o que cada botão faz. Por exemplo, um ícone de "Excluir" pode ser uma lixeira, e um ícone de "Adicionar" pode ser um sinal de mais. Eles tornam nossa interface mais amigável e fácil de entender.

import React, { useState } from "react";
import {
    Button,
    Table,
    TableBody,
    TableCell,
    TableContainer,
    TableHead,
    TableRow,
    Paper,
    Typography,
    Box,
    Dialog,
    DialogTitle,
    DialogContent,
    DialogActions
} from "@mui/material";
import DeleteIcon from "@mui/icons-material/Delete";
import AddCircleOutlineIcon from "@mui/icons-material/AddCircleOutline";
Enter fullscreen mode Exit fullscreen mode

Vamos definir o estilo para a tabela e para o cabeçalho da tabela no arquivo TelefoneTable.js. Eles são responsáveis por definir a aparência visual da tabela e do cabeçalho. Vou explicar cada um deles:

tableStyle:

Este estilo é aplicado à tabela em si. Aqui estão as propriedades que ele define:
- minWidth: Define a largura mínima da tabela como 800 pixels.
- margin: Define as margens ao redor da tabela como "auto", o que centraliza a tabela horizontalmente na tela.
- marginTop: Define uma margem superior de 24 pixels, dando um espaço entre a parte superior da tabela e o conteúdo acima dela.
- backgroundColor: Define a cor de fundo da tabela como "#DEDEDE", que é um cinza claro.
- border: Define uma borda de 2 pixels de largura e cor "#3C3C3C" ao redor da tabela.

headerCellStyle:

Este estilo é aplicado às células do cabeçalho da tabela (onde estão os títulos das colunas). Aqui estão as propriedades que ele define:
- backgroundColor: Define a cor de fundo das células do cabeçalho como "#818181", um cinza mais escuro.
- border: Define uma borda de 1 pixel de largura e cor "#3C3C3C" ao redor das células do cabeçalho.
- fontWeight: Define o peso da fonte como "bold", tornando os títulos das colunas em negrito.

const tableStyle = {
    minWidth: 800,
    margin: "auto",
    marginTop: "24px",
    backgroundColor: "#DEDEDE",
    border: "2px solid #3C3C3C"
};

const headerCellStyle = {
    backgroundColor: "#818181",
    border: "1px solid #3C3C3C",
    fontWeight: "bold"
};
Enter fullscreen mode Exit fullscreen mode

Componente TelefoneTable

No arquivo TelefoneTable.js, estamos criando uma função chamada TelefoneTable que será o nosso componente. Esse componente é como um organizador para listar os números de telefone em uma tabela. Agora, vamos ver o que acontece dentro dessa função:

Recebendo Propriedades:
A função TelefoneTable recebe três propriedades especiais que são como informações que outras partes do nosso aplicativo vão nos fornecer:
- telefone: Esta propriedade contém a lista de números de telefone que queremos mostrar na tabela. É como uma lista de contatos que nos dão para listar.
- handleDeleteTelefone: Esta propriedade é uma função que outras partes do aplicativo nos dão. Ela nos ajuda a lidar com a exclusão de números de telefone da tabela. É como ter um assistente que nos ajuda a apagar informações da lista.
- setShowForm: Outra função que recebemos e que nos ajuda a controlar se o formulário para adicionar números de telefone deve ser mostrado ou oculto. É como um interruptor que liga ou desliga o formulário.
Estrutura da Tabela: Dentro desta função, estamos criando a estrutura visual da tabela. Isso inclui a definição das colunas da tabela (nome, número, e-mail) e como essas colunas devem ser formatadas na tela.
Funções para Lidar com a Tabela:
Também estamos criando funções dentro desta função principal. Por exemplo, quando alguém clica no botão "Excluir", usamos a função handleDeleteTelefone que recebemos como propriedade para lidar com essa ação. É como ter um conjunto de regras para gerenciar interações na tabela.
Estilo da Tabela:
Assim como definimos o estilo para o formulário no TelefoneForm.js, também estamos definindo o estilo para a tabela aqui. Estamos escolhendo como a tabela deve parecer visualmente, como as cores de fundo, o espaçamento entre as células e o estilo dos botões.

function TelefoneTable({ telefone, handleDeleteTelefone, setShowForm })
Enter fullscreen mode Exit fullscreen mode

Vamos criar duas caixas de memória especiais:

openDialog: Imagine isso como um interruptor que pode ser ligado ou desligado. Ele nos ajuda a decidir se queremos mostrar ou esconder uma caixa de diálogo especial. Essa caixa de diálogo é usada quando alguém quer excluir um número de telefone. Quando openDialog está ligado (verdadeiro), mostramos a caixa de diálogo. Quando está desligado (falso), a caixa de diálogo fica escondida.

telefoneToDelete: Isso é como uma caixa onde colocamos o número de telefone que alguém quer excluir. Quando alguém clica no botão para excluir um número de telefone, colocamos esse número na caixa telefoneToDelete. É como escrever o nome da pessoa que queremos excluir da lista.

Essas duas caixas de memória nos ajudam a gerenciar o processo de exclusão de números de telefone. openDialog nos diz quando mostrar a caixa de diálogo de confirmação e telefoneToDelete guarda o número que será excluído. É como ter um sistema de segurança para garantir que não excluiremos números de telefone por engano.

    const [openDialog, setOpenDialog] = useState(false);
    const [telefoneToDelete, setTelefoneToDelete] = useState(null);
Enter fullscreen mode Exit fullscreen mode

Agora vamos inserir funções em um estilo mais acessível:

handleConfirmDelete: Esta função é como uma pessoa que verifica se realmente queremos excluir algo. Quando alguém clica no botão "Confirmar" para excluir um número de telefone, a função handleConfirmDelete é chamada. Ela verifica se estamos certos de que queremos excluir o número de telefone que está na caixa telefoneToDelete. Se estivermos certos, ela executa a ação de exclusão. É como ter alguém perguntando: "Você tem certeza de que quer fazer isso?" e, se dissermos "Sim", a ação é realizada.

handleOpenDialog: Esta função é como a pessoa que nos avisa quando algo importante está prestes a acontecer. Quando alguém clica no botão para excluir um número de telefone, a função handleOpenDialog é chamada. Ela coloca o número de telefone que será excluído na caixa telefoneToDelete e liga o interruptor openDialog. Isso faz com que a caixa de diálogo de confirmação seja exibida na tela. É como ter alguém dizendo: "Ei, você quer mesmo fazer isso? Vou mostrar a você uma janela para confirmar."

Portanto, essas duas funções trabalham juntas para garantir que não excluamos números de telefone por engano. A primeira função nos pergunta se estamos certos, e a segunda função nos mostra uma janela de confirmação antes de realizar a ação de exclusão. É como ter um sistema de segurança para evitar erros.

    const handleConfirmDelete = () => {
            if (telefoneToDelete) {
                handleDeleteTelefone(telefoneToDelete.id);
                setTelefoneToDelete(null);
            }
            setOpenDialog(false);
        };
        
    const handleOpenDialog = (telefone) => {
            setTelefoneToDelete(telefone);
            setOpenDialog(true);
        };
Enter fullscreen mode Exit fullscreen mode

Proximo passo é criar o que será renderizado, uma tabela que mostra os números de telefone, incluindo informações como o nome, o número e o e-mail, em um formato organizado. Além disso, estamos adicionando botões que permitem excluir os números de telefone quando necessário.

Aqui está o que está acontecendo:

  1. Tabela de Números de Telefone: Imaginem que estamos organizando uma lista de contatos, como uma lista telefônica. A tabela que estamos criando é como essa lista. Ela possui colunas para o nome, o número de telefone e o e-mail, e cada linha representa um contato.

  2. Botão "Excluir": Para cada contato na tabela, há um botão "Excluir". Quando alguém clica nesse botão, podemos excluir o contato da lista de números de telefone.

 return (
        <div>
            <Box display="flex" justifyContent="space-between" alignItems="center">
                <Typography variant="h6">TeleLista</Typography>
                <Button
                variant="contained"
                color="primary"
                startIcon={<AddCircleOutlineIcon />}
                onClick={() => setShowForm(true)}
                >
                Adicionar Contato
                </Button>
            </Box>
            <TableContainer component={Paper} style={tableStyle}>
                <Table>
                <TableHead>
                    <TableRow>
                    <TableCell style={headerCellStyle} align="center">
                        Nome
                    </TableCell>
                    <TableCell style={headerCellStyle} align="center">
                        Telefone
                    </TableCell>
                    <TableCell style={headerCellStyle} align="center">
                        E-mail
                    </TableCell>
                    <TableCell style={headerCellStyle} align="center">
                        Ações
                    </TableCell>
                    </TableRow>
                </TableHead>
                <TableBody>
                    {telefone.length === 0 ? (
                    <TableRow>
                        <TableCell colSpan={3} align="center">
                        <Typography variant="subtitle1">
                            Não  contatos disponíveis.
                        </Typography>
                        </TableCell>
                    </TableRow>
                    ) : (
                    telefone.map((telefone) => (
                        <TableRow key={telefone.id}>
                        <TableCell align="center">{telefone.name}</TableCell>
                        <TableCell align="center">{telefone.number}</TableCell>
                        <TableCell align="center">{telefone.email}</TableCell>
                        <TableCell align="center">
                            <Button
                            variant="outlined"
                            color="error"
                            startIcon={<DeleteIcon />}
                            onClick={() => handleOpenDialog(telefone)}
                            >
                            Excluir
                            </Button>
                        </TableCell>
                        </TableRow>
                    ))
                    )}
                </TableBody>
                </Table>
            </TableContainer>
            <Dialog open={openDialog} onClose={() => setOpenDialog(false)}>
                <DialogTitle>Confirmar Exclusão</DialogTitle>
                <DialogContent>
                Tem certeza de que deseja excluir o contato "{telefoneToDelete?.title}"?
                </DialogContent>
                <DialogActions>
                <Button onClick={() => setOpenDialog(false)} color="primary">
                    Cancelar
                </Button>
                <Button onClick={handleConfirmDelete} color="error">
                    Confirmar
                </Button>
                </DialogActions>
            </Dialog>
            </div>
        );
Enter fullscreen mode Exit fullscreen mode

Index.js
Este arquivo é uma parte importante da configuração de um aplicativo React.

import { StrictMode } from "react";: Aqui estamos importando o componente StrictMode do React. O StrictMode é uma ferramenta que ajuda a encontrar e prevenir problemas no código e nas práticas de desenvolvimento. É usado para garantir que o aplicativo seja desenvolvido de maneira mais segura e eficiente.

import { createRoot } from "react-dom/client";: Estamos importando a função createRoot do pacote react-dom/client. O createRoot é usado para criar a raiz do aplicativo React, onde todo o conteúdo será renderizado na página.

import App from "./App";: Estamos importando o componente App do arquivo App.js. O App é o componente principal do nosso aplicativo, que contém a maior parte da lógica e da interface do usuário.

const rootElement = document.getElementById("root");: Estamos obtendo o elemento HTML com o id "root". Este é o local onde nosso aplicativo React será renderizado na página. É como encontrar o espaço vazio onde vamos colocar nosso quebra-cabeça.

const root = createRoot(rootElement);: Estamos criando a raiz do nosso aplicativo React com base no elemento HTML que encontramos anteriormente. Esta raiz é onde todo o conteúdo do nosso aplicativo será inserido.

root.render(...): Aqui estamos usando a função render da raiz para renderizar nosso aplicativo. O que estamos renderizando é o componente App que importamos anteriormente. O <StrictMode> é usado para envolver o componente App e aplicar o modo estrito a todo o aplicativo. Isso ajuda a encontrar potenciais problemas no código durante o desenvolvimento.

O arquivo index.js é responsável por iniciar nosso aplicativo React, criando a raiz onde o conteúdo será renderizado e renderizando o componente App, que é o ponto de partida do nosso aplicativo

Imports e Renderização

import { StrictMode } from "react";: Estamos importando o componente StrictMode do React. O StrictMode é uma ferramenta que ajuda a encontrar e prevenir problemas no código e nas práticas de desenvolvimento. É usado para garantir que o aplicativo seja desenvolvido de maneira mais segura e eficiente.

import { createRoot } from "react-dom/client";: Estamos importando a função createRoot do pacote react-dom/client. O createRoot é usado para criar a raiz do aplicativo React, onde todo o conteúdo será renderizado na página.

import App from "./App";: Estamos importando o componente App do arquivo App.js. O App é o componente principal do nosso aplicativo, que contém a maior parte da lógica e da interface do usuário.

import { StrictMode } from "react";
import { createRoot } from "react-dom/client";
import App from "./App";
Enter fullscreen mode Exit fullscreen mode

const rootElement = document.getElementById("root");: Estamos obtendo o elemento HTML com o id "root". Este é o local onde nosso aplicativo React será renderizado na página. É como encontrar o espaço vazio onde vamos colocar nosso quebra-cabeça.

const rootElement = document.getElementById("root");
Enter fullscreen mode Exit fullscreen mode

const root = createRoot(rootElement);: Estamos criando a raiz do nosso aplicativo React com base no elemento HTML que encontramos anteriormente. Esta raiz é onde todo o conteúdo do nosso aplicativo será inserido.

root.render(...): Aqui estamos usando a função render da raiz para renderizar nosso aplicativo. O que estamos renderizando é o componente App que importamos anteriormente. O <StrictMode> é usado para envolver o componente App e aplicar o modo estrito a todo o aplicativo. Isso ajuda a encontrar potenciais problemas no código durante o desenvolvimento.

const root = createRoot(rootElement);
root.render( 
    <StrictMode> 
        <App /> 
    </StrictMode> 
);
Enter fullscreen mode Exit fullscreen mode

O arquivo index.js é responsável por iniciar nosso aplicativo React, criando a raiz onde o conteúdo será renderizado e renderizando o componente App, que é o ponto de partida do nosso aplicativo


Espero que esta documentação passo a passo tenha ajudado a entender melhor o funcionamento da sua aplicação React e como os diferentes componentes se relacionam entre si. Se você tiver alguma dúvida específica, precisar de mais informações sobre algum aspecto do código, correção se falei alguma besteira ou dica de como melhorar, sinta-se à vontade para perguntar.

💖 💪 🙅 🚩
drlegobox
Diego Viana

Posted on September 20, 2023

Join Our Newsletter. No Spam, Only the good stuff.

Sign up to receive the latest update from our blog.

Related