Home / File/ util.ts — vue Source File

util.ts — vue Source File

Architecture documentation for util.ts, a typescript file in the vue codebase. 1 imports, 11 dependents.

File typescript ServerRenderer TemplateRenderer 1 imports 11 dependents 7 functions

Entity Profile

Dependency Diagram

graph LR
  a0033b88_b768_84c8_da01_e6315f54737c["util.ts"]
  156bf2e1_8a13_f22d_5437_54f14bcef8fa["util"]
  a0033b88_b768_84c8_da01_e6315f54737c --> 156bf2e1_8a13_f22d_5437_54f14bcef8fa
  4f458806_5efe_c468_112c_62e6fa467b7c["create-bundle-renderer.ts"]
  4f458806_5efe_c468_112c_62e6fa467b7c --> a0033b88_b768_84c8_da01_e6315f54737c
  38cdd14a_61b8_35ed_893f_b542594d7017["create-renderer.ts"]
  38cdd14a_61b8_35ed_893f_b542594d7017 --> a0033b88_b768_84c8_da01_e6315f54737c
  bc187cab_30a4_3c2e_1a8b_ee1317ae8c83["attrs.ts"]
  bc187cab_30a4_3c2e_1a8b_ee1317ae8c83 --> a0033b88_b768_84c8_da01_e6315f54737c
  ff7a3eb3_b82b_c8e2_0a43_cd439e85d4a3["class.ts"]
  ff7a3eb3_b82b_c8e2_0a43_cd439e85d4a3 --> a0033b88_b768_84c8_da01_e6315f54737c
  2d0c5ed1_0a31_49db_0a74_ee78b6474708["dom-props.ts"]
  2d0c5ed1_0a31_49db_0a74_ee78b6474708 --> a0033b88_b768_84c8_da01_e6315f54737c
  1bba1212_b24c_b9c5_98d6_faf10821140f["style.ts"]
  1bba1212_b24c_b9c5_98d6_faf10821140f --> a0033b88_b768_84c8_da01_e6315f54737c
  d70222cb_3265_c3fc_c0cf_09247995ea9a["codegen.ts"]
  d70222cb_3265_c3fc_c0cf_09247995ea9a --> a0033b88_b768_84c8_da01_e6315f54737c
  90d3f44d_ff5a_6ebd_69e4_9cea3949738e["modules.ts"]
  90d3f44d_ff5a_6ebd_69e4_9cea3949738e --> a0033b88_b768_84c8_da01_e6315f54737c
  b4035da1_cf86_9027_2643_66e42fd3924f["runtime-helpers.ts"]
  b4035da1_cf86_9027_2643_66e42fd3924f --> a0033b88_b768_84c8_da01_e6315f54737c
  affe67c1_b5f5_cf58_e5d3_d3d820ab290f["render.ts"]
  affe67c1_b5f5_cf58_e5d3_d3d820ab290f --> a0033b88_b768_84c8_da01_e6315f54737c
  70b92f4c_021d_4bb1_d973_4e94bcad69f8["index.ts"]
  70b92f4c_021d_4bb1_d973_4e94bcad69f8 --> a0033b88_b768_84c8_da01_e6315f54737c
  style a0033b88_b768_84c8_da01_e6315f54737c 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 = {
  '<': '&lt;',
  '>': '&gt;',
  '"': '&quot;',
  '&': '&amp;'
}

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 }
}

Subdomains

Dependencies

  • util

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, TemplateRenderer 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: TemplateRenderer, 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