Water Activity
About This Attraction
Gili Air offers several snorkeling spots that are perfect for both beginners and experienced snorkelers. The island is known for its clear waters and diverse marine life, including sea turtles, colorful fish, and coral reefs. Popular locations include the eastern shore near Bel Air Resort and the northern coast, which are easily accessible from the beach. Most snorkeling areas on Gili Air do not have specific opening hours, as they are natural sites, but its best to go during daylight for visibility and safety. Equipment can be rented from local shops across the island.
To get the most out of your snorkeling experience, consider joining a guided tour, which often includes multiple spots around Gili Air and nearby islands. These tours provide masks, snorkels, and sometimes fins, making them convenient for those who do not bring their own gear. Additionally, guides can point out interesting marine creatures that might be missed otherwise. Remember to respect the marine environment by not touching or stepping on corals. By following these tips and being mindful of the environment, you can enjoy a memorable snorkeling adventure in Gili Air.
Location Details
Address
Gili Air, North Lombok, West Nusa Tenggara, Indonesia
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
Free
Child
Free
Student
Free
Senior
Free
Opening Hours & Booking
Open
Days
Daily
Hours
08:00 - 17:00
Seasonality
Year-round
Booking
Booking Required?
No
Nearby Attractions
Gili Air, one of the three Gili Islands in Indonesia, is a peaceful destination that…
Learn More
Crystal Bay in Nusa Penida is a well-known destination for beach lovers and snorkelers. It…
Learn More
Prambanan Temple, located in Yogyakarta, Indonesia, is a remarkable example of ancient Hindu architecture. Built…
Learn More
Borobudur is a renowned Buddhist temple located in Central Java, Indonesia, near Yogyakarta. The temple…
Learn More
Ubud, located in the heart of Bali, Indonesia, is renowned for its lush rice terraces…
Learn More
Malioboro Street in Yogyakarta is a popular destination known for its array of shops, street…
Learn More
Kraton Palace, located in Yogyakarta, Indonesia, serves as the official residence of the Sultan. This…
Learn More
The Gili Air Night Market is a popular destination for both locals and tourists on…
Learn More
Gili Air Beach is a popular destination located on Gili Air, one of the three…
Learn More
Tanah Lot is a prominent cultural landmark located on the coast of Bali, Indonesia. Known…
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';
}
});
});
}
});