import { createApp } from 'vue' import { createRouter, createWebHistory } from 'vue-router' import App from './index.vue' import Demo from './Demo.vue' import { demos } from '@demos' import 'iframe-resizer/js/iframeResizer.contentWindow' import iframeResize from 'iframe-resizer/js/iframeResizer' import './style.css' const routes = demos .map(({ name, tabs }) => { return { path: `/${name}`, component: Demo, props: { name, tabs, }, } }) const router = createRouter({ history: createWebHistory('preview'), routes, }) createApp(App) .directive('resize', { beforeMount: (el, { value = {} }) => { el.addEventListener('load', () => { iframeResize({ ...value, // messageCallback(messageData) { // if (messageData.message.type !== 'resize') { // return // } // const style = window.getComputedStyle(el.parentElement) // const maxHeight = parseInt(style.getPropertyValue('max-height'), 10) // if (messageData.message.height > maxHeight) { // el.setAttribute('scrolling', 'auto') // } else { // el.setAttribute('scrolling', 'no') // } // el?.iFrameResizer?.resize?.() // }, }, el) }) }, unmounted(el) { el?.iFrameResizer?.removeListeners?.() }, }) .use(router) .mount('#app')