gradientStepComponent.tsx 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. onCheckForReOrder: () => void;
  14. }
  15. export class GradientStepComponent extends React.Component<IGradientStepComponentProps, {gradient: number}> {
  16. constructor(props: IGradientStepComponentProps) {
  17. super(props);
  18. this.state={gradient: props.step.step};
  19. }
  20. updateColor(color: string) {
  21. this.props.step.color = Color3.FromHexString(color);
  22. this.props.onUpdateStep();
  23. this.forceUpdate();
  24. }
  25. updateStep(gradient: number) {
  26. this.props.step.step = gradient;
  27. this.setState({gradient: gradient});
  28. this.props.onUpdateStep();
  29. }
  30. onPointerUp() {
  31. this.props.onCheckForReOrder();
  32. }
  33. render() {
  34. let step = this.props.step;
  35. return (
  36. <div className="gradient-step">
  37. <div className="step">
  38. {`#${this.props.lineIndex}`}
  39. </div>
  40. <input type="color" value={step.color.toHexString()} onChange={(evt) => this.updateColor(evt.target.value)} />
  41. <div className="step-value">
  42. {step.step.toFixed(2)}
  43. </div>
  44. <div className="step-slider">
  45. <input className="range" type="range" step={0.01} min={0} max={1.0} value={step.step}
  46. onPointerUp={evt => this.onPointerUp()}
  47. onChange={evt => this.updateStep(parseFloat(evt.target.value))} />
  48. </div>
  49. <div className="gradient-delete" onClick={() => this.props.onDelete()}>
  50. <FontAwesomeIcon icon={faTrash} />
  51. </div>
  52. </div>
  53. )
  54. }
  55. }