77 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
// vue compiler module for transforming `<tag>:<attribute>` to `require`
 | 
						|
 | 
						|
import { urlToRequire, ASTNode, Attr } from './utils'
 | 
						|
 | 
						|
export interface AssetURLOptions {
 | 
						|
  [name: string]: string | string[]
 | 
						|
}
 | 
						|
 | 
						|
export interface TransformAssetUrlsOptions {
 | 
						|
  /**
 | 
						|
   * If base is provided, instead of transforming relative asset urls into
 | 
						|
   * imports, they will be directly rewritten to absolute urls.
 | 
						|
   */
 | 
						|
  base?: string
 | 
						|
}
 | 
						|
 | 
						|
const defaultOptions: AssetURLOptions = {
 | 
						|
  audio: 'src',
 | 
						|
  video: ['src', 'poster'],
 | 
						|
  source: 'src',
 | 
						|
  img: 'src',
 | 
						|
  image: ['xlink:href', 'href'],
 | 
						|
  use: ['xlink:href', 'href']
 | 
						|
}
 | 
						|
 | 
						|
export default (
 | 
						|
  userOptions?: AssetURLOptions,
 | 
						|
  transformAssetUrlsOption?: TransformAssetUrlsOptions
 | 
						|
) => {
 | 
						|
  const options = userOptions
 | 
						|
    ? Object.assign({}, defaultOptions, userOptions)
 | 
						|
    : defaultOptions
 | 
						|
 | 
						|
  return {
 | 
						|
    postTransformNode: (node: ASTNode) => {
 | 
						|
      transform(node, options, transformAssetUrlsOption)
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
function transform(
 | 
						|
  node: ASTNode,
 | 
						|
  options: AssetURLOptions,
 | 
						|
  transformAssetUrlsOption?: TransformAssetUrlsOptions
 | 
						|
) {
 | 
						|
  for (const tag in options) {
 | 
						|
    if ((tag === '*' || node.tag === tag) && node.attrs) {
 | 
						|
      const attributes = options[tag]
 | 
						|
      if (typeof attributes === 'string') {
 | 
						|
        node.attrs.some(attr =>
 | 
						|
          rewrite(attr, attributes, transformAssetUrlsOption)
 | 
						|
        )
 | 
						|
      } else if (Array.isArray(attributes)) {
 | 
						|
        attributes.forEach(item =>
 | 
						|
          node.attrs.some(attr => rewrite(attr, item, transformAssetUrlsOption))
 | 
						|
        )
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
function rewrite(
 | 
						|
  attr: Attr,
 | 
						|
  name: string,
 | 
						|
  transformAssetUrlsOption?: TransformAssetUrlsOptions
 | 
						|
) {
 | 
						|
  if (attr.name === name) {
 | 
						|
    const value = attr.value
 | 
						|
    // only transform static URLs
 | 
						|
    if (value.charAt(0) === '"' && value.charAt(value.length - 1) === '"') {
 | 
						|
      attr.value = urlToRequire(value.slice(1, -1), transformAssetUrlsOption)
 | 
						|
      return true
 | 
						|
    }
 | 
						|
  }
 | 
						|
  return false
 | 
						|
}
 |