import {Injectable, PipeTransform, Pipe} from '@angular/core'; import { isStringMap, StringWrapper, isPresent, RegExpWrapper } from '../../src/facade/lang'; import {InvalidPipeArgumentException} from './invalid_pipe_argument_exception'; var interpolationExp: RegExp = RegExpWrapper.create('#'); /** * * Maps a value to a string that pluralizes the value properly. * * ## Usage * * expression | i18nPlural:mapping * * where `expression` is a number and `mapping` is an object that indicates the proper text for * when the `expression` evaluates to 0, 1, or some other number. You can interpolate the actual * value into the text using the `#` sign. * * ## Example * * ``` *
* {{ messages.length | i18nPlural: messageMapping }} *
* * class MyApp { * messages: any[]; * messageMapping: any = { * '=0': 'No messages.', * '=1': 'One message.', * 'other': '# messages.' * } * ... * } * ``` * */ @Pipe({name: 'i18nPlural', pure: true}) @Injectable() export class I18nPluralPipe implements PipeTransform { transform(value: number, pluralMap: {[count: string]: string}): string { var key: string; var valueStr: string; if (!isStringMap(pluralMap)) { throw new InvalidPipeArgumentException(I18nPluralPipe, pluralMap); } key = value === 0 || value === 1 ? `=${value}` : 'other'; valueStr = isPresent(value) ? value.toString() : ''; return StringWrapper.replaceAll(pluralMap[key], interpolationExp, valueStr); } }