{"id":29269702,"url":"https://github.com/raphaelamonteiro/atviv-wb","last_synced_at":"2025-07-04T21:08:38.311Z","repository":{"id":301992821,"uuid":"1010775493","full_name":"raphaelamonteiro/ATVIV-WB","owner":"raphaelamonteiro","description":"Interface web que consume micro-serviço RESTful e permite ao usuário realizar as operações básicas de gerenciamento de clientes através de uma GUI moderna feita com React","archived":false,"fork":false,"pushed_at":"2025-06-30T01:28:42.000Z","size":36317,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-06-30T02:24:27.665Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/raphaelamonteiro.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-06-29T19:22:16.000Z","updated_at":"2025-06-30T01:29:59.000Z","dependencies_parsed_at":"2025-06-30T02:34:39.817Z","dependency_job_id":null,"html_url":"https://github.com/raphaelamonteiro/ATVIV-WB","commit_stats":null,"previous_names":["raphaelamonteiro/atviv-wb"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/raphaelamonteiro/ATVIV-WB","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/raphaelamonteiro%2FATVIV-WB","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/raphaelamonteiro%2FATVIV-WB/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/raphaelamonteiro%2FATVIV-WB/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/raphaelamonteiro%2FATVIV-WB/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/raphaelamonteiro","download_url":"https://codeload.github.com/raphaelamonteiro/ATVIV-WB/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/raphaelamonteiro%2FATVIV-WB/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":263619806,"owners_count":23489563,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-07-04T21:08:35.341Z","updated_at":"2025-07-04T21:08:38.306Z","avatar_url":"https://github.com/raphaelamonteiro.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# 🧾 Atividade prática ATVIV – Integração Front-end e Back-end (RESTful)\n\n**Professor:** [Gerson da Penha Neto](https://github.com/gerson-pn)\n\n---\n\n## 🚀 Tecnologias utilizadas\n\n\u003cdiv style=\"display: flex; gap: 10px;\"\u003e\n\u003cimg align=\"center\" alt=\"TypeScript\" height=\"30\" width=\"40\" src=\"https://cdn.jsdelivr.net/gh/devicons/devicon@latest/icons/typescript/typescript-original.svg\"/\u003e\n\n\u003cimg align=\"center\" alt=\"React\" height=\"30\" width=\"40\" src=\"https://cdn.jsdelivr.net/gh/devicons/devicon@latest/icons/react/react-original.svg\"/\u003e\n\n\u003cimg align=\"center\" alt=\"Java\" height=\"30\" width=\"40\" src=\"https://cdn.jsdelivr.net/gh/devicons/devicon@latest/icons/java/java-original.svg\"/\u003e\n\n\u003cimg align=\"center\" alt=\"VSCode\" height=\"30\" width=\"40\" src=\"https://cdn.jsdelivr.net/gh/devicons/devicon@latest/icons/vscode/vscode-original.svg\"/\u003e\n\u003c/div\u003e\n\n---\n\n## ☕ Contextualização\n\nNesta etapa, o objetivo é integrar **front-end e back-end** usando os princípios da **arquitetura REST**.\n\nVocê já desenvolveu interfaces gráficas no front-end e agora irá utilizar esse conhecimento para criar uma aplicação que se comunica com um **micro-serviço back-end** RESTful desenvolvido em Java.\n\nA comunicação entre as camadas ocorre por meio de **requisições HTTP** e **troca de dados em formato JSON**, permitindo a manipulação (listar, cadastrar, editar, excluir) de **clientes** de forma dinâmica e independente entre front e back.\n\n---\n\n## 💡 Atividade proposta\n\nCriar uma **interface web** que consuma um micro-serviço RESTful existente (fornecido via arquivo `wbbackend.jar`) e permita ao usuário realizar as operações básicas de gerenciamento de clientes através de uma GUI moderna feita com React.\n\n### 🎯 Objetivo:\n\nDesenvolver uma aplicação front-end capaz de:\n\n* Listar todos os clientes\n* Cadastrar novos clientes\n* Editar informações de clientes\n* Excluir clientes\n\nTudo isso consumindo as **rotas REST** disponibilizadas pelo micro-serviço.\n\n---\n\n## 🛠️ Funcionalidades obrigatórias\n\n* Integração completa com os endpoints REST:\n\n  * `GET /clientes`\n  * `GET /cliente/{id}`\n  * `POST /cliente/cadastrar`\n  * `PUT /cliente/atualizar`\n  * `DELETE /cliente/excluir`\n* Formulários de cadastro e edição\n* Listagem de clientes\n* Exclusão de clientes\n* Interface com feedback visual para o usuário\n\n---\n\n## ✅ Pré-requisitos\n\nAntes de rodar o sistema, certifique-se de ter instalado:\n\n* [Node.js](https://nodejs.org/) (versão 14 ou superior)\n* [Java JDK](https://www.oracle.com/java/technologies/javase/jdk17-archive-downloads.html) (versão 17 ou superior)\n* npm (vem com o Node.js)\n\nVerifique com:\n\n```bash\nnode -v\nnpm -v\njava -version\n```\n\n---\n\n## ▶️ Como executar o projeto\n\n### 🧪 1. Iniciar o back-end\n\n1. Baixe o `wbbackend.jar` no repositório:\n   [`https://github.com/gerson-pn/atviv-wb-typescript`](https://github.com/gerson-pn/atviv-wb-typescript)\n\n2. Execute no terminal:\n\n```bash\njava -jar wbbackend.jar\n```\n\nO back-end estará disponível em:\n\n```bash\nhttp://localhost:32832\n```\n\n---\n\n### 💻 2. Iniciar o front-end\n\n1. **Clone este repositório:**\n\n```bash\ngit clone https://github.com/raphaelamonteiro/ATVIV-REST-WB.git\ncd ATVIV-REST-WB\n```\n\n2. **Instale as dependências:**\n\n```bash\nnpm install\n```\n\n3. **Inicie a aplicação:**\n\n```bash\nnpm run dev\n```\n\n4. Acesse no navegador:\n\n```bash\nhttp://localhost:3000\n```\n\n---\n\n### 🧩 Materiais de apoio\n\n* 🔗 Repositório de apoio: [atviv-wb-typescript](https://github.com/gerson-pn/atviv-wb-typescript)\n* 📘 [Documentação do React](https://reactjs.org)\n* 🧪 [Arquitetura REST explicada](https://restfulapi.net/)\n* ☕ [Como executar um arquivo .jar](https://www.baeldung.com/java-run-jar)\n\n---\n\n\u003e Por [Raphaela Monteiro](https://github.com/raphaelamonteiro)\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraphaelamonteiro%2Fatviv-wb","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fraphaelamonteiro%2Fatviv-wb","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraphaelamonteiro%2Fatviv-wb/lists"}