Giter VIP home page Giter VIP logo

4eddit-sagan-3's Introduction

Future4 | Full-Stack Web Development Bootcamp

Desenvolvimento de aplicações completas, incluindo frontend Web com React e backend com Node.js.

Projeto: 4eddit

Site do projeto: link

Versão Web

Versão mobile

Escopo

Essa semana, vocês irão implementar uma rede social! Já fizemos vários protótipos de redes sociais, mas nenhuma delas realmente funcional. A ideia agora é fazer uma rede real, com cadastro, login, posts, likes e comentários. Para isso, iremos nos basear no reddit.com.

A rede social terá 4 páginas:

Página de login

1

A página de login possui dois campos de texto: email e senha. O comportamento será o mesmo da página de login feita semana passada. Ao fazer o login, o usuário deverá ser redirecionado para a página de feed.

A página possui também um botão "Cadastrar", que leva o usuário para a página de cadastro.

Página de cadastro

2

A página de cadastro possui 3 campos: nome de usuário, email e senha. O endpoint de cadastro retornará as mesmas informações do endpoint de login. Portanto, após cadastrar, o usuário deverá ser redirecionado para a página de feed, já estando logado (ou seja, com o token salvo no LocalStorage).

Página de feed (lista de posts)

3

A página de feed deverá mostrar todos os posts, além de um formulário para a criação de post. O formulário possui apenas o campo de texto. Cada post mostrará o nome de usuário que postou, o texto do post, o número de votos (positivo ou negativo) e o número de comentários. Caso o usuário tenha votado positiva ou negativamente, isso deverá estar indicado. Todas essa informações serão fornecidas pela API.

Quando o usuário clicar em um post, ele deverá ser redirecionado para a página do respectivo post.

Quando um usuário clicar em votar (positiva ou negativamente), uma requisição deverá ser feita indicando a "direção" do voto. Um voto positivo é indicado com o número 1. Um voto negativo é indicado com o número -1. Para remover um voto, a direção deve ser 0.

Essa página só pode ser acessada por um usuário logado. Caso o usuário não esteja logado, deverá ser redirecionado para a página de login.

Página de post

4

A página de um post mostrará o mesmo card de post da página de feed, com o usuário, texto, curtidas e número de comentários. Abaixo, terá um formulário para criação de comentários e os cards de comentários. A estrutura é muito similar à do post, mas comentários não possuem outros comentários dentro deles. A lógica de votos é a mesma do post.

Essa página só pode ser acessada por um usuário logado. Caso o usuário não esteja logado, deverá ser redirecionado para a página de login.

4eddit-sagan-3's People

Contributors

eloisafagundes avatar rosanarezende avatar soter19 avatar

Watchers

 avatar  avatar  avatar

4eddit-sagan-3's Issues

Integração com API Login

Definição de feito: possibilidade de logar usuário integrado na LoginPage.

  • Login integrada na LoginPage

Deployar a aplicação

Definição de feito: aplicação funcionando após deploy no surge com todas as funcionalidades.

  • Deploy no surge.

  • Teste da aplicação.

  • Funcionando.

Criar rotas e containers

Definição de feito: rotas criadas, lincadas com os respectivos containers, testadas através da URL.

  • / (LoginPage)

  • /register (RegisterPage)

  • /posts/feed (FeedPage)

  • /posts/detail (DetailPage)

LoginPage - estilização

Definição de feito: LoginPage com layout estático usando Material-UI e com botões de rota apontando para as páginas corretas

  • layout estático com Material-UI

  • botões de rotas funcionando

Untitled (3)

DetailPage - estilização

Definição de feito: DetailPage com layout estático usando Material-UI e com botões de rota apontando para as páginas corretas

  • layout estático com Material-UI

  • botões de rotas funcionando

Untitled

RegisterPage - estilização

Definição de feito: RegisterPage com layout estático usando Material-UI e com botões de rota apontando para as páginas corretas

  • layout estático com Material-UI

  • botões de rotas funcionando

Untitled (1)

Validar formulários

Definição de feito: Todos os campos dos formulários devem ser validados, usando ou não Regex, antes de serem submetidos

  • Regex funcionando

  • Outras validações aplicadas e funcionando, caso não seja possível utiliza Regex

Integração com API Vote

Definição de feito: possibilidade de votar em um post integrado na FeedPage e DetailPage.

  • Vote integrada na FeedPage.

  • Vote integrada na DetailPage.

Componentizar

Descrição de feito: todas as páginas refatoradas, separando o que for possível componentizar.

Desafio 4

Definição de feito: conseguir buscar post no feed por nome e texto.

  • - Implementar busca por NOME do post no feed.

  • - Implementar busca por TEXTO do post no feed.

Tema do Material-UI

Definição de feito: tema do material-UI criado e devidamente implementado no projeto.

  • criar tema

  • adicionar ao projeto

FeedPage - estilização

Definição de feito: FeedPage com layout estático usando Material-UI e com botões de rota apontando para as páginas corretas

  • layout estático com Material-UI

  • botões de rotas funcionando

Untitled (2)

Inicializar projeto

Definição de feito: projeto clonado com bibliotecas instaladas e todos terem acesso no Github

Appbar - estilização inicial

Definição de feito: Appbar criada, com logo, conectada com todas as páginas, e já recebendo props para renderizar o que for necessário em cada página.

  • criar Appbar

  • Adicionar em cada página

  • Receber props

  • Implementar switch case (mesmo que com mockups)

Desafio 5

Definição de feito: todas as páginas que esperam dados da API tem loading implementado.

Implementar loading em todas as páginas que esperam dados da API

  • Lista de posts

  • Detalhe de post

Desafio 1

Definição de feito: todas as páginas responsivas (usando media queries - comparar a como o Reddit de verdade se comporta), com deploy no surge testado em celulares.

  • Garantir responsividade em todas as páginas

  • Fazer deploy no surge

  • Usar os celulares de verdade para testar as páginas.

  • Comparar com o Reddit - os botões se comportam igual

Desafio 3

Definição de feito: funcionalidade de compartilhamento permite mandar o post para outra rede social.

  • Implementar funcionalidade de "Compartilhar", que permite mandar o post para outra rede social.

Desafio 2

Definição de feito: funcionalidade de Logout funcionando.

  • Implementar funcionalidade de Logout.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.