const form = document.getElementById('merge-form'); const calendars = document.getElementById('calendars'); const addCalendarButton = document.getElementById('add-calendar'); const refreshCalendarsButton = document.getElementById('refresh-calendars'); const result = document.getElementById('result'); let calendarIndex = 1; let mergedUrl = ''; // Function to validate URL format function isValidUrl(url) { const urlPattern = /^(https?:\/\/[^\s$.?#].[^\s]*)$/; // Regex for URL validation return urlPattern.test(url); } addCalendarButton.addEventListener('click', () => { const newCalendar = document.createElement('div'); newCalendar.className = 'calendar'; newCalendar.innerHTML = ` `; calendars.appendChild(newCalendar); calendarIndex++; }); form.addEventListener('submit', (event) => { event.preventDefault(); const linkGroupName = document.getElementById('link-group-name').value; const calendarsData = []; let valid = true; // Flag to track URL validity for (let i = 0; i < calendarIndex; i++) { const prefix = document.getElementById(`prefix-${i}`); const override = document.getElementById(`override-${i}`); const url = document.getElementById(`url-${i}`); if (prefix && override && url) { // Validate the URL if (!isValidUrl(url.value)) { valid = false; // Set flag to false if any URL is invalid alert(`Invalid URL format for calendar ${i + 1}: ${url.value}`); } else { calendarsData.push({ prefix: prefix.value, override: override.checked, url: url.value }); } } } if (valid) { fetch('/merge', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ linkGroupName, calendars: calendarsData }) }) .then((response) => { if (!response.ok) { return response.json().then(err => { throw err; }); } return response.json(); }) .then((data) => { mergedUrl = data.url; result.innerHTML = `Merged calendar URL: ${data.url}`; console.log('Links added successfully!'); }) .catch((error) => { console.error('Error:', error); result.innerHTML = `Error merging calendars: ${error.message || 'Unknown error'}` }); } }); // Refresh button event listener refreshCalendarsButton.addEventListener('click', () => { if (mergedUrl) { // Extract the calendar ID from the URL const calendarId = mergedUrl.split('/').pop(); // Call the server to refresh the merged calendar fetch(`/refresh/${calendarId}`, { method: 'POST' }) .then((response) => { if (!response.ok) { throw new Error('Failed to refresh calendar data'); } return response.json(); }) .then((data) => { result.innerHTML = `Merged calendar URL: ${mergedUrl}`; console.log('Calendar data refreshed successfully!'); }) .catch((error) => { console.error('Error refreshing calendar data:', error); result.innerHTML = `Error refreshing calendar data: ${error.message || 'Unknown error'}`; }); } else { alert('No merged calendar URL available to refresh.'); } });