Historic District
About This Attraction
Rovinj Old Town is a charming area in the coastal city of Rovinj, Croatia. It is known for its narrow cobblestone streets and colorful buildings which date back to the Venetian period. A key attraction is the Church of St. Euphemia, where visitors can enjoy panoramic views of the Adriatic Sea. The old town does not have official opening hours as it is an open and public space, though individual shops and restaurants may have their own schedules.
Tourists often explore the local markets and art galleries that line the streets. There are also many cafes offering local cuisine and fresh seafood. As you stroll through the old town, take note of the historic architecture that reflects Rovinjs past under Venetian rule. Public transportation options are available for getting to and from Rovinj Old Town, making it a convenient stop on any travel itinerary.
Location Details
Address
Old Town, 52210 Rovinj, Croatia
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
St. Euphemias Basilica in Rovinj is a prominent landmark known for its stunning Baroque architecture.…
Learn More
Zlatni Rt Forest Park, also known as Punta Corrente, is a popular destination in Rovinj,…
Learn More
Trieste Cathedral, also known as the Cathedral of San Giusto, is a significant historical and…
Learn More
Piazza Unità dItalia is the largest square in Trieste, Italy, and one of the largest…
Learn More
Miramare Castle, located in Trieste, Italy, is a 19th-century castle set on the Gulf of…
Learn More
Sottomarina Beach in Chioggia, Italy, is a popular destination for both locals and tourists looking…
Learn More
The Cathedral of Chioggia, officially known as the Basilica of St. Mary of the Assumption,…
Learn More
The Soca River in Kobarid is a renowned destination for outdoor enthusiasts and nature lovers.…
Learn More
Palazzo Ducale in Genoa is a historic building that once served as the residence of…
Learn More
The Doges Palace in Venice is an iconic historic site that once served as the…
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';
}
});
});
}
});