import { patchClass } from './modules/class' import { patchStyle } from './modules/style' import { patchAttr } from './modules/attrs' import { patchDOMProp } from './modules/props' import { patchEvent } from './modules/events' import { isOn } from '@vue/shared' import { VNode, ComponentInternalInstance } from '@vue/runtime-core' export function patchProp( el: Element, key: string, nextValue: any, prevValue: any, isSVG: boolean, prevChildren?: VNode[], parentComponent?: ComponentInternalInstance, unmountChildren?: any ) { switch (key) { // special case 'class': patchClass(el, nextValue, isSVG) break case 'style': patchStyle(el, prevValue, nextValue) break default: if (isOn(key)) { patchEvent( el, key.slice(2).toLowerCase(), prevValue, nextValue, parentComponent ) } else if (!isSVG && key in el) { patchDOMProp( el, key, nextValue, prevChildren, parentComponent, unmountChildren ) } else { patchAttr(el, key, nextValue, isSVG) } break } }