TripleImageSquare.js
4.54 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
import React, {Component } from 'react'
import {View, StyleSheet, Text, Dimensions,TouchableOpacity, Platform} from 'react-native';
import Immutable, {Map} from 'immutable';
import YH_Image from '../../../common/components/YH_Image';
export default class TripleImageSquare extends Component{
constructor(props) {
super(props);
}
shouldComponentUpdate(nextProps){
if (Immutable.is(nextProps.resource, this.props.resource)) {
return false;
} else {
return true;
}
}
render() {
let {resource} = this.props;
if (!resource) {
return (<View style={{height:0,width:width,backgroundColor:'white'}}/>);
}
let list = resource.get('module_data').get('data').toJS();
let properties = resource.get('module_data').get('properties').toJS();
let isModuleMargin = properties.isModuleMargin;
let displayType = properties.displayType;
if (!displayType) {
return (<View style={{height:0,width:width,backgroundColor:'red'}}/>);
};
let yh_exposureData = this.props.yh_exposureData?this.props.yh_exposureData:null;
let moduleOrder = resource.get('module_order') + 1;
let moduleType = resource.get('module_type');
let showProductInfo = true;
list.map((data, i) => {
let showProductInfoItem = data.showProductInfo?data.showProductInfo:false;
let product = data.product;
if (!product) {
showProductInfoItem= false;
}
if (!showProductInfoItem) {
showProductInfo = false;
}
});
return (
<View style={{flexDirection: 'row',width:width,height: isModuleMargin=='1'?containerHeigth+nullHeigth:containerHeigth,backgroundColor: '#f0f0f0'}}>
{list.map((data, i) => {
let backgroundImage = data?data.pic:'';
let linkType = data.linkType;
let product = data.product;
let title = data.text?data.text:'';
let salePrice = product?parseFloat(product.sales_price):0;
let originPrice = product?parseFloat(product.market_price):0;
let name = product?product.product_name:'';
let price = '¥' + salePrice.toFixed(2);
let sale = '¥' + originPrice.toFixed(2);
let saleAble = false;//salePrice>0?true:false;
let linkReource = data.resource;
let yh_exposureData = this.props.yh_exposureData?this.props.yh_exposureData:null;
let url = '';
if (linkType == '0') {
url = `http://m.yohobuy.com?openby:yohobuy={"action":"go.poollist","params":{"productPool":"${linkReource}","title":"${title}"}}`;
} else if (linkType == '1') {
url = `http://m.yohobuy.com?openby:yohobuy={"action":"go.productDetail","params":{"product_skn":"${linkReource}","from_page_name":"${Platform.OS === 'ios'?'iFP_RedPersonBrand':'aFP_RedPersonBrand'}","from_page_param":"${yh_exposureData?yh_exposureData.P_PARAM:null}"}}`;
} else if (linkType == '2') {
url = linkReource;
}
let new_yh_exposureData = null;
if (yh_exposureData){
new_yh_exposureData = {
I_INDEX: i,
ACTION_URL: url,
...yh_exposureData,
};
}
return (
<TouchableOpacity yh_exposureData={new_yh_exposureData} activeOpacity={1.0} key={'row'+i} style={styles.imagetype} onPress={() => {this.props.onPressProduct && this.props.onPressProduct(url,moduleOrder,moduleType,i+1)}} >
<YH_Image url={backgroundImage} style={[styles.imagetype,{resizeMode: 'contain'}]}/>
{linkType=='1' && showProductInfo?<View style={styles.maskContainer}>
<Text style={{marginTop: 2,marginLeft: 10,fontSize: 11,backgroundColor: 'transparent',color: saleAble?'red':'white',}}>{price}</Text>
{saleAble?<Text style={styles.deleteSale}>{sale}</Text>:null}
</View>:null}
</TouchableOpacity>
)
})}
</View>
)
}
}
let {width, height} = Dimensions.get('window');
let containerHeigth = width/3;
let maskHeight = 30;
let nullHeigth = 10;
let styles = StyleSheet.create({
maskContainer:{
position: 'absolute',
width: width/3,
height: 24,
backgroundColor: 'rgba(0,0,0,0.3)',
top: containerHeigth-24,
flexDirection: 'row',
alignItems: 'center',
flexDirection: 'row',
},
imagetype: {
width:width/3 ,
height:containerHeigth,
backgroundColor: '#f5f7f6',
},
deleteSale: {
marginLeft: 2,
marginTop: 4,
fontSize: 11,
backgroundColor: 'transparent',
color: 'white',
textDecorationLine: 'line-through',
},
});