\n
\n
\n
\n
\n
\n 会员价 :\n {access_token ? (\n \n ¥\n {detailData?.discount_price}\n {detailData?.discount == 1 ? null : (\n \n [\n {detailData && detailData.discount\n ? (detailData.discount * 10).toFixed(1)\n : \"\"}\n 折]\n \n )}\n \n ) : (\n ?\n )}\n
\n
\n 价 格:¥{detailData?.output_price}\n
\n
\n {activity && access_token && activity.e_time && activity.s_time ? (\n
\n ) : null}\n {access_token ? null : (\n
this.toLogin()}>\n 登录享会员优惠价 \n
\n )}\n
\n {access_token ? null : (\n
this.membershipCard()}>\n
\n
\n 开通会员最高享{(max_discount * 10).toFixed(1)}折,本单会员优惠价\n \n ¥{(detailData?.output_price * max_discount).toFixed(2)}\n \n
\n
\n
\n )}\n\n
\n
{detailData?.name}
\n\n {!(hiddenBtn || shopping_cart) ? (\n
this.toCollect(has_collect)}\n >\n \n 收藏\n
\n ) : null}\n
\n {detailData?.is_book ? (\n
\n
\n
ISBN:{detailData?.isbn}
\n
\n
\n
作者:{detailData?.writer}
\n {!hiddenBtn ? (\n
\n this.toAllProducts(`作者:${detailData.writer}`)\n }\n >\n 更多作品\n \n
\n ) : null}\n
\n
\n
出版社:{detailData?.pub_name}
\n {!hiddenBtn ? (\n
\n this.toAllProducts(`出版社:${detailData.pub_name}`)\n }\n >\n 更多作品\n \n
\n ) : null}\n
\n
\n ) : (\n
\n
\n
分类: \n
{detailData?.type_name}
\n
\n
\n
规格:\n
{detailData?.standard}
\n
\n
\n
材质:\n
{detailData?.media}
\n
\n
\n
重量:\n
{detailData?.weight}
\n
\n
\n )}\n
\n\n
\n

this.closeBack()}\n />\n
\n {celingArr.map((item, idx) => {\n return (\n - this.toCelingActive(idx)}\n >\n {item.title}\n
\n );\n })}\n
\n
\n\n {!shopping_cart ? (\n
\n
店铺及配送
\n {/* {!hiddenBtn ? (\n
\n
送至\n
this.toSelectAddress()}>\n {addressDefault && addressDefault?.city_name ? (\n
\n {addressDefault?.city_name}\n {addressDefault?.country_name}\n {addressDefault?.detail}\n
\n ) : (\n
\n {storeDetailData && storeDetailData.address\n ? storeDetailData.address\n : \"点击添加收货地址\"}\n
\n )}\n\n
\n
\n
\n ) : null} */}\n\n
\n
店铺\n
\n
\n {storeDetailData?.name}\n {!hiddenBtn ? (\n this.changeStore()}\n />\n ) : null}\n
\n\n
\n {this.stars(storeDetailData?.comment_avg_score)}\n {storeDetailData?.comment_count}条评价\n
\n
\n {!hiddenBtn ? (\n
\n
this.toStoreDetail()}>\n \n 店铺\n
\n
this.toChat()}>\n \n 客服\n
\n
\n ) : null}\n
\n {!hiddenBtn && detailData.freight ? (\n
\n
运费\n
{detailData?.freight}
\n
\n
\n ) : null}\n
\n
位置\n
\n {locationEnable ? {storeDetailData?.distance} : \"\"}\n {storeDetailData?.address}\n
\n
\n
\n
\n
\n
{detailData?.name}
\n {detailData?.stock_amount > 0 ? (\n
\n
\n
所在书架:\n
\n {shelf_ids &&\n shelf_ids.length &&\n shelf_ids.map((item, idx) => {\n return
{item}
;\n })}\n
\n
\n
\n 库存:\n {detailData?.stock_amount}\n
\n
\n ) : (\n
\n
\n \n 当前店铺无货\n
\n {!hiddenBtn ? (\n
\n this.changeStore()}\n />\n
\n ) : null}\n
\n )}\n
\n
\n
\n ) : null}\n\n \n
\n
商品详情
\n {content1 ? (\n
\n ) : null}\n {writer_summary1 ? (\n
\n ) : null}\n {market_desc1 ? (\n
\n ) : null}\n {directory1 ? (\n
\n
\n 目录\n
\n
\n {/* {productExtend.directory} */}\n
\n
\n ) : null}\n\n {/*
{productExtend.directory}
*/}\n {productExtend && productExtend.wonderful_page ? (\n
\n ) : null}\n {productExtend && productExtend.title_page_url ? (\n
\n
\n 详情\n
\n

\n
\n ) : null}\n
\n {!(hiddenBtn || shopping_cart) && is_mall ? (\n
\n
\n
this.toChat()}>\n \n\n 客服\n
\n
this.toCartDetail()}>\n \n 购物车\n {cartSummary && cartSummary.total_amount > 0 ? (\n {cartSummary.total_amount}\n ) : null}\n
\n
\n {detailData?.stock_amount > 0 ? (\n
\n this.addCartNative()}>\n 加入购物车\n \n this.buyPreview()}>\n 我要购买\n \n
\n ) : (\n
\n 缺货\n
\n )}\n
\n ) : null}\n
\n );\n }\n}\nexport default withRouter(ProductDetail);\n","import React, { Component } from \"react\";\nimport { withRouter } from \"react-router-dom\";\n\nimport { Mask } from \"antd-mobile\";\nimport \"./dialog.scss\";\nclass Dialog extends Component {\n constructor(props) {\n super(props);\n this.state = {};\n }\n\n sure = () => {\n this.props.sure();\n };\n render() {\n const { visible, setCheckVisible, title, cont } = this.props;\n var title1 = title || \"确认核验\";\n var cont1 = cont || \"请仔细核验,确认要提交吗?\";\n return (\n \n
\n
押金金额
\n
\n {summary.deposit_balance || 0}元\n
\n {summary.refunding_deposit ? (\n
提现中 {summary.refunding_deposit}元
\n ) : null}\n
{\n this.changeStep(4);\n }}\n >\n 查看明细\n
\n
\n
\n
退押金说明
\n
申请退押金后,将不再享有借阅权益:
\n
1.您将无法再借阅书籍。
\n
\n 2.您已购买的借阅卡借阅权益将冻结,有效期内再次交纳押金后恢复。期间购物权益不受影响。\n
\n
退款方式
\n
默认按原支付路径原路退回;
\n
\n 支付时间较早,或因其他原因无法原路退回的用户,将退款至微信零钱,您需要关注【句象图书】微信服务号,点击底部菜单【句象会员-申请退押金】,使用注册手机号登录后,申请提现。\n
\n
到账时间
\n
\n 退款一般1~3个工作日到账,具体还依赖于支付渠道的处理时间,如遇特殊情况,以支付渠道通知为准。\n
\n
\n
\n );\n const step2 = (\n \n
\n
\n
申请退款成功
\n {summary.refunding_deposit ? (\n
提现中 {summary.refunding_deposit}元
\n ) : null}\n
\n 退款一般1-3个工作日到账\n
\n 具体依赖于支付渠道的处理时间\n
\n
\n {depositSuccess ? (\n
\n
\n 押金金额:¥{depositSuccess.amount}\n
\n
\n 退款方式:{depositSuccess.refund_method_text}\n
\n
\n 申请时间:{depositSuccess.apply_time}\n
\n
\n ) : null}\n
\n );\n const step4 = (\n \n
\n \n

this.goBack()} />\n
我的钱包\n
\n
\n \n
\n
\n
我的零钱
\n
{walletInfo.vender || \"\"}
\n
¥{walletInfo.balance || \"0.00\"}
\n
\n this.goToPage(\"/wallet/code\")}>付款\n { this.handleRecharge() }}>充值\n
\n
\n
\n - this.goToPage(\"/wallet/details\")}>钱包明细
\n - this.goToPage(\"/wallet/password\")}>{walletInfo.has_pay_password ? \"修改\" : \"设置\"}支付密码
\n
\n\n {showRechargeModal ?\n
\n
{ this.handleRecharge() }}>选择付款方式
\n
\n - { this.handleRechargeSelect(1) }}>\n
在线充值
\n \n \n - { this.handleRechargeSelect(2) }}>\n
充值卡
\n \n \n - { this.goRecharge() }}>确定
\n
\n
\n : null}\n\n
\n );\n }\n}\nexport default withRouter(Wallet);\n","import React, { Component } from \"react\";\nimport { withRouter } from \"react-router-dom\";\nimport { Toast } from \"antd-mobile\";\nimport $https from \"../../../httpdata\";\nimport getParam from \"../../../utils/getParam\";\nimport \"./index.scss\";\n\nclass WalletDetails extends Component {\n constructor(props) {\n super(props);\n const { match, location } = props;\n this.invoiceId = match.params.id;\n this.needClose = getParam(location.search, \"needClose\");\n this.state = {\n backIcon: require(\"../../common/img/back.png\"),\n walletDetails: {},\n billList: [],\n loadingFlag: false,\n page: 1,\n page_size: 10,\n last_page: null,\n type: 0,\n };\n }\n\n componentDidMount() {\n const that = this;\n this.getWalletDetails();\n\n window.onscroll = function () {\n var pageNum = that.state.page;\n const { last_page } = that.state;\n var scrollTop =\n document.documentElement.scrollTop || document.body.scrollTop;\n var windowHeight =\n document.documentElement.clientHeight || document.body.clientHeight;\n var scrollHeight =\n document.documentElement.scrollHeight || document.body.scrollHeight;\n if (scrollTop + windowHeight >= scrollHeight) {\n if (!last_page) {\n that.setState({\n loadingFlag: true,\n });\n return;\n }\n if (pageNum < last_page) {\n pageNum = pageNum + 1;\n\n that.setState({\n page: pageNum,\n loadingFlag: true,\n }, () => {\n that.getWalletDetails();\n });\n } else {\n that.setState({\n loadingFlag: false,\n });\n }\n\n //考虑到滚动的位置一般可能会大于一点可滚动的高度,所以这里不能用等于\n }\n };\n }\n\n getWalletDetails = () => {\n $https\n .get(\"/api/v1/wallet/bill\", {\n id: this.invoiceId,\n type: this.state.type\n })\n .then((res) => {\n if (res && res.data && res.data.bills && res.data.account) {\n const bills = res.data.bills || {};\n const billData = bills.data || [];\n const arr = this.state.billList ? this.state.billList : [];\n const newArr = [...arr, ...billData];\n this.setState({\n last_page: bills.last_page,\n loadingFlag: false,\n walletDetails: res.data.account,\n billList: newArr\n });\n } else {\n Toast.show((res && res.msg) || \"数据异常!\");\n }\n });\n }\n\n changeType = (e, type) => {\n this.setState({\n billList: [],\n loadingFlag: true,\n type\n }, () => {\n this.getWalletDetails();\n })\n }\n\n goBack = () => {\n if (this.needClose) {\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"closeWeb\",\n })\n );\n } else {\n this.props.history.go(-1);\n }\n }\n\n render() {\n const { backIcon, walletDetails, billList, loadingFlag, type } = this.state;\n\n return (\n \n
\n \n

this.goBack()} />\n
充值\n
\n
\n \n {this.rechargeType === 1 ? (\n
\n
\n
充值金额
\n
\n - {\n this.selectMoney(200);\n }}\n >\n ¥200\n
\n - {\n this.selectMoney(500);\n }}\n >\n ¥500\n
\n - {\n this.selectMoney(1000);\n }}\n >\n ¥1000\n
\n
\n
\n
\n
{\n this.changeMoney(e);\n }}\n />\n
{\n this.createOrder();\n }}\n >\n 立即充值\n
\n
\n
\n ) : this.rechargeType === 2 ? (\n
\n
请输入密码
\n
{\n this.handleInputCardPassword(e);\n }}\n />\n
\n
使用规则
\n
\n 1.本卡仅可充值一次,不记名、不挂失、遗失不补。使用过后自动作废。\n
\n
2.购买时请确保密码涂层完好,一经售出,概不退换。
\n
3.本卡最终解释权归该书店所有。
\n
充值方式
\n
1.微信扫描二维码关注书店微商城,注册成为会员。
\n
\n 2.轻刮涂层获得密码,点击“个人中心”到“我的钱包”,点击“充值”,输入密码进行充值。\n
\n
\n
{\n this.chargeCard();\n }}\n >\n 确定\n
\n
\n ) : null}\n
\n );\n }\n}\nexport default withRouter(Wallet);\n","import \"./membershipCard.scss\";\nimport React, { Component } from \"react\";\nimport { withRouter } from \"react-router-dom\";\nimport $https from \"../../../httpdata\";\nimport getParam from \"../../../utils/getParam\";\nclass MembershipCard extends Component {\n constructor(props) {\n super(props);\n this.state = {\n backIcon: require(\"../../common/img/back.png\"),\n vip: require(\"./img/vip.png\"),\n // pointsActive: require(\"./img/points-active.png\"),\n // points: require(\"./img/points.png\"),\n\n // activeType: 0,\n // page: 1,\n // page_size: 6,\n categories: [],\n mobile: null,\n loadingFlag: false,\n\n // last_page: null,\n // balance: 0,\n };\n }\n componentDidMount() {\n let that = this;\n this.getCardCategories();\n document.addEventListener(\"visibilitychange\", function () {\n /*ie10+ moz webkit 默认*/\n if (!document[\"hidden\"]) {\n that.getCardCategories();\n }\n });\n // let that = this;\n // window.onscroll = function () {\n // var pageNum = that.state.page;\n // const { last_page } = that.state;\n // var scrollTop =\n // document.documentElement.scrollTop || document.body.scrollTop;\n // var windowHeight =\n // document.documentElement.clientHeight || document.body.clientHeight;\n // var scrollHeight =\n // document.documentElement.scrollHeight || document.body.scrollHeight;\n // if (scrollTop + windowHeight >= scrollHeight) {\n // if (!last_page) {\n // that.setState({\n // loadingFlag: true,\n // });\n // return;\n // }\n // if (pageNum < last_page) {\n // pageNum = pageNum + 1;\n\n // that.setState(\n // {\n // page: pageNum,\n // loadingFlag: true,\n // },\n // () => {\n // // that.getCardCategories();\n // }\n // );\n // } else {\n // that.setState({\n // loadingFlag: false,\n // });\n // }\n\n // //考虑到滚动的位置一般可能会大于一点可滚动的高度,所以这里不能用等于\n // }\n // };\n }\n componentWillUnmount() {}\n getCardCategories = () => {\n $https\n .get(\"/api/v1/card/categories\", {\n station_id: window.localStorage.getItem(\"stationId\"),\n type: getParam(this.props.location.search, \"classType\")\n ? getParam(this.props.location.search, \"classType\")\n : 0,\n })\n .then((res) => {\n // console.log(res);\n // var arr = this.state.pointsList ? this.state.pointsList : [];\n // var newArr = [...arr, ...res.data.paginator.data];\n this.setState({\n // last_page: res.data.paginator.last_page,\n categories: res.data && res.data.categories,\n mobile: res.data && res.data.mobile,\n loadingFlag: false,\n // balance: res.data.balance,\n });\n });\n };\n toDetail = (class_id) => {\n this.props.history.push({\n pathname: `/membershipCardDetail`,\n search: `class_id=${encodeURIComponent(class_id)}`,\n });\n };\n // changeType = (type) => {\n // this.setState(\n // {\n // activeType: type,\n // page: 1,\n // pointsList: [],\n // loadingFlag: true,\n // },\n // () => {\n // this.getCardCategories();\n // }\n // );\n // };\n goBack = () => {\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"closeWeb\",\n })\n );\n };\n render() {\n const { backIcon, vip, categories, mobile } = this.state;\n return (\n \n
\n this.goBack()} />\n 借书详情\n \n \n {verified ? (\n
\n
\n \n 核验信息\n
\n
\n
\n
\n
核验时间:{product && product.deliver_time}
\n
借阅门店:{product && product.borrow_station.name}
\n
核验人员:{product && product.deliver_staff}
\n
\n
\n
\n ) : null}\n
\n
\n \n 借阅信息\n
\n
\n
\n \n {user?.mobile}\n {borrow_card && borrow_card.name}\n
\n
\n
订单号:{product && product.order_sn}
\n\n
借阅时间:{product && product.create_time}
\n
\n
\n - \n
\n {borrow_card?.used_num + borrow_card?.return_num}\n 本\n
\n 累计借阅\n \n - \n
\n {borrow_card?.used_num}本\n
\n 借阅中\n \n - \n
\n {borrow_card?.overdue_times}次\n
\n 累计超期\n \n - \n
\n {borrow_card?.return_num}本\n
\n 累计归还\n \n
\n
\n
\n
\n
\n \n 书籍信息\n
\n
\n
\n \n
\n
this.toBookDetail()}>\n
\n \n {product && product.product && product.product.name}\n \n\n \n
\n
\n 定价:¥\n {product && product.product && product.product.output_price}\n
\n
\n
\n
\n \n 作者:\n {product && product.product && product.product.writer}\n \n
\n
\n 出版社:\n {product && product.product && product.product.pub_name}\n
\n
\n ISBN:{product && product.product && product.product.isbn}\n
\n
\n 出版时间:\n {product && product.product && product.product.publish_date}\n
\n
\n
\n
\n
\n
\n
\n {product &&\n product.borrow_images &&\n product.borrow_images.length >= 1 ? (\n
\n
\n \n \n 书籍照片(\n {product &&\n product.borrow_images &&\n product.borrow_images.length}\n 张)\n \n
\n\n this.setImgVisible(false)}\n />\n \n {imgsResult.length &&\n imgsResult.map((item, index) => {\n return (\n \n {item.map((itm, idx) => {\n return (\n this.getImgVal(itm)}\n fit=\"cover\"\n />\n );\n })}\n \n );\n })}\n \n \n ) : null}\n\n
\n {verified ? (\n
this.goBack()}>下一本\n ) : (\n
\n this.goBack()}>\n 取消借阅\n \n this.judgeDialog()}>借阅核验通过\n
\n )}\n
\n
\n
\n
\n );\n }\n}\n\nexport default withRouter(Borrow);\n","import React, { Component } from \"react\";\nimport \"./returnBook.scss\";\nimport { withRouter } from \"react-router-dom\";\nimport { Image, Swiper, Toast, ImageViewer } from \"antd-mobile\";\nimport $https from \"../../../httpdata\";\nimport getParam from \"../../../utils/getParam\";\nimport Dialog from \"../../../components/dialog/dialog\";\nclass ReturnBook extends Component {\n constructor(props) {\n super(props);\n this.state = {\n backIcon: require(\"../../common/img/back-active.png\"),\n titleIcon: require(\"./img/titleIcon.png\"),\n borrowIcon: require(\"./img/borrowIcon.png\"),\n defaultAvatar: require(\"./img/defaultAvatar.png\"),\n infoRight: require(\"../../common/img/shop-info-right.png\"),\n alreadyReturn: require(\"./img/alreadyReturn.png\"),\n borrowing: require(\"./img/borrowing.png\"),\n verified: null,\n order_sn: \"\",\n user_id: \"\",\n crossStore: require(\"./img/crossStore.png\"),\n user: null,\n checkVisible: false,\n stationId: null,\n return_sn: null,\n product: null,\n borrow_card: null,\n imgVisible: false,\n imgUrl: \"\",\n imgsResult: [],\n };\n }\n componentDidMount() {\n let that = this;\n\n window.onCommonData = async function (res) {\n that.setState(\n {\n stationId:\n getParam(that.props.location.search, \"station_id\") || res.stationId,\n order_sn: getParam(that.props.location.search, \"order_sn\"),\n user_id: getParam(that.props.location.search, \"user_id\"),\n return_sn: getParam(that.props.location.search, \"return_sn\"),\n },\n () => {\n that.getDetail();\n }\n );\n };\n\n window.JXNative &&\n window.JXNative.postMessage &&\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"commonData\",\n })\n );\n }\n getDetail() {\n const { order_sn, user_id, return_sn } = this.state;\n $https\n .get(\"/api/staff/v1/order/borrow/product\", {\n order_sn,\n user_id,\n return_sn,\n })\n .then((res) => {\n console.log(res);\n this.setState(\n {\n verified:\n res.data.product.status == 2\n ? false\n : res.data.product.status == 1\n ? true\n : null,\n user: res.data.user,\n product: res.data.product,\n borrow_card: res.data.borrow_card,\n },\n () => {\n const { product } = this.state;\n if (\n product &&\n product.borrow_images.length &&\n product.borrow_images\n ) {\n var result = [];\n for (var i = 0; i < product.borrow_images.length; i += 3) {\n result.push(product.borrow_images.slice(i, i + 3));\n }\n this.setState({\n imgsResult: result,\n });\n }\n }\n );\n });\n }\n returnCheck = () => {\n const { order_sn, user_id, return_sn, stationId } = this.state;\n $https\n .post(\"/api/staff/v1/order/borrow/return\", {\n order_sn,\n user_id,\n station_id: stationId,\n return_sn,\n })\n .then((res) => {\n this.getDetail();\n this.setCheckVisible(false);\n if (res.msg == \"success\") {\n Toast.show({\n content: \"核验通过\",\n });\n } else {\n Toast.show({\n content: res.msg,\n });\n }\n });\n };\n goBack = () => {\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"closeWeb\",\n })\n );\n };\n setCheckVisible = (val) => {\n this.setState({\n checkVisible: val,\n });\n };\n toBookDetail = () => {\n const { product } = this.state;\n this.props.history.push({\n pathname: `/productDetail`,\n search: `goods_id=${product.product.id}&from=staff`,\n });\n };\n setImgVisible = (val) => {\n this.setState({\n imgVisible: val,\n });\n };\n getImgVal = (val) => {\n this.setState(\n {\n imgUrl: val,\n },\n () => {\n this.setState({\n imgVisible: true,\n });\n }\n );\n };\n render() {\n const {\n backIcon,\n titleIcon,\n borrowIcon,\n defaultAvatar,\n infoRight,\n alreadyReturn,\n verified,\n borrowing,\n crossStore,\n stationId,\n user,\n checkVisible,\n product,\n borrow_card,\n imgVisible,\n imgUrl,\n imgsResult,\n } = this.state;\n\n return (\n \n
\n this.goBack()} />\n 借书详情\n \n \n {verified ? (\n
\n
\n \n 核验信息\n
\n
\n
\n
\n
核验时间:{product && product.receive_time}
\n
借阅门店:{product && product.borrow_station.name}
\n
核验人员:{product && product.receive_staff}
\n
\n
\n {verified &&\n product &&\n product.borrow_station &&\n product.borrow_station.id !== stationId ? (\n
\n ) : null}\n
\n ) : null}\n\n
\n {!verified &&\n product &&\n product.borrow_station &&\n product.borrow_station.id !== stationId ? (\n
\n ) : null}\n
\n \n 借阅信息\n
\n
\n
\n \n {user?.mobile}\n {borrow_card && borrow_card.name}\n
\n
\n
订单号:{product && product.order_sn}
\n
\n {verified ? \"归还时间\" : \"到期时间\"}:\n {verified\n ? product && product.receive_time\n : product && product.expire_time}\n
\n
借阅时间:{product && product.create_time}
\n
\n 借阅门店:\n \n {product && product.borrow_station.name}\n \n
\n
\n\n {verified ? (\n
\n - \n
\n 超期天数:\n {product && product.overdue_days}天\n
\n \n - \n
\n 超期费用:\n ¥ {product && product.overdue_fee}\n
\n \n - \n
\n 已付超期费用:\n \n ¥{product && product.has_paid_fee}\n \n
\n \n - \n
\n 支付时间:\n {product && product.pay_time}\n
\n \n
\n ) : (\n
\n - \n
\n 超期天数:\n \n {product && product.overdue_days}天\n \n
\n \n - \n
\n 超期费用:\n ¥ {product && product.overdue_fee}\n
\n \n - \n
\n 已付超期费用:\n ¥{product && product.has_paid_fee}\n
\n \n - \n
\n 未支付超期费用:\n \n ¥{product && product.not_paid_fee}\n \n
\n \n - \n
\n 累计借阅:\n \n \n {borrow_card?.used_num + borrow_card?.return_num}\n \n 本\n \n
\n \n - \n
\n 借阅中:\n {borrow_card && borrow_card.used_num}本\n
\n \n - \n
\n 累计超期:\n \n {borrow_card && borrow_card.overdue_times}次\n \n
\n \n - \n
\n 累计归还:\n {borrow_card && borrow_card.return_num}本\n
\n \n
\n )}\n
\n
\n
\n
\n \n 书籍信息\n
\n
\n
\n this.setImgShowVisible(true)}\n fit=\"cover\"\n />\n
\n\n
this.toBookDetail()}>\n
\n \n {product && product.product && product.product.name}\n \n\n \n
\n
\n 定价:¥\n {product && product.product && product.product.output_price}\n
\n
\n
\n
\n \n 作者:\n {product && product.product && product.product.writer}\n \n
\n
\n 出版社:\n {product && product.product && product.product.pub_name}\n
\n
\n ISBN:{product && product.product && product.product.isbn}\n
\n
\n 出版时间:\n {product && product.product && product.product.publish_date}\n
\n
\n
\n
\n
\n
\n
\n
this.setImgVisible(false)}\n />\n\n {product &&\n product.borrow_images &&\n product.borrow_images.length >= 1 ? (\n \n
\n \n \n 书籍照片(\n {product &&\n product.borrow_images &&\n product.borrow_images.length}\n 张)\n \n
\n \n {imgsResult.length &&\n imgsResult.map((item, index) => {\n return (\n \n {item.map((itm, idx) => {\n return (\n this.getImgVal(itm)}\n fit=\"cover\"\n />\n );\n })}\n \n );\n })}\n \n \n ) : null}\n\n \n {verified ? (\n
this.goBack()}>下一本\n ) : (\n
\n this.goBack()}>\n 取消核验\n \n this.setCheckVisible()}>还书核验通过\n
\n )}\n
\n \n \n );\n }\n}\n\nexport default withRouter(ReturnBook);\n","import React, { Component } from \"react\";\nimport \"./shop.scss\";\nimport { withRouter } from \"react-router-dom\";\nimport { Image, Toast } from \"antd-mobile\";\nimport $https from \"../../../httpdata\";\nimport getParam from \"../../../utils/getParam\";\nimport Dialog from \"../../../components/dialog/dialog\";\nimport DialogTip from \"../../../components/dialogTip/dialogTip\";\nclass ReturnBook extends Component {\n constructor(props) {\n super(props);\n this.state = {\n backIcon: require(\"../../common/img/back-active.png\"),\n titleIcon: require(\"./img/titleIcon.png\"),\n borrowIcon: require(\"./img/borrowIcon.png\"),\n defaultAvatar: require(\"./img/defaultAvatar.png\"),\n infoRight: require(\"../../common/img/shop-info-right.png\"),\n alreadyReturn: require(\"./img/alreadyReturn.png\"),\n borrowing: require(\"./img/borrowing.png\"),\n verified: null,\n crossStore: require(\"./img/crossStore.png\"),\n order_sn: \"\",\n detailData: {},\n checkVisible: false,\n user_id: \"\",\n visibleTip: false,\n stationId: \"\",\n cont1: \"\",\n cont2: \"\",\n originalStoreData: null,\n btnClass: false,\n };\n }\n componentDidMount() {\n let that = this;\n\n window.onCommonData = async function (res) {\n that.setState(\n {\n stationId: res.stationId,\n },\n () => {\n that.getStoreDetail();\n }\n );\n };\n\n window.JXNative &&\n window.JXNative.postMessage &&\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"commonData\",\n })\n );\n this.setState(\n {\n order_sn: getParam(this.props.location.search, \"order_sn\"),\n user_id: getParam(this.props.location.search, \"user_id\"),\n },\n () => {\n this.getDetail();\n }\n );\n }\n getDetail() {\n const { order_sn, user_id } = this.state;\n $https\n .get(\"/api/staff/v1/order/shop/detail\", {\n order_sn,\n user_id,\n })\n .then((res) => {\n var verified;\n if (res.data.summary.order_status == \"WAIT_BUYER_CONFIRM_GOODS\") {\n verified = false;\n } else if (res.data.summary.order_status == \"TRADE_FINISHED\") {\n verified = true;\n }\n this.setState(\n {\n verified,\n detailData: res.data,\n },\n () => {\n console.log(\n document.body.getElementsByClassName(\"buyDetail\")[0].offsetHeight,\n document.body.clientHeight\n );\n if (\n document.body.getElementsByClassName(\"buyDetail\")[0]\n .offsetHeight < document.body.clientHeight\n ) {\n this.setState({\n btnClass: true,\n });\n }\n }\n );\n });\n }\n borrowCheck = () => {\n const { order_sn, user_id, stationId } = this.state;\n $https\n .post(\"/api/staff/v1/order/shop/check\", {\n order_sn,\n user_id,\n station_id: stationId,\n })\n .then((res) => {\n this.getDetail();\n this.setCheckVisible(false);\n if (res.msg == \"success\") {\n Toast.show({\n content: \"核验通过\",\n });\n } else {\n Toast.show({\n content: res.msg,\n });\n }\n });\n };\n goBack = () => {\n window.JXNative.postMessage(\n JSON.stringify({\n action: \"closeWeb\",\n })\n );\n };\n setCheckVisible = (val) => {\n this.setState({\n checkVisible: val,\n });\n };\n setCloseVisible = (val) => {\n this.setState({\n visibleTip: val,\n });\n };\n toBookDetail = (id) => {\n this.props.history.push({\n pathname: `/productDetail`,\n search: `goods_id=${id}&from=staff`,\n });\n };\n judgeDialog = () => {\n const { stationId, detailData, originalStoreData } = this.state;\n\n var id = detailData && detailData.station && detailData.station.id;\n\n if (stationId !== id) {\n this.setState(\n {\n cont2: `购买门店:${\n detailData && detailData.station && detailData.station.name\n }`,\n cont1: `核验门店:${originalStoreData && originalStoreData.name}`,\n },\n () => {\n this.setState({\n visibleTip: true,\n });\n }\n );\n } else {\n this.setState({\n checkVisible: true,\n });\n }\n };\n getStoreDetail = () => {\n const { stationId } = this.state;\n $https\n .get(\"/api/staff/v1/station\", {\n station_id: stationId,\n })\n .then((res) => {\n this.setState({ originalStoreData: res.data });\n });\n };\n render() {\n const {\n backIcon,\n titleIcon,\n borrowIcon,\n defaultAvatar,\n infoRight,\n verified,\n visibleTip,\n detailData,\n checkVisible,\n cont1,\n cont2,\n btnClass,\n } = this.state;\n\n return (\n