SmartX turn off warnings
[Biblio-RFID.git] / examples / selfcheck.js
index 1803949..a03d297 100644 (file)
@@ -16,12 +16,24 @@ if(!window.console) {
 var state;
 var scan_timeout;
 var pending_jsonp = 0;
+var only_reader = '';
 
 // timeout warning dialog
 var tick_timeout = 25; // s
 var tick_warning = 10; // s
 var tick = 0;
 
+function beep( message ) {
+       pending_jsonp++;
+       $.getJSON("/beep/" + message)
+       .done( function(data) {
+               pending_jsonp--;
+       })
+       .fail( function(data) {
+               pending_jsonp--;
+       });
+}
+
 function start_timeout() {
        $('#timeout').hide();
        tick = Math.round( tick_timeout * ( 1000 / tag_rescan ) );
@@ -36,11 +48,13 @@ function change_page(new_state) {
                        $('.checkin').show();
                        circulation_type = 'checkin';
                        borrower_cardnumber = 0; // fake
+                       only_reader = '/only/3M';
                } else if ( new_state == 'checkout' ) {
                        new_state = 'circulation'; // page has different name
                        $('.checkout').show();
                        $('.checkin').hide();
                        circulation_type = 'checkout';
+                       only_reader = '/only/3M';
                }
 
                state = new_state;
@@ -59,6 +73,7 @@ function change_page(new_state) {
                        book_barcodes = {};
                        $('ul#books').html(''); // clear book list
                        $('#books_count').html( 0 );
+                       only_reader = '/only/librfid';
                        scan_tags();
                }
 
@@ -69,7 +84,8 @@ function change_page(new_state) {
                        },end_timeout);
                }
 
-               if ( state == 'error' ) {
+               if ( state == 'error' || state == 'error-borrower' ) {
+                       beep( 'error page' );
                        window.setTimeout(function(){
                                //change_page('start');
                                location.reload();
@@ -85,11 +101,21 @@ function change_page(new_state) {
 }
 
 function got_visible_tags(data,textStatus) {
+       console.log('got_visible_tags', data,textStatus);
+       wait_counter = 0;
+       $('#working').hide();
+
        var html = 'No tags in range';
        if ( data.tags ) {
                html = '<ul class="tags">';
                $.each(data.tags, function(i,tag) {
                        console.debug( i, tag );
+
+                 if ( tag.hasOwnProperty('error') ) {
+                               html += 'ERROR ' + tag.sid + ' ' + tag.error;
+                               change_page('error-borrower');
+                 } else {
+
                        html += '<li><tt class="' + tag.security + '">' + tag.sid;
                        var content = tag.content || tag.borrower.cardnumber;
 
@@ -99,6 +125,8 @@ function got_visible_tags(data,textStatus) {
                                        link = 'catalogue/search.pl?q=';
                                } else if ( content.length == 12 && content.substr(0,2) == 20 ) {
                                        link = 'members/member.pl?member=';
+                               } else if ( tag.tag_type == 'SmartX' ) {
+                                       link = 'members/member.pl?member=';
                                } else {
                                        html += '<b>UNKNOWN TAG</b> '+content;
                                }
@@ -111,9 +139,12 @@ function got_visible_tags(data,textStatus) {
                                }
 
                                console.debug( 'calling', state, content );
-                               window[state]( content, tag.sid ); // call function with barcode
+                               window[state]( content, tag ); // call function with barcode
 
                        }
+
+                 } // not error
+
                });
                html += '</ul>';
 
@@ -132,13 +163,22 @@ function got_visible_tags(data,textStatus) {
        pending_jsonp--;
 };
 
+var wait_counter = 0;
+
 function scan_tags() {
        if ( pending_jsonp ) {
-               console.debug('scan_tags disabled ', pending_jsonp, ' requests waiting');
+               wait_counter++;
+               console.debug('scan_tags', 'tick', tick, 'pending_jsonp', pending_jsonp, ' wait_conter', wait_counter);
+               if ( wait_counter > 10 ) $('#working').show(); // tag_rescan = 200ms * 10 = 2s
        } else {
-               console.info('scan_tags');
+               console.info('scan_tags', 'tock', tick, only_reader, 'wait_counter', wait_counter, 'tick', tick);
                pending_jsonp++;
-               $.getJSON("/scan?callback=?", got_visible_tags);
+               $.getJSON("/scan"+only_reader+"?callback=?", got_visible_tags).fail( function(data) {
+                       console.error('scan error pending jsonp', pending_jsonp);
+                       pending_jsonp--;
+                       wait_counter = 0;
+                       $('#working').hide();
+               });
        }
 
        if ( tick > 0 ) {
@@ -179,10 +219,10 @@ var borrower_cardnumber;
 var circulation_type;
 var book_barcodes = {};
 
-function start( cardnumber ) {
+function start( cardnumber, tag ) {
 
-       if ( cardnumber.length != 12 || cardnumber.substr(0,2) != "20" ) {
-               console.error(cardnumber, ' is not borrower card');
+       if ( tag.tag_type != 'SmartX' && ( cardnumber.length != 12 || cardnumber.substr(0,2) != "20" ) ) {
+               console.error(cardnumber, 'is not borrower card', tag);
                return;
        }
 
@@ -196,10 +236,18 @@ function start( cardnumber ) {
                console.info('patron', data);
                fill_in( 'borrower_name', data['AE'] );
                fill_in( 'borrower_email', data['BE'] );
-               fill_in( 'hold_items',    data['fixed'].substr( 2 + 14 + 3 + 18 + ( 0 * 4 ), 4 ) ) * 1;
-               fill_in( 'overdue_items', data['fixed'].substr( 2 + 14 + 3 + 18 + ( 1 * 4 ), 4 ) ) * 1;
-               fill_in( 'charged_items', data['fixed'].substr( 2 + 14 + 3 + 18 + ( 2 * 4 ), 4 ) ) * 1;
-               fill_in( 'fine_items',    data['fixed'].substr( 2 + 14 + 3 + 18 + ( 3 * 4 ), 4 ) ) * 1;
+               fill_in( 'hold_items',    data['fixed'].substr( 2 + 14 + 3 + 18 + ( 0 * 4 ), 4 ) * 1 );
+               //fill_in( 'overdue_items', data['fixed'].substr( 2 + 14 + 3 + 18 + ( 1 * 4 ), 4 ) * 1 );
+               var overdue = data['fixed'].substr( 2 + 14 + 3 + 18 + ( 1 * 4 ), 4 ) * 1;
+               if ( overdue > 0 ) {
+                       overdue = '<span style="color:red">'+overdue+'</span>';
+                       beep( 'overdue: ' + overdue );
+               }
+               fill_in( 'overdue_items', overdue );
+               fill_in( 'charged_items', data['fixed'].substr( 2 + 14 + 3 + 18 + ( 2 * 4 ), 4 ) * 1 );
+               fill_in( 'fine_items',    data['fixed'].substr( 2 + 14 + 3 + 18 + ( 3 * 4 ), 4 ) * 1 );
+
+
                pending_jsonp--;
                change_page('borrower_info');
        }).fail( function(data) {
@@ -212,25 +260,32 @@ function borrower_info() {
        // nop
 }
 
-function circulation( barcode, sid ) {
+function circulation( barcode, tag ) {
        if ( barcode
                        && barcode.length == 10
                        && barcode.substr(0,3) == 130
                        && book_barcodes[barcode] != 1
+                       && tag.reader == '3M810'
        ) { // book, not seen yet
                book_barcodes[ barcode ] = 1;
                pending_jsonp++;
-               $.getJSON('/sip2/'+circulation_type+'/'+borrower_cardnumber+'/'+barcode+'/'+sid , function( data ) {
+               $.getJSON('/sip2/'+circulation_type+'/'+borrower_cardnumber+'/'+barcode+'/'+tag.sid , function( data ) {
                        console.info( circulation_type, data );
 
                        var color = 'red';
-                       var error = 'Transakcija neuspješna. Odnesite knjige na pult!';
+                       var message = 'Transakcija neuspješna. Odnesite knjige na pult!';
                        if ( data['fixed'].substr(2,1) == 1 ) {
                                color='green';
-                               error = '';
+                               message = circulation_type == 'checkout' ? 'Posuđeno' : 'Vraćeno';
+                       } else {
+                               beep( circulation_type + ': ' + data['AF'] );
+                       }
+
+                       if ( data['AF'] ) {
+                               message = data['AF'] + ' ' + message;
                        }
 
-                       $('ul#books').append('<li style="color:'+color+'">' + ( data['AJ'] || barcode ) + ( data['AF'] ? ' <b>' + data['AF'] + '</b> ' + error : '' ) + '</li>');
+                       $('ul#books').append('<li>' + ( data['AJ'] || barcode ) + ' <b style="color:'+color+'">' + message + '</b></li>');
                        $('#books_count').html( $('ul#books > li').length );
                        console.debug( book_barcodes );
                        pending_jsonp--;