115d8c05a73efdc18699db8286d0a25f788ed751
- Ajout de Java 21 dans Dockerfile pour compatibilité Capacitor - Création de fichiers de types séparés (lib/types/) pour éviter dépendances API routes - Configuration next.config.export.js pour export statique - Exclusion temporaire des routes API pendant le build - Correction configuration Gradle (Java 17/21) - Script build-apk.sh amélioré avec gestion des routes API - APK généré avec succès (4.5MB) dans dist/compagnon-admin-debug.apk Fichiers de types créés: - lib/types/place.ts - lib/types/infos.ts - lib/types/tides.ts - lib/types/excursions.ts - lib/types/sun-times.ts - lib/types/notifications.ts Tous les imports mis à jour pour utiliser les nouveaux fichiers de types.
Compagnon du lagon - Pension Marama
Application web PWA (Progressive Web App) destinée aux clients d'une pension de famille en Polynésie. Cette application remplace le livret d'accueil papier et offre une expérience numérique optimisée pour les connexions internet faibles.
Technologies
- Framework: Next.js 14 (App Router)
- Langage: TypeScript
- Styling: Tailwind CSS
- Icons: Lucide-React
- Components: Shadcn/UI
Fonctionnalités
Onglet Accueil
- Header personnalisé avec numéro de bungalow
- Card WiFi avec copie du mot de passe
- Widget météo (placeholder)
- Section "Le mot du gérant"
Onglet Explorer
- Liste de catégories (Plages, Restaurants/Roulottes, Epiceries, Activités)
- Liste de lieux recommandés par catégorie
- Intégration Google Maps pour chaque lieu
Onglet Infos Pratiques
- FAQ en accordéon (Check-out, Petit-déjeuner, Climatisation, Numéros d'urgence)
- Lexique tahitien (5 mots essentiels)
Installation
Développement local
# Installer les dépendances
npm install
# Copier le fichier d'environnement
cp env.example .env.local
# Modifier les variables dans .env.local selon vos besoins
# Lancer le serveur de développement
npm run dev
L'application sera accessible sur :
- Local : http://localhost:3000
- Réseau local : http://VOTRE_IP:3000 (voir ci-dessous)
Tester sur un appareil mobile
Le serveur est configuré pour être accessible depuis votre réseau local.
-
Trouver votre adresse IP locale :
hostname -IOu regardez dans les paramètres réseau de votre système.
-
Sur votre mobile (connecté au même Wi-Fi) :
- Ouvrez le navigateur (Chrome, Safari, etc.)
- Allez à :
http://VOTRE_IP:3000 - Exemple :
http://192.168.1.100:3000
-
Tester la PWA :
- Dans Chrome mobile : Menu (⋮) → "Ajouter à l'écran d'accueil"
- Dans Safari iOS : Partager → "Sur l'écran d'accueil"
- L'app s'ouvrira comme une application native
-
Mode développeur du navigateur (alternative) :
- Sur PC :
F12→ Toggle device toolbar (Ctrl+Shift+M) - Permet de simuler différents appareils mobiles
- Sur PC :
Docker
Build et run
# Build de l'image
docker-compose build
# Lancer le conteneur
docker-compose up -d
# Voir les logs
docker-compose logs -f
# Arrêter le conteneur
docker-compose down
Variables d'environnement Docker
Créez un fichier .env à la racine du projet avec vos variables :
NEXT_PUBLIC_BUNGALOW_NUMBER=1
NEXT_PUBLIC_WIFI_NAME=Lagon-WiFi
NEXT_PUBLIC_WIFI_PASSWORD=motdepasse123
NEXT_PUBLIC_GERANT_MESSAGE=Bienvenue dans notre pension de famille !
Configuration
Variables d'environnement
NEXT_PUBLIC_BUNGALOW_NUMBER: Numéro du bungalow (dynamique selon le client)NEXT_PUBLIC_WIFI_NAME: Nom du réseau WiFiNEXT_PUBLIC_WIFI_PASSWORD: Mot de passe WiFiNEXT_PUBLIC_GERANT_MESSAGE: Message personnalisé du gérant
Structure du projet
├── app/
│ ├── accueil/ # Page d'accueil
│ ├── explorer/ # Page explorer
│ ├── infos/ # Page infos pratiques
│ ├── api/ # Routes API
│ └── layout.tsx # Layout principal
├── components/
│ ├── accueil/ # Composants page accueil
│ ├── explorer/ # Composants page explorer
│ ├── infos/ # Composants page infos
│ ├── layout/ # Composants layout
│ └── ui/ # Composants Shadcn/UI
├── lib/ # Utilitaires et configuration
└── public/ # Assets statiques et PWA
PWA
L'application est configurée comme PWA avec :
- Manifest.json pour l'installation
- Service Worker pour le cache offline
- Optimisations pour connexions faibles
Design System
- Couleur primaire: #0E7490 (Bleu lagon)
- Couleur secondaire: #ECFCCB (Vert citron pâle)
- Background: #FAFAFA (Blanc cassé)
- Typographie: Inter, minimum 16px
- Bordures: Très arrondies (rounded-xl, rounded-2xl)
Production
# Build de production
npm run build
# Lancer en production
npm start
Licence
Propriétaire - Tous droits réservés
Description
Languages
TypeScript
79.6%
Shell
15.1%
JavaScript
3.6%
Java
0.9%
Dockerfile
0.6%
Other
0.2%