Skip to content

Latest commit

 

History

History
162 lines (101 loc) · 4.53 KB

README.md

File metadata and controls

162 lines (101 loc) · 4.53 KB

clone-twitter

Imagem de capa

NPM

Sobre o Projeto:

Demo do Projeto

Este projeto teve inicio como um teste para uma vaga de emprego, mas acabou se tornando um projeto experimental para aplicar novos conhecimentos e meios alternativos de se organizar.

O objetivo do projeto é ser um clone simplificado da famosa rede socil Twitter.

Como funções do projeto temos:

  • Criação de Tweet;
  • Criação de Comentário em Tweet;
  • Possibilidade de Seguir um outro Usuário;
  • Criar, Editar e Deletar sua conta de Usuário;
  • Além de um Login/Logout simples;

E como aplicação de novos conhecimentos temos:

  • Login com autententicação JWT;
  • Aplicação de API REST Full;
  • Axios para as requisições do frontend;
  • Frontend utilizando o novo framework svelte;
  • Paginação de Tweets e Comentários;

O projeto não aborda:

  • Sistema de recuperação de senha;
  • Sistema de notificação de novos Tweets/Comentários;
  • Sistema de #;
  • Sistema de curtidas;

Layout mobile

Mobile 1 Mobile 2

Layout Web

Web 1

Web 2

Modelo conceitual

MER

Modelo de Entidade e Relacionamento

Tecnologias utilizadas:

Back end

  • PHP
  • Composer

Front end

  • HTML / CSS / JS
  • Nodejs
  • Svelte

Implantação em produção

  • Back end: Heroku
  • Front end web: Netlify
  • Banco de dados: PostgreSQL

Por onde começar:

Back end

Pré-requisitos: PHP 7.4, Composer e Apache(Lampp, Xampp, Wamp).

# clonar repositório dentro do servidor apache
git clone https://github.com/EvelynGitHub/clone-twitter.git

# entrar na pasta do projeto back end
cd clone-twitter/backend

# executar o projeto
composer install

Agora, ainda dentro de backend , crie um arquivo chamado env.php . Este é o arquivo que vai conter as váriaveis de ambiente, nele você deve colocar as informações para ele acessar o banco que você criou segundo o digrama MER mostrado acima. Seu conteúdo deve ser similar a esse:

<?php
    // Essa URL pode mudar dependendo do que estiver usando
    putenv("URL=http://localhost/clone-twitter");

    putenv("DB_DRIVE=pgsql");

    putenv("DB_HOST=localhost");

    putenv("DB_PORT=5432");

    putenv("DB_NAME=nome_do_banco_criado_por_você");

    putenv("DB_USER_NAME=root");

    putenv("DB_USER_PASSWD=sua_senha_de_usuario");

Agora que já mudou o que tinha que mudar, você pode testar o backend com algum software com Insomnia ou Postman.

**OBS.:**Você pode usar um banco MYSQL para testar também, mas pode ser que alguma coisa da paginação não funcione 100%.

Front end web

Pré-requisitos: npm / yarn

O frontend é independente do backend, isso quer dizer que você pode executar apenas ele. Os dados que você vai acessar serão os da API que já está implementada. Para executar o frontend:

# clonar repositório
git clone https://github.com/EvelynGitHub/clone-twitter.git

# entrar na pasta do projeto front end web
cd clone-twitter/frontend

# instalar dependências
npm i

# executar o projeto
npm run dev

Caso queira testar junto do backend local, você deve entrar dentro de frontend/src/api/Service.js e mudar a linha baseURL para algo como:

const axiosAPI = axios.create({
    baseURL: "http://localhost/clone-twitter" 
});

Lembre-se que o valor da baseURL deve coincidir com o valor da variável de ambiente URL colocado no env.php.

Como começar a usar:

Como um Usuário não logado você pode acessar o HOME, os perfils dos cadastrados e é claro o login.

Se registre para poder ver tudo o que é possível fazer. O reste você descobre usando.

Autor(es)

Evelyn Francisco Brandão

https://www.linkedin.com/in/evelyn-brandão