diff --git a/.gitignore b/.gitignore index 9ed2123..20229eb 100644 --- a/.gitignore +++ b/.gitignore @@ -1,6 +1,7 @@ __pycache__/ +test/ conf/*custom.ini .directory *.swp *~ -*.pyc \ No newline at end of file +*.pyc diff --git a/frontend/frontend.js b/frontend/frontend.js index 54231a1..b4a9a59 100644 --- a/frontend/frontend.js +++ b/frontend/frontend.js @@ -1,32 +1,65 @@ -// Require moment.js (with locales) -function Get(yourUrl){ - var Httpreq = new XMLHttpRequest(); - Httpreq.open("GET",yourUrl,false); - Httpreq.send(null); - return Httpreq.responseText; +function zerocalcareDisplay() { + + zerocalcareOutput = document.getElementById('zerocalcareOutput'); + + if (xhr.readyState == 4 && xhr.status == 200) { + + var json_obj = JSON.parse(xhr.responseText); + + for (i in json_obj) { + // Future improvements needed for a better backend output date in ISO format + // Now we have to parse the string :( very very ugly + var datetime = json_obj[i]['DATETIME']; + var moments = datetime.split(' '); + + var dateMoments = moments[0].split('-'); + var date = {}; + date['Y'] = dateMoments[0]; + date['M'] = dateMoments[1]; + date['MM'] = ['gennaio', 'febbraio', 'marzo', 'aprile', 'maggio', 'giugno', 'luglio', 'agosto', 'settembre', 'ottobre', 'novembre', 'dicembre'][date['M'] - 1]; + date['D'] = dateMoments[2]; + var time = moments[1]; + + var eventElement = document.createElement('div'); + + var titleElement = document.createElement('h5'); + titleElement.appendChild(document.createTextNode(json_obj[i]['NAME'])); + titleElement.style.fontStyle = 'italic'; + titleElement.classList.add('widget-title'); + + var dateElement = document.createElement('div'); + dateElement.appendChild(document.createTextNode('📅 ' + date['D'] + ' ' + date['MM'] + ' ' + date['Y'])); + + var timeElement = document.createElement('div'); + var timeString = (json_obj[i]['ALL_DAY'] == true) ? 'Tutto il giorno' : ('ore ' + time.substring(0, 5)); + timeElement.appendChild(document.createTextNode('⏰ ' + timeString)); + + // add if location is not empty -- default location should be selected by backend + var locationElement = document.createElement('div'); + if (typeof json_obj[i]['LOCATION'] !== 'undefined' && json_obj[i]['LOCATION'] != '') { + var locationString = json_obj[i]['LOCATION']; + } + else { + var locationString = 'Officina Informatica'; + } + locationElement.appendChild(document.createTextNode('📍 ' + locationString)); + + eventElement.appendChild(titleElement); + eventElement.appendChild(dateElement); + eventElement.appendChild(timeElement); + eventElement.appendChild(locationElement); + zerocalcareOutput.appendChild(eventElement); + } + } + else { + zerocalcareOutput.childNodes[0].textContent = 'API Error: Calendario non disponibile'; + } } -var json_obj = JSON.parse(Get("https://golem.linux.it/cgi/zerocalcare/main.py?interval=4weeks")); -console.log("this is the JSON: "+JSON.stringify(json_obj)); - -moment.locale('it'); -for (i in json_obj) { - var time_str; - var date = moment(json_obj[i]["DATETIME"]) - console.log(JSON.stringify(json_obj[i])); - document.write('