Museum
About This Attraction
The MAS Museum, located in Antwerp, Belgium, is a striking modern building that focuses on the citys history and its connections to the world. The museums full name, Museum aan de Stroom, reflects its location by the Scheldt River. Visitors can explore a variety of exhibits spread across ten floors, each offering insights into Antwerp's past as a major port and its cultural interactions over the centuries.
For those interested in practical MAS Museum travel information, the attraction is accessible by public transport and offers panoramic views from its rooftop terrace. Additionally, admission to the building and terrace is free, although there are fees for special exhibitions. The museum is open every day except Mondays, ensuring ample opportunity for visitors to enjoy its collections.
Location Details
Address
Hanzestedenplaats 1, 2000 Antwerp, Belgium
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
12 EUR
Child
0 EUR
Student
8 EUR
Senior
8 EUR
Opening Hours & Booking
Open
Days
Tuesday to Sunday
Hours
10:00 AM to 5:00 PM
Seasonality
Year-round
Booking
Booking Required?
No
Nearby Attractions
The Cathedral of Our Lady in Antwerp is a significant landmark known for its stunning…
Learn More
Antwerp Zoo, located in the heart of Antwerp, Belgium, is one of the oldest animal…
Learn More
The Atomium is a unique and iconic structure located in Brussels, Belgium. Built for the…
Learn More
The Grand Place in Brussels is a central square surrounded by opulent guildhalls, the Town…
Learn More
Manneken Pis is a famous bronze statue located in the heart of Brussels, Belgium. Created…
Learn More
The Royal Palace in Brussels is a prominent landmark and the official palace of the…
Learn More
The Nieuwe Kerk in Delft is a historic church that stands as a significant landmark…
Learn More
The Erasmus Bridge, located in Rotterdam, is an architectural landmark known for its unique design.…
Learn More
The Cube Houses in Rotterdam are an architectural marvel designed by Dutch architect Piet Blom.…
Learn More
Markthal in Rotterdam is a striking architectural landmark known for its large arch-shaped structure. Opened…
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';
}
});
});
}
});