Front-end do aplicativo My Health, desenvolvido na disciplina Engenharia de Software II, no período 2022.2, sob a orientação da professora Adicineia.
- Clique em "Fork" para criar um fork do repositório.
- Clone o fork do projeto em sua máquina.
- Crie uma nova branch cujo nome descreva as modificações que fará, exemplo:
git checkout -b refatorar-componente-tal
- Faça suas alterações e commite-as no repositório local.
- Pushe as alterações para o repositório remoto —
git push origin HEAD
- Abra um pull request do seu fork para este repositório.
Digamos que novos commits foram adicionados à branch master
do repositório principal, tal que seu repositório local ficou desatualizado. Para atualizá-lo, siga estes passos:
Caso ainda não tenha o feito, adicione o repositório principal (não o seu fork) à lista de origens, com o nome upstream
:
git remote add upstream https://github.com/ajsaraujo/my-health-app
Depois, puxe as mudanças do repositório upstream usando o comando fetch:
git fetch upstream
Finalmente, mude para a branch master e mescle-a à master que você acabou de baixar do upstream.
git checkout master
git merge upstream/master
Pronto, agora sua branch master está atualizada em relação à do repositório principal.
Para mais informações, referencie esta thread: How do I update or sync a forked repository on GitHub?
Você precisará ter o Node.js instalado.
- Instale as dependências com
npm i
. - Execute o projeto no seu navegador com
npm run web
.
Para adicionar novas páginas/rotas ao app, você deve seguir estes passos:
Primeiro, adicione a rota em RouteParams
, especificando o tipo de input que ela recebe. Caso não seja necessário input, use o tipo NO_PARAMS
.
export type RouteParams = {
// Rotas existentes...
+ MinhaNovaRota: TipoInput
}
Agora, na definição do seu componente, você deve tipar as props de acordo com o nome da rota que você colocou em RouteParams
:
type ComponentProps = NativeStackScreenProps<RouteParams, 'MinhaNovaRota'>
export default function MeuNovoComponent(props: ComponentProps) {}
Finalmente, adicione a tela em App.tsx
:
{*/ Telas do seu módulos */}
+ <Stack.Screen name="Nova tela" component={MeuNovoComponent}></Stack.Screen>
A seguir, algumas recomendações de estilo, a fim de manter a integridade conceitual do projeto.
Procure escrever as mensagens de commit iniciando com letra maiúscula e com um verbo no infinitivo.
Ou seja, algo como:
- "Criar tela de..."
- "Refatorar..."
- "Adicionar..."
- "Corrigir bug no..."
E não algo como:
- "corrigir..." -> começa com letra minúscula
- "fix: alguma coisa..." -> não usaremos conventional commits!
Se quiser fazer um commit intermediário ou não souber o que escrever na mensagem de commit, use a mensagem "WIP" (work in progress). Use com parcimônia.
Quando abrir um Merge Request, se ele tiver muitos commits ou o histórico estiver desorganizado, marque a opção "Squash commits" para condensar todos os commits num só após a mesclagem. Isso facilita a leitura do histórico.
Procure nomear os símbolos (variáveis, constantes, funções, classes) em inglês. Quanto ao casing:
- Use
PascalCamelCase
para classes, tipos, enumerações e componentes React Native. - Use
camelCase
para variáveis, constantes e funções.
Procure também nomear os arquivos com o mesmo nome do que está sendo exportado por eles.
Os módulos do My Health estão abaixo de modules/
. Código genérico que possa ser utilizado em mais de um módulo fica em shared/
.
As pastas de modules/
têm a seguinte estrutura:
components/
: componentes que compõem as páginas. Cards, botões, tabelas, campos de entrada, etc.models/
: classes e tipos que modelam os dados do domínio.pages/
: subpáginas do módulo.services/
: código com lógica complexa, que faz gerenciamento de estado ou se comunica com serviços externos.utils/
: funções utilitárias com escopo limitado. Funções de formatação de texto, por exemplo.
shared/
tem uma estrutura similar. Até então, a única diferença é que ele tem uma pasta ui/
que agrega components/
e estilos/cores globais.
Arquivos de teste devem ser criados imediatamente vizinhos ao arquivo que testam, e com o sufixo spec
. Por exemplo, se você vai testar o código de um arquivo chamado sum.ts
, o teste deve ser sum.spec.ts
.
Procure utilizar múltiplos de 8 para definir margens e recuos (padding). Isso faz com que a UI pareça mais consistente. Caso precise de uma granularidade maior, use múltiplos de 4.
Evite usar strings literais para estilizar cores - prefira definí-las no arquivo colors.ts
, tal que elas possam ser mais facilmente reutilizadas ao longo do projeto.