Я создал страницу воспроизведения видео, на которой есть видеопроигрыватель с информацией о видео под ним, например, кнопка «нравится / в отличие от», индекс комментариев и форма добавления комментариев. Все работает нормально, кроме div, отображающего количество лайков для конкретного видео. Как и есть разница в длине лайков между prevProps и this.props, поэтому он обновляется так, как должен, в отличие от этого, длина по какой-то причине остается той же, даже если бэкэнд обновляется соответствующим образом, а лайки никогда не получает. Есть идеи, почему он не работает?
componentDidUpdate(prevProps) {
// console.log(prevProps.likes.length, this.props.likes.length)
if (prevProps.likes.length !== this.props.likes.length) {
this.props.fetchLikes();
console.log(this.likesNumber());
} else if (prevProps.comments.length !== this.props.comments.length) {
this.props.fetchComments();
this.commentsNumber();
}
}
likesNumber() {
if (!this.props.video) return null;
const videoLikes = this.props.likes.filter(like => Object.values(like)[0].video_id == this.props.video.id);
if (videoLikes.length === 1) {
return "1 Like"
} else {
return `${videoLikes.length} Likes`
}
}
метод рендеринга
render() {
if (!this.props.video) { return null }
const users = this.props.users;
const videoLikes = this.props.likes.filter(like => Object.values(like)[0].video_id == this.props.video.id);
const videoComments = this.props.comments.filter(comment => comment.video_id == this.props.video.id);
const owner = users.filter(user => user.id === this.props.video.owner_id)[0];
if (!owner) { return null };
return (
<div id="video-container">
<video
className="video-player"
controls="controls"
src={this.props.video.video_url}
onPlay={this.playCount}
autoPlay="autoplay"
muted >
<div className="like"><Like id="like" video={this.props.video} props={this.props}/></div>
</video>
<div id="play-info">
<div className="header-like">
<h1 className="play-title">{this.props.video.video_title}</h1>
<Like video={this.props.video} props={this.props}/>
</div>
<h2 className="play-date">{this.dateCreated(this.props.video.created_at)}</h2>
<div className="owner-name-initial">
<h2 className="owner-initial">{owner.username.split("")[0]}</h2>
<h2 className="owner-name">{owner.username}</h2>
</div>
<div className="video-info">
{/* <div className="play-count">
<img src="https://img.icons8.com/windows/48/000000/play.png" />
<h2 >{this.state.count}</h2>
<div className="hidden-views">{this.playNumber()}</div>
</div> */}
<div className="likes-count">
<img src="https://img.icons8.com/windows/32/000000/like.png" />
<h2>{videoLikes.length}</h2>
<div className="hidden-likes">{this.likesNumber()}</div>
</div>
<div className="comments-count">
<img src="https://img.icons8.com/material-outlined/50/000000/topic.png" />
<h2>{videoComments.length}</h2>
<div className="hidden-comments">{this.commentsNumber()}</div>
</div>
</div>
<h2 className="play-description">{this.props.video.video_description}</h2>
</div>
<CommentIndex video={this.props.video} history={this.props.history}/>
<Comment video={this.props.video} history={this.props.history}/>
<div className="home-footer">
<h2 className="home-footer-1">@2020</h2>
<h2 className="home-footer-2">
Made with
<svg viewBox="0 0 20 20" className="_3Weix"><path d="M10 18a1.23 1.23 0 01-.8-.4 14.25 14.25 0 00-4.4-3.7C2.5 12.3 0 10.7 0 7.5a5.52 5.52 0 011.6-3.9A5.73 5.73 0 016 2a5.25 5.25 0 014 1.9A5.85 5.85 0 0114 2c2.9 0 6 2.2 6 5.5s-2.5 4.8-4.8 6.4a15.51 15.51 0 00-4.4 3.7 1.23 1.23 0 01-.8.4z" fill="rgb(255,0,0)"></path></svg>
NYC
</h2>
</div>
</div>
);
}
контроллер лайков
class Api::LikesController < ApplicationController
def index
@likes = Like.all
render :index
end
def new
@like = Like.new
render :new
end
def show
@like = Like.find(params[:id])
render :show
end
def create
@like = Like.new(like_params)
@like.liker_id = current_user.id
if @like.save
render :show
else
render json: @like.errors.full_messages , status: 422
end
end
def destroy
@like = Like.find(params[:id])
@like.destroy
render :index
# respond_to do |f|
# f.html { redirect_to :index }
# f.json { head :no_content }
# end
end
def like_params
params.require(:like).permit(:liker_id, :video_id)
end
end
jbuilder partial / index / show
json.extract! like, :id, :liker_id, :video_id, :created_at
json.array! @likes do |like|
# @likes.each do |like|
json.set! like.id do
json.partial! 'like', like: like
end
end
json.partial! 'like', like: @like