Ilovexm24/www/js/main.js

386 lines
11 KiB
JavaScript
Raw Normal View History

2017-03-05 17:31:47 +01:00
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
///VARIABILI GLOBALI///
var FONTE = FONTE || {};
FONTE.dbName = "xm24";
FONTE.dbHandler;
2017-03-25 16:32:18 +01:00
FONTE.updatedCategoriesCount;
FONTE.updatedPostsCount;
FONTE.neededPostsCount;
2017-03-05 17:31:47 +01:00
FONTE.tagsPageInitiated = false;
FONTE.categoriesList = [8, 497];
FONTE.categories = {
ilove : [497,647,590], //ilove, 4mar, solid
info : [8,42,68,3], //ilove, 4mar, solid
2017-03-25 16:32:18 +01:00
};
FONTE.page_loaded = {
ilove : 0,
info : 0,
};
2017-03-05 17:31:47 +01:00
FONTE.hrefseguente = "";
FONTE.contentListId = '#mostralistainfo';
2017-03-25 16:32:18 +01:00
FONTE.contentListClass = '.news';
2017-03-05 17:31:47 +01:00
FONTE.ajaxError = false;
/*
* data ultimo aggiornamento
*/
function displayLastUpdateDate() {
2017-03-05 17:31:47 +01:00
var lastUpdate = window.localStorage.getItem('db_update_date');
if (lastUpdate) {
var data = lastUpdate.split('T');
var datagiorno = data[0];
var dataora = data[1];
$("#datadiritti").empty();
$("#datadirittiora").empty();
2017-03-25 16:32:18 +01:00
display_results("#datadiritti", datagiorno);
display_results("#datadirittiora", dataora);
2017-03-05 17:31:47 +01:00
if (data) {
$("#boxdata").css("display", "block");
}
} else {
toastr.warning('Warn: manca la data del tuo ultimo aggiornamento. Aggiorna al più presto.');
2017-03-05 17:31:47 +01:00
}
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
var paginacorrente = "";
function alterContent(url) {
paginacorrente = $("body").pagecontainer("getActivePage").attr("id");
switch (url) {
case '#index':
$("#navheader").addClass("hide");
$("#navfooter").addClass("hide");
break;
case '#ilove':
$("#navheader").removeClass("hide");
2017-03-25 16:32:18 +01:00
$("#navfooter").addClass("hide");
postsUpdate(FONTE.categories.ilove);
2017-03-05 17:31:47 +01:00
break;
case '#info':
$("#navheader").removeClass("hide");
$("#navfooter").addClass("hide");
2017-03-25 16:32:18 +01:00
postsUpdate(FONTE.categories.info);
2017-03-05 17:31:47 +01:00
break;
case '#events':
$("#navheader").removeClass("hide");
$("#navfooter").addClass("hide");
2017-03-18 19:32:26 +01:00
EVENTS.render();
break;
2017-03-05 17:31:47 +01:00
case '#aggiorna':
$("#navheader").removeClass("hide");
$("#navfooter").removeClass("hide");
// ultimoAggiornamento();
break;
case '#ultime':
case '#tag':
$("#navheader").removeClass("hide");
$("#navfooter").removeClass("hide");
break;
case '#quotidiano':
$("#navheader").removeClass("hide");
$("#navfooter").removeClass("hide");
myJsonRandomPost('#titolosingleR', '#mostracontentsingleR');
break;
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
// Alter the url according to the anchor's href attribute, and
// store the data-foo attribute information with the url
$.mobile.navigate(url);
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
/*///////////////utilities//////////////http://stackoverflow.com/questions/901115/how-can-i-get-query-string-values-in-javascript*/
function getParameterByName(name, url) {
if (!url) url = window.location.href;
name = name.replace(/[\[\]]/g, "\\$&");
2017-03-25 16:32:18 +01:00
var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"),
results = regex.exec(url);
2017-03-05 17:31:47 +01:00
if (!results) return null;
if (!results[2]) return '';
return decodeURIComponent(results[2].replace(/\+/g, " "));
}
function display_results(contenitore, messaggio) {
$(contenitore).text(messaggio);
2017-03-25 16:32:18 +01:00
}
2017-03-18 17:14:26 +01:00
2017-03-05 17:31:47 +01:00
$(function () {
$("form").submit(function () {
return false;
});
});
function benvenuta() {
$("#benvenuta").popup("open");
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
2017-03-18 15:43:44 +01:00
//function aggiornaora() {
// $("#aggiornaora").popup("open");
//};
2017-03-05 17:31:47 +01:00
function run() {
2017-03-05 17:31:47 +01:00
initStorage();
overlayblock();
if (checkConnection()) {
2017-03-25 16:32:18 +01:00
postsUpdate(FONTE.categories.info);
} else {
2017-03-25 16:32:18 +01:00
renderLastNews(FONTE.contentListClass, FONTE.categories.info);
2017-03-05 17:31:47 +01:00
}
2017-03-25 16:32:18 +01:00
}
2017-03-18 16:15:57 +01:00
2017-03-05 17:31:47 +01:00
/*per link in browser di default */
document.addEventListener("deviceready", onDeviceReady, false);
//le cose all'inizio
2017-03-18 17:14:26 +01:00
$(document).on("mobileinit", function () {
$("body").pagecontainer({
defaults: true
2017-03-18 17:14:26 +01:00
});
$(".ui-loader").loader({
defaults: true
});
2017-03-25 16:32:18 +01:00
$("input").button();
});
2017-03-18 17:14:26 +01:00
$(document).on("pagecontainerchange", function () {    
var current = $(".ui-page-active").prop("id");     // Remove active class from nav buttons
2017-03-25 16:32:18 +01:00
if(current == 'info' || current == 'ilove' || current == 'events'){
$("#navfooter").addClass("hide");
2017-03-19 12:59:23 +01:00
} else {
$("#navfooter").removeClass("hide");
}
console.log("current" + current);
$("[data-role='navbar'] a.ui-btn-active").removeClass("ui-btn-active");     // Add active class to current nav button
    
$("[data-role='navbar'] a").each(function () {
var href = $(this).prop("href");        
if (href.indexOf(current, href.length - current.length) !== -1) {            
$(this).addClass("ui-btn-active");        
}    
2017-03-18 17:14:26 +01:00
});
});
2017-03-18 17:14:26 +01:00
$(document).on("pagecreate", function () {
$("body > [data-role='panel']").panel();
$("body > [data-role='panel'] [data-role='listview']").listview();
$("body > [data-role='header']").toolbar();
$("body > [data-role='footer']").toolbar();
$("body > [data-role='navbar']").navbar();
$("#navfooter").navbar();
postInList();
});
2017-03-18 17:14:26 +01:00
/*per inizio navigazione*/
var Site = function () {
this.homepage = "#index"; // the default page that is loaded
this.init();
};
2017-03-18 17:14:26 +01:00
Site.prototype.init = function () {
var self = this;
$(document).ready(function () {
// default page if no hash given
// this changes the hash, so the event is fired
// no need to call self.navigate
window.location.hash = self.homepage;
2017-03-18 17:14:26 +01:00
});
};
2017-03-25 16:32:18 +01:00
// On document ready
$(function () {
// intercettaUrl();
// new Site();
// $(".minibox").click(function () {});
});
2017-03-18 17:14:26 +01:00
2017-03-05 17:31:47 +01:00
function onDeviceReady() {
// console.log('deviceready');
createDB();
run();
2017-03-05 17:31:47 +01:00
$("a.nav").on("click", function (event) {
// Prevent the usual navigation behavior
event.preventDefault();
hrefseguente = $(this).attr("href");
alterContent(hrefseguente);
});
2017-03-18 17:14:26 +01:00
// eliminare le due righe:
$("body > [data-role='header']").toolbar();
$("[data-role='navbar']").navbar();
2017-03-25 16:32:18 +01:00
//Non uso pageContent per non lanciare 2 volte il recupero dei dati da internet
$("#navheader").removeClass("hide");
$("#navfooter").addClass("hide");
}
2017-03-05 17:31:47 +01:00
function overlayblock() {
$(".overlaynero").toggleClass("hide");
}
/*///////////////fine utilities//////////////*/
var weburl = "http://www.ecn.org/xm24/";
var arrayTag = [];
/*/////finite variabili globali////////*/
function intercettaUrl() {
// LETTURA - Log the results of the navigate event
$(window).on("navigate", function (event, data) {
idPost = getParameterByName('id');
2017-03-25 16:32:18 +01:00
if (idPost !== "") {
2017-03-05 17:31:47 +01:00
myJsonPost(idPost, "#titolosingle", "#mostracontentsingle");
}
});
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function postInList() {
//SCRITTURA
$("body").on('click', '.listevoci li > a', function (event) {
// console.log("HUU_post in list");
var idOra = $(this).attr("data-post");
var _class = $(this).attr("class");
2017-03-05 17:31:47 +01:00
$("#titolosingle").empty();
$("#mostracontentsingle").empty();
//console.log(idOra);
myJsonPost(idOra, "#titolosingle", "#mostracontentsingle", _class);
2017-03-05 17:31:47 +01:00
// Prevent the usual navigation behavior
event.preventDefault();
/*se serve idTAg, mettiamolo nell'url!! e anche nella page!*/
2017-03-25 16:32:18 +01:00
$("#singleQpost").attr("id", '#singleQpost?id=' + idOra);
2017-03-05 17:31:47 +01:00
$(":mobile-pagecontainer").pagecontainer("load", '#singleQpost' + idOra, {
showLoadMsg: false
});
$("#navfooter").removeClass("hide");
2017-03-05 17:31:47 +01:00
location.hash = '#singleQpost?id=' + idOra;
});
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function cercaMe() {
var input_text = $("input.cerca").val();
input_text = encodeURIComponent(input_text);
var jsonurl = weburl + "wp-json/wp/v2/posts?per_page=10&search=" + input_text + "";
2017-03-05 17:31:47 +01:00
$(".listresult").empty();
$("body").pagecontainer("change", "#ricerca");
$.mobile.loading('show');
var lastUpdate = window.localStorage.getItem('db_update_date');
if (lastUpdate) {
var lastUpdateDate = Date.parse(lastUpdate);
$.ajax({
2017-03-25 16:32:18 +01:00
dataType: "json",
url: jsonurl,
success: function (data) {
2017-03-05 17:31:47 +01:00
var items = [];
$.each(data, function (key, val) {
var id = val.id;
var time = val.modified;
var title = val.title.rendered;
var url = val.guid.rendered;
var tag = data.tags;
var splitTime = time.split("T");
var cleanTime = splitTime[0];
var dTime = new Date(time);
if (dTime.getTime() <= lastUpdateDate) {
//key mi dice l'indice'
2017-03-18 17:54:19 +01:00
items.push("<li><a href='#singleQpost' data-post='" + id + "'>" + title + "</a><br/><small>" + cleanTime + "</small></li>");
2017-03-05 17:31:47 +01:00
} else {
2017-03-18 17:54:19 +01:00
items.push("<p><a href='#' onclick='aggiornaora();' style='color:#666;' data-post='" + id + "'>" + title + "</a><br/><small>" + cleanTime + "</small></p>");
2017-03-05 17:31:47 +01:00
}
});
$("<ul/>", {
2017-03-25 16:32:18 +01:00
"class": "my-new-list",
html: items.join("")
2017-03-05 17:31:47 +01:00
}).prependTo(".listresult");
$.mobile.loading('hide');
2017-03-25 16:32:18 +01:00
},
error: JSONErrorHandler
2017-03-05 17:31:47 +01:00
});
} else {
toastr.error('Err: ERR_NOUPDATE');
2017-03-05 17:31:47 +01:00
}
}
function findImg(htmlString) {
var pos = htmlString.indexOf('<img ');
while (pos != -1) {
pos += 5;
htmlString = [htmlString.slice(0, pos), ' onerror="imgNotFound(this);" ', htmlString.slice(pos)].join('');
pos = htmlString.indexOf('<img ', pos);
}
return htmlString;
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function imgNotFound(img) {
var parent = $(img).parent();
parent.empty();
2017-03-25 16:32:18 +01:00
parent.append('<span>Immagine disponibile online.</span>');
}
2017-03-05 17:31:47 +01:00
function JSONErrorHandler(jqXHR, textStatus, errorThrown) {
if (!FONTE.ajaxError) {
var errMsg = "Err: ";
if(jqXHR.status === 404) {
errMsg += "Sito non raggiungibile. ";
}
toastr.error(errMsg);
2017-03-05 17:31:47 +01:00
FONTE.ajaxError = true;
}
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function cerca() {
var ret = checkConnection('ERR_CERCA');
2017-03-18 16:15:57 +01:00
if (ret) {
2017-03-05 17:31:47 +01:00
cercaMe();
2017-03-18 16:15:57 +01:00
}
return ret;
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function segnalaBug() {
return checkConnection('ERR_SEGNALA');
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function mostraEsperto() {
var ret = checkConnection('ERR_ESPERTO');
if (ret) {
2017-03-05 17:31:47 +01:00
myJsonPage(2167, '#espertotitle', '#mostraesperto');
}
2017-03-18 16:15:57 +01:00
return ret;
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function checkAndUpdate() {
var ret = checkConnection('ERR_ESPERTO');
if (ret) {
2017-03-05 17:31:47 +01:00
update();
}
2017-03-18 16:15:57 +01:00
return ret;
2017-03-25 16:32:18 +01:00
}
2017-03-05 17:31:47 +01:00
function checkAndReset() {
var ret = checkConnection('ERR_ESPERTO');
if (ret) {
2017-03-05 17:31:47 +01:00
resetAndUpdate();
2017-03-18 16:15:57 +01:00
}
return ret;
2017-03-25 16:32:18 +01:00
}