blob: 4691b84155f20f6d27d3002db7c50ee794601b8f [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { ref, onMounted, watch } from 'vue'
import { useLogHeight } from '@/hooks'
import { useFileStore } from '@/store/file'
export function useLogOpen() {
const logRef = ref()
let logWindow: Window | null = null
const { toggleFloatingLogHeight } = useLogHeight()
const fileStore = useFileStore()
const onMessage = (ev: MessageEvent) => {
const { type } = ev.data
if (type === 'close') {
closeWindow()
}
}
const openNewWindow = () => {
logWindow = window.open(`/log`, '_blank')
if (!logWindow) return
logWindow.addEventListener('load', () => {
postLog(fileStore.getCurrentFile?.log || '')
})
}
const postLog = (value: string) => {
window.postMessage({
type: 'log',
data: value
})
}
const closeWindow = () => {
toggleFloatingLogHeight(false)
logWindow = null
}
const onDragEnd = (ev: DragEvent) => {
if (
ev.clientX > window.innerWidth - 50 ||
ev.clientY > window.innerHeight - 50 ||
ev.clientX < 50 ||
ev.clientY < 50
) {
if (logWindow) {
logWindow.focus()
} else {
openNewWindow()
}
toggleFloatingLogHeight(true)
}
}
watch(
() => fileStore.getCurrentFile?.log,
(value) => {
postLog(value || '')
}
)
onMounted(() => {
logRef.value.addEventListener('dragend', onDragEnd)
window.addEventListener('message', onMessage)
})
return { logRef }
}