|
@@ -8,7 +8,7 @@ import EditTpl from "../../components/edit/index";
|
|
|
|
|
|
import { LevelList1 } from '../../components/LevelList1/index.jsx';
|
|
|
import { NumTostring } from '../../components/numTostring';
|
|
|
-
|
|
|
+var QRCode = require('qrcode.react');
|
|
|
|
|
|
class Industry extends React.Component {
|
|
|
state = {
|
|
@@ -65,7 +65,7 @@ class Industry extends React.Component {
|
|
|
...params,
|
|
|
params: {
|
|
|
pageNum: 1,
|
|
|
- pageSize: 50,
|
|
|
+ pageSize: 5000,
|
|
|
...e
|
|
|
}
|
|
|
}).then(res => {
|
|
@@ -117,6 +117,8 @@ class Industry extends React.Component {
|
|
|
}
|
|
|
}).then(res => {
|
|
|
const { config } = res;
|
|
|
+ const {data:{id = ''}} = config;
|
|
|
+ config.data.qrcode = id?`http://wxh5.gzqlyx.com/#/pages/product/product?id=${id}`:'';
|
|
|
this.setState({ ProductDetailsData: config, productSubscript });
|
|
|
});
|
|
|
}
|
|
@@ -147,12 +149,49 @@ class Industry extends React.Component {
|
|
|
//组件销毁
|
|
|
clearTimeout(this.carouselTime);
|
|
|
}
|
|
|
+ //进入内页
|
|
|
+ goLink = (e,i)=>{
|
|
|
+ //处理path 替换 页面 与 pId
|
|
|
+ let {match:{
|
|
|
+ path,
|
|
|
+ url
|
|
|
+ }} = this.props;
|
|
|
+ url = url.split("/");
|
|
|
+ path = path.split("/").map((x,i)=>{
|
|
|
+ const iu = url[i];
|
|
|
+ if(i == 1){
|
|
|
+ return "detail";
|
|
|
+ }
|
|
|
+ const k = x.indexOf(":"),
|
|
|
+ j = x.indexOf("?");
|
|
|
+ if (k != -1) {
|
|
|
+ x = x.substring(k + 1, j);
|
|
|
+ }
|
|
|
+ if (x == 'pId') {
|
|
|
+ return iu+"-"+e.id;
|
|
|
+ }
|
|
|
+ return iu;
|
|
|
+ }).join("/");
|
|
|
+ return path;
|
|
|
+ }
|
|
|
+ LevelList2Click(e){
|
|
|
+ const {data:{minTitle = [],firmId}} = this.state.ProductDetailsData;
|
|
|
+ if((minTitle[e] || {}).key === 'umsCompanyInfo'){
|
|
|
+ this.props.history.push(this.goLink({id:firmId}));
|
|
|
+ }
|
|
|
+ }
|
|
|
render() {
|
|
|
const { productSubscript, classificationListData, productListData, inputValue, ProductDetailsData, ProductDetailsData: { data: DetailsData } ,activeItem=0} = this.state,
|
|
|
p_list = (((productListData || {}).data || {}).list || []);
|
|
|
const PovertyAlleviationArticle = {
|
|
|
data: {
|
|
|
- list: ['brandName', 'spec', 'qualityGuaranteePeriod', 'placeOfProduction', 'umsCompanyInfo'].map((x, i) => {
|
|
|
+ list: (DetailsData.minTitle || []).map(x=>{
|
|
|
+ return {
|
|
|
+ title:x.name,
|
|
|
+ name:DetailsData[x.key]
|
|
|
+ }
|
|
|
+ }),
|
|
|
+ a:['brandName', 'spec', 'qualityGuaranteePeriod', 'placeOfProduction', 'umsCompanyInfo'].map((x, i) => {
|
|
|
const name = DetailsData[x];
|
|
|
if (name) {
|
|
|
return {
|
|
@@ -184,15 +223,15 @@ class Industry extends React.Component {
|
|
|
{p_list.map((x, i) => {
|
|
|
return (<li key={i} onClick={e => this.getProductDetails(x, i)}>
|
|
|
<div className={`${styles.ulListItem} ${productSubscript == i ? styles.hover : ''}`}>
|
|
|
- <div className={styles.img} style={{ backgroundImage: `url(${x.pic})` }}></div>
|
|
|
+ <div className={styles.img} style={{ backgroundImage: `url(${x.pic}?imageMogr2/quality/60/thumbnail/100x100)` }}></div>
|
|
|
<h3>{x.name}</h3>
|
|
|
<div className={"level-line"}></div>
|
|
|
<div className={styles.itemText}>
|
|
|
- {x.brandName ? <span>品牌:{x.brandName}</span> : ''}
|
|
|
- {x.price ? <span>零售价:{x.price}</span> : ''}
|
|
|
+ {x.brandName ? <span>品牌:{x.brandName || ''}</span> : ''}
|
|
|
+ {x.price ? <span key={x.spec}>规格:{x.spec || ''}</span> : ''}
|
|
|
</div>
|
|
|
{x.umsCompanyInfo ? <div className={styles.itemText}>
|
|
|
- <span>供应商:{x.umsCompanyInfo || ''}</span>
|
|
|
+ <span key={x.qualityGuaranteePeriod}>{x.qualityGuaranteePeriod?`保质期:${x.qualityGuaranteePeriod}`:'参考包装'}</span>
|
|
|
</div> : ''}
|
|
|
</div>
|
|
|
</li>)
|
|
@@ -206,9 +245,11 @@ class Industry extends React.Component {
|
|
|
<Box style={{ height: "58%", display: "flex" }}>
|
|
|
<div className={styles.productImges} style={{ backgroundImage: `url(${DetailsData.pic})` }}></div>
|
|
|
<div className={styles.productHref}>
|
|
|
+ {DetailsData.qrcode && <QRCode value={DetailsData.qrcode} style={{width:"10vw",height:"10vw"}} ></QRCode>}
|
|
|
+
|
|
|
<div className={styles.retailPrice}>{DetailsData.retailPriceTitle}</div>
|
|
|
- <div className={styles.NumTostring}>{DetailsData.priceIcon}<NumTostring>{DetailsData.price || ''}</NumTostring></div>
|
|
|
- <div className={styles.retailPrice}>{DetailsData.PurchaseLinkTitle}</div>
|
|
|
+ <div className={styles.NumTostring}><span style={{fontSize:"40px"}}>{DetailsData.priceIcon}{DetailsData.price || '暂无售价'}</span></div>
|
|
|
+ <div className={styles.retailPrice}>{(DetailsData.buyUrls || []).length?DetailsData.PurchaseLinkTitle:''}</div>
|
|
|
<div className={styles.BuyLink}>
|
|
|
{(DetailsData.buyUrls || []).map((x, i) => {
|
|
|
return (
|
|
@@ -222,13 +263,11 @@ class Industry extends React.Component {
|
|
|
<br />
|
|
|
<Title>{DetailsData.name}</Title>
|
|
|
<br />
|
|
|
- <LevelList2 data={PovertyAlleviationArticle}></LevelList2>
|
|
|
+ <LevelList2 active={(...e)=>this.LevelList2Click(...e)} data={PovertyAlleviationArticle}></LevelList2>
|
|
|
<br />
|
|
|
<Box no={true} style={{ flex: 1 }}>
|
|
|
<Title>{DetailsData.IntroductionTitle}</Title>
|
|
|
- <div className={styles.IntroductionInfo}>
|
|
|
- {DetailsData.description}
|
|
|
- </div>
|
|
|
+ <div className={styles.IntroductionInfo} dangerouslySetInnerHTML={{__html:DetailsData.description}}></div>
|
|
|
</Box>
|
|
|
</div>
|
|
|
</Box>
|