{"id":17008897,"url":"https://github.com/nashem8/system-notices","last_synced_at":"2026-02-14T14:06:06.844Z","repository":{"id":253198934,"uuid":"842772875","full_name":"nashEm8/system-notices","owner":"nashEm8","description":"Neste desafio, utilizaremos API para cadastrar produtos e visualizá-los em nosso site.","archived":false,"fork":false,"pushed_at":"2024-10-02T00:54:12.000Z","size":6460,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-08-20T00:47:30.817Z","etag":null,"topics":["angular-cli","bootstrap","html-css-javascript","json-server","postman","typescript"],"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/nashEm8.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":"2024-08-15T03:41:37.000Z","updated_at":"2024-10-02T00:54:44.000Z","dependencies_parsed_at":null,"dependency_job_id":"421d5780-9e1a-4143-8310-59fb9be07fcc","html_url":"https://github.com/nashEm8/system-notices","commit_stats":{"total_commits":2,"total_committers":1,"mean_commits":2.0,"dds":0.0,"last_synced_commit":"edbba0cb78f0b9ed52ab1474a1cea503f78e3f9d"},"previous_names":["nashem8/infinity-games-consumo-api","nashem8/system-notices"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/nashEm8/system-notices","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nashEm8%2Fsystem-notices","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nashEm8%2Fsystem-notices/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nashEm8%2Fsystem-notices/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nashEm8%2Fsystem-notices/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/nashEm8","download_url":"https://codeload.github.com/nashEm8/system-notices/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/nashEm8%2Fsystem-notices/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":273553850,"owners_count":25126220,"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","status":"online","status_checked_at":"2025-09-04T02:00:08.968Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"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":["angular-cli","bootstrap","html-css-javascript","json-server","postman","typescript"],"created_at":"2024-10-14T05:40:17.312Z","updated_at":"2026-02-14T14:06:06.802Z","avatar_url":"https://github.com/nashEm8.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"\n# Desafio Criação de Sistema de Consumo de API e utilização dos métodos HTTP\n\nProjeto realizado como resposta ao desafio envolvendo consumo de API utilizando o Angular CLI. \n\n## 1️⃣​ Funcionalidade\nPara rodar o projeto em seu computador será necessário fazer um `git clone` ou fazer o download dos arquivos.\n\nApós isso, basta rodar o seguinte comando: \n- `npm install` - para fazer download dos módulos do node\n- `npm start` - para startar a aplicação\n- clicar no link: `http://localhost:4200/` que será exibido no seu terminal\n\n## 2️⃣​ Objetivo\nCriar um layout estático e responsivo, seguindo um modelo pré definido, utilizando o Angular CLI. Após isso consumir a API, exibindo as informações da mesma na tela e também utilizar os métodos de requisição HTTP para coletar os dados da API e inserir na tela. \n\n####  1° Etapa - Criação do Layout\n​\nDurante o desenvolvimento utilizei meus conhecimentos em HTML e CSS para criar da melhor forma um layout agradável/funcional que seguisse de perto o modelo pré definido, também seguindo a recomendação de uso de fonte (Open Sans). No projeto, aproveitei ao máximo os recursos do angular de componentização, para criar os componentes necessários e assim deixar o código o mais legível possível. \n\n#### 2° Etapa - Consumo da API e exibição dos dados\nUtilizei o padrão MVC na construção do projeto, definindo um modelo Noticia para receber os dados da API (`id, image, title, body`) e instanciar um novo objeto notícia sempre que chamar um método de requisição.\n\nO consumo da APi foi feito usando o `HttpClient` do Angular, que fornece os métodos para realizar requisições HTTP (`GET, POST, PUT, DELETE`) de forma assíncrona, retornando observáveis (`Observable`), permitindo que o código seja fácil de lidar com as respostas da API.\n\nPor meio de injeção de dependências no meu arquivo noticia.service.ts utilizando o `@Injectable({ providedIn: 'root' })`, permiti que toda a aplicação tivesse acesso ao serviço. \n\nPor meio da url que contém o endpoint da API, pude implementar os métodos HTTP `GET, POST` e como bônus os métodos `PUT e DELETE`e defini as rotas de acesso associadas aos meus componentes, passando (se necessário) os dados para utilizar esses métodos.\n\nEndpoints | URL               | Descrição                                       | Corpo da solicitação  | Corpo da resposta |\n----------| ------------------| ------------------------------------------------|-----------------------|-------------------|\nGET       | /api/v1/post      | Obter todas as notícias                         | Nenhum                | Lista de notícias |\nGET       | /api/v1/post/{id} | Obter uma notícia por identificador             | Nenhum                | Uma notícia       |\nPOST      | /api/v1/post      | Adicionar uma notícia                           | Dados da notícia      | Nenhum            |\nPUT       | /api/v1/post{id}  | Atualizar os dados de uma notícia existente     | Dados da notíca       | Nenhum            |\nDELETE    | /api/v1/post{id}  | Excluir uma notícia                             | Nenhum                | Nenhum            |\n\n\n#### Métodos de requisição implementados: \n![metodos](https://github.com/user-attachments/assets/3e088e43-d820-4a17-9a5f-d250e4b372ff)\n\n## 3️⃣​ Instruções e resultados\nPara utilizar as funcionalidades, basta abrir o link exibido no terminal. Após isso verá todas as notícias listadas na página inicial, clicando no botão **Ler mais**, você terá acesso ao conteúdo da notícia individual. \nPara **cadastrar** uma notícia basta clicar no link do menu _Inserir uma notícia_ e depois no item do menu _Cadastrar notícia_, daí basta fornecer os dados corretos para poder visualizá-la. \n\nAo retornar, poderá listar todas as notícias e também utilizar os outros métodos `PUT e DELETE`\n\n| Página Inicial               | Página ao clicar em \"Ler mais\"|\n|------------------------------|-------------------------------|\n| ![inicio](https://github.com/user-attachments/assets/219e77ac-3c17-4aae-89a7-51329bfd655c) | ![noticia](https://github.com/user-attachments/assets/e872b944-6f3c-4c8a-a90f-663c94ee6b4e) \n\n| Página listando todas as notícias               | Página de cadastro de notícia|\n|------------------------------|-------------------------------|\n|![lista](https://github.com/user-attachments/assets/a6ba4176-a961-4039-8a28-abe663d96af9) | ![cadastro](https://github.com/user-attachments/assets/107eef47-6ba4-49bd-9c22-6228359191ec)  |------------------------------|-------------------------------|\n\n\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnashem8%2Fsystem-notices","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fnashem8%2Fsystem-notices","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fnashem8%2Fsystem-notices/lists"}