UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

188 lines 18.7 kB
'use strict';"use strict"; 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 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, digits) { if (digits === void 0) { digits = null; } 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, digits) { if (digits === void 0) { digits = null; } 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, currencyCode, symbolDisplay, digits) { if (currencyCode === void 0) { currencyCode = 'USD'; } if (symbolDisplay === void 0) { symbolDisplay = false; } if (digits === void 0) { digits = 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":["diffing_plugin_wrapper-output_path-BRJer1J9.tmp/angular2/src/common/pipes/number_pipe.ts"],"names":[],"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';\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, digits: string = null): string {\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, digits: string = null): string {\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, currencyCode: string = 'USD', symbolDisplay: boolean = false,\n            digits: string = null): string {\n    return NumberPipe._format(value, NumberFormatStyle.Currency, digits, currencyCode,\n                              symbolDisplay);\n  }\n}\n"]}