// dictionary: deveui as key, count as value var abos_to_buy = {} function validate(what, text) { if (what == 'alias') { var re = /^[a-zA-Z0-9 ]{1,25}$/; } return re.test(text); } function HandleAbocostResponse(data) { var ordered = Object.keys(data).sort().reduce( (obj, key) => { obj[key] = data[key]; return obj; }, {} ); counter = 0; total_amount = 0; charge_data = ''; console.log("Response: "); console.log(data); abo_table = ''; abo_table += ''; jQuery.each(ordered, function (index, val) { counter += 1; abo_table += ''; total_amount += (val[1] / 100); if (charge_data == '') { charge_data = index + ":" + val[0] + ":" + val[1]; } else { charge_data += "," + index + ":" + val[0] + ":" + val[1]; } }); abo_table += ''; abo_table += "
Aliasverlängern bisBetrag
' + val[3] + '' + moment(val[2], 'DD.MM.YYYY').add('years', val[0]).format('DD.MM.YYYY') + '' + (val[1] / 100).toFixed(2) + '
Total CHF' + (total_amount).toFixed(2) + '
"; if (counter > 0) { $("#abos_verlaengern").html(abo_table); console.log("charge_data: " + charge_data); $("#charge_data").html(charge_data); $("#cart").addClass("is-active"); } } $(document).ready(function () { abos_to_buy = {}; $(".show-modal").click(function () { $("#alias_exclamation").hide(); var alias = $(this).prev().html(); var deveui = $(this).prev().attr('id').replace("alias_", ""); $('#deveui').html(deveui); $("#alias").val(alias); $("#modal").addClass("is-active"); }); $("#cart-close").click(function () { $("#cart").removeClass("is-active"); }); $("#payment_notifier_close").click(function () { $("#payment_notifier").removeClass("is-active"); location.reload(true); }); $(".abo_plus").click(function () { var deveui = $(this).prev().attr('id').replace("abo_add_years_", ""); console.log(deveui); el = $(this).parent().find(".abo_add_years"); el_text = $(this).parent().parent().find(".abo_add_years_text"); counter = Number(el.html()); if (counter < 3) { counter = counter + 1; if (deveui in abos_to_buy) { abos_to_buy[deveui] += 1; } else { abos_to_buy[deveui] = 1; } el.html(counter); if (counter == 1) { el_text.html("+" + counter + " Jahr"); } else { el_text.html("+" + counter + " Jahre"); } } console.log("abos_to_buy: %o", abos_to_buy); }); $(".abo_minus").click(function () { var deveui = $(this).prev().attr('id').replace("abo_", ""); el = $(this).parent().find(".abo_add_years"); el_text = $(this).parent().parent().find(".abo_add_years_text"); counter = Number(el.html()); if (counter > 0) { counter = counter - 1; el.html(counter); if (deveui in abos_to_buy) { abos_to_buy[deveui] -= 1; if (abos_to_buy[deveui] == 0) { delete abos_to_buy[deveui]; } } if (counter == 0) { el_text.html(" "); } else if (counter == 1) { el_text.html("+" + counter + " Jahr"); } else { el_text.html("+" + counter + " Jahre"); } } console.log("deveui: %s", deveui); console.log("abos_to_buy: %o", abos_to_buy); }); function add_years(dt, n) { return new Date(dt.setFullYear(dt.getFullYear() + n)); } $(".abo_pay").click(function () { console.log(Object.keys(abos_to_buy).length); if (Object.keys(abos_to_buy).length < 1) { return; } loadStripeLibrary(); $.ajax({ url: "abocost", type: "POST", //send it through post method dataType: "json", data: JSON.stringify(abos_to_buy), success: function(response) { console.log("SUCCESS"); console.log(response); HandleAbocostResponse(response); }, error: function(xhr) { console.log("ERROR"); console.log(xhr); } }); }); $("#modal-close").click(function () { $("#modal").removeClass("is-active"); }); $("#modal-save").click(function () { // Validation Code var is_valid = true; if (!validate('alias', $('#alias').val())) { $('#alias_errormsg').html('Ungültige Bezeichnung; erlaubte Zeichen A-Z, 0-9 und Leerschlag'); $("#alias").addClass("is-danger"); $("#alias_exclamation").show(); is_valid = false; } else { $('#alias_errormsg').html(''); $("#alias").removeClass("is-danger"); $("#alias_exclamation").hide(); } if (!(is_valid)) { return; } $.ajax({ url: "save_tracker_settings", type: "get", //send it through get method dataType: "json", data: { deveui: $('#deveui').html(), alias: $('#alias').val() }, success: function (response) { if (response.rc == 0) { $('#alias_' + $('#deveui').html()).html($('#alias').val()); } }, error: function (xhr) { //Do Something to handle error } }); $("#modal").removeClass("is-active"); }); }); function loadStripeLibrary() { $.ajax({ url: "https://js.stripe.com/v3/", dataType: "script", async: false, // <-- This is the key success: function () { // all good... SetupStripe(); }, error: function () { throw new Error("Could not load script " + script); } }); } function SetupStripe() { // Set your publishable key: remember to change this to your live publishable key in production // See your keys here: https://dashboard.stripe.com/account/apikeys stripe = Stripe('pk_test_51Icq29K2XyHQRTs2DeltUIWrbFb5evfJVGaQzMv4r50g8Q7HAUkSFr7BBGv0aP1damXIhM6fZ4Yf9Wz0qW6TpTVi00dWcW7J1O'); elements = stripe.elements({ locale: "de" }); // Set up Stripe.js and Elements to use in checkout form style = { base: { color: "#32325d", } }; card = elements.create("card", { style: style }); card.mount("#card-element"); $("#card-errors-article").hide(); card.addEventListener('change', ({ error }) => { if (error) { $("#card-errors").text(error.message); $("#card-errors-article").show(); } else { $("#card-errors").text(""); $("#card-errors-article").hide(); } }); } function ConfirmPayment(clientSecret) { stripe.confirmCardPayment(clientSecret, { payment_method: { card: card, billing_details: { name: '{{ .UserName }}' } } }).then(function (result) { if (result.error) { // Show error to your customer (e.g., insufficient funds) $('#card-errors').text(result.error.message); $('#card-errors-article').show(); //Do Something to handle error EndPaymentProgress(); } else { // The payment has been processed! if (result.paymentIntent.status === 'succeeded') { // Show a success message to your customer // There's a risk of the customer closing the window before callback // execution. Set up a webhook or plugin to listen for the // payment_intent.succeeded event that handles any business critical // post-payment actions. $('#card-errors').text(""); $('#card-errors-article').hide(); $("#cart").removeClass("is-active"); EndPaymentProgress(); $('#payment_notifier').addClass('is-active'); } } }); } function StartPaymentProgress() { $("#cart-pay").attr("disabled", true).addClass("is-loading"); $("#cart-close").attr("disabled", true); } function EndPaymentProgress() { $("#cart-pay").attr("disabled", false).removeClass("is-loading"); $("#cart-close").attr("disabled", false); } function PayMe() { $.ajax({ url: "getstripepaymentintent", type: "get", //send it through get method dataType: "json", data: { charge_data: $("#charge_data").html() }, success: function (response) { if (response.rc == 0) { ConfirmPayment(response.stripeclientsecret); } }, error: function (xhr) { //Do Something to handle error EndPaymentProgress(); } }); } $('#cart-pay').on('click', function (ev) { StartPaymentProgress(); PayMe(); }); // draw all maps var woBischIcon = L.icon({ iconUrl: '/static/images/marker.png', iconSize: [64, 64], iconAnchor: [32, 64] }); var maps = []; $(document).ready(function () { $(".tracker").each(function (index) { deveui = $(this).find("div").first().attr("id"); lat = $(this).find("#lat").html(); lon = $(this).find("#lon").html(); var map = new L.Map('map_' + deveui, { crs: L.CRS.EPSG3857, zoomControl: false }); map.dragging.disable(); map.touchZoom.disable(); map.doubleClickZoom.disable(); map.scrollWheelZoom.disable(); map.boxZoom.disable(); map.keyboard.disable(); if (map.tap) map.tap.disable(); var url = 'https://wmts20.geo.admin.ch/1.0.0/ch.swisstopo.pixelkarte-farbe/default/current/3857/{z}/{x}/{y}.jpeg'; var tilelayer = new L.tileLayer(url); map.addLayer(tilelayer); map.attributionControl.setPrefix('Source: Swiss Federal Office of Topography') map.setView(L.latLng(lat, lon), 10); var marker = L.marker([lat, lon], { icon: woBischIcon }).addTo(map); maps.push(map); }); });