Shopping and Entertainment Complex
About This Attraction
Canal City Hakata is a large shopping and entertainment complex located in Fukuoka, Japan. It features a wide variety of stores, restaurants, and attractions spread over multiple floors. The complex also has a beautifully designed canal running through it, adding to its unique architecture. Visitors can enjoy various events and performances held regularly at this dynamic location. Canal City Hakata opening hours typically range from 10:00 AM to 9:00 PM for shops, but they may vary for restaurants and entertainment venues.
The complex is conveniently accessible by public transportation, making it an ideal destination for both locals and tourists. In addition to shopping, the facility offers cinemas, hotels, and even an indoor theater. With its diverse range of activities and services, Canal City Hakata provides something for everyone. Its a popular spot for families, couples, and solo travelers looking to spend an enjoyable day out. The centers layout makes it easy to navigate, ensuring a pleasant experience for all visitors.
Location Details
Address
1-2 Sumiyoshi, Hakata Ward, Fukuoka, 812-0018, Japan
Visitor Information
Pricing & Ratings
Ticket Prices
Adult
Free
Child
Free
Student
Free
Senior
Free
Opening Hours & Booking
Open
Days
Daily
Hours
10:00 AM - 9:00 PM
Seasonality
Year-round
Booking
Booking Required?
No
Nearby Attractions
Ohori Park in Fukuoka is a popular destination for both locals and tourists, offering a…
Learn More
Fukuoka Tower, located in Fukuoka City, Japan, stands as one of the tallest seaside towers…
Learn More
Haeundae Beach is one of the most popular tourist destinations in Busan, South Korea. Known…
Learn More
Jagalchi Fish Market in Busan is one of South Koreas largest seafood markets, located near…
Learn More
Gamcheon Culture Village in Busan is a must-see destination for visitors interested in art and…
Learn More
Andong Confucian Academy, also known as Dosan Seowon, is a significant historical site located in…
Learn More
Hahoe Folk Village, located in Andong, South Korea, is a well-preserved traditional village that offers…
Learn More
Universal Studios Japan, located in Osaka, is one of the countrys most popular theme parks,…
Learn More
Dotonbori is a popular tourist destination in Osaka, Japan, known for its vibrant nightlife and…
Learn More
Osaka Castle is a historic landmark situated in Osaka, Japan. It was originally built in…
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';
}
});
});
}
});