source: trip-planner-front/node_modules/@angular/common/esm2015/src/pipes/date_pipe.js@ 6a3a178

Last change on this file since 6a3a178 was 6a3a178, checked in by Ema <ema_spirova@…>, 3 years ago

initial commit

  • Property mode set to 100644
File size: 38.9 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC All Rights Reserved.
4 *
5 * Use of this source code is governed by an MIT-style license that can be
6 * found in the LICENSE file at https://angular.io/license
7 */
8import { Inject, LOCALE_ID, Pipe } from '@angular/core';
9import { formatDate } from '../i18n/format_date';
10import { invalidPipeArgumentError } from './invalid_pipe_argument_error';
11// clang-format off
12/**
13 * @ngModule CommonModule
14 * @description
15 *
16 * Formats a date value according to locale rules.
17 *
18 * `DatePipe` is executed only when it detects a pure change to the input value.
19 * A pure change is either a change to a primitive input value
20 * (such as `String`, `Number`, `Boolean`, or `Symbol`),
21 * or a changed object reference (such as `Date`, `Array`, `Function`, or `Object`).
22 *
23 * Note that mutating a `Date` object does not cause the pipe to be rendered again.
24 * To ensure that the pipe is executed, you must create a new `Date` object.
25 *
26 * Only the `en-US` locale data comes with Angular. To localize dates
27 * in another language, you must import the corresponding locale data.
28 * See the [I18n guide](guide/i18n-common-format-data-locale) for more information.
29 *
30 * @see `formatDate()`
31 *
32 *
33 * @usageNotes
34 *
35 * The result of this pipe is not reevaluated when the input is mutated. To avoid the need to
36 * reformat the date on every change-detection cycle, treat the date as an immutable object
37 * and change the reference when the pipe needs to run again.
38 *
39 * ### Pre-defined format options
40 *
41 * | Option | Equivalent to | Examples (given in `en-US` locale) |
42 * |---------------|-------------------------------------|-------------------------------------------------|
43 * | `'short'` | `'M/d/yy, h:mm a'` | `6/15/15, 9:03 AM` |
44 * | `'medium'` | `'MMM d, y, h:mm:ss a'` | `Jun 15, 2015, 9:03:01 AM` |
45 * | `'long'` | `'MMMM d, y, h:mm:ss a z'` | `June 15, 2015 at 9:03:01 AM GMT+1` |
46 * | `'full'` | `'EEEE, MMMM d, y, h:mm:ss a zzzz'` | `Monday, June 15, 2015 at 9:03:01 AM GMT+01:00` |
47 * | `'shortDate'` | `'M/d/yy'` | `6/15/15` |
48 * | `'mediumDate'`| `'MMM d, y'` | `Jun 15, 2015` |
49 * | `'longDate'` | `'MMMM d, y'` | `June 15, 2015` |
50 * | `'fullDate'` | `'EEEE, MMMM d, y'` | `Monday, June 15, 2015` |
51 * | `'shortTime'` | `'h:mm a'` | `9:03 AM` |
52 * | `'mediumTime'`| `'h:mm:ss a'` | `9:03:01 AM` |
53 * | `'longTime'` | `'h:mm:ss a z'` | `9:03:01 AM GMT+1` |
54 * | `'fullTime'` | `'h:mm:ss a zzzz'` | `9:03:01 AM GMT+01:00` |
55 *
56 * ### Custom format options
57 *
58 * You can construct a format string using symbols to specify the components
59 * of a date-time value, as described in the following table.
60 * Format details depend on the locale.
61 * Fields marked with (*) are only available in the extra data set for the given locale.
62 *
63 * | Field type | Format | Description | Example Value |
64 * |-------------------- |-------------|---------------------------------------------------------------|------------------------------------------------------------|
65 * | Era | G, GG & GGG | Abbreviated | AD |
66 * | | GGGG | Wide | Anno Domini |
67 * | | GGGGG | Narrow | A |
68 * | Year | y | Numeric: minimum digits | 2, 20, 201, 2017, 20173 |
69 * | | yy | Numeric: 2 digits + zero padded | 02, 20, 01, 17, 73 |
70 * | | yyy | Numeric: 3 digits + zero padded | 002, 020, 201, 2017, 20173 |
71 * | | yyyy | Numeric: 4 digits or more + zero padded | 0002, 0020, 0201, 2017, 20173 |
72 * | Week-numbering year | Y | Numeric: minimum digits | 2, 20, 201, 2017, 20173 |
73 * | | YY | Numeric: 2 digits + zero padded | 02, 20, 01, 17, 73 |
74 * | | YYY | Numeric: 3 digits + zero padded | 002, 020, 201, 2017, 20173 |
75 * | | YYYY | Numeric: 4 digits or more + zero padded | 0002, 0020, 0201, 2017, 20173 |
76 * | Month | M | Numeric: 1 digit | 9, 12 |
77 * | | MM | Numeric: 2 digits + zero padded | 09, 12 |
78 * | | MMM | Abbreviated | Sep |
79 * | | MMMM | Wide | September |
80 * | | MMMMM | Narrow | S |
81 * | Month standalone | L | Numeric: 1 digit | 9, 12 |
82 * | | LL | Numeric: 2 digits + zero padded | 09, 12 |
83 * | | LLL | Abbreviated | Sep |
84 * | | LLLL | Wide | September |
85 * | | LLLLL | Narrow | S |
86 * | Week of year | w | Numeric: minimum digits | 1... 53 |
87 * | | ww | Numeric: 2 digits + zero padded | 01... 53 |
88 * | Week of month | W | Numeric: 1 digit | 1... 5 |
89 * | Day of month | d | Numeric: minimum digits | 1 |
90 * | | dd | Numeric: 2 digits + zero padded | 01 |
91 * | Week day | E, EE & EEE | Abbreviated | Tue |
92 * | | EEEE | Wide | Tuesday |
93 * | | EEEEE | Narrow | T |
94 * | | EEEEEE | Short | Tu |
95 * | Week day standalone | c, cc | Numeric: 1 digit | 2 |
96 * | | ccc | Abbreviated | Tue |
97 * | | cccc | Wide | Tuesday |
98 * | | ccccc | Narrow | T |
99 * | | cccccc | Short | Tu |
100 * | Period | a, aa & aaa | Abbreviated | am/pm or AM/PM |
101 * | | aaaa | Wide (fallback to `a` when missing) | ante meridiem/post meridiem |
102 * | | aaaaa | Narrow | a/p |
103 * | Period* | B, BB & BBB | Abbreviated | mid. |
104 * | | BBBB | Wide | am, pm, midnight, noon, morning, afternoon, evening, night |
105 * | | BBBBB | Narrow | md |
106 * | Period standalone* | b, bb & bbb | Abbreviated | mid. |
107 * | | bbbb | Wide | am, pm, midnight, noon, morning, afternoon, evening, night |
108 * | | bbbbb | Narrow | md |
109 * | Hour 1-12 | h | Numeric: minimum digits | 1, 12 |
110 * | | hh | Numeric: 2 digits + zero padded | 01, 12 |
111 * | Hour 0-23 | H | Numeric: minimum digits | 0, 23 |
112 * | | HH | Numeric: 2 digits + zero padded | 00, 23 |
113 * | Minute | m | Numeric: minimum digits | 8, 59 |
114 * | | mm | Numeric: 2 digits + zero padded | 08, 59 |
115 * | Second | s | Numeric: minimum digits | 0... 59 |
116 * | | ss | Numeric: 2 digits + zero padded | 00... 59 |
117 * | Fractional seconds | S | Numeric: 1 digit | 0... 9 |
118 * | | SS | Numeric: 2 digits + zero padded | 00... 99 |
119 * | | SSS | Numeric: 3 digits + zero padded (= milliseconds) | 000... 999 |
120 * | Zone | z, zz & zzz | Short specific non location format (fallback to O) | GMT-8 |
121 * | | zzzz | Long specific non location format (fallback to OOOO) | GMT-08:00 |
122 * | | Z, ZZ & ZZZ | ISO8601 basic format | -0800 |
123 * | | ZZZZ | Long localized GMT format | GMT-8:00 |
124 * | | ZZZZZ | ISO8601 extended format + Z indicator for offset 0 (= XXXXX) | -08:00 |
125 * | | O, OO & OOO | Short localized GMT format | GMT-8 |
126 * | | OOOO | Long localized GMT format | GMT-08:00 |
127 *
128 *
129 * ### Format examples
130 *
131 * These examples transform a date into various formats,
132 * assuming that `dateObj` is a JavaScript `Date` object for
133 * year: 2015, month: 6, day: 15, hour: 21, minute: 43, second: 11,
134 * given in the local time for the `en-US` locale.
135 *
136 * ```
137 * {{ dateObj | date }} // output is 'Jun 15, 2015'
138 * {{ dateObj | date:'medium' }} // output is 'Jun 15, 2015, 9:43:11 PM'
139 * {{ dateObj | date:'shortTime' }} // output is '9:43 PM'
140 * {{ dateObj | date:'mm:ss' }} // output is '43:11'
141 * ```
142 *
143 * ### Usage example
144 *
145 * The following component uses a date pipe to display the current date in different formats.
146 *
147 * ```
148 * @Component({
149 * selector: 'date-pipe',
150 * template: `<div>
151 * <p>Today is {{today | date}}</p>
152 * <p>Or if you prefer, {{today | date:'fullDate'}}</p>
153 * <p>The time is {{today | date:'h:mm a z'}}</p>
154 * </div>`
155 * })
156 * // Get the current date and time as a date-time value.
157 * export class DatePipeComponent {
158 * today: number = Date.now();
159 * }
160 * ```
161 *
162 * @publicApi
163 */
164// clang-format on
165export class DatePipe {
166 constructor(locale) {
167 this.locale = locale;
168 }
169 transform(value, format = 'mediumDate', timezone, locale) {
170 if (value == null || value === '' || value !== value)
171 return null;
172 try {
173 return formatDate(value, format, locale || this.locale, timezone);
174 }
175 catch (error) {
176 throw invalidPipeArgumentError(DatePipe, error.message);
177 }
178 }
179}
180DatePipe.decorators = [
181 { type: Pipe, args: [{ name: 'date', pure: true },] }
182];
183DatePipe.ctorParameters = () => [
184 { type: String, decorators: [{ type: Inject, args: [LOCALE_ID,] }] }
185];
186//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date_pipe.js","sourceRoot":"","sources":["../../../../../../../packages/common/src/pipes/date_pipe.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,MAAM,EAAE,SAAS,EAAE,IAAI,EAAgB,MAAM,eAAe,CAAC;AACrE,OAAO,EAAC,UAAU,EAAC,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAC,wBAAwB,EAAC,MAAM,+BAA+B,CAAC;AAEvE,mBAAmB;AACnB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuJG;AACH,kBAAkB;AAElB,MAAM,OAAO,QAAQ;IACnB,YAAuC,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;IAAG,CAAC;IAqBzD,SAAS,CACL,KAAwC,EAAE,MAAM,GAAG,YAAY,EAAE,QAAiB,EAClF,MAAe;QACjB,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,KAAK,KAAK;YAAE,OAAO,IAAI,CAAC;QAElE,IAAI;YACF,OAAO,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;SACnE;QAAC,OAAO,KAAK,EAAE;YACd,MAAM,wBAAwB,CAAC,QAAQ,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;SACzD;IACH,CAAC;;;YAjCF,IAAI,SAAC,EAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAC;;;yCAEjB,MAAM,SAAC,SAAS","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Inject, LOCALE_ID, Pipe, PipeTransform} from '@angular/core';\nimport {formatDate} from '../i18n/format_date';\nimport {invalidPipeArgumentError} from './invalid_pipe_argument_error';\n\n// clang-format off\n/**\n * @ngModule CommonModule\n * @description\n *\n * Formats a date value according to locale rules.\n * \n * `DatePipe` is executed only when it detects a pure change to the input value.\n * A pure change is either a change to a primitive input value\n * (such as `String`, `Number`, `Boolean`, or `Symbol`),\n * or a changed object reference (such as `Date`, `Array`, `Function`, or `Object`).\n *\n * Note that mutating a `Date` object does not cause the pipe to be rendered again.\n * To ensure that the pipe is executed, you must create a new `Date` object.\n *\n * Only the `en-US` locale data comes with Angular. To localize dates\n * in another language, you must import the corresponding locale data.\n * See the [I18n guide](guide/i18n-common-format-data-locale) for more information.\n *\n * @see `formatDate()`\n *\n *\n * @usageNotes\n *\n * The result of this pipe is not reevaluated when the input is mutated. To avoid the need to\n * reformat the date on every change-detection cycle, treat the date as an immutable object\n * and change the reference when the pipe needs to run again.\n *\n * ### Pre-defined format options\n *\n * | Option        | Equivalent to                       | Examples (given in `en-US` locale)              |\n * |---------------|-------------------------------------|-------------------------------------------------|\n * | `'short'`     | `'M/d/yy, h:mm a'`                  | `6/15/15, 9:03 AM`                              |\n * | `'medium'`    | `'MMM d, y, h:mm:ss a'`             | `Jun 15, 2015, 9:03:01 AM`                      |\n * | `'long'`      | `'MMMM d, y, h:mm:ss a z'`          | `June 15, 2015 at 9:03:01 AM GMT+1`             |\n * | `'full'`      | `'EEEE, MMMM d, y, h:mm:ss a zzzz'` | `Monday, June 15, 2015 at 9:03:01 AM GMT+01:00` |\n * | `'shortDate'` | `'M/d/yy'`                          | `6/15/15`                                       |\n * | `'mediumDate'`| `'MMM d, y'`                        | `Jun 15, 2015`                                  |\n * | `'longDate'`  | `'MMMM d, y'`                       | `June 15, 2015`                                 |\n * | `'fullDate'`  | `'EEEE, MMMM d, y'`                 | `Monday, June 15, 2015`                         |\n * | `'shortTime'` | `'h:mm a'`                          | `9:03 AM`                                       |\n * | `'mediumTime'`| `'h:mm:ss a'`                       | `9:03:01 AM`                                    |\n * | `'longTime'`  | `'h:mm:ss a z'`                     | `9:03:01 AM GMT+1`                              |\n * | `'fullTime'`  | `'h:mm:ss a zzzz'`                  | `9:03:01 AM GMT+01:00`                          |\n *\n * ### Custom format options\n *\n * You can construct a format string using symbols to specify the components\n * of a date-time value, as described in the following table.\n * Format details depend on the locale.\n * Fields marked with (*) are only available in the extra data set for the given locale.\n *\n *  | Field type          | Format      | Description                                                   | Example Value                                              |\n *  |-------------------- |-------------|---------------------------------------------------------------|------------------------------------------------------------|\n *  | Era                 | G, GG & GGG | Abbreviated                                                   | AD                                                         |\n *  |                     | GGGG        | Wide                                                          | Anno Domini                                                |\n *  |                     | GGGGG       | Narrow                                                        | A                                                          |\n *  | Year                | y           | Numeric: minimum digits                                       | 2, 20, 201, 2017, 20173                                    |\n *  |                     | yy          | Numeric: 2 digits + zero padded                               | 02, 20, 01, 17, 73                                         |\n *  |                     | yyy         | Numeric: 3 digits + zero padded                               | 002, 020, 201, 2017, 20173                                 |\n *  |                     | yyyy        | Numeric: 4 digits or more + zero padded                       | 0002, 0020, 0201, 2017, 20173                              |\n *  | Week-numbering year | Y           | Numeric: minimum digits                                       | 2, 20, 201, 2017, 20173                                    |\n *  |                     | YY          | Numeric: 2 digits + zero padded                               | 02, 20, 01, 17, 73                                         |\n *  |                     | YYY         | Numeric: 3 digits + zero padded                               | 002, 020, 201, 2017, 20173                                 |\n *  |                     | YYYY        | Numeric: 4 digits or more + zero padded                       | 0002, 0020, 0201, 2017, 20173                              |\n *  | Month               | M           | Numeric: 1 digit                                              | 9, 12                                                      |\n *  |                     | MM          | Numeric: 2 digits + zero padded                               | 09, 12                                                     |\n *  |                     | MMM         | Abbreviated                                                   | Sep                                                        |\n *  |                     | MMMM        | Wide                                                          | September                                                  |\n *  |                     | MMMMM       | Narrow                                                        | S                                                          |\n *  | Month standalone    | L           | Numeric: 1 digit                                              | 9, 12                                                      |\n *  |                     | LL          | Numeric: 2 digits + zero padded                               | 09, 12                                                     |\n *  |                     | LLL         | Abbreviated                                                   | Sep                                                        |\n *  |                     | LLLL        | Wide                                                          | September                                                  |\n *  |                     | LLLLL       | Narrow                                                        | S                                                          |\n *  | Week of year        | w           | Numeric: minimum digits                                       | 1... 53                                                    |\n *  |                     | ww          | Numeric: 2 digits + zero padded                               | 01... 53                                                   |\n *  | Week of month       | W           | Numeric: 1 digit                                              | 1... 5                                                     |\n *  | Day of month        | d           | Numeric: minimum digits                                       | 1                                                          |\n *  |                     | dd          | Numeric: 2 digits + zero padded                               | 01                                                         |\n *  | Week day            | E, EE & EEE | Abbreviated                                                   | Tue                                                        |\n *  |                     | EEEE        | Wide                                                          | Tuesday                                                    |\n *  |                     | EEEEE       | Narrow                                                        | T                                                          |\n *  |                     | EEEEEE      | Short                                                         | Tu                                                         |\n *  | Week day standalone | c, cc       | Numeric: 1 digit                                              | 2                                                          |\n *  |                     | ccc         | Abbreviated                                                   | Tue                                                        |\n *  |                     | cccc        | Wide                                                          | Tuesday                                                    |\n *  |                     | ccccc       | Narrow                                                        | T                                                          |\n *  |                     | cccccc      | Short                                                         | Tu                                                         |\n *  | Period              | a, aa & aaa | Abbreviated                                                   | am/pm or AM/PM                                             |\n *  |                     | aaaa        | Wide (fallback to `a` when missing)                           | ante meridiem/post meridiem                                |\n *  |                     | aaaaa       | Narrow                                                        | a/p                                                        |\n *  | Period*             | B, BB & BBB | Abbreviated                                                   | mid.                                                       |\n *  |                     | BBBB        | Wide                                                          | am, pm, midnight, noon, morning, afternoon, evening, night |\n *  |                     | BBBBB       | Narrow                                                        | md                                                         |\n *  | Period standalone*  | b, bb & bbb | Abbreviated                                                   | mid.                                                       |\n *  |                     | bbbb        | Wide                                                          | am, pm, midnight, noon, morning, afternoon, evening, night |\n *  |                     | bbbbb       | Narrow                                                        | md                                                         |\n *  | Hour 1-12           | h           | Numeric: minimum digits                                       | 1, 12                                                      |\n *  |                     | hh          | Numeric: 2 digits + zero padded                               | 01, 12                                                     |\n *  | Hour 0-23           | H           | Numeric: minimum digits                                       | 0, 23                                                      |\n *  |                     | HH          | Numeric: 2 digits + zero padded                               | 00, 23                                                     |\n *  | Minute              | m           | Numeric: minimum digits                                       | 8, 59                                                      |\n *  |                     | mm          | Numeric: 2 digits + zero padded                               | 08, 59                                                     |\n *  | Second              | s           | Numeric: minimum digits                                       | 0... 59                                                    |\n *  |                     | ss          | Numeric: 2 digits + zero padded                               | 00... 59                                                   |\n *  | Fractional seconds  | S           | Numeric: 1 digit                                              | 0... 9                                                     |\n *  |                     | SS          | Numeric: 2 digits + zero padded                               | 00... 99                                                   |\n *  |                     | SSS         | Numeric: 3 digits + zero padded (= milliseconds)              | 000... 999                                                 |\n *  | Zone                | z, zz & zzz | Short specific non location format (fallback to O)            | GMT-8                                                      |\n *  |                     | zzzz        | Long specific non location format (fallback to OOOO)          | GMT-08:00                                                  |\n *  |                     | Z, ZZ & ZZZ | ISO8601 basic format                                          | -0800                                                      |\n *  |                     | ZZZZ        | Long localized GMT format                                     | GMT-8:00                                                   |\n *  |                     | ZZZZZ       | ISO8601 extended format + Z indicator for offset 0 (= XXXXX)  | -08:00                                                     |\n *  |                     | O, OO & OOO | Short localized GMT format                                    | GMT-8                                                      |\n *  |                     | OOOO        | Long localized GMT format                                     | GMT-08:00                                                  |\n *\n *\n * ### Format examples\n *\n * These examples transform a date into various formats,\n * assuming that `dateObj` is a JavaScript `Date` object for\n * year: 2015, month: 6, day: 15, hour: 21, minute: 43, second: 11,\n * given in the local time for the `en-US` locale.\n *\n * ```\n * {{ dateObj | date }}               // output is 'Jun 15, 2015'\n * {{ dateObj | date:'medium' }}      // output is 'Jun 15, 2015, 9:43:11 PM'\n * {{ dateObj | date:'shortTime' }}   // output is '9:43 PM'\n * {{ dateObj | date:'mm:ss' }}       // output is '43:11'\n * ```\n *\n * ### Usage example\n *\n * The following component uses a date pipe to display the current date in different formats.\n *\n * ```\n * @Component({\n *  selector: 'date-pipe',\n *  template: `<div>\n *    <p>Today is {{today | date}}</p>\n *    <p>Or if you prefer, {{today | date:'fullDate'}}</p>\n *    <p>The time is {{today | date:'h:mm a z'}}</p>\n *  </div>`\n * })\n * // Get the current date and time as a date-time value.\n * export class DatePipeComponent {\n *   today: number = Date.now();\n * }\n * ```\n *\n * @publicApi\n */\n// clang-format on\n@Pipe({name: 'date', pure: true})\nexport class DatePipe implements PipeTransform {\n  constructor(@Inject(LOCALE_ID) private locale: string) {}\n\n  /**\n   * @param value The date expression: a `Date` object,  a number\n   * (milliseconds since UTC epoch), or an ISO string (https://www.w3.org/TR/NOTE-datetime).\n   * @param format The date/time components to include, using predefined options or a\n   * custom format string.\n   * @param timezone A timezone offset (such as `'+0430'`), or a standard\n   * UTC/GMT or continental US timezone abbreviation.\n   * When not supplied, uses the end-user's local system timezone.\n   * @param locale A locale code for the locale format rules to use.\n   * When not supplied, uses the value of `LOCALE_ID`, which is `en-US` by default.\n   * See [Setting your app locale](guide/i18n-common-locale-id).\n   * @returns A date string in the desired format.\n   */\n  transform(value: Date|string|number, format?: string, timezone?: string, locale?: string): string\n      |null;\n  transform(value: null|undefined, format?: string, timezone?: string, locale?: string): null;\n  transform(\n      value: Date|string|number|null|undefined, format?: string, timezone?: string,\n      locale?: string): string|null;\n  transform(\n      value: Date|string|number|null|undefined, format = 'mediumDate', timezone?: string,\n      locale?: string): string|null {\n    if (value == null || value === '' || value !== value) return null;\n\n    try {\n      return formatDate(value, format, locale || this.locale, timezone);\n    } catch (error) {\n      throw invalidPipeArgumentError(DatePipe, error.message);\n    }\n  }\n}\n"]}
Note: See TracBrowser for help on using the repository browser.