Added map using Leaflet

This commit is contained in:
Atharva Sawant
2024-10-23 16:25:47 +05:30
parent 0249cd68b9
commit b85823259a
3 changed files with 67 additions and 7 deletions

View File

@@ -6,16 +6,25 @@
</header>
<main class="container mx-auto p-4">
<div class="text-center py-12">
<h2 class="text-xl mb-4">Welcome to TrackMap</h2>
<p class="text-gray-600">Upload your GPX files to get started analyzing your cycling tracks</p>
<div class="mb-6">
<h2 class="text-xl mb-4">Your Cycling Tracks</h2>
<MapView />
</div>
<div class="text-center py-8 text-gray-500">
<p>Upload GPX files to see your tracks on the map</p>
</div>
</main>
</div>
</template>
<script>
import MapView from './components/MapView.vue'
export default {
name: 'App'
name: 'App',
components: {
MapView
}
}
</script>

View File

@@ -0,0 +1,51 @@
<template>
<div id="map" class="w-full h-96 rounded-lg shadow-md"></div>
</template>
<script>
import { ref, onMounted, onUnmounted } from 'vue'
import L from 'leaflet'
export default {
name: 'MapView',
setup() {
const map = ref(null)
const getLocationFromIP = async () => {
try {
const response = await fetch('https://ipapi.co/json/')
const data = await response.json()
return [data.latitude, data.longitude]
} catch (error) {
console.log('Could not get location from IP:', error)
// Default to San Francisco for localhost/fallback
return [37.7749, -122.4194]
}
}
const initMap = async () => {
const coords = await getLocationFromIP()
map.value = L.map('map').setView(coords, 10)
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map.value)
}
onMounted(() => {
initMap()
})
onUnmounted(() => {
if (map.value) {
map.value.remove()
}
})
return {
map
}
}
}
</script>

View File

@@ -1,10 +1,10 @@
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
@import 'leaflet/dist/leaflet.css';
@tailwind base;
@tailwind components;
@tailwind utilities;
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
@import 'leaflet/dist/leaflet.css';
@layer base {
* {
box-sizing: border-box;