gradientStepComponent.tsx 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import * as React from 'react';
  2. import { GlobalState } from '../../../globalState';
  3. import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
  4. import { faTrash } from '@fortawesome/free-solid-svg-icons';
  5. import { Color3 } from 'babylonjs/Maths/math.color';
  6. import { GradientBlockColorStep } from 'babylonjs/Materials/Node/Blocks/gradientBlock';
  7. interface IGradientStepComponentProps {
  8. globalState: GlobalState;
  9. step: GradientBlockColorStep;
  10. lineIndex: number;
  11. onDelete: () => void;
  12. onUpdateStep: () => void;
  13. }
  14. export class GradientStepComponent extends React.Component<IGradientStepComponentProps, {gradient: number}> {
  15. constructor(props: IGradientStepComponentProps) {
  16. super(props);
  17. this.state={gradient: props.step.step};
  18. }
  19. updateColor(color: string) {
  20. this.props.step.color = Color3.FromHexString(color);
  21. this.props.onUpdateStep();
  22. this.forceUpdate();
  23. }
  24. updateStep(gradient: number) {
  25. this.props.step.step = gradient;
  26. this.setState({gradient: gradient});
  27. this.props.onUpdateStep();
  28. }
  29. render() {
  30. let step = this.props.step;
  31. return (
  32. <div className="gradient-step">
  33. <div className="step">
  34. {`#${this.props.lineIndex}`}
  35. </div>
  36. <input type="color" value={step.color.toHexString()} onChange={(evt) => this.updateColor(evt.target.value)} />
  37. <div className="step-value">
  38. {step.step.toFixed(2)}
  39. </div>
  40. <div className="step-slider">
  41. <input className="range" type="range" step={0.01} min={0} max={1.0} value={step.step}
  42. onChange={evt => this.updateStep(parseFloat(evt.target.value))} />
  43. </div>
  44. <div className="gradient-delete" onClick={() => this.props.onDelete()}>
  45. <FontAwesomeIcon icon={faTrash} />
  46. </div>
  47. </div>
  48. )
  49. }
  50. }