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
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>
26 lines
796 B
JavaScript
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
|
|
}
|
|
}
|