Files
ComfyUI/custom_nodes/ComfyUI-KJNodes/web/js/protovisUtil.js
jaidaken f09734b0ee
Some checks failed
Python Linting / Run Ruff (push) Has been cancelled
Python Linting / Run Pylint (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.10, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.11, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-stable (12.1, , linux, 3.12, [self-hosted Linux], stable) (push) Has been cancelled
Full Comfy CI Workflow Runs / test-unix-nightly (12.1, , linux, 3.11, [self-hosted Linux], nightly) (push) Has been cancelled
Execution Tests / test (macos-latest) (push) Has been cancelled
Execution Tests / test (ubuntu-latest) (push) Has been cancelled
Execution Tests / test (windows-latest) (push) Has been cancelled
Test server launches without errors / test (push) Has been cancelled
Unit Tests / test (macos-latest) (push) Has been cancelled
Unit Tests / test (ubuntu-latest) (push) Has been cancelled
Unit Tests / test (windows-2022) (push) Has been cancelled
Add custom nodes, Civitai loras (LFS), and vast.ai setup script
Includes 30 custom nodes committed directly, 7 Civitai-exclusive
loras stored via Git LFS, and a setup script that installs all
dependencies and downloads HuggingFace-hosted models on vast.ai.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-09 00:56:42 +00:00

26 lines
796 B
JavaScript

/**
* Utility functions for protovis in ComfyUI.
*/
/**
* Get correct local coordinates for protovis in transformed containers.
* Uses getBoundingClientRect() which properly accounts for CSS transforms.
*
* This fixes coordinate calculation issues when protovis widgets are rendered
* inside ComfyUI's vueNodes mode, which uses CSS transforms for panning/zooming.
*
* @param {pv.Mark} mark - The protovis mark instance
* @returns {{x: number, y: number}} Local coordinates relative to the canvas
*/
export function getLocalMouse(mark) {
const e = pv.event
if (!e) return { x: 0, y: 0 }
const canvas = mark.root.canvas()
if (!canvas) return { x: 0, y: 0 }
const rect = canvas.getBoundingClientRect()
return {
x: e.clientX - rect.left,
y: e.clientY - rect.top
}
}