UNPKG

@antv/x6

Version:

JavaScript diagramming library that uses SVG and HTML for rendering

38 lines (33 loc) 741 B
import { Path } from '../../geometry' import type { SimpleAttrs } from '../attr' import type { MarkerFactory } from './index' import { normalize } from './util' export interface DiamondMarkerOptions extends SimpleAttrs { size?: number width?: number height?: number offset?: number } export const diamond: MarkerFactory<DiamondMarkerOptions> = ({ size, width, height, offset, ...attrs }) => { const s = size || 10 const w = width || s const h = height || s const path = new Path() path .moveTo(0, h / 2) .lineTo(w / 2, 0) .lineTo(w, h / 2) .lineTo(w / 2, h) .close() return { ...attrs, tagName: 'path', d: normalize(path.serialize(), offset == null ? -w / 2 : offset), } }