{"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"]}