// 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 += '| Alias | verlängern bis | Betrag | 
|---|
';
    jQuery.each(ordered, function (index, val) {
        counter += 1;
        abo_table += '| ' + val[3] + ' | ' + moment(val[2], 'DD.MM.YYYY').add(val[0], 'years').format('DD.MM.YYYY') + ' | ' + (val[1] / 100).toFixed(2) + ' | 
';
        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 += '| Total CHF |  | ' + (total_amount).toFixed(2) + ' | 
';
    abo_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();
});