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

@@ -31,7 +31,8 @@
"language_selection": "Idioma",
"support": "Soporte",
"calendar": "Calendario",
"admin_panel": "Panel de administración"
"admin_panel": "Panel de administración",
"navigation": "Navegación"
},
"about": {
"about": "Acerca de",
@@ -43,7 +44,15 @@
"nominatim_2": "Sus datos están licenciados bajo la licencia ODbL.",
"other_attributions": "Atribuciones adicionales se pueden encontrar en el archivo README.",
"close": "Cerrar",
"generic_attributions": "Inicie sesión en AdventureLog para ver las atribuciones para integraciones y servicios habilitados."
"generic_attributions": "Inicie sesión en AdventureLog para ver las atribuciones para integraciones y servicios habilitados.",
"attributions": "Atribuciones",
"developer": "Revelador",
"license_info": "Licencia",
"sponsor": "Patrocinador",
"thank_you": "¡Gracias por usar Adventurelog!",
"version": "Versión",
"view_changelog": "Ver ChangeLog",
"view_license": "Ver licencia"
},
"home": {
"hero_1": "Descubre las Aventuras Más Emocionantes del Mundo",
@@ -64,11 +73,6 @@
"of_world": "del mundo"
},
"adventures": {
"collection_remove_success": "¡Aventura eliminada de la colección con éxito!",
"collection_remove_error": "Error al eliminar la aventura de la colección",
"collection_link_success": "¡Aventura vinculada a la colección con éxito!",
"collection_link_error": "Error al vincular la aventura a la colección",
"adventure_delete_confirm": "¿Estás seguro de que quieres eliminar esta aventura? Esta acción no se puede deshacer.",
"open_details": "Abrir Detalles",
"edit_adventure": "Editar Aventura",
"remove_from_collection": "Eliminar de la Colección",
@@ -80,8 +84,6 @@
"homepage": "Página principal",
"latitude": "Latitud",
"longitude": "Longitud",
"not_found": "Aventura no encontrada",
"not_found_desc": "La aventura que buscabas no se pudo encontrar. \nPruebe una aventura diferente o vuelva a consultar más tarde.",
"visit": "Visita",
"visits": "Visitas",
"adventure": "Aventura",
@@ -116,8 +118,6 @@
"share": "Compartir",
"unarchive": "Desarchivar",
"cancel": "Cancelar",
"adventure_delete_success": "¡Aventura eliminada con éxito!",
"delete_adventure": "Eliminar aventura",
"planned": "Planificado",
"visited": "Visitado",
"dates": "Fechas",
@@ -134,10 +134,6 @@
"activity_types": "Tipos de actividad",
"add": "Agregar",
"add_notes": "Agregar notas",
"adventure_create_error": "No se pudo crear la aventura",
"adventure_created": "Aventura creada",
"adventure_update_error": "No se pudo actualizar la aventura",
"adventure_updated": "Aventura actualizada",
"basic_information": "Información básica",
"category": "Categoría",
"clear_map": "Limpiar mapa",
@@ -153,26 +149,21 @@
"location": "Ubicación",
"location_information": "Información de ubicación",
"my_images": "Mis imágenes",
"new_adventure": "Nueva aventura",
"no_description_found": "No se encontró ninguna descripción",
"no_images": "Sin imágenes",
"no_location": "Por favor ingresa una ubicación",
"no_results": "No se encontraron resultados",
"public_adventure": "Aventura pública",
"remove": "Eliminar",
"save_next": "Guardar y Siguiente",
"search_for_location": "Buscar una ubicación",
"search_results": "Resultados de búsqueda",
"share_adventure": "¡Comparte esta aventura!",
"start_date": "Fecha de inicio",
"upload_image": "Subir imagen",
"url": "URL",
"warning": "Advertencia",
"wiki_desc": "Extrae un extracto de un artículo de Wikipedia que coincide con el nombre de la aventura.",
"wikipedia": "Wikipedia",
"adventure_not_found": "No hay aventuras que mostrar. \n¡Agregue algunas usando el botón más en la parte inferior derecha o intente cambiar los filtros!",
"no_adventures_found": "No se encontraron aventuras",
"no_collections_found": "No se encontraron colecciones para agregar esta aventura.",
"my_adventures": "Mis aventuras",
"no_linkable_adventures": "No se encontraron aventuras que puedan vincularse a esta colección.",
"mark_visited": "Marcar como visitado",
@@ -233,10 +224,7 @@
"starting_airport": "Aeropuerto de inicio",
"to": "A",
"transportation_delete_confirm": "¿Está seguro de que desea eliminar este transporte? \nEsta acción no se puede deshacer.",
"will_be_marked": "se marcará como visitado una vez guardada la aventura.",
"cities_updated": "ciudades actualizadas",
"create_adventure": "Crear aventura",
"no_adventures_to_recommendations": "No se encontraron aventuras. \nAñade al menos una aventura para obtener recomendaciones.",
"finding_recommendations": "Descubriendo gemas ocultas para tu próxima aventura",
"attachment": "Adjunto",
"attachment_delete_success": "¡El archivo adjunto se eliminó exitosamente!",
@@ -298,7 +286,197 @@
"name_location": "Nombre, ubicación",
"collection_contents": "Contenido de la colección",
"check_in": "Registrarse",
"check_out": "Verificar"
"check_out": "Verificar",
"collection_link_location_error": "Error de vinculación de la ubicación para la recopilación",
"collection_link_location_success": "¡Ubicación vinculada a la colección con éxito!",
"collection_locations": "Incluir ubicaciones de colección",
"collection_remove_location_error": "Error de eliminación de la ubicación de la colección",
"collection_remove_location_success": "¡Ubicación eliminada de la colección con éxito!",
"create_location": "Crear ubicación",
"delete_location": "Eliminar la ubicación",
"edit_location": "Ubicación de edición",
"location_create_error": "No se pudo crear la ubicación",
"location_created": "Ubicación creada",
"location_delete_confirm": "¿Estás seguro de que quieres eliminar esta ubicación? \nEsta acción no se puede deshacer.",
"location_delete_success": "Ubicación eliminada con éxito!",
"location_not_found": "Ubicación no encontrada",
"location_not_found_desc": "No se podía encontrar la ubicación que estaba buscando. \nPruebe una ubicación diferente o vuelva a consultar más tarde.",
"location_update_error": "No se pudo actualizar la ubicación",
"location_updated": "Ubicación actualizada",
"new_location": "Nueva ubicación",
"no_collections_to_add_location": "No se encuentran colecciones para agregar esta ubicación a.",
"no_locations_to_recommendations": "No se encontraron ubicaciones. \nAgregue al menos una ubicación para obtener recomendaciones.",
"public_location": "Ubicación pública",
"share_location": "¡Comparte esta ubicación!",
"visit_calendar": "Visitar el calendario",
"wiki_location_desc": "Extrae extracto del artículo de Wikipedia que coincide con el nombre de la ubicación.",
"will_be_marked_location": "se marcará según lo visitado una vez que se guarde la ubicación.",
"no_locations_found": "No se encontraron ubicaciones",
"image_modal_navigate": "Use teclas de flecha o haga clic para navegar",
"details": "Detalles",
"leave": "Dejar",
"leave_collection": "Recolección de licencia",
"leave_collection_warning": "¿Estás seguro de que quieres dejar esta colección? \nCualquier ubicación que agregó no estará vinculado y permanecerá en su cuenta.",
"left_collection_message": "Colección de izquierda con éxito",
"loading_collections": "Cargando colecciones ...",
"quick_start": "Comienzo rápido",
"click_map": "Haga clic en el mapa para seleccionar una ubicación",
"continue": "Continuar",
"getting_location_details": "Obtener detalles de ubicación",
"location_selected": "Ubicación seleccionada",
"search_location": "Buscar una ubicación",
"search_placeholder": "Ingrese a la ciudad, ubicación o punto de referencia ...",
"searching": "Búsqueda",
"select_on_map": "Seleccionar en el mapa",
"use_current_location": "Utilice la ubicación actual",
"create_new_location": "Crear nueva ubicación",
"update_location_details": "Actualizar detalles de ubicación",
"back": "Atrás",
"click_on_map": "Haga clic en el mapa para seleccionar una ubicación",
"location_display_name": "Nombre de la pantalla de ubicación",
"location_map": "Ubicación",
"or": "O",
"processing": "Tratamiento",
"public_location_description": "Haga que esta ubicación sea visible para otros usuarios",
"wikipedia_error": "No se pudo generar una descripción de Wikipedia",
"add_first_trail": "Agregue su primera ruta con el botón de arriba",
"add_new_trail": "Agregar nuevo sendero",
"add_wanderer_trail": "Agregar sendero Wanderer",
"attachment_management": "Gestión de adjuntos",
"attachment_name_required": "Nombre de archivo adjunto requerido",
"attachment_remove_error": "Se produjo un error al eliminar el archivo adjunto",
"attachment_removed": "Adjunto eliminado con éxito",
"attachment_updated": "Adjunto actualizado con éxito",
"create_trail": "Crear rastro",
"image_management": "Gestión de imágenes",
"no_attachments_uploaded_yet": "No hay archivos adjuntos cargados todavía",
"no_external_link": "No hay enlace externo disponible",
"no_file_selected": "No hay archivo seleccionado",
"no_images_uploaded_yet": "No hay imágenes cargadas todavía",
"no_trails_added": "Todavía no se agregan senderos",
"no_trails_available": "No hay senderos disponibles",
"no_trails_found_matching": "No se encontraron senderos coincidentes",
"select_wanderer_trail": "Seleccione un sendero de su cuenta de Wanderer",
"trail_created_successfully": "Sendero creado con éxito",
"trail_creation_failed": "No se pudo crear un sendero",
"trail_fetch_failed": "No se pudo buscar senderos de Wanderer",
"trail_link_required": "Se requiere un enlace de sendero",
"trail_removal_failed": "No se pudo quitar el sendero",
"trail_removed_successfully": "Sendero eliminado con éxito",
"trail_update_failed": "No se pudo actualizar el sendero",
"trail_updated_successfully": "Sendero actualizado con éxito",
"trails_found_for": "senderos encontrados para",
"trails_management": "Gestión de senderos",
"trails_management_description": "Administre los senderos asociados con esta ubicación. \nLos senderos se pueden vincular a servicios externos como Alltrails o Link a Wanderer Trails.",
"upload_attachment": "Subir el archivo adjunto",
"upload_first_attachment": "Cargue su primer archivo adjunto utilizando las opciones anteriores",
"upload_first_image": "Sube tu primera imagen usando una de las opciones de arriba",
"upload_from_device": "Cargar desde el dispositivo",
"upload_from_url": "Subir desde URL",
"wanderer_integration_error": "La integración de Wanderer no está habilitada o ha expirado.",
"external_link": "Enlace externo",
"search_trails_placeholder": "Búsqueda de senderos por nombre",
"trail_name": "Nombre de sendero",
"add_trail": "Agregar rastro",
"achievements": "Logros",
"activity_options": "Opciones de actividad",
"avg_speed": "Velocidad promedio",
"cadence": "Cadencia",
"calories": "Calorías",
"created": "Creado",
"elevation": "Elevación",
"export_gpx": "GPX de exportación",
"export_original": "Exportar original",
"gain": "ganar",
"import_activity": "Actividad de importación",
"likes": "Gustos",
"max_speed": "Velocidad máxima",
"moving_time": "Tiempo de mudanza",
"pace": "Paso",
"photos": "Fotos",
"time": "Tiempo",
"trail": "Camino",
"view_gpx": "Ver GPX",
"view_on": "Ver",
"view_trail": "Ver el sendero",
"activity_name": "Nombre de actividad",
"activity_name_placeholder": "Carrera matutina",
"add_new_activity": "Agregar nueva actividad",
"average_cadence": "Cadencia promedio",
"average_speed": "Velocidad promedio",
"complete_import": "Importación completa",
"complete_strava_import": "Importación completa de Strava",
"date_selection": "Selección de fecha",
"elapsed_time": "Tiempo transcurrido",
"elevation_gain": "Ganancia de elevación",
"elevation_high": "Elevación alta",
"elevation_loss": "Pérdida de elevación",
"elevation_low": "Elevación baja",
"end_lat": "Final de la latitud",
"end_lng": "Longitud final",
"gpx_file": "Archivo gpx",
"gpx_file_downloaded": "Archivo GPX descargado. \nCárguelo a continuación para completar la importación.",
"gpx_file_required": "Requerido el archivo GPX",
"importing": "Importador",
"loading_activities": "Actividades de carga",
"next_image": "Siguiente imagen",
"no_strava_activities": "No se encontraron actividades de Strava durante esta visita",
"no_visits_description": "Cree su primera visita seleccionando las fechas anteriores",
"notes_placeholder": "Agregue notas sobre esta visita",
"previous_image": "Imagen anterior",
"rest_time": "Tiempo de descanso",
"saved_activities": "Actividades guardadas",
"sport_type": "Tipo deportivo",
"sport_type_placeholder": "Sendero",
"start_lat": "Iniciar latitud",
"start_lng": "Iniciar longitud",
"strava_activity_ready": "Strava Activity Ready",
"trails": "Senderos",
"upload_activity": "Carga de actividad",
"upload_gpx_file": "Sube el archivo GPX que se acaba de descargar para completar la importación Strava",
"uploading": "Carga",
"view_strava_activities": "Ver actividades de Strava",
"current_attachments": "Archivos adjuntos actuales",
"connect_to_wanderer": "Conéctese con Wanderer",
"active_duration": "Duración activa",
"activities_name": "Actividades",
"activity_statistics": "Estadísticas de actividad",
"activity_statistics_description": "Tus logros de aptitud y actividad",
"total_covered": "Total cubierto",
"total_recorded": "Total registrado",
"activity_name_required": "Se requiere el nombre de la actividad",
"add_activity": "Agregar actividad",
"add_visit": "Agregar visita",
"confirm_delete_activity": "¿Estás seguro de que quieres eliminar esta actividad?",
"download_gpx": "Descargar GPX",
"edit_visit": "Editar visita",
"remove_visit": "Eliminar visita",
"strava_activities_during_visit": "Actividades de Strava durante la visita",
"update_visit": "Visita de actualización",
"high": "Alto",
"low": "Bajo",
"rest": "Descansar",
"total": "Total",
"attachment_removed_error": "Error al eliminar el archivo adjunto",
"attachment_removed_success": "Adjunto eliminado con éxito",
"attachments_upload_info": "Los archivos adjuntos se cargarán después de guardar el",
"image_upload_info": "Las imágenes se cargarán después de guardar el",
"linked_locations": "Ubicaciones vinculadas",
"lodging_save_error": "Error al horno de alojamiento",
"my_attachments": "Mis archivos adjuntos",
"no_attachments": "Sin archivos adjuntos",
"no_attachments_desc": "Subir archivos para comenzar",
"no_images_desc": "Subir imágenes para comenzar",
"route_map": "Mapa de ruta",
"selected_attachments": "Archivos adjuntos seleccionados",
"selected_images": "Imágenes seleccionadas",
"activities_text": "actividades",
"activity_breakdown_by_category": "Desglose de actividad por categoría",
"distance_covered": "Distancia cubierta",
"recorded_sessions": "Sesiones grabadas",
"total_activities": "Actividades totales",
"total_climbed": "Total escalado",
"total_distance": "Distancia total"
},
"worldtravel": {
"all": "Todo",
@@ -354,7 +532,8 @@
"oldest_first": "El más antiguo primero",
"unvisited_first": "Primero no visitado",
"visited_first": "Visitado primero",
"total_items": "Total de artículos"
"total_items": "Total de artículos",
"getting_location_details": "Obtener detalles de ubicación"
},
"auth": {
"forgot_password": "¿Has olvidado tu contraseña?",
@@ -373,10 +552,14 @@
"public_tooltip": "Con un perfil público, los usuarios pueden compartir colecciones con usted y ver su perfil en la página de usuarios.",
"new_password": "Nueva contraseña",
"or_3rd_party": "O inicie sesión con un servicio de terceros",
"no_public_adventures": "No se encontraron aventuras públicas",
"no_public_collections": "No se encontraron colecciones públicas",
"user_adventures": "Aventuras de usuario",
"user_collections": "Colecciones de usuarios"
"user_collections": "Colecciones de usuarios",
"no_public_locations": "No se encontraron ubicaciones públicas",
"user_locations": "Ubicación de usuarios",
"enter_password": "Ingrese su contraseña",
"enter_username": "Ingrese su nombre de usuario",
"logging_in": "Iniciar sesión",
"totp": "Código de dos factores"
},
"users": {
"no_users_found": "No se encontraron usuarios con perfiles públicos."
@@ -493,7 +676,40 @@
"all_rights_reserved": "Reservados todos los derechos.",
"email_verified_erorr_desc": "Su correo electrónico no pudo ser verificado. \nPor favor intente de nuevo.",
"no_emai_set": "Sin conjunto de correo electrónico",
"invalid_credentials": "Credenciales no válidas"
"invalid_credentials": "Credenciales no válidas",
"backup_restore": "Respaldo",
"backup_restore_desc": "Guardar sus datos o restaurarlo desde un archivo de copia de seguridad anterior.",
"complete_setup_to_enable": "Configuración completa para habilitar MFA",
"copy_all": "Copiar todo",
"enter_6_digit_code": "Ingrese el código de 6 dígitos",
"enter_code_from_app": "Ingrese el código desde la aplicación",
"error_occurred": "Se ha producido un error",
"important": "Importante",
"manual_entry": "Entrada manual",
"mfa_already_enabled": "MFA ya habilitado",
"mfa_required": "MFA requerido",
"scan_qr_code": "Escanear el código QR",
"scan_with_authenticator_app": "Escanear con la aplicación Authenticator",
"secure_your_account": "Asegure su cuenta",
"setup_required": "Configuración requerida",
"verify_setup": "Verificar la configuración",
"whats_included": "¿Qué está incluido?",
"backup_your_data": "Haga una copia de seguridad de sus datos",
"backup_your_data_desc": "Descargue una copia de seguridad completa de los datos de su cuenta, incluidas ubicaciones, colecciones, medios y visitas.",
"data_override_acknowledge": "Reconozco que esto anulará todos mis datos existentes.",
"data_override_acknowledge_desc": "Esta acción es irreversible y reemplazará todas las ubicaciones, colecciones y visitas en su cuenta.",
"data_override_warning": "Advertencia de anulación de datos",
"data_override_warning_desc": "La restauración de datos reemplazará completamente todos los datos existentes (que se incluyen en la copia de seguridad) en su cuenta. \nEsta acción no se puede deshacer.",
"integrations_settings": "Configuración de integraciones",
"media": "Medios de comunicación",
"restore_data": "Restaurar datos",
"restore_data_desc": "Cargue un archivo de copia de seguridad para restaurar sus datos.",
"select_backup_file": "Seleccione el archivo de copia de seguridad",
"world_travel_visits": "Visitas de viajes mundiales",
"activities": "Actividades",
"trails": "Senderos",
"use_imperial": "Use unidades imperiales",
"use_imperial_desc": "Use unidades imperiales (pies, pulgadas, libras) en lugar de unidades métricas"
},
"checklist": {
"checklist_delete_error": "Error al eliminar la lista de tareas",
@@ -505,7 +721,17 @@
"item_cannot_be_empty": "El elemento no puede estar vacío",
"items": "Elementos",
"new_item": "Nuevo artículo",
"new_checklist": "Nueva lista de verificación"
"new_checklist": "Nueva lista de verificación",
"add_new_item": "Agregar nuevo artículo",
"add_your_first_item": "Agrega tu primer artículo",
"checklist_viewer": "Visor de la lista de verificación",
"completed": "Terminado",
"current_items": "Artículos actuales",
"editing_checklist": "Lista de verificación de edición",
"enter_checklist_title": "Ingrese el título de la lista de verificación",
"no_items_yet": "No hay artículos todavía",
"update_checklist_details": "Lista de verificación de edición",
"viewing_checklist": "Visualización de la lista de verificación"
},
"collection": {
"collection_created": "¡Colección creada con éxito!",
@@ -539,7 +765,11 @@
"open": "Abrir",
"save": "Guardar",
"invalid_url": "URL no válida",
"note_viewer": "Visor de notas"
"note_viewer": "Visor de notas",
"create_new_note": "Crear nueva nota",
"enter_note_title": "Ingrese el título de nota",
"update_note_details": "Nota de edición",
"viewing_note": "Nota de visualización"
},
"transportation": {
"modes": {
@@ -563,12 +793,26 @@
"transportation_delete_error": "Error al eliminar el transporte",
"ending_airport_desc": "Ingrese el código de aeropuerto final (por ejemplo, LAX)",
"fetch_location_information": "Información de ubicación para obtener",
"starting_airport_desc": "Ingrese el código de aeropuerto inicial (por ejemplo, JFK)"
"starting_airport_desc": "Ingrese el código de aeropuerto inicial (por ejemplo, JFK)",
"create_new_transportation": "Nuevo transporte",
"enter_flight_number": "Ingrese el número de vuelo",
"enter_from_location": "Ingrese desde la ubicación",
"enter_link": "Ingrese el enlace",
"enter_to_location": "Ingrese a la ubicación",
"enter_transportation_name": "Ingrese el nombre del transporte",
"select_type": "Tipo de selección",
"update_transportation_details": "Actualizar detalles de transporte"
},
"search": {
"adventurelog_results": "Resultados del registro de aventuras",
"online_results": "Resultados en línea",
"public_adventures": "Aventuras públicas"
"public_adventures": "Aventuras públicas",
"cities": "Ciudades",
"countries": "Países",
"found": "encontró",
"result": "Resultado",
"results": "Resultados",
"try_searching_desc": "Intente buscar aventuras, colecciones, países, regiones, ciudades o usuarios."
},
"map": {
"add_adventure": "Agregar nueva aventura",
@@ -583,9 +827,14 @@
"display_options": "Opciones de visualización",
"map_controls": "Controles de mapa",
"marker_placed_on_map": "Marcador colocado en el mapa",
"place_marker_desc": "Haga clic en el mapa para colocar un marcador o agregar una aventura sin ubicación.",
"regions": "Regiones",
"adventures_shown": "aventuras mostradas"
"add_location": "Agregar nueva ubicación",
"add_location_at_marker": "Agregar nueva ubicación en el marcador",
"location_map": "Mapa de ubicación",
"locations_shown": "ubicaciones mostradas",
"place_marker_desc_location": "Haga clic en el mapa para colocar un marcador.",
"show_activities": "Mostrar actividades",
"show_visited_cities": "Ciudades visitadas"
},
"share": {
"no_users_shared": "Ningún usuario compartió con",
@@ -597,7 +846,11 @@
"with": "con",
"go_to_settings": "Ir a configuración",
"no_shared_found": "No se encontraron colecciones que se compartan contigo.",
"set_public": "Para permitir que los usuarios compartan contenido con usted, necesita que su perfil esté configurado como público."
"set_public": "Para permitir que los usuarios compartan contenido con usted, necesita que su perfil esté configurado como público.",
"available": "Disponible",
"pending": "Pendiente",
"revoke_invite": "Revocar la invitación",
"send_invite": "Enviar invitación"
},
"languages": {},
"profile": {
@@ -611,9 +864,9 @@
"no_shared_adventures": "Este usuario aún no ha compartido ninguna aventura pública.",
"no_shared_collections": "Este usuario aún no ha compartido ninguna colección pública.",
"planned_trips": "Viajes planificados",
"public_adventure_experiences": "Experiencias de aventura pública",
"travel_statistics": "Estadísticas de viaje",
"your_journey_at_a_glance": "Tu viaje de aventura a un vistazo"
"your_journey_at_a_glance": "Tu viaje de aventura a un vistazo",
"public_location_experiences": "Experiencias de ubicación pública"
},
"categories": {
"category_name": "Nombre de categoría",
@@ -622,9 +875,9 @@
"manage_categories": "Administrar categorías",
"no_categories_found": "No se encontraron categorías.",
"select_category": "Seleccionar categoría",
"update_after_refresh": "Las tarjetas de aventuras se actualizarán una vez que actualices la página.",
"add_new_category": "Agregar nueva categoría",
"name_required": "Se requiere el nombre de la categoría"
"name_required": "Se requiere el nombre de la categoría",
"location_update_after_refresh": "Las tarjetas de ubicación se actualizarán una vez que actualice la página."
},
"dashboard": {
"add_some": "¿Por qué no empezar a planificar tu próxima aventura? \nPuedes agregar una nueva aventura haciendo clic en el botón de abajo.",
@@ -665,14 +918,26 @@
"integration_already_exists": "Ya existe una integración Immich. \nSolo puedes tener una integración a la vez.",
"integration_not_found": "Integración Immich no encontrada. \nPor favor cree una nueva integración.",
"network_error": "Error de red mientras se conecta al servidor Immich. \nVerifique su conexión y vuelva a intentarlo.",
"validation_error": "Se produjo un error al validar la integración de Immich. \nVerifique la URL y la tecla API de su servidor."
"validation_error": "Se produjo un error al validar la integración de Immich. \nVerifique la URL y la tecla API de su servidor.",
"by_album": "Por álbum",
"by_date": "Por fecha",
"error_no_object_id": "No se proporcionó una identificación de objeto",
"fetch_error": "Error al obtener datos de la integración de Immich",
"image_search_placeholder": "Buscar usando Immich",
"loading": "Cargando",
"loading_albums": "Cargando álbumes",
"no_images": "No se encuentran imágenes",
"select_album": "Álbum seleccionado",
"select_album_first": "Seleccione un álbum primero",
"select_date": "Fecha de selección",
"try_different_date": "Prueba una fecha diferente"
},
"recomendations": {
"recommendation": "Recomendación",
"recommendations": "Recomendaciones",
"adventure_recommendations": "Recomendaciones de aventura",
"food": "Comida",
"tourism": "Turismo"
"tourism": "Turismo",
"location_recommendations": "Recomendaciones de ubicación"
},
"lodging": {
"apartment": "Apartamento",
@@ -689,23 +954,65 @@
"reservation_number": "Número de reserva",
"resort": "Complejo",
"villa": "Villa",
"edit_lodging": "Editar alojamiento"
"edit_lodging": "Editar alojamiento",
"create_new_lodging": "Nuevo alojamiento",
"enter_lodging_name": "Ingrese el nombre de alojamiento",
"enter_price": "Ingresar precio",
"enter_reservation_number": "Ingrese el número de reserva",
"update_lodging_details": "Actualizar detalles de alojamiento"
},
"google_maps": {
"google_maps_integration_desc": "Conecte su cuenta de Google Maps para obtener resultados y recomendaciones de búsqueda de ubicación de alta calidad."
"google_maps_integration_desc": "Conecte su cuenta de Google Maps para obtener resultados y recomendaciones de búsqueda de ubicación de alta calidad.",
"google_maps_integration_desc_no_staff": "El administrador primero debe habilitar esta integración en este servidor."
},
"calendar": {
"all_categories": "Todas las categorías",
"all_day_event": "Evento todo el día",
"calendar_overview": "Descripción general del calendario",
"categories": "Categorías",
"day": "Día",
"events_scheduled": "Eventos programados",
"filter_by_category": "Filtrar por categoría",
"filtered_results": "Resultados filtrados",
"month": "Mes",
"today": "Hoy",
"total_events": "Total de eventos",
"week": "Semana"
},
"locations": {
"location": "Ubicación",
"locations": "Ubicación",
"my_locations": "Mis ubicaciones"
},
"settings_download_backup": "Descargar copia de seguridad",
"invites": {
"accept": "Aceptar",
"accept_failed": "No se pudo aceptar la invitación",
"accepted": "Invite aceptado",
"by": "por",
"decline": "Rechazar",
"decline_failed": "No se pudo rechazar la invitación",
"declined": "Invitación disminuyó",
"invited_on": "Invitado",
"no_invites": "Sin invitaciones",
"no_invites_desc": "Asegúrese de que su perfil sea público para que los usuarios puedan invitarlo.",
"pending_invites": "Invitaciones pendientes",
"title": "Invitaciones"
},
"strava": {
"account_connected": "Cuenta conectada",
"admin_setup_required": "El administrador del servidor debe habilitarlo a nivel mundial",
"authorization_error": "Redirección de errores a la URL de autorización de Strava",
"connect_account": "Cuenta de conexión",
"disconnect": "Desconectar",
"disconnect_error": "Error de desconexión de Strava",
"disconnected": "Desconectado con éxito de Strava",
"not_configured": "Strava no configurado",
"ready_to_connect": "Listo para conectarse",
"strava_integration_desc": "Conéctese a Strava para importar fácilmente sus actividades a ubicaciones y visitas",
"gpx_required": "Sube el archivo GPX para completar la importación de Strava",
"not_enabled": "La integración de Strava no está habilitada en este caso."
},
"wanderer": {
"connected": "Conectado con éxito a Wanderer",
"connection_error": "Error conectándose a Wanderer",
"wanderer_integration_desc": "Conéctese a Wanderer para importar y ver fácilmente sus senderos en ubicaciones"
}
}