angular2
Version:
Angular 2 - a web framework for modern web apps
188 lines • 20.6 kB
JavaScript
;var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var lang_1 = require('angular2/src/facade/lang');
var exceptions_1 = require('angular2/src/facade/exceptions');
var intl_1 = require('angular2/src/facade/intl');
var core_1 = require('angular2/core');
var collection_1 = require('angular2/src/facade/collection');
var invalid_pipe_argument_exception_1 = require('./invalid_pipe_argument_exception');
var defaultLocale = 'en-US';
var _re = lang_1.RegExpWrapper.create('^(\\d+)?\\.((\\d+)(\\-(\\d+))?)?$');
/**
* Internal base class for numeric pipes.
*/
var NumberPipe = (function () {
function NumberPipe() {
}
/** @internal */
NumberPipe._format = function (value, style, digits, currency, currencyAsSymbol) {
if (currency === void 0) { currency = null; }
if (currencyAsSymbol === void 0) { currencyAsSymbol = false; }
if (lang_1.isBlank(value))
return null;
if (!lang_1.isNumber(value)) {
throw new invalid_pipe_argument_exception_1.InvalidPipeArgumentException(NumberPipe, value);
}
var minInt = 1, minFraction = 0, maxFraction = 3;
if (lang_1.isPresent(digits)) {
var parts = lang_1.RegExpWrapper.firstMatch(_re, digits);
if (lang_1.isBlank(parts)) {
throw new exceptions_1.BaseException(digits + " is not a valid digit info for number pipes");
}
if (lang_1.isPresent(parts[1])) {
minInt = lang_1.NumberWrapper.parseIntAutoRadix(parts[1]);
}
if (lang_1.isPresent(parts[3])) {
minFraction = lang_1.NumberWrapper.parseIntAutoRadix(parts[3]);
}
if (lang_1.isPresent(parts[5])) {
maxFraction = lang_1.NumberWrapper.parseIntAutoRadix(parts[5]);
}
}
return intl_1.NumberFormatter.format(value, defaultLocale, style, {
minimumIntegerDigits: minInt,
minimumFractionDigits: minFraction,
maximumFractionDigits: maxFraction,
currency: currency,
currencyAsSymbol: currencyAsSymbol
});
};
NumberPipe = __decorate([
lang_1.CONST(),
core_1.Injectable(),
__metadata('design:paramtypes', [])
], NumberPipe);
return NumberPipe;
})();
exports.NumberPipe = NumberPipe;
/**
* WARNING: this pipe uses the Internationalization API.
* Therefore it is only reliable in Chrome and Opera browsers.
*
* Formats a number as local text. i.e. group sizing and separator and other locale-specific
* configurations are based on the active locale.
*
* ### Usage
*
* expression | number[:digitInfo]
*
* where `expression` is a number and `digitInfo` has the following format:
*
* {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}
*
* - minIntegerDigits is the minimum number of integer digits to use. Defaults to 1.
* - minFractionDigits is the minimum number of digits after fraction. Defaults to 0.
* - maxFractionDigits is the maximum number of digits after fraction. Defaults to 3.
*
* For more information on the acceptable range for each of these numbers and other
* details see your native internationalization library.
*
* ### Example
*
* {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='NumberPipe'}
*/
var DecimalPipe = (function (_super) {
__extends(DecimalPipe, _super);
function DecimalPipe() {
_super.apply(this, arguments);
}
DecimalPipe.prototype.transform = function (value, args) {
var digits = collection_1.ListWrapper.first(args);
return NumberPipe._format(value, intl_1.NumberFormatStyle.Decimal, digits);
};
DecimalPipe = __decorate([
lang_1.CONST(),
core_1.Pipe({ name: 'number' }),
core_1.Injectable(),
__metadata('design:paramtypes', [])
], DecimalPipe);
return DecimalPipe;
})(NumberPipe);
exports.DecimalPipe = DecimalPipe;
/**
* WARNING: this pipe uses the Internationalization API.
* Therefore it is only reliable in Chrome and Opera browsers.
*
* Formats a number as local percent.
*
* ### Usage
*
* expression | percent[:digitInfo]
*
* For more information about `digitInfo` see {@link DecimalPipe}
*
* ### Example
*
* {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='PercentPipe'}
*/
var PercentPipe = (function (_super) {
__extends(PercentPipe, _super);
function PercentPipe() {
_super.apply(this, arguments);
}
PercentPipe.prototype.transform = function (value, args) {
var digits = collection_1.ListWrapper.first(args);
return NumberPipe._format(value, intl_1.NumberFormatStyle.Percent, digits);
};
PercentPipe = __decorate([
lang_1.CONST(),
core_1.Pipe({ name: 'percent' }),
core_1.Injectable(),
__metadata('design:paramtypes', [])
], PercentPipe);
return PercentPipe;
})(NumberPipe);
exports.PercentPipe = PercentPipe;
/**
* WARNING: this pipe uses the Internationalization API.
* Therefore it is only reliable in Chrome and Opera browsers.
*
* Formats a number as local currency.
*
* ### Usage
*
* expression | currency[:currencyCode[:symbolDisplay[:digitInfo]]]
*
* where `currencyCode` is the ISO 4217 currency code, such as "USD" for the US dollar and
* "EUR" for the euro. `symbolDisplay` is a boolean indicating whether to use the currency
* symbol (e.g. $) or the currency code (e.g. USD) in the output. The default for this value
* is `false`.
* For more information about `digitInfo` see {@link DecimalPipe}
*
* ### Example
*
* {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='CurrencyPipe'}
*/
var CurrencyPipe = (function (_super) {
__extends(CurrencyPipe, _super);
function CurrencyPipe() {
_super.apply(this, arguments);
}
CurrencyPipe.prototype.transform = function (value, args) {
var currencyCode = lang_1.isPresent(args) && args.length > 0 ? args[0] : 'USD';
var symbolDisplay = lang_1.isPresent(args) && args.length > 1 ? args[1] : false;
var digits = lang_1.isPresent(args) && args.length > 2 ? args[2] : null;
return NumberPipe._format(value, intl_1.NumberFormatStyle.Currency, digits, currencyCode, symbolDisplay);
};
CurrencyPipe = __decorate([
lang_1.CONST(),
core_1.Pipe({ name: 'currency' }),
core_1.Injectable(),
__metadata('design:paramtypes', [])
], CurrencyPipe);
return CurrencyPipe;
})(NumberPipe);
exports.CurrencyPipe = CurrencyPipe;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number_pipe.js","sourceRoot":"","sources":["angular2/src/common/pipes/number_pipe.ts"],"names":["NumberPipe","NumberPipe.constructor","NumberPipe._format","DecimalPipe","DecimalPipe.constructor","DecimalPipe.transform","PercentPipe","PercentPipe.constructor","PercentPipe.transform","CurrencyPipe","CurrencyPipe.constructor","CurrencyPipe.transform"],"mappings":"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","sourcesContent":["import {\n  isNumber,\n  isPresent,\n  isBlank,\n  StringWrapper,\n  NumberWrapper,\n  RegExpWrapper,\n  CONST,\n  FunctionWrapper\n} from 'angular2/src/facade/lang';\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {NumberFormatter, NumberFormatStyle} from 'angular2/src/facade/intl';\nimport {Injectable, PipeTransform, WrappedValue, Pipe} from 'angular2/core';\nimport {ListWrapper} from 'angular2/src/facade/collection';\n\nimport {InvalidPipeArgumentException} from './invalid_pipe_argument_exception';\n\nvar defaultLocale: string = 'en-US';\nvar _re = RegExpWrapper.create('^(\\\\d+)?\\\\.((\\\\d+)(\\\\-(\\\\d+))?)?$');\n\n/**\n * Internal base class for numeric pipes.\n */\n@CONST()\n@Injectable()\nexport class NumberPipe {\n  /** @internal */\n  static _format(value: number, style: NumberFormatStyle, digits: string, currency: string = null,\n                 currencyAsSymbol: boolean = false): string {\n    if (isBlank(value)) return null;\n    if (!isNumber(value)) {\n      throw new InvalidPipeArgumentException(NumberPipe, value);\n    }\n    var minInt = 1, minFraction = 0, maxFraction = 3;\n    if (isPresent(digits)) {\n      var parts = RegExpWrapper.firstMatch(_re, digits);\n      if (isBlank(parts)) {\n        throw new BaseException(`${digits} is not a valid digit info for number pipes`);\n      }\n      if (isPresent(parts[1])) {  // min integer digits\n        minInt = NumberWrapper.parseIntAutoRadix(parts[1]);\n      }\n      if (isPresent(parts[3])) {  // min fraction digits\n        minFraction = NumberWrapper.parseIntAutoRadix(parts[3]);\n      }\n      if (isPresent(parts[5])) {  // max fraction digits\n        maxFraction = NumberWrapper.parseIntAutoRadix(parts[5]);\n      }\n    }\n    return NumberFormatter.format(value, defaultLocale, style, {\n      minimumIntegerDigits: minInt,\n      minimumFractionDigits: minFraction,\n      maximumFractionDigits: maxFraction,\n      currency: currency,\n      currencyAsSymbol: currencyAsSymbol\n    });\n  }\n}\n\n/**\n * WARNING: this pipe uses the Internationalization API.\n * Therefore it is only reliable in Chrome and Opera browsers.\n *\n * Formats a number as local text. i.e. group sizing and separator and other locale-specific\n * configurations are based on the active locale.\n *\n * ### Usage\n *\n *     expression | number[:digitInfo]\n *\n * where `expression` is a number and `digitInfo` has the following format:\n *\n *     {minIntegerDigits}.{minFractionDigits}-{maxFractionDigits}\n *\n * - minIntegerDigits is the minimum number of integer digits to use. Defaults to 1.\n * - minFractionDigits is the minimum number of digits after fraction. Defaults to 0.\n * - maxFractionDigits is the maximum number of digits after fraction. Defaults to 3.\n *\n * For more information on the acceptable range for each of these numbers and other\n * details see your native internationalization library.\n *\n * ### Example\n *\n * {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='NumberPipe'}\n */\n@CONST()\n@Pipe({name: 'number'})\n@Injectable()\nexport class DecimalPipe extends NumberPipe implements PipeTransform {\n  transform(value: any, args: any[]): string {\n    var digits: string = ListWrapper.first(args);\n    return NumberPipe._format(value, NumberFormatStyle.Decimal, digits);\n  }\n}\n\n/**\n * WARNING: this pipe uses the Internationalization API.\n * Therefore it is only reliable in Chrome and Opera browsers.\n *\n * Formats a number as local percent.\n *\n * ### Usage\n *\n *     expression | percent[:digitInfo]\n *\n * For more information about `digitInfo` see {@link DecimalPipe}\n *\n * ### Example\n *\n * {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='PercentPipe'}\n */\n@CONST()\n@Pipe({name: 'percent'})\n@Injectable()\nexport class PercentPipe extends NumberPipe implements PipeTransform {\n  transform(value: any, args: any[]): string {\n    var digits: string = ListWrapper.first(args);\n    return NumberPipe._format(value, NumberFormatStyle.Percent, digits);\n  }\n}\n\n/**\n * WARNING: this pipe uses the Internationalization API.\n * Therefore it is only reliable in Chrome and Opera browsers.\n *\n * Formats a number as local currency.\n *\n * ### Usage\n *\n *     expression | currency[:currencyCode[:symbolDisplay[:digitInfo]]]\n *\n * where `currencyCode` is the ISO 4217 currency code, such as \"USD\" for the US dollar and\n * \"EUR\" for the euro. `symbolDisplay` is a boolean indicating whether to use the currency\n * symbol (e.g. $) or the currency code (e.g. USD) in the output. The default for this value\n * is `false`.\n * For more information about `digitInfo` see {@link DecimalPipe}\n *\n * ### Example\n *\n * {@example core/pipes/ts/number_pipe/number_pipe_example.ts region='CurrencyPipe'}\n */\n@CONST()\n@Pipe({name: 'currency'})\n@Injectable()\nexport class CurrencyPipe extends NumberPipe implements PipeTransform {\n  transform(value: any, args: any[]): string {\n    var currencyCode: string = isPresent(args) && args.length > 0 ? args[0] : 'USD';\n    var symbolDisplay: boolean = isPresent(args) && args.length > 1 ? args[1] : false;\n    var digits: string = isPresent(args) && args.length > 2 ? args[2] : null;\n    return NumberPipe._format(value, NumberFormatStyle.Currency, digits, currencyCode,\n                              symbolDisplay);\n  }\n}\n"]}