370 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			370 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| // 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 = '<table class="table is-bordered is-fullwidth" >';
 | |
|     abo_table += '<tr><th class="is-2">Alias</th><th>verlängern bis</th><th class="has-text-right">Betrag</th></tr>';
 | |
|     jQuery.each(ordered, function (index, val) {
 | |
|         counter += 1;
 | |
|         abo_table += '<tr><td>' + val[3] + '</td><td>' + moment(val[2], 'DD.MM.YYYY').add(val[0], 'years').format('DD.MM.YYYY') + '</td><td class="has-text-right">' + (val[1] / 100).toFixed(2) + '</td></tr>';
 | |
|         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 += '<tr><td>Total CHF</td><td></td><td class="has-text-right">' + (total_amount).toFixed(2) + '</td></tr>';
 | |
|     abo_table += "</table>";
 | |
|     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();
 | |
| });
 |