mirror of
https://github.com/tornadocash/tornado-initiation-ui.git
synced 2025-01-22 16:09:24 +01:00
72 lines
1.8 KiB
Vue
72 lines
1.8 KiB
Vue
<script>
|
|
export default {
|
|
name: 'TransitionExpand',
|
|
functional: true,
|
|
render(createElement, context) {
|
|
const data = {
|
|
props: {
|
|
name: 'expand',
|
|
},
|
|
on: {
|
|
afterEnter(element) {
|
|
element.style.height = 'auto'
|
|
},
|
|
enter(element) {
|
|
const { width } = getComputedStyle(element)
|
|
element.style.width = width
|
|
element.style.position = 'absolute'
|
|
element.style.visibility = 'hidden'
|
|
element.style.height = 'auto'
|
|
const { height } = getComputedStyle(element)
|
|
element.style.width = null
|
|
element.style.position = null
|
|
element.style.visibility = null
|
|
element.style.height = 0
|
|
// Force repaint to make sure the
|
|
// animation is triggered correctly.
|
|
// eslint-disable-next-line no-unused-expressions
|
|
getComputedStyle(element).height
|
|
requestAnimationFrame(() => {
|
|
element.style.height = height
|
|
})
|
|
},
|
|
leave(element) {
|
|
const { height } = getComputedStyle(element)
|
|
element.style.height = height
|
|
// Force repaint to make sure the
|
|
// animation is triggered correctly.
|
|
// eslint-disable-next-line no-unused-expressions
|
|
getComputedStyle(element).height
|
|
requestAnimationFrame(() => {
|
|
element.style.height = 0
|
|
})
|
|
},
|
|
},
|
|
}
|
|
return createElement('transition', data, context.children)
|
|
},
|
|
}
|
|
</script>
|
|
|
|
<style scoped>
|
|
* {
|
|
will-change: height;
|
|
transform: translateZ(0);
|
|
backface-visibility: hidden;
|
|
perspective: 1000px;
|
|
}
|
|
</style>
|
|
|
|
<style>
|
|
.expand-enter-active,
|
|
.expand-leave-active {
|
|
transition: height 0.2s ease-in-out, opacity 0.2s;
|
|
overflow: hidden;
|
|
}
|
|
.expand-enter,
|
|
.expand-leave-to {
|
|
height: 0;
|
|
opacity: 0;
|
|
}
|
|
</style>
|