2024-08-19 23:12:58 +02:00

3.9 KiB

Lollms Flow

Lollms Flow is a powerful JavaScript library for building and visualizing workflows of execution. It provides an intuitive way to create, connect, and manage nodes in a workflow, as well as visualize and interact with the workflow through a drag-and-drop interface.

Features

  • Create custom workflow nodes with inputs and outputs
  • Connect nodes to form complex workflows
  • Visualize workflows with an interactive SVG-based interface
  • Drag-and-drop functionality for easy node positioning
  • Save and load workflows to/from JSON
  • Execute workflows and obtain results
  • Integration with local storage for persistent workflows
  • Customizable node operations

Installation

For Lollms Users

If you're using Lollms with the server running, you can include Lollms Flow directly in your HTML:

<script src="/lollms_assets/js/lollms_flow"></script>

For Non-Lollms Users

If you're not using Lollms or need to specify the full server path:

<script src="http://localhost:9600/lollms_assets/js/lollms_flow"></script>

Note: Make sure to activate the server of the app in Lollms, or the CORS policy may prevent access.

Usage

  1. Create a container for the workflow in your HTML:
<div id="workflow-container"></div>
  1. Initialize the WorkflowVisualizer:
const visualizer = new WorkflowVisualizer("workflow-container");
  1. Define node operations:
const nodeOperations = {
    "Add": (inputs) => ({ sum: inputs.a + inputs.b }),
    "Multiply": (inputs) => ({ product: inputs.x * inputs.y }),
    "Output": (inputs) => console.log("Result:", inputs.result)
};
  1. Create and add nodes:
const addNode = new WorkflowNode(0, "Add", [
    { name: "a", type: "number" },
    { name: "b", type: "number" }
], [
    { name: "sum", type: "number" }
], nodeOperations["Add"], 50, 50);

visualizer.addNode(addNode);
  1. Connect nodes:
visualizer.connectNodes(0, 0, 1, 0);
  1. Execute the workflow:
const results = visualizer.execute();
console.log(results);

API Reference

WorkflowNode

Constructor: WorkflowNode(id, name, inputs, outputs, operation, x = 0, y = 0)

Methods:

  • connect(outputIndex, targetNode, inputIndex)
  • execute(inputs)
  • toJSON()
  • static fromJSON(json, operation)

Workflow

Constructor: Workflow()

Methods:

  • addNode(node)
  • connectNodes(sourceId, sourceOutput, targetId, targetInput)
  • canConnect(sourceNode, sourceOutput, targetNode, targetInput)
  • execute()
  • toJSON()
  • static fromJSON(json, nodeOperations)

WorkflowVisualizer

Constructor: WorkflowVisualizer(containerId)

Methods:

  • addNode(node)
  • connectNodes(sourceId, sourceOutput, targetId, targetInput)
  • execute()
  • saveToJSON()
  • loadFromJSON(json, nodeOperations)
  • saveToLocalStorage(key)
  • loadFromLocalStorage(key, nodeOperations)
  • redraw()

Example

const visualizer = new WorkflowVisualizer("workflow-container");

const addNode = new WorkflowNode(0, "Add", [
    { name: "a", type: "number" },
    { name: "b", type: "number" }
], [
    { name: "sum", type: "number" }
], nodeOperations["Add"], 50, 50);

const multiplyNode = new WorkflowNode(1, "Multiply", [
    { name: "x", type: "number" },
    { name: "y", type: "number" }
], [
    { name: "product", type: "number" }
], nodeOperations["Multiply"], 250, 50);

const outputNode = new WorkflowNode(2, "Output", [
    { name: "result", type: "number" }
], [], nodeOperations["Output"], 450, 50);

visualizer.addNode(addNode);
visualizer.addNode(multiplyNode);
visualizer.addNode(outputNode);

visualizer.connectNodes(0, 0, 1, 0);
visualizer.connectNodes(1, 0, 2, 0);

const results = visualizer.execute();
console.log(results);

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License.