Activities, Trails, Wanderer + Strava Integration, UI Refresh, Devops Improvments, and more (#785)

* Implement code changes to enhance functionality and improve performance

* Update nl.json

Fix Dutch translations.

* feat(security): add Trivy security scans for Docker images and source code

* feat(security): restructure Trivy scans for improved clarity and organization

* fix(dependencies): update Django version to 5.2.2

* style(workflows): standardize quotes and fix typo in frontend-test.yml

* feat(workflows): add job names for clarity in backend and frontend test workflows

* refactor(workflows): remove path filters from pull_request and push triggers in backend and frontend workflows

* feat(workflows): add paths to push and pull_request triggers for backend and frontend workflows

* refactor(workflows): simplify trigger paths for backend and frontend workflows
fix(dependencies): add overrides for esbuild in frontend package.json

* fix(package): add missing pnpm overrides for esbuild in package.json

* fix(workflows): add missing severity parameter for Trivy filesystem scan

* fix(workflows): add missing severity parameter for Docker image scans in Trivy workflow

* fix(workflows): remove MEDIUM severity from Trivy scans in security workflow

* added-fix-image-deletion (#681)

* added-fix-image-deletion

* feat(commands): add image cleanup command to find and delete unused files

* fix(models): ensure associated AdventureImages are deleted and files cleaned up on Adventure deletion

* fix(models): ensure associated Attachment files are deleted and their filesystem cleaned up on Adventure deletion

---------

Co-authored-by: ferdousahmed <taninme@gmail.com>
Co-authored-by: Sean Morley

* Rename Adventures to Locations (#696)

* Refactor user_id to user in adventures and related models, views, and components

- Updated all instances of user_id to user in the adventures app, including models, serializers, views, and frontend components.
- Adjusted queries and filters to reflect the new user field naming convention.
- Ensured consistency across the codebase for user identification in adventures, collections, notes, and transportation entities.
- Modified frontend components to align with the updated data structure, ensuring proper access control and rendering based on user ownership.

* Refactor adventure-related views and components to use "Location" terminology

- Updated GlobalSearchView to replace AdventureSerializer with LocationSerializer.
- Modified IcsCalendarGeneratorViewSet to use LocationSerializer instead of AdventureSerializer.
- Created new LocationImageViewSet for managing location images, including primary image toggling and image deletion.
- Introduced LocationViewSet for managing locations with enhanced filtering, sorting, and sharing capabilities.
- Updated ReverseGeocodeViewSet to utilize LocationSerializer.
- Added ActivityTypesView to retrieve distinct activity types from locations.
- Refactored user views to replace AdventureSerializer with LocationSerializer.
- Updated frontend components to reflect changes from "adventure" to "location", including AdventureCard, AdventureLink, AdventureModal, and others.
- Adjusted API endpoints in frontend routes to align with new location-based structure.
- Ensured all references to adventures are replaced with locations across the codebase.

* refactor: rename adventures to locations across the application

- Updated localization files to replace adventure-related terms with location-related terms.
- Refactored TypeScript types and variables from Adventure to Location in various routes and components.
- Adjusted UI elements and labels to reflect the change from adventures to locations.
- Ensured all references to adventures in the codebase are consistent with the new location terminology.

* Refactor code structure for improved readability and maintainability

* feat: Implement location details page with server-side loading and deletion functionality

- Added +page.server.ts to handle server-side loading of additional location info.
- Created +page.svelte for displaying location details, including images, visits, and maps.
- Integrated GPX file handling and rendering on the map.
- Updated map route to link to locations instead of adventures.
- Refactored profile and search routes to use LocationCard instead of AdventureCard.

* docs: Update terminology from "Adventure" to "Location" and enhance project overview

* docs: Clarify collection examples in usage documentation

* feat: Enable credentials for GPX file fetch and add CORS_ALLOW_CREDENTIALS setting

* Refactor adventure references to locations across the backend and frontend

- Updated CategoryViewSet to reflect location context instead of adventures.
- Modified ChecklistViewSet to include locations in retrieval logic.
- Changed GlobalSearchView to search for locations instead of adventures.
- Adjusted IcsCalendarGeneratorViewSet to handle locations instead of adventures.
- Refactored LocationImageViewSet to remove unused import.
- Updated LocationViewSet to clarify public access for locations.
- Changed LodgingViewSet to reference locations instead of adventures.
- Modified NoteViewSet to prevent listing all locations.
- Updated RecommendationsViewSet to handle locations in parsing and response.
- Adjusted ReverseGeocodeViewSet to search through user locations.
- Updated StatsViewSet to count locations instead of adventures.
- Changed TagsView to reflect activity types for locations.
- Updated TransportationViewSet to reference locations instead of adventures.
- Added new translations for search results related to locations in multiple languages.
- Updated dashboard and profile pages to reflect location counts instead of adventure counts.
- Adjusted search routes to handle locations instead of adventures.

* Update banner image

* style: Update stats component background and border for improved visibility

* refactor: Rename AdventureCard and AdventureModal to LocationCard and LocationModal for consistency

* Import and Export Functionality (#698)

* feat(backup): add BackupViewSet for data export and import functionality

* Fixed frontend returning corrupt binary data

* feat(import): enhance import functionality with confirmation check and improved city/region/country handling

* Potential fix for code scanning alert no. 29: Information exposure through an exception

Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>

* Refactor response handling to use arrayBuffer instead of bytes

* Refactor image cleanup command to use LocationImage model and update import/export view to include backup and restore functionality

* Update backup export versioning and improve data restore warning message

* Enhance image navigation and localization support in modal components

* Refactor location handling in Immich integration components for consistency

* Enhance backup and restore functionality with improved localization and error handling

* Improve accessibility by adding 'for' attribute to backup file input label

---------

Co-authored-by: Christian Zäske <blitzdose@gmail.com>
Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>

* refactor(serializers): rename Location to Adventure and update related fields

* refactor(serializers): rename Adventure to Location and update related fields

* chore(requirements): update pillow version to 11.3.0

* Add PT-BR translations (#739)

* Fixed frontend returning corrupt binary data

* fix(adventure): enhance collection ownership validation in AdventureSerializer (#723)

* Add PT-BR translations

Add translation for Brazilian Portuguese to the project;

Signed-off-by: Lucas Zampieri <lzampier@redhat.com>

---------

Signed-off-by: Lucas Zampieri <lzampier@redhat.com>
Co-authored-by: Sean Morley <98704938+seanmorley15@users.noreply.github.com>
Co-authored-by: Christian Zäske <blitzdose@gmail.com>

* fix: update date formatting for adventure items to include timezone

* Image/attachment overhaul, activities, trails and integrations with Strava and Wanderer (#726)

* refactor(models, views, serializers): rename LocationImage and Attachment to ContentImage and ContentAttachment, update related references

* feat: Enhance collection sharing and location management features

- Implemented unsharing functionality in CollectionViewSet, including removal of user-owned locations from collections.
- Refactored ContentImageViewSet to support multiple content types and improved permission checks for image uploads.
- Added user ownership checks in LocationViewSet for delete operations.
- Enhanced collection management in the frontend to display both owned and shared collections separately.
- Updated Immich integration to handle access control based on location visibility and user permissions.
- Improved UI components to show creator information and manage collection links more effectively.
- Added loading states and error handling in collection fetching logic.

* feat: enhance transportation card and modal with image handling

- Added CardCarousel component to TransportationCard for image display.
- Implemented privacy indicator with Eye and EyeOff icons.
- Introduced image upload functionality in TransportationModal, allowing users to upload multiple images.
- Added image management features: remove image and set primary image.
- Updated Transportation and Location types to include images as ContentImage array.
- Enhanced UI for image upload and display in modal, including selected images preview and current images management.

* feat: update CardCarousel component to handle images, name, and icon props across various cards

* feat: add Discord link to AboutModal and update appVersion in config

* feat: add LocationQuickStart and LocationVisits components for enhanced location selection and visit management

- Implemented LocationQuickStart.svelte for searching and selecting locations on a map with reverse geocoding.
- Created LocationVisits.svelte to manage visit dates and notes for locations, including timezone handling and validation.
- Updated types to remove location property from Attachment type.
- Modified locations page to integrate NewLocationModal for creating and editing locations, syncing updates with adventures.

* feat: update button styles and add back and close functionality in location components

* Collection invite system

* feat: update CollectionSerializer to include 'shared_with' as a read-only field; update app version; add new background images and localization strings for invites

* feat: add Strava integration with OAuth flow and activity management

- Implemented IntegrationView for listing integrations including Immich, Google Maps, and Strava.
- Created StravaIntegrationView for handling OAuth authorization and token exchange.
- Added functionality to refresh Strava access tokens when needed.
- Implemented endpoints to fetch user activities from Strava and extract essential information.
- Added Strava logo asset and integrated it into the frontend settings page.
- Updated settings page to display Strava integration status.
- Enhanced location management to include trails with create, edit, and delete functionalities.
- Updated types and localization files to support new features.

* feat: enhance Strava integration with user-specific settings and management options; update localization strings

* feat: update Strava integration settings and add Wanderer logo; enhance user experience with active section management

* Add StravaActivity and Activity types to types.ts

- Introduced StravaActivity type to represent detailed activity data from Strava.
- Added Activity type to encapsulate user activities, including optional trail and GPX file information.
- Updated Location type to include an array of activities associated with each visit.

* feat: streamline location and activity management; enhance Strava import functionality and add activity handling in server actions

* feat: add ActivityCard component and update LocationVisits to use it; modify Activity type to reference trail as string

* feat: add geojson support to ActivitySerializer and ActivityCard; enhance location page with activity summaries and GPS tracks

* feat: add trails property to recommendation object in collection page

* feat: add Wanderer integration with authentication and management features

* feat: implement Wanderer integration with trail management and UI components; enhance settings for reauthentication

* feat: add measurement system field to CustomUser model and update related serializers, migrations, and UI components

* feat: add measurement system support across ActivityCard, StravaActivityCard, NewLocationModal, LocationVisits, and related utility functions

* feat: enhance Wanderer integration with trail data fetching and UI updates; add measurement system support

* feat: add TrailCard component for displaying trail details with measurement system support

* feat: add wanderer link support in TrailSerializer and TrailCard; update measurement system handling in location page

* feat: integrate memcached for caching in Wanderer services; update Docker, settings, and supervisord configurations

* feat: add activity statistics to user profile; include distance, moving time, elevation, and total activities

* feat: enhance import/export functionality to include trails and activities; update UI components and localization

* feat: integrate NewLocationModal across various components; update location handling and state management

* Refactor Location and Visit types: Replace visits structure in Location with Visit type and add location, created_at, and updated_at fields to Visit

* feat: enhance permissions and validation in activity, trail, and visit views; add unique constraint to CollectionInvite model

* feat: sync visits when updating adventures in collection page

* feat: add geojson support for attachments and refactor GPX handling in location page

* chore: remove unused dependencies from pnpm-lock.yaml

* feat: add Strava and Wanderer integration documentation and configuration options

* Add support for Japanese and Arabic languages in localization

* Add new localization strings for Russian, Swedish, and Chinese languages

- Updated translations in ru.json, sv.json, and zh.json to include new phrases related to collections, activities, and integrations.
- Added strings for leaving collections, loading collections, and quick start instructions.
- Included new sections for invites and Strava integration with relevant messages.
- Enhanced Google Maps integration descriptions for clarity.

* Add localization support for activity-related features and update UI labels

- Added new Russian, Swedish, and Chinese translations for activity statistics, achievements, and related terms.
- Updated UI components to use localized strings for activity statistics, distance, moving time, and other relevant fields.
- Enhanced user experience by ensuring all relevant buttons and labels are translated and accessible.

* fix: update appVersion to reflect the latest development version

* feat: add getActivityColor function and integrate activity color coding in map and location pages

* feat: add support for showing activities and visited cities on the map

* feat: update map page to display counts for visited cities and activities

* fix: remove debug print statement from IsOwnerOrSharedWithFullAccess permission class

* feat: add MapStyleSelector component and integrate basemap selection in map page

* feat: enhance basemap functions with 3D terrain support and update XYZ style handling

* feat: add management command to recalculate elevation data from GPX files and update activity view to handle elevation data extraction

* feat: update MapStyleSelector component and enhance basemap options for improved user experience

* feat: refactor activity model and admin to use sport_type, update serializers and components for improved activity handling

* feat: update Activity model string representation to use sport_type instead of type

* feat: update activity handling to use sport_type for color determination in map and location components

* feat: Add attachments support to Transportation and Lodging types

- Updated Transportation and Lodging types to include attachments array.
- Enhanced localization files for multiple languages to include new strings related to attachments, lodging, and transportation.
- Added error and success messages for attachment removal and upload information.
- Included new prompts for creating and updating lodging and transportation details across various languages.

* feat: Enhance activity statistics and breakdown by category in user profile

* feat: Add SPORT_CATEGORIES for better organization of sports types and update StatsViewSet to use it

* feat: Enhance CategoryDropdown for mobile responsiveness and add category creation functionality

* feat: Update inspirational quote in adventure log

* feat: Localize navigation labels in Navbar and add translation to en.json

* feat: Update navigation elements to use anchor tags for better accessibility and add new fields to signup form

* Translate login button text to support internationalization

* feat: Refactor location visit status logic and add utility function for visited locations count

* chore: Upgrade GitHub Actions and remove unused timezone import

* fix: Update Docker image tags in GitHub Actions workflow for consistency

* fix: Update Docker image build process to use BuildKit cache for improved performance

* chore: Remove unused imports from stats_view.py for cleaner code

* Increase background image opacity on login and signup pages for improved visibility

* fix: Add postgresql-client to runtime dependencies in Dockerfile

* fix: Update workflow files to include permissions for GitHub Actions

* fix: Update esbuild version to ^0.25.9 in package.json and pnpm-lock.yaml for compatibility

* chore: improve Chinese translation (#796)

* fix: update adventure log quote and remove unused activity type field

* fix: optimize import process by using get_or_create for visited cities and regions

* fix: update README to reflect changes from adventures to locations and enhance feature descriptions

* fix: update documentation to reflect changes from adventures to locations and enhance feature descriptions

* Update google_maps_integration.md (#743)

* Update google_maps_integration.md

Explain APIs needed for AdventureLogs versions.

Fixes #731 and #727

* Fix a typo google_maps_integration.md

---------

Co-authored-by: Sean Morley <98704938+seanmorley15@users.noreply.github.com>

* fix: update appVersion to reflect the main branch version

* fix: update image source for satellite map in documentation

* Update frontend/src/lib/components/NewLocationModal.svelte

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* Add localization updates for multiple languages

- Japanese (ja.json): Added new activity-related phrases and checklist terms.
- Korean (ko.json): Included activity breakdown and checklist enhancements.
- Dutch (nl.json): Updated activity descriptions and added checklist functionalities.
- Norwegian (no.json): Enhanced activity and checklist terminology.
- Polish (pl.json): Added new phrases for activities and checklist management.
- Brazilian Portuguese (pt-br.json): Updated activity-related terms and checklist features.
- Russian (ru.json): Included new phrases for activities and checklist management.
- Swedish (sv.json): Enhanced activity descriptions and checklist functionalities.
- Chinese (zh.json): Added new activity-related phrases and checklist terms.

* fix: enhance image upload handling to support immich_id

* Add "not_enabled" message for Strava integration in multiple languages

- Updated Spanish, French, Italian, Japanese, Korean, Dutch, Norwegian, Polish, Brazilian Portuguese, Russian, Swedish, and Chinese locale files to include a new message indicating that Strava integration is not enabled in the current instance.

---------

Signed-off-by: Lucas Zampieri <lzampier@redhat.com>
Co-authored-by: Ycer0n <37674033+Ycer0n@users.noreply.github.com>
Co-authored-by: taninme <5262715+taninme@users.noreply.github.com>
Co-authored-by: ferdousahmed <taninme@gmail.com>
Co-authored-by: Christian Zäske <blitzdose@gmail.com>
Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com>
Co-authored-by: Lucas Zampieri <lcasmz54@gmail.com>
Co-authored-by: pplulee <pplulee@live.cn>
Co-authored-by: Cathelijne Hornstra <github@hornstra.com>
Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This commit is contained in:
Sean Morley
2025-08-19 08:50:45 -04:00
committed by GitHub
parent 4e96e529f4
commit a3f0eda63f
220 changed files with 27763 additions and 6653 deletions

View File

@@ -9,23 +9,25 @@
"oss_attributions": "Attributions Open Source",
"other_attributions": "Des attributions supplémentaires peuvent être trouvées dans le fichier README.",
"source_code": "Code source",
"generic_attributions": "Connectez-vous à AdventureLog pour afficher les attributions pour les intégrations et services activés."
"generic_attributions": "Connectez-vous à AdventureLog pour afficher les attributions pour les intégrations et services activés.",
"attributions": "Attributions",
"developer": "Promoteur",
"license_info": "Licence",
"sponsor": "Parrainer",
"thank_you": "Merci d'utiliser AdventureLog!",
"version": "Version",
"view_changelog": "Voir Changelog",
"view_license": "Afficher la licence"
},
"adventures": {
"activities": {},
"add_to_collection": "Ajouter à la collection",
"adventure_delete_confirm": "Êtes-vous sûr de vouloir supprimer cette aventure ? \nCette action ne peut pas être annulée.",
"collection_link_error": "Erreur lors de la liaison de l'aventure à la collection",
"collection_link_success": "Aventure liée à la collection avec succès !",
"collection_remove_error": "Erreur lors de la suppression de l'aventure de la collection",
"collection_remove_success": "Aventure supprimée de la collection avec succès !",
"delete": "Supprimer",
"edit_adventure": "Modifier l'aventure",
"no_image_found": "Aucune image trouvée",
"open_details": "Ouvrir les détails",
"remove_from_collection": "Supprimer de la collection",
"adventure": "Aventure",
"adventure_delete_success": "Aventure supprimée avec succès !",
"archive": "Archiver",
"archived": "Archivée",
"archived_collection_message": "Collection archivée avec succès !",
@@ -40,7 +42,6 @@
"create_new": "Créer une nouvelle aventure...",
"date": "Date",
"dates": "Dates",
"delete_adventure": "Supprimer l'aventure",
"delete_collection": "Supprimer la collection",
"delete_collection_success": "Collection supprimée avec succès !",
"descending": "Descendant",
@@ -57,8 +58,6 @@
"my_collections": "Mes collections",
"name": "Nom",
"no_image_url": "Aucune image trouvée à cette URL.",
"not_found": "Aventure introuvable",
"not_found_desc": "L'aventure que vous cherchez est introuvable. \nVeuillez essayer une autre aventure ou revenez plus tard.",
"open_filters": "Ouvrir les filtres",
"order_by": "Trier par",
"order_direction": "Direction du tri",
@@ -81,10 +80,6 @@
"activity_types": "Types d'activités",
"add": "Ajouter",
"add_notes": "Ajouter des notes",
"adventure_create_error": "Échec de la création de l'aventure",
"adventure_created": "Aventure créée",
"adventure_update_error": "Échec de la mise à jour de l'aventure",
"adventure_updated": "Aventure mise à jour",
"basic_information": "Informations de base",
"category": "Catégorie",
"clear_map": "Effacer la carte",
@@ -100,23 +95,19 @@
"location": "Lieu",
"location_information": "Informations de localisation",
"my_images": "Mes images",
"new_adventure": "Nouvelle aventure",
"no_description_found": "Aucune description trouvée",
"no_images": "Aucune image",
"no_location": "Veuillez entrer un emplacement",
"no_results": "Aucun résultat trouvé",
"public_adventure": "Aventure publique",
"remove": "Retirer",
"save_next": "Sauvegarder",
"search_for_location": "Rechercher un lieu",
"search_results": "Résultats de la recherche",
"see_adventures": "Voir les aventures",
"share_adventure": "Partagez cette aventure !",
"start_date": "Date de début",
"upload_image": "Télécharger une image",
"url": "URL",
"warning": "Avertissement",
"wiki_desc": "Obtient un extrait de l'article Wikipédia correspondant au nom de l'aventure.",
"wikipedia": "Wikipédia",
"adventure_not_found": "Il n'y a aucune aventure à afficher. \nAjoutez-en en utilisant le bouton '+' en bas à droite ou essayez de changer les filtres !",
"all": "Tous",
@@ -124,7 +115,6 @@
"mark_visited": "Marquer comme visité",
"my_adventures": "Mes aventures",
"no_adventures_found": "Aucune aventure trouvée",
"no_collections_found": "Aucune collection trouvée pour ajouter cette aventure.",
"no_linkable_adventures": "Aucune aventure trouvée pouvant être liée à cette collection.",
"not_visited": "Non visitée",
"regions_updated": "régions mises à jour",
@@ -181,10 +171,7 @@
"starting_airport": "Aéroport de départ",
"to": "Vers",
"transportation_delete_confirm": "Etes-vous sûr de vouloir supprimer ce transport ? \nCette action ne peut pas être annulée.",
"will_be_marked": "sera marqué comme visité une fois laventure sauvegardée.",
"cities_updated": "villes mises à jour",
"create_adventure": "Créer une aventure",
"no_adventures_to_recommendations": "Aucune aventure trouvée. \nAjoutez au moins une aventure pour obtenir des recommandations.",
"finding_recommendations": "Découvrir des trésors cachés pour votre prochaine aventure",
"attachment": "Pièce jointe",
"attachment_delete_success": "Pièce jointe supprimée avec succès !",
@@ -246,7 +233,197 @@
"name_location": "nom, emplacement",
"collection_contents": "Contenu de la collection",
"check_in": "Enregistrement",
"check_out": "Vérifier"
"check_out": "Vérifier",
"collection_link_location_error": "Erreur liant l'emplacement à la collection",
"collection_link_location_success": "Emplacement lié à la collection avec succès!",
"collection_locations": "Inclure les emplacements de collecte",
"collection_remove_location_error": "Erreur de suppression de l'emplacement de la collection",
"collection_remove_location_success": "Emplacement retiré de la collection avec succès!",
"create_location": "Créer un emplacement",
"delete_location": "Supprimer l'emplacement",
"edit_location": "Modifier l'emplacement",
"location_create_error": "Échec de la création de l'emplacement",
"location_created": "Emplacement créé",
"location_delete_confirm": "Êtes-vous sûr de vouloir supprimer cet emplacement? \nCette action ne peut pas être annulée.",
"location_delete_success": "Emplacement supprimé avec succès!",
"location_not_found": "Emplacement introuvable",
"location_not_found_desc": "L'emplacement que vous recherchiez n'a pas pu être trouvé. \nVeuillez essayer un autre emplacement ou revenir plus tard.",
"location_update_error": "Échec de la mise à jour de l'emplacement",
"location_updated": "Emplacement mis à jour",
"new_location": "Nouvel emplacement",
"no_collections_to_add_location": "Aucune collection n'a été trouvée pour ajouter cet emplacement à.",
"no_locations_to_recommendations": "Aucun emplacement trouvé. \nAjoutez au moins un emplacement pour obtenir des recommandations.",
"public_location": "Lieu public",
"share_location": "Partagez cet emplacement!",
"visit_calendar": "Visiter le calendrier",
"wiki_location_desc": "Tire un extrait de l'article de Wikipedia correspondant au nom de l'emplacement.",
"will_be_marked_location": "sera marqué comme visité une fois l'emplacement enregistré.",
"no_locations_found": "Aucun emplacement trouvé",
"image_modal_navigate": "Utilisez des touches flèches ou cliquez pour naviguer",
"details": "Détails",
"leave": "Partir",
"leave_collection": "Collecte de congé",
"leave_collection_warning": "Êtes-vous sûr de vouloir quitter cette collection? \nTous les emplacements que vous avez ajoutés seront non liés et resteront dans votre compte.",
"left_collection_message": "Collection de gauche avec succès",
"loading_collections": "Chargement des collections ...",
"quick_start": "Démarrage rapide",
"achievements": "Réalisations",
"active_duration": "Durée active",
"activities_name": "Activités",
"activity_name": "Nom d'activité",
"activity_name_placeholder": "Run du matin",
"activity_name_required": "Le nom d'activité est requis",
"activity_options": "Options d'activité",
"activity_statistics": "Statistiques d'activité",
"activity_statistics_description": "Vos réalisations de fitness et d'activité",
"add_activity": "Ajouter une activité",
"add_first_trail": "Ajoutez votre premier sentier en utilisant le bouton ci-dessus",
"add_new_activity": "Ajouter une nouvelle activité",
"add_new_trail": "Ajouter un nouveau sentier",
"add_trail": "Ajouter une piste",
"add_visit": "Ajouter la visite",
"add_wanderer_trail": "Ajouter le sentier Wanderer",
"attachment_management": "Gestion de l'attachement",
"attachment_name_required": "Nom de la pièce jointe requis",
"attachment_remove_error": "Une erreur s'est produite lors du retrait de la pièce jointe",
"attachment_removed": "L'attachement supprimé avec succès",
"attachment_updated": "Pièce jointe mise à jour avec succès",
"average_cadence": "Cadence moyenne",
"average_speed": "Vitesse moyenne",
"avg_speed": "Vitesse moyenne",
"back": "Dos",
"cadence": "Cadence",
"calories": "Calories",
"click_map": "Cliquez sur la carte pour sélectionner un emplacement",
"click_on_map": "Cliquez sur la carte pour sélectionner un emplacement",
"complete_import": "Importation complète",
"complete_strava_import": "Importation complète de Strava",
"confirm_delete_activity": "Êtes-vous sûr de vouloir supprimer cette activité?",
"connect_to_wanderer": "Connectez-vous à Wanderer",
"continue": "Continuer",
"create_new_location": "Créer un nouvel emplacement",
"create_trail": "Créer une piste",
"created": "Créé",
"current_attachments": "Attachements actuels",
"date_selection": "Sélection de date",
"download_gpx": "Télécharger GPX",
"edit_visit": "Modifier la visite",
"elapsed_time": "Temps écoulé",
"elevation": "Élévation",
"elevation_gain": "Gain d'altitude",
"elevation_high": "Élévation élevée",
"elevation_loss": "Perte",
"elevation_low": "Élévation basse",
"end_lat": "Latitude finale",
"end_lng": "Fin de longitude",
"export_gpx": "Exporter gpx",
"export_original": "Exporter original",
"external_link": "Lien externe",
"gain": "gagner",
"getting_location_details": "Obtenir les détails de l'emplacement",
"gpx_file": "Fichier gpx",
"gpx_file_downloaded": "Fichier GPX téléchargé. \nVeuillez le télécharger ci-dessous pour terminer l'importation.",
"gpx_file_required": "Fichier GPX requis",
"image_management": "Gestion de l'image",
"import_activity": "Activité d'importation",
"importing": "Importation",
"likes": "Goûts",
"loading_activities": "Activités de chargement",
"location_display_name": "Nom de l'écran d'emplacement",
"location_map": "Emplacement",
"location_selected": "Emplacement sélectionné",
"max_speed": "Vitesse maximale",
"moving_time": "Temps de déménagement",
"next_image": "Image suivante",
"no_attachments_uploaded_yet": "Aucune pièce jointe encore téléchargée",
"no_external_link": "Aucun lien externe disponible",
"no_file_selected": "Aucun fichier sélectionné",
"no_images_uploaded_yet": "Aucune images encore téléchargées",
"no_strava_activities": "Aucune activité Strava trouvée lors de cette visite",
"no_trails_added": "Aucun sentier ajouté encore",
"no_trails_available": "Pas de sentiers disponibles",
"no_trails_found_matching": "Aucun sentier trouvé correspondant",
"no_visits_description": "Créez votre première visite en sélectionnant les dates ci-dessus",
"notes_placeholder": "Ajouter des notes sur cette visite",
"or": "OU",
"pace": "Rythme",
"photos": "Photos",
"previous_image": "Image précédente",
"processing": "Traitement",
"public_location_description": "Rendre cet emplacement visible pour les autres utilisateurs",
"remove_visit": "Supprimer la visite",
"rest_time": "Temps de repos",
"saved_activities": "Activités sauvées",
"search_location": "Rechercher un emplacement",
"search_placeholder": "Entrez la ville, l'emplacement ou le point de repère ...",
"search_trails_placeholder": "Recherchez les sentiers par nom",
"searching": "Recherche",
"select_on_map": "Sélectionner sur la carte",
"select_wanderer_trail": "Sélectionnez un sentier dans votre compte Wanderer",
"sport_type": "Type de sport",
"sport_type_placeholder": "Trace",
"start_lat": "Commencer la latitude",
"start_lng": "Commencer la longitude",
"strava_activities_during_visit": "Activités de Strava lors de la visite",
"strava_activity_ready": "Activité Strava prête",
"time": "Temps",
"total_covered": "Total couvert",
"total_recorded": "Total enregistré",
"trail": "Piste",
"trail_created_successfully": "Trail créé avec succès",
"trail_creation_failed": "Échec de la création de sentiers",
"trail_fetch_failed": "Échec de la récupération des sentiers Wanderer",
"trail_link_required": "Une liaison de sentier est requise",
"trail_name": "Nom du sentier",
"trail_removal_failed": "Échec de la suppression du sentier",
"trail_removed_successfully": "Le sentier a été supprimé avec succès",
"trail_update_failed": "Échec de la mise à jour du sentier",
"trail_updated_successfully": "Trail mis à jour avec succès",
"trails": "Sentiers",
"trails_found_for": "sentiers trouvés pour",
"trails_management": "Gestion des sentiers",
"trails_management_description": "Gérez les sentiers associés à cet emplacement. \nLes sentiers peuvent être liés à des services externes comme Alltrails ou à un lien vers Wanderer Trails.",
"update_location_details": "Mettre à jour les détails de l'emplacement",
"update_visit": "Mettre à jour la visite",
"upload_activity": "Télécharger l'activité",
"upload_attachment": "Télécharger la pièce jointe",
"upload_first_attachment": "Téléchargez votre première pièce jointe à l'aide des options ci-dessus",
"upload_first_image": "Téléchargez votre première image en utilisant l'une des options ci-dessus",
"upload_from_device": "Télécharger à partir de l'appareil",
"upload_from_url": "Télécharger de l'URL",
"upload_gpx_file": "Téléchargez le fichier gpx qui vient d'être téléchargé pour terminer l'importation de Strava",
"uploading": "Téléchargement",
"use_current_location": "Utiliser l'emplacement actuel",
"view_gpx": "Afficher GPX",
"view_on": "Voir",
"view_strava_activities": "Voir les activités de Strava",
"view_trail": "Voir le sentier",
"wanderer_integration_error": "L'intégration des vagabonds n'est pas activée ou a expiré.",
"wikipedia_error": "Échec de génération de description à partir de Wikipedia",
"high": "Haut",
"low": "Faible",
"total": "Total",
"rest": "Repos",
"attachment_removed_error": "Erreur supprimant la pièce jointe",
"attachment_removed_success": "Attachement supprimé avec succès",
"attachments_upload_info": "Les pièces jointes seront téléchargées après avoir enregistré le",
"image_upload_info": "Les images seront téléchargées après avoir enregistré le",
"linked_locations": "Emplacements liés",
"lodging_save_error": "Économie d'erreur",
"my_attachments": "Mes pièces jointes",
"no_attachments": "Aucune pièce jointe",
"no_attachments_desc": "Télécharger des fichiers pour commencer",
"no_images_desc": "Télécharger des images pour commencer",
"route_map": "Carte d'itinéraire",
"selected_attachments": "Attachements sélectionnés",
"selected_images": "Images sélectionnées",
"activities_text": "activités",
"activity_breakdown_by_category": "Déchange d'activité par catégorie",
"distance_covered": "Distance couverte",
"recorded_sessions": "Sessions enregistrées",
"total_activities": "Activités totales",
"total_climbed": "Total grimpé",
"total_distance": "Distance totale"
},
"home": {
"desc_1": "Découvrez, planifiez et explorez en toute simplicité",
@@ -298,7 +475,8 @@
"language_selection": "Langue",
"support": "Soutien",
"calendar": "Calendrier",
"admin_panel": "Panneau d'administration"
"admin_panel": "Panneau d'administration",
"navigation": "Navigation"
},
"auth": {
"confirm_password": "Confirmer le mot de passe",
@@ -317,10 +495,14 @@
"public_tooltip": "Avec un profil public, les utilisateurs peuvent partager des collections avec vous et afficher votre profil sur la page des utilisateurs.",
"new_password": "Nouveau mot de passe",
"or_3rd_party": "Ou connectez-vous avec un service tiers",
"no_public_adventures": "Aucune aventure publique trouvée",
"no_public_collections": "Aucune collection publique trouvée",
"user_adventures": "Aventures de l'utilisateur",
"user_collections": "Collections de l'utilisateur"
"user_collections": "Collections de l'utilisateur",
"no_public_locations": "Aucun emplacement public trouvé",
"user_locations": "Emplacements des utilisateurs",
"enter_password": "Entrez votre mot de passe",
"enter_username": "Entrez votre nom d'utilisateur",
"logging_in": "Se connecter",
"totp": "Code à deux facteurs"
},
"users": {
"no_users_found": "Aucun utilisateur trouvé avec un profil public."
@@ -379,7 +561,8 @@
"oldest_first": "Le plus ancien premier",
"unvisited_first": "Sans visité d'abord",
"visited_first": "Visité en premier",
"total_items": "Total des articles"
"total_items": "Total des articles",
"getting_location_details": "Obtenir les détails de l'emplacement"
},
"settings": {
"account_settings": "Paramètres du compte utilisateur",
@@ -493,7 +676,40 @@
"disconnected": "Déconnecté",
"email_management": "Gestion des e-mails",
"enter_last_name": "Entrez votre nom de famille",
"invalid_credentials": "Des références non valides"
"invalid_credentials": "Des références non valides",
"backup_restore": "Sauvegarde",
"backup_restore_desc": "Enregistrez vos données ou restaurez-les à partir d'un fichier de sauvegarde précédent.",
"complete_setup_to_enable": "Configuration complète pour activer le MFA",
"copy_all": "Copier tout",
"enter_6_digit_code": "Entrez le code à 6 chiffres",
"enter_code_from_app": "Entrez le code à partir de l'application",
"error_occurred": "Une erreur s'est produite",
"important": "Important",
"manual_entry": "Entrée manuelle",
"mfa_already_enabled": "MFA déjà activé",
"mfa_required": "MFA requis",
"scan_qr_code": "Scanner le code QR",
"scan_with_authenticator_app": "Scanner avec l'application Authenticatrice",
"secure_your_account": "Sécuriser votre compte",
"setup_required": "Configuration requise",
"verify_setup": "Vérifiez la configuration",
"whats_included": "Ce qui est inclus",
"backup_your_data": "Sauvegardez vos données",
"backup_your_data_desc": "Téléchargez une sauvegarde complète des données de votre compte, y compris les emplacements, les collections, les médias et les visites.",
"data_override_acknowledge": "Je reconnais que cela remplacera toutes mes données existantes",
"data_override_acknowledge_desc": "Cette action est irréversible et remplacera tous les emplacements, collections et visites dans votre compte.",
"data_override_warning": "Avertissement de remplacement des données",
"data_override_warning_desc": "La restauration des données remplacera complètement toutes les données existantes (incluses dans la sauvegarde) dans votre compte. \nCette action ne peut pas être annulée.",
"integrations_settings": "Paramètres des intégrations",
"media": "Médias",
"restore_data": "Restaurer les données",
"restore_data_desc": "Téléchargez un fichier de sauvegarde pour restaurer vos données.",
"select_backup_file": "Sélectionnez le fichier de sauvegarde",
"world_travel_visits": "Visites de voyage dans le monde",
"activities": "Activités",
"trails": "Sentiers",
"use_imperial": "Utilisez des unités impériales",
"use_imperial_desc": "Utilisez des unités impériales (pieds, pouces, livres) au lieu d'unités métriques"
},
"checklist": {
"checklist_delete_error": "Erreur lors de la suppression de la liste de contrôle",
@@ -505,7 +721,17 @@
"item_cannot_be_empty": "L'élément ne peut pas être vide",
"items": "Éléments",
"new_item": "Nouvel élément",
"new_checklist": "Nouvelle liste de contrôle"
"new_checklist": "Nouvelle liste de contrôle",
"add_new_item": "Ajouter un nouvel article",
"add_your_first_item": "Ajoutez votre premier article",
"checklist_viewer": "Visionner de la liste de contrôle",
"completed": "Complété",
"current_items": "Articles actuels",
"editing_checklist": "Liste de contrôle d'édition",
"enter_checklist_title": "Entrez le titre de la liste de contrôle",
"no_items_yet": "Pas encore d'articles",
"update_checklist_details": "Liste de contrôle d'édition",
"viewing_checklist": "Affichage de la liste de contrôle"
},
"collection": {
"collection_created": "Collection créée avec succès !",
@@ -539,7 +765,11 @@
"open": "Ouvrir",
"save": "Sauvegarder",
"invalid_url": "URL invalide",
"note_viewer": "Visionneuse de notes"
"note_viewer": "Visionneuse de notes",
"create_new_note": "Créer une nouvelle note",
"enter_note_title": "Entrez le titre de la note",
"update_note_details": "Note de montage",
"viewing_note": "Note d'observation"
},
"transportation": {
"edit": "Modifier",
@@ -563,12 +793,26 @@
"transportation_deleted": "Déplacement supprimé avec succès !",
"ending_airport_desc": "Entrez le code de l'aéroport de départ (par exemple, CDG)",
"fetch_location_information": "Récupérer les informations sur les lieux",
"starting_airport_desc": "Entrez le code de l'aéroport d'arrivée (par exemple, ORY)"
"starting_airport_desc": "Entrez le code de l'aéroport d'arrivée (par exemple, ORY)",
"create_new_transportation": "Nouveau transport",
"enter_flight_number": "Entrez le numéro de vol",
"enter_from_location": "Entrer de l'emplacement",
"enter_link": "Entrez le lien",
"enter_to_location": "Entrez à l'emplacement",
"enter_transportation_name": "Entrez le nom du transport",
"select_type": "Sélectionner le type",
"update_transportation_details": "Mettre à jour les détails du transport"
},
"search": {
"adventurelog_results": "Résultats dans AdventureLog",
"online_results": "Résultats en ligne",
"public_adventures": "Aventures publiques"
"public_adventures": "Aventures publiques",
"cities": "Villes",
"countries": "Pays",
"found": "trouvé",
"result": "Résultat",
"results": "Résultats",
"try_searching_desc": "Essayez de rechercher des aventures, des collections, des pays, des régions, des villes ou des utilisateurs."
},
"map": {
"add_adventure": "Ajouter une nouvelle aventure",
@@ -579,13 +823,18 @@
"show_visited_regions": "Afficher les régions visitées",
"view_details": "Afficher les détails",
"adventure_stats": "Statistiques d'aventure",
"adventures_shown": "aventures montrées",
"completion": "Achèvement",
"display_options": "Options d'affichage",
"map_controls": "Contrôles de cartes",
"marker_placed_on_map": "Marqueur placé sur la carte",
"place_marker_desc": "Cliquez sur la carte pour placer un marqueur ou ajouter une aventure sans emplacement.",
"regions": "Régions"
"regions": "Régions",
"add_location": "Ajouter un nouvel emplacement",
"add_location_at_marker": "Ajouter un nouvel emplacement chez Marker",
"location_map": "Carte de localisation",
"locations_shown": "Emplacements montrés",
"place_marker_desc_location": "Cliquez sur la carte pour placer un marqueur.",
"show_activities": "Montrer les activités",
"show_visited_cities": "Villes visites"
},
"languages": {},
"share": {
@@ -598,7 +847,11 @@
"with": "avec",
"go_to_settings": "Allez dans les paramètres",
"no_shared_found": "Aucune collection ne semble encore avoir été partagée avec vous.",
"set_public": "Afin de permettre aux utilisateurs de partager avec vous, vous devez rendre votre profil public."
"set_public": "Afin de permettre aux utilisateurs de partager avec vous, vous devez rendre votre profil public.",
"available": "Disponible",
"pending": "En attente",
"revoke_invite": "Revoke Inviter",
"send_invite": "Envoyer l'invitation"
},
"profile": {
"member_since": "Membre depuis",
@@ -611,9 +864,9 @@
"no_shared_adventures": "Cet utilisateur n'a encore partagé aucune aventure publique.",
"no_shared_collections": "Cet utilisateur n'a pas encore partagé de collections publiques.",
"planned_trips": "Voyages prévus",
"public_adventure_experiences": "Expériences d'aventure publique",
"travel_statistics": "Statistiques de voyage",
"your_journey_at_a_glance": "Votre voyage d'aventure en un coup d'œil"
"your_journey_at_a_glance": "Votre voyage d'aventure en un coup d'œil",
"public_location_experiences": "Expériences de localisation publique"
},
"categories": {
"category_name": "Nom de la catégorie",
@@ -622,9 +875,9 @@
"manage_categories": "Gérer les catégories",
"no_categories_found": "Aucune catégorie trouvée.",
"select_category": "Sélectionnez une catégorie",
"update_after_refresh": "Les cartes d'aventure seront mises à jour une fois que vous aurez actualisé la page.",
"add_new_category": "Ajouter une nouvelle catégorie",
"name_required": "Le nom de catégorie est requis"
"name_required": "Le nom de catégorie est requis",
"location_update_after_refresh": "Les cartes de localisation seront mises à jour une fois que vous avez actualisé la page."
},
"dashboard": {
"add_some": "Pourquoi ne pas commencer à planifier votre prochaine aventure ? \nVous pouvez ajouter une nouvelle aventure en cliquant sur le bouton ci-dessous.",
@@ -665,14 +918,26 @@
"integration_already_exists": "Une intégration Immich existe déjà. \nVous ne pouvez avoir qu'une seule intégration à la fois.",
"integration_not_found": "L'intégration d'immich n'est pas trouvée. \nVeuillez créer une nouvelle intégration.",
"network_error": "Erreur réseau lors de la connexion au serveur Immich. \nVeuillez vérifier votre connexion et réessayer.",
"validation_error": "Une erreur s'est produite lors de la validation de l'intégration d'Immich. \nVeuillez vérifier l'URL et la clé API de votre serveur."
"validation_error": "Une erreur s'est produite lors de la validation de l'intégration d'Immich. \nVeuillez vérifier l'URL et la clé API de votre serveur.",
"by_album": "Par album",
"by_date": "Par date",
"error_no_object_id": "Aucun ID d'objet n'a été fourni",
"fetch_error": "Erreur récupérant les données de l'intégration d'Immich",
"image_search_placeholder": "Recherche à l'aide d'Immich",
"loading": "Chargement",
"loading_albums": "Chargement des albums",
"no_images": "Aucune image trouvée",
"select_album": "Sélectionner l'album",
"select_album_first": "Sélectionnez d'abord un album",
"select_date": "Sélectionner la date",
"try_different_date": "Essayez une date différente"
},
"recomendations": {
"recommendation": "Recommandation",
"recommendations": "Recommandations",
"adventure_recommendations": "Recommandations d'aventure",
"food": "Nourriture",
"tourism": "Tourisme"
"tourism": "Tourisme",
"location_recommendations": "Recommandations de localisation"
},
"lodging": {
"apartment": "Appartement",
@@ -689,23 +954,65 @@
"other": "Autre",
"reservation_number": "Numéro de réservation",
"resort": "Complexe touristique",
"villa": "Villa"
"villa": "Villa",
"create_new_lodging": "Nouveau logement",
"enter_lodging_name": "Entrez le nom de l'hébergement",
"enter_price": "Saisir le prix",
"enter_reservation_number": "Entrez le numéro de réservation",
"update_lodging_details": "Mettre à jour les détails de l'hébergement"
},
"google_maps": {
"google_maps_integration_desc": "Connectez votre compte Google Maps pour obtenir des résultats de recherche et recommandations de recherche de haute qualité."
"google_maps_integration_desc": "Connectez votre compte Google Maps pour obtenir des résultats de recherche et recommandations de recherche de haute qualité.",
"google_maps_integration_desc_no_staff": "Cette intégration doit d'abord être activée par l'administrateur sur ce serveur."
},
"calendar": {
"all_categories": "Toutes les catégories",
"all_day_event": "Événement toute la journée",
"calendar_overview": "Aperçu du calendrier",
"categories": "Catégories",
"day": "Jour",
"events_scheduled": "événements prévus",
"filter_by_category": "Filtre par catégorie",
"filtered_results": "Résultats filtrés",
"month": "Mois",
"today": "Aujourd'hui",
"total_events": "Événements totaux",
"week": "Semaine"
},
"locations": {
"location": "Emplacement",
"locations": "Lieux",
"my_locations": "Mes emplacements"
},
"settings_download_backup": "Télécharger la sauvegarde",
"invites": {
"accept_failed": "Échec de l'acceptation de l'invitation",
"accepted": "Inviter accepté",
"by": "par",
"decline": "Déclin",
"decline_failed": "Échec de refuser l'invitation",
"declined": "Invite a refusé",
"invited_on": "Invité",
"no_invites": "Aucune invitation",
"no_invites_desc": "Assurez-vous que votre profil est public afin que les utilisateurs puissent vous inviter.",
"pending_invites": "Invitations en attente",
"title": "Invitations",
"accept": "Accepter"
},
"strava": {
"account_connected": "Compte connecté",
"admin_setup_required": "L'administrateur du serveur doit l'activer à l'échelle mondiale",
"authorization_error": "Redirection d'erreur vers l'URL de l'autorisation Strava",
"connect_account": "Connecter le compte",
"disconnect": "Débrancher",
"disconnect_error": "Erreur de déconnexion de Strava",
"disconnected": "Déconnecté avec succès de Strava",
"not_configured": "Strava non configuré",
"ready_to_connect": "Prêt à se connecter",
"strava_integration_desc": "Connectez-vous à Strava pour importer facilement vos activités dans des emplacements et des visites",
"gpx_required": "Veuillez télécharger le fichier gpx pour terminer l'importation de Strava",
"not_enabled": "L'intégration de Strava n'est pas activée sur cette instance."
},
"wanderer": {
"connected": "Connecté avec succès à Wanderer",
"connection_error": "Erreur de connexion à Wanderer",
"wanderer_integration_desc": "Connectez-vous à Wanderer pour importer facilement et afficher vos sentiers dans les endroits"
}
}