UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

284 lines 31.7 kB
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { if (typeof Reflect === "object" && typeof Reflect.decorate === "function") return Reflect.decorate(decorators, target, key, desc); switch (arguments.length) { case 2: return decorators.reduceRight(function(o, d) { return (d && d(o)) || o; }, target); case 3: return decorators.reduceRight(function(o, d) { return (d && d(target, key)), void 0; }, void 0); case 4: return decorators.reduceRight(function(o, d) { return (d && d(target, key, o)) || o; }, desc); } }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; import { Injectable } from 'angular2/src/core/di'; import { isPresent, isBlank, RegExpWrapper } from 'angular2/src/facade/lang'; export function createWithoutPackagePrefix() { return new UrlResolver(); } /** * Used by the {@link Compiler} when resolving HTML and CSS template URLs. * * This interface can be overridden by the application developer to create custom behavior. * * See {@link Compiler} */ export let UrlResolver = class { /** * Resolves the `url` given the `baseUrl`: * - when the `url` is null, the `baseUrl` is returned, * - if `url` is relative ('path/to/here', './path/to/here'), the resolved url is a combination of * `baseUrl` and `url`, * - if `url` is absolute (it has a scheme: 'http://', 'https://' or start with '/'), the `url` is * returned as is (ignoring the `baseUrl`) * * @param {string} baseUrl * @param {string} url * @returns {string} the resolved URL */ resolve(baseUrl, url) { return _resolveUrl(baseUrl, url); } }; UrlResolver = __decorate([ Injectable(), __metadata('design:paramtypes', []) ], UrlResolver); // The code below is adapted from Traceur: // https://github.com/google/traceur-compiler/blob/9511c1dafa972bf0de1202a8a863bad02f0f95a8/src/runtime/url.js /** * Builds a URI string from already-encoded parts. * * No encoding is performed. Any component may be omitted as either null or * undefined. * * @param {?string=} opt_scheme The scheme such as 'http'. * @param {?string=} opt_userInfo The user name before the '@'. * @param {?string=} opt_domain The domain such as 'www.google.com', already * URI-encoded. * @param {(string|null)=} opt_port The port number. * @param {?string=} opt_path The path, already URI-encoded. If it is not * empty, it must begin with a slash. * @param {?string=} opt_queryData The URI-encoded query data. * @param {?string=} opt_fragment The URI-encoded fragment identifier. * @return {string} The fully combined URI. */ function _buildFromEncodedParts(opt_scheme, opt_userInfo, opt_domain, opt_port, opt_path, opt_queryData, opt_fragment) { var out = []; if (isPresent(opt_scheme)) { out.push(opt_scheme + ':'); } if (isPresent(opt_domain)) { out.push('//'); if (isPresent(opt_userInfo)) { out.push(opt_userInfo + '@'); } out.push(opt_domain); if (isPresent(opt_port)) { out.push(':' + opt_port); } } if (isPresent(opt_path)) { out.push(opt_path); } if (isPresent(opt_queryData)) { out.push('?' + opt_queryData); } if (isPresent(opt_fragment)) { out.push('#' + opt_fragment); } return out.join(''); } /** * A regular expression for breaking a URI into its component parts. * * {@link http://www.gbiv.com/protocols/uri/rfc/rfc3986.html#RFC2234} says * As the "first-match-wins" algorithm is identical to the "greedy" * disambiguation method used by POSIX regular expressions, it is natural and * commonplace to use a regular expression for parsing the potential five * components of a URI reference. * * The following line is the regular expression for breaking-down a * well-formed URI reference into its components. * * <pre> * ^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\?([^#]*))?(#(.*))? * 12 3 4 5 6 7 8 9 * </pre> * * The numbers in the second line above are only to assist readability; they * indicate the reference points for each subexpression (i.e., each paired * parenthesis). We refer to the value matched for subexpression <n> as $<n>. * For example, matching the above expression to * <pre> * http://www.ics.uci.edu/pub/ietf/uri/#Related * </pre> * results in the following subexpression matches: * <pre> * $1 = http: * $2 = http * $3 = //www.ics.uci.edu * $4 = www.ics.uci.edu * $5 = /pub/ietf/uri/ * $6 = <undefined> * $7 = <undefined> * $8 = #Related * $9 = Related * </pre> * where <undefined> indicates that the component is not present, as is the * case for the query component in the above example. Therefore, we can * determine the value of the five components as * <pre> * scheme = $2 * authority = $4 * path = $5 * query = $7 * fragment = $9 * </pre> * * The regular expression has been modified slightly to expose the * userInfo, domain, and port separately from the authority. * The modified version yields * <pre> * $1 = http scheme * $2 = <undefined> userInfo -\ * $3 = www.ics.uci.edu domain | authority * $4 = <undefined> port -/ * $5 = /pub/ietf/uri/ path * $6 = <undefined> query without ? * $7 = Related fragment without # * </pre> * @type {!RegExp} * @internal */ var _splitRe = RegExpWrapper.create('^' + '(?:' + '([^:/?#.]+)' + // used by other URL parts such as :, // ?, /, #, and . ':)?' + '(?://' + '(?:([^/?#]*)@)?' + '([\\w\\d\\-\\u0100-\\uffff.%]*)' + // digits, dashes, dots, percent // escapes, and unicode characters. '(?::([0-9]+))?' + ')?' + '([^?#]+)?' + '(?:\\?([^#]*))?' + '(?:#(.*))?' + '$'); /** * The index of each URI component in the return value of goog.uri.utils.split. * @enum {number} */ var _ComponentIndex; (function (_ComponentIndex) { _ComponentIndex[_ComponentIndex["Scheme"] = 1] = "Scheme"; _ComponentIndex[_ComponentIndex["UserInfo"] = 2] = "UserInfo"; _ComponentIndex[_ComponentIndex["Domain"] = 3] = "Domain"; _ComponentIndex[_ComponentIndex["Port"] = 4] = "Port"; _ComponentIndex[_ComponentIndex["Path"] = 5] = "Path"; _ComponentIndex[_ComponentIndex["QueryData"] = 6] = "QueryData"; _ComponentIndex[_ComponentIndex["Fragment"] = 7] = "Fragment"; })(_ComponentIndex || (_ComponentIndex = {})); /** * Splits a URI into its component parts. * * Each component can be accessed via the component indices; for example: * <pre> * goog.uri.utils.split(someStr)[goog.uri.utils.CompontentIndex.QUERY_DATA]; * </pre> * * @param {string} uri The URI string to examine. * @return {!Array.<string|undefined>} Each component still URI-encoded. * Each component that is present will contain the encoded value, whereas * components that are not present will be undefined or empty, depending * on the browser's regular expression implementation. Never null, since * arbitrary strings may still look like path names. */ function _split(uri) { return RegExpWrapper.firstMatch(_splitRe, uri); } /** * Removes dot segments in given path component, as described in * RFC 3986, section 5.2.4. * * @param {string} path A non-empty path component. * @return {string} Path component with removed dot segments. */ function _removeDotSegments(path) { if (path == '/') return '/'; var leadingSlash = path[0] == '/' ? '/' : ''; var trailingSlash = path[path.length - 1] === '/' ? '/' : ''; var segments = path.split('/'); var out = []; var up = 0; for (var pos = 0; pos < segments.length; pos++) { var segment = segments[pos]; switch (segment) { case '': case '.': break; case '..': if (out.length > 0) { out.pop(); } else { up++; } break; default: out.push(segment); } } if (leadingSlash == '') { while (up-- > 0) { out.unshift('..'); } if (out.length === 0) out.push('.'); } return leadingSlash + out.join('/') + trailingSlash; } /** * Takes an array of the parts from split and canonicalizes the path part * and then joins all the parts. * @param {Array.<string?>} parts * @return {string} */ function _joinAndCanonicalizePath(parts) { var path = parts[_ComponentIndex.Path]; path = isBlank(path) ? '' : _removeDotSegments(path); parts[_ComponentIndex.Path] = path; return _buildFromEncodedParts(parts[_ComponentIndex.Scheme], parts[_ComponentIndex.UserInfo], parts[_ComponentIndex.Domain], parts[_ComponentIndex.Port], path, parts[_ComponentIndex.QueryData], parts[_ComponentIndex.Fragment]); } /** * Resolves a URL. * @param {string} base The URL acting as the base URL. * @param {string} to The URL to resolve. * @return {string} */ function _resolveUrl(base, url) { var parts = _split(encodeURI(url)); var baseParts = _split(base); if (isPresent(parts[_ComponentIndex.Scheme])) { return _joinAndCanonicalizePath(parts); } else { parts[_ComponentIndex.Scheme] = baseParts[_ComponentIndex.Scheme]; } for (var i = _ComponentIndex.Scheme; i <= _ComponentIndex.Port; i++) { if (isBlank(parts[i])) { parts[i] = baseParts[i]; } } if (parts[_ComponentIndex.Path][0] == '/') { return _joinAndCanonicalizePath(parts); } var path = baseParts[_ComponentIndex.Path]; if (isBlank(path)) path = '/'; var index = path.lastIndexOf('/'); path = path.substring(0, index + 1) + parts[_ComponentIndex.Path]; parts[_ComponentIndex.Path] = path; return _joinAndCanonicalizePath(parts); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url_resolver.js","sourceRoot":"","sources":["angular2/src/compiler/url_resolver.ts"],"names":["createWithoutPackagePrefix","UrlResolver","UrlResolver.resolve","_buildFromEncodedParts","_ComponentIndex","_split","_removeDotSegments","_joinAndCanonicalizePath","_resolveUrl"],"mappings":"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AeA,CAACA,IAAIA,EAAEA,CAACA,EAAEA,EAAEA,CAACA;QACpEA,EAAEA,CAACA,CAACA,OAAOA,CAACA,KAAKA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA,CAACA;YACtBA,KAAKA,CAACA,CAACA,CAACA,GAAGA,SAASA,CAACA,CAACA,CAACA,CAACA;QAC1BA,CAACA;IACHA,CAACA;IAEDA,EAAEA,CAACA,CAACA,KAAKA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA,CAACA,CAACA,IAAIA,GAAGA,CAACA,CAACA,CAACA;QAC1CA,MAAMA,CAACA,wBAAwBA,CAACA,KAAKA,CAACA,CAACA;IACzCA,CAACA;IAEDA,IAAIA,IAAIA,GAAGA,SAASA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA;IAC3CA,EAAEA,CAACA,CAACA,OAAOA,CAACA,IAAIA,CAACA,CAACA;QAACA,IAAIA,GAAGA,GAAGA,CAACA;IAC9BA,IAAIA,KAAKA,GAAGA,IAAIA,CAACA,WAAWA,CAACA,GAAGA,CAACA,CAACA;IAClCA,IAAIA,GAAGA,IAAIA,CAACA,SAASA,CAACA,CAACA,EAAEA,KAAKA,GAAGA,CAACA,CAACA,GAAGA,KAAKA,CAACA,eAAeA,CAACA,IAAIA,CAACA,CAACA;IAClEA,KAAKA,CAACA,eAAeA,CAACA,IAAIA,CAACA,GAAGA,IAAIA,CAACA;IACnCA,MAAMA,CAACA,wBAAwBA,CAACA,KAAKA,CAACA,CAACA;AACzCA,CAACA","sourcesContent":["import {Injectable} from 'angular2/src/core/di';\nimport {isPresent, isBlank, RegExpWrapper, normalizeBlank} from 'angular2/src/facade/lang';\nimport {BaseException, WrappedException} from 'angular2/src/facade/exceptions';\nimport {ListWrapper} from 'angular2/src/facade/collection';\n\nexport function createWithoutPackagePrefix(): UrlResolver {\n  return new UrlResolver();\n}\n\n\n/**\n * Used by the {@link Compiler} when resolving HTML and CSS template URLs.\n *\n * This interface can be overridden by the application developer to create custom behavior.\n *\n * See {@link Compiler}\n */\n@Injectable()\nexport class UrlResolver {\n  /**\n   * Resolves the `url` given the `baseUrl`:\n   * - when the `url` is null, the `baseUrl` is returned,\n   * - if `url` is relative ('path/to/here', './path/to/here'), the resolved url is a combination of\n   * `baseUrl` and `url`,\n   * - if `url` is absolute (it has a scheme: 'http://', 'https://' or start with '/'), the `url` is\n   * returned as is (ignoring the `baseUrl`)\n   *\n   * @param {string} baseUrl\n   * @param {string} url\n   * @returns {string} the resolved URL\n   */\n  resolve(baseUrl: string, url: string): string { return _resolveUrl(baseUrl, url); }\n}\n\n// The code below is adapted from Traceur:\n// https://github.com/google/traceur-compiler/blob/9511c1dafa972bf0de1202a8a863bad02f0f95a8/src/runtime/url.js\n\n/**\n * Builds a URI string from already-encoded parts.\n *\n * No encoding is performed.  Any component may be omitted as either null or\n * undefined.\n *\n * @param {?string=} opt_scheme The scheme such as 'http'.\n * @param {?string=} opt_userInfo The user name before the '@'.\n * @param {?string=} opt_domain The domain such as 'www.google.com', already\n *     URI-encoded.\n * @param {(string|null)=} opt_port The port number.\n * @param {?string=} opt_path The path, already URI-encoded.  If it is not\n *     empty, it must begin with a slash.\n * @param {?string=} opt_queryData The URI-encoded query data.\n * @param {?string=} opt_fragment The URI-encoded fragment identifier.\n * @return {string} The fully combined URI.\n */\nfunction _buildFromEncodedParts(opt_scheme?: string, opt_userInfo?: string, opt_domain?: string,\n                                opt_port?: string, opt_path?: string, opt_queryData?: string,\n                                opt_fragment?: string): string {\n  var out = [];\n\n  if (isPresent(opt_scheme)) {\n    out.push(opt_scheme + ':');\n  }\n\n  if (isPresent(opt_domain)) {\n    out.push('//');\n\n    if (isPresent(opt_userInfo)) {\n      out.push(opt_userInfo + '@');\n    }\n\n    out.push(opt_domain);\n\n    if (isPresent(opt_port)) {\n      out.push(':' + opt_port);\n    }\n  }\n\n  if (isPresent(opt_path)) {\n    out.push(opt_path);\n  }\n\n  if (isPresent(opt_queryData)) {\n    out.push('?' + opt_queryData);\n  }\n\n  if (isPresent(opt_fragment)) {\n    out.push('#' + opt_fragment);\n  }\n\n  return out.join('');\n}\n\n/**\n * A regular expression for breaking a URI into its component parts.\n *\n * {@link http://www.gbiv.com/protocols/uri/rfc/rfc3986.html#RFC2234} says\n * As the \"first-match-wins\" algorithm is identical to the \"greedy\"\n * disambiguation method used by POSIX regular expressions, it is natural and\n * commonplace to use a regular expression for parsing the potential five\n * components of a URI reference.\n *\n * The following line is the regular expression for breaking-down a\n * well-formed URI reference into its components.\n *\n * <pre>\n * ^(([^:/?#]+):)?(//([^/?#]*))?([^?#]*)(\\?([^#]*))?(#(.*))?\n *  12            3  4          5       6  7        8 9\n * </pre>\n *\n * The numbers in the second line above are only to assist readability; they\n * indicate the reference points for each subexpression (i.e., each paired\n * parenthesis). We refer to the value matched for subexpression <n> as $<n>.\n * For example, matching the above expression to\n * <pre>\n *     http://www.ics.uci.edu/pub/ietf/uri/#Related\n * </pre>\n * results in the following subexpression matches:\n * <pre>\n *    $1 = http:\n *    $2 = http\n *    $3 = //www.ics.uci.edu\n *    $4 = www.ics.uci.edu\n *    $5 = /pub/ietf/uri/\n *    $6 = <undefined>\n *    $7 = <undefined>\n *    $8 = #Related\n *    $9 = Related\n * </pre>\n * where <undefined> indicates that the component is not present, as is the\n * case for the query component in the above example. Therefore, we can\n * determine the value of the five components as\n * <pre>\n *    scheme    = $2\n *    authority = $4\n *    path      = $5\n *    query     = $7\n *    fragment  = $9\n * </pre>\n *\n * The regular expression has been modified slightly to expose the\n * userInfo, domain, and port separately from the authority.\n * The modified version yields\n * <pre>\n *    $1 = http              scheme\n *    $2 = <undefined>       userInfo -\\\n *    $3 = www.ics.uci.edu   domain     | authority\n *    $4 = <undefined>       port     -/\n *    $5 = /pub/ietf/uri/    path\n *    $6 = <undefined>       query without ?\n *    $7 = Related           fragment without #\n * </pre>\n * @type {!RegExp}\n * @internal\n */\nvar _splitRe =\n    RegExpWrapper.create('^' +\n                         '(?:' +\n                         '([^:/?#.]+)' +  // scheme - ignore special characters\n                                          // used by other URL parts such as :,\n                                          // ?, /, #, and .\n                         ':)?' +\n                         '(?://' +\n                         '(?:([^/?#]*)@)?' +                  // userInfo\n                         '([\\\\w\\\\d\\\\-\\\\u0100-\\\\uffff.%]*)' +  // domain - restrict to letters,\n                                                              // digits, dashes, dots, percent\n                                                              // escapes, and unicode characters.\n                         '(?::([0-9]+))?' +                   // port\n                         ')?' +\n                         '([^?#]+)?' +        // path\n                         '(?:\\\\?([^#]*))?' +  // query\n                         '(?:#(.*))?' +       // fragment\n                         '$');\n\n/**\n * The index of each URI component in the return value of goog.uri.utils.split.\n * @enum {number}\n */\nenum _ComponentIndex {\n  Scheme = 1,\n  UserInfo,\n  Domain,\n  Port,\n  Path,\n  QueryData,\n  Fragment\n}\n\n/**\n * Splits a URI into its component parts.\n *\n * Each component can be accessed via the component indices; for example:\n * <pre>\n * goog.uri.utils.split(someStr)[goog.uri.utils.CompontentIndex.QUERY_DATA];\n * </pre>\n *\n * @param {string} uri The URI string to examine.\n * @return {!Array.<string|undefined>} Each component still URI-encoded.\n *     Each component that is present will contain the encoded value, whereas\n *     components that are not present will be undefined or empty, depending\n *     on the browser's regular expression implementation.  Never null, since\n *     arbitrary strings may still look like path names.\n */\nfunction _split(uri: string): Array<string | any> {\n  return RegExpWrapper.firstMatch(_splitRe, uri);\n}\n\n/**\n  * Removes dot segments in given path component, as described in\n  * RFC 3986, section 5.2.4.\n  *\n  * @param {string} path A non-empty path component.\n  * @return {string} Path component with removed dot segments.\n  */\nfunction _removeDotSegments(path: string): string {\n  if (path == '/') return '/';\n\n  var leadingSlash = path[0] == '/' ? '/' : '';\n  var trailingSlash = path[path.length - 1] === '/' ? '/' : '';\n  var segments = path.split('/');\n\n  var out: string[] = [];\n  var up = 0;\n  for (var pos = 0; pos < segments.length; pos++) {\n    var segment = segments[pos];\n    switch (segment) {\n      case '':\n      case '.':\n        break;\n      case '..':\n        if (out.length > 0) {\n          out.pop();\n        } else {\n          up++;\n        }\n        break;\n      default:\n        out.push(segment);\n    }\n  }\n\n  if (leadingSlash == '') {\n    while (up-- > 0) {\n      out.unshift('..');\n    }\n\n    if (out.length === 0) out.push('.');\n  }\n\n  return leadingSlash + out.join('/') + trailingSlash;\n}\n\n/**\n * Takes an array of the parts from split and canonicalizes the path part\n * and then joins all the parts.\n * @param {Array.<string?>} parts\n * @return {string}\n */\nfunction _joinAndCanonicalizePath(parts: any[]): string {\n  var path = parts[_ComponentIndex.Path];\n  path = isBlank(path) ? '' : _removeDotSegments(path);\n  parts[_ComponentIndex.Path] = path;\n\n  return _buildFromEncodedParts(parts[_ComponentIndex.Scheme], parts[_ComponentIndex.UserInfo],\n                                parts[_ComponentIndex.Domain], parts[_ComponentIndex.Port], path,\n                                parts[_ComponentIndex.QueryData], parts[_ComponentIndex.Fragment]);\n}\n\n/**\n * Resolves a URL.\n * @param {string} base The URL acting as the base URL.\n * @param {string} to The URL to resolve.\n * @return {string}\n */\nfunction _resolveUrl(base: string, url: string): string {\n  var parts = _split(encodeURI(url));\n  var baseParts = _split(base);\n\n  if (isPresent(parts[_ComponentIndex.Scheme])) {\n    return _joinAndCanonicalizePath(parts);\n  } else {\n    parts[_ComponentIndex.Scheme] = baseParts[_ComponentIndex.Scheme];\n  }\n\n  for (var i = _ComponentIndex.Scheme; i <= _ComponentIndex.Port; i++) {\n    if (isBlank(parts[i])) {\n      parts[i] = baseParts[i];\n    }\n  }\n\n  if (parts[_ComponentIndex.Path][0] == '/') {\n    return _joinAndCanonicalizePath(parts);\n  }\n\n  var path = baseParts[_ComponentIndex.Path];\n  if (isBlank(path)) path = '/';\n  var index = path.lastIndexOf('/');\n  path = path.substring(0, index + 1) + parts[_ComponentIndex.Path];\n  parts[_ComponentIndex.Path] = path;\n  return _joinAndCanonicalizePath(parts);\n}\n"]}