mirror of
https://github.com/nuxt/nuxt.git
synced 2024-12-18 10:17:16 +00:00
61 lines
1.3 KiB
JavaScript
61 lines
1.3 KiB
JavaScript
|
import Vue from 'vue'
|
||
|
|
||
|
const transitionsKeys = [
|
||
|
'name',
|
||
|
'mode',
|
||
|
'css',
|
||
|
'type',
|
||
|
'enterClass',
|
||
|
'leaveClass',
|
||
|
'enterActiveClass',
|
||
|
'leaveActiveClass'
|
||
|
]
|
||
|
const listenersKeys = [
|
||
|
'beforeEnter',
|
||
|
'enter',
|
||
|
'afterEnter',
|
||
|
'enterCancelled',
|
||
|
'beforeLeave',
|
||
|
'leave',
|
||
|
'afterLeave',
|
||
|
'leaveCancelled'
|
||
|
]
|
||
|
|
||
|
export default {
|
||
|
name: 'nuxt-child',
|
||
|
functional: true,
|
||
|
render (h, { parent, data }) {
|
||
|
data.nuxtChild = true
|
||
|
|
||
|
const transitions = parent.$nuxt.nuxt.transitions
|
||
|
const defaultTransition = parent.$nuxt.nuxt.defaultTransition
|
||
|
let depth = 0
|
||
|
while (parent) {
|
||
|
if (parent.$vnode && parent.$vnode.data.nuxtChild) {
|
||
|
depth++
|
||
|
}
|
||
|
parent = parent.$parent
|
||
|
}
|
||
|
data.nuxtChildDepth = depth
|
||
|
const transition = transitions[depth] || defaultTransition
|
||
|
let transitionProps = {}
|
||
|
transitionsKeys.forEach((key) => {
|
||
|
if (typeof transition[key] !== 'undefined') {
|
||
|
transitionProps[key] = transition[key]
|
||
|
}
|
||
|
})
|
||
|
let listeners = {}
|
||
|
listenersKeys.forEach((key) => {
|
||
|
if (typeof transition[key] === 'function') {
|
||
|
listeners[key] = transition[key]
|
||
|
}
|
||
|
})
|
||
|
return h('transition', {
|
||
|
props: transitionProps,
|
||
|
on: listeners
|
||
|
}, [
|
||
|
h('router-view', data)
|
||
|
])
|
||
|
}
|
||
|
}
|