UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

126 lines 21.4 kB
import { isBlank, isPresent } from 'angular2/src/facade/lang'; import { BaseException } from 'angular2/src/facade/exceptions'; import { Map } from 'angular2/src/facade/collection'; import { PromiseWrapper } from 'angular2/src/facade/async'; import { RouteRecognizer, RedirectRecognizer, PathMatch } from './route_recognizer'; import { Route, AsyncRoute, AuxRoute, Redirect } from './route_config_impl'; import { AsyncRouteHandler } from './async_route_handler'; import { SyncRouteHandler } from './sync_route_handler'; /** * `ComponentRecognizer` is responsible for recognizing routes for a single component. * It is consumed by `RouteRegistry`, which knows how to recognize an entire hierarchy of * components. */ export class ComponentRecognizer { constructor() { this.names = new Map(); // map from name to recognizer this.auxNames = new Map(); // map from starting path to recognizer this.auxRoutes = new Map(); // TODO: optimize this into a trie this.matchers = []; this.defaultRoute = null; } /** * returns whether or not the config is terminal */ config(config) { var handler; if (isPresent(config.name) && config.name[0].toUpperCase() != config.name[0]) { var suggestedName = config.name[0].toUpperCase() + config.name.substring(1); throw new BaseException(`Route "${config.path}" with name "${config.name}" does not begin with an uppercase letter. Route names should be CamelCase like "${suggestedName}".`); } if (config instanceof AuxRoute) { handler = new SyncRouteHandler(config.component, config.data); let path = config.path.startsWith('/') ? config.path.substring(1) : config.path; var recognizer = new RouteRecognizer(config.path, handler); this.auxRoutes.set(path, recognizer); if (isPresent(config.name)) { this.auxNames.set(config.name, recognizer); } return recognizer.terminal; } var useAsDefault = false; if (config instanceof Redirect) { let redirector = new RedirectRecognizer(config.path, config.redirectTo); this._assertNoHashCollision(redirector.hash, config.path); this.matchers.push(redirector); return true; } if (config instanceof Route) { handler = new SyncRouteHandler(config.component, config.data); useAsDefault = isPresent(config.useAsDefault) && config.useAsDefault; } else if (config instanceof AsyncRoute) { handler = new AsyncRouteHandler(config.loader, config.data); useAsDefault = isPresent(config.useAsDefault) && config.useAsDefault; } var recognizer = new RouteRecognizer(config.path, handler); this._assertNoHashCollision(recognizer.hash, config.path); if (useAsDefault) { if (isPresent(this.defaultRoute)) { throw new BaseException(`Only one route can be default`); } this.defaultRoute = recognizer; } this.matchers.push(recognizer); if (isPresent(config.name)) { this.names.set(config.name, recognizer); } return recognizer.terminal; } _assertNoHashCollision(hash, path) { this.matchers.forEach((matcher) => { if (hash == matcher.hash) { throw new BaseException(`Configuration '${path}' conflicts with existing route '${matcher.path}'`); } }); } /** * Given a URL, returns a list of `RouteMatch`es, which are partial recognitions for some route. */ recognize(urlParse) { var solutions = []; this.matchers.forEach((routeRecognizer) => { var pathMatch = routeRecognizer.recognize(urlParse); if (isPresent(pathMatch)) { solutions.push(pathMatch); } }); // handle cases where we are routing just to an aux route if (solutions.length == 0 && isPresent(urlParse) && urlParse.auxiliary.length > 0) { return [PromiseWrapper.resolve(new PathMatch(null, null, urlParse.auxiliary))]; } return solutions; } recognizeAuxiliary(urlParse) { var routeRecognizer = this.auxRoutes.get(urlParse.path); if (isPresent(routeRecognizer)) { return [routeRecognizer.recognize(urlParse)]; } return [PromiseWrapper.resolve(null)]; } hasRoute(name) { return this.names.has(name); } componentLoaded(name) { return this.hasRoute(name) && isPresent(this.names.get(name).handler.componentType); } loadComponent(name) { return this.names.get(name).handler.resolveComponentType(); } generate(name, params) { var pathRecognizer = this.names.get(name); if (isBlank(pathRecognizer)) { return null; } return pathRecognizer.generate(params); } generateAuxiliary(name, params) { var pathRecognizer = this.auxNames.get(name); if (isBlank(pathRecognizer)) { return null; } return pathRecognizer.generate(params); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component_recognizer.js","sourceRoot":"","sources":["angular2/src/router/component_recognizer.ts"],"names":["ComponentRecognizer","ComponentRecognizer.constructor","ComponentRecognizer.config","ComponentRecognizer._assertNoHashCollision","ComponentRecognizer.recognize","ComponentRecognizer.recognizeAuxiliary","ComponentRecognizer.hasRoute","ComponentRecognizer.componentLoaded","ComponentRecognizer.loadComponent","ComponentRecognizer.generate","ComponentRecognizer.generateAuxiliary"],"mappings":"OAAO,EAAC,OAAO,EAAE,SAAS,EAAC,MAAM,0BAA0B;OACpD,EAAC,aAAa,EAAmB,MAAM,gCAAgC;OACvE,EAAC,GAAG,EAA4C,MAAM,gCAAgC;OACtF,EAAC,cAAc,EAAC,MAAM,2BAA2B;OAEjD,EAEL,eAAe,EACf,kBAAkB,EAElB,SAAS,EACV,MAAM,oBAAoB;OACpB,EAAC,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAkB,MAAM,qBAAqB;OACnF,EAAC,iBAAiB,EAAC,MAAM,uBAAuB;OAChD,EAAC,gBAAgB,EAAC,MAAM,sBAAsB;AAKrD;;;;GAIG;AACH;IAAAA;QACEC,UAAKA,GAAGA,IAAIA,GAAGA,EAA2BA,CAACA;QAE3CA,8BAA8BA;QAC9BA,aAAQA,GAAGA,IAAIA,GAAGA,EAA2BA,CAACA;QAE9CA,uCAAuCA;QACvCA,cAASA,GAAGA,IAAIA,GAAGA,EAA2BA,CAACA;QAE/CA,kCAAkCA;QAClCA,aAAQA,GAAyBA,EAAEA,CAACA;QAEpCA,iBAAYA,GAAoBA,IAAIA,CAACA;IA8HvCA,CAACA;IA5HCD;;OAEGA;IACHA,MAAMA,CAACA,MAAuBA;QAC5BE,IAAIA,OAAOA,CAACA;QAEZA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,CAACA,IAAIA,CAACA,IAAIA,MAAMA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,WAAWA,EAAEA,IAAIA,MAAMA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;YAC7EA,IAAIA,aAAaA,GAAGA,MAAMA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,WAAWA,EAAEA,GAAGA,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;YAC5EA,MAAMA,IAAIA,aAAaA,CACnBA,UAAUA,MAAMA,CAACA,IAAIA,gBAAgBA,MAAMA,CAACA,IAAIA,oFAAoFA,aAAaA,IAAIA,CAACA,CAACA;QAC7JA,CAACA;QAEDA,EAAEA,CAACA,CAACA,MAAMA,YAAYA,QAAQA,CAACA,CAACA,CAACA;YAC/BA,OAAOA,GAAGA,IAAIA,gBAAgBA,CAACA,MAAMA,CAACA,SAASA,EAAEA,MAAMA,CAACA,IAAIA,CAACA,CAACA;YAC9DA,IAAIA,IAAIA,GAAGA,MAAMA,CAACA,IAAIA,CAACA,UAAUA,CAACA,GAAGA,CAACA,GAAGA,MAAMA,CAACA,IAAIA,CAACA,SAASA,CAACA,CAACA,CAACA,GAAGA,MAAMA,CAACA,IAAIA,CAACA;YAChFA,IAAIA,UAAUA,GAAGA,IAAIA,eAAeA,CAACA,MAAMA,CAACA,IAAIA,EAAEA,OAAOA,CAACA,CAACA;YAC3DA,IAAIA,CAACA,SAASA,CAACA,GAAGA,CAACA,IAAIA,EAAEA,UAAUA,CAACA,CAACA;YACrCA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA;gBAC3BA,IAAIA,CAACA,QAAQA,CAACA,GAAGA,CAACA,MAAMA,CAACA,IAAIA,EAAEA,UAAUA,CAACA,CAACA;YAC7CA,CAACA;YACDA,MAAMA,CAACA,UAAUA,CAACA,QAAQA,CAACA;QAC7BA,CAACA;QAEDA,IAAIA,YAAYA,GAAGA,KAAKA,CAACA;QAEzBA,EAAEA,CAACA,CAACA,MAAMA,YAAYA,QAAQA,CAACA,CAACA,CAACA;YAC/BA,IAAIA,UAAUA,GAAGA,IAAIA,kBAAkBA,CAACA,MAAMA,CAACA,IAAIA,EAAEA,MAAMA,CAACA,UAAUA,CAACA,CAACA;YACxEA,IAAIA,CAACA,sBAAsBA,CAACA,UAAUA,CAACA,IAAIA,EAAEA,MAAMA,CAACA,IAAIA,CAACA,CAACA;YAC1DA,IAAIA,CAACA,QAAQA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA;YAC/BA,MAAMA,CAACA,IAAIA,CAACA;QACdA,CAACA;QAEDA,EAAEA,CAACA,CAACA,MAAMA,YAAYA,KAAKA,CAACA,CAACA,CAACA;YAC5BA,OAAOA,GAAGA,IAAIA,gBAAgBA,CAACA,MAAMA,CAACA,SAASA,EAAEA,MAAMA,CAACA,IAAIA,CAACA,CAACA;YAC9DA,YAAYA,GAAGA,SAASA,CAACA,MAAMA,CAACA,YAAYA,CAACA,IAAIA,MAAMA,CAACA,YAAYA,CAACA;QACvEA,CAACA;QAACA,IAAIA,CAACA,EAAEA,CAACA,CAACA,MAAMA,YAAYA,UAAUA,CAACA,CAACA,CAACA;YACxCA,OAAOA,GAAGA,IAAIA,iBAAiBA,CAACA,MAAMA,CAACA,MAAMA,EAAEA,MAAMA,CAACA,IAAIA,CAACA,CAACA;YAC5DA,YAAYA,GAAGA,SAASA,CAACA,MAAMA,CAACA,YAAYA,CAACA,IAAIA,MAAMA,CAACA,YAAYA,CAACA;QACvEA,CAACA;QACDA,IAAIA,UAAUA,GAAGA,IAAIA,eAAeA,CAACA,MAAMA,CAACA,IAAIA,EAAEA,OAAOA,CAACA,CAACA;QAE3DA,IAAIA,CAACA,sBAAsBA,CAACA,UAAUA,CAACA,IAAIA,EAAEA,MAAMA,CAACA,IAAIA,CAACA,CAACA;QAE1DA,EAAEA,CAACA,CAACA,YAAYA,CAACA,CAACA,CAACA;YACjBA,EAAEA,CAACA,CAACA,SAASA,CAACA,IAAIA,CAACA,YAAYA,CAACA,CAACA,CAACA,CAACA;gBACjCA,MAAMA,IAAIA,aAAaA,CAACA,+BAA+BA,CAACA,CAACA;YAC3DA,CAACA;YACDA,IAAIA,CAACA,YAAYA,GAAGA,UAAUA,CAACA;QACjCA,CAACA;QAEDA,IAAIA,CAACA,QAAQA,CAACA,IAAIA,CAACA,UAAUA,CAACA,CAACA;QAC/BA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA;YAC3BA,IAAIA,CAACA,KAAKA,CAACA,GAAGA,CAACA,MAAMA,CAACA,IAAIA,EAAEA,UAAUA,CAACA,CAACA;QAC1CA,CAACA;QACDA,MAAMA,CAACA,UAAUA,CAACA,QAAQA,CAACA;IAC7BA,CAACA;IAGOF,sBAAsBA,CAACA,IAAYA,EAAEA,IAAIA;QAC/CG,IAAIA,CAACA,QAAQA,CAACA,OAAOA,CAACA,CAACA,OAAOA;YAC5BA,EAAEA,CAACA,CAACA,IAAIA,IAAIA,OAAOA,CAACA,IAAIA,CAACA,CAACA,CAACA;gBACzBA,MAAMA,IAAIA,aAAaA,CACnBA,kBAAkBA,IAAIA,oCAAoCA,OAAOA,CAACA,IAAIA,GAAGA,CAACA,CAACA;YACjFA,CAACA;QACHA,CAACA,CAACA,CAACA;IACLA,CAACA;IAGDH;;OAEGA;IACHA,SAASA,CAACA,QAAaA;QACrBI,IAAIA,SAASA,GAAGA,EAAEA,CAACA;QAEnBA,IAAIA,CAACA,QAAQA,CAACA,OAAOA,CAACA,CAACA,eAAmCA;YACxDA,IAAIA,SAASA,GAAGA,eAAeA,CAACA,SAASA,CAACA,QAAQA,CAACA,CAACA;YAEpDA,EAAEA,CAACA,CAACA,SAASA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;gBACzBA,SAASA,CAACA,IAAIA,CAACA,SAASA,CAACA,CAACA;YAC5BA,CAACA;QACHA,CAACA,CAACA,CAACA;QAEHA,yDAAyDA;QACzDA,EAAEA,CAACA,CAACA,SAASA,CAACA,MAAMA,IAAIA,CAACA,IAAIA,SAASA,CAACA,QAAQA,CAACA,IAAIA,QAAQA,CAACA,SAASA,CAACA,MAAMA,GAAGA,CAACA,CAACA,CAACA,CAACA;YAClFA,MAAMA,CAACA,CAACA,cAAcA,CAACA,OAAOA,CAACA,IAAIA,SAASA,CAACA,IAAIA,EAAEA,IAAIA,EAAEA,QAAQA,CAACA,SAASA,CAACA,CAACA,CAACA,CAACA;QACjFA,CAACA;QAEDA,MAAMA,CAACA,SAASA,CAACA;IACnBA,CAACA;IAEDJ,kBAAkBA,CAACA,QAAaA;QAC9BK,IAAIA,eAAeA,GAAoBA,IAAIA,CAACA,SAASA,CAACA,GAAGA,CAACA,QAAQA,CAACA,IAAIA,CAACA,CAACA;QACzEA,EAAEA,CAACA,CAACA,SAASA,CAACA,eAAeA,CAACA,CAACA,CAACA,CAACA;YAC/BA,MAAMA,CAACA,CAACA,eAAeA,CAACA,SAASA,CAACA,QAAQA,CAACA,CAACA,CAACA;QAC/CA,CAACA;QAEDA,MAAMA,CAACA,CAACA,cAAcA,CAACA,OAAOA,CAACA,IAAIA,CAACA,CAACA,CAACA;IACxCA,CAACA;IAEDL,QAAQA,CAACA,IAAYA,IAAaM,MAAMA,CAACA,IAAIA,CAACA,KAAKA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA;IAEhEN,eAAeA,CAACA,IAAYA;QAC1BO,MAAMA,CAACA,IAAIA,CAACA,QAAQA,CAACA,IAAIA,CAACA,IAAIA,SAASA,CAACA,IAAIA,CAACA,KAAKA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,OAAOA,CAACA,aAAaA,CAACA,CAACA;IACtFA,CAACA;IAEDP,aAAaA,CAACA,IAAYA;QACxBQ,MAAMA,CAACA,IAAIA,CAACA,KAAKA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA,OAAOA,CAACA,oBAAoBA,EAAEA,CAACA;IAC7DA,CAACA;IAEDR,QAAQA,CAACA,IAAYA,EAAEA,MAAWA;QAChCS,IAAIA,cAAcA,GAAoBA,IAAIA,CAACA,KAAKA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA;QAC3DA,EAAEA,CAACA,CAACA,OAAOA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC5BA,MAAMA,CAACA,IAAIA,CAACA;QACdA,CAACA;QACDA,MAAMA,CAACA,cAAcA,CAACA,QAAQA,CAACA,MAAMA,CAACA,CAACA;IACzCA,CAACA;IAEDT,iBAAiBA,CAACA,IAAYA,EAAEA,MAAWA;QACzCU,IAAIA,cAAcA,GAAoBA,IAAIA,CAACA,QAAQA,CAACA,GAAGA,CAACA,IAAIA,CAACA,CAACA;QAC9DA,EAAEA,CAACA,CAACA,OAAOA,CAACA,cAAcA,CAACA,CAACA,CAACA,CAACA;YAC5BA,MAAMA,CAACA,IAAIA,CAACA;QACdA,CAACA;QACDA,MAAMA,CAACA,cAAcA,CAACA,QAAQA,CAACA,MAAMA,CAACA,CAACA;IACzCA,CAACA;AACHV,CAACA;AAAA","sourcesContent":["import {isBlank, isPresent} from 'angular2/src/facade/lang';\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {Map, MapWrapper, ListWrapper, StringMapWrapper} from 'angular2/src/facade/collection';\nimport {PromiseWrapper} from 'angular2/src/facade/async';\n\nimport {\n  AbstractRecognizer,\n  RouteRecognizer,\n  RedirectRecognizer,\n  RouteMatch,\n  PathMatch\n} from './route_recognizer';\nimport {Route, AsyncRoute, AuxRoute, Redirect, RouteDefinition} from './route_config_impl';\nimport {AsyncRouteHandler} from './async_route_handler';\nimport {SyncRouteHandler} from './sync_route_handler';\nimport {Url} from './url_parser';\nimport {ComponentInstruction} from './instruction';\n\n\n/**\n * `ComponentRecognizer` is responsible for recognizing routes for a single component.\n * It is consumed by `RouteRegistry`, which knows how to recognize an entire hierarchy of\n * components.\n */\nexport class ComponentRecognizer {\n  names = new Map<string, RouteRecognizer>();\n\n  // map from name to recognizer\n  auxNames = new Map<string, RouteRecognizer>();\n\n  // map from starting path to recognizer\n  auxRoutes = new Map<string, RouteRecognizer>();\n\n  // TODO: optimize this into a trie\n  matchers: AbstractRecognizer[] = [];\n\n  defaultRoute: RouteRecognizer = null;\n\n  /**\n   * returns whether or not the config is terminal\n   */\n  config(config: RouteDefinition): boolean {\n    var handler;\n\n    if (isPresent(config.name) && config.name[0].toUpperCase() != config.name[0]) {\n      var suggestedName = config.name[0].toUpperCase() + config.name.substring(1);\n      throw new BaseException(\n          `Route \"${config.path}\" with name \"${config.name}\" does not begin with an uppercase letter. Route names should be CamelCase like \"${suggestedName}\".`);\n    }\n\n    if (config instanceof AuxRoute) {\n      handler = new SyncRouteHandler(config.component, config.data);\n      let path = config.path.startsWith('/') ? config.path.substring(1) : config.path;\n      var recognizer = new RouteRecognizer(config.path, handler);\n      this.auxRoutes.set(path, recognizer);\n      if (isPresent(config.name)) {\n        this.auxNames.set(config.name, recognizer);\n      }\n      return recognizer.terminal;\n    }\n\n    var useAsDefault = false;\n\n    if (config instanceof Redirect) {\n      let redirector = new RedirectRecognizer(config.path, config.redirectTo);\n      this._assertNoHashCollision(redirector.hash, config.path);\n      this.matchers.push(redirector);\n      return true;\n    }\n\n    if (config instanceof Route) {\n      handler = new SyncRouteHandler(config.component, config.data);\n      useAsDefault = isPresent(config.useAsDefault) && config.useAsDefault;\n    } else if (config instanceof AsyncRoute) {\n      handler = new AsyncRouteHandler(config.loader, config.data);\n      useAsDefault = isPresent(config.useAsDefault) && config.useAsDefault;\n    }\n    var recognizer = new RouteRecognizer(config.path, handler);\n\n    this._assertNoHashCollision(recognizer.hash, config.path);\n\n    if (useAsDefault) {\n      if (isPresent(this.defaultRoute)) {\n        throw new BaseException(`Only one route can be default`);\n      }\n      this.defaultRoute = recognizer;\n    }\n\n    this.matchers.push(recognizer);\n    if (isPresent(config.name)) {\n      this.names.set(config.name, recognizer);\n    }\n    return recognizer.terminal;\n  }\n\n\n  private _assertNoHashCollision(hash: string, path) {\n    this.matchers.forEach((matcher) => {\n      if (hash == matcher.hash) {\n        throw new BaseException(\n            `Configuration '${path}' conflicts with existing route '${matcher.path}'`);\n      }\n    });\n  }\n\n\n  /**\n   * Given a URL, returns a list of `RouteMatch`es, which are partial recognitions for some route.\n   */\n  recognize(urlParse: Url): Promise<RouteMatch>[] {\n    var solutions = [];\n\n    this.matchers.forEach((routeRecognizer: AbstractRecognizer) => {\n      var pathMatch = routeRecognizer.recognize(urlParse);\n\n      if (isPresent(pathMatch)) {\n        solutions.push(pathMatch);\n      }\n    });\n\n    // handle cases where we are routing just to an aux route\n    if (solutions.length == 0 && isPresent(urlParse) && urlParse.auxiliary.length > 0) {\n      return [PromiseWrapper.resolve(new PathMatch(null, null, urlParse.auxiliary))];\n    }\n\n    return solutions;\n  }\n\n  recognizeAuxiliary(urlParse: Url): Promise<RouteMatch>[] {\n    var routeRecognizer: RouteRecognizer = this.auxRoutes.get(urlParse.path);\n    if (isPresent(routeRecognizer)) {\n      return [routeRecognizer.recognize(urlParse)];\n    }\n\n    return [PromiseWrapper.resolve(null)];\n  }\n\n  hasRoute(name: string): boolean { return this.names.has(name); }\n\n  componentLoaded(name: string): boolean {\n    return this.hasRoute(name) && isPresent(this.names.get(name).handler.componentType);\n  }\n\n  loadComponent(name: string): Promise<any> {\n    return this.names.get(name).handler.resolveComponentType();\n  }\n\n  generate(name: string, params: any): ComponentInstruction {\n    var pathRecognizer: RouteRecognizer = this.names.get(name);\n    if (isBlank(pathRecognizer)) {\n      return null;\n    }\n    return pathRecognizer.generate(params);\n  }\n\n  generateAuxiliary(name: string, params: any): ComponentInstruction {\n    var pathRecognizer: RouteRecognizer = this.auxNames.get(name);\n    if (isBlank(pathRecognizer)) {\n      return null;\n    }\n    return pathRecognizer.generate(params);\n  }\n}\n"]}