util.ts — vue Source File
Architecture documentation for util.ts, a typescript file in the vue codebase. 1 imports, 11 dependents.
Entity Profile
Dependency Diagram
graph LR 89eacf5c_deee_e42e_d519_69cb05e48e63["util.ts"] 09aa5370_2caa_6b33_3f44_6ac5211bd11b["util"] 89eacf5c_deee_e42e_d519_69cb05e48e63 --> 09aa5370_2caa_6b33_3f44_6ac5211bd11b f74c7f32_6b84_af20_b750_d2532206091d["create-bundle-renderer.ts"] f74c7f32_6b84_af20_b750_d2532206091d --> 89eacf5c_deee_e42e_d519_69cb05e48e63 53b05d28_585e_4d3e_ad81_d6a7ef6875f2["create-renderer.ts"] 53b05d28_585e_4d3e_ad81_d6a7ef6875f2 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 f549c274_b375_8785_e025_a5d238ba23a1["attrs.ts"] f549c274_b375_8785_e025_a5d238ba23a1 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 b037395d_adef_0c6b_2399_c342b56734c4["class.ts"] b037395d_adef_0c6b_2399_c342b56734c4 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 6c8aaa22_3be8_0715_bdbe_23562ffc07d2["dom-props.ts"] 6c8aaa22_3be8_0715_bdbe_23562ffc07d2 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 9ebd262e_02c0_2bf3_c67d_fa9e59f467c5["style.ts"] 9ebd262e_02c0_2bf3_c67d_fa9e59f467c5 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 4aaa14b9_d580_5a66_5221_1be3a11a7eed["codegen.ts"] 4aaa14b9_d580_5a66_5221_1be3a11a7eed --> 89eacf5c_deee_e42e_d519_69cb05e48e63 92853cf6_4176_f03f_0670_cca3d63c003e["modules.ts"] 92853cf6_4176_f03f_0670_cca3d63c003e --> 89eacf5c_deee_e42e_d519_69cb05e48e63 b5390896_1fe7_f1d9_81bd_c577287dddd4["runtime-helpers.ts"] b5390896_1fe7_f1d9_81bd_c577287dddd4 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 439dcf36_0570_3186_196e_91c09d6d3ea6["render.ts"] 439dcf36_0570_3186_196e_91c09d6d3ea6 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 dd60f8d3_0510_6c88_43e7_0031a6d72263["index.ts"] dd60f8d3_0510_6c88_43e7_0031a6d72263 --> 89eacf5c_deee_e42e_d519_69cb05e48e63 style 89eacf5c_deee_e42e_d519_69cb05e48e63 fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import { makeMap } from 'shared/util'
const isAttr = makeMap(
'accept,accept-charset,accesskey,action,align,alt,async,autocomplete,' +
'autofocus,autoplay,autosave,bgcolor,border,buffered,challenge,charset,' +
'checked,cite,class,code,codebase,color,cols,colspan,content,' +
'contenteditable,contextmenu,controls,coords,data,datetime,default,' +
'defer,dir,dirname,disabled,download,draggable,dropzone,enctype,for,' +
'form,formaction,headers,height,hidden,high,href,hreflang,http-equiv,' +
'icon,id,ismap,itemprop,keytype,kind,label,lang,language,list,loop,low,' +
'manifest,max,maxlength,media,method,GET,POST,min,multiple,email,file,' +
'muted,name,novalidate,open,optimum,pattern,ping,placeholder,poster,' +
'preload,radiogroup,readonly,rel,required,reversed,rows,rowspan,sandbox,' +
'scope,scoped,seamless,selected,shape,size,type,text,password,sizes,span,' +
'spellcheck,src,srcdoc,srclang,srcset,start,step,style,summary,tabindex,' +
'target,title,usemap,value,width,wrap'
)
const unsafeAttrCharRE = /[>/="'\u0009\u000a\u000c\u0020]/ // eslint-disable-line no-control-regex
export const isSSRUnsafeAttr = (name: string): boolean => {
return unsafeAttrCharRE.test(name)
}
/* istanbul ignore next */
const isRenderableAttr = (name: string): boolean => {
return (
isAttr(name) || name.indexOf('data-') === 0 || name.indexOf('aria-') === 0
)
}
export { isRenderableAttr }
export const propsToAttrMap = {
acceptCharset: 'accept-charset',
className: 'class',
htmlFor: 'for',
httpEquiv: 'http-equiv'
}
const ESC = {
'<': '<',
'>': '>',
'"': '"',
'&': '&'
}
export function escape(s: string) {
return s.replace(/[<>"&]/g, escapeChar)
}
function escapeChar(a) {
return ESC[a] || a
}
export const noUnitNumericStyleProps = {
'animation-iteration-count': true,
'border-image-outset': true,
'border-image-slice': true,
'border-image-width': true,
'box-flex': true,
'box-flex-group': true,
'box-ordinal-group': true,
'column-count': true,
columns: true,
flex: true,
'flex-grow': true,
'flex-positive': true,
'flex-shrink': true,
'flex-negative': true,
'flex-order': true,
'grid-row': true,
'grid-row-end': true,
'grid-row-span': true,
'grid-row-start': true,
'grid-column': true,
'grid-column-end': true,
'grid-column-span': true,
'grid-column-start': true,
'font-weight': true,
'line-clamp': true,
'line-height': true,
opacity: true,
order: true,
orphans: true,
'tab-size': true,
widows: true,
'z-index': true,
zoom: true,
// SVG
'fill-opacity': true,
'flood-opacity': true,
'stop-opacity': true,
'stroke-dasharray': true,
'stroke-dashoffset': true,
'stroke-miterlimit': true,
'stroke-opacity': true,
'stroke-width': true
}
export const isJS = (file: string): boolean => /\.js(\?[^.]+)?$/.test(file)
export const isCSS = (file: string): boolean => /\.css(\?[^.]+)?$/.test(file)
export function createPromiseCallback() {
let resolve, reject
const promise: Promise<string> = new Promise((_resolve, _reject) => {
resolve = _resolve
reject = _reject
})
const cb = (err: Error, res?: string) => {
if (err) return reject(err)
resolve(res || '')
}
return { promise, cb }
}
Domain
Subdomains
Functions
Dependencies
- util
Imported By
- packages/server-renderer/src/modules/attrs.ts
- packages/server-renderer/src/modules/class.ts
- packages/server-renderer/src/optimizing-compiler/codegen.ts
- packages/server-renderer/src/bundle-renderer/create-bundle-renderer.ts
- packages/server-renderer/src/create-renderer.ts
- packages/server-renderer/src/modules/dom-props.ts
- packages/server-renderer/src/template-renderer/index.ts
- packages/server-renderer/src/optimizing-compiler/modules.ts
- packages/server-renderer/src/render.ts
- packages/server-renderer/src/optimizing-compiler/runtime-helpers.ts
- packages/server-renderer/src/modules/style.ts
Source
Frequently Asked Questions
What does util.ts do?
util.ts is a source file in the vue codebase, written in typescript. It belongs to the ServerRenderer domain, BundleRenderer subdomain.
What functions are defined in util.ts?
util.ts defines 7 function(s): createPromiseCallback, escape, escapeChar, isCSS, isJS, isRenderableAttr, isSSRUnsafeAttr.
What does util.ts depend on?
util.ts imports 1 module(s): util.
What files import util.ts?
util.ts is imported by 11 file(s): attrs.ts, class.ts, codegen.ts, create-bundle-renderer.ts, create-renderer.ts, dom-props.ts, index.ts, modules.ts, and 3 more.
Where is util.ts in the architecture?
util.ts is located at packages/server-renderer/src/util.ts (domain: ServerRenderer, subdomain: BundleRenderer, directory: packages/server-renderer/src).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free