// __UNSAFE__ // Reason: potentially setting innerHTML. // This can come from explicit usage of v-html or innerHTML as a prop in render import { warn, DeprecationTypes, compatUtils } from '@vue/runtime-core' // functions. The user is responsible for using them with only trusted content. export function patchDOMProp( el: any, key: string, value: any, // the following args are passed only due to potential innerHTML/textContent // overriding existing VNodes, in which case the old tree must be properly // unmounted. prevChildren: any, parentComponent: any, parentSuspense: any, unmountChildren: any ) { if (key === 'innerHTML' || key === 'textContent') { if (prevChildren) { unmountChildren(prevChildren, parentComponent, parentSuspense) } el[key] = value == null ? '' : value return } if (key === 'value' && el.tagName !== 'PROGRESS') { // store value as _value as well since // non-string values will be stringified. el._value = value const newValue = value == null ? '' : value if (el.value !== newValue) { el.value = newValue } if (value == null) { el.removeAttribute('value') } return } if (value === '' || value == null) { const type = typeof el[key] if (value === '' && type === 'boolean') { // e.g.