Skip to content

GitLab

  • Menu
Projects Groups Snippets
    • Loading...
  • Help
    • Help
    • Support
    • Community forum
    • Submit feedback
    • Contribute to GitLab
  • Sign in
  • Point-Tills-Wiki Point-Tills-Wiki
  • Project information
    • Project information
    • Activity
    • Labels
    • Planning hierarchy
    • Members
  • Repository
    • Repository
    • Files
    • Commits
    • Branches
    • Tags
    • Contributors
    • Graph
    • Compare
  • Issues 0
    • Issues 0
    • List
    • Boards
    • Service Desk
    • Milestones
  • Merge requests 0
    • Merge requests 0
  • CI/CD
    • CI/CD
    • Pipelines
    • Jobs
    • Schedules
  • Deployments
    • Deployments
    • Environments
    • Releases
  • Monitor
    • Monitor
    • Incidents
  • Packages & Registries
    • Packages & Registries
    • Package Registry
    • Infrastructure Registry
  • Analytics
    • Analytics
    • Value stream
    • CI/CD
    • Repository
  • Wiki
    • Wiki
  • Snippets
    • Snippets
  • Activity
  • Graph
  • Create a new issue
  • Jobs
  • Commits
  • Issue Boards
Collapse sidebar
  • Point Tils um aplicativo para interpretes de Lingua Brasileira de Sinais
  • Point-Tills-WikiPoint-Tills-Wiki
  • Wiki
  • arquitetura

arquitetura · Changes

Page history
Update arquitetura authored Aug 24, 2025 by Augusto Baldino's avatar Augusto Baldino
Show whitespace changes
Inline Side-by-side
arquitetura.md
View page @ 136aae85
......@@ -66,4 +66,90 @@ https://backend-v5gs.onrender.com/swagger-ui/index.html
```
### Frontend
TODO
\ No newline at end of file
Aplicativo móvel em React Native + Expo com theming (light/dark), roteamento por arquivos (expo-router) e estilização com NativeWind/Tailwind.
- Plataforma: Android
- Linguagem: TypeScript
- Navegação: React Navigation + Expo Router
- UI: NativeWind + Gluestack UI overlay/toast + Lucid icons
### Requisitos
- Node.js LTS ≥ 22.17.0
- npm ≥ 10
- dispositivo Android/iOS
- Conta no Expo: https://expo.dev
> Observação: A CI usa Node 20, mas o desenvolvimento local recomenda Node 22 LTS.
## Primeiros passos
1. Instalar dependencias
```bash
npm install
```
2. Instalar EAS CLI
```bash
npm install --global eas-cli
```
3. Autenticar no Expo/EAS
```bash
eas login
eas whoami
```
4. Iniciar o app (modo desenvolvimento)
```bash
npm run start
```
- Pressione “a” para Android (emulador) ou escanei o QR Code no Expo Go.
## Scripts úteis
- Lint: `npm run lint`
- Formatação (checar): `npm run format:check`
- Formatação (corrigir): `npm run format:write`
- Verificação de dependencias: `depcheck`
- Diagnóstico: `npx expo-doctor`
- Type-check: `npx tsc --noEmit`
## Estrutura de Pastas
![image](uploads/4fa932853f0fcf80a3cbb844ec30013e/image.png)
## UI e Theming
- Tema global via [contexts/ThemeProvider.tsx](src/contexts/ThemeProvider.tsx) que integra:
- React Navigation ThemeProvider
- GluestackUIProvider (NativeWind vars)
- Cores centralizadas em [constants/Colors.ts](src/constants/Colors.ts)
- Tailwind estendido com variáveis (CSS vars) em
- [components/ui/gluestack-ui-provider/config.ts](src/components/ui/gluestack-ui-provider/config.ts)
- [tailwind.config.js](tailwind.config.js)
## Navegação
O roteamento é baseado em arquivos (expo-router), mais informações sobre o funcionamento em https://docs.expo.dev/router/basics/core-concepts/#4-root-_layouttsx-replaces-appjsxtsx
## Padrões de código
- TypeScript strict ([tsconfig.json](tsconfig.json))
- ESLint + Prettier ([eslint.config.js](eslint.config.js), [.prettierrc](.prettierrc))
- Strings com aspas simples
- Componentes funcionais e hooks idiomáticos
- Evitar estilos inline (usar Tailwind/NativeWind)
## CI/CD
- PR Checks: lint, type-check, prebuild Android/iOS, depcheck, audit, expo-doctor
- Workflow: [.github/workflows/pr_checks.yml](.github/workflows/pr_checks.yml)
- Nightly Build Android com EAS:
- Workflow: [.github/workflows/nightly_build.yml](.github/workflows/nightly_build.yml)
- Publica release no GitHub e anexa APK quando disponível
Clone repository

Logo-Dark_Blue

Point Tils


Home

Arquitetura

Backend

Banco de Dados

Configuração

Design/Mockups

Escopo

Frontend

Gerência

Processo

Qualidade


Sprint 0

Sprint 1

Sprint 2

Sprint 3

Sprint 4