source: trip-planner-front/node_modules/@angular/common/esm2015/src/location/platform_location.js

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

initial commit

  • Property mode set to 100644
File size: 17.2 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, Injectable, InjectionToken, ɵɵinject } from '@angular/core';
9import { getDOM } from '../dom_adapter';
10import { DOCUMENT } from '../dom_tokens';
11import * as i0 from "@angular/core";
12/**
13 * This class should not be used directly by an application developer. Instead, use
14 * {@link Location}.
15 *
16 * `PlatformLocation` encapsulates all calls to DOM APIs, which allows the Router to be
17 * platform-agnostic.
18 * This means that we can have different implementation of `PlatformLocation` for the different
19 * platforms that Angular supports. For example, `@angular/platform-browser` provides an
20 * implementation specific to the browser environment, while `@angular/platform-server` provides
21 * one suitable for use with server-side rendering.
22 *
23 * The `PlatformLocation` class is used directly by all implementations of {@link LocationStrategy}
24 * when they need to interact with the DOM APIs like pushState, popState, etc.
25 *
26 * {@link LocationStrategy} in turn is used by the {@link Location} service which is used directly
27 * by the {@link Router} in order to navigate between routes. Since all interactions between {@link
28 * Router} /
29 * {@link Location} / {@link LocationStrategy} and DOM APIs flow through the `PlatformLocation`
30 * class, they are all platform-agnostic.
31 *
32 * @publicApi
33 */
34export class PlatformLocation {
35 historyGo(relativePosition) {
36 throw new Error('Not implemented');
37 }
38}
39PlatformLocation.ɵprov = i0.ɵɵdefineInjectable({ factory: useBrowserPlatformLocation, token: PlatformLocation, providedIn: "platform" });
40PlatformLocation.decorators = [
41 { type: Injectable, args: [{
42 providedIn: 'platform',
43 // See #23917
44 useFactory: useBrowserPlatformLocation
45 },] }
46];
47export function useBrowserPlatformLocation() {
48 return ɵɵinject(BrowserPlatformLocation);
49}
50/**
51 * @description
52 * Indicates when a location is initialized.
53 *
54 * @publicApi
55 */
56export const LOCATION_INITIALIZED = new InjectionToken('Location Initialized');
57/**
58 * `PlatformLocation` encapsulates all of the direct calls to platform APIs.
59 * This class should not be used directly by an application developer. Instead, use
60 * {@link Location}.
61 */
62export class BrowserPlatformLocation extends PlatformLocation {
63 constructor(_doc) {
64 super();
65 this._doc = _doc;
66 this._init();
67 }
68 // This is moved to its own method so that `MockPlatformLocationStrategy` can overwrite it
69 /** @internal */
70 _init() {
71 this.location = window.location;
72 this._history = window.history;
73 }
74 getBaseHrefFromDOM() {
75 return getDOM().getBaseHref(this._doc);
76 }
77 onPopState(fn) {
78 const window = getDOM().getGlobalEventTarget(this._doc, 'window');
79 window.addEventListener('popstate', fn, false);
80 return () => window.removeEventListener('popstate', fn);
81 }
82 onHashChange(fn) {
83 const window = getDOM().getGlobalEventTarget(this._doc, 'window');
84 window.addEventListener('hashchange', fn, false);
85 return () => window.removeEventListener('hashchange', fn);
86 }
87 get href() {
88 return this.location.href;
89 }
90 get protocol() {
91 return this.location.protocol;
92 }
93 get hostname() {
94 return this.location.hostname;
95 }
96 get port() {
97 return this.location.port;
98 }
99 get pathname() {
100 return this.location.pathname;
101 }
102 get search() {
103 return this.location.search;
104 }
105 get hash() {
106 return this.location.hash;
107 }
108 set pathname(newPath) {
109 this.location.pathname = newPath;
110 }
111 pushState(state, title, url) {
112 if (supportsState()) {
113 this._history.pushState(state, title, url);
114 }
115 else {
116 this.location.hash = url;
117 }
118 }
119 replaceState(state, title, url) {
120 if (supportsState()) {
121 this._history.replaceState(state, title, url);
122 }
123 else {
124 this.location.hash = url;
125 }
126 }
127 forward() {
128 this._history.forward();
129 }
130 back() {
131 this._history.back();
132 }
133 historyGo(relativePosition = 0) {
134 this._history.go(relativePosition);
135 }
136 getState() {
137 return this._history.state;
138 }
139}
140BrowserPlatformLocation.ɵprov = i0.ɵɵdefineInjectable({ factory: createBrowserPlatformLocation, token: BrowserPlatformLocation, providedIn: "platform" });
141BrowserPlatformLocation.decorators = [
142 { type: Injectable, args: [{
143 providedIn: 'platform',
144 // See #23917
145 useFactory: createBrowserPlatformLocation,
146 },] }
147];
148BrowserPlatformLocation.ctorParameters = () => [
149 { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
150];
151export function supportsState() {
152 return !!window.history.pushState;
153}
154export function createBrowserPlatformLocation() {
155 return new BrowserPlatformLocation(ɵɵinject(DOCUMENT));
156}
157//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"platform_location.js","sourceRoot":"","sources":["../../../../../../../packages/common/src/location/platform_location.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 {Inject, Injectable, InjectionToken, ɵɵinject} from '@angular/core';\nimport {getDOM} from '../dom_adapter';\nimport {DOCUMENT} from '../dom_tokens';\n\n/**\n * This class should not be used directly by an application developer. Instead, use\n * {@link Location}.\n *\n * `PlatformLocation` encapsulates all calls to DOM APIs, which allows the Router to be\n * platform-agnostic.\n * This means that we can have different implementation of `PlatformLocation` for the different\n * platforms that Angular supports. For example, `@angular/platform-browser` provides an\n * implementation specific to the browser environment, while `@angular/platform-server` provides\n * one suitable for use with server-side rendering.\n *\n * The `PlatformLocation` class is used directly by all implementations of {@link LocationStrategy}\n * when they need to interact with the DOM APIs like pushState, popState, etc.\n *\n * {@link LocationStrategy} in turn is used by the {@link Location} service which is used directly\n * by the {@link Router} in order to navigate between routes. Since all interactions between {@link\n * Router} /\n * {@link Location} / {@link LocationStrategy} and DOM APIs flow through the `PlatformLocation`\n * class, they are all platform-agnostic.\n *\n * @publicApi\n */\n@Injectable({\n  providedIn: 'platform',\n  // See #23917\n  useFactory: useBrowserPlatformLocation\n})\nexport abstract class PlatformLocation {\n  abstract getBaseHrefFromDOM(): string;\n  abstract getState(): unknown;\n  /**\n   * Returns a function that, when executed, removes the `popstate` event handler.\n   */\n  abstract onPopState(fn: LocationChangeListener): VoidFunction;\n  /**\n   * Returns a function that, when executed, removes the `hashchange` event handler.\n   */\n  abstract onHashChange(fn: LocationChangeListener): VoidFunction;\n\n  abstract get href(): string;\n  abstract get protocol(): string;\n  abstract get hostname(): string;\n  abstract get port(): string;\n  abstract get pathname(): string;\n  abstract get search(): string;\n  abstract get hash(): string;\n\n  abstract replaceState(state: any, title: string, url: string): void;\n\n  abstract pushState(state: any, title: string, url: string): void;\n\n  abstract forward(): void;\n\n  abstract back(): void;\n\n  historyGo?(relativePosition: number): void {\n    throw new Error('Not implemented');\n  }\n}\n\nexport function useBrowserPlatformLocation() {\n  return ɵɵinject(BrowserPlatformLocation);\n}\n\n/**\n * @description\n * Indicates when a location is initialized.\n *\n * @publicApi\n */\nexport const LOCATION_INITIALIZED = new InjectionToken<Promise<any>>('Location Initialized');\n\n/**\n * @description\n * A serializable version of the event from `onPopState` or `onHashChange`\n *\n * @publicApi\n */\nexport interface LocationChangeEvent {\n  type: string;\n  state: any;\n}\n\n/**\n * @publicApi\n */\nexport interface LocationChangeListener {\n  (event: LocationChangeEvent): any;\n}\n\n\n\n/**\n * `PlatformLocation` encapsulates all of the direct calls to platform APIs.\n * This class should not be used directly by an application developer. Instead, use\n * {@link Location}.\n */\n@Injectable({\n  providedIn: 'platform',\n  // See #23917\n  useFactory: createBrowserPlatformLocation,\n})\nexport class BrowserPlatformLocation extends PlatformLocation {\n  public readonly location!: Location;\n  private _history!: History;\n\n  constructor(@Inject(DOCUMENT) private _doc: any) {\n    super();\n    this._init();\n  }\n\n  // This is moved to its own method so that `MockPlatformLocationStrategy` can overwrite it\n  /** @internal */\n  _init() {\n    (this as {location: Location}).location = window.location;\n    this._history = window.history;\n  }\n\n  override getBaseHrefFromDOM(): string {\n    return getDOM().getBaseHref(this._doc)!;\n  }\n\n  override onPopState(fn: LocationChangeListener): VoidFunction {\n    const window = getDOM().getGlobalEventTarget(this._doc, 'window');\n    window.addEventListener('popstate', fn, false);\n    return () => window.removeEventListener('popstate', fn);\n  }\n\n  override onHashChange(fn: LocationChangeListener): VoidFunction {\n    const window = getDOM().getGlobalEventTarget(this._doc, 'window');\n    window.addEventListener('hashchange', fn, false);\n    return () => window.removeEventListener('hashchange', fn);\n  }\n\n  override get href(): string {\n    return this.location.href;\n  }\n  override get protocol(): string {\n    return this.location.protocol;\n  }\n  override get hostname(): string {\n    return this.location.hostname;\n  }\n  override get port(): string {\n    return this.location.port;\n  }\n  override get pathname(): string {\n    return this.location.pathname;\n  }\n  override get search(): string {\n    return this.location.search;\n  }\n  override get hash(): string {\n    return this.location.hash;\n  }\n  override set pathname(newPath: string) {\n    this.location.pathname = newPath;\n  }\n\n  override pushState(state: any, title: string, url: string): void {\n    if (supportsState()) {\n      this._history.pushState(state, title, url);\n    } else {\n      this.location.hash = url;\n    }\n  }\n\n  override replaceState(state: any, title: string, url: string): void {\n    if (supportsState()) {\n      this._history.replaceState(state, title, url);\n    } else {\n      this.location.hash = url;\n    }\n  }\n\n  override forward(): void {\n    this._history.forward();\n  }\n\n  override back(): void {\n    this._history.back();\n  }\n\n  override historyGo(relativePosition: number = 0): void {\n    this._history.go(relativePosition);\n  }\n\n  override getState(): unknown {\n    return this._history.state;\n  }\n}\n\nexport function supportsState(): boolean {\n  return !!window.history.pushState;\n}\nexport function createBrowserPlatformLocation() {\n  return new BrowserPlatformLocation(ɵɵinject(DOCUMENT));\n}\n"]}
Note: See TracBrowser for help on using the repository browser.