import { ref, reactive } from 'https://cdnjs.cloudflare.com/ajax/libs/vue/3.0.2/vue.esm-browser.js'; const ModalContainer = { template: ` .modal { display: none; } .modal-backdrop { z-index: 0; background: rgba(0, 0, 0, 0.4); } /* vueのtransitionを使わないなら不要 */ .fade-enter-active, .fade-leave-active { transition: opacity .15s; } .fade-enter, .fade-leave-to { opacity: 0; } × {{ title }} Modal body text goes here. `, props: { enableBackdrop: { type: Boolean, default: true }, title: { type: String, default: '' }, size: { type: String, default: 'modal-sm' } }, setup(props, context) { const visible = ref(false) const display_mode = reactive({display: 'none'}) let scrollbarWidth = 0; let orgBodyPaddingRight = 0; // let orgBodyPosition = 'relative'; function show() { scrollbarWidth = window.innerWidth - document.body.clientWidth; orgBodyPaddingRight = document.body.style.paddingRight; // orgBodyPosition = document.body.style.position; // document.body.style.position = 'fixed'; if (scrollbarWidth ) { document.body.style.paddingRight = `${scrollbarWidth }px`; } // document.body.style.position = 'fix'; document.body.style.height = '100vh'; document.body.style.overflowY = 'hidden'; visible.value = true; display_mode.display = 'block'; } function hide(event) { if (event && event.target.classList.contains('modal-backdrop') && !props.enableBackdrop) return; if (scrollbarWidth ) { document.body.style.paddingRight = orgBodyPaddingRight; } // document.body.style.position = orgBodyPosition; document.body.style.height = 'auto'; document.body.style.overflowY = 'auto'; visible.value = false; display_mode.display = 'none'; } return { visible, display_mode, show, hide } } }; export default ModalContainer;
Modal body text goes here.