mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-20 14:30:41 +00:00
- Allow dragging zoom pane with middle click - Prevent selection of canvasOnly widgets - These widgets would not display in app mode, so allow selection would only cause confusion. - Support displaying the error dialogue in app mode - Add a somewhat involved mobile app mode error indication system <img width="300" alt="image" src="https://github.com/user-attachments/assets/d8793bbd-fff5-4b2a-a316-6ff154bae2c4" /> <img width="300" alt="image" src="https://github.com/user-attachments/assets/cb88b0f6-f7e5-409e-ae43-f1348f946b19" /> ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-9617-Even-further-app-fixes-31d6d73d365081c891dfdfe3477cfd61) by [Unito](https://www.unito.io)
61 lines
1.6 KiB
Vue
61 lines
1.6 KiB
Vue
<script setup lang="ts">
|
|
import { computed, ref, useTemplateRef } from 'vue'
|
|
|
|
const zoomPane = useTemplateRef('zoomPane')
|
|
|
|
const zoom = ref(1.0)
|
|
const panX = ref(0.0)
|
|
const panY = ref(0.0)
|
|
|
|
function handleWheel(e: WheelEvent) {
|
|
const zoomPaneEl = zoomPane.value
|
|
if (!zoomPaneEl || (e.deltaY < 0 ? zoom.value > 1200 : zoom.value < -500))
|
|
return
|
|
|
|
zoom.value -= e.deltaY
|
|
const { x, y, width, height } = zoomPaneEl.getBoundingClientRect()
|
|
const offsetX = e.clientX - x - width / 2
|
|
const offsetY = e.clientY - y - height / 2
|
|
const scaler = 1.1 ** (e.deltaY / -30)
|
|
|
|
panY.value = panY.value * scaler - offsetY * (scaler - 1)
|
|
panX.value = panX.value * scaler - offsetX * (scaler - 1)
|
|
}
|
|
|
|
let dragging = false
|
|
function handleDown(e: PointerEvent) {
|
|
if (e.button !== 0 && e.button !== 1) return
|
|
|
|
const zoomPaneEl = zoomPane.value
|
|
if (!zoomPaneEl) return
|
|
zoomPaneEl.parentElement?.focus()
|
|
|
|
zoomPaneEl.setPointerCapture(e.pointerId)
|
|
dragging = true
|
|
}
|
|
function handleMove(e: PointerEvent) {
|
|
if (!dragging) return
|
|
panX.value += e.movementX
|
|
panY.value += e.movementY
|
|
}
|
|
|
|
const transform = computed(() => {
|
|
const scale = 1.1 ** (zoom.value / 30)
|
|
const matrix = [scale, 0, 0, scale, panX.value, panY.value]
|
|
return `matrix(${matrix.join(',')})`
|
|
})
|
|
</script>
|
|
<template>
|
|
<div
|
|
ref="zoomPane"
|
|
class="place-content-center contain-size"
|
|
@wheel="handleWheel"
|
|
@pointerdown.prevent="handleDown"
|
|
@pointermove="handleMove"
|
|
@pointerup="dragging = false"
|
|
@pointercancel="dragging = false"
|
|
>
|
|
<slot :style="{ transform }" />
|
|
</div>
|
|
</template>
|