react-planner-viewer
Version:
react-planner-viewer is a React Component for view plans builded with react-planner in 2D mode
82 lines (69 loc) • 2.32 kB
JSX
import React from 'react';
import path from 'path';
export default {
name: 'access',
prototype: 'holes',
info: {
tag: ['access'],
group: 'access',
title: 'access',
description: 'hole in the wall',
image: require('./gate.png')
},
properties: {
width: {
label: 'width',
type: 'length-measure',
defaultValue: {
length: 80
}
},
gate: {
label: 'gate',
type: 'string',
selectAreas: true,
defaultValue: "none",
},
source: {
label: 'source',
type: 'string',
defaultValue: "none",
},
target: {
label: 'target',
type: 'string',
defaultValue: "none",
},
},
render2D: function (element, layer, scene) {
const STYLE_HOLE_BASE = { stroke: '#000', strokeWidth: '3px', fill: '#000' };
const STYLE_HOLE_SELECTED = { stroke: '#0096fd', strokeWidth: '4px', fill: '#0096fd', cursor: 'move' };
const STYLE_ARC_BASE = { stroke: '#000', strokeWidth: '3px', strokeDasharray: '5,5', fill: 'none' };
const STYLE_ARC_SELECTED = {
stroke: '#0096fd',
strokeWidth: '4px',
strokeDasharray: '5,5',
fill: 'none',
cursor: 'move'
};
let epsilon = 3;
let holeWidth = element.properties.get('width').get('length');
let holePath = `M${0} ${-epsilon} L${holeWidth} ${-epsilon} L${holeWidth} ${epsilon} L${0} ${epsilon} z`;
let arcPath = `M${0},${0} A${0},${0} 0 0,1 ${holeWidth},${0}`;
let holeStyle = element.selected ? STYLE_HOLE_SELECTED : STYLE_HOLE_BASE;
let arcStyle = element.selected ? STYLE_ARC_SELECTED : STYLE_ARC_BASE;
let length = element.properties.get('width').get('length');
return (
<g transform={`translate(${-length / 2}, 0)`}>
<text x="0" y="0" transform={`scale(1, -1)`} style={STYLE_TEXT}>
{element.getIn(['properties', 'gate'])}
</text>
<line key='1' x1={0} y1={holeWidth / 6 - epsilon} x2={0} y2={-holeWidth / 6 + epsilon} style={holeStyle}
transform={`scale(${-1},${1})`} />
<line key='2' x1={-holeWidth} y1={holeWidth / 6 - epsilon} x2={-holeWidth} y2={-holeWidth / 6 + epsilon} style={holeStyle}
transform={`scale(${-1},${1})`} />
<path key='3' d={arcPath} style={arcStyle} />
</g>
)
},
}