UNPKG

@angular/common

Version:

Angular - commonly needed directives and services

152 lines • 13.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { APP_BASE_HREF, CommonModule, HashLocationStrategy, Location, LocationStrategy, PathLocationStrategy, PlatformLocation } from '@angular/common'; import { Inject, InjectionToken, NgModule, Optional } from '@angular/core'; import { UpgradeModule } from '@angular/upgrade/static'; import { $locationShim, $locationShimProvider } from './location_shim'; import { AngularJSUrlCodec, UrlCodec } from './params'; /** * Configuration options for LocationUpgrade. * * \@publicApi * @record */ export function LocationUpgradeConfig() { } if (false) { /** * Configures whether the location upgrade module should use the `HashLocationStrategy` * or the `PathLocationStrategy` * @type {?|undefined} */ LocationUpgradeConfig.prototype.useHash; /** * Configures the hash prefix used in the URL when using the `HashLocationStrategy` * @type {?|undefined} */ LocationUpgradeConfig.prototype.hashPrefix; /** * Configures the URL codec for encoding and decoding URLs. Default is the `AngularJSCodec` * @type {?|undefined} */ LocationUpgradeConfig.prototype.urlCodec; /** * Configures the base href when used in server-side rendered applications * @type {?|undefined} */ LocationUpgradeConfig.prototype.serverBaseHref; /** * Configures the base href when used in client-side rendered applications * @type {?|undefined} */ LocationUpgradeConfig.prototype.appBaseHref; } /** * A provider token used to configure the location upgrade module. * * \@publicApi * @type {?} */ export const LOCATION_UPGRADE_CONFIGURATION = new InjectionToken('LOCATION_UPGRADE_CONFIGURATION'); /** @type {?} */ const APP_BASE_HREF_RESOLVED = new InjectionToken('APP_BASE_HREF_RESOLVED'); /** * `NgModule` used for providing and configuring Angular's Unified Location Service for upgrading. * * @see [Using the Unified Angular Location Service](guide/upgrade#using-the-unified-angular-location-service) * * \@publicApi */ export class LocationUpgradeModule { /** * @param {?=} config * @return {?} */ static config(config) { return { ngModule: LocationUpgradeModule, providers: [ Location, { provide: $locationShim, useFactory: provide$location, deps: [UpgradeModule, Location, PlatformLocation, UrlCodec, LocationStrategy] }, { provide: LOCATION_UPGRADE_CONFIGURATION, useValue: config ? config : {} }, { provide: UrlCodec, useFactory: provideUrlCodec, deps: [LOCATION_UPGRADE_CONFIGURATION] }, { provide: APP_BASE_HREF_RESOLVED, useFactory: provideAppBaseHref, deps: [LOCATION_UPGRADE_CONFIGURATION, [new Inject(APP_BASE_HREF), new Optional()]] }, { provide: LocationStrategy, useFactory: provideLocationStrategy, deps: [ PlatformLocation, APP_BASE_HREF_RESOLVED, LOCATION_UPGRADE_CONFIGURATION, ] }, ], }; } } LocationUpgradeModule.decorators = [ { type: NgModule, args: [{ imports: [CommonModule] },] } ]; /** * @param {?} config * @param {?=} appBaseHref * @return {?} */ export function provideAppBaseHref(config, appBaseHref) { if (config && config.appBaseHref != null) { return config.appBaseHref; } else if (appBaseHref != null) { return appBaseHref; } return ''; } /** * @param {?} config * @return {?} */ export function provideUrlCodec(config) { /** @type {?} */ const codec = config && config.urlCodec || AngularJSUrlCodec; return new ((/** @type {?} */ (codec)))(); } /** * @param {?} platformLocation * @param {?} baseHref * @param {?=} options * @return {?} */ export function provideLocationStrategy(platformLocation, baseHref, options = {}) { return options.useHash ? new HashLocationStrategy(platformLocation, baseHref) : new PathLocationStrategy(platformLocation, baseHref); } /** * @param {?} ngUpgrade * @param {?} location * @param {?} platformLocation * @param {?} urlCodec * @param {?} locationStrategy * @return {?} */ export function provide$location(ngUpgrade, location, platformLocation, urlCodec, locationStrategy) { /** @type {?} */ const $locationProvider = new $locationShimProvider(ngUpgrade, location, platformLocation, urlCodec, locationStrategy); return $locationProvider.$get(); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"location_upgrade_module.js","sourceRoot":"","sources":["../../../../../../../packages/common/upgrade/src/location_upgrade_module.ts"],"names":[],"mappings":";;;;;;;;;;;AAQA,OAAO,EAAC,aAAa,EAAE,YAAY,EAAE,oBAAoB,EAAE,QAAQ,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AACtJ,OAAO,EAAC,MAAM,EAAE,cAAc,EAAuB,QAAQ,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AAC9F,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AAEtD,OAAO,EAAC,aAAa,EAAE,qBAAqB,EAAC,MAAM,iBAAiB,CAAC;AACrE,OAAO,EAAC,iBAAiB,EAAE,QAAQ,EAAC,MAAM,UAAU,CAAC;;;;;;;AAQrD,2CAsBC;;;;;;;IAjBC,wCAAkB;;;;;IAIlB,2CAAoB;;;;;IAIpB,yCAA2B;;;;;IAI3B,+CAAwB;;;;;IAIxB,4CAAqB;;;;;;;;AAQvB,MAAM,OAAO,8BAA8B,GACvC,IAAI,cAAc,CAAwB,gCAAgC,CAAC;;MAEzE,sBAAsB,GAAG,IAAI,cAAc,CAAS,wBAAwB,CAAC;;;;;;;;AAUnF,MAAM,OAAO,qBAAqB;;;;;IAChC,MAAM,CAAC,MAAM,CAAC,MAA8B;QAC1C,OAAO;YACL,QAAQ,EAAE,qBAAqB;YAC/B,SAAS,EAAE;gBACT,QAAQ;gBACR;oBACE,OAAO,EAAE,aAAa;oBACtB,UAAU,EAAE,gBAAgB;oBAC5B,IAAI,EAAE,CAAC,aAAa,EAAE,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,gBAAgB,CAAC;iBAC9E;gBACD,EAAC,OAAO,EAAE,8BAA8B,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAC;gBACzE,EAAC,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,8BAA8B,CAAC,EAAC;gBACxF;oBACE,OAAO,EAAE,sBAAsB;oBAC/B,UAAU,EAAE,kBAAkB;oBAC9B,IAAI,EAAE,CAAC,8BAA8B,EAAE,CAAC,IAAI,MAAM,CAAC,aAAa,CAAC,EAAE,IAAI,QAAQ,EAAE,CAAC,CAAC;iBACpF;gBACD;oBACE,OAAO,EAAE,gBAAgB;oBACzB,UAAU,EAAE,uBAAuB;oBACnC,IAAI,EAAE;wBACJ,gBAAgB;wBAChB,sBAAsB;wBACtB,8BAA8B;qBAC/B;iBACF;aACF;SACF,CAAC;IACJ,CAAC;;;YA9BF,QAAQ,SAAC,EAAC,OAAO,EAAE,CAAC,YAAY,CAAC,EAAC;;;;;;;AAiCnC,MAAM,UAAU,kBAAkB,CAAC,MAA6B,EAAE,WAAoB;IACpF,IAAI,MAAM,IAAI,MAAM,CAAC,WAAW,IAAI,IAAI,EAAE;QACxC,OAAO,MAAM,CAAC,WAAW,CAAC;KAC3B;SAAM,IAAI,WAAW,IAAI,IAAI,EAAE;QAC9B,OAAO,WAAW,CAAC;KACpB;IACD,OAAO,EAAE,CAAC;AACZ,CAAC;;;;;AAED,MAAM,UAAU,eAAe,CAAC,MAA6B;;UACrD,KAAK,GAAG,MAAM,IAAI,MAAM,CAAC,QAAQ,IAAI,iBAAiB;IAC5D,OAAO,IAAI,CAAC,mBAAA,KAAK,EAAO,CAAC,EAAE,CAAC;AAC9B,CAAC;;;;;;;AAED,MAAM,UAAU,uBAAuB,CACnC,gBAAkC,EAAE,QAAgB,EAAE,UAAiC,EAAE;IAC3F,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,oBAAoB,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC,CAAC;QACtD,IAAI,oBAAoB,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC;AAChF,CAAC;;;;;;;;;AAED,MAAM,UAAU,gBAAgB,CAC5B,SAAwB,EAAE,QAAkB,EAAE,gBAAkC,EAChF,QAAkB,EAAE,gBAAkC;;UAClD,iBAAiB,GACnB,IAAI,qBAAqB,CAAC,SAAS,EAAE,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,EAAE,gBAAgB,CAAC;IAEhG,OAAO,iBAAiB,CAAC,IAAI,EAAE,CAAC;AAClC,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {APP_BASE_HREF, CommonModule, HashLocationStrategy, Location, LocationStrategy, PathLocationStrategy, PlatformLocation} from '@angular/common';\nimport {Inject, InjectionToken, ModuleWithProviders, NgModule, Optional} from '@angular/core';\nimport {UpgradeModule} from '@angular/upgrade/static';\n\nimport {$locationShim, $locationShimProvider} from './location_shim';\nimport {AngularJSUrlCodec, UrlCodec} from './params';\n\n\n/**\n * Configuration options for LocationUpgrade.\n *\n * @publicApi\n */\nexport interface LocationUpgradeConfig {\n  /**\n   * Configures whether the location upgrade module should use the `HashLocationStrategy`\n   * or the `PathLocationStrategy`\n   */\n  useHash?: boolean;\n  /**\n   * Configures the hash prefix used in the URL when using the `HashLocationStrategy`\n   */\n  hashPrefix?: string;\n  /**\n   * Configures the URL codec for encoding and decoding URLs. Default is the `AngularJSCodec`\n   */\n  urlCodec?: typeof UrlCodec;\n  /**\n   * Configures the base href when used in server-side rendered applications\n   */\n  serverBaseHref?: string;\n  /**\n   * Configures the base href when used in client-side rendered applications\n   */\n  appBaseHref?: string;\n}\n\n/**\n * A provider token used to configure the location upgrade module.\n *\n * @publicApi\n */\nexport const LOCATION_UPGRADE_CONFIGURATION =\n    new InjectionToken<LocationUpgradeConfig>('LOCATION_UPGRADE_CONFIGURATION');\n\nconst APP_BASE_HREF_RESOLVED = new InjectionToken<string>('APP_BASE_HREF_RESOLVED');\n\n/**\n * `NgModule` used for providing and configuring Angular's Unified Location Service for upgrading.\n * \n * @see [Using the Unified Angular Location Service](guide/upgrade#using-the-unified-angular-location-service)\n *\n * @publicApi\n */\n@NgModule({imports: [CommonModule]})\nexport class LocationUpgradeModule {\n  static config(config?: LocationUpgradeConfig): ModuleWithProviders<LocationUpgradeModule> {\n    return {\n      ngModule: LocationUpgradeModule,\n      providers: [\n        Location,\n        {\n          provide: $locationShim,\n          useFactory: provide$location,\n          deps: [UpgradeModule, Location, PlatformLocation, UrlCodec, LocationStrategy]\n        },\n        {provide: LOCATION_UPGRADE_CONFIGURATION, useValue: config ? config : {}},\n        {provide: UrlCodec, useFactory: provideUrlCodec, deps: [LOCATION_UPGRADE_CONFIGURATION]},\n        {\n          provide: APP_BASE_HREF_RESOLVED,\n          useFactory: provideAppBaseHref,\n          deps: [LOCATION_UPGRADE_CONFIGURATION, [new Inject(APP_BASE_HREF), new Optional()]]\n        },\n        {\n          provide: LocationStrategy,\n          useFactory: provideLocationStrategy,\n          deps: [\n            PlatformLocation,\n            APP_BASE_HREF_RESOLVED,\n            LOCATION_UPGRADE_CONFIGURATION,\n          ]\n        },\n      ],\n    };\n  }\n}\n\nexport function provideAppBaseHref(config: LocationUpgradeConfig, appBaseHref?: string) {\n  if (config && config.appBaseHref != null) {\n    return config.appBaseHref;\n  } else if (appBaseHref != null) {\n    return appBaseHref;\n  }\n  return '';\n}\n\nexport function provideUrlCodec(config: LocationUpgradeConfig) {\n  const codec = config && config.urlCodec || AngularJSUrlCodec;\n  return new (codec as any)();\n}\n\nexport function provideLocationStrategy(\n    platformLocation: PlatformLocation, baseHref: string, options: LocationUpgradeConfig = {}) {\n  return options.useHash ? new HashLocationStrategy(platformLocation, baseHref) :\n                           new PathLocationStrategy(platformLocation, baseHref);\n}\n\nexport function provide$location(\n    ngUpgrade: UpgradeModule, location: Location, platformLocation: PlatformLocation,\n    urlCodec: UrlCodec, locationStrategy: LocationStrategy) {\n  const $locationProvider =\n      new $locationShimProvider(ngUpgrade, location, platformLocation, urlCodec, locationStrategy);\n\n  return $locationProvider.$get();\n}"]}