# Api e ReactJS do MonkChat | Linguagem de Programação **Autor**: Vitório Trindade Santana **Turma**: Informática C **Número**: 50 [toc] ## Print ### ReactJS ![](https://i.imgur.com/AetslsN.png) ### VScode ![](https://i.imgur.com/qaPT9Ce.png) ## Códigos ### ReactJS #### Conteudo.JS ```javascript= import { ContainerConteudo } from './conteudo.styled' import { ChatButton, ChatInput, ChatTextArea } from '../../components/outros/inputs' import {useState} from 'react'; import Api from '../../services/api'; const api = new Api(); export default function Conteudo() { const [chat, setChat] = useState([]); const atualizar = async () => { const mensagens = await api.listarMensagens(1); setChat (mensagens) } return ( <ContainerConteudo> <div className="container-form"> <div className="box-sala"> <div> <div className="label">Sala</div> <ChatInput /> </div> <div> <div className="label">Nick</div> <ChatInput /> </div> <div> <ChatButton> Criar </ChatButton> <ChatButton> Entrar </ChatButton> </div> </div> <div className="box-mensagem"> <div className="label">Mensagem</div> <ChatTextArea /> <ChatButton className="btn-enviar"> Enviar </ChatButton> </div> </div> <div className="container-chat"> <img onClick={atualizar} className="chat-atualizar" src="/assets/images/atualizar.png" alt="" /> <div className="chat"> {chat.map(x => <div className="chat-message"> <div>({new Date(x.dt_mensagem.replace('Z', '')).toLocaleTimeString()})</div> <div><b>{x.tb_usuario.nm_usuario}</b> fala para <b>Todos</b>:</div> <div> {x.ds_mensagem} </div> </div> )} </div> </div> </ContainerConteudo> ) } ``` #### Api.Js ```javascript= import axios from 'axios' const api = axios.create({ baseURL: 'http://localhost:3030' }) export default class Api { async listarMensagens(idSala) { let r = await api.get(`/chat/${idSala}`); return r.data; } } ```
{"metaMigratedAt":"2023-06-16T07:43:12.448Z","metaMigratedFrom":"Content","title":"Api e ReactJS do MonkChat | Linguagem de Programação","breaks":true,"contributors":"[{\"id\":\"052c8e10-b233-429a-a1e0-0d8df7864830\",\"add\":5902,\"del\":3301}]"}
Expand menu