naive-ui/packages/mixins/zindexable.js

41 lines
928 B
JavaScript

import zIndexManager from '../utils/dom/zIndexManager'
/**
* watch active on component,
* acquire new z-index on content when active is set to true
*
* dependency:
* $refs.contentContainer
* $vm.active
* $vm.detached
*/
export default {
mounted () {
if (!this.detached) return
zIndexManager.registerElement(this._getZindexableContent())
},
watch: {
active (newActive) {
if (!this.detached) return
console.debug('[zindexable.watch.active]:', newActive)
if (newActive) {
zIndexManager.setNewZIndex(this._getZindexableContent())
}
}
},
beforeDestroy () {
if (!this.detached) return
zIndexManager.unregisterElement(this._getZindexableContent())
},
methods: {
_getZindexableContent () {
if (this.$refs.contentContainer) {
return this.$refs.contentContainer
} else {
return this.getZindexableContent()
}
}
}
}