Browse Source

Nows uses deferred.promise, and recognizes 'keypress' for history.

devel
Jonathan Rosenbaum 10 years ago
parent
commit
26a0721620
  1. 228
      js/transaction.js

228
js/transaction.js

@ -17,8 +17,9 @@ $(function() {
// Add focus for easier tab browsing // Add focus for easier tab browsing
// use .paid parent and hover & classes // use .paid parent and hover & classes
// If page has not been reloaded after a shop period ends, prevent edit from working. // 1. If page has not been reloaded after a shop period ends, prevent edit from working.
// Note: create transaction covered via a mysql_error()), but with a reload - header("Refresh:0;") // Note: create transaction covered via a mysql_error()), but with a reload - header("Refresh:0;")
// 2. Don't send event signal to the save button when shop is open
$('[href*="trans_id="]').click(function(e){ $('[href*="trans_id="]').click(function(e){
var remember_me; var remember_me;
$.post("json/transaction.php", {shop_exist: 1}, function(data) { $.post("json/transaction.php", {shop_exist: 1}, function(data) {
@ -27,11 +28,13 @@ $(function() {
var start_new_shop = "Start New Shop"; var start_new_shop = "Start New Shop";
$("#current_shop").html("&nbsp<a href='shop_log.php'>" + start_new_shop + "</a>"); $("#current_shop").html("&nbsp<a href='shop_log.php'>" + start_new_shop + "</a>");
} else { } else {
// First successful click
remember_me = "unbind"; remember_me = "unbind";
} }
}); });
if (remember_me == "unbind") { if (remember_me == "unbind") {
$('[href*="trans_id="]').on('click'); // Second successful click
//$('[href*="trans_id="]').on('click');
} }
else { else {
e.preventDefault(); e.preventDefault();
@ -39,7 +42,7 @@ $(function() {
} ); } );
// Do the same thing as previously, but for editing a transaction (could make a function :) // Do the same thing as previously, but for editing a transaction (could make a function :)
$('#save_transaction').click(function(e){ $('#save_transaction').on("click keypress", function(e){
var remember_me; var remember_me;
$.post("json/transaction.php", {shop_exist: 1}, function(data) { $.post("json/transaction.php", {shop_exist: 1}, function(data) {
@ -51,7 +54,7 @@ $(function() {
} }
}); });
if (remember_me == "unbind") { if (remember_me == "unbind") {
$('#save_transaction').on('click'); $('#save_transaction').on('click keypress');
} }
else { else {
e.preventDefault(); e.preventDefault();
@ -66,7 +69,7 @@ $(function() {
open_shop = data; open_shop = data;
var start_new_shop = "Start New Shop"; var start_new_shop = "Start New Shop";
$("input[name='Submit43']").click(function(){ $("input[name='Submit43']").on("click keypress", function(){
$("#current_shop").html("&nbsp<a href='shop_log.php'>" + start_new_shop + "</a>"); $("#current_shop").html("&nbsp<a href='shop_log.php'>" + start_new_shop + "</a>");
event.preventDefault(); event.preventDefault();
}); });
@ -456,90 +459,99 @@ $(function() {
// On save (or close) check for errors // On save (or close) check for errors
function save_or_close(button_choice, type_of_button) { function save_or_close(button_choice, type_of_button) {
//function error_handler(input,error_span,error,error_text,event) // Deferred Promise, since we don't know when the click will be made,
var err1 = 0, err2 = 0, err3 = 0, err4 = 0, err5 = 0, err6 = 0, err7 = 0, err8 = 0; // it is an asynchronous function, and we need to know the returned result.
var dfd = $.Deferred();
$(button_choice).on("click keypress", function(e) {
$(button_choice).click(function(e) { //function error_handler(input,error_span,error,error_text,event)
var err1 = 0, err2 = 0, err3 = 0, err4 = 0, err5 = 0, err6 = 0, err7 = 0, err8 = 0;
console.log(e.which);
// sold_to error if (e.which === 13 || e.which === 1) {
if ( !$("[name='sold_to']").is("span") ) { // Patron already performed transaction and isn't logged in
if ( !$("#anonymous").prop("checked") ) { // sold_to error
if (sold_to.length) { if ( !$("[name='sold_to']").is("span") ) { // Patron already performed transaction and isn't logged in
err1 = error_handler(sold_to.val(), sold_to_error, "no_selection", "*Required&nbsp;&nbsp;&nbsp;",e); if ( !$("#anonymous").prop("checked") ) {
if (sold_to.length) {
err1 = error_handler(sold_to.val(), sold_to_error, "no_selection", "*Required&nbsp;&nbsp;&nbsp;",e);
}
} else if ( $("#anonymous").prop("checked") ) {
sold_to_error.hide();
} }
} else if ( $("#anonymous").prop("checked") ) {
sold_to_error.hide();
} }
}
// sold_by error // sold_by error
err2 = error_handler(sold_by.val(), sold_by_error, "no_selection", "*Required",e); err2 = error_handler(sold_by.val(), sold_by_error, "no_selection", "*Required",e);
// for storage transactions don't check for payment_type and payment until there is an actual date // for storage transactions don't check for payment_type and payment until there is an actual date
var payment_type = $("input[name='payment_type']"); // payment_type variable needs to be kept within scope var payment_type = $("input[name='payment_type']"); // payment_type variable needs to be kept within scope
var payment_type_result; var payment_type_result;
if ( date.val() != "0000-00-00" && date.val() != "") { if ( date.val() != "0000-00-00" && date.val() != "") {
// payment type error // payment type error
if (payment_type.length) { if (payment_type.length) {
payment_type.each(function(){ if ($(this).prop("checked") == true) { payment_type_result = true; } }); payment_type.each(function(){ if ($(this).prop("checked") == true) { payment_type_result = true; } });
err3 = error_handler(payment_type_result, payment_type_error, undefined,"*Required",e); err3 = error_handler(payment_type_result, payment_type_error, undefined,"*Required",e);
} }
// payment error // payment error
if (amount.length) { if (amount.length) {
err4 = error_handler(amount.val(), payment_error, "","*Required",e); err4 = error_handler(amount.val(), payment_error, "","*Required",e);
} }
} }
// description error // description error
if ( $("#transaction_type").val() != "Deposit" ) { // Deposit description is implicit if ( $("#transaction_type").val() != "Deposit" ) { // Deposit description is implicit
err5 = error_handler(description.val(), description_error, "","*Required: a detailed description",e); err5 = error_handler(description.val(), description_error, "","*Required: a detailed description",e);
} }
// check number error - error_handler() // check number error - error_handler()
var check_number = $("#check_number"); // check number variable needs to be within this scope var check_number = $("#check_number"); // check number variable needs to be within this scope
if ( check_number.is(":visible") || payment_type_result == "check" ) { if ( check_number.is(":visible") || payment_type_result == "check" ) {
if (check_number.val() == undefined) { if (check_number.val() == undefined) {
err6 = error_handler(check_number.val(), check_number_error, undefined,"*Required: enter a check number",e); err6 = error_handler(check_number.val(), check_number_error, undefined,"*Required: enter a check number",e);
} else { } else {
err6 = error_handler(check_number.val(), check_number_error, "","*Required: enter a check number",e); err6 = error_handler(check_number.val(), check_number_error, "","*Required: enter a check number",e);
} }
} else if ( !check_number.is(":visible") ) { } else if ( !check_number.is(":visible") ) {
check_number_error.hide(); check_number_error.hide();
} }
// quantity // quantity
err7 = error_handler(quantity.val(), quantity_error, "","*Required",e); err7 = error_handler(quantity.val(), quantity_error, "","*Required",e);
// date // date
if (!$("#date_startstorage").length) { // not a storage transaction if (!$("#date_startstorage").length) { // not a storage transaction
err8 = error_handler(date.val(), date_error, "","*Required",e); err8 = error_handler(date.val(), date_error, "","*Required",e);
}
// Decides whether or not to post a parent error message (at the top)
if ( ( err1 + err2 + err3 + err4 + err5 + err6 + err7) > 0) {
if ( !transaction_error.is(":visible") ) {
transaction_error.show();
} }
if (type_of_button === "Save") {
transaction_error.text("Correct errors below"); // Decides whether or not to post a parent error message (at the top)
if ( ( err1 + err2 + err3 + err4 + err5 + err6 + err7) > 0) {
if ( !transaction_error.is(":visible") ) {
transaction_error.show();
}
if (type_of_button === "Save") {
transaction_error.text("Correct errors below");
} else {
transaction_error.text("Correct errors below, and save before closing.");
}
} else { } else {
transaction_error.text("Correct errors below, and save before closing."); transaction_error.hide();
dfd.resolve("Success");
} }
} else {
transaction_error.hide(); } // event type
}
}); });
if ( ( err1 + err2 + err3 + err4 + err5 + err6 + err7) == 0) { return dfd.promise()
return "Success";
}
} // end function save_or_close } // end function save_or_close
@ -590,53 +602,59 @@ $(function() {
var check_number_error = $("#check_number_error"); var check_number_error = $("#check_number_error");
//var check_number = $("#check_number").on("input"); //var check_number = $("#check_number").on("input");
var result = save_or_close($("#save_transaction"), "Save");
// note: it is possible to close with all error conditions being satisfied, // note: it is possible to close with all error conditions being satisfied,
// however, it is no biggy. // however, it is no biggy.
save_or_close($("#close_transaction"), "Close"); save_or_close($("#close_transaction"), "Close");
// Save history // Using deferred.promise .. pretty cool
if (result === "Success") { save_or_close($("#save_transaction"), "Save").done(function(success) {
transaction_id = $("input[name='transaction_id']").val(); console.log(success);
// store the transaction's history // Save history
var transaction_history = []; if (success === "Success") {
var current_transaction =
{ transaction_id = $("input[name='transaction_id']").val();
date_startstorage: $("#date_startstorage").val(),
date: $("#date").val(), // store the transaction's history
transaction_type: $("#transaction_type").val(), var transaction_history = [];
amount: $("#amount").val(), var current_transaction =
description: $("#description").val(), {
sold_to: $("#sold_to").val(), date_startstorage: $("#date_startstorage").val(),
sold_by: $("[name='sold_by']").val(), date: $("#date").val(),
quantity: $("#quantity").val(), transaction_type: $("#transaction_type").val(),
shop_id: $("#shop_id").val(), amount: $("#amount").val(),
payment_type: $("#payment_type").val(), description: $("#description").val(),
check_number: $("#check_number").val(), sold_to: $("#sold_to").val(),
anonymous: $("#anonymous").val() sold_by: $("[name='sold_by']").val(),
}; quantity: $("#quantity").val(),
shop_id: $("#shop_id").val(),
// check for prior transactions payment_type: $("#payment_type").val(),
$.post("json/transaction.php",{ history_select: 1, transaction_id: transaction_id }, function(data) { check_number: $("#check_number").val(),
anonymous: $("#anonymous").val()
if (data === "First Transaction") { };
console.log(data);
// check for prior transactions
$.post("json/transaction.php",{ history_select: 1, transaction_id: transaction_id }, function(data) {
if (data === "First Transaction") {
console.log(data);
transaction_history.push(current_transaction);
} else {
transaction_history = $.parseJSON(data);
transaction_history.push(current_transaction); transaction_history.push(current_transaction);
} else { //var obj = $.parseJSON(data);
transaction_history = $.parseJSON(data); }
transaction_history.push(current_transaction);
//var obj = $.parseJSON(data);
}
} ); } );
$.post("json/transaction.php",{ history_update: 1, transaction_id: transaction_id, history: transaction_history });
$.post("json/transaction.php",{ history_update: 1, transaction_id: transaction_id, history: transaction_history });
} // End Save History
} // End Save History
}) // end function save_and_close
// On reload if patron isn't logged in replace pull-down with patrons name // On reload if patron isn't logged in replace pull-down with patrons name
@ -764,7 +782,7 @@ $(function() {
// If storage date is NULL, update to 0000-00-00 on save // If storage date is NULL, update to 0000-00-00 on save
$("#save_transaction").click(function(e) { $("#save_transaction").on("click keypress", function(e) {
if ( !$("#date").val().length ) { if ( !$("#date").val().length ) {
$("#date").val("0000-00-00"); $("#date").val("0000-00-00");

Loading…
Cancel
Save