UserBrief.js 2.74 KB
'use strict';

import React from 'react';
import ReactNative from 'react-native';
import ImmutablePropTypes from 'react-immutable-proptypes';
import SlicedImage from '../../../common/components/SlicedImage';
import PropTypes from 'prop-types';
const {
    View,
    Text,
    Image,
    TouchableOpacity,
    StyleSheet,
    Dimensions,
    ViewPropTypes
} = ReactNative;

export default class UserBrief extends React.Component {

    static propTypes = {
        containerStyle: ViewPropTypes.style,
        avatar: PropTypes.string,
        name: PropTypes.string,
        timeago: PropTypes.string,
        isOwner: PropTypes.bool,
        onPressAvatar: PropTypes.func,
    };

    constructor(props) {
        super (props);


    }

    _renderUserName() {
        if (this.props.isOwner) {
            return (
                <Text style={styles.name} numberOfLines={1} onPress={() => {
                    this.props.onPressAvatar && this.props.onPressAvatar();
                }}>
                    {this.props.name + ' | '}
                    <Text style={styles.owner}>楼主</Text>
                </Text>
            );
        } else {
            return (
                <Text style={styles.name} numberOfLines={1} onPress={() => {
                    this.props.onPressAvatar && this.props.onPressAvatar();
                }}>
                    {this.props.name}
                </Text>
            );
        }
    }

    render() {
        return (
            <View style={[styles.container, this.props.containerStyle]}>
                <TouchableOpacity onPress={() => {
                    this.props.onPressAvatar && this.props.onPressAvatar();
                }}>
                    <SlicedImage style={styles.avatar} source={{uri: this.props.avatar}} resizeMode={'cover'} defaultSource={require('../../images/avatar/avatar_default.png')}/>
                </TouchableOpacity>

                <View style={styles.text}>
                    {this._renderUserName()}
                    {this.props.timeago ? <Text style={styles.timeago}>{this.props.timeago}</Text> : null}
                </View>
            </View>
        );
    }
}

let {width, height} = Dimensions.get('window');
let nameWidth = Math.ceil((260 / 750) * width);

let styles = StyleSheet.create({
    container: {
        flexDirection: 'row',
        alignItems: 'center',
    },
    avatar: {
        width: 30,
        height: 30,
        borderRadius: 15,
    },
    text: {
        marginLeft: 5,
    },
    name: {
        fontFamily: 'Helvetica Light',
        color: 'black',
        fontSize: 13,
        maxWidth: nameWidth,
    },
    owner: {
        color: '#4a90e2',
    },
    timeago: {
        fontFamily: 'Helvetica Light',
        color: '#b0b0b0',
        fontSize: 10,
    },
});