0
React + Reduxアプリで新しいコメントを追加するには、react-motion
でアニメーション化しようとしています。reduxとのリアクション
class Comments extends Component {
getDefaultStyles() {
const { comments } = this.props;
return comments.map((c, i) => {
return {
key: "" + i,
style: { top: -50, opacity: 0.2 },
data: c
}
});
}
getStyles() {
const { comments } = this.props;
return comments.map((c, i) => {
return {
key: "" + i,
style: {
top: spring(0, presets.gentle),
opacity: spring(1, presets.gentle)
},
data: c
}
})
}
willEnter() {
return { top: -50, opacity: 0.2 }
}
render() {
let { comments } = this.props;
return (
<div>
<TransitionMotion defaultStyles={this.getDefaultStyles()} styles={this.getStyles()} willEnter={this.willEnter}>
{styles =>
<div>
{
styles.map((c) => {
return (
<Comment key={c.key} comment={c.data} style={{...c.style, overflow: 'hidden'}} />
)
})
}
</div>
}
</TransitionMotion>
</div>
)
}
}
次に、スタイルはComment
コンポーネントの最初のdivに渡されます。
コメントを読み込んでいる間、アニメーションはOKです。しかし、ユーザーがコメントを追加した後、fetchComments
メソッドが呼び出されてすべてのコメントが取得されると、アニメーションは発生しません。これは還元と関係がありますか?私はmapStateToProps
とconnect
を使ってコメントを渡しています。