通用评论

1
  1. {"version":3,"sources":["../src/App.js"],"names":["App","props","state","loading","oss","list","page","total","isNoMoreComment","handleChangeLoading","bind","sGetComment","sGetReply","sCreateComment","sCreateReply","sCommentFavor","sOssSts","key","value","setState","API","type","businessId","axios","get","LIMIT","then","response","data","newList","oldList","filter","o","isTemporary","concat","info","catch","error","msg","ERROR_DEFAULT","message","finally","commentId","replies","map","item","id","isNoMoreReply","content","method","business_id","withCredentials","success","unshift","cb","comment_id","favored","favor_count","showEditor","children","showList","marginTop","Component","propTypes","PropTypes","number","isRequired","string","bool","defaultProps","Editor"],"mappings":"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","file":"App.js","sourcesContent":["import React, { Component } from \"react\";\nimport PropTypes from \"prop-types\";\nimport { message } from \"antd\";\nimport axios from \"./axios\";\nimport { ERROR_DEFAULT, LIMIT } from \"./constant\";\nimport { CommentContext } from \"./Comment\";\nimport { isFunction } from \"./helper\";\nimport CommentInput from \"./components/CommentInput\";\nimport CommentList from \"./components/CommentList\";\nimport Editor from \"./components/Editor\";\nimport \"./App.css\";\n\nclass App extends Component {\n constructor(props) {\n super(props);\n this.state = {\n loading: {},\n\n // oss 配置\n oss: {},\n\n // 评论数据\n list: [],\n page: 1,\n total: 0,\n // 是否没有更多评论了\n isNoMoreComment: false\n };\n this.handleChangeLoading = this.handleChangeLoading.bind(this);\n this.sGetComment = this.sGetComment.bind(this);\n this.sGetReply = this.sGetReply.bind(this);\n this.sCreateComment = this.sCreateComment.bind(this);\n this.sCreateReply = this.sCreateReply.bind(this);\n this.sCommentFavor = this.sCommentFavor.bind(this);\n this.sOssSts = this.sOssSts.bind(this);\n }\n\n componentDidMount() {}\n\n /**\n * 改变 loading 状态\n * @param {string} key key\n * @param {string} value value\n */\n handleChangeLoading(key, value) {\n const { loading } = this.state;\n loading[key] = value;\n this.setState({ loading });\n }\n\n /**\n * 获取评论列表\n */\n sGetComment({ page = 1 } = {}) {\n this.handleChangeLoading(\"sGetComment\", true);\n const { API, type, businessId } = this.props;\n axios\n .get(\n `${API}/comments?type=${type}&business_id=${businessId}&page=${page}&limit=${LIMIT}`\n )\n .then(response => {\n const { list, page, total } = response.data;\n if (list) {\n let newList = list;\n if (page > 1) {\n let { list: oldList } = this.state;\n // 删除临时数据\n oldList = oldList.filter(o => !o.isTemporary);\n newList = oldList.concat(newList);\n }\n this.setState({\n list: newList,\n page,\n total\n });\n } else {\n message.info(\"没有更多评论了\");\n this.setState({\n isNoMoreComment: true\n });\n }\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sGetComment\", false);\n });\n }\n\n /**\n * 获取更多回复\n */\n sGetReply({ commentId, page = 1 } = {}) {\n this.handleChangeLoading(\"sGetReply\", true);\n const { API } = this.props;\n axios\n .get(`${API}/replies?comment_id=${commentId}&page=${page}&limit=${LIMIT}`)\n .then(response => {\n const { list: replies } = response.data;\n if (!replies) {\n message.info(\"没有更多数据了!\");\n }\n const list = this.state.list.map(item => {\n if (item.id === commentId) {\n if (!item.replies) item.replies = [];\n if (replies) {\n if (page === 1) {\n // 如果当前页数为第一页,则清空当前所有的 replies\n // 并将获取到的 replies 存放在 state\n item.replies = replies;\n } else {\n item.replies = item.replies.concat(replies);\n // 如果当前页数非第一页,则合并 replies\n }\n } else {\n item.isNoMoreReply = true;\n }\n }\n return item;\n });\n this.setState({ list });\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sGetReply\", false);\n });\n }\n\n /**\n * 添加评论\n * @param {string} content comment content\n */\n sCreateComment(content) {\n if (!content) return message.error(\"评论内容不能为空 \");\n this.handleChangeLoading(\"sCreateComment\", true);\n const { API, type, businessId } = this.props;\n axios(`${API}/comments`, {\n method: \"post\",\n data: {\n type,\n business_id: businessId,\n content\n },\n withCredentials: true\n })\n .then(response => {\n message.success(\"评论成功!\");\n // 将数据写入到 list 中\n // 临时插入\n // 等到获取数据之后,删除临时数据\n const { list } = this.state;\n list.unshift({\n ...response.data,\n isTemporary: true // 临时的数据\n });\n this.setState({ list });\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sCreateComment\", false);\n });\n }\n\n /**\n * 添加回复\n * 回复评论/回复回复\n * @param {object} data { comment_id, content, [reply_id] }\n */\n sCreateReply(data, cb) {\n if (!data.content) return message.error(\"回复内容不能为空 \");\n this.handleChangeLoading(\"sCreateReply\", true);\n const { API } = this.props;\n axios(`${API}/replies`, {\n method: \"post\",\n data,\n withCredentials: true\n })\n .then(response => {\n // // 将该条数据插入到 list 中\n // const list = this.state.list.map(item => {\n // if (item.id === data.comment_id) {\n // if (!item.replies) item.replies = [];\n // item.reply_count += 1\n // item.replies.unshift(response.data);\n // }\n // return item;\n // });\n // this.setState({ list });\n this.sGetReply({ commentId: data.comment_id });\n message.success(\"回复成功!\");\n if (isFunction(cb)) cb();\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sCreateReply\", false);\n });\n }\n\n /**\n * 点赞/取消点赞\n * @param {string} commentId { commentId }\n * @param {boolean} favored 是否已经点过赞\n */\n sCommentFavor(commentId, favored) {\n this.handleChangeLoading(\"sCommentFavor\", true);\n const { API } = this.props;\n axios(`${API}/comments/${commentId}/favor`, {\n method: favored ? \"delete\" : \"put\",\n withCredentials: true\n })\n .then(response => {\n message.success(favored ? \"取消点赞成功!\" : \"点赞成功!\");\n // 更新 list 中的该项数据的 favored\n const list = this.state.list.map(item => {\n if (item.id === commentId) {\n item.favored = !favored;\n item.favor_count += favored ? -1 : 1;\n }\n return item;\n });\n this.setState({ list });\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sCommentFavor\", false);\n });\n }\n\n /**\n * 获取 OSS 上传的参数\n */\n sOssSts() {\n this.handleChangeLoading(\"sOssSts\", true);\n const { API } = this.props;\n axios\n .get(`${API}/oss/sts`)\n .then(response => {\n this.setState({ oss: { ...response.data } });\n })\n .catch(error => {\n if (error.response && error.response.data && error.response.data.msg) {\n message.error(error.response.data.msg || ERROR_DEFAULT);\n return;\n }\n message.error(error.message || ERROR_DEFAULT);\n })\n .finally(() => {\n this.handleChangeLoading(\"sOssSts\", false);\n });\n }\n\n render() {\n // 添加到 Context 的数据\n const value = {\n ...this.state,\n ...this.props,\n sCreateComment: this.sCreateComment,\n sGetComment: this.sGetComment,\n sCommentFavor: this.sCommentFavor,\n sCreateReply: this.sCreateReply,\n sGetReply: this.sGetReply,\n sOssSts: this.sOssSts\n };\n\n return (\n <CommentContext.Provider value={value}>\n <div className=\"comment\">\n {this.props.showEditor && (\n <CommentInput content={this.props.children} />\n )}\n {this.props.showList && (\n <div style={{ marginTop: 20 }}>\n <CommentList />\n </div>\n )}\n </div>\n </CommentContext.Provider>\n );\n }\n}\n\nApp.propTypes = {\n type: PropTypes.number.isRequired, // 评论的 type\n businessId: PropTypes.string.isRequired, // 评论的 business_id\n API: PropTypes.string, // 评论的 API 前缀\n showList: PropTypes.bool, // 是否显示评论列表\n showEditor: PropTypes.bool // 是否显示评论输入框\n};\n\nApp.defaultProps = {\n API: \"http://api.links123.net/comment/v1\",\n showList: true,\n showEditor: true\n};\n\nexport { Editor };\n\nexport default App;\n"]}