import React from 'react' import * as d3 from 'd3' class TimelineCategories extends React.Component { constructor (props) { super(props) this.grabRef = React.createRef() this.state = { isInitialized: false } } componentDidUpdate () { if (!this.state.isInitialized) { const drag = d3.drag() .on('start', this.props.onDragStart) .on('drag', this.props.onDrag) .on('end', this.props.onDragEnd) d3.select(this.grabRef.current) .call(drag) this.setState({ isInitialized: true }) } } renderCategory (category, idx) { const dims = this.props.dims const strokeWidth = dims.trackHeight / (this.props.categories.length + 1) return ( {category.category} ) } render () { const { dims } = this.props return ( {this.props.categories.map((cat, idx) => this.renderCategory(cat, idx))} ) } } export default TimelineCategories