{"id":21766489,"url":"https://github.com/kastorcode/gostack-challenge-05","last_synced_at":"2026-04-17T15:07:09.793Z","repository":{"id":123500355,"uuid":"401301829","full_name":"kastorcode/gostack-challenge-05","owner":"kastorcode","description":"Challenge #5 of the Rocketseat GoStack Bootcamp: First project with ReactJS.","archived":false,"fork":false,"pushed_at":"2021-08-30T10:23:59.000Z","size":387,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-03-21T05:27:41.638Z","etag":null,"topics":["bootcamp","brazil","challenge","course","css","frontend","goiania","goias","gostack","html","javascript","matheus","oliveira","ramalho","reactjs","rocketseat"],"latest_commit_sha":null,"homepage":"https://rocketseat.com.br","language":"JavaScript","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/kastorcode.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}},"created_at":"2021-08-30T10:22:30.000Z","updated_at":"2021-08-30T10:36:44.000Z","dependencies_parsed_at":null,"dependency_job_id":"cf1188d1-dab7-49dc-907f-996d05152238","html_url":"https://github.com/kastorcode/gostack-challenge-05","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/kastorcode/gostack-challenge-05","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kastorcode%2Fgostack-challenge-05","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kastorcode%2Fgostack-challenge-05/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kastorcode%2Fgostack-challenge-05/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kastorcode%2Fgostack-challenge-05/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kastorcode","download_url":"https://codeload.github.com/kastorcode/gostack-challenge-05/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kastorcode%2Fgostack-challenge-05/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31933781,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-17T12:37:54.787Z","status":"ssl_error","status_checked_at":"2026-04-17T12:37:25.095Z","response_time":62,"last_error":"SSL_read: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"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":["bootcamp","brazil","challenge","course","css","frontend","goiania","goias","gostack","html","javascript","matheus","oliveira","ramalho","reactjs","rocketseat"],"created_at":"2024-11-26T13:17:43.733Z","updated_at":"2026-04-17T15:07:09.788Z","avatar_url":"https://github.com/kastorcode.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"## GoStack Bootcamp Challenge 5\n\u003e 🚀 Practical project of the [Rocketseat](https://rocketseat.com.br) GoStack Bootcamp.  \n👷 Developed by Matheus Ramalho de Oliveira.  \n🔨 Systems Analyst, Full-Stack Developer.  \n🏡 Goiânia, Goiás, Brasil.  \n✉️ kastorcode@gmail.com  \n👍 [instagram.com/kastorcode](https://www.instagram.com/kastorcode)\n\n---\n\n### Screenshots\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"screenshots/1.png\" /\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"screenshots/2.png\" /\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"screenshots/3.png\" /\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"screenshots/4.png\" /\u003e\n\u003c/p\u003e\n\n---\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"assets/gostack.png\" /\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n    Challenge 5: First project with ReactJS\n\u003c/p\u003e\n\n---\n\n## :rocket: Sobre o desafio\n\nNesse desafio você adicionará novas funcionalidades na aplicação que desenvolvemos ao longo desse módulo.\n\n### Funcionalidades\n\n#### 1. Captando erros\n\nAdicione um `try/catch` por volta do código presente na função `handleSubmit` presente no componente `Main` e caso um repositório não seja encontrado na API do Github adicione uma borda vermelha por volta do input em que o usuário digitou o nome do repositório.\n\n#### 2. Repositório duplicado\n\nAntes de fazer a chamada à API na função `handleSubmit` faça uma verificação para ver se o repositório não está duplicado, ou seja, se ele ainda não existe no estado de `repositories`.\n\nCaso exista, dispare um erro, e com isso o código cairá no `catch` do `try/catch` criado na funcionalidade anterior.\n\n```js\nthrow new Error('Repositório duplicado');\n```\n\n#### 3. Filtro de estado\n\nAdicione um filtro de estado na listagem de Issues que criamos no detalhe do repositório. O estado representa se a issue está em aberto, fechada ou uma opção para exibir todas.\n\nExemplos de requisição:\n\n```\nhttps://api.github.com/repos/rocketseat/unform/issues?state=all\nhttps://api.github.com/repos/rocketseat/unform/issues?state=open\nhttps://api.github.com/repos/rocketseat/unform/issues?state=closed\n```\n\nVocê pode encontrar a documentação [nesse link](https://developer.github.com/v3/issues/#parameters-1);\n\n#### 4. Paginação\n\nAdicione paginação nas issues listadas no detalhe do repositório. A API do Github lista no máximo 30 issues por página e você pode controlar o número da página atual por um parâmetro no endereço da requisição:\n\n```\nhttps://api.github.com/repos/rocketseat/unform/issues?page=2\n```\n\nAdicione apenas um botão de próxima página e página anterior. O botão de página anterior deve ficar desativado na primeira página.\n\n---\n\n### 🗓 ️Roadmap\n- Introduction to Node.js\n- Creating Node.js project\n- Continuing Node.js project\n- CSS Flexbox\n- UI Design\n- Introduction to React\n- First project with ReactJS\n- First project with React Native\n- Front-end documentation\n- Flux architecture\n- Using React Hooks\n- Server-side rendering(SSR) with ReactJS\n- GraphQL\n- Expo\n- Creating ReactJS project\n- Creating React Native project\n- Animations with React Native\n- Full-stack app development\n- Node.js tests\n- Node.js deploy\n- ReactJS tests\n- React Native tests\n- ReactJS deploy\n- React Native publication\n- WebSocket with Express\n- Advanced patterns at Node.js\n- OmniStack SaaS(software as a service) and AdonisJS\n- Final challenge\n- Monorepo\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkastorcode%2Fgostack-challenge-05","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkastorcode%2Fgostack-challenge-05","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkastorcode%2Fgostack-challenge-05/lists"}