import { h, Component } from 'preact' import { connect } from 'react-redux' import { bindActionCreators } from 'redux' import * as liveActions from '../live/actions' class Select extends Component { constructor(props){ super(props) this.handleChange = this.handleChange.bind(this) } handleChange(e){ clearTimeout(this.timeout) let new_value = e.target.value this.props.actions.set_param(this.props.name, new_value) this.props.onChange && this.props.onChange(new_value) } render() { const value = this.props.opt[this.props.name] const options = (this.props.options || []).map((key,i) => { let name, value if (typeof key == 'string') { name = key.length < 4 ? key.toUpperCase() : key value = key } else { let frames = Math.round(key.count / 30) + ' s.' name = key.name.replace(/_/g, ' ') + ' (' + frames + ')' value = key.name } return ( ) }) return (