Natural Landmark
About This Attraction
The Maspalomas Dunes in Gran Canaria offer a unique landscape that resembles a mini desert by the sea. These dunes are part of a protected nature reserve, spanning approximately 400 hectares. Travelers can enjoy a peaceful walk through the sandy terrain, which is home to various plant species and wildlife. For those seeking more structured activities, camel rides are available, providing a memorable way to experience the area.
Located on the southern coast of Gran Canaria, Maspalomas Dunes are easily accessible from nearby tourist areas. The dunes connect to Maspalomas Beach, where visitors can relax by the ocean. There are several viewing points around the dunes for photography or simply enjoying the view. For more detailed Maspalomas Dunes travel information, local tourist offices provide maps and guidance.
Location Details
Address
Maspalomas, 35100 San Bartolomé de Tirajana, Gran Canaria, Spain
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
Free
Child
Free
Student
Free
Senior
Free
Opening Hours & Booking
Open
Days
Daily
Hours
Open 24 hours
Seasonality
Year-round
Booking
Booking Required?
No
Nearby Attractions
Roque Nublo is a prominent natural landmark located in the center of Gran Canaria, Spain.…
Learn More
Las Palmas Old Town, also known as Vegueta, is a historic area in Gran Canaria…
Learn More
The Auditorio de Tenerife is an architectural marvel located in Santa Cruz de Tenerife, Spain.…
Learn More
Anaga Rural Park is a protected natural area located in the northeastern part of Tenerife,…
Learn More
Teide National Park in Tenerife is a UNESCO World Heritage site known for its stunning…
Learn More
Siam Park in Tenerife is a popular water park known for its Thai-inspired architecture and…
Learn More
Loro Parque in Tenerife is a popular zoo and aquarium that attracts visitors from around…
Learn More
Cofete Beach is a remote and stunning location on the island of Fuerteventura, part of…
Learn More
Betancuria, located on the island of Fuerteventura in the Canary Islands, is known for its…
Learn More
Corralejo Natural Park, located on the island of Fuerteventura in the Canary Islands, is renowned…
Learn More
";
}
// Initialize modal controls
const initModalControls = function() {
console.log('Initializing modal controls');
const modal = document.getElementById('attraction-modal');
const closeBtn = document.querySelector('.attraction-modal-close');
if (closeBtn) {
closeBtn.addEventListener('click', function() {
modal.style.display = 'none';
document.body.style.overflow = '';
});
}
window.addEventListener('click', function(event) {
if (event.target === modal) {
modal.style.display = 'none';
document.body.style.overflow = '';
}
});
// Make attraction cards clickable
const attractionCards = document.querySelectorAll('.attraction-card');
console.log('Found ' + attractionCards.length + ' attraction cards');
attractionCards.forEach(card => {
card.addEventListener('click', function(e) {
openModalWithCardData(this);
});
});
};
// Function to open modal with card data
const openModalWithCardData = function(card) {
// Get data from hidden div
const data = card.querySelector('.attraction-full-data');
if (!data) {
console.error('No attraction data found in card');
return;
}
const modal = document.getElementById('attraction-modal');
if (!modal) {
console.error('Modal element still not found after creation attempt');
return;
}
// Helper function to safely get element text
function getElementText(selector) {
const element = data.querySelector(selector);
return element ? element.textContent : '';
}
try {
// Basic Info
document.getElementById('attraction-modal-title').textContent = getElementText('.attraction-name');
document.getElementById('attraction-modal-type').textContent = getElementText('.attraction-type-full');
document.getElementById('attraction-modal-description').textContent = getElementText('.attraction-description-full');
// Reset all containers to hidden
['attraction-modal-hours-container', 'attraction-modal-price-container',
'attraction-modal-address-container', 'attraction-modal-image-container'].forEach(id => {
const container = document.getElementById(id);
if (container) container.style.display = 'none';
});
// Rating
const ratingText = getElementText('.attraction-rating-full');
if (ratingText) {
const ratingValue = parseFloat(ratingText);
if (!isNaN(ratingValue)) {
const ratingValueEl = document.getElementById('attraction-modal-rating-value');
const ratingFillEl = document.getElementById('attraction-modal-rating-fill');
if (ratingValueEl) ratingValueEl.textContent = ratingValue.toFixed(1) + '/10';
if (ratingFillEl) ratingFillEl.style.width = (ratingValue * 10) + '%';
}
}
// Show the modal
modal.style.display = 'block';
document.body.style.overflow = 'hidden'; // Prevent background scrolling
console.log('Modal opened successfully');
} catch (error) {
console.error('Error opening modal:', error);
}
};
// Try to create the modal
const created = createModal();
console.log('Modal created:', created);
// If not created (already exists), initialize the controls
if (!created) {
initModalControls();
}
// Also initialize distance toggle
const distanceToggle = document.getElementById('distance-unit-toggle');
if (distanceToggle) {
distanceToggle.addEventListener('change', function() {
const showKm = this.checked;
// Update toggle labels
const labels = document.querySelectorAll('.toggle-label');
if (labels.length >= 2) {
labels[0].style.opacity = showKm ? '0.5' : '1';
labels[1].style.opacity = showKm ? '1' : '0.5';
}
// Update all distance displays
document.querySelectorAll('.nearby-attraction-card').forEach(card => {
const kmEl = card.querySelector('.distance-km');
const miEl = card.querySelector('.distance-mi');
if (kmEl && miEl) {
kmEl.style.display = showKm ? 'inline' : 'none';
miEl.style.display = showKm ? 'none' : 'inline';
}
});
});
}
});