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,7 +9,15 @@
"oss_attributions": "오픈 소스 속성",
"other_attributions": "추가 속성은 README 파일에서 찾을 수 있습니다.",
"source_code": "소스 코드",
"generic_attributions": "Adventurelog에 로그인하여 활성화 된 통합 및 서비스에 대한 속성을보십시오."
"generic_attributions": "Adventurelog에 로그인하여 활성화 된 통합 및 서비스에 대한 속성을보십시오.",
"attributions": "속성",
"developer": "개발자",
"license_info": "특허",
"sponsor": "스폰서",
"thank_you": "Adventurelog를 사용해 주셔서 감사합니다!",
"version": "버전",
"view_changelog": "changelog를 봅니다",
"view_license": "라이센스보기"
},
"adventures": {
"actions": "행동",
@@ -22,13 +30,7 @@
"add_to_collection": "컬렉션에 추가하세요",
"adventure": "모험",
"adventure_calendar": "모험 달력",
"adventure_create_error": "모험을 만들지 못했습니다",
"adventure_created": "모험 생성됨",
"adventure_delete_confirm": "이 모험을 삭제 하시겠습니까? 이 행동은 취소 할 수 없습니다.",
"adventure_delete_success": "모험이 성공적으로 삭제되었습니다!",
"adventure_not_found": "표시할 모험이 없습니다. 오른쪽 하단의 플러스 버튼을 사용하여 추가하거나 필터를 변경하세요!",
"adventure_update_error": "모험을 업데이트하지 못했습니다",
"adventure_updated": "모험 업데이트됨",
"all": "모두",
"archive": "보관",
"archived": "보관됨",
@@ -56,16 +58,11 @@
"collection_adventures": "컬렉션 모험을 추가하세요",
"collection_archived": "이 컬렉션은 보관되었습니다.",
"collection_completed": "이 컬렉션을 완성했습니다!",
"collection_link_error": "컬렉션에 모험 연결 중 오류",
"collection_link_success": "컬렉션에 모험이 성공적으로 연결되었습니다!",
"collection_remove_error": "컬렉션에서 모험을 제거 중 오류",
"collection_remove_success": "컬렉션에서 모험이 제거되었습니다!",
"collection_stats": "컬렉션 통계",
"copied_to_clipboard": "클립 보드에 복사됨!",
"copy_failed": "복사 실패",
"copy_link": "링크 복사",
"count_txt": "검색과 일치하는 결과",
"create_adventure": "모험 생성",
"create_new": "새로 만들기...",
"date": "일자",
"date_constrain": "컬렉션 일자로 제한",
@@ -74,7 +71,6 @@
"day": "일",
"days": "일",
"delete": "삭제",
"delete_adventure": "모험 삭제",
"delete_checklist": "체크리스트 삭제",
"delete_collection": "컬렉션 삭제",
"delete_collection_success": "컬렉션이 성공적으로 삭제되었습니다!",
@@ -123,10 +119,7 @@
"my_collections": "내 컬렉션",
"my_images": "내 이미지",
"name": "이름",
"new_adventure": "새로운 모험",
"no_adventures_found": "모험이 없습니다",
"no_adventures_to_recommendations": "모험이 없습니다. 장소를 추천받으려면 최소 하나 이상의 모험을 등록해야 합니다.",
"no_collections_found": "이 모험을 추가할 수 있는 컬렉션이 없습니다.",
"no_description_found": "설명이 없습니다",
"no_image_found": "이미지가 없습니다",
"no_image_url": "해당 URL에 이미지가 없습니다.",
@@ -135,8 +128,6 @@
"no_location": "위치를 입력하세요",
"no_location_found": "위치가 없습니다",
"no_results": "결과가 없습니다",
"not_found": "모험이 없습니다",
"not_found_desc": "당신이 찾고 있던 모험을 찾을 수 없었습니다. 다른 모험을 찾아보거나 나중에 다시 해 보세요.",
"not_visited": "방문하지 않음",
"note": "노트",
"note_delete_confirm": "이 노트를 삭제 하시겠습니까? 이 행동은 취소 할 수 없습니다.",
@@ -151,7 +142,6 @@
"preview": "미리보기",
"private": "비공개",
"public": "공개",
"public_adventure": "공개 모험",
"rating": "평가",
"regions_updated": "지역이 업데이트되었습니다",
"remove": "제거",
@@ -162,7 +152,6 @@
"see_adventures": "모험 보기",
"set_to_pin": "고정하기",
"share": "공유",
"share_adventure": "이 모험을 공유하세요!",
"show": "보기",
"sort": "정렬",
"sources": "출처",
@@ -190,10 +179,8 @@
"visited_region_check_desc": "이것을 선택하면 서버는 방문한 모든 모험을 확인하고 그 모험의 지역을 표시하여 세계 여행에서 방문 여부를 표시합니다.",
"visits": "방문",
"warning": "경고",
"wiki_desc": "모험의 이름과 일치하는 글을 위키백과에서 가져옵니다.",
"wiki_image_error": "위키백과 이미지 가져오기 오류",
"wikipedia": "위키백과",
"will_be_marked": "모험이 저장되면 방문했다고 표시합니다.",
"checklists": "체크리스트",
"cities_updated": "도시 업데이트됨",
"clear": "초기화",
@@ -246,7 +233,197 @@
"name_location": "이름, 위치",
"collection_contents": "수집 내용",
"check_in": "체크인",
"check_out": "체크 아웃"
"check_out": "체크 아웃",
"collection_link_location_error": "오류 연결 위치 컬렉션",
"collection_link_location_success": "컬렉션에 링크 된 위치!",
"collection_locations": "수집 위치를 포함합니다",
"collection_remove_location_error": "수집에서 위치를 제거하는 오류",
"collection_remove_location_success": "컬렉션에서 제거 된 위치는 성공적으로!",
"create_location": "위치를 만듭니다",
"delete_location": "위치 삭제",
"edit_location": "위치 편집",
"location_create_error": "위치를 만들지 못했습니다",
"location_created": "생성 된 위치",
"location_delete_confirm": "이 위치를 삭제 하시겠습니까? \n이 조치는 취소 할 수 없습니다.",
"location_delete_success": "위치가 성공적으로 삭제되었습니다!",
"location_not_found": "위치를 찾을 수 없습니다",
"location_not_found_desc": "당신이 찾고 있던 위치는 찾을 수 없습니다. \n다른 위치를 시도하거나 나중에 다시 확인하십시오.",
"location_update_error": "위치를 업데이트하지 못했습니다",
"location_updated": "위치 업데이트",
"new_location": "새로운 위치",
"no_collections_to_add_location": "이 위치를 추가하는 컬렉션은 없습니다.",
"no_locations_to_recommendations": "발견 된 위치는 없습니다. \n권장 사항을 얻으려면 하나 이상의 위치를 ​​추가하십시오.",
"public_location": "공개 위치",
"share_location": "이 위치를 공유하십시오!",
"visit_calendar": "캘린더를 방문하십시오",
"wiki_location_desc": "위치 이름과 일치하는 Wikipedia 기사에서 발췌 한 내용을 가져옵니다.",
"will_be_marked_location": "위치가 저장되면 방문한대로 표시됩니다.",
"no_locations_found": "발견 된 위치는 없습니다",
"image_modal_navigate": "화살표 키를 사용하거나 클릭하여 탐색하십시오",
"details": "세부",
"leave": "떠나다",
"leave_collection": "컬렉션을 떠나십시오",
"leave_collection_warning": "이 컬렉션을 떠나고 싶습니까? \n추가 한 모든 위치는 inke가 무제한 상태이며 귀하의 계정에 남아 있습니다.",
"left_collection_message": "성공적으로 컬렉션을 떠났습니다",
"loading_collections": "컬렉션로드 ...",
"quick_start": "빠른 시작",
"achievements": "업적",
"active_duration": "활성 기간",
"activities_name": "활동",
"activity_name": "활동 이름",
"activity_name_placeholder": "아침 달리기",
"activity_name_required": "활동 이름이 필요합니다",
"activity_options": "활동 옵션",
"activity_statistics": "활동 통계",
"activity_statistics_description": "귀하의 체력 및 활동 성과",
"add_activity": "활동 추가",
"add_first_trail": "위의 버튼을 사용하여 첫 번째 트레일을 추가하십시오",
"add_new_activity": "새로운 활동을 추가하십시오",
"add_new_trail": "새로운 트레일을 추가하십시오",
"add_trail": "트레일을 추가하십시오",
"add_visit": "방문 추가",
"add_wanderer_trail": "방랑자 트레일을 추가하십시오",
"attachment_management": "첨부 관리",
"attachment_name_required": "첨부 이름이 필요합니다",
"attachment_remove_error": "첨부 파일을 제거하는 동안 오류가 발생했습니다",
"attachment_removed": "첨부 파일이 성공적으로 제거되었습니다",
"attachment_updated": "첨부 파일이 성공적으로 업데이트되었습니다",
"average_cadence": "평균 케이던스",
"average_speed": "평균 속도",
"avg_speed": "평균 속도",
"back": "뒤쪽에",
"cadence": "운율",
"calories": "칼로리",
"click_map": "위치를 선택하려면지도를 클릭하십시오",
"click_on_map": "위치를 선택하려면지도를 클릭하십시오",
"complete_import": "완전한 수입",
"complete_strava_import": "완전한 Strava 가져 오기",
"confirm_delete_activity": "이 활동을 삭제 하시겠습니까?",
"connect_to_wanderer": "Wanderer에 연결하십시오",
"continue": "계속하다",
"create_new_location": "새로운 위치를 만듭니다",
"create_trail": "트레일을 만듭니다",
"created": "생성",
"current_attachments": "현재 첨부 파일",
"date_selection": "날짜 선택",
"download_gpx": "GPX를 다운로드하십시오",
"edit_visit": "방문 편집",
"elapsed_time": "경과 시간",
"elevation": "높이",
"elevation_gain": "고도 이득",
"elevation_high": "높은 높이",
"elevation_loss": "고도 손실",
"elevation_low": "높이가 낮습니다",
"end_lat": "끝 위도",
"end_lng": "종말 경도",
"export_gpx": "GPX 내보내기",
"export_original": "원본 내보내기",
"external_link": "외부 링크",
"gain": "얻다",
"getting_location_details": "위치 세부 정보 얻기",
"gpx_file": "GPX 파일",
"gpx_file_downloaded": "GPX 파일 다운로드. \n가져 오기를 완료하려면 아래에 업로드하십시오.",
"gpx_file_required": "GPX 파일이 필요합니다",
"image_management": "이미지 관리",
"import_activity": "수입 활동",
"importing": "가져 오기",
"likes": "좋아합니다",
"loading_activities": "로딩 활동",
"location_display_name": "위치 표시 이름",
"location_map": "위치",
"location_selected": "선택된 위치",
"max_speed": "최대 속도",
"moving_time": "이동 시간",
"next_image": "다음 이미지",
"no_attachments_uploaded_yet": "아직 첨부 파일이 업로드되지 않았습니다",
"no_external_link": "외부 링크가 없습니다",
"no_file_selected": "선택된 파일이 없습니다",
"no_images_uploaded_yet": "아직 이미지가 업로드되지 않았습니다",
"no_strava_activities": "이 방문 동안 Strava 활동이 발견되지 않았습니다",
"no_trails_added": "아직 트레일이 추가되지 않았습니다",
"no_trails_available": "사용 가능한 트레일이 없습니다",
"no_trails_found_matching": "일치하는 트레일이 없습니다",
"no_visits_description": "위의 날짜를 선택하여 첫 방문을 만듭니다",
"notes_placeholder": "이 방문에 대한 메모를 추가하십시오",
"or": "또는",
"pace": "속도",
"photos": "사진",
"previous_image": "이전 이미지",
"processing": "처리",
"public_location_description": "이 위치를 다른 사용자에게 보이게하십시오",
"remove_visit": "방문을 제거하십시오",
"rest_time": "휴식 시간",
"saved_activities": "저장된 활동",
"search_location": "위치를 검색하십시오",
"search_placeholder": "도시, 위치 또는 랜드 마크를 입력하십시오 ...",
"search_trails_placeholder": "이름으로 트레일을 검색합니다",
"searching": "수색",
"select_on_map": "지도에서 선택하십시오",
"select_wanderer_trail": "방랑자 계정에서 트레일을 선택하십시오",
"sport_type": "스포츠 유형",
"sport_type_placeholder": "트레일 러닝",
"start_lat": "위도를 시작하십시오",
"start_lng": "경도를 시작하십시오",
"strava_activities_during_visit": "방문 중 Strava 활동",
"strava_activity_ready": "Strava 활동 준비",
"time": "시간",
"total_covered": "총 커버",
"total_recorded": "기록 된 총",
"trail": "자취",
"trail_created_successfully": "트레일이 성공적으로 만들어졌습니다",
"trail_creation_failed": "트레일을 만들지 못했습니다",
"trail_fetch_failed": "방랑자 트레일을 가져 오지 못했습니다",
"trail_link_required": "트레일 링크가 필요합니다",
"trail_name": "트레일 이름",
"trail_removal_failed": "트레일을 제거하지 못했습니다",
"trail_removed_successfully": "트레일이 성공적으로 제거되었습니다",
"trail_update_failed": "트레일을 업데이트하지 못했습니다",
"trail_updated_successfully": "트레일이 성공적으로 업데이트되었습니다",
"trails": "트레일",
"trails_found_for": "발견 된 트레일",
"trails_management": "트레일 관리",
"trails_management_description": "이 위치와 관련된 트레일을 관리하십시오. \n트레일은 AllTrails 또는 Wanderer Trails 링크와 같은 외부 서비스에 연결될 수 있습니다.",
"update_location_details": "위치 세부 사항을 업데이트합니다",
"update_visit": "업데이트 방문",
"upload_activity": "활동 업로드 활동",
"upload_attachment": "첨부 파일 업로드",
"upload_first_attachment": "위의 옵션을 사용하여 첫 번째 첨부 파일을 업로드하십시오",
"upload_first_image": "위의 옵션 중 하나를 사용하여 첫 번째 이미지를 업로드하십시오.",
"upload_from_device": "장치에서 업로드하십시오",
"upload_from_url": "URL에서 업로드하십시오",
"upload_gpx_file": "Strava 가져 오기를 완료하기 위해 방금 다운로드 한 GPX 파일 업로드",
"uploading": "업로드",
"use_current_location": "현재 위치를 사용하십시오",
"view_gpx": "GPX를 봅니다",
"view_on": "보기",
"view_strava_activities": "Strava 활동을보십시오",
"view_trail": "트레일보기",
"wanderer_integration_error": "방랑자 통합은 활성화되지 않았거나 만료되었습니다.",
"wikipedia_error": "Wikipedia에서 설명을 생성하지 못했습니다",
"high": "높은",
"low": "낮은",
"rest": "나머지",
"total": "총",
"attachment_removed_error": "첨부 파일 제거 오류",
"attachment_removed_success": "첨부 파일이 성공적으로 제거되었습니다",
"attachments_upload_info": "저장 후 첨부 파일이 업로드됩니다",
"image_upload_info": "저장 후 이미지가 업로드됩니다",
"linked_locations": "연결된 위치",
"lodging_save_error": "오류 저축 숙박",
"my_attachments": "내 첨부 파일",
"no_attachments": "첨부 파일이 없습니다",
"no_attachments_desc": "시작하려면 파일을 업로드하십시오",
"no_images_desc": "시작하려면 이미지를 업로드하십시오",
"route_map": "경로지도",
"selected_attachments": "선택된 첨부 파일",
"selected_images": "선택된 이미지",
"activities_text": "활동",
"activity_breakdown_by_category": "카테고리 별 활동 분해",
"distance_covered": "거리는",
"recorded_sessions": "기록 된 세션",
"total_activities": "총 활동",
"total_climbed": "총계가 올라 갔다",
"total_distance": "총 거리"
},
"auth": {
"confirm_password": "비밀번호 확인",
@@ -265,10 +442,14 @@
"registration_disabled": "현재 등록할 수 없습니다.",
"signup": "가입",
"username": "사용자 이름",
"no_public_adventures": "공개 모험이 발견되지 않았습니다",
"no_public_collections": "공개 컬렉션이 발견되지 않았습니다",
"user_adventures": "사용자 모험",
"user_collections": "사용자 수집"
"user_collections": "사용자 수집",
"no_public_locations": "공공 장소가 발견되지 않았습니다",
"user_locations": "사용자 위치",
"enter_password": "비밀번호를 입력하십시오",
"enter_username": "사용자 이름을 입력하십시오",
"logging_in": "로그인",
"totp": "2 단계 코드"
},
"categories": {
"category_name": "카테고리 이름",
@@ -277,9 +458,9 @@
"manage_categories": "카테고리 관리",
"no_categories_found": "카테고리가 없습니다.",
"select_category": "카테고리 선택",
"update_after_refresh": "페이지를 새로고침해야 모험 카드가 업데이트됩니다.",
"add_new_category": "새 카테고리를 추가하십시오",
"name_required": "카테고리 이름이 필요합니다"
"name_required": "카테고리 이름이 필요합니다",
"location_update_after_refresh": "페이지를 새로 고치면 위치 카드가 업데이트됩니다."
},
"checklist": {
"checklist_delete_error": "체크리스트 삭제 오류",
@@ -291,7 +472,17 @@
"item_cannot_be_empty": "항목은 비어있을 수 없습니다",
"items": "항목",
"new_checklist": "새 체크리스트",
"new_item": "새 항목"
"new_item": "새 항목",
"add_your_first_item": "첫 번째 항목을 추가하십시오",
"completed": "완전한",
"current_items": "현재 항목",
"editing_checklist": "체크리스트 편집",
"enter_checklist_title": "체크리스트 제목을 입력하십시오",
"no_items_yet": "아직 항목이 없습니다",
"update_checklist_details": "체크리스트 편집",
"viewing_checklist": "체크리스트보기",
"add_new_item": "새 항목을 추가하십시오",
"checklist_viewer": "점검표 뷰어"
},
"collection": {
"collection_created": "컬렉션이 성공적으로 생성되었습니다!",
@@ -370,7 +561,19 @@
"integration_already_exists": "면역 통합이 이미 존재합니다. \n한 번에 하나만 통합 할 수 있습니다.",
"integration_not_found": "Immich 통합을 찾을 수 없습니다. \n새로운 통합을 작성하십시오.",
"network_error": "Immich 서버에 연결하는 동안 네트워크 오류. \n연결을 확인하고 다시 시도하십시오.",
"validation_error": "면역 통합을 검증하는 동안 오류가 발생했습니다. \n서버 URL 및 API 키를 확인하십시오."
"validation_error": "면역 통합을 검증하는 동안 오류가 발생했습니다. \n서버 URL 및 API 키를 확인하십시오.",
"by_album": "앨범에 의해",
"by_date": "날짜에 따라",
"error_no_object_id": "객체 ID가 제공되지 않았습니다",
"fetch_error": "Immich 통합에서 데이터를 가져 오기",
"image_search_placeholder": "Immich를 사용하여 검색하십시오",
"loading": "로딩",
"loading_albums": "앨범로드",
"no_images": "이미지가 없습니다",
"select_album": "앨범을 선택하십시오",
"select_album_first": "먼저 앨범을 선택하십시오",
"select_date": "날짜를 선택하십시오",
"try_different_date": "다른 날짜를 시도하십시오"
},
"map": {
"add_adventure": "새로운 모험 추가",
@@ -381,13 +584,18 @@
"show_visited_regions": "방문한 지역 보기",
"view_details": "상세 보기",
"adventure_stats": "모험 통계",
"adventures_shown": "모험 쇼",
"completion": "완성",
"display_options": "디스플레이 옵션",
"map_controls": "맵 컨트롤",
"marker_placed_on_map": "마커가지도에 배치되었습니다",
"place_marker_desc": "지도를 클릭하여 마커를 배치하거나 위치없이 모험을 추가하십시오.",
"regions": "지역"
"regions": "지역",
"add_location": "새로운 위치를 추가하십시오",
"add_location_at_marker": "마커에 새 위치를 추가하십시오",
"location_map": "위치지도",
"locations_shown": "표시된 위치",
"place_marker_desc_location": "지도를 클릭하여 마커를 배치하십시오.",
"show_activities": "활동을 보여줍니다",
"show_visited_cities": "도시를 방문했습니다"
},
"navbar": {
"about": "Adventurelog 소개",
@@ -421,7 +629,8 @@
},
"users": "사용자",
"worldtravel": "세계 여행",
"admin_panel": "관리자 패널"
"admin_panel": "관리자 패널",
"navigation": "항해"
},
"notes": {
"add_a_link": "링크 추가",
@@ -435,7 +644,11 @@
"note_public": "이 노트는 공개 컬렉션에 있기 때문에 공개되었습니다.",
"note_viewer": "노트 뷰어",
"open": "열기",
"save": "저장"
"save": "저장",
"create_new_note": "새 메모를 만듭니다",
"enter_note_title": "메모 제목을 입력하십시오",
"update_note_details": "편집 노트",
"viewing_note": "보기 노트"
},
"profile": {
"member_since": "가입 시점",
@@ -448,21 +661,27 @@
"no_shared_adventures": "이 사용자는 아직 공개 모험을 공유하지 않았습니다.",
"no_shared_collections": "이 사용자는 아직 공개 컬렉션을 공유하지 않았습니다.",
"planned_trips": "계획된 여행",
"public_adventure_experiences": "공개 모험 경험",
"your_journey_at_a_glance": "당신의 모험 여행",
"travel_statistics": "여행 통계"
"travel_statistics": "여행 통계",
"public_location_experiences": "공개 위치 경험"
},
"recomendations": {
"recommendation": "추천",
"recommendations": "권장 사항",
"adventure_recommendations": "모험 추천",
"food": "음식",
"tourism": "관광 여행"
"tourism": "관광 여행",
"location_recommendations": "위치 권장 사항"
},
"search": {
"adventurelog_results": "Adventurelog 결과",
"online_results": "온라인 결과",
"public_adventures": "공개 모험"
"public_adventures": "공개 모험",
"cities": "도시",
"countries": "국가",
"found": "설립하다",
"result": "결과",
"results": "결과",
"try_searching_desc": "모험, 컬렉션, 국가, 지역, 도시 또는 사용자를 검색하십시오."
},
"settings": {
"about_this_background": "이 배경에 대해",
@@ -576,7 +795,40 @@
"social_auth_setup": "소셜 인증 설정",
"staff_status": "직원 상태",
"staff_user": "직원 사용자",
"invalid_credentials": "잘못된 자격 증명"
"invalid_credentials": "잘못된 자격 증명",
"backup_restore": "지원",
"backup_restore_desc": "데이터를 저장하거나 이전 백업 파일에서 복원하십시오.",
"complete_setup_to_enable": "MFA를 활성화하기위한 완전한 설정",
"copy_all": "모두 복사하십시오",
"enter_6_digit_code": "6 자리 코드를 입력하십시오",
"enter_code_from_app": "앱에서 코드를 입력하십시오",
"error_occurred": "오류가 발생했습니다",
"important": "중요한",
"manual_entry": "수동 입력",
"mfa_already_enabled": "MFA는 이미 활성화되었습니다",
"mfa_required": "MFA가 필요합니다",
"scan_qr_code": "QR 코드를 스캔하십시오",
"scan_with_authenticator_app": "Authenticator 앱으로 스캔하십시오",
"secure_your_account": "계정을 확보하십시오",
"setup_required": "설정이 필요합니다",
"verify_setup": "설정을 확인하십시오",
"whats_included": "포함 된 내용",
"backup_your_data": "데이터를 백업하십시오",
"backup_your_data_desc": "위치, 컬렉션, 미디어 및 방문을 포함하여 계정 데이터의 전체 백업을 다운로드하십시오.",
"data_override_acknowledge": "나는 이것이 나의 모든 기존 데이터를 무시할 것임을 인정합니다.",
"data_override_acknowledge_desc": "이 조치는 돌이킬 수 없으며 계정의 모든 위치, 컬렉션 및 방문을 대체합니다.",
"data_override_warning": "데이터를 우선적으로 경고합니다",
"data_override_warning_desc": "데이터 복원은 계정의 모든 기존 데이터 (백업에 포함 된)를 완전히 대체합니다. \n이 조치는 취소 할 수 없습니다.",
"integrations_settings": "통합 설정",
"media": "메디아",
"restore_data": "데이터를 복원하십시오",
"restore_data_desc": "백업 파일을 업로드하여 데이터를 복원하십시오.",
"select_backup_file": "백업 파일을 선택하십시오",
"world_travel_visits": "세계 여행 방문",
"activities": "활동",
"trails": "트레일",
"use_imperial": "제국 유닛을 사용하십시오",
"use_imperial_desc": "메트릭 단위 대신 황실 단위 (피트, 인치, 파운드)를 사용하십시오."
},
"share": {
"go_to_settings": "설정으로 이동",
@@ -588,7 +840,11 @@
"shared": "공유됨",
"shared_with": "공유한 사용자",
"unshared": "공유되지 않음",
"with": "함께 하는 사용자"
"with": "함께 하는 사용자",
"available": "사용 가능",
"pending": "보류 중",
"revoke_invite": "취소 초대",
"send_invite": "초대를 보내십시오"
},
"transportation": {
"edit": "편집",
@@ -612,7 +868,15 @@
"type": "유형",
"ending_airport_desc": "엔드 공항 코드 입력 (예 : LAX)",
"fetch_location_information": "위치 정보를 가져 오십시오",
"starting_airport_desc": "공항 시작 코드 입력 (예 : JFK)"
"starting_airport_desc": "공항 시작 코드 입력 (예 : JFK)",
"create_new_transportation": "새로운 교통",
"enter_flight_number": "비행 번호를 입력하십시오",
"enter_from_location": "위치에서 입력하십시오",
"enter_link": "링크를 입력하십시오",
"enter_to_location": "위치에 입력하십시오",
"enter_transportation_name": "운송 이름을 입력하십시오",
"select_type": "유형을 선택하십시오",
"update_transportation_details": "전송 세부 사항을 업데이트하십시오"
},
"users": {
"no_users_found": "공개 프로필인 사용자가 없습니다."
@@ -671,7 +935,8 @@
"oldest_first": "가장 오래된 첫 번째",
"unvisited_first": "먼저 방문하지 않습니다",
"visited_first": "먼저 방문했습니다",
"total_items": "총 항목"
"total_items": "총 항목",
"getting_location_details": "위치 세부 정보 얻기"
},
"lodging": {
"apartment": "아파트",
@@ -688,23 +953,65 @@
"other": "다른",
"reservation_number": "예약 번호",
"resort": "의지",
"villa": "별장"
"villa": "별장",
"create_new_lodging": "새로운 숙박",
"enter_lodging_name": "숙박 이름을 입력하십시오",
"enter_price": "가격을 입력하십시오",
"enter_reservation_number": "예약 번호를 입력하십시오",
"update_lodging_details": "숙박 세부 사항을 업데이트하십시오"
},
"google_maps": {
"google_maps_integration_desc": "Google지도 계정을 연결하여 고품질 위치 검색 결과 및 권장 사항을 얻으십시오."
"google_maps_integration_desc": "Google지도 계정을 연결하여 고품질 위치 검색 결과 및 권장 사항을 얻으십시오.",
"google_maps_integration_desc_no_staff": "이 통합은 먼저이 서버의 관리자가 활성화해야합니다."
},
"calendar": {
"all_categories": "모든 카테고리",
"all_day_event": "하루 종일 이벤트",
"calendar_overview": "캘린더 개요",
"categories": "카테고리",
"day": "낮",
"events_scheduled": "예약 된 이벤트",
"filter_by_category": "카테고리 별 필터",
"filtered_results": "필터링 된 결과",
"month": "월",
"today": "오늘",
"total_events": "총 이벤트",
"week": "주"
},
"locations": {
"location": "위치",
"locations": "위치",
"my_locations": "내 위치"
},
"settings_download_backup": "백업을 다운로드하십시오",
"invites": {
"accept": "수용하다",
"accept_failed": "초대를 수락하지 못했습니다",
"accepted": "허가를 초대하십시오",
"by": "~에 의해",
"decline": "감소",
"decline_failed": "초대를 거부하지 못했습니다",
"declined": "초대 거절",
"invited_on": "초대",
"no_invites": "초대하지 않습니다",
"no_invites_desc": "사용자가 귀하를 초대 할 수 있도록 프로필이 공개되어 있는지 확인하십시오.",
"pending_invites": "보류중인 초대",
"title": "초대"
},
"strava": {
"account_connected": "계정이 연결되어 있습니다",
"admin_setup_required": "서버 관리자는 전 세계적으로 활성화해야합니다",
"authorization_error": "Strava Authorization URL로 오류를 방향으로 리디렉션합니다",
"connect_account": "계정을 연결하십시오",
"disconnect": "연결을 끊습니다",
"disconnect_error": "Strava에서 오류 분리",
"disconnected": "Strava에서 성공적으로 분리되었습니다",
"not_configured": "Strava는 구성되지 않았습니다",
"ready_to_connect": "연결 준비",
"strava_integration_desc": "Strava에 연결하여 액티브를 위치 및 방문으로 쉽게 가져 오십시오.",
"gpx_required": "Strava 가져 오기를 완료하려면 GPX 파일을 업로드하십시오.",
"not_enabled": "이 인스턴스에서는 Strava 통합이 활성화되지 않습니다."
},
"wanderer": {
"connected": "Wanderer에 성공적으로 연결되었습니다",
"connection_error": "방랑자에 연결하는 오류",
"wanderer_integration_desc": "Wanderer에 연결하여 위치에서 트레일을 쉽게 가져오고 볼 수 있습니다."
}
}