// dictionary: deveui as key, count as value var abos_to_buy = {} var stripe_pk = ""; function validate(what, text) { if (what == 'alias') { var re = /^[a-zA-Z0-9 ]{1,25}$/; } else if (what == 'smsnumber') { var re = /^\+[0-9]{11,11}$/; } else if (what == 'minmax') { var re = /^[0-9]{1,6},[0-9]{1,6}$/; } 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 = ''; 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(val[0], 'years').format('DD.MM.YYYY') + '' + (val[1] / 100).toFixed(2) + '
Total CHF' + (total_amount).toFixed(2) + '
"; if (counter > 0) { $("#abos_verlaengern").html(abo_table); $("#charge_data").html(charge_data); $("#cart").addClass("is-active"); } } $( document ).ready(function() { abos_to_buy = {}; $(".show-modal").click(function() { $("#alias_exclamation").hide(); $("#smsnumber_exclamation").hide(); $("#minmax_exclamation").hide(); var alias = $(this).prev().html(); var deveui = $(this).prev().attr('id').replace("alias_",""); $('#deveui').html(deveui); var alarmactive = $('#alarmactive_'+deveui).html(); var smsnumber = $('#smsnumber_'+deveui).html(); var minmax = $('#minmax_'+deveui).html(); $("#alias").val(alias); console.log(alarmactive); if (alarmactive == "1") { $('#checkbox').prop('checked', true); } else { $('#checkbox').prop('checked', false); } $("#smsnumber").val(smsnumber); $("#minmax").val(minmax); $("#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_", ""); 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"); } } }); $(".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"); } } }); function add_years(dt, n) { return new Date(dt.setFullYear(dt.getFullYear() + n)); } $(".abo_pay").click(function () { if (Object.keys(abos_to_buy).length < 1) { return; } $.ajax({ url: "abocost", type: "POST", //send it through post method dataType: "json", data: JSON.stringify(abos_to_buy), success: function(response) { if (stripe_pk == "") { stripe_pk = response['stripe_pk']; loadStripeLibrary(); } HandleAbocostResponse(response['data']); }, error: function(xhr) { } }); }); $("#modal-close").click(function () { $("#modal").removeClass("is-active"); }); $("#modal-save").click(function() { var alarmactive = "0"; if ($('#checkbox').prop('checked')) { alarmactive = "1"; } // 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 (!validate('smsnumber',$('#smsnumber').val())) { $('#smsnumber_errormsg').html('Beispiel einer gültigen SMS Nummer: +41761234567'); $("#smsnumber").addClass("is-danger"); $("#smsnumber_exclamation").show(); is_valid = false; } else { $('#smsnumber_errormsg').html(''); $("#smsnumber").removeClass("is-danger"); $("#smsnumber_exclamation").hide(); } if (!validate('minmax',$('#minmax').val())) { $('#minmax_errormsg').html('Minium,Maximum, Beispiel: 20000,10000'); $("#minmax").addClass("is-danger"); $("#minmax_exclamation").show(); is_valid = false; } else { const minmaxArr = $('#minmax').val().split(","); if ((Number(minmaxArr[1]) > Number(minmaxArr[0])) || (minmaxArr[1] == '0')) { if ( ($('#minmax').val() != "0,0") && (Number(minmaxArr[1]) - Number(minmaxArr[0]) < 200)) { $('#minmax_errormsg').html('Differenz zwischen Maximum und Minimum muss mindestens 200g sein'); $("#minmax").addClass("is-danger"); $("#minmax_exclamation").show(); is_valid = false; } else { $('#minmax_errormsg').html(''); $("#minmax").removeClass("is-danger"); $("#minmax_exclamation").hide(); } } else { $('#minmax_errormsg').html('Maximum muss grösser als Minimum sein (oder 0)'); $("#minmax").addClass("is-danger"); $("#minmax_exclamation").show(); is_valid = false; } } if (!(is_valid)) { return; } $.ajax({ url: "save_scale_settings", type: "get", //send it through get method dataType: "json", data: { deveui: $('#deveui').html(), alias: $('#alias').val(), smsnumber: $("#smsnumber").val(), minmax: $("#minmax").val(), alarmactive: alarmactive }, success: function(response) { console.log('save success'); if (response.rc == 0) { $('#alias_'+$('#deveui').html()).html($('#alias').val()); var alarmactive = "0"; if ($('#checkbox').prop('checked')) { alarmactive = "1"; } $('#alarmactive_'+$('#deveui').html()).html(alarmactive); $('#smsnumber_'+$('#deveui').html()).html($('#smsnumber').val()); $('#minmax_'+$('#deveui').html()).html($('#minmax').val()); location.reload(true); } }, error: function(xhr) { console.log('save error'); //Do Something to handle error } }); console.log("save"); $("#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... console.log("loadStripeLibrary called..."); 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(stripe_pk); 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) console.log(result.error.message); $('#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. console.log("Payment succeeded!!!"); $('#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(); });