{"id":22276849,"url":"https://github.com/raizertechdev/tarefasstackx-itemcrud","last_synced_at":"2025-03-25T17:43:46.397Z","repository":{"id":265138904,"uuid":"893256898","full_name":"RaizerTechDev/tarefasStackX-itemCrud","owner":"RaizerTechDev","description":"Desenvolvimento de uma tarefa proposta pelo curso Stackx, envolvendo uma aplicação fictícia com funcionalidades CRUD (Create, Read, Update, Delete), utilizando Node.js, JavaScript e MongoDB Atlas. O projeto inclui a criação de uma tabela fictícia e a execução de queries para gerenciar dados de forma prática e estratégica.","archived":false,"fork":false,"pushed_at":"2024-11-27T21:32:47.000Z","size":180,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-01-30T15:40:55.043Z","etag":null,"topics":["crud-application","javascript","mongodb-atlas","nodejs"],"latest_commit_sha":null,"homepage":"https://github.com/RaizerTechDev/tarefasStackX-itemCrud/blob/master/Documentation.md","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/RaizerTechDev.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-11-24T00:01:04.000Z","updated_at":"2024-11-27T21:32:51.000Z","dependencies_parsed_at":"2024-11-27T22:19:32.664Z","dependency_job_id":"62d24d8b-be9b-433b-ac74-ba5593cf9071","html_url":"https://github.com/RaizerTechDev/tarefasStackX-itemCrud","commit_stats":null,"previous_names":["raizertechdev/tarefasstackx-itemcrud"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefasStackX-itemCrud","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefasStackX-itemCrud/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefasStackX-itemCrud/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/RaizerTechDev%2FtarefasStackX-itemCrud/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/RaizerTechDev","download_url":"https://codeload.github.com/RaizerTechDev/tarefasStackX-itemCrud/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245512282,"owners_count":20627555,"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":["crud-application","javascript","mongodb-atlas","nodejs"],"created_at":"2024-12-03T14:16:23.581Z","updated_at":"2025-03-25T17:43:46.363Z","avatar_url":"https://github.com/RaizerTechDev.png","language":"JavaScript","readme":"# Tarefa - Gerenciamento Banco de Dados\r\n\r\n## Índice\r\n\r\n- [Objetivo](#-objetivo)\r\n- [Documentação](#-documentação-do-projeto)\r\n- [Instalação](#instalação-com-bash)\r\n- [Demonstração Código Resumido](#demonstração-código-resumido)\r\n  - [- `models/usuarioModels.js`](#--modelsusuariomodeljs)\r\n  - [- `database/index.js`](#--databaseindexjs)\r\n  - [- `app.js`](#--appjs)\r\n\r\n## 🌟 Objetivo:\r\n🔍 Desafio Estratégico:\r\n Crie uma tabela fictícia 📋 e, em seguida, demonstre o poder de um CRUD com queries específicas para cada ação:\r\n\r\n1️⃣ Criar uma nova linha na tabela.\r\n2️⃣ Realizar uma leitura (seleção) dos dados.\r\n3️⃣ Update (editar) os dados existentes.\r\n4️⃣ Deletar uma linha específica.\r\n\r\n🎯 Coloque em prática suas habilidades com essas operações essenciais! 🚀\r\n\r\n\u003cbr\u003e\r\n\r\n---\r\n\r\n## 📖 Documentação do Projeto\r\n\r\n \u003cdiv align=\"center\"\u003e\r\n\r\n\u003cimg src =\"././public/assets/images/doc.png\" alt=\"Descrição da Imagem\" height=\"45\"\u003e\r\n\r\n[✨ **Clique aqui para saber mais da documentação** ✨](https://github.com/RaizerTechDev/tarefasStackX-itemCrud/blob/master/Documentation.md)\r\n\r\n\u003cbr\u003e\r\n\r\n\u003cdiv align=\"center\"\u003e\r\n  \r\n\u003cimg src= \"https://media.giphy.com/media/3zSF3Gnr7cxMbi6WoP/giphy.gif\" align=\"center\" height=\"55\" width=\"55\"\u003e [Demonstração-Tabelas] \u003cimg src= \"https://media.giphy.com/media/E5DzZsofmgxc9wjbhX/giphy.gif\" align=\"center\" height=\"35\" width=\"35\"\u003e\r\n\r\n\u003cimg height=\"480em\" src=\"././public/assets/images/readme-tarefa-item-crud.png\"  align=\"center\"\u003e\r\n\r\n\u003cimg height=\"480em\" src=\"././public/assets/images/readme-tabelas-item-crud-2.png\"  align=\"center\"\u003e\r\n\r\n\u003cbr\u003e\r\n\r\n---\r\n\r\n\u003cdiv align=\"left\"\u003e\r\n\r\n## Instalação com bash\r\n\r\n- Clone o repositório:\r\n\r\n```\r\ngit clone https://github.com/seu-usuario/nome-do-repositorio.git\r\n```\r\n\r\n- Navegue até o diretório do projeto:\r\n\r\n```\r\ncd nome-do-repositorio\r\n```\r\n\r\n- Instale as dependências:\r\n\r\n```\r\nnpm install dotenv mongoose cli-table\r\n```\r\n\r\n- Instalando pacotes para formatação\r\n\r\n```\r\nnpm install --save-dev eslint eslint-config-prettier eslint-plugin-prettier prettier\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n- Inicie o servidor:\r\n\r\n```\r\nnpm start\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n- Vai iniciar no terminal a consulta das Tabelas.\r\n\r\n---\r\n\r\n## Demonstração Código Resumido\r\n\r\n#### - `models/usuarioModel.js`\r\n\r\n```javascript\r\nconst mongoose = require(\"mongoose\");\r\n\r\nconst usuarioSchema = new mongoose.Schema({\r\n  nome: { type: String, required: true },\r\n  email: { type: String, required: true, unique: true },\r\n  telefone: { type: String, required: true },\r\n  data_cadastro: { type: Date, default: Date.now },\r\n});\r\n\r\nconst Usuario = mongoose.model(\"Usuario\", usuarioSchema);\r\n\r\nmodule.exports = Usuario;\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n#### - `database/index.js`\r\n\r\n```javascript\r\nconst mongoose = require(\"mongoose\");\r\nrequire(\"dotenv\").config();\r\n\r\n// Função para conectar ao banco de dados\r\nconst connectToDatabase = async () =\u003e {\r\n  try {\r\n    const dbURI = process.env.MONGO_URI; // URL de conexão no ambiente\r\n    if (!dbURI) {\r\n      console.error(\"A variável de ambiente MONGO_URI não foi definida!\");\r\n      process.exit(1);\r\n    }\r\n\r\n    await mongoose.connect(dbURI);\r\n    console.log(\"Conectado ao MongoDB com sucesso!\");\r\n  } catch (err) {\r\n    console.error(\"Error connecting to MongoDB:\", err.message);\r\n    process.exit(1); // Encerra o processo com erro\r\n  }\r\n};\r\n\r\n// Exporta a função para ser usada em outros arquivos\r\nmodule.exports = connectToDatabase;\r\n```\r\n\r\n\u003cbr\u003e\r\n\r\n#### - `app.js`\r\n\r\n```javascript\r\nconst connectToDatabase = require(\"./src/database/index\");\r\nconst Usuario = require(\"./src/models/usuarioModel\");\r\nconst Table = require(\"cli-table\");\r\n\r\n// Execução das operações\r\nawait createUsuario(); // Criar\r\nawait readUsuarios(); // Ler\r\nawait updateUsuario(); // Editar\r\nawait deleteUsuario(); // Excluir\r\n\r\nconsole.log(\"\\n### CRUD Operations Completed ###\\n\");\r\nprocess.exit(0);\r\n```\r\n\r\n---\r\n\r\n## Tecnologias\r\n\r\n\u003cimg src=\"https://media.giphy.com/media/iT138SodaACo9LImgi/giphy.gif\" align=\"center\" height=\"75\" width=\"75\"\u003e Tecnologias utilizadas no projeto:\r\n\r\n- `JavaScript (JS)`\r\n  \"Linguagem de Programação do Navegador\".\r\n  \"Scripting Dinâmico para Web\".\r\n  \u003cbr\u003e\r\n\r\n- `Node.js`\r\n  \"Ambiente de Execução JavaScript do Lado do Servidor\".\r\n  \"Servidor Escalável em JavaScript\".\r\n  \u003cbr\u003e\r\n\r\n- `Documentation.md`\r\n  \"Guia detalhado para uso e manutenção do projeto.\"\r\n  \"Referência central para funcionalidades, práticas e requisitos.\"\r\n  \u003cbr\u003e\r\n\r\n- `Git`\r\n  \"Sistema de controle de versões\"\r\n  \u003cbr\u003e\r\n\r\n- `Github`\r\n  \"Plataforma para hospedagem de código-fonte\"\r\n  \u003cbr\u003e\r\n\r\n- `Visual Studio Code`\r\n  \"Editor de código-fonte\"\r\n  \u003cbr\u003e\r\n\r\n---\r\n\r\n## Licença\r\n\r\n- Esse projeto está sob a licença MIT.\r\n  \u003cbr\u003e\r\n\r\n---\r\n\r\n\u003cimg src=\"https://media.giphy.com/media/ImmvDZ2c9xPR8gDvHV/giphy.gif\" align=\"center\" height=\"25\" width=\"25\"\u003e Autor\r\n\r\n\u003cp\u003e\r\n    \u003cimg align=left margin=10 width=80 src=\"https://avatars.githubusercontent.com/u/87991807?v=4\"/\u003e\r\n    \u003cp\u003e\u0026nbsp\u0026nbsp\u0026nbspRafaelRaizer-Dev\u003cbr\u003e\r\n    \u0026nbsp\u0026nbsp\u0026nbsp\u003ca href=\"https://api.whatsapp.com/send/?phone=47999327137\"\u003eWhatsapp\u003c/a\u003e\u0026nbsp;|\u0026nbsp;\u003ca href=\"https://www.linkedin.com/in/rafael-raizer//\"\u003eLinkedIn\u003c/a\u003e\u0026nbsp;|\u0026nbsp;\u003ca href=\"https://github.com/RaizerTechDev\"\u003eGitHub\u003c/a\u003e|\u0026nbsp;\u003ca href=\"https://public.tableau.com/app/profile/rafael.raizer\"\u003eTableau\u003c/a\u003e|\u0026nbsp;\u003ca href=\"https://raizertechdev-portfolio.netlify.app/\"\u003ePortfólio\u003c/a\u003e\u0026nbsp;\u003c/p\u003e\r\n\u003c/p\u003e\r\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraizertechdev%2Ftarefasstackx-itemcrud","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fraizertechdev%2Ftarefasstackx-itemcrud","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fraizertechdev%2Ftarefasstackx-itemcrud/lists"}