|
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