Solucionado (ver solução)
Solucionado
(ver solução)
2
respostas

[Bug] menssagem de warning ao digitar no input depois de refatorar o componente Campo

Depois que refatorei o componente Campo passou a aparecer um warning no console.log toda vez que digito algo no input . Insira aqui a descrição dessa imagem para ajudar na acessibilidade

import { useState } from 'react';
import Botao from '../Botao';
import Campo from '../Campo';
import ListaSuspensa from '../ListaSuspensa';
import './Formulario.css'

const Formulario = ({ aoColaboradorCadastrado, times, novotime }) => {


    const [nome, setNome] = useState('')
    const [cargo, setCargo] = useState('')
    const [imagem, setImagem] = useState('')
    const [time, setTime] = useState('')
    const [nomeTime, setNomeTime] = useState('')
    const [cor, setCor] = useState('')

    const aoSalvar = (evento) => {
        evento.preventDefault()
        aoColaboradorCadastrado({ nome, cargo, imagem, time, favorito: false })
        setNome('')
        setCargo('')
        setImagem('')
        setTime('')

    }

    const cadastrarTime = (evento) => {
        evento.preventDefault()
        novotime({ nome: nomeTime, cor: cor })
        setNomeTime('')
        setCor('')
    }
    return (
        <section className='formulario'>
            <form onSubmit={aoSalvar}>
                <h2>Preencha os dados para criar o card do colaborador.</h2>
                <Campo
                    valor={nome}
                    aoAlterado={valor => setNome(valor)}
                    obrigatorio={true}
                    label="Nome"
                    placeholder="Digite seu nome"
                />
                <Campo
                    valor={cargo}
                    aoAlterado={valor => setCargo(valor)}
                    obrigatorio={true}
                    label="Cargo"
                    placeholder="Digite seu cargo"
                />
                <Campo
                    valor={imagem}
                    aoAlterado={valor => setImagem(valor)}
                    label="Imagem"
                    placeholder="Informe o endereço da imagem"
                />
                <ListaSuspensa
                    itens={times}
                    label="Time" required={true}
                    valor={time}
                    aoAlterado={valor => setTime(valor)} />
                <Botao>
                    Criar Card
                </Botao>

            </form>
            <form onSubmit={cadastrarTime}>
                <h2>Preencha os dados para criar um novo time.</h2>
                <Campo
                    valor={nomeTime}
                    aoAlterado={valor => setNomeTime(valor)}
                    obrigatorio={true}
                    label='Nome'
                    placeholder="Informe o nome do time a ser criado"
                />
                <Campo
                    type='color'
                    valor={cor}
                    aoAlterado={valor => setCor(valor)}
                    label='Cor'
                    placeholder="Informe o código hexadecimal da cor do time"
                />
                <Botao>
                    Criar time
                </Botao>
            </form>
        </section>
    )
}

export default Formulario;
import './Campo.css'
const Campo = ({type = 'text', label, placeholder, valor, aoAlterado, obrigatorio = false}) => {

    //const type = props.type || 'text'
    const className = `campo campo-${type}`

    const aoDigitado = (evento) => {
        aoAlterado(evento.target.value)   
    } 

    return (
        <div className={className}>
            <label>{label}</label>
            <input 
            type={type} 
            value={valor} 
            onChange={aoDigitado} 
            required={obrigatorio} 
            placeholder={placeholder} />
        </div>

    )
}

export default Campo;

percebi que se eu passar o valor de type direto no input . exemplo em vez de type={type} colocar type= 'text' o warning para de aparecer.

2 respostas
solução!

Oi, Fábio, tudo bem?

Pelo que você descreveu e pela imagem do console, parece que o warning está relacionado ao valor do input do tipo 'color'. O aviso indica que o valor especificado para o input de cor não está no formato correto, que deve ser "#rrggbb", onde "rr", "gg" e "bb" são números hexadecimais de dois dígitos representando as componentes vermelha, verde e azul da cor, respectivamente.

No seu código, você inicializa o estado cor com uma string vazia (''). Quando o componente Campo que lida com a cor é renderizado pela primeira vez, o valor do input é essa string vazia, o que não é um valor válido para um input do tipo 'color'.

Ao colocar o type como text, o aviso desaparece, pois todos os campos vão ser lidos como texto. Contudo, isso pode ser um problema já que campos que esperam tipos diferentes recebem agora o tipo texto. Neste caso, uma possível solução para essa situação seria inicializar o estado cor com um valor de cor hexadecimal válido. Por exemplo, você pode usar uma cor padrão como preto ('#000000') ou qualquer outra cor de sua escolha. Aqui está um exemplo de como você poderia ajustar a inicialização do estado cor:

const [cor, setCor] = useState('#000000')

Espero ter ajudado. Caso tenha dúvidas, conte com o fórum. Abraços!

Caso este post tenha lhe ajudado, por favor, marcar como solucionado ✓. Bons Estudos!

Deu certo, valeu!

Quer mergulhar em tecnologia e aprendizagem?

Receba a newsletter que o nosso CEO escreve pessoalmente, com insights do mercado de trabalho, ciência e desenvolvimento de software