Не работает checked на слайдер в Реакте. Как адаптировать уже готовый код под React?

Есть слайдер, который написан на чистом css, в нём используется checked для переключения между input с изображением. Ранее сайт писался на чистом html + js, и все работало, но при переносе на Реакт именно эта часть работает некорректно. Переключение происходит очень криво, не с первого раза. Предполагаю, что ошибка именно в checked. Можете подсказать, как именно можно адаптировать этот код под Реакт.

#slider-photo [type="radio"] {
  display: none;
}

.carousel {
  height: 250px;
  width: 100%;
  margin: 100px 0;
}

#slider-photo {
  height: 100%;
  position: relative;
  perspective: 1000px;
  transform-style: preserve-3d;
}

#slider-photo label {
  margin: auto;
  width: 30%;
  height: 100%;
  border-radius: 15px;
  position: absolute;
  left: 0;
  right: 0;
  cursor: pointer;
  transition: transform 0.4s ease;
  overflow: hidden;
}

#slider-photo label img {
  width: 100%;
  height: 100%;
  display: block;
}

#s1-photo:checked~#slide2,
#s2-photo:checked~#slide3,
#s3-photo:checked~#slide4,
#s4-photo:checked~#slide5,
#s5-photo:checked~#slide1 {
  box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3), 0 2px 2px 0 rgba(0, 0, 0, 0.2);
  transform: translate3d(-100%, 0, -200px);
}

#s1-photo:checked~#slide3,
#s2-photo:checked~#slide4,
#s3-photo:checked~#slide5,
#s4-photo:checked~#slide1,
#s5-photo:checked~#slide2 {
  box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3), 0 2px 2px 0 rgba(0, 0, 0, 0.2);
  transform: translate3d(100%, 0, -200px);
}

#s1-photo:checked~#slide4,
#s2-photo:checked~#slide5,
#s3-photo:checked~#slide1,
#s4-photo:checked~#slide2,
#s5-photo:checked~#slide3 {
  box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3), 0 2px 2px 0 rgba(0, 0, 0, 0.2);
  transform: translate3d(150%, 0, -200px);
}

#s1-photo:checked~#slide5,
#s2-photo:checked~#slide1,
#s3-photo:checked~#slide2,
#s4-photo:checked~#slide3,
#s5-photo:checked~#slide4 {
  box-shadow: 0 6px 10px 0 rgba(0, 0, 0, 0.3), 0 2px 2px 0 rgba(0, 0, 0, 0.2);
  transform: translate3d(-150%, 0, -200px);
}

.photo__h2 {
  font-family: "Montserrat", sans-serif;
  font-size: 36px;
  line-height: 47px;
  color: #121214;
  text-align: center;
  margin-top: 80px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div className="carousel">

  <section id="slider-photo">
    <input readOnly type="radio" name="slider-photo" id="s1-photo" />
    <input readOnly type="radio" name="slider-photo" id="s2-photo" checked />
    <input readOnly type="radio" name="slider-photo" id="s3-photo" />
    <input readOnly type="radio" name="slider-photo" id="s4-photo" />
    <input readOnly type="radio" name="slider-photo" id="s5-photo" />

    <label htmlFor="s1-photo" id="slide1">
        <div className="slider-image">
            <img src={FirstPhoto} alt="photo" />
        </div>
    </label>
    <label htmlFor="s2-photo" id="slide2">
        <div className="slider-image">
            <img src={SecendPhoto} alt="photo" />
        </div>
    </label>
    <label htmlFor="s3-photo" id="slide3">
        <div className="slider-image">
            <img src={ThirdPhoto} alt="photo" />
        </div>
    </label>

    <label htmlFor="s4-photo" id="slide4">
      <div className="slider-image">
          <img src={FourPhoto} alt="qadro" />
      </div>
    </label>

    <label htmlFor="s5-photo" id="slide5">
        <div className="slider-image">
            <img src={FivePhoto} alt="qadro" />
        </div>
    </label>

  </section>
</div>

Пример как это работает без Реакта https://codepen.io/Herxagon/pen/aPPLJb.


Ответы (0 шт):