123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519 |
- describe('NumericEditor', () => {
- var id = 'testContainer';
- beforeEach(function() {
- this.$container = $(`<div id="${id}"></div>`).appendTo('body');
- });
- afterEach(function() {
- if (this.$container) {
- destroy();
- this.$container.remove();
- }
- });
- var arrayOfObjects = function() {
- return [
- {id: 1, name: 'Ted', lastName: 'Right'},
- {id: 2, name: 'Frank', lastName: 'Honest'},
- {id: 3, name: 'Joan', lastName: 'Well'},
- {id: 4, name: 'Sid', lastName: 'Strong'},
- {id: 5, name: 'Jane', lastName: 'Neat'},
- {id: 6, name: 'Chuck', lastName: 'Jackson'},
- {id: 7, name: 'Meg', lastName: 'Jansen'},
- {id: 8, name: 'Rob', lastName: 'Norris'},
- {id: 9, name: 'Sean', lastName: 'O\'Hara'},
- {id: 10, name: 'Eve', lastName: 'Branson'}
- ];
- };
- it('should convert numeric value to number (object data source)', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '999';
- destroyEditor();
- setTimeout(() => {
- expect(typeof getDataAtCell(2, 0)).toEqual('number');
- expect(getDataAtCell(2, 0)).toEqual(999);
- done();
- }, 100);
- });
- it('should apply changes to editor after validation', (done) => {
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric'},
- ]
- });
- selectCell(0, 0);
- keyDown('delete');
- setTimeout(() => {
- expect(getActiveEditor().originalValue).toEqual('');
- done();
- }, 100);
- });
- it('should allow custom validator', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- allowInvalid: false,
- columns: [
- {
- data: 'id',
- type: 'numeric',
- validator(val, cb) {
- cb(parseInt(val, 10) > 100);
- }
- },
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '99';
- destroyEditor();
- setTimeout(() => {
- expect(getDataAtCell(2, 0)).not.toEqual(99); // should be ignored
- document.activeElement.value = '999';
- onAfterValidate.calls.reset();
- destroyEditor();
- }, 100);
- setTimeout(() => {
- expect(getDataAtCell(2, 0)).toEqual(999);
- done();
- }, 200);
- });
- it('should convert string in format \'XX.XX\' to a float with the same value', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '99.99';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getDataAtCell(2, 0)).toEqual(parseFloat(99.99));
- done();
- }, 100);
- });
- it('should convert string in format \'XX.XX\' to a float when passing float without leading zero', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '.74';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getDataAtCell(2, 0)).toEqual(parseFloat(0.74));
- done();
- }, 100);
- });
- it('should convert string in format \'XX,XX\' (with comma as separator) to a float with the same value if the numeric locale ' +
- 'specifies comma as the precision delimiter (language=de)', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', language: 'de-DE'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '99,99';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getDataAtCell(2, 0)).toEqual(parseFloat(99.99));
- done();
- }, 100);
- });
- it('should display a string in a format \'$X,XXX.XX\' when using language=en, appropriate format in column settings and \'XXXX.XX\' as ' +
- 'an input string', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', format: '$0,0.00', language: 'en-US'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '2456.22';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getCell(2, 0).innerHTML).toEqual('$2,456.22');
- done();
- }, 100);
- });
- it('should display a string in a format \'X.XXX,XX €\' when using language=de, appropriate format in column settings and \'XXXX,XX\' as an ' +
- 'input string (that comes from manual input)', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', format: '0,0.00 $', language: 'de-DE'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '2456,22';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getCell(2, 0).innerHTML).toEqual('2.456,22 €');
- done();
- }, 100);
- });
- it('should display a string in a format \'X.XXX,XX €\' when using language=de, appropriate format in column settings and \'XXXX.XX\' as an ' +
- 'input string (that comes from paste)', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', format: '0,0.00 $', language: 'de-DE'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '2456.22';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getCell(2, 0).innerHTML).toEqual('2.456,22 €');
- done();
- }, 100);
- });
- it('should not validate input values in different formats than \'XX.XX\' and \'XX,XX\'', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- function manuallySetValueTo(val) {
- keyDown('enter');
- document.activeElement.value = val;
- onAfterValidate.calls.reset();
- destroyEditor();
- }
- manuallySetValueTo('22.22');
- setTimeout(() => {
- expect($(getCell(2, 0)).hasClass('htInvalid')).toBe(false); // should validate alright
- manuallySetValueTo('2,000,000.22');
- }, 100);
- setTimeout(() => {
- expect($(getCell(2, 0)).hasClass('htInvalid')).toBe(true);
- manuallySetValueTo('11,11');
- }, 200);
- setTimeout(() => {
- expect($(getCell(2, 0)).hasClass('htInvalid')).toBe(false); // should validate alright
- manuallySetValueTo('one thounsand');
- }, 300);
- setTimeout(() => {
- expect($(getCell(2, 0)).hasClass('htInvalid')).toBe(true);
- manuallySetValueTo('99d99');
- }, 400);
- setTimeout(() => {
- expect($(getCell(2, 0)).hasClass('htInvalid')).toBe(true);
- done();
- }, 500);
- });
- it('should paste formatted data if source cell has format', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', format: '0,0.00 $', language: 'de-DE'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- keyDown('enter');
- document.activeElement.value = '€123,00';
- onAfterValidate.calls.reset();
- destroyEditor();
- setTimeout(() => {
- expect(getCell(2, 0).innerHTML).toEqual('123,00 €');
- done();
- }, 100);
- });
- it('should display a string in a format \'X XXX,XX €\' when using language=de, appropriate format in column settings and \'XXXX,XX\' as an ' +
- 'input string and ignore not needed zeros at the end', (done) => {
- var onAfterValidate = jasmine.createSpy('onAfterValidate');
- handsontable({
- data: [
- {id: 1, name: 'Ted', lastName: 'Right', money: 0},
- {id: 2, name: 'Frank', lastName: 'Honest', money: 0},
- {id: 3, name: 'Joan', lastName: 'Well', money: 0},
- {id: 4, name: 'Sid', lastName: 'Strong', money: 0},
- {id: 5, name: 'Jane', lastName: 'Neat', money: 0},
- {id: 6, name: 'Chuck', lastName: 'Jackson', money: 0},
- {id: 7, name: 'Meg', lastName: 'Jansen', money: 0},
- {id: 8, name: 'Rob', lastName: 'Norris', money: 0},
- {id: 9, name: 'Sean', lastName: 'O\'Hara', money: 0},
- {id: 10, name: 'Eve', lastName: 'Branson', money: 0}
- ],
- columns: [
- {data: 'id', type: 'numeric', format: '0,0.00 $', language: 'de-DE'},
- {data: 'name'},
- {data: 'lastName'},
- {data: 'money', type: 'numeric', format: '$0,0.00', language: 'en-US'}
- ],
- afterValidate: onAfterValidate
- });
- selectCell(2, 0);
- function manuallySetValueTo(val) {
- keyDown('enter');
- document.activeElement.value = val;
- onAfterValidate.calls.reset();
- destroyEditor();
- }
- manuallySetValueTo('2456,220');
- setTimeout(() => {
- expect(getCell(2, 0).innerHTML).toEqual('2.456,22 €');
- deselectCell();
- selectCell(2, 3);
- manuallySetValueTo('2456.220');
- }, 100);
- setTimeout(() => {
- expect(getCell(2, 3).innerHTML).toEqual('$2,456.22');
- done();
- }, 200);
- });
- it('should mark text as invalid without removing', (done) => {
- var hot = handsontable({
- data: arrayOfObjects(),
- columns: [
- {data: 'id', type: 'numeric', format: '0,0.00'},
- {data: 'name'},
- {data: 'lastName'}
- ],
- });
- hot.setDataAtCell(0, 0, 'abc');
- setTimeout(() => {
- expect(hot.getDataAtCell(0, 0)).toEqual('abc');
- done();
- }, 200);
- });
- it('should not throw error on closing editor when column data is defined as \'length\'', () => {
- hot = handsontable({
- data: [
- {length: 4},
- {length: 5},
- ],
- columns: [
- {
- data: 'length', type: 'numeric'
- },
- {},
- {}
- ]
- });
- selectCell(1, 0);
- keyDown('enter');
- document.activeElement.value = '999';
- expect(() => {
- destroyEditor();
- }).not.toThrow();
- });
- describe('Cell corner is showed properly when changing focused cells #3877', () => {
- var isFocusedCellDisplayingCornerTest = function(settings) {
- var moveFromRow = settings.moveFromRow;
- var moveFromCol = settings.moveFromCol;
- var moveToRow = settings.moveToRow;
- var moveToCol = settings.moveToCol;
- var doneFunc = settings.doneFunc;
- var $corner = settings.$container.find('.wtBorder.current.corner');
- selectCell(moveFromRow, moveFromCol);
- keyDown('enter');
- selectCell(moveToRow, moveToCol);
- setTimeout(() => {
- expect($corner.css('display')).toEqual('block');
- doneFunc();
- }, 100);
- };
- it('Moving from numeric editor to text editor', function(done) {
- handsontable({
- data: [
- {id: 1, name: 'Ted', lastName: 'Right', money: 0}
- ],
- columns: [
- {data: 'id'},
- {data: 'name'},
- {data: 'lastName'},
- {data: 'money', type: 'numeric', format: '$0,0.00', language: 'en-US'}
- ]
- });
- isFocusedCellDisplayingCornerTest({
- moveFromRow: 0,
- moveFromCol: 3,
- moveToRow: 0,
- moveToCol: 0,
- $container: this.$container,
- doneFunc: done
- });
- });
- it('Moving from text editor to numeric editor', function(done) {
- handsontable({
- data: [
- {id: 1, name: 'Ted', lastName: 'Right', money: 0}
- ],
- columns: [
- {data: 'id'},
- {data: 'name'},
- {data: 'lastName'},
- {data: 'money', type: 'numeric', format: '$0,0.00', language: 'en-US'}
- ]
- });
- isFocusedCellDisplayingCornerTest({
- moveFromRow: 0,
- moveFromCol: 1,
- moveToRow: 0,
- moveToCol: 3,
- $container: this.$container,
- doneFunc: done
- });
- });
- });
- });
|