- <%= link_to maps_v2_path(start_at: start_at + 1.day, end_at: end_at + 1.day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" do %>
+ <%= link_to map_v2_path(start_at: start_at + 1.day, end_at: end_at + 1.day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" do %>
<%= icon 'chevron-right' %>
<% end %>
@@ -51,18 +51,18 @@
<%= link_to "Today",
- maps_v2_path(start_at: Time.current.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]),
+ map_v2_path(start_at: Time.current.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]),
class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" %>
- <%= link_to "Last 7 days", maps_v2_path(start_at: 1.week.ago.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" %>
+ <%= link_to "Last 7 days", map_v2_path(start_at: 1.week.ago.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" %>
- <%= link_to "Last month", maps_v2_path(start_at: 1.month.ago.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" %>
+ <%= link_to "Last month", map_v2_path(start_at: 1.month.ago.beginning_of_day, end_at: Time.current.end_of_day, import_id: params[:import_id]), class: "btn btn-sm border border-base-300 hover:btn-ghost w-full" %>
diff --git a/config/routes.rb b/config/routes.rb
index bb5f9e19..8ee7565d 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -110,20 +110,15 @@ Rails.application.routes.draw do
resources :metrics, only: [:index]
- # V1 (Leaflet) - legacy
- get 'map', to: 'map#index'
-
- # Main maps entry - redirects to MapLibre
- get '/maps', to: 'maps#index', as: :maps
-
- # Maps namespace
- namespace :maps do
+ # Map namespace with versioning
+ namespace :map do
+ get '/v1', to: 'leaflet#index', as: :v1
get '/v2', to: 'maplibre#index', as: :v2
end
# Backward compatibility redirects
- get '/maps_v2', to: redirect('/maps/v2')
- get '/maps/maplibre', to: redirect('/maps/v2')
+ get '/map', to: 'map/leaflet#index'
+ get '/maps/v2', to: redirect('/map/v2')
namespace :api do
namespace :v1 do
diff --git a/e2e/setup/auth.setup.js b/e2e/setup/auth.setup.js
index 72f486dd..de992dbf 100644
--- a/e2e/setup/auth.setup.js
+++ b/e2e/setup/auth.setup.js
@@ -16,8 +16,8 @@ setup('authenticate', async ({ page }) => {
// Click login button
await page.click('input[type="submit"][value="Log in"]');
- // Wait for successful navigation
- await page.waitForURL('/map', { timeout: 10000 });
+ // Wait for successful navigation to map (v1 or v2 depending on user preference)
+ await page.waitForURL(/\/map(\/v[12])?/, { timeout: 10000 });
// Save authentication state
await page.context().storageState({ path: authFile });
diff --git a/e2e/v2/helpers/setup.js b/e2e/v2/helpers/setup.js
index 86b61417..922c6848 100644
--- a/e2e/v2/helpers/setup.js
+++ b/e2e/v2/helpers/setup.js
@@ -7,7 +7,7 @@
* @param {Page} page - Playwright page object
*/
export async function navigateToMapsV2(page) {
- await page.goto('/maps/v2');
+ await page.goto('/map/v2');
}
/**
diff --git a/e2e/v2/map/area-selection.spec.js b/e2e/v2/map/area-selection.spec.js
index 2dc6b7c9..9cab52d7 100644
--- a/e2e/v2/map/area-selection.spec.js
+++ b/e2e/v2/map/area-selection.spec.js
@@ -5,7 +5,7 @@ import { waitForMapLibre, waitForLoadingComplete } from '../helpers/setup.js'
test.describe('Area Selection in Maps V2', () => {
test.beforeEach(async ({ page }) => {
// Navigate to Maps V2 with specific date range that has data
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
diff --git a/e2e/v2/map/core.spec.js b/e2e/v2/map/core.spec.js
index 3fded569..9bd6840b 100644
--- a/e2e/v2/map/core.spec.js
+++ b/e2e/v2/map/core.spec.js
@@ -33,7 +33,7 @@ test.describe('Map Core', () => {
})
test('has valid initial center and zoom', async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
@@ -83,7 +83,7 @@ test.describe('Map Core', () => {
test.describe('Data Bounds', () => {
test('fits map bounds to loaded data', async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
@@ -96,7 +96,7 @@ test.describe('Map Core', () => {
test.describe('Lifecycle', () => {
test('cleans up and reinitializes on navigation', async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForLoadingComplete(page)
@@ -114,7 +114,7 @@ test.describe('Map Core', () => {
})
test('reloads data when changing date range', async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForLoadingComplete(page)
diff --git a/e2e/v2/map/interactions.spec.js b/e2e/v2/map/interactions.spec.js
index 60bfef2e..9110a038 100644
--- a/e2e/v2/map/interactions.spec.js
+++ b/e2e/v2/map/interactions.spec.js
@@ -9,7 +9,7 @@ import {
test.describe('Map Interactions', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForLoadingComplete(page)
await page.waitForTimeout(500)
diff --git a/e2e/v2/map/layers/advanced.spec.js b/e2e/v2/map/layers/advanced.spec.js
index 04dd482c..965164a4 100644
--- a/e2e/v2/map/layers/advanced.spec.js
+++ b/e2e/v2/map/layers/advanced.spec.js
@@ -3,12 +3,12 @@ import { closeOnboardingModal } from '../../../helpers/navigation.js'
test.describe('Advanced Layers', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2')
+ await page.goto('/map/v2')
await page.evaluate(() => {
localStorage.removeItem('dawarich-maps-maplibre-settings')
})
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await page.waitForTimeout(2000)
})
diff --git a/e2e/v2/map/layers/heatmap.spec.js b/e2e/v2/map/layers/heatmap.spec.js
index 9e36631d..20e8bd36 100644
--- a/e2e/v2/map/layers/heatmap.spec.js
+++ b/e2e/v2/map/layers/heatmap.spec.js
@@ -3,7 +3,7 @@ import { closeOnboardingModal } from '../../../helpers/navigation.js'
test.describe('Heatmap Layer', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await page.waitForTimeout(2000)
})
diff --git a/e2e/v2/map/layers/points.spec.js b/e2e/v2/map/layers/points.spec.js
index e1c662c9..30843556 100644
--- a/e2e/v2/map/layers/points.spec.js
+++ b/e2e/v2/map/layers/points.spec.js
@@ -9,7 +9,7 @@ import {
test.describe('Points Layer', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForLoadingComplete(page)
await page.waitForTimeout(1500)
diff --git a/e2e/v2/map/layers/routes.spec.js b/e2e/v2/map/layers/routes.spec.js
index b1b87e83..ad705fb9 100644
--- a/e2e/v2/map/layers/routes.spec.js
+++ b/e2e/v2/map/layers/routes.spec.js
@@ -11,7 +11,7 @@ import {
test.describe('Routes Layer', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
diff --git a/e2e/v2/map/performance.spec.js b/e2e/v2/map/performance.spec.js
index 002e5eff..20a9a51a 100644
--- a/e2e/v2/map/performance.spec.js
+++ b/e2e/v2/map/performance.spec.js
@@ -6,7 +6,7 @@ test.describe('Map Performance', () => {
test('map loads within acceptable time', async ({ page }) => {
const startTime = Date.now()
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
@@ -19,7 +19,7 @@ test.describe('Map Performance', () => {
})
test('handles large datasets efficiently', async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-01T00:00&end_at=2025-10-31T23:59')
+ await page.goto('/map/v2?start_at=2025-10-01T00:00&end_at=2025-10-31T23:59')
await closeOnboardingModal(page)
const startTime = Date.now()
diff --git a/e2e/v2/map/search.spec.js b/e2e/v2/map/search.spec.js
index 26e055f2..d1434e42 100644
--- a/e2e/v2/map/search.spec.js
+++ b/e2e/v2/map/search.spec.js
@@ -18,7 +18,7 @@ test.describe('Location Search', () => {
test.setTimeout(60000)
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await waitForMapLibre(page)
await waitForLoadingComplete(page)
diff --git a/e2e/v2/map/settings.spec.js b/e2e/v2/map/settings.spec.js
index b11baef2..60c46f3c 100644
--- a/e2e/v2/map/settings.spec.js
+++ b/e2e/v2/map/settings.spec.js
@@ -4,7 +4,7 @@ import { getLayerVisibility } from '../helpers/setup.js'
test.describe('Map Settings', () => {
test.beforeEach(async ({ page }) => {
- await page.goto('/maps/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
+ await page.goto('/map/v2?start_at=2025-10-15T00:00&end_at=2025-10-15T23:59')
await closeOnboardingModal(page)
await page.waitForTimeout(2000)
})
diff --git a/spec/requests/authentication_spec.rb b/spec/requests/authentication_spec.rb
index 4486e86c..b526ebd7 100644
--- a/spec/requests/authentication_spec.rb
+++ b/spec/requests/authentication_spec.rb
@@ -7,7 +7,7 @@ RSpec.describe 'Authentication', type: :request do
describe 'Route Protection' do
it 'redirects to sign in page when accessing protected routes while signed out' do
- get map_path
+ get map_v1_path
expect(response).to redirect_to(new_user_session_path)
end