Posts를 만들면서 약간 아쉬웠던 부분은 Delete 부분에 대해서 너무 SmartForm에 의지하여 간단하게 넘어가긴 했다.
목록에서 지우거나 상세 보기에서 지울 일도 분명 있을 것이다.
역시나 이것도 목록(ex. withList)을 가져올 때 처럼 HoC(Higher-Order Component)를 사용한다.
http://docs.vulcanjs.org/mutations.html#Remove-Mutation 부분을 참조하자.
이번에 구현할 것은 목록마다 remove 버튼을 달고 버튼을 누르면 이벤트를 받아 삭제하도록 구현해보자.
그러면 withRemove를 registerComponent시 사용할 수 있다.
withList와 함께 withRemove도 추가하자.
showRemove={true}옵션을 통해 한줄 찍 긋고 Delete라고 나오는 부분을 클릭하는 것도 좋지만
목록에서 지우거나 상세 보기에서 지울 일도 분명 있을 것이다.
역시나 이것도 목록(ex. withList)을 가져올 때 처럼 HoC(Higher-Order Component)를 사용한다.
http://docs.vulcanjs.org/mutations.html#Remove-Mutation 부분을 참조하자.
이번에 구현할 것은 목록마다 remove 버튼을 달고 버튼을 누르면 이벤트를 받아 삭제하도록 구현해보자.
import { registerComponent, withList, withRemove } from 'meteor/vulcan:core';먼저 해야할 것은 withRemove를 import에 추가하는 것이다.
그러면 withRemove를 registerComponent시 사용할 수 있다.
withList와 함께 withRemove도 추가하자.
registerComponent('PostsListComponent', PostsListComponent, [
withList, {
collection: Posts
}], [
withRemove, {
collection: Posts
}
]);
withRemove도 withList와 동일하게 collection만 지정하면 된다.
준비는 다 되었다. withRemove를 붙여서 this.props는 removeMutation을 갖게 되었다.
removeMutation의 사용법은 다음과 같다.
this.props.removeMutation({
documentId: documentId
}).then(/* success */).catch(/* error */);
promise를 지원한다. 오류처리는 catch에 정상적 완료 후에 무언가를 하려면 then에 function을 구현하자.
지금은 별 생각이 없으므로 버튼을 만들고 단순하게 붙여보자.
<button onClick={()=>this.props.removeMutation({
documentId: o._id
})
.then(console.log)
.catch(console.log)
}>Remove</button>
이런 버튼을 붙이면 되겠다.
전체 소스를 다시 살펴보자. PostsListComponent는 이렇게 되었다.
import React, { Component } from 'react';
import { Link } from 'react-router';
import { registerComponent, withList, withRemove } from 'meteor/vulcan:core';
import Posts from "../modules/posts/collection.js";
class PostsListComponent extends Component {
render () {
return (
<div>
{
this.props.results
&& this.props.results.map(o=>
<div key={o._id}>
<Link to={`/posts/${o._id}`}>{o.title}</Link>
<button onClick={()=>this.props.removeMutation({
documentId: o._id
})
.then(console.log)
.catch(console.log)
}>Remove</button>
</div>
)
}
</div>
);
}
}
registerComponent('PostsListComponent', PostsListComponent, [
withList, {
collection: Posts
}], [
withRemove, {
collection: Posts
}
]);
export default PostsListComponent;
목록 한건한건 오른쪽 끝에 Remove버튼이 붙었고 누르자마 해당 Post가 지워진다.
HoC는 처음엔 다소 어색하지만 한번 맛들이면 빠져나오기 힘들다. 일관적인 구현을 위해 적극적으로 사용하자.
HoC는 처음엔 다소 어색하지만 한번 맛들이면 빠져나오기 힘들다. 일관적인 구현을 위해 적극적으로 사용하자.
댓글
댓글 쓰기