@logicflow/react-node-registry
Version:
LogicFlow React Shape
65 lines (55 loc) • 1.49 kB
text/typescript
import LogicFlow, { HtmlNodeModel, IHtmlNodeProperties } from '@logicflow/core'
import { cloneDeep } from 'lodash-es'
export interface ReactCustomProperties extends IHtmlNodeProperties {
// 形状属性
width?: number
height?: number
radius?: number
// 文字位置属性
refX?: number
refY?: number
// 样式属性
style?: LogicFlow.CommonTheme
textStyle?: LogicFlow.TextNodeTheme
}
export class ReactNodeModel<
P extends ReactCustomProperties = ReactCustomProperties,
> extends HtmlNodeModel<P> {
setAttributes() {
const { width, height, radius } = this.properties
if (width) {
this.width = width
}
if (height) {
this.height = height
}
if (radius) {
this.radius = radius
}
}
getTextStyle(): LogicFlow.TextNodeTheme {
// const { x, y, width, height } = this
const { refX = 0, refY = 0, textStyle } = this.properties
const style = super.getTextStyle()
// 通过 transform 重新设置 text 的位置
return {
...style,
...(cloneDeep(textStyle) || {}),
transform: `matrix(1 0 0 1 ${refX} ${refY})`,
}
}
getNodeStyle(): LogicFlow.CommonTheme {
const style = super.getNodeStyle()
const {
style: customNodeStyle,
// radius = 0, // 第二种方式,设置圆角
} = this.properties
return {
...style,
...(cloneDeep(customNodeStyle) || {}),
// rx: radius,
// ry: radius,
}
}
}
export default ReactNodeModel