Default currency code in CurrencyPipe is currently hardcoded to USD
and is not configurable. This commit allows the default currency code
to be configurable by adding a DEFAULT_CURRENCY_CODE injection token.
Example:
```
providers: [{ provide: DEFAULT_CURRENCY_CODE, useValue: "GBP" }]
...
{{ 123.45 | currency }} // outputs £123.45 as opposed to always $123.45 before
```
Closes: #25461
PR Close #32584
		
	
			
		
			
				
	
	
		
			138 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /**
 | ||
|  * @license
 | ||
|  * Copyright Google Inc. All Rights Reserved.
 | ||
|  *
 | ||
|  * Use of this source code is governed by an MIT-style license that can be
 | ||
|  * found in the LICENSE file at https://angular.io/license
 | ||
|  */
 | ||
| 
 | ||
| import localeEn from '@angular/common/locales/en';
 | ||
| import localeEsUS from '@angular/common/locales/es-US';
 | ||
| import localeFr from '@angular/common/locales/fr';
 | ||
| import localeAr from '@angular/common/locales/ar';
 | ||
| import localeDeAt from '@angular/common/locales/de-AT';
 | ||
| import localeDa from '@angular/common/locales/da';
 | ||
| import {ɵunregisterLocaleData, ɵregisterLocaleData} from '@angular/core';
 | ||
| import {CurrencyPipe, DecimalPipe, PercentPipe} from '@angular/common';
 | ||
| import {beforeEach, describe, expect, it} from '@angular/core/testing/src/testing_internal';
 | ||
| 
 | ||
| {
 | ||
|   describe('Number pipes', () => {
 | ||
|     beforeAll(() => {
 | ||
|       ɵregisterLocaleData(localeEn);
 | ||
|       ɵregisterLocaleData(localeEsUS);
 | ||
|       ɵregisterLocaleData(localeFr);
 | ||
|       ɵregisterLocaleData(localeAr);
 | ||
|       ɵregisterLocaleData(localeDeAt);
 | ||
|       ɵregisterLocaleData(localeDa);
 | ||
|     });
 | ||
| 
 | ||
|     afterAll(() => ɵunregisterLocaleData());
 | ||
| 
 | ||
|     describe('DecimalPipe', () => {
 | ||
|       describe('transform', () => {
 | ||
|         let pipe: DecimalPipe;
 | ||
|         beforeEach(() => { pipe = new DecimalPipe('en-US'); });
 | ||
| 
 | ||
|         it('should return correct value for numbers', () => {
 | ||
|           expect(pipe.transform(12345)).toEqual('12,345');
 | ||
|           expect(pipe.transform(1.123456, '3.4-5')).toEqual('001.12346');
 | ||
|         });
 | ||
| 
 | ||
|         it('should support strings', () => {
 | ||
|           expect(pipe.transform('12345')).toEqual('12,345');
 | ||
|           expect(pipe.transform('123', '.2')).toEqual('123.00');
 | ||
|           expect(pipe.transform('1', '3.')).toEqual('001');
 | ||
|           expect(pipe.transform('1.1', '3.4-5')).toEqual('001.1000');
 | ||
|           expect(pipe.transform('1.123456', '3.4-5')).toEqual('001.12346');
 | ||
|           expect(pipe.transform('1.1234')).toEqual('1.123');
 | ||
|         });
 | ||
| 
 | ||
|         it('should not support other objects', () => {
 | ||
|           expect(() => pipe.transform({}))
 | ||
|               .toThrowError(
 | ||
|                   `InvalidPipeArgument: '[object Object] is not a number' for pipe 'DecimalPipe'`);
 | ||
|           expect(() => pipe.transform('123abc'))
 | ||
|               .toThrowError(`InvalidPipeArgument: '123abc is not a number' for pipe 'DecimalPipe'`);
 | ||
|         });
 | ||
|       });
 | ||
| 
 | ||
|       describe('transform with custom locales', () => {
 | ||
|         it('should return the correct format for es-US', () => {
 | ||
|           const pipe = new DecimalPipe('es-US');
 | ||
|           expect(pipe.transform('9999999.99', '1.2-2')).toEqual('9,999,999.99');
 | ||
|         });
 | ||
|       });
 | ||
|     });
 | ||
| 
 | ||
|     describe('PercentPipe', () => {
 | ||
|       let pipe: PercentPipe;
 | ||
| 
 | ||
|       beforeEach(() => { pipe = new PercentPipe('en-US'); });
 | ||
| 
 | ||
|       describe('transform', () => {
 | ||
|         it('should return correct value for numbers', () => {
 | ||
|           expect(pipe.transform(1.23)).toEqual('123%');
 | ||
|           expect(pipe.transform(1.234)).toEqual('123%');
 | ||
|           expect(pipe.transform(1.236)).toEqual('124%');
 | ||
|           expect(pipe.transform(12.3456, '0.0-10')).toEqual('1,234.56%');
 | ||
|         });
 | ||
| 
 | ||
|         it('should not support other objects', () => {
 | ||
|           expect(() => pipe.transform({}))
 | ||
|               .toThrowError(
 | ||
|                   `InvalidPipeArgument: '[object Object] is not a number' for pipe 'PercentPipe'`);
 | ||
|         });
 | ||
|       });
 | ||
|     });
 | ||
| 
 | ||
|     describe('CurrencyPipe', () => {
 | ||
|       let pipe: CurrencyPipe;
 | ||
| 
 | ||
|       beforeEach(() => { pipe = new CurrencyPipe('en-US', 'USD'); });
 | ||
| 
 | ||
|       describe('transform', () => {
 | ||
|         it('should return correct value for numbers', () => {
 | ||
|           expect(pipe.transform(123)).toEqual('$123.00');
 | ||
|           expect(pipe.transform(12, 'EUR', 'code', '.1')).toEqual('EUR12.0');
 | ||
|           expect(pipe.transform(5.1234, 'USD', 'code', '.0-3')).toEqual('USD5.123');
 | ||
|           expect(pipe.transform(5.1234, 'USD', 'code')).toEqual('USD5.12');
 | ||
|           expect(pipe.transform(5.1234, 'USD', '')).toEqual('5.12');
 | ||
|           expect(pipe.transform(5.1234, 'USD', 'symbol')).toEqual('$5.12');
 | ||
|           expect(pipe.transform(5.1234, 'CAD', 'symbol')).toEqual('CA$5.12');
 | ||
|           expect(pipe.transform(5.1234, 'CAD', 'symbol-narrow')).toEqual('$5.12');
 | ||
|           expect(pipe.transform(5.1234, 'CAD', 'symbol-narrow', '5.2-2')).toEqual('$00,005.12');
 | ||
|           expect(pipe.transform(5.1234, 'CAD', 'symbol-narrow', '5.2-2', 'fr'))
 | ||
|               .toEqual('00\u202f005,12 $');
 | ||
|           expect(pipe.transform(5, 'USD', 'symbol', '', 'fr')).toEqual('5,00 $US');
 | ||
|           expect(pipe.transform(123456789, 'EUR', 'symbol', '', 'de-at'))
 | ||
|               .toEqual('€ 123.456.789,00');
 | ||
|           expect(pipe.transform(5.1234, 'EUR', '', '', 'de-at')).toEqual('5,12');
 | ||
|           expect(pipe.transform(5.1234, 'DKK', '', '', 'da')).toEqual('5,12');
 | ||
|         });
 | ||
| 
 | ||
|         it('should support any currency code name', () => {
 | ||
|           // currency code is unknown, default formatting options will be used
 | ||
|           expect(pipe.transform(5.1234, 'unexisting_ISO_code', 'symbol'))
 | ||
|               .toEqual('unexisting_ISO_code5.12');
 | ||
|           // currency code is USD, the pipe will format based on USD but will display "Custom name"
 | ||
|           expect(pipe.transform(5.1234, 'USD', 'Custom name')).toEqual('Custom name5.12');
 | ||
|         });
 | ||
| 
 | ||
|         it('should not support other objects', () => {
 | ||
|           expect(() => pipe.transform({}))
 | ||
|               .toThrowError(
 | ||
|                   `InvalidPipeArgument: '[object Object] is not a number' for pipe 'CurrencyPipe'`);
 | ||
|         });
 | ||
| 
 | ||
|         it('should warn if you are using the v4 signature', () => {
 | ||
|           const warnSpy = spyOn(console, 'warn');
 | ||
|           pipe.transform(123, 'USD', true);
 | ||
|           expect(warnSpy).toHaveBeenCalledWith(
 | ||
|               `Warning: the currency pipe has been changed in Angular v5. The symbolDisplay option (third parameter) is now a string instead of a boolean. The accepted values are "code", "symbol" or "symbol-narrow".`);
 | ||
|         });
 | ||
|       });
 | ||
|     });
 | ||
|   });
 | ||
| }
 |