utils.ts — vue Source File
Architecture documentation for utils.ts, a typescript file in the vue codebase. 4 imports, 2 dependents.
Entity Profile
Dependency Diagram
graph LR 2347b93b_5b26_2b27_6743_fe5fed353eb5["utils.ts"] dcc849a8_8698_9d99_84f0_b76bdf69610c["assetUrl.ts"] 2347b93b_5b26_2b27_6743_fe5fed353eb5 --> dcc849a8_8698_9d99_84f0_b76bdf69610c 0220941a_2501_c188_2847_00cf7829329c["TransformAssetUrlsOptions"] 2347b93b_5b26_2b27_6743_fe5fed353eb5 --> 0220941a_2501_c188_2847_00cf7829329c 6688f0d3_bcc7_cc69_7ca5_96930a2aed95["url"] 2347b93b_5b26_2b27_6743_fe5fed353eb5 --> 6688f0d3_bcc7_cc69_7ca5_96930a2aed95 1d29bf33_f532_e958_df1c_3bd911068a94["path"] 2347b93b_5b26_2b27_6743_fe5fed353eb5 --> 1d29bf33_f532_e958_df1c_3bd911068a94 dcc849a8_8698_9d99_84f0_b76bdf69610c["assetUrl.ts"] dcc849a8_8698_9d99_84f0_b76bdf69610c --> 2347b93b_5b26_2b27_6743_fe5fed353eb5 b079557f_1b35_1202_e466_a7574ca75db9["srcset.ts"] b079557f_1b35_1202_e466_a7574ca75db9 --> 2347b93b_5b26_2b27_6743_fe5fed353eb5 style 2347b93b_5b26_2b27_6743_fe5fed353eb5 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import { TransformAssetUrlsOptions } from './assetUrl'
import { UrlWithStringQuery, parse as uriParse } from 'url'
import path from 'path'
export function urlToRequire(
url: string,
transformAssetUrlsOption: TransformAssetUrlsOptions = {}
): string {
const returnValue = `"${url}"`
// same logic as in transform-require.js
const firstChar = url.charAt(0)
if (firstChar === '~') {
const secondChar = url.charAt(1)
url = url.slice(secondChar === '/' ? 2 : 1)
}
if (isExternalUrl(url) || isDataUrl(url) || firstChar === '#') {
return returnValue
}
const uriParts = parseUriParts(url)
if (transformAssetUrlsOption.base) {
// explicit base - directly rewrite the url into absolute url
// does not apply to absolute urls or urls that start with `@`
// since they are aliases
if (firstChar === '.' || firstChar === '~') {
// Allow for full hostnames provided in options.base
const base = parseUriParts(transformAssetUrlsOption.base)
const protocol = base.protocol || ''
const host = base.host ? protocol + '//' + base.host : ''
const basePath = base.path || '/'
// when packaged in the browser, path will be using the posix-
// only version provided by rollup-plugin-node-builtins.
return `"${host}${(path.posix || path).join(
basePath,
uriParts.path + (uriParts.hash || '')
)}"`
}
}
if (
transformAssetUrlsOption.includeAbsolute ||
firstChar === '.' ||
firstChar === '~' ||
firstChar === '@'
) {
if (!uriParts.hash) {
return `require("${url}")`
} else {
// support uri fragment case by excluding it from
// the require and instead appending it as string;
// assuming that the path part is sufficient according to
// the above caseing(t.i. no protocol-auth-host parts expected)
return `require("${uriParts.path}") + "${uriParts.hash}"`
}
}
return returnValue
}
/**
* vuejs/component-compiler-utils#22 Support uri fragment in transformed require
* @param urlString an url as a string
*/
function parseUriParts(urlString: string): UrlWithStringQuery {
// initialize return value
const returnValue: UrlWithStringQuery = uriParse('')
if (urlString) {
// A TypeError is thrown if urlString is not a string
// @see https://nodejs.org/api/url.html#url_url_parse_urlstring_parsequerystring_slashesdenotehost
if ('string' === typeof urlString) {
// check is an uri
return uriParse(urlString, false, true) // take apart the uri
}
}
return returnValue
}
const externalRE = /^(https?:)?\/\//
function isExternalUrl(url: string): boolean {
return externalRE.test(url)
}
const dataUrlRE = /^\s*data:/i
function isDataUrl(url: string): boolean {
return dataUrlRE.test(url)
}
Domain
Subdomains
Dependencies
Imported By
Source
Frequently Asked Questions
What does utils.ts do?
utils.ts is a source file in the vue codebase, written in typescript. It belongs to the CompilerSFC domain, ScriptAnalyzer subdomain.
What functions are defined in utils.ts?
utils.ts defines 4 function(s): isDataUrl, isExternalUrl, parseUriParts, urlToRequire.
What does utils.ts depend on?
utils.ts imports 4 module(s): TransformAssetUrlsOptions, assetUrl.ts, path, url.
What files import utils.ts?
utils.ts is imported by 2 file(s): assetUrl.ts, srcset.ts.
Where is utils.ts in the architecture?
utils.ts is located at packages/compiler-sfc/src/templateCompilerModules/utils.ts (domain: CompilerSFC, subdomain: ScriptAnalyzer, directory: packages/compiler-sfc/src/templateCompilerModules).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free