gradientStepComponent.tsx 2.5 KB

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