|
24 | 24 | function input(val, dataValidationAttr, elAttr) { |
25 | 25 | if(!elAttr) |
26 | 26 | elAttr = {}; |
27 | | - if( typeof dataValidationAttr == 'string') { |
| 27 | + if( typeof dataValidationAttr === 'string') { |
28 | 28 | elAttr['data-validation'] = dataValidationAttr; |
29 | 29 | } else if(dataValidationAttr) { |
30 | 30 | $.each(dataValidationAttr, function(x, val) { |
31 | | - if( x == '' ) { |
| 31 | + if( x === '' ) { |
32 | 32 | elAttr['data-validation'] = val; |
33 | 33 | } else { |
34 | 34 | elAttr['data-validation-'+x] = val; |
|
51 | 51 | var result = $.formUtils.validateInput($el, $.formUtils.LANG, $.formUtils.defaultConfig(), $form); |
52 | 52 |
|
53 | 53 | var message; |
54 | | - if( typeof obj.val == 'string' ) { |
| 54 | + if (typeof obj.val === 'string' ) { |
55 | 55 | message = 'Check that "'+obj.val+'" is '+(obj.isValid ? 'valid':'invalid'); |
56 | | - } else { |
| 56 | + } |
| 57 | + else { |
57 | 58 | message = 'Check that input[value="'+obj.val.attr('value')+'"] is '+(obj.isValid ? 'valid':'invalid'); |
58 | 59 | } |
59 | 60 |
|
60 | | - if( !result.shouldChangeDisplay && obj.isValid ) { |
61 | | - equal( |
62 | | - null, |
63 | | - null, |
64 | | - message |
65 | | - ); |
| 61 | + if (!result.shouldChangeDisplay && obj.isValid ) { |
| 62 | + equal(null, null, message); |
66 | 63 | } |
67 | | - else if( $el.attr('data-validation-optional') && !$el.val() ) { |
68 | | - equal( |
69 | | - null, |
70 | | - null, |
71 | | - message |
72 | | - ); |
73 | | - } else { |
74 | | - equal( |
75 | | - result.isValid, |
76 | | - obj.isValid, |
77 | | - message |
78 | | - ); |
| 64 | + else { |
| 65 | + equal(result.isValid, obj.isValid, message); |
79 | 66 | } |
80 | 67 | } |
81 | 68 |
|
|
460 | 447 | }); |
461 | 448 |
|
462 | 449 | /* |
463 | | - * NUMBER VALIDATION |
| 450 | + * NUMBER VALIDATION type=text (HTML4) |
464 | 451 | */ |
465 | | - test("Number validation", function() { |
| 452 | + test('Number validation for <input type=text"/>', function() { |
466 | 453 |
|
467 | 454 | clearForm(); |
468 | 455 |
|
469 | 456 | var links = [ |
470 | | - {val:'123', isValid:true}, |
471 | | - {val:'', isValid:false}, |
472 | | - {val:'asdfsd', isValid:false}, |
473 | | - {val:'-123', isValid:false}, |
474 | | - {val:input('-123', {'allowing':'negative', '':'number'}), isValid:true}, |
475 | | - {val:'1.032', isValid:false}, |
476 | | - {val:input('1.023', {'allowing':'float', '':'number'}), isValid:true}, |
477 | | - {val:'-1.032', isValid:false}, |
478 | | - {val:input('-1.023', {'allowing':'float,negative', '':'number'}), isValid:true}, |
479 | | - {val:input('1.0234', {'allowing':'float,negative', '':'number'}), isValid:true}, |
480 | | - {val:input('1.0235', {'allowing':'float,negative,number', '':'number'}), isValid:true}, |
481 | | - {val:input('1.0236', {'allowing':'float,negative,number', 'decimal-separator':',', '':'number'}), isValid:false}, |
482 | | - {val:input('1,023', {'allowing':'float,negative,number', 'decimal-separator':',', '':'number'}), isValid:true}, |
483 | | - {val:'123', isValid:true}, |
484 | | - {val:input('12', {'allowing':'range[1;10]', '':'number'}), isValid:false}, |
485 | | - {val:input('-1', {'allowing':'range[1;10]', '':'number'}), isValid:false}, |
486 | | - {val:input('1', {'allowing':'range[1;10]', '':'number'}), isValid:true}, |
487 | | - {val:input('10', {'allowing':'range[1;10]', '':'number'}), isValid:true}, |
488 | | - {val:input('5', {'allowing':'range[1;10]', '':'number'}), isValid:true}, |
489 | | - {val:input('-1', {'allowing':'range[-10;10],negative', '':'number'}), isValid:true}, |
490 | | - {val:input('0.0001', {'allowing':'range[0.05;0.9]', '':'number'}), isValid:false}, |
491 | | - {val:input('0.06', {'allowing':'range[0.05;0.9],float', '':'number'}), isValid:true} |
| 457 | + {val: '123', isValid: true}, |
| 458 | + {val: '', isValid: false}, |
| 459 | + {val: 'asdfsd', isValid: false}, |
| 460 | + {val: '-123', isValid: false}, |
| 461 | + {val: '1.032', isValid: false}, |
| 462 | + {val: '-1.032', isValid: false}, |
| 463 | + {val: input('-123' , {'allowing': 'negative', '': 'number'}), isValid: true}, |
| 464 | + {val: input('-1', {'allowing': 'range[-10;10],negative', '': 'number'}), isValid: true}, |
| 465 | + //Test ranges |
| 466 | + {val: input('12', {'allowing': 'range[1;10]', '':'number'}), isValid: false}, |
| 467 | + {val: input('-1', {'allowing': 'range[1;10]', '':'number'}), isValid: false}, |
| 468 | + {val: input('1', {'allowing': 'range[1;10]', '':'number'}), isValid: true}, |
| 469 | + {val: input('10', {'allowing': 'range[1;10]', '':'number'}), isValid: true}, |
| 470 | + {val: input('5', {'allowing': 'range[1;10]', '':'number'}), isValid: true}, |
| 471 | + {val: input('', {'optional': true, '': 'number' }), isValid: true}, |
| 472 | + //Test floats |
| 473 | + {val: input('1.023' , {'allowing': 'float', '': 'number'}), isValid: true}, |
| 474 | + {val: input('-1.023', {'allowing': 'float,negative', '': 'number'}), isValid: true}, |
| 475 | + {val: input('1.0234', {'allowing': 'float,negative', '': 'number'}), isValid: true}, |
| 476 | + {val: input('1.0235', {'allowing': 'float,negative,number', '': 'number'}), isValid: true}, |
| 477 | + {val: input('1.0236', {'allowing': 'float,negative,number', 'decimal-separator': ',', |
| 478 | + '': 'number'}), isValid: false}, |
| 479 | + {val: input('1,023', {'allowing': 'float,negative,number', 'decimal-separator':',', |
| 480 | + '': 'number'}), isValid: true}, |
| 481 | + {val: input('0.0001', {'allowing': 'range[0.05;0.9]', '': 'number'}), isValid: false}, |
| 482 | + {val: input('0.06', {'allowing': 'range[0.05;0.9],float', '': 'number'}), isValid: true} |
492 | 483 | ]; |
493 | 484 |
|
494 | 485 | $.each(links, function(i, obj) { |
495 | 486 | runTest(obj, 'number'); |
496 | 487 | }); |
497 | 488 | }); |
498 | 489 |
|
| 490 | + /** |
| 491 | + * NUMBER VALIDATION for type = "number" (HTML5) |
| 492 | + */ |
| 493 | + test('Number validation for <input type="number"/>', function () { |
| 494 | + clearForm(); |
| 495 | + var links = []; |
| 496 | + var numberType = {type: 'number'}; |
| 497 | + links.push( |
| 498 | + {val: input('123', {'': 'number'}, numberType), isValid: true}, |
| 499 | + {val: input('', {'': 'number'}, numberType), isValid: false}, |
| 500 | + {val: input('asdfsd', {'': 'number'}, numberType), isValid: false}, |
| 501 | + {val: input('-123', {'': 'number'}, numberType), isValid: false}, |
| 502 | + {val: input('1.032', {'': 'number'}, numberType), isValid: false}, |
| 503 | + {val: input('-1.032', {'': 'number'}, numberType), isValid: false}, |
| 504 | + {val: input('-123' , {'allowing': 'negative', '': 'number'}, numberType), isValid: true}, |
| 505 | + {val: input('', {'optional': true, '': 'number' }, numberType), isValid: true}, |
| 506 | + //Test ranges |
| 507 | + {val: input('12', {'allowing': 'range[1;10]', '':'number'}, numberType), isValid: false}, |
| 508 | + {val: input('-1', {'allowing': 'range[1;10]', '':'number'}, numberType), isValid: false}, |
| 509 | + {val: input('1', {'allowing': 'range[1;10]', '':'number'}, numberType), isValid: true}, |
| 510 | + {val: input('10', {'allowing': 'range[1;10]', '':'number'}, numberType), isValid: true}, |
| 511 | + {val: input('5', {'allowing': 'range[1;10]', '':'number'}, numberType), isValid: true}, |
| 512 | + {val: input('-1', {'allowing': 'range[-10;10],negative', '': 'number'}, numberType), isValid: true}, |
| 513 | + //Test floats |
| 514 | + {val: input('1.023' , {'allowing': 'float', '': 'number'}, numberType), isValid: true}, |
| 515 | + {val: input('-1.023', {'allowing': 'float,negative', '': 'number'}, numberType), isValid: true}, |
| 516 | + {val: input('1.0234', {'allowing': 'float,negative', '': 'number'}, numberType), isValid: true}, |
| 517 | + {val: input('1.0235', {'allowing': 'float,negative,number', '': 'number'}, numberType), isValid: true}, |
| 518 | + {val: input('1.0236', {'allowing': 'float,negative,number', 'decimal-separator': ',', |
| 519 | + '': 'number'}, numberType), isValid: false}, |
| 520 | + {val: input('0.0001', {'allowing': 'range[0.05;0.9]', '': 'number'}, numberType), isValid: false}, |
| 521 | + {val: input('0.06', {'allowing': 'range[0.05;0.9],float', 'decimal-separator': '.', |
| 522 | + '': 'number'}, numberType), isValid: true} |
| 523 | + ); |
| 524 | + /* Tests that fail with HTML input type number because of bugs in how browsers handle decimal separators: |
| 525 | + {val: input('1,023', {'allowing': 'float,negative,number', 'decimal-separator':',', |
| 526 | + '': 'number'}, {'lang': 'no', type: 'number'}), isValid: true}, |
| 527 | + */ |
| 528 | + |
| 529 | + $.each(links, function(i, obj) { |
| 530 | + runTest(obj, 'number'); |
| 531 | + }); |
| 532 | + }); |
499 | 533 | /* |
500 | 534 | * DATE VALIDATION |
501 | 535 | */ |
|
0 commit comments