@angular/platform-browser 19.0.0-next.1 → 19.0.0-next.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/animations/async/index.d.ts +10 -1
- package/animations/index.d.ts +1 -1
- package/fesm2022/animations/async.mjs +25 -9
- package/fesm2022/animations/async.mjs.map +1 -1
- package/fesm2022/animations.mjs +12 -12
- package/fesm2022/platform-browser.mjs +49 -49
- package/fesm2022/platform-browser.mjs.map +1 -1
- package/fesm2022/testing.mjs +5 -5
- package/index.d.ts +1 -1
- package/package.json +4 -12
- package/testing/index.d.ts +1 -1
- package/esm2022/animations/animations.mjs +0 -5
- package/esm2022/animations/async/async.mjs +0 -5
- package/esm2022/animations/async/index.mjs +0 -13
- package/esm2022/animations/async/public_api.mjs +0 -14
- package/esm2022/animations/async/src/async-animations.mjs +0 -15
- package/esm2022/animations/async/src/async_animation_renderer.mjs +0 -207
- package/esm2022/animations/async/src/private_export.mjs +0 -9
- package/esm2022/animations/async/src/providers.mjs +0 -55
- package/esm2022/animations/index.mjs +0 -13
- package/esm2022/animations/public_api.mjs +0 -14
- package/esm2022/animations/src/animations.mjs +0 -16
- package/esm2022/animations/src/module.mjs +0 -123
- package/esm2022/animations/src/private_export.mjs +0 -9
- package/esm2022/animations/src/providers.mjs +0 -66
- package/esm2022/index.mjs +0 -13
- package/esm2022/platform-browser.mjs +0 -5
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/src/browser/browser_adapter.mjs +0 -86
- package/esm2022/src/browser/generic_browser_adapter.mjs +0 -21
- package/esm2022/src/browser/meta.mjs +0 -176
- package/esm2022/src/browser/testability.mjs +0 -57
- package/esm2022/src/browser/title.mjs +0 -48
- package/esm2022/src/browser/tools/common_tools.mjs +0 -63
- package/esm2022/src/browser/tools/tools.mjs +0 -36
- package/esm2022/src/browser/xhr.mjs +0 -16
- package/esm2022/src/browser.mjs +0 -241
- package/esm2022/src/dom/debug/by.mjs +0 -61
- package/esm2022/src/dom/dom_renderer.mjs +0 -381
- package/esm2022/src/dom/events/dom_events.mjs +0 -37
- package/esm2022/src/dom/events/event_delegation.mjs +0 -37
- package/esm2022/src/dom/events/event_manager.mjs +0 -91
- package/esm2022/src/dom/events/hammer_gestures.mjs +0 -266
- package/esm2022/src/dom/events/key_events.mjs +0 -183
- package/esm2022/src/dom/shared_styles_host.mjs +0 -161
- package/esm2022/src/dom/util.mjs +0 -26
- package/esm2022/src/errors.mjs +0 -2
- package/esm2022/src/hydration.mjs +0 -183
- package/esm2022/src/platform-browser.mjs +0 -20
- package/esm2022/src/private_export.mjs +0 -18
- package/esm2022/src/security/dom_sanitization_service.mjs +0 -119
- package/esm2022/src/version.mjs +0 -18
- package/esm2022/testing/index.mjs +0 -13
- package/esm2022/testing/public_api.mjs +0 -15
- package/esm2022/testing/src/browser.mjs +0 -52
- package/esm2022/testing/src/browser_util.mjs +0 -130
- package/esm2022/testing/src/matchers.mjs +0 -146
- package/esm2022/testing/src/testing.mjs +0 -14
- package/esm2022/testing/testing.mjs +0 -5
@@ -1,161 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
import { DOCUMENT, isPlatformServer } from '@angular/common';
|
9
|
-
import { APP_ID, CSP_NONCE, Inject, Injectable, Optional, PLATFORM_ID, } from '@angular/core';
|
10
|
-
import * as i0 from "@angular/core";
|
11
|
-
/** The style elements attribute name used to set value of `APP_ID` token. */
|
12
|
-
const APP_ID_ATTRIBUTE_NAME = 'ng-app-id';
|
13
|
-
export class SharedStylesHost {
|
14
|
-
constructor(doc, appId, nonce, platformId = {}) {
|
15
|
-
this.doc = doc;
|
16
|
-
this.appId = appId;
|
17
|
-
this.nonce = nonce;
|
18
|
-
this.platformId = platformId;
|
19
|
-
// Maps all registered host nodes to a list of style nodes that have been added to the host node.
|
20
|
-
this.styleRef = new Map();
|
21
|
-
this.hostNodes = new Set();
|
22
|
-
this.styleNodesInDOM = this.collectServerRenderedStyles();
|
23
|
-
this.platformIsServer = isPlatformServer(platformId);
|
24
|
-
this.resetHostNodes();
|
25
|
-
}
|
26
|
-
addStyles(styles) {
|
27
|
-
for (const style of styles) {
|
28
|
-
const usageCount = this.changeUsageCount(style, 1);
|
29
|
-
if (usageCount === 1) {
|
30
|
-
this.onStyleAdded(style);
|
31
|
-
}
|
32
|
-
}
|
33
|
-
}
|
34
|
-
removeStyles(styles) {
|
35
|
-
for (const style of styles) {
|
36
|
-
const usageCount = this.changeUsageCount(style, -1);
|
37
|
-
if (usageCount <= 0) {
|
38
|
-
this.onStyleRemoved(style);
|
39
|
-
}
|
40
|
-
}
|
41
|
-
}
|
42
|
-
ngOnDestroy() {
|
43
|
-
const styleNodesInDOM = this.styleNodesInDOM;
|
44
|
-
if (styleNodesInDOM) {
|
45
|
-
styleNodesInDOM.forEach((node) => node.remove());
|
46
|
-
styleNodesInDOM.clear();
|
47
|
-
}
|
48
|
-
for (const style of this.getAllStyles()) {
|
49
|
-
this.onStyleRemoved(style);
|
50
|
-
}
|
51
|
-
this.resetHostNodes();
|
52
|
-
}
|
53
|
-
addHost(hostNode) {
|
54
|
-
this.hostNodes.add(hostNode);
|
55
|
-
for (const style of this.getAllStyles()) {
|
56
|
-
this.addStyleToHost(hostNode, style);
|
57
|
-
}
|
58
|
-
}
|
59
|
-
removeHost(hostNode) {
|
60
|
-
this.hostNodes.delete(hostNode);
|
61
|
-
}
|
62
|
-
getAllStyles() {
|
63
|
-
return this.styleRef.keys();
|
64
|
-
}
|
65
|
-
onStyleAdded(style) {
|
66
|
-
for (const host of this.hostNodes) {
|
67
|
-
this.addStyleToHost(host, style);
|
68
|
-
}
|
69
|
-
}
|
70
|
-
onStyleRemoved(style) {
|
71
|
-
const styleRef = this.styleRef;
|
72
|
-
styleRef.get(style)?.elements?.forEach((node) => node.remove());
|
73
|
-
styleRef.delete(style);
|
74
|
-
}
|
75
|
-
collectServerRenderedStyles() {
|
76
|
-
const styles = this.doc.head?.querySelectorAll(`style[${APP_ID_ATTRIBUTE_NAME}="${this.appId}"]`);
|
77
|
-
if (styles?.length) {
|
78
|
-
const styleMap = new Map();
|
79
|
-
styles.forEach((style) => {
|
80
|
-
if (style.textContent != null) {
|
81
|
-
styleMap.set(style.textContent, style);
|
82
|
-
}
|
83
|
-
});
|
84
|
-
return styleMap;
|
85
|
-
}
|
86
|
-
return null;
|
87
|
-
}
|
88
|
-
changeUsageCount(style, delta) {
|
89
|
-
const map = this.styleRef;
|
90
|
-
if (map.has(style)) {
|
91
|
-
const styleRefValue = map.get(style);
|
92
|
-
styleRefValue.usage += delta;
|
93
|
-
return styleRefValue.usage;
|
94
|
-
}
|
95
|
-
map.set(style, { usage: delta, elements: [] });
|
96
|
-
return delta;
|
97
|
-
}
|
98
|
-
getStyleElement(host, style) {
|
99
|
-
const styleNodesInDOM = this.styleNodesInDOM;
|
100
|
-
const styleEl = styleNodesInDOM?.get(style);
|
101
|
-
if (styleEl?.parentNode === host) {
|
102
|
-
// `styleNodesInDOM` cannot be undefined due to the above `styleNodesInDOM?.get`.
|
103
|
-
styleNodesInDOM.delete(style);
|
104
|
-
styleEl.removeAttribute(APP_ID_ATTRIBUTE_NAME);
|
105
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
106
|
-
// This attribute is solely used for debugging purposes.
|
107
|
-
styleEl.setAttribute('ng-style-reused', '');
|
108
|
-
}
|
109
|
-
return styleEl;
|
110
|
-
}
|
111
|
-
else {
|
112
|
-
const styleEl = this.doc.createElement('style');
|
113
|
-
if (this.nonce) {
|
114
|
-
styleEl.setAttribute('nonce', this.nonce);
|
115
|
-
}
|
116
|
-
styleEl.textContent = style;
|
117
|
-
if (this.platformIsServer) {
|
118
|
-
styleEl.setAttribute(APP_ID_ATTRIBUTE_NAME, this.appId);
|
119
|
-
}
|
120
|
-
host.appendChild(styleEl);
|
121
|
-
return styleEl;
|
122
|
-
}
|
123
|
-
}
|
124
|
-
addStyleToHost(host, style) {
|
125
|
-
const styleEl = this.getStyleElement(host, style);
|
126
|
-
const styleRef = this.styleRef;
|
127
|
-
const styleElRef = styleRef.get(style)?.elements;
|
128
|
-
if (styleElRef) {
|
129
|
-
styleElRef.push(styleEl);
|
130
|
-
}
|
131
|
-
else {
|
132
|
-
styleRef.set(style, { elements: [styleEl], usage: 1 });
|
133
|
-
}
|
134
|
-
}
|
135
|
-
resetHostNodes() {
|
136
|
-
const hostNodes = this.hostNodes;
|
137
|
-
hostNodes.clear();
|
138
|
-
// Re-add the head element back since this is the default host.
|
139
|
-
hostNodes.add(this.doc.head);
|
140
|
-
}
|
141
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: SharedStylesHost, deps: [{ token: DOCUMENT }, { token: APP_ID }, { token: CSP_NONCE, optional: true }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
142
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: SharedStylesHost }); }
|
143
|
-
}
|
144
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: SharedStylesHost, decorators: [{
|
145
|
-
type: Injectable
|
146
|
-
}], ctorParameters: () => [{ type: Document, decorators: [{
|
147
|
-
type: Inject,
|
148
|
-
args: [DOCUMENT]
|
149
|
-
}] }, { type: undefined, decorators: [{
|
150
|
-
type: Inject,
|
151
|
-
args: [APP_ID]
|
152
|
-
}] }, { type: undefined, decorators: [{
|
153
|
-
type: Inject,
|
154
|
-
args: [CSP_NONCE]
|
155
|
-
}, {
|
156
|
-
type: Optional
|
157
|
-
}] }, { type: undefined, decorators: [{
|
158
|
-
type: Inject,
|
159
|
-
args: [PLATFORM_ID]
|
160
|
-
}] }] });
|
161
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shared_styles_host.js","sourceRoot":"","sources":["../../../../../../../packages/platform-browser/src/dom/shared_styles_host.ts"],"names":[],"mappings":"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","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 {DOCUMENT, isPlatformServer} from '@angular/common';\nimport {\n  APP_ID,\n  CSP_NONCE,\n  Inject,\n  Injectable,\n  OnDestroy,\n  Optional,\n  PLATFORM_ID,\n} from '@angular/core';\n\n/** The style elements attribute name used to set value of `APP_ID` token. */\nconst APP_ID_ATTRIBUTE_NAME = 'ng-app-id';\n\n@Injectable()\nexport class SharedStylesHost implements OnDestroy {\n  // Maps all registered host nodes to a list of style nodes that have been added to the host node.\n  private readonly styleRef = new Map<\n    string /** Style string */,\n    {\n      elements: HTMLStyleElement[];\n      usage: number;\n    }\n  >();\n  private readonly hostNodes = new Set<Node>();\n  private readonly styleNodesInDOM: Map<string, HTMLStyleElement> | null;\n  private readonly platformIsServer: boolean;\n\n  constructor(\n    @Inject(DOCUMENT) private readonly doc: Document,\n    @Inject(APP_ID) private readonly appId: string,\n    @Inject(CSP_NONCE) @Optional() private nonce?: string | null,\n    @Inject(PLATFORM_ID) readonly platformId: object = {},\n  ) {\n    this.styleNodesInDOM = this.collectServerRenderedStyles();\n    this.platformIsServer = isPlatformServer(platformId);\n    this.resetHostNodes();\n  }\n\n  addStyles(styles: string[]): void {\n    for (const style of styles) {\n      const usageCount = this.changeUsageCount(style, 1);\n\n      if (usageCount === 1) {\n        this.onStyleAdded(style);\n      }\n    }\n  }\n\n  removeStyles(styles: string[]): void {\n    for (const style of styles) {\n      const usageCount = this.changeUsageCount(style, -1);\n\n      if (usageCount <= 0) {\n        this.onStyleRemoved(style);\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    const styleNodesInDOM = this.styleNodesInDOM;\n    if (styleNodesInDOM) {\n      styleNodesInDOM.forEach((node) => node.remove());\n      styleNodesInDOM.clear();\n    }\n\n    for (const style of this.getAllStyles()) {\n      this.onStyleRemoved(style);\n    }\n\n    this.resetHostNodes();\n  }\n\n  addHost(hostNode: Node): void {\n    this.hostNodes.add(hostNode);\n\n    for (const style of this.getAllStyles()) {\n      this.addStyleToHost(hostNode, style);\n    }\n  }\n\n  removeHost(hostNode: Node): void {\n    this.hostNodes.delete(hostNode);\n  }\n\n  private getAllStyles(): IterableIterator<string> {\n    return this.styleRef.keys();\n  }\n\n  private onStyleAdded(style: string): void {\n    for (const host of this.hostNodes) {\n      this.addStyleToHost(host, style);\n    }\n  }\n\n  private onStyleRemoved(style: string): void {\n    const styleRef = this.styleRef;\n    styleRef.get(style)?.elements?.forEach((node) => node.remove());\n    styleRef.delete(style);\n  }\n\n  private collectServerRenderedStyles(): Map<string, HTMLStyleElement> | null {\n    const styles = this.doc.head?.querySelectorAll<HTMLStyleElement>(\n      `style[${APP_ID_ATTRIBUTE_NAME}=\"${this.appId}\"]`,\n    );\n\n    if (styles?.length) {\n      const styleMap = new Map<string, HTMLStyleElement>();\n\n      styles.forEach((style) => {\n        if (style.textContent != null) {\n          styleMap.set(style.textContent, style);\n        }\n      });\n\n      return styleMap;\n    }\n\n    return null;\n  }\n\n  private changeUsageCount(style: string, delta: number): number {\n    const map = this.styleRef;\n    if (map.has(style)) {\n      const styleRefValue = map.get(style)!;\n      styleRefValue.usage += delta;\n\n      return styleRefValue.usage;\n    }\n\n    map.set(style, {usage: delta, elements: []});\n    return delta;\n  }\n\n  private getStyleElement(host: Node, style: string): HTMLStyleElement {\n    const styleNodesInDOM = this.styleNodesInDOM;\n    const styleEl = styleNodesInDOM?.get(style);\n    if (styleEl?.parentNode === host) {\n      // `styleNodesInDOM` cannot be undefined due to the above `styleNodesInDOM?.get`.\n      styleNodesInDOM!.delete(style);\n\n      styleEl.removeAttribute(APP_ID_ATTRIBUTE_NAME);\n\n      if (typeof ngDevMode === 'undefined' || ngDevMode) {\n        // This attribute is solely used for debugging purposes.\n        styleEl.setAttribute('ng-style-reused', '');\n      }\n\n      return styleEl;\n    } else {\n      const styleEl = this.doc.createElement('style');\n\n      if (this.nonce) {\n        styleEl.setAttribute('nonce', this.nonce);\n      }\n\n      styleEl.textContent = style;\n\n      if (this.platformIsServer) {\n        styleEl.setAttribute(APP_ID_ATTRIBUTE_NAME, this.appId);\n      }\n\n      host.appendChild(styleEl);\n\n      return styleEl;\n    }\n  }\n\n  private addStyleToHost(host: Node, style: string): void {\n    const styleEl = this.getStyleElement(host, style);\n    const styleRef = this.styleRef;\n    const styleElRef = styleRef.get(style)?.elements;\n    if (styleElRef) {\n      styleElRef.push(styleEl);\n    } else {\n      styleRef.set(style, {elements: [styleEl], usage: 1});\n    }\n  }\n\n  private resetHostNodes(): void {\n    const hostNodes = this.hostNodes;\n    hostNodes.clear();\n    // Re-add the head element back since this is the default host.\n    hostNodes.add(this.doc.head);\n  }\n}\n"]}
|
package/esm2022/src/dom/util.mjs
DELETED
@@ -1,26 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
import { ɵglobal as global } from '@angular/core';
|
9
|
-
/**
|
10
|
-
* Exports the value under a given `name` in the global property `ng`. For example `ng.probe` if
|
11
|
-
* `name` is `'probe'`.
|
12
|
-
* @param name Name under which it will be exported. Keep in mind this will be a property of the
|
13
|
-
* global `ng` object.
|
14
|
-
* @param value The value to export.
|
15
|
-
*/
|
16
|
-
export function exportNgVar(name, value) {
|
17
|
-
if (typeof COMPILED === 'undefined' || !COMPILED) {
|
18
|
-
// Note: we can't export `ng` when using closure enhanced optimization as:
|
19
|
-
// - closure declares globals itself for minified names, which sometimes clobber our `ng` global
|
20
|
-
// - we can't declare a closure extern as the namespace `ng` is already used within Google
|
21
|
-
// for typings for angularJS (via `goog.provide('ng....')`).
|
22
|
-
const ng = (global['ng'] = global['ng'] || {});
|
23
|
-
ng[name] = value;
|
24
|
-
}
|
25
|
-
}
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYXRmb3JtLWJyb3dzZXIvc3JjL2RvbS91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVILE9BQU8sRUFBQyxPQUFPLElBQUksTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWhEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBWSxFQUFFLEtBQVU7SUFDbEQsSUFBSSxPQUFPLFFBQVEsS0FBSyxXQUFXLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqRCwwRUFBMEU7UUFDMUUsZ0dBQWdHO1FBQ2hHLDBGQUEwRjtRQUMxRiw4REFBOEQ7UUFDOUQsTUFBTSxFQUFFLEdBQUcsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUksTUFBTSxDQUFDLElBQUksQ0FBc0MsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNyRixFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDO0lBQ25CLENBQUM7QUFDSCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7ybVnbG9iYWwgYXMgZ2xvYmFsfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBFeHBvcnRzIHRoZSB2YWx1ZSB1bmRlciBhIGdpdmVuIGBuYW1lYCBpbiB0aGUgZ2xvYmFsIHByb3BlcnR5IGBuZ2AuIEZvciBleGFtcGxlIGBuZy5wcm9iZWAgaWZcbiAqIGBuYW1lYCBpcyBgJ3Byb2JlJ2AuXG4gKiBAcGFyYW0gbmFtZSBOYW1lIHVuZGVyIHdoaWNoIGl0IHdpbGwgYmUgZXhwb3J0ZWQuIEtlZXAgaW4gbWluZCB0aGlzIHdpbGwgYmUgYSBwcm9wZXJ0eSBvZiB0aGVcbiAqIGdsb2JhbCBgbmdgIG9iamVjdC5cbiAqIEBwYXJhbSB2YWx1ZSBUaGUgdmFsdWUgdG8gZXhwb3J0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gZXhwb3J0TmdWYXIobmFtZTogc3RyaW5nLCB2YWx1ZTogYW55KTogdm9pZCB7XG4gIGlmICh0eXBlb2YgQ09NUElMRUQgPT09ICd1bmRlZmluZWQnIHx8ICFDT01QSUxFRCkge1xuICAgIC8vIE5vdGU6IHdlIGNhbid0IGV4cG9ydCBgbmdgIHdoZW4gdXNpbmcgY2xvc3VyZSBlbmhhbmNlZCBvcHRpbWl6YXRpb24gYXM6XG4gICAgLy8gLSBjbG9zdXJlIGRlY2xhcmVzIGdsb2JhbHMgaXRzZWxmIGZvciBtaW5pZmllZCBuYW1lcywgd2hpY2ggc29tZXRpbWVzIGNsb2JiZXIgb3VyIGBuZ2AgZ2xvYmFsXG4gICAgLy8gLSB3ZSBjYW4ndCBkZWNsYXJlIGEgY2xvc3VyZSBleHRlcm4gYXMgdGhlIG5hbWVzcGFjZSBgbmdgIGlzIGFscmVhZHkgdXNlZCB3aXRoaW4gR29vZ2xlXG4gICAgLy8gICBmb3IgdHlwaW5ncyBmb3IgYW5ndWxhckpTICh2aWEgYGdvb2cucHJvdmlkZSgnbmcuLi4uJylgKS5cbiAgICBjb25zdCBuZyA9IChnbG9iYWxbJ25nJ10gPSAoZ2xvYmFsWyduZyddIGFzIHtba2V5OiBzdHJpbmddOiBhbnl9IHwgdW5kZWZpbmVkKSB8fCB7fSk7XG4gICAgbmdbbmFtZV0gPSB2YWx1ZTtcbiAgfVxufVxuIl19
|
package/esm2022/src/errors.mjs
DELETED
@@ -1,2 +0,0 @@
|
|
1
|
-
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhdGZvcm0tYnJvd3Nlci9zcmMvZXJyb3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cbi8qKlxuICogVGhlIGxpc3Qgb2YgZXJyb3IgY29kZXMgdXNlZCBpbiBydW50aW1lIGNvZGUgb2YgdGhlIGBwbGF0Zm9ybS1icm93c2VyYCBwYWNrYWdlLlxuICogUmVzZXJ2ZWQgZXJyb3IgY29kZSByYW5nZTogNTAwMC01NTAwLlxuICovXG5leHBvcnQgY29uc3QgZW51bSBSdW50aW1lRXJyb3JDb2RlIHtcbiAgLy8gSHlkcmF0aW9uIEVycm9yc1xuICBVTlNVUFBPUlRFRF9aT05FSlNfSU5TVEFOQ0UgPSAtNTAwMCxcblxuICAvLyBtaXNjIGVycm9ycyAoNTEwMC01MjAwIHJhbmdlKVxuICBCUk9XU0VSX01PRFVMRV9BTFJFQURZX0xPQURFRCA9IDUxMDAsXG4gIE5PX1BMVUdJTl9GT1JfRVZFTlQgPSA1MTAxLFxuICBVTlNVUFBPUlRFRF9FVkVOVF9UQVJHRVQgPSA1MTAyLFxuICBURVNUQUJJTElUWV9OT1RfRk9VTkQgPSA1MTAzLFxuICBST09UX05PREVfTk9UX0ZPVU5EID0gLTUxMDQsXG4gIFVORVhQRUNURURfU1lOVEhFVElDX1BST1BFUlRZID0gNTEwNSxcblxuICAvLyBTYW5pdGl6YXRpb24tcmVsYXRlZCBlcnJvcnMgKDUyMDAtNTMwMCByYW5nZSlcbiAgU0FOSVRJWkFUSU9OX1VOU0FGRV9TQ1JJUFQgPSA1MjAwLFxuICBTQU5JVElaQVRJT05fVU5TQUZFX1JFU09VUkNFX1VSTCA9IDUyMDEsXG4gIFNBTklUSVpBVElPTl9VTkVYUEVDVEVEX0NUWCA9IDUyMDIsXG5cbiAgLy8gQW5pbWF0aW9ucyByZWxhdGVkIGVycm9ycyAoNTMwMC01NDAwIHJhbmdlKVxuICBBTklNQVRJT05fUkVOREVSRVJfQVNZTkNfTE9BRElOR19GQUlMVVJFID0gNTMwMCxcbn1cbiJdfQ==
|
@@ -1,183 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
import { ɵwithHttpTransferCache } from '@angular/common/http';
|
9
|
-
import { ENVIRONMENT_INITIALIZER, inject, makeEnvironmentProviders, NgZone, ɵConsole as Console, ɵformatRuntimeError as formatRuntimeError, ɵwithDomHydration as withDomHydration, ɵwithEventReplay, ɵwithI18nSupport, } from '@angular/core';
|
10
|
-
/**
|
11
|
-
* The list of features as an enum to uniquely type each `HydrationFeature`.
|
12
|
-
* @see {@link HydrationFeature}
|
13
|
-
*
|
14
|
-
* @publicApi
|
15
|
-
*/
|
16
|
-
export var HydrationFeatureKind;
|
17
|
-
(function (HydrationFeatureKind) {
|
18
|
-
HydrationFeatureKind[HydrationFeatureKind["NoHttpTransferCache"] = 0] = "NoHttpTransferCache";
|
19
|
-
HydrationFeatureKind[HydrationFeatureKind["HttpTransferCacheOptions"] = 1] = "HttpTransferCacheOptions";
|
20
|
-
HydrationFeatureKind[HydrationFeatureKind["I18nSupport"] = 2] = "I18nSupport";
|
21
|
-
HydrationFeatureKind[HydrationFeatureKind["EventReplay"] = 3] = "EventReplay";
|
22
|
-
})(HydrationFeatureKind || (HydrationFeatureKind = {}));
|
23
|
-
/**
|
24
|
-
* Helper function to create an object that represents a Hydration feature.
|
25
|
-
*/
|
26
|
-
function hydrationFeature(ɵkind, ɵproviders = [], ɵoptions = {}) {
|
27
|
-
return { ɵkind, ɵproviders };
|
28
|
-
}
|
29
|
-
/**
|
30
|
-
* Disables HTTP transfer cache. Effectively causes HTTP requests to be performed twice: once on the
|
31
|
-
* server and other one on the browser.
|
32
|
-
*
|
33
|
-
* @publicApi
|
34
|
-
*/
|
35
|
-
export function withNoHttpTransferCache() {
|
36
|
-
// This feature has no providers and acts as a flag that turns off
|
37
|
-
// HTTP transfer cache (which otherwise is turned on by default).
|
38
|
-
return hydrationFeature(HydrationFeatureKind.NoHttpTransferCache);
|
39
|
-
}
|
40
|
-
/**
|
41
|
-
* The function accepts a an object, which allows to configure cache parameters,
|
42
|
-
* such as which headers should be included (no headers are included by default),
|
43
|
-
* wether POST requests should be cached or a callback function to determine if a
|
44
|
-
* particular request should be cached.
|
45
|
-
*
|
46
|
-
* @publicApi
|
47
|
-
*/
|
48
|
-
export function withHttpTransferCacheOptions(options) {
|
49
|
-
// This feature has no providers and acts as a flag to pass options to the HTTP transfer cache.
|
50
|
-
return hydrationFeature(HydrationFeatureKind.HttpTransferCacheOptions, ɵwithHttpTransferCache(options));
|
51
|
-
}
|
52
|
-
/**
|
53
|
-
* Enables support for hydrating i18n blocks.
|
54
|
-
*
|
55
|
-
* @developerPreview
|
56
|
-
* @publicApi
|
57
|
-
*/
|
58
|
-
export function withI18nSupport() {
|
59
|
-
return hydrationFeature(HydrationFeatureKind.I18nSupport, ɵwithI18nSupport());
|
60
|
-
}
|
61
|
-
/**
|
62
|
-
* Enables support for replaying user events (e.g. `click`s) that happened on a page
|
63
|
-
* before hydration logic has completed. Once an application is hydrated, all captured
|
64
|
-
* events are replayed and relevant event listeners are executed.
|
65
|
-
*
|
66
|
-
* @usageNotes
|
67
|
-
*
|
68
|
-
* Basic example of how you can enable event replay in your application when
|
69
|
-
* `bootstrapApplication` function is used:
|
70
|
-
* ```
|
71
|
-
* bootstrapApplication(AppComponent, {
|
72
|
-
* providers: [provideClientHydration(withEventReplay())]
|
73
|
-
* });
|
74
|
-
* ```
|
75
|
-
* @developerPreview
|
76
|
-
* @publicApi
|
77
|
-
* @see {@link provideClientHydration}
|
78
|
-
*/
|
79
|
-
export function withEventReplay() {
|
80
|
-
return hydrationFeature(HydrationFeatureKind.EventReplay, ɵwithEventReplay());
|
81
|
-
}
|
82
|
-
/**
|
83
|
-
* Returns an `ENVIRONMENT_INITIALIZER` token setup with a function
|
84
|
-
* that verifies whether compatible ZoneJS was used in an application
|
85
|
-
* and logs a warning in a console if it's not the case.
|
86
|
-
*/
|
87
|
-
function provideZoneJsCompatibilityDetector() {
|
88
|
-
return [
|
89
|
-
{
|
90
|
-
provide: ENVIRONMENT_INITIALIZER,
|
91
|
-
useValue: () => {
|
92
|
-
const ngZone = inject(NgZone);
|
93
|
-
// Checking `ngZone instanceof NgZone` would be insufficient here,
|
94
|
-
// because custom implementations might use NgZone as a base class.
|
95
|
-
if (ngZone.constructor !== NgZone) {
|
96
|
-
const console = inject(Console);
|
97
|
-
const message = formatRuntimeError(-5000 /* RuntimeErrorCode.UNSUPPORTED_ZONEJS_INSTANCE */, 'Angular detected that hydration was enabled for an application ' +
|
98
|
-
'that uses a custom or a noop Zone.js implementation. ' +
|
99
|
-
'This is not yet a fully supported configuration.');
|
100
|
-
// tslint:disable-next-line:no-console
|
101
|
-
console.warn(message);
|
102
|
-
}
|
103
|
-
},
|
104
|
-
multi: true,
|
105
|
-
},
|
106
|
-
];
|
107
|
-
}
|
108
|
-
/**
|
109
|
-
* Sets up providers necessary to enable hydration functionality for the application.
|
110
|
-
*
|
111
|
-
* By default, the function enables the recommended set of features for the optimal
|
112
|
-
* performance for most of the applications. It includes the following features:
|
113
|
-
*
|
114
|
-
* * Reconciling DOM hydration. Learn more about it [here](guide/hydration).
|
115
|
-
* * [`HttpClient`](api/common/http/HttpClient) response caching while running on the server and
|
116
|
-
* transferring this cache to the client to avoid extra HTTP requests. Learn more about data caching
|
117
|
-
* [here](guide/ssr#caching-data-when-using-httpclient).
|
118
|
-
*
|
119
|
-
* These functions allow you to disable some of the default features or enable new ones:
|
120
|
-
*
|
121
|
-
* * {@link withNoHttpTransferCache} to disable HTTP transfer cache
|
122
|
-
* * {@link withHttpTransferCacheOptions} to configure some HTTP transfer cache options
|
123
|
-
* * {@link withI18nSupport} to enable hydration support for i18n blocks
|
124
|
-
* * {@link withEventReplay} to enable support for replaying user events
|
125
|
-
*
|
126
|
-
* @usageNotes
|
127
|
-
*
|
128
|
-
* Basic example of how you can enable hydration in your application when
|
129
|
-
* `bootstrapApplication` function is used:
|
130
|
-
* ```
|
131
|
-
* bootstrapApplication(AppComponent, {
|
132
|
-
* providers: [provideClientHydration()]
|
133
|
-
* });
|
134
|
-
* ```
|
135
|
-
*
|
136
|
-
* Alternatively if you are using NgModules, you would add `provideClientHydration`
|
137
|
-
* to your root app module's provider list.
|
138
|
-
* ```
|
139
|
-
* @NgModule({
|
140
|
-
* declarations: [RootCmp],
|
141
|
-
* bootstrap: [RootCmp],
|
142
|
-
* providers: [provideClientHydration()],
|
143
|
-
* })
|
144
|
-
* export class AppModule {}
|
145
|
-
* ```
|
146
|
-
*
|
147
|
-
* @see {@link withNoHttpTransferCache}
|
148
|
-
* @see {@link withHttpTransferCacheOptions}
|
149
|
-
* @see {@link withI18nSupport}
|
150
|
-
* @see {@link withEventReplay}
|
151
|
-
*
|
152
|
-
* @param features Optional features to configure additional router behaviors.
|
153
|
-
* @returns A set of providers to enable hydration.
|
154
|
-
*
|
155
|
-
* @publicApi
|
156
|
-
*/
|
157
|
-
export function provideClientHydration(...features) {
|
158
|
-
const providers = [];
|
159
|
-
const featuresKind = new Set();
|
160
|
-
const hasHttpTransferCacheOptions = featuresKind.has(HydrationFeatureKind.HttpTransferCacheOptions);
|
161
|
-
for (const { ɵproviders, ɵkind } of features) {
|
162
|
-
featuresKind.add(ɵkind);
|
163
|
-
if (ɵproviders.length) {
|
164
|
-
providers.push(ɵproviders);
|
165
|
-
}
|
166
|
-
}
|
167
|
-
if (typeof ngDevMode !== 'undefined' &&
|
168
|
-
ngDevMode &&
|
169
|
-
featuresKind.has(HydrationFeatureKind.NoHttpTransferCache) &&
|
170
|
-
hasHttpTransferCacheOptions) {
|
171
|
-
// TODO: Make this a runtime error
|
172
|
-
throw new Error('Configuration error: found both withHttpTransferCacheOptions() and withNoHttpTransferCache() in the same call to provideClientHydration(), which is a contradiction.');
|
173
|
-
}
|
174
|
-
return makeEnvironmentProviders([
|
175
|
-
typeof ngDevMode !== 'undefined' && ngDevMode ? provideZoneJsCompatibilityDetector() : [],
|
176
|
-
withDomHydration(),
|
177
|
-
featuresKind.has(HydrationFeatureKind.NoHttpTransferCache) || hasHttpTransferCacheOptions
|
178
|
-
? []
|
179
|
-
: ɵwithHttpTransferCache({}),
|
180
|
-
providers,
|
181
|
-
]);
|
182
|
-
}
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hydration.js","sourceRoot":"","sources":["../../../../../../packages/platform-browser/src/hydration.ts"],"names":[],"mappings":"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","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 {HttpTransferCacheOptions, ɵwithHttpTransferCache} from '@angular/common/http';\nimport {\n  ENVIRONMENT_INITIALIZER,\n  EnvironmentProviders,\n  inject,\n  makeEnvironmentProviders,\n  NgZone,\n  Provider,\n  ɵConsole as Console,\n  ɵformatRuntimeError as formatRuntimeError,\n  ɵwithDomHydration as withDomHydration,\n  ɵwithEventReplay,\n  ɵwithI18nSupport,\n} from '@angular/core';\n\nimport {RuntimeErrorCode} from './errors';\n\n/**\n * The list of features as an enum to uniquely type each `HydrationFeature`.\n * @see {@link HydrationFeature}\n *\n * @publicApi\n */\nexport enum HydrationFeatureKind {\n  NoHttpTransferCache,\n  HttpTransferCacheOptions,\n  I18nSupport,\n  EventReplay,\n}\n\n/**\n * Helper type to represent a Hydration feature.\n *\n * @publicApi\n */\nexport interface HydrationFeature<FeatureKind extends HydrationFeatureKind> {\n  ɵkind: FeatureKind;\n  ɵproviders: Provider[];\n}\n\n/**\n * Helper function to create an object that represents a Hydration feature.\n */\nfunction hydrationFeature<FeatureKind extends HydrationFeatureKind>(\n  ɵkind: FeatureKind,\n  ɵproviders: Provider[] = [],\n  ɵoptions: unknown = {},\n): HydrationFeature<FeatureKind> {\n  return {ɵkind, ɵproviders};\n}\n\n/**\n * Disables HTTP transfer cache. Effectively causes HTTP requests to be performed twice: once on the\n * server and other one on the browser.\n *\n * @publicApi\n */\nexport function withNoHttpTransferCache(): HydrationFeature<HydrationFeatureKind.NoHttpTransferCache> {\n  // This feature has no providers and acts as a flag that turns off\n  // HTTP transfer cache (which otherwise is turned on by default).\n  return hydrationFeature(HydrationFeatureKind.NoHttpTransferCache);\n}\n\n/**\n * The function accepts a an object, which allows to configure cache parameters,\n * such as which headers should be included (no headers are included by default),\n * wether POST requests should be cached or a callback function to determine if a\n * particular request should be cached.\n *\n * @publicApi\n */\nexport function withHttpTransferCacheOptions(\n  options: HttpTransferCacheOptions,\n): HydrationFeature<HydrationFeatureKind.HttpTransferCacheOptions> {\n  // This feature has no providers and acts as a flag to pass options to the HTTP transfer cache.\n  return hydrationFeature(\n    HydrationFeatureKind.HttpTransferCacheOptions,\n    ɵwithHttpTransferCache(options),\n  );\n}\n\n/**\n * Enables support for hydrating i18n blocks.\n *\n * @developerPreview\n * @publicApi\n */\nexport function withI18nSupport(): HydrationFeature<HydrationFeatureKind.I18nSupport> {\n  return hydrationFeature(HydrationFeatureKind.I18nSupport, ɵwithI18nSupport());\n}\n\n/**\n * Enables support for replaying user events (e.g. `click`s) that happened on a page\n * before hydration logic has completed. Once an application is hydrated, all captured\n * events are replayed and relevant event listeners are executed.\n *\n * @usageNotes\n *\n * Basic example of how you can enable event replay in your application when\n * `bootstrapApplication` function is used:\n * ```\n * bootstrapApplication(AppComponent, {\n *   providers: [provideClientHydration(withEventReplay())]\n * });\n * ```\n * @developerPreview\n * @publicApi\n * @see {@link provideClientHydration}\n */\nexport function withEventReplay(): HydrationFeature<HydrationFeatureKind.EventReplay> {\n  return hydrationFeature(HydrationFeatureKind.EventReplay, ɵwithEventReplay());\n}\n\n/**\n * Returns an `ENVIRONMENT_INITIALIZER` token setup with a function\n * that verifies whether compatible ZoneJS was used in an application\n * and logs a warning in a console if it's not the case.\n */\nfunction provideZoneJsCompatibilityDetector(): Provider[] {\n  return [\n    {\n      provide: ENVIRONMENT_INITIALIZER,\n      useValue: () => {\n        const ngZone = inject(NgZone);\n        // Checking `ngZone instanceof NgZone` would be insufficient here,\n        // because custom implementations might use NgZone as a base class.\n        if (ngZone.constructor !== NgZone) {\n          const console = inject(Console);\n          const message = formatRuntimeError(\n            RuntimeErrorCode.UNSUPPORTED_ZONEJS_INSTANCE,\n            'Angular detected that hydration was enabled for an application ' +\n              'that uses a custom or a noop Zone.js implementation. ' +\n              'This is not yet a fully supported configuration.',\n          );\n          // tslint:disable-next-line:no-console\n          console.warn(message);\n        }\n      },\n      multi: true,\n    },\n  ];\n}\n\n/**\n * Sets up providers necessary to enable hydration functionality for the application.\n *\n * By default, the function enables the recommended set of features for the optimal\n * performance for most of the applications. It includes the following features:\n *\n * * Reconciling DOM hydration. Learn more about it [here](guide/hydration).\n * * [`HttpClient`](api/common/http/HttpClient) response caching while running on the server and\n * transferring this cache to the client to avoid extra HTTP requests. Learn more about data caching\n * [here](guide/ssr#caching-data-when-using-httpclient).\n *\n * These functions allow you to disable some of the default features or enable new ones:\n *\n * * {@link withNoHttpTransferCache} to disable HTTP transfer cache\n * * {@link withHttpTransferCacheOptions} to configure some HTTP transfer cache options\n * * {@link withI18nSupport} to enable hydration support for i18n blocks\n * * {@link withEventReplay} to enable support for replaying user events\n *\n * @usageNotes\n *\n * Basic example of how you can enable hydration in your application when\n * `bootstrapApplication` function is used:\n * ```\n * bootstrapApplication(AppComponent, {\n *   providers: [provideClientHydration()]\n * });\n * ```\n *\n * Alternatively if you are using NgModules, you would add `provideClientHydration`\n * to your root app module's provider list.\n * ```\n * @NgModule({\n *   declarations: [RootCmp],\n *   bootstrap: [RootCmp],\n *   providers: [provideClientHydration()],\n * })\n * export class AppModule {}\n * ```\n *\n * @see {@link withNoHttpTransferCache}\n * @see {@link withHttpTransferCacheOptions}\n * @see {@link withI18nSupport}\n * @see {@link withEventReplay}\n *\n * @param features Optional features to configure additional router behaviors.\n * @returns A set of providers to enable hydration.\n *\n * @publicApi\n */\nexport function provideClientHydration(\n  ...features: HydrationFeature<HydrationFeatureKind>[]\n): EnvironmentProviders {\n  const providers: Provider[] = [];\n  const featuresKind = new Set<HydrationFeatureKind>();\n  const hasHttpTransferCacheOptions = featuresKind.has(\n    HydrationFeatureKind.HttpTransferCacheOptions,\n  );\n\n  for (const {ɵproviders, ɵkind} of features) {\n    featuresKind.add(ɵkind);\n\n    if (ɵproviders.length) {\n      providers.push(ɵproviders);\n    }\n  }\n\n  if (\n    typeof ngDevMode !== 'undefined' &&\n    ngDevMode &&\n    featuresKind.has(HydrationFeatureKind.NoHttpTransferCache) &&\n    hasHttpTransferCacheOptions\n  ) {\n    // TODO: Make this a runtime error\n    throw new Error(\n      'Configuration error: found both withHttpTransferCacheOptions() and withNoHttpTransferCache() in the same call to provideClientHydration(), which is a contradiction.',\n    );\n  }\n\n  return makeEnvironmentProviders([\n    typeof ngDevMode !== 'undefined' && ngDevMode ? provideZoneJsCompatibilityDetector() : [],\n    withDomHydration(),\n    featuresKind.has(HydrationFeatureKind.NoHttpTransferCache) || hasHttpTransferCacheOptions\n      ? []\n      : ɵwithHttpTransferCache({}),\n    providers,\n  ]);\n}\n"]}
|
@@ -1,20 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
export { bootstrapApplication, BrowserModule, createApplication, platformBrowser, provideProtractorTestingSupport, } from './browser';
|
9
|
-
export { Meta } from './browser/meta';
|
10
|
-
export { Title } from './browser/title';
|
11
|
-
export { disableDebugTools, enableDebugTools } from './browser/tools/tools';
|
12
|
-
export { By } from './dom/debug/by';
|
13
|
-
export { REMOVE_STYLES_ON_COMPONENT_DESTROY } from './dom/dom_renderer';
|
14
|
-
export { EVENT_MANAGER_PLUGINS, EventManager, EventManagerPlugin } from './dom/events/event_manager';
|
15
|
-
export { HAMMER_GESTURE_CONFIG, HAMMER_LOADER, HammerGestureConfig, HammerModule, } from './dom/events/hammer_gestures';
|
16
|
-
export { DomSanitizer, } from './security/dom_sanitization_service';
|
17
|
-
export { HydrationFeatureKind, provideClientHydration, withEventReplay, withHttpTransferCacheOptions, withI18nSupport, withNoHttpTransferCache, } from './hydration';
|
18
|
-
export * from './private_export';
|
19
|
-
export { VERSION } from './version';
|
20
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdGZvcm0tYnJvd3Nlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3BsYXRmb3JtLWJyb3dzZXIvc3JjL3BsYXRmb3JtLWJyb3dzZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUVMLG9CQUFvQixFQUNwQixhQUFhLEVBQ2IsaUJBQWlCLEVBQ2pCLGVBQWUsRUFDZiwrQkFBK0IsR0FDaEMsTUFBTSxXQUFXLENBQUM7QUFDbkIsT0FBTyxFQUFDLElBQUksRUFBaUIsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdEMsT0FBTyxFQUFDLGlCQUFpQixFQUFFLGdCQUFnQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDMUUsT0FBTyxFQUFDLEVBQUUsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ2xDLE9BQU8sRUFBQyxrQ0FBa0MsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBQ3RFLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxZQUFZLEVBQUUsa0JBQWtCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNuRyxPQUFPLEVBQ0wscUJBQXFCLEVBQ3JCLGFBQWEsRUFDYixtQkFBbUIsRUFFbkIsWUFBWSxHQUNiLE1BQU0sOEJBQThCLENBQUM7QUFDdEMsT0FBTyxFQUNMLFlBQVksR0FPYixNQUFNLHFDQUFxQyxDQUFDO0FBQzdDLE9BQU8sRUFFTCxvQkFBb0IsRUFDcEIsc0JBQXNCLEVBQ3RCLGVBQWUsRUFDZiw0QkFBNEIsRUFDNUIsZUFBZSxFQUNmLHVCQUF1QixHQUN4QixNQUFNLGFBQWEsQ0FBQztBQUVyQixjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuZXhwb3J0IHtcbiAgQXBwbGljYXRpb25Db25maWcsXG4gIGJvb3RzdHJhcEFwcGxpY2F0aW9uLFxuICBCcm93c2VyTW9kdWxlLFxuICBjcmVhdGVBcHBsaWNhdGlvbixcbiAgcGxhdGZvcm1Ccm93c2VyLFxuICBwcm92aWRlUHJvdHJhY3RvclRlc3RpbmdTdXBwb3J0LFxufSBmcm9tICcuL2Jyb3dzZXInO1xuZXhwb3J0IHtNZXRhLCBNZXRhRGVmaW5pdGlvbn0gZnJvbSAnLi9icm93c2VyL21ldGEnO1xuZXhwb3J0IHtUaXRsZX0gZnJvbSAnLi9icm93c2VyL3RpdGxlJztcbmV4cG9ydCB7ZGlzYWJsZURlYnVnVG9vbHMsIGVuYWJsZURlYnVnVG9vbHN9IGZyb20gJy4vYnJvd3Nlci90b29scy90b29scyc7XG5leHBvcnQge0J5fSBmcm9tICcuL2RvbS9kZWJ1Zy9ieSc7XG5leHBvcnQge1JFTU9WRV9TVFlMRVNfT05fQ09NUE9ORU5UX0RFU1RST1l9IGZyb20gJy4vZG9tL2RvbV9yZW5kZXJlcic7XG5leHBvcnQge0VWRU5UX01BTkFHRVJfUExVR0lOUywgRXZlbnRNYW5hZ2VyLCBFdmVudE1hbmFnZXJQbHVnaW59IGZyb20gJy4vZG9tL2V2ZW50cy9ldmVudF9tYW5hZ2VyJztcbmV4cG9ydCB7XG4gIEhBTU1FUl9HRVNUVVJFX0NPTkZJRyxcbiAgSEFNTUVSX0xPQURFUixcbiAgSGFtbWVyR2VzdHVyZUNvbmZpZyxcbiAgSGFtbWVyTG9hZGVyLFxuICBIYW1tZXJNb2R1bGUsXG59IGZyb20gJy4vZG9tL2V2ZW50cy9oYW1tZXJfZ2VzdHVyZXMnO1xuZXhwb3J0IHtcbiAgRG9tU2FuaXRpemVyLFxuICBTYWZlSHRtbCxcbiAgU2FmZVJlc291cmNlVXJsLFxuICBTYWZlU2NyaXB0LFxuICBTYWZlU3R5bGUsXG4gIFNhZmVVcmwsXG4gIFNhZmVWYWx1ZSxcbn0gZnJvbSAnLi9zZWN1cml0eS9kb21fc2FuaXRpemF0aW9uX3NlcnZpY2UnO1xuZXhwb3J0IHtcbiAgSHlkcmF0aW9uRmVhdHVyZSxcbiAgSHlkcmF0aW9uRmVhdHVyZUtpbmQsXG4gIHByb3ZpZGVDbGllbnRIeWRyYXRpb24sXG4gIHdpdGhFdmVudFJlcGxheSxcbiAgd2l0aEh0dHBUcmFuc2ZlckNhY2hlT3B0aW9ucyxcbiAgd2l0aEkxOG5TdXBwb3J0LFxuICB3aXRoTm9IdHRwVHJhbnNmZXJDYWNoZSxcbn0gZnJvbSAnLi9oeWRyYXRpb24nO1xuXG5leHBvcnQgKiBmcm9tICcuL3ByaXZhdGVfZXhwb3J0JztcbmV4cG9ydCB7VkVSU0lPTn0gZnJvbSAnLi92ZXJzaW9uJztcbiJdfQ==
|
@@ -1,18 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
export { ɵgetDOM } from '@angular/common';
|
9
|
-
export { initDomAdapter as ɵinitDomAdapter, INTERNAL_BROWSER_PLATFORM_PROVIDERS as ɵINTERNAL_BROWSER_PLATFORM_PROVIDERS, } from './browser';
|
10
|
-
export { BrowserDomAdapter as ɵBrowserDomAdapter } from './browser/browser_adapter';
|
11
|
-
export { BrowserGetTestability as ɵBrowserGetTestability } from './browser/testability';
|
12
|
-
export { DomRendererFactory2 as ɵDomRendererFactory2 } from './dom/dom_renderer';
|
13
|
-
export { DomEventsPlugin as ɵDomEventsPlugin } from './dom/events/dom_events';
|
14
|
-
export { HammerGesturesPlugin as ɵHammerGesturesPlugin } from './dom/events/hammer_gestures';
|
15
|
-
export { KeyEventsPlugin as ɵKeyEventsPlugin } from './dom/events/key_events';
|
16
|
-
export { SharedStylesHost as ɵSharedStylesHost } from './dom/shared_styles_host';
|
17
|
-
export { DomSanitizerImpl as ɵDomSanitizerImpl } from './security/dom_sanitization_service';
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpdmF0ZV9leHBvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGF0Zm9ybS1icm93c2VyL3NyYy9wcml2YXRlX2V4cG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDeEMsT0FBTyxFQUNMLGNBQWMsSUFBSSxlQUFlLEVBQ2pDLG1DQUFtQyxJQUFJLG9DQUFvQyxHQUM1RSxNQUFNLFdBQVcsQ0FBQztBQUNuQixPQUFPLEVBQUMsaUJBQWlCLElBQUksa0JBQWtCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRixPQUFPLEVBQUMscUJBQXFCLElBQUksc0JBQXNCLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RixPQUFPLEVBQUMsbUJBQW1CLElBQUksb0JBQW9CLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQztBQUMvRSxPQUFPLEVBQUMsZUFBZSxJQUFJLGdCQUFnQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDNUUsT0FBTyxFQUFDLG9CQUFvQixJQUFJLHFCQUFxQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDM0YsT0FBTyxFQUFDLGVBQWUsSUFBSSxnQkFBZ0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQzVFLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxpQkFBaUIsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBRS9FLE9BQU8sRUFBQyxnQkFBZ0IsSUFBSSxpQkFBaUIsRUFBQyxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmV4cG9ydCB7ybVnZXRET019IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5leHBvcnQge1xuICBpbml0RG9tQWRhcHRlciBhcyDJtWluaXREb21BZGFwdGVyLFxuICBJTlRFUk5BTF9CUk9XU0VSX1BMQVRGT1JNX1BST1ZJREVSUyBhcyDJtUlOVEVSTkFMX0JST1dTRVJfUExBVEZPUk1fUFJPVklERVJTLFxufSBmcm9tICcuL2Jyb3dzZXInO1xuZXhwb3J0IHtCcm93c2VyRG9tQWRhcHRlciBhcyDJtUJyb3dzZXJEb21BZGFwdGVyfSBmcm9tICcuL2Jyb3dzZXIvYnJvd3Nlcl9hZGFwdGVyJztcbmV4cG9ydCB7QnJvd3NlckdldFRlc3RhYmlsaXR5IGFzIMm1QnJvd3NlckdldFRlc3RhYmlsaXR5fSBmcm9tICcuL2Jyb3dzZXIvdGVzdGFiaWxpdHknO1xuZXhwb3J0IHtEb21SZW5kZXJlckZhY3RvcnkyIGFzIMm1RG9tUmVuZGVyZXJGYWN0b3J5Mn0gZnJvbSAnLi9kb20vZG9tX3JlbmRlcmVyJztcbmV4cG9ydCB7RG9tRXZlbnRzUGx1Z2luIGFzIMm1RG9tRXZlbnRzUGx1Z2lufSBmcm9tICcuL2RvbS9ldmVudHMvZG9tX2V2ZW50cyc7XG5leHBvcnQge0hhbW1lckdlc3R1cmVzUGx1Z2luIGFzIMm1SGFtbWVyR2VzdHVyZXNQbHVnaW59IGZyb20gJy4vZG9tL2V2ZW50cy9oYW1tZXJfZ2VzdHVyZXMnO1xuZXhwb3J0IHtLZXlFdmVudHNQbHVnaW4gYXMgybVLZXlFdmVudHNQbHVnaW59IGZyb20gJy4vZG9tL2V2ZW50cy9rZXlfZXZlbnRzJztcbmV4cG9ydCB7U2hhcmVkU3R5bGVzSG9zdCBhcyDJtVNoYXJlZFN0eWxlc0hvc3R9IGZyb20gJy4vZG9tL3NoYXJlZF9zdHlsZXNfaG9zdCc7XG5leHBvcnQge1J1bnRpbWVFcnJvckNvZGUgYXMgybVSdW50aW1lRXJyb3JDb2RlfSBmcm9tICcuL2Vycm9ycyc7XG5leHBvcnQge0RvbVNhbml0aXplckltcGwgYXMgybVEb21TYW5pdGl6ZXJJbXBsfSBmcm9tICcuL3NlY3VyaXR5L2RvbV9zYW5pdGl6YXRpb25fc2VydmljZSc7XG4iXX0=
|
@@ -1,119 +0,0 @@
|
|
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
|
-
*/
|
8
|
-
import { DOCUMENT } from '@angular/common';
|
9
|
-
import { forwardRef, Inject, Injectable, SecurityContext, ɵ_sanitizeHtml as _sanitizeHtml, ɵ_sanitizeUrl as _sanitizeUrl, ɵallowSanitizationBypassAndThrow as allowSanitizationBypassOrThrow, ɵbypassSanitizationTrustHtml as bypassSanitizationTrustHtml, ɵbypassSanitizationTrustResourceUrl as bypassSanitizationTrustResourceUrl, ɵbypassSanitizationTrustScript as bypassSanitizationTrustScript, ɵbypassSanitizationTrustStyle as bypassSanitizationTrustStyle, ɵbypassSanitizationTrustUrl as bypassSanitizationTrustUrl, ɵRuntimeError as RuntimeError, ɵunwrapSafeValue as unwrapSafeValue, ɵXSS_SECURITY_URL as XSS_SECURITY_URL, } from '@angular/core';
|
10
|
-
import * as i0 from "@angular/core";
|
11
|
-
export { SecurityContext };
|
12
|
-
/**
|
13
|
-
* DomSanitizer helps preventing Cross Site Scripting Security bugs (XSS) by sanitizing
|
14
|
-
* values to be safe to use in the different DOM contexts.
|
15
|
-
*
|
16
|
-
* For example, when binding a URL in an `<a [href]="someValue">` hyperlink, `someValue` will be
|
17
|
-
* sanitized so that an attacker cannot inject e.g. a `javascript:` URL that would execute code on
|
18
|
-
* the website.
|
19
|
-
*
|
20
|
-
* In specific situations, it might be necessary to disable sanitization, for example if the
|
21
|
-
* application genuinely needs to produce a `javascript:` style link with a dynamic value in it.
|
22
|
-
* Users can bypass security by constructing a value with one of the `bypassSecurityTrust...`
|
23
|
-
* methods, and then binding to that value from the template.
|
24
|
-
*
|
25
|
-
* These situations should be very rare, and extraordinary care must be taken to avoid creating a
|
26
|
-
* Cross Site Scripting (XSS) security bug!
|
27
|
-
*
|
28
|
-
* When using `bypassSecurityTrust...`, make sure to call the method as early as possible and as
|
29
|
-
* close as possible to the source of the value, to make it easy to verify no security bug is
|
30
|
-
* created by its use.
|
31
|
-
*
|
32
|
-
* It is not required (and not recommended) to bypass security if the value is safe, e.g. a URL that
|
33
|
-
* does not start with a suspicious protocol, or an HTML snippet that does not contain dangerous
|
34
|
-
* code. The sanitizer leaves safe values intact.
|
35
|
-
*
|
36
|
-
* @security Calling any of the `bypassSecurityTrust...` APIs disables Angular's built-in
|
37
|
-
* sanitization for the value passed in. Carefully check and audit all values and code paths going
|
38
|
-
* into this call. Make sure any user data is appropriately escaped for this security context.
|
39
|
-
* For more detail, see the [Security Guide](https://g.co/ng/security).
|
40
|
-
*
|
41
|
-
* @publicApi
|
42
|
-
*/
|
43
|
-
export class DomSanitizer {
|
44
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizer, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
45
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizer, providedIn: 'root', useExisting: i0.forwardRef(() => DomSanitizerImpl) }); }
|
46
|
-
}
|
47
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizer, decorators: [{
|
48
|
-
type: Injectable,
|
49
|
-
args: [{ providedIn: 'root', useExisting: forwardRef(() => DomSanitizerImpl) }]
|
50
|
-
}] });
|
51
|
-
export class DomSanitizerImpl extends DomSanitizer {
|
52
|
-
constructor(_doc) {
|
53
|
-
super();
|
54
|
-
this._doc = _doc;
|
55
|
-
}
|
56
|
-
sanitize(ctx, value) {
|
57
|
-
if (value == null)
|
58
|
-
return null;
|
59
|
-
switch (ctx) {
|
60
|
-
case SecurityContext.NONE:
|
61
|
-
return value;
|
62
|
-
case SecurityContext.HTML:
|
63
|
-
if (allowSanitizationBypassOrThrow(value, "HTML" /* BypassType.Html */)) {
|
64
|
-
return unwrapSafeValue(value);
|
65
|
-
}
|
66
|
-
return _sanitizeHtml(this._doc, String(value)).toString();
|
67
|
-
case SecurityContext.STYLE:
|
68
|
-
if (allowSanitizationBypassOrThrow(value, "Style" /* BypassType.Style */)) {
|
69
|
-
return unwrapSafeValue(value);
|
70
|
-
}
|
71
|
-
return value;
|
72
|
-
case SecurityContext.SCRIPT:
|
73
|
-
if (allowSanitizationBypassOrThrow(value, "Script" /* BypassType.Script */)) {
|
74
|
-
return unwrapSafeValue(value);
|
75
|
-
}
|
76
|
-
throw new RuntimeError(5200 /* RuntimeErrorCode.SANITIZATION_UNSAFE_SCRIPT */, (typeof ngDevMode === 'undefined' || ngDevMode) &&
|
77
|
-
'unsafe value used in a script context');
|
78
|
-
case SecurityContext.URL:
|
79
|
-
if (allowSanitizationBypassOrThrow(value, "URL" /* BypassType.Url */)) {
|
80
|
-
return unwrapSafeValue(value);
|
81
|
-
}
|
82
|
-
return _sanitizeUrl(String(value));
|
83
|
-
case SecurityContext.RESOURCE_URL:
|
84
|
-
if (allowSanitizationBypassOrThrow(value, "ResourceURL" /* BypassType.ResourceUrl */)) {
|
85
|
-
return unwrapSafeValue(value);
|
86
|
-
}
|
87
|
-
throw new RuntimeError(5201 /* RuntimeErrorCode.SANITIZATION_UNSAFE_RESOURCE_URL */, (typeof ngDevMode === 'undefined' || ngDevMode) &&
|
88
|
-
`unsafe value used in a resource URL context (see ${XSS_SECURITY_URL})`);
|
89
|
-
default:
|
90
|
-
throw new RuntimeError(5202 /* RuntimeErrorCode.SANITIZATION_UNEXPECTED_CTX */, (typeof ngDevMode === 'undefined' || ngDevMode) &&
|
91
|
-
`Unexpected SecurityContext ${ctx} (see ${XSS_SECURITY_URL})`);
|
92
|
-
}
|
93
|
-
}
|
94
|
-
bypassSecurityTrustHtml(value) {
|
95
|
-
return bypassSanitizationTrustHtml(value);
|
96
|
-
}
|
97
|
-
bypassSecurityTrustStyle(value) {
|
98
|
-
return bypassSanitizationTrustStyle(value);
|
99
|
-
}
|
100
|
-
bypassSecurityTrustScript(value) {
|
101
|
-
return bypassSanitizationTrustScript(value);
|
102
|
-
}
|
103
|
-
bypassSecurityTrustUrl(value) {
|
104
|
-
return bypassSanitizationTrustUrl(value);
|
105
|
-
}
|
106
|
-
bypassSecurityTrustResourceUrl(value) {
|
107
|
-
return bypassSanitizationTrustResourceUrl(value);
|
108
|
-
}
|
109
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizerImpl, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
110
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizerImpl, providedIn: 'root' }); }
|
111
|
-
}
|
112
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DomSanitizerImpl, decorators: [{
|
113
|
-
type: Injectable,
|
114
|
-
args: [{ providedIn: 'root' }]
|
115
|
-
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
116
|
-
type: Inject,
|
117
|
-
args: [DOCUMENT]
|
118
|
-
}] }] });
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dom_sanitization_service.js","sourceRoot":"","sources":["../../../../../../../packages/platform-browser/src/security/dom_sanitization_service.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EACL,UAAU,EACV,MAAM,EACN,UAAU,EAEV,eAAe,EACf,cAAc,IAAI,aAAa,EAC/B,aAAa,IAAI,YAAY,EAC7B,gCAAgC,IAAI,8BAA8B,EAClE,4BAA4B,IAAI,2BAA2B,EAC3D,mCAAmC,IAAI,kCAAkC,EACzE,8BAA8B,IAAI,6BAA6B,EAC/D,6BAA6B,IAAI,4BAA4B,EAC7D,2BAA2B,IAAI,0BAA0B,EAEzD,aAAa,IAAI,YAAY,EAC7B,gBAAgB,IAAI,eAAe,EACnC,iBAAiB,IAAI,gBAAgB,GACtC,MAAM,eAAe,CAAC;;AAIvB,OAAO,EAAC,eAAe,EAAC,CAAC;AA4CzB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AAEH,MAAM,OAAgB,YAAY;yHAAZ,YAAY;6HAAZ,YAAY,cADT,MAAM,mCAAgC,gBAAgB;;sGACzD,YAAY;kBADjC,UAAU;mBAAC,EAAC,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,EAAC;;AA2DjF,MAAM,OAAO,gBAAiB,SAAQ,YAAY;IAChD,YAAsC,IAAS;QAC7C,KAAK,EAAE,CAAC;QAD4B,SAAI,GAAJ,IAAI,CAAK;IAE/C,CAAC;IAEQ,QAAQ,CAAC,GAAoB,EAAE,KAAgC;QACtE,IAAI,KAAK,IAAI,IAAI;YAAE,OAAO,IAAI,CAAC;QAC/B,QAAQ,GAAG,EAAE,CAAC;YACZ,KAAK,eAAe,CAAC,IAAI;gBACvB,OAAO,KAAe,CAAC;YACzB,KAAK,eAAe,CAAC,IAAI;gBACvB,IAAI,8BAA8B,CAAC,KAAK,+BAAkB,EAAE,CAAC;oBAC3D,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,OAAO,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;YAC5D,KAAK,eAAe,CAAC,KAAK;gBACxB,IAAI,8BAA8B,CAAC,KAAK,iCAAmB,EAAE,CAAC;oBAC5D,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,OAAO,KAAe,CAAC;YACzB,KAAK,eAAe,CAAC,MAAM;gBACzB,IAAI,8BAA8B,CAAC,KAAK,mCAAoB,EAAE,CAAC;oBAC7D,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,MAAM,IAAI,YAAY,yDAEpB,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC;oBAC7C,uCAAuC,CAC1C,CAAC;YACJ,KAAK,eAAe,CAAC,GAAG;gBACtB,IAAI,8BAA8B,CAAC,KAAK,6BAAiB,EAAE,CAAC;oBAC1D,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,OAAO,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACrC,KAAK,eAAe,CAAC,YAAY;gBAC/B,IAAI,8BAA8B,CAAC,KAAK,6CAAyB,EAAE,CAAC;oBAClE,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC;gBAChC,CAAC;gBACD,MAAM,IAAI,YAAY,+DAEpB,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC;oBAC7C,oDAAoD,gBAAgB,GAAG,CAC1E,CAAC;YACJ;gBACE,MAAM,IAAI,YAAY,0DAEpB,CAAC,OAAO,SAAS,KAAK,WAAW,IAAI,SAAS,CAAC;oBAC7C,8BAA8B,GAAG,SAAS,gBAAgB,GAAG,CAChE,CAAC;QACN,CAAC;IACH,CAAC;IAEQ,uBAAuB,CAAC,KAAa;QAC5C,OAAO,2BAA2B,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IACQ,wBAAwB,CAAC,KAAa;QAC7C,OAAO,4BAA4B,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IACQ,yBAAyB,CAAC,KAAa;QAC9C,OAAO,6BAA6B,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IACQ,sBAAsB,CAAC,KAAa;QAC3C,OAAO,0BAA0B,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;IACQ,8BAA8B,CAAC,KAAa;QACnD,OAAO,kCAAkC,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;yHAlEU,gBAAgB,kBACP,QAAQ;6HADjB,gBAAgB,cADJ,MAAM;;sGAClB,gBAAgB;kBAD5B,UAAU;mBAAC,EAAC,UAAU,EAAE,MAAM,EAAC;;0BAEjB,MAAM;2BAAC,QAAQ","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 {DOCUMENT} from '@angular/common';\nimport {\n  forwardRef,\n  Inject,\n  Injectable,\n  Sanitizer,\n  SecurityContext,\n  ɵ_sanitizeHtml as _sanitizeHtml,\n  ɵ_sanitizeUrl as _sanitizeUrl,\n  ɵallowSanitizationBypassAndThrow as allowSanitizationBypassOrThrow,\n  ɵbypassSanitizationTrustHtml as bypassSanitizationTrustHtml,\n  ɵbypassSanitizationTrustResourceUrl as bypassSanitizationTrustResourceUrl,\n  ɵbypassSanitizationTrustScript as bypassSanitizationTrustScript,\n  ɵbypassSanitizationTrustStyle as bypassSanitizationTrustStyle,\n  ɵbypassSanitizationTrustUrl as bypassSanitizationTrustUrl,\n  ɵBypassType as BypassType,\n  ɵRuntimeError as RuntimeError,\n  ɵunwrapSafeValue as unwrapSafeValue,\n  ɵXSS_SECURITY_URL as XSS_SECURITY_URL,\n} from '@angular/core';\n\nimport {RuntimeErrorCode} from '../errors';\n\nexport {SecurityContext};\n\n/**\n * Marker interface for a value that's safe to use in a particular context.\n *\n * @publicApi\n */\nexport interface SafeValue {}\n\n/**\n * Marker interface for a value that's safe to use as HTML.\n *\n * @publicApi\n */\nexport interface SafeHtml extends SafeValue {}\n\n/**\n * Marker interface for a value that's safe to use as style (CSS).\n *\n * @publicApi\n */\nexport interface SafeStyle extends SafeValue {}\n\n/**\n * Marker interface for a value that's safe to use as JavaScript.\n *\n * @publicApi\n */\nexport interface SafeScript extends SafeValue {}\n\n/**\n * Marker interface for a value that's safe to use as a URL linking to a document.\n *\n * @publicApi\n */\nexport interface SafeUrl extends SafeValue {}\n\n/**\n * Marker interface for a value that's safe to use as a URL to load executable code from.\n *\n * @publicApi\n */\nexport interface SafeResourceUrl extends SafeValue {}\n\n/**\n * DomSanitizer helps preventing Cross Site Scripting Security bugs (XSS) by sanitizing\n * values to be safe to use in the different DOM contexts.\n *\n * For example, when binding a URL in an `<a [href]=\"someValue\">` hyperlink, `someValue` will be\n * sanitized so that an attacker cannot inject e.g. a `javascript:` URL that would execute code on\n * the website.\n *\n * In specific situations, it might be necessary to disable sanitization, for example if the\n * application genuinely needs to produce a `javascript:` style link with a dynamic value in it.\n * Users can bypass security by constructing a value with one of the `bypassSecurityTrust...`\n * methods, and then binding to that value from the template.\n *\n * These situations should be very rare, and extraordinary care must be taken to avoid creating a\n * Cross Site Scripting (XSS) security bug!\n *\n * When using `bypassSecurityTrust...`, make sure to call the method as early as possible and as\n * close as possible to the source of the value, to make it easy to verify no security bug is\n * created by its use.\n *\n * It is not required (and not recommended) to bypass security if the value is safe, e.g. a URL that\n * does not start with a suspicious protocol, or an HTML snippet that does not contain dangerous\n * code. The sanitizer leaves safe values intact.\n *\n * @security Calling any of the `bypassSecurityTrust...` APIs disables Angular's built-in\n * sanitization for the value passed in. Carefully check and audit all values and code paths going\n * into this call. Make sure any user data is appropriately escaped for this security context.\n * For more detail, see the [Security Guide](https://g.co/ng/security).\n *\n * @publicApi\n */\n@Injectable({providedIn: 'root', useExisting: forwardRef(() => DomSanitizerImpl)})\nexport abstract class DomSanitizer implements Sanitizer {\n  /**\n   * Gets a safe value from either a known safe value or a value with unknown safety.\n   *\n   * If the given value is already a `SafeValue`, this method returns the unwrapped value.\n   * If the security context is HTML and the given value is a plain string, this method\n   * sanitizes the string, removing any potentially unsafe content.\n   * For any other security context, this method throws an error if provided\n   * with a plain string.\n   */\n  abstract sanitize(context: SecurityContext, value: SafeValue | string | null): string | null;\n\n  /**\n   * Bypass security and trust the given value to be safe HTML. Only use this when the bound HTML\n   * is unsafe (e.g. contains `<script>` tags) and the code should be executed. The sanitizer will\n   * leave safe HTML intact, so in most situations this method should not be used.\n   *\n   * **WARNING:** calling this method with untrusted user data exposes your application to XSS\n   * security risks!\n   */\n  abstract bypassSecurityTrustHtml(value: string): SafeHtml;\n\n  /**\n   * Bypass security and trust the given value to be safe style value (CSS).\n   *\n   * **WARNING:** calling this method with untrusted user data exposes your application to XSS\n   * security risks!\n   */\n  abstract bypassSecurityTrustStyle(value: string): SafeStyle;\n\n  /**\n   * Bypass security and trust the given value to be safe JavaScript.\n   *\n   * **WARNING:** calling this method with untrusted user data exposes your application to XSS\n   * security risks!\n   */\n  abstract bypassSecurityTrustScript(value: string): SafeScript;\n\n  /**\n   * Bypass security and trust the given value to be a safe style URL, i.e. a value that can be used\n   * in hyperlinks or `<img src>`.\n   *\n   * **WARNING:** calling this method with untrusted user data exposes your application to XSS\n   * security risks!\n   */\n  abstract bypassSecurityTrustUrl(value: string): SafeUrl;\n\n  /**\n   * Bypass security and trust the given value to be a safe resource URL, i.e. a location that may\n   * be used to load executable code from, like `<script src>`, or `<iframe src>`.\n   *\n   * **WARNING:** calling this method with untrusted user data exposes your application to XSS\n   * security risks!\n   */\n  abstract bypassSecurityTrustResourceUrl(value: string): SafeResourceUrl;\n}\n\n@Injectable({providedIn: 'root'})\nexport class DomSanitizerImpl extends DomSanitizer {\n  constructor(@Inject(DOCUMENT) private _doc: any) {\n    super();\n  }\n\n  override sanitize(ctx: SecurityContext, value: SafeValue | string | null): string | null {\n    if (value == null) return null;\n    switch (ctx) {\n      case SecurityContext.NONE:\n        return value as string;\n      case SecurityContext.HTML:\n        if (allowSanitizationBypassOrThrow(value, BypassType.Html)) {\n          return unwrapSafeValue(value);\n        }\n        return _sanitizeHtml(this._doc, String(value)).toString();\n      case SecurityContext.STYLE:\n        if (allowSanitizationBypassOrThrow(value, BypassType.Style)) {\n          return unwrapSafeValue(value);\n        }\n        return value as string;\n      case SecurityContext.SCRIPT:\n        if (allowSanitizationBypassOrThrow(value, BypassType.Script)) {\n          return unwrapSafeValue(value);\n        }\n        throw new RuntimeError(\n          RuntimeErrorCode.SANITIZATION_UNSAFE_SCRIPT,\n          (typeof ngDevMode === 'undefined' || ngDevMode) &&\n            'unsafe value used in a script context',\n        );\n      case SecurityContext.URL:\n        if (allowSanitizationBypassOrThrow(value, BypassType.Url)) {\n          return unwrapSafeValue(value);\n        }\n        return _sanitizeUrl(String(value));\n      case SecurityContext.RESOURCE_URL:\n        if (allowSanitizationBypassOrThrow(value, BypassType.ResourceUrl)) {\n          return unwrapSafeValue(value);\n        }\n        throw new RuntimeError(\n          RuntimeErrorCode.SANITIZATION_UNSAFE_RESOURCE_URL,\n          (typeof ngDevMode === 'undefined' || ngDevMode) &&\n            `unsafe value used in a resource URL context (see ${XSS_SECURITY_URL})`,\n        );\n      default:\n        throw new RuntimeError(\n          RuntimeErrorCode.SANITIZATION_UNEXPECTED_CTX,\n          (typeof ngDevMode === 'undefined' || ngDevMode) &&\n            `Unexpected SecurityContext ${ctx} (see ${XSS_SECURITY_URL})`,\n        );\n    }\n  }\n\n  override bypassSecurityTrustHtml(value: string): SafeHtml {\n    return bypassSanitizationTrustHtml(value);\n  }\n  override bypassSecurityTrustStyle(value: string): SafeStyle {\n    return bypassSanitizationTrustStyle(value);\n  }\n  override bypassSecurityTrustScript(value: string): SafeScript {\n    return bypassSanitizationTrustScript(value);\n  }\n  override bypassSecurityTrustUrl(value: string): SafeUrl {\n    return bypassSanitizationTrustUrl(value);\n  }\n  override bypassSecurityTrustResourceUrl(value: string): SafeResourceUrl {\n    return bypassSanitizationTrustResourceUrl(value);\n  }\n}\n"]}
|