Skip to content

Latest commit

 

History

History
130 lines (82 loc) · 7.37 KB

README.md

File metadata and controls

130 lines (82 loc) · 7.37 KB

Desafio Interesses iDent

Este é um desafio para a vaga de desenvolvedor Fullstack Traiine da iDent!

Como rodar este projeto ?

Simples, basta voce criar uma pasta no seu localhost chamada iDent e jogar todos os arquivos existentes no github lá pra dentro e pronto ;)

É claro, a pasta iDent deve estar contida dentro de www ou html para que possa funcionar e ser acessada por http://localhost/iDent (Caso voce estiver usando no seu servidor local).

E se mesmo assim voce resolveu jogar a pasta iDent dentro de uma outra subpasta, é muito provavel que você tenha que fazer modificações nos arquivos .htaccess (O caminho do RewriteBase) existentes dentro do projeto (Um deles esta na pasta principal, e o outro esta na pasta public).

Telas do Projeto

Screenshot Screenshot Screenshot Screenshot Screenshot Screenshot

Considerações!

Este projeto foi criado inicialmente no Windows 10, utilizando o programa WampServer 3.0.6.

Vaga Fullstack Developer Trainee

Você foi secionado para o desafio Trainee Fullstack do iDent. \o/

Este desafio serve para podermos avaliar melhor seus conhecimentos práticos no nosso stack de desenvolvimento (PHP, MySQL, jQuery, HTML Responsivo). Não há soluções certas ou erradas, ok? Esse é um espaço para você mostrar todo seu conhecimento. As melhores soluções ou com maior potencial serão selecionadas para a vaga.

Boa sorte!

Cenário

Para todos os usuários no iDent, nós pedimos no momento do cadastro que indiquem 3 ou mais interesses dentro da Odontologia. Esses interesses podem ser técnicas, especialidades, procedimentos, materiais, etc...

No momento que o usuário preenche seu interesse nós sugerimos uma lista (autocomplete) que é alimentada a partir de uma tabela de intersses oficiais (pré-cadastrados por nós), porém o usuário também pode adicionar um texto livre como interesse gerando uma tabela de sugestes de interesses.

Desta forma conseguimos fazer com que a maioria dos interesses sejam oficiais (gerendo inteligência para o negócio, como por exemplo segmentação de base por interesse ou sugestões de conteúdo), mas não tolimos o usuário de indicar interesses que estão faltando para tratarmos no futuro (sugestões).

Estrutura de dados

Para facilitar a compreensão do desafio, primeiro estude e tire suas dúvidas sobre a estrutura de dados que é utilizada para gestão de interesses no iDent:

Tabela: interest

Utilizada para armazenar a lista de interesses oficiais

ID name abbr created
Primary Key Nome do interesse oficial Abreviação do interesse oficial Quando o interesse oficial foi inserido no banco
7 Cirurgia e Traumatologia Buco-maxilo-facial CTBMF 2018-04-02 09:00:00

Tabela: interest_suggestion

Utilizada para armazenar a lista de sugestões dos usuários

ID userID name created
Primary Key ID do usuário que fez a sugestão (FK: user.ID) Nome do interesse sugerido pelo usuário Quando o interesse foi sugerido
20 109124 Trauma panfacial 2018-04-02 09:00:00

Tabela: interest_user

Utilizada para armazenar os interesses que o usuário segue. Tabela relacional com interest ou interest_suggestion dependendo da flag interestIsSuggestion

ID userID interestID interestIsSuggestion created
Primary Key ID do usuário que segue um interesse ID do interesse ou da sugestão de interesse (FK: interest.ID ou interest_suggestion.ID) Flag que indica se o interesse é sugesto ou não. Se 1 então interestID => interest_suggestion.ID se 0 então interestID => interest.ID Quando o interesse foi seguido
1 109124 7 0 2018-04-02 09:00:00
1 109124 20 1 2018-04-02 09:00:00

Desafio - Corrigir erros de digitação em massa

Temos que criar um sistema e interface para tratamento humano dessas sugestões. A ideia é que um operador possa acessar o seu sistema e ver a lista de sugestões inputadas pelos usuários. Nesta mesma tela ele poderá redigitar o interesse com um autocomplete em cima dos oficiais para remapear um interesse sugestão para oficial. Isso facilita a correção de erros de digitação.

Requisitos

Tela: Gerenciador de interesses

.* Lista sugestões dos usuários: Limite de 30 sugestões com autoload por rolagem .* Cada linha deve conter seu campo de busca para remapeamento de interesses .* Ao começar a digitar abre autocomplete com interesses oficiais para remapeamento .* O operador poderá selecionar um interesse oficial para remapear .* Interface responsiva

Ação de remapear

.* Ao remapear o sistema deve editar a linha relacional da interest_user setando o interestIsSuggestion como 0 e o interestID como o ID do interesse oficial .* Além disso deve apagar a sugestão do banco após o remapeamento .* Plus (desafio extra opcional)! Se até aqui você se deu bem e quer ir além, pode ver uma forma de remapear casos identicos automaticamente. Ex: Dois usuários sugeriram trauma panfacial e o operador remapeou um deles para trauma, desta forma ambos seriam remapeados para dar mais agilidade para o operador.

Sugestão de Wireframe

Essa sugestão é apenas para melhor compreensão do desafio. Não é necessário segui-lo, você pode usar suas noções de UX para propor soluções melhores ou ainda mais rápidas de fazer.

alt text

Regras a instruções

Regras

  1. Deadline entrega: 16/03/2018
  2. Forma de entrega: fork público deste repositório (Separar credenciais de acesso ao banco do código)
  3. Se não for possível concluir o desafio por algum motivo entregar até onde foi possível para sua solução ser considerada.
  4. Você poderá utilizar as tecnologias do nosso stack: PHP, Javascript, MySQL
  5. É permitida a utilização de frameworks CSS e Javascript
  6. Não é permitida a utilização de frameworks PHP
  7. Desenvolver a aplicação seguindo os padrões de orientação a objeto e MVC e DAO
  8. A aplicação deverá rodar sem caminhos absolutos, apenas relativos. Ou seja, funcionar em qualquer pasta de um servidor que execute PHP com permissões de acesso aos subdiretórios.
  9. Caso não consiga cumprir algumas das regras, quebre-as mas não deixe de enviar a sua solução.

Quesitos de avaliação

  1. Organização do código
  2. Design Patterns de programação (Front e Back)
  3. Gestão de índices e performance de Queries no DB
  4. Simplicidade da solução
  5. Nível de avanço e proatividade no desafio

Acesso ao banco de dados

Já tem um banco de dados criado para facilitar o setup. Sua aplicaçao poderá se conectar direto com ela. Para visualização dos dados sugiro o site http://www.phpmyadmin.co que serve um phpMyAdmin remoto.

host user pass database
isl-instance-db-dev.cnqjbbch9s0a.us-east-1.rds.amazonaws.com Enviado no convite do desafio Enviado no convite do desafio ident_[seu nome]