Skip to content

Latest commit

 

History

History
100 lines (85 loc) · 3.48 KB

File metadata and controls

100 lines (85 loc) · 3.48 KB

Able Interface

export interface Able<Props extends IObject<any> = IObject<any>, Events extends IObject<any> = IObject<any>> {
    name: string;
    props: { [key in keyof Props]: any };
    events: { [key in keyof Events]: string };
    // Whether to always include in able. It is recommended to use always in frameworks other than react
    always?: boolean;
    ableGroup?: string;
    updateRect?: boolean;
    canPinch?: boolean;
    css?: string[];
    // Fired when the event is cleared
    unset?: (moveable: any) => any;
    // Renders the React DOM structure for the able.
    render?: (moveable: any, renderer: Renderer) => any;

    // Operates when a drag event occurs for the single target.
    dragStart?: (moveable: any, e: GestoTypes.OnDragStart) => any;
    drag?: (moveable: any, e: GestoTypes.OnDrag) => any;
    dragEnd?: (moveable: any, e: GestoTypes.OnDragEnd) => any;

    // Operates when a pinch event occurs for the single target.
    pinchStart?: (moveable: any, e: GestoTypes.OnPinchStart) => any;
    pinch?: (moveable: any, e: GestoTypes.OnPinch) => any;
    pinchEnd?: (moveable: any, e: GestoTypes.OnPinchEnd) => any;

    // Condition that occurs dragControl
    dragControlCondition?: (target: SVGElement | HTMLElement) => boolean;
    // Operates when a drag event occurs for the moveable control and single target.
    dragControlStart?: (moveable: any, e: GestoTypes.OnDragStart) => any;
    dragControl?: (moveable: any, e: GestoTypes.OnDrag) => any;
    dragControlEnd?: (moveable: any, e: GestoTypes.OnDragEnd) => any;

    // Condition that occurs dragGroup
    dragGroupCondition?: (e: any) => boolean;
    // Operates when a drag event occurs for the multi target.
    dragGroupStart?: (moveable: any, e: GestoTypes.OnDragStart) => any;
    dragGroup?: (moveable: any, e: GestoTypes.OnDrag) => any;
    dragGroupEnd?: (moveable: any, e: GestoTypes.OnDragEnd) => any;

    // Operates when a pinch event occurs for the multi target.
    pinchGroupStart?: (moveable: any, e: GestoTypes.OnPinchStart) => any;
    pinchGroup?: (moveable: any, e: GestoTypes.OnPinch) => any;
    pinchGroupEnd?: (moveable: any, e: GestoTypes.OnPinchEnd) => any;

    // Condition that occurs dragGroupControl
    dragGroupControlCondition?: (e: any) => boolean;
    // Operates when a drag event occurs for the moveable control and multi target.
    dragGroupControlStart?: (moveable: any, e: GestoTypes.OnDragStart) => any;
    dragGroupControl?: (moveable: any, e: GestoTypes.OnDragStart) => any;
    dragGroupControlEnd?: (moveable: any, e: GestoTypes.OnDragEnd) => any;

    // Execute the operation of able for external request
    request?: (moveable: any) => AbleRequester;
}

Example

import Moveable, { MoveableManagerInterface, Renderer } from "react-moveable";

interface CustomAbleProps {
    customAble: boolean;
    prop1: number;
}
const CustomAble = {
    name: "customAble",
    props: [
        "customAble",
        "prop1",
    ],
    events: [],
    render(moveable: MoveableManagerInterface<CustomAbleProps>, React: Renderer) {
        const CustomElement = React.useCSS("div", `
        {
            position: absolute;
        }
        `);
        console.log(moveable.props.prop1);

        // Add key (required)
        // Add class prefix moveable-(required)
        return <CustomElement key="custom-element" className="moveable-custom">
        </CustomElement>;
    },
}

<Moveable
    ables={[CustomAble]}
    props={{
        customAble: true,
        prop1: 3,
    }}
    />