River
About This Attraction
The Pangani River, located in northeastern Tanzania, is a significant waterway flowing from the Kilimanjaro region to the Indian Ocean. It stretches over 500 kilometers and passes through various landscapes, including lush forests and arid savannas. The river is not only a crucial source of water for agricultural activities but also supports various forms of life, both aquatic and terrestrial. For those interested in Pangani River travel information, the river offers opportunities for canoeing and bird watching, making it an attractive destination for nature enthusiasts.
In addition to its natural beauty, the Pangani River holds historical importance. The town of Pangani, situated near the rivers mouth, has remnants of colonial-era buildings that reflect its past as a trade center. Today, visitors can explore these historical sites while enjoying the scenic views along the river. With its combination of natural and historical attractions, the Pangani River provides a unique experience for those visiting the area.
Location Details
Address
Pangani, Tanga Region, Tanzania
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
Free
Child
Free
Student
Free
Senior
Free
Opening Hours & Booking
Open
Days
Daily
Hours
24 hours
Seasonality
Year-round
Booking
Booking Required?
No
Nearby Attractions
Maziwe Island, located off the coast of Pangani, Tanzania, is a small marine sanctuary known…
Learn More
Vumawimbi Beach is located on Pemba Island, which is part of the Zanzibar Archipelago in…
Learn More
Ngezi Forest Reserve on Pemba Island is a protected area that covers approximately 1,440 hectares.…
Learn More
Misali Island, located off the coast of Pemba Island in Tanzania, is a small island…
Learn More
The Pemba Flying Fox Sanctuary, located on Pemba Island in Tanzania, is a vital conservation…
Learn More
Nungwi Beach is located on the northern tip of Zanzibar, Tanzania, and is renowned for…
Learn More
Prison Island, also known as Changuu Island, is located a short boat ride from Stone…
Learn More
Spice Farms in Zanzibar offer an educational and aromatic experience for visitors interested in learning…
Learn More
Stone Town, located on the island of Zanzibar, is a UNESCO World Heritage site known…
Learn More
Bagamoyo Historical Town, located on the coast of Tanzania, is an area rich in history…
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';
}
});
});
}
});