Компонент React Animation не будет обновляться

Я использую оболочку React для библиотеки анимации anime.js и пытаюсь создать приложение, которое принимает пользовательский ввод, а затем анимирует div на основе ввода

(Картинка для наглядности)

Он начинается с простого подвижного квадрата, но после нажатия кнопки "Анимация" он обновляется до того, что ввел пользователь.

Однако, когда я нажимаю кнопку анимации, div просто полностью исчезает, а если я нажимаю на нее второй раз, весь родительский компонент и все исчезают! Это оставляет меня с этим сообщением об ошибке, однако в консоли.

Я провел тестирование, и реквизиты передаются объекту outputDivProps в AnimationOutput.jsx, и они верны, но div просто не обновляется должным образом.

Родительский компонент (Animation.jsx)

Компоненты AnimationForm.jsx & AnimationOutput.jsx

import React, {Component} from 'react';
import {Segment} from 'semantic-ui-react';

import AnimationForm from './AnimationForm.jsx';
import AnimationOutput from './AnimationOutput.jsx';
import BoxChanger from './BoxChanger.jsx';

export default class Animation extends Component {
  constructor(props) {
    super(props);

    this.state = {
        boxColor: 'white',
        boxShape: 'square',
        boxDiration: 3,
        boxTranslate: '50vw',
        boxEasing: 'linear',
        boxDelay: 0
    };
  }

  updateAni = (boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay) => {
    console.log('updateAni: ' + boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay);

    this.setState({
      boxColor: boxColor,
      boxShape: boxShape,
      boxDiration: boxDiration,
      boxTranslate: boxTranslate,
      boxEasing: boxEasing,
      boxDelay: boxDelay
    });
  }

  render() {
    const {boxColor, boxShape, boxDiration, boxTranslate, boxEasing, boxDelay} = this.state;

    return (<Segment inverted>
      <h2>Animation Creator!</h2>

      <AnimationForm aniUpdate={this.updateAni}/>
      <h3>Box Animations!</h3>
      <AnimationOutput boxColor={boxColor} boxShape={boxShape} boxDiration={boxDiration * 1000} boxTranslate={boxTranslate} boxEasing={boxEasing} boxDelay={boxDelay * 1000}/>
      <BoxChanger/>
    </Segment>
  );
  }
}

Компонент формы (AnimationForm.jsx)

import React, {Component} from 'react';
import {Form, Input, Button, Select, Radio} from 'semantic-ui-react';

export default class AnimationForm extends Component {
  state = {
    boxColorValue: '',
    boxShapeValue: '',
    boxDirationValue: '',
    boxTranslateValue: '',
    boxEasingValue: '',
    boxDelayValue: ''
  };

  handleChange = (e, {name, value}) => this.setState({[name]: value});

  handleSubmit = () => {
    const {boxColorValue, boxShapeValue, boxDirationValue, boxTranslateValue, boxEasingValue, boxDelayValue} = this.state;
    this.props.aniUpdate(boxColorValue, boxShapeValue, boxDirationValue, boxTranslateValue, boxEasingValue, boxDelayValue);
  }

  render() {

    const {boxColorValue, boxDirationValue, boxTranslateValue, boxDelayValue} = this.state;

    const options = [/* Options for dropdown */]

    return (<Form inverted className='box-animation-form' size={'big'}>
      <Form.Group widths='equal'>
        <Form.Field control={Input} name='boxColorValue' value={boxColorValue} label='Color' placeholder='exp. #ffffff or white' onChange={this.handleChange}/>
        <Form.Field control={Input} name='boxDirationValue' value={boxDirationValue} label='Diration' placeholder='exp. 2 or 5 (seconds)' onChange={this.handleChange}/>
        <Form.Field control={Select} name='boxEasingValue' label='Transition Type' value={options.value} options={options} placeholder='Types' onChange={this.handleChange}/>
      </Form.Group>
      <Form.Group inline>
        <label>Shape</label>
        <Form.Field control={Radio} label='Square' checked={this.state.boxShapeValue === 'square'} onClick={() => this.setState({boxShapeValue: 'square'})}/>
        <Form.Field control={Radio} label='Circle' checked={this.state.boxShapeValue === 'circle'} onClick={() => this.setState({boxShapeValue: 'circle'})}/>
        <Form.Field control={Radio} label='Triangle' checked={this.state.boxShapeValue === 'triangle'} onClick={() => this.setState({boxShapeValue: 'triangle'})}/>
      </Form.Group>
      <Form.Group widths='equal'>
        <Form.Field control={Input} name='boxTranslateValue' value={boxTranslateValue} label='Want it to move?' placeholder='exp. 200 or 200px' onChange={this.handleChange}/>
        <Form.Field control={Input} name='boxDelayValue' value={boxDelayValue} label='Delay' placeholder='exp. 1 or 2 (seconds)' onChange={this.handleChange}/>
      </Form.Group>
      <Button inverted color='green' onClick={this.handleSubmit}>Animate!</Button>
    </Form>);
  }
}

Компонент анимационного блока (AnimationOutput.jsx)

-Я думаю, что проблема здесь!

import React from 'react';
import Anime from 'react-anime';

const AnimationOutput = (props) => {
console.log('AnimationOutput: ' + props.boxColor, props.boxShape, props.boxDiration, props.boxTranslate, props.boxEasing, props.boxDelay);

  let outputDivProps = {
    easing: 'linear',
    loop: true,
    direction: 'alternate',
    duration: props.boxDiration,
    translateX: props.boxTranslate
  };

  let outputDivStyle = {
    width: 100,
    height: 100,
    backgroundColor: props.boxColor
  };

console.log(outputDivProps)

  return (<div className='animation-output-box'>
    <Anime {...outputDivProps}>
      <div style={outputDivStyle}></div>
    </Anime>
  </div>);
}

export default AnimationOutput;

0 ответов

Другие вопросы по тегам