jellyflow-runtime 0.2.0

Headless store, rules, schema, profile, and change pipeline for Jellyflow.
Documentation
use crate::io::NodeGraphPanOnDragButtons;
use crate::runtime::drag::{
    PointerGestureClaim, PointerGestureClaimInput, resolve_pointer_gesture_claim,
};
use crate::runtime::selection::{
    SelectionPointerClaim, SelectionPointerClaimInput, resolve_selection_pointer_claim,
};

use super::types::{ViewportGestureContext, ViewportPointerButton};

const XYFLOW_ACTIVATION_PAN_ON_DRAG: NodeGraphPanOnDragButtons = NodeGraphPanOnDragButtons {
    left: true,
    middle: true,
    right: false,
};

pub(super) fn effective_pan_on_drag_buttons(
    buttons: NodeGraphPanOnDragButtons,
    context: ViewportGestureContext,
) -> NodeGraphPanOnDragButtons {
    if context.selection_key_pressed {
        NodeGraphPanOnDragButtons::default()
    } else if context.pan_activation_key_pressed {
        XYFLOW_ACTIVATION_PAN_ON_DRAG
    } else {
        buttons
    }
}

pub(super) fn effective_pan_on_scroll_enabled(
    pan_on_scroll: bool,
    context: ViewportGestureContext,
) -> bool {
    pan_on_scroll || context.pan_activation_key_pressed
}

pub(super) fn selection_modifier_claims_drag(context: ViewportGestureContext) -> bool {
    resolve_selection_pointer_claim(SelectionPointerClaimInput::new(
        jellyflow_core::core::CanvasPoint { x: 0.1, y: 0.0 },
        0.0,
        context.selection_key_pressed,
        context.user_selection_active,
    )) == SelectionPointerClaim::SelectionMayClaimDrag
}

pub(super) fn pointer_drag_claim(context: ViewportGestureContext) -> PointerGestureClaim {
    if context.user_selection_active {
        return PointerGestureClaim::Selection;
    }

    let claim = resolve_pointer_gesture_claim(PointerGestureClaimInput::new(
        jellyflow_core::core::CanvasPoint { x: 0.1, y: 0.0 },
        context.selection_key_pressed,
        false,
        context.connection_in_progress,
        0.0,
        f32::INFINITY,
    ));

    if claim == PointerGestureClaim::Selection && !selection_modifier_claims_drag(context) {
        PointerGestureClaim::None
    } else {
        claim
    }
}

pub(super) fn pan_on_drag_enabled(buttons: NodeGraphPanOnDragButtons) -> bool {
    buttons.left || buttons.middle || buttons.right
}

pub(super) fn pan_button_allowed(
    buttons: NodeGraphPanOnDragButtons,
    button: ViewportPointerButton,
) -> bool {
    match button {
        ViewportPointerButton::Left => buttons.left,
        ViewportPointerButton::Middle => buttons.middle,
        ViewportPointerButton::Right => buttons.right,
        ViewportPointerButton::Other => false,
    }
}