You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					230 lines
				
				8.4 KiB
			
		
		
			
		
	
	
					230 lines
				
				8.4 KiB
			| 
											3 years ago
										 | const createNumberMask = (isVerify()) ? | ||
|  |   require('../dist/createNumberMask.js').default : | ||
|  |   require('../src/createNumberMask.js').default | ||
|  | 
 | ||
|  | describe('createNumberMask', () => { | ||
|  |   it('can returns a configured currency mask', () => { | ||
|  |     let numberMask = createNumberMask() | ||
|  | 
 | ||
|  |     expect(numberMask).to.be.a('function') | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('takes a prefix', () => { | ||
|  |     let numberMask = createNumberMask({prefix: '$'}) | ||
|  | 
 | ||
|  |     expect(numberMask('12')).to.deep.equal(['$', /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('takes a suffix', () => { | ||
|  |     let numberMask = createNumberMask({suffix: ' $', prefix: ''}) | ||
|  | 
 | ||
|  |     expect(numberMask('12')).to.deep.equal([/\d/, /\d/, ' ', '$']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('works when the prefix contains numbers', () => { | ||
|  |     let numberMask = createNumberMask({prefix: 'm2 '}) | ||
|  | 
 | ||
|  |     expect(numberMask('m2 1')).to.deep.equal(['m', '2', ' ', /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('works when the suffix contains numbers', () => { | ||
|  |     let numberMask = createNumberMask({prefix: '', suffix: ' m2'}) | ||
|  | 
 | ||
|  |     expect(numberMask('1 m2')).to.deep.equal([/\d/, ' ', 'm', '2']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('works when there is a decimal and the suffix contains numbers', () => { | ||
|  |     let numberMask = createNumberMask({prefix: '', suffix: ' m2', allowDecimal: true}) | ||
|  | 
 | ||
|  |     expect(numberMask('1.2 m2')).to.deep.equal([/\d/, '[]', '.', '[]', /\d/, ' ', 'm', '2']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can be configured to add a thousands separator or not', () => { | ||
|  |     let numberMaskWithoutThousandsSeparator = createNumberMask({includeThousandsSeparator: false}) | ||
|  |     expect(numberMaskWithoutThousandsSeparator('1000')).to.deep.equal(['$', /\d/, /\d/, /\d/, /\d/]) | ||
|  | 
 | ||
|  |     let numberMaskWithThousandsSeparator = createNumberMask() | ||
|  |     expect(numberMaskWithThousandsSeparator('1000')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can be configured with a custom character for the thousands separator', () => { | ||
|  |     let numberMask = createNumberMask({thousandsSeparatorSymbol: '.'}) | ||
|  | 
 | ||
|  |     expect(numberMask('1000')).to.deep.equal(['$', /\d/, '.', /\d/, /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can be configured to accept a fraction and returns the fraction separator with caret traps', () => { | ||
|  |     let numberMask = createNumberMask({allowDecimal: true}) | ||
|  | 
 | ||
|  |     expect(numberMask('1000.')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/, '[]', '.', '[]']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('rejects fractions by default', () => { | ||
|  |     let numberMask = createNumberMask() | ||
|  | 
 | ||
|  |     expect(numberMask('1000.')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can be configured with a custom character for the fraction separator', () => { | ||
|  |     let numberMask = createNumberMask({ | ||
|  |       allowDecimal: true, | ||
|  |       decimalSymbol: ',', | ||
|  |       thousandsSeparatorSymbol: '.' | ||
|  |     }) | ||
|  | 
 | ||
|  |     expect(numberMask('1000,')).to.deep.equal(['$', /\d/, '.', /\d/, /\d/, /\d/, '[]', ',', '[]']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can limit the length of the fraction', () => { | ||
|  |     let numberMask = createNumberMask({allowDecimal: true, decimalLimit: 2}) | ||
|  | 
 | ||
|  |     expect(numberMask('1000.3823')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/, '[]', '.', '[]', /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can require a fraction', () => { | ||
|  |     let numberMask = createNumberMask({requireDecimal: true}) | ||
|  | 
 | ||
|  |     expect(numberMask('1000')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/, '[]', '.', '[]']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('accepts negative integers', function() { | ||
|  |     let numberMask = createNumberMask({allowNegative: true}) | ||
|  |     expect(numberMask('-$12')).to.deep.equal([/-/, '$', /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('ignores multiple minus signs', function() { | ||
|  |     let numberMask = createNumberMask({allowNegative: true}) | ||
|  |     expect(numberMask('--$12')).to.deep.equal([/-/, '$', /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('adds a digit placeholder if the input is nothing but a minus sign in order to attract the caret', () => { | ||
|  |     let numberMask = createNumberMask({allowNegative: true}) | ||
|  |     expect(numberMask('-')).to.deep.equal([/-/, '$', /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('starts with dot should be considered as decimal input', () => { | ||
|  |     let numberMask = createNumberMask({prefix: '$', allowDecimal: true}) | ||
|  |     expect(numberMask('.')).to.deep.equal(['$', '0', '.', /\d/]) | ||
|  | 
 | ||
|  |     numberMask = createNumberMask({prefix: '#', allowDecimal: true}) | ||
|  |     expect(numberMask('.')).to.deep.equal(['#', '0', '.', /\d/]) | ||
|  | 
 | ||
|  |     numberMask = createNumberMask({prefix: '', allowDecimal: true}) | ||
|  |     expect(numberMask('.')).to.deep.equal(['0', '.', /\d/]) | ||
|  | 
 | ||
|  |     numberMask = createNumberMask({allowDecimal: false}) | ||
|  |     expect(numberMask('.')).to.deep.equal(['$']) | ||
|  | 
 | ||
|  |     numberMask = createNumberMask({prefix: '', suffix: '$', allowDecimal: true}) | ||
|  |     expect(numberMask('.')).to.deep.equal(['0', '.', /\d/, '$']) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('can allow leading zeroes', function() { | ||
|  |     let numberMask = createNumberMask({allowLeadingZeroes: true}) | ||
|  |     expect(numberMask('012')).to.deep.equal(['$', /\d/, /\d/, /\d/]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   it('works with large numbers when leading zeroes is false', function() { | ||
|  |     let numberMask = createNumberMask({allowLeadingZeroes: false}) | ||
|  |     expect(numberMask('111111111111111111111111')).to.deep.equal([ | ||
|  |       '$', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', | ||
|  |       /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/ | ||
|  |     ]) | ||
|  |   }) | ||
|  | 
 | ||
|  |   describe('integer limiting', () => { | ||
|  |     it('can limit the length of the integer part', () => { | ||
|  |       let numberMask = createNumberMask({integerLimit: 3}) | ||
|  |       expect(numberMask('1999')).to.deep.equal(['$', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('works when there is a prefix', () => { | ||
|  |       let numberMask = createNumberMask({integerLimit: 3, prefix: '$'}) | ||
|  |       expect(numberMask('$1999')).to.deep.equal(['$', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('works when there is a thousands separator', () => { | ||
|  |       expect(createNumberMask({integerLimit: 4, prefix: ''})('1,9995')) | ||
|  |         .to.deep.equal([/\d/, ',', /\d/, /\d/, /\d/]) | ||
|  | 
 | ||
|  |       expect(createNumberMask({integerLimit: 7, prefix: ''})('1,000,0001')) | ||
|  |         .to.deep.equal([/\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('works when there is a decimal and a prefix', () => { | ||
|  |       let numberMask = createNumberMask({integerLimit: 3, allowDecimal: true}) | ||
|  |       expect(numberMask('$199.34')).to.deep.equal(['$', /\d/, /\d/, /\d/, '[]', '.', '[]', /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('works when there is a decimal and no prefix', () => { | ||
|  |       let numberMask = createNumberMask({integerLimit: 3, allowDecimal: true, prefix: ''}) | ||
|  |       expect(numberMask('199.34')).to.deep.equal([/\d/, /\d/, /\d/, '[]', '.', '[]', /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('works when thousandsSeparatorSymbol is a period', () => { | ||
|  |       let numberMask = createNumberMask({ | ||
|  |         prefix: '', | ||
|  |         thousandsSeparatorSymbol: '.', | ||
|  |         decimalSymbol: ',', | ||
|  |         allowDecimal: true, | ||
|  |         requireDecimal: true, | ||
|  |         integerLimit: 5, | ||
|  |         decimalLimit: 3, | ||
|  |       }) | ||
|  |       expect(numberMask('1234567890,12345678')) | ||
|  |         .to.deep.equal([/\d/, /\d/, '.', /\d/, /\d/, /\d/, '[]', ',', '[]', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  |   }) | ||
|  | 
 | ||
|  |   describe('numberMask default behavior', () => { | ||
|  |     let numberMask = null | ||
|  | 
 | ||
|  |     beforeEach(() => { | ||
|  |       numberMask = createNumberMask() | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('returns a mask that has the same number of digits as the given number', () => { | ||
|  |       expect(numberMask('20382')).to.deep.equal(['$', /\d/, /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('uses the dollar symbol as the default prefix', () => { | ||
|  |       expect(numberMask('1')).to.deep.equal(['$', /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('adds no suffix by default', () => { | ||
|  |       expect(numberMask('1')).to.deep.equal(['$', /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('returns a mask that appends the currency symbol', () => { | ||
|  |       expect(numberMask('1')).to.deep.equal(['$', /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('adds adds a comma after a thousand', () => { | ||
|  |       expect(numberMask('1000')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('adds as many commas as needed', () => { | ||
|  |       expect(numberMask('23984209342084')) | ||
|  |         .to | ||
|  |         .deep | ||
|  |         .equal( | ||
|  |           ['$', /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/, ',', /\d/, /\d/, /\d/] | ||
|  |         ) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('accepts any string and strips out any non-digit characters', () => { | ||
|  |       expect(numberMask('h4x0r sp43k')).to.deep.equal(['$', /\d/, ',', /\d/, /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('does not allow leading zeroes', function() { | ||
|  |       let numberMask = createNumberMask() | ||
|  |       expect(numberMask('012')).to.deep.equal(['$', /\d/, /\d/]) | ||
|  |     }) | ||
|  | 
 | ||
|  |     it('allows one leading zero followed by a fraction', function() { | ||
|  |       let numberMask = createNumberMask({allowDecimal: true}) | ||
|  |       expect(numberMask('0.12')).to.deep.equal(['$', /\d/, '[]', '.', '[]', /\d/, /\d/]) | ||
|  |     }) | ||
|  |   }) | ||
|  | }) |