g6/packages/site/docs/apis/data/NodeUserModel.en.md
2023-11-10 18:43:02 +08:00

151 lines
5.5 KiB
Markdown

---
title: NodeUserModel
order: 3
---
The data part of each node model in the user input data is explained as follows.
```typescript
interface NodeUserModel {
id: string | number;
data: NodeUserModelData;
}
```
## id
The unique ID of the node. Once the node is created, the ID cannot be changed.
- **Required**: True;
- **Type**: `string|number`;
## data
The data of the node, excluding the ID. It is recommended to store business data. If data conversion is needed, it can be done through the transform function configured in the Graph instance, see [Specification.transforms](../graph/Specification.en.md#transforms). The converted data becomes the internal data that circulates within the graph. All subsequent accesses will be based on this internal data. For rendering-related data, it can be mapped using the node mapper of the Graph instance, see [Specification.node](../graph/Specification.en.md#node) The input of this mapper is the internal data, and the generated display data is only consumed by the renderer. Users will not obtain it anywhere.
- **Required**: True;
- **Type**: [`NodeUserModelData`](#nodeusermodeldatatype);
### NodeUserModelData.type
Type: string The rendering type of the node. It can be a node type that has been registered with the graph class. Built-in and default registered types include `'circle-node'`, `'rect-node'`, and `'image-node'`.
- **Required**: False;
- **Type**: `string`;
### NodeUserModelData.x
Type: number The x-axis position of the node. If the node position is not specified and no `layout` is configured for the graph instance, the node may be rendered at the top left corner of the canvas.
- **Required**: False;
- **Type**: `number`;
### NodeUserModelData.y
The y-axis position of the node. If the node position is not specified and no `layout` is configured for the graph instance, the node may be rendered at the top left corner of the canvas.
- **Required**: False;
- **Type**: `number`;
### NodeUserModelData.z
For 2D graphs, there is no need to specify the z value. If it is specified, it may cause the node to be invisible under the WebGL renderer. In 3D graphs, the z value is required and represents the z-axis position of the node. If the node position is not specified and no `layout` is configured for the graph instance, the node may be rendered at the top left corner of the canvas.
- **Required**: False;
- **Type**: `number`;
### NodeUserModelData.visible
Whether the node is displayed by default.
- **Required**: False;
- **Type**: `boolean`;
### NodeUserModelData.color
The main color of the primary shape (keyShape) of the node, expressed as a hexadecimal string. This is provided for simple configuration. More style configurations should be done in the node mapper of the graph instance, where the keyShape and various graphic styles are configured.
- **Required**: False;
- **Type**: `string`;
### NodeUserModelData.label
The text content of the label shape of the node. This is provided for simple configuration. More style configurations should be done in the node mapper of the graph instance, where the text value of the labelShape or other graphic styles are configured.
- **Required**: False;
- **Type**: `string`;
### NodeUserModelData.badges
The configuration of the badges around the node. The possible positions `BadgePosition` are as follows. This is provided for simple configuration. More style configurations should be done in the node mapper of the graph instance, where the graphic styles of the badgeShapes are configured.
- **Required**: False;
- **Type**:
```typescript
{
position: BadgePosition,
type: 'text' | 'icon',
img?: string, // required when type is 'text'
text?: string, // required when type is 'icon'
}[];
```
```typescript
BadgePosition: 'rightTop' |
'right' |
'rightBottom' |
'bottomRight' |
'bottom' |
'bottomLeft' |
'leftBottom' |
'left' |
'leftTop' |
'topLeft' |
'top' |
'topRight';
```
### NodeUserModelData.icon
The configuration of the central icon of the node. This is provided for simple configuration. More style configurations should be done in the node mapper of the graph instance, where the graphic styles of the iconShape are configured.
- **Required**: False;
- **Type**:
```typescript
{
type: 'text' | 'icon',
img?: string, // required when type is 'text'
text?: string, // required when type is 'icon'
}
```
### NodeUserModelData.anchorPoints
The positions where the edges are connected to the node. If not configured, the edges will automatically find the nearest positions on the edge of the node for connection. For example, `[[0,0.5],[1,0.5]]`, where the numbers indicate the percentage position relative to the primary shape (keyShape) of the node in the x or y direction. This is provided for simple configuration. More style configurations should be done in the node mapper of the graph instance, where the graphic styles of the anchorShapes are configured.
- **Required**: False;
- **Type**: `number[][]`;
### NodeUserModelData.parentId
In a graph with combos, it indicates the ID of the combo to which the node belongs.
- **Required**: False;
- **Type**: `string | number`;
### NodeUserModelData.isRoot
If you want to display the data as a tree diagram and use tree layout at the same time, specify whether this node is one of the root nodes of the tree.
- **Required**: False;
- **Type**: `boolean`;
### NodeUserModelData.preventPolylineEdgeOverlap
Whether to treat this node as an obstacle and make it avoid the `'polyline-edge'` type of edges. The default value is `false`.
- **Required**: False;
- **Type**: `boolean`;