attrs.js 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /* @flow */
  2. import { makeMap } from 'shared/util'
  3. // attributes that should be using props for binding
  4. export const mustUseProp = makeMap('value,selected,checked,muted')
  5. export const isEnumeratedAttr = makeMap('contenteditable,draggable,spellcheck')
  6. export const isBooleanAttr = makeMap(
  7. 'allowfullscreen,async,autofocus,autoplay,checked,compact,controls,declare,' +
  8. 'default,defaultchecked,defaultmuted,defaultselected,defer,disabled,' +
  9. 'enabled,formnovalidate,hidden,indeterminate,inert,ismap,itemscope,loop,multiple,' +
  10. 'muted,nohref,noresize,noshade,novalidate,nowrap,open,pauseonexit,readonly,' +
  11. 'required,reversed,scoped,seamless,selected,sortable,translate,' +
  12. 'truespeed,typemustmatch,visible'
  13. )
  14. const isAttr = makeMap(
  15. 'accept,accept-charset,accesskey,action,align,alt,async,autocomplete,' +
  16. 'autofocus,autoplay,autosave,bgcolor,border,buffered,challenge,charset,' +
  17. 'checked,cite,class,code,codebase,color,cols,colspan,content,http-equiv,' +
  18. 'name,contenteditable,contextmenu,controls,coords,data,datetime,default,' +
  19. 'defer,dir,dirname,disabled,download,draggable,dropzone,enctype,method,for,' +
  20. 'form,formaction,headers,<th>,height,hidden,high,href,hreflang,http-equiv,' +
  21. 'icon,id,ismap,itemprop,keytype,kind,label,lang,language,list,loop,low,' +
  22. 'manifest,max,maxlength,media,method,GET,POST,min,multiple,email,file,' +
  23. 'muted,name,novalidate,open,optimum,pattern,ping,placeholder,poster,' +
  24. 'preload,radiogroup,readonly,rel,required,reversed,rows,rowspan,sandbox,' +
  25. 'scope,scoped,seamless,selected,shape,size,type,text,password,sizes,span,' +
  26. 'spellcheck,src,srcdoc,srclang,srcset,start,step,style,summary,tabindex,' +
  27. 'target,title,type,usemap,value,width,wrap'
  28. )
  29. export const isRenderableAttr = (name: string): boolean => {
  30. return (
  31. isAttr(name) ||
  32. name.indexOf('data-') === 0 ||
  33. name.indexOf('aria-') === 0
  34. )
  35. }
  36. export const propsToAttrMap = {
  37. acceptCharset: 'accept-charset',
  38. className: 'class',
  39. htmlFor: 'for',
  40. httpEquiv: 'http-equiv'
  41. }
  42. export const xlinkNS = 'http://www.w3.org/1999/xlink'
  43. export const isXlink = (name: string): boolean => {
  44. return name.charAt(5) === ':' && name.slice(0, 5) === 'xlink'
  45. }
  46. export const getXlinkProp = (name: string): string => {
  47. return isXlink(name) ? name.slice(6, name.length) : ''
  48. }
  49. export const isFalsyAttrValue = (val: any): boolean => {
  50. return val == null || val === false
  51. }