Academy / docs /advanced-development /creating-custom-node.mdx
kortique's picture
add locale settings to all pages "advanced development"
e525cad
---
sidebar_position: 1
---
# Creating Custom Nodes
Creating custom nodes allows you to bypass limitations associated with Piper's standard node library, or even simply improve the functionality of current nodes.
Let's create a custom **Merge text to JSON** node that takes multiple text strings and combines them into a single JSON array.
## **1. Loading a Node from the Node Library**
To create a custom node, start by loading an existing node that's closest to your requirements. Navigate to the node library using the **plus (+)** icon in the top left corner of the pipeline workspace and select the **Input Text** node for modification, since it has minimal code and works with strings.
After adding the node, open its settings.
![Node Settings Panel](../img/create-node-1.png)
The settings panel includes several tabs:
- **Inputs** - Current node parameters, their configuration, image loading
- **Design** - Creating input and output parameters, defining their properties
- **Script** - Editing JavaScript code, node logic
- **Environment** - Configure environment variables
- **Catalog** - View node metadata and publish it
- **YAML** - Access the node's YAML
## **2. Node Configuration**
Customization begins in the **Design** tab, where the node structure is defined.
![Design Tab](../img/create-node-2.png)
### Basic Properties
- **ID** - Internal name used in code (lowercase Latin letters, no spaces)
- **Title** - Display name visible to the user
For our node, the previous values need to be replaced with:
- ID: `merge_text_to_json`
- Title: `Merge text to JSON`
### Adding Input Parameters
Our node needs 4 string inputs. To add a new input:
1. Expand the **Inputs** hamburger menu
2. Enter the new input name: `string1`
3. Click **Add**
![Adding New Input Parameter](../img/create-node-3.png)
Configure the input parameters:
- **Type**: string (i.e., text)
- **Title**: String 1 (name displayed on the node)
![Configuring Input Properties](../img/create-node-4.png)
Repeat this process to create inputs `string2`, `string3`, and `string4`.
To remove the previous input parameter `input_text`, uncheck it in the Inputs menu.
![Removing Original Input](../img/create-node-5.png)
If no visual changes occur, you need to temporarily open another tab and then return to Design.
### Advanced Input Parameter Settings
Access to detailed settings is opened through the hamburger menu.
![Input Parameter Settings Dropdown Menu](../img/create-node-6.png)
Available options include:
- **Order** (number) - Sets the order of inputs in the node
- **Description** (text) - Tooltip text for the parameter
- **Required** (boolean) - True makes the parameter mandatory
- **Group** (text) - Groups related settings
- **Enum** (text) - Creates dropdown lists with predefined values
- **Multiline** (boolean) - Expands String fields for long text
- **Min, Max** (number) - Sets constraints for Integer fields
- **Step** (number) - Converts Integer field to slider with step equal to Step value
- **Default** - Sets default values
- **Placeholder** (text) - Shows hints in empty String fields
- **Schema** - Technical field for scripts
- **Extensions** (text) - Adds special functionality (e.g., draw-mask for setting masks on uploaded images)
![Example Extension Configuration](../img/create-node-7.png)
### Configuring Output Parameters
Create an output parameter. To do this, delete the previous output `output_text` and add a new `json_output` with the following parameters:
- **Type**: JSON
- **Title**: JSON
The final Design window should look something like this:
![Edited Design Tab](../img/create-node-8.png)
:::tip Tip
Monitor your changes in the **Inputs** tab to see how modifications affect the node structure.
:::
The next step - writing the node's script logic, is covered in the **Node Script Tab** section.