()
| 347 | // SSR vnode transforms, only used when user includes client-oriented render |
| 348 | // function in SSR |
| 349 | export function initVModelForSSR(): void { |
| 350 | vModelText.getSSRProps = ({ value }) => ({ value }) |
| 351 | |
| 352 | vModelRadio.getSSRProps = ({ value }, vnode) => { |
| 353 | if (vnode.props && looseEqual(vnode.props.value, value)) { |
| 354 | return { checked: true } |
| 355 | } |
| 356 | } |
| 357 | |
| 358 | vModelCheckbox.getSSRProps = ({ value }, vnode) => { |
| 359 | if (isArray(value)) { |
| 360 | if (vnode.props && looseIndexOf(value, vnode.props.value) > -1) { |
| 361 | return { checked: true } |
| 362 | } |
| 363 | } else if (isSet(value)) { |
| 364 | if (vnode.props && value.has(vnode.props.value)) { |
| 365 | return { checked: true } |
| 366 | } |
| 367 | } else if (value) { |
| 368 | return { checked: true } |
| 369 | } |
| 370 | } |
| 371 | |
| 372 | vModelDynamic.getSSRProps = (binding, vnode) => { |
| 373 | if (typeof vnode.type !== 'string') { |
| 374 | return |
| 375 | } |
| 376 | const modelToUse = resolveDynamicModel( |
| 377 | // resolveDynamicModel expects an uppercase tag name, but vnode.type is lowercase |
| 378 | vnode.type.toUpperCase(), |
| 379 | vnode.props && vnode.props.type, |
| 380 | ) |
| 381 | if (modelToUse.getSSRProps) { |
| 382 | return modelToUse.getSSRProps(binding, vnode) |
| 383 | } |
| 384 | } |
| 385 | } |
| 386 | |
| 387 | export type VModelDirective = |
| 388 | | typeof vModelText |
no test coverage detected