UNPKG

jimu-mobile

Version:

积木组件库助力移动端开发

139 lines (128 loc) 6.03 kB
import React, { Component } from 'react'; import classNames from 'classnames'; import PropTypes from 'prop-types'; // 引用方式: // <CarRecord filedMap={{"pay_type":["企业支付","个人垫付","混合支付"],"use_car_type":{"1":"出租车","2":"专车","3":"快车","4":"代驾"},"use_car_srv":{"101":"出租车单次用车","201":"专车单次用车","202":"专车时租","203":"专车接机","204":"专车送机","301":"快车"},"require_level":{"100":"舒适型","200":"豪华型","400":"商务型","600":"普通型"}}} weekFormat="zh" drsFontLen={5} nameSubstrLen={3} weekShow={true} dateFormat="yyyy-mm-dd hh:ss" superAdmin={0} start_name="北京首都国际机场T2航站楼1" end_name="当代城市家园-东门" create_time={1430291523} use_car_type={2} require_level={600} pay_type={0} real_pay={0} tip_fee={10} other_fee={30} realname="牛德华" /> export default class CarRecord extends Component { static propTypes = { drsFontLen: PropTypes.number, nameFontLen: PropTypes.number, nameSubstrLen: PropTypes.number, weekFormat: PropTypes.string, weekShow: PropTypes.bool, dateFormat: PropTypes.string, className: PropTypes.string, start_name: PropTypes.string.isRequired, end_name: PropTypes.string.isRequired, filedMap: PropTypes.object.isRequired, create_time: PropTypes.number.isRequired, use_car_type: PropTypes.number.isRequired, require_level: PropTypes.number.isRequired, pay_type: PropTypes.number.isRequired, real_pay: PropTypes.number.isRequired, tip_fee: PropTypes.number.isRequired, other_fee: PropTypes.number.isRequired, realname: PropTypes.string.isRequired, } static defaultProps = { drsFontLen: 15, // 地址文字截取数 number nameFontLen: 5, // 人名文字截取判断数 number nameSubstrLen: 3, // 人名文字截取拼接数 number weekFormat: 'zh', // 星期名称格式 string (zh、en、enlong) weekShow: true, // 星期是否展示 bool dateFormat: 'yyyy-MM-dd hh:mm', // 日期格式 string ( yyyy-MM-dd hh:mm 、 yyyy/mm/dd hh:mm、 yyyy-MM-dd、 yyyy/mm/dd) } // 日期格式化 yyyy-MM-dd hh:mm ; yyyy/mm/dd hh:mm setDateFormat(date, fmt) { const o = { 'M+': date.getMonth() + 1, // 月份 'd+': date.getDate(), // 日 'h+': date.getHours(), // 小时 'm+': date.getMinutes(), // 分 's+': date.getSeconds(), // 秒 }; if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (`${date.getFullYear()}`).substr(4 - RegExp.$1.length)); for (const k in o) { if (new RegExp(`(${k})`).test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : ((`00${o[k]}`).substr((`${o[k]}`).length))); } return fmt; } // 设置星期格式 setWeekFormat(time) { const week = { zh: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'], en: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'], enlong: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'], }; const dayCn = week[this.props.weekFormat][time.getDay()]; return dayCn; } // 地址文字截取 subFontChar(name, num = this.props.drsFontLen) { const re = /[0-9]|[a-z]|[A-Z]|\./; let length = 0; let i = 0; if (name.length <= num) { return name; } for (i = 0; i < name.length; i++) { if (length > num) { break; } if (re.test(name[i])) { length += 0.5; } else { length += 1; } } return length > num ? `${name.substr(0, i - 1)}...` : name; } // 名字文字截取 changeName(name, fontLen = this.props.nameFontLen, subNum = this.props.nameSubstrLen) { return name.length >= fontLen ? `${name.substr(0, subNum)}...` : name; } render() { const { start_name, end_name, filedMap, create_time, className, use_car_type, require_level, pay_type, real_pay, tip_fee, other_fee, realname, superAdmin, drsFontLen, nameFontLen, nameSubstrLen, weekFormat, weekShow, dateFormat, ...others } = this.props; const username = this.changeName(realname), timeObj = new Date(create_time * 1000), data = !weekShow ? this.setDateFormat(timeObj, this.props.dateFormat) : `${this.setDateFormat(timeObj, this.props.dateFormat)} ${this.setWeekFormat(timeObj)}`, startName = start_name && this.subFontChar(start_name), endName = end_name && this.subFontChar(end_name), cls = classNames({ 'car-record-list': true, [className]: className, }), Component = this.props.href ? 'a' : 'div'; return ( <Component className={cls} {...others}> <div className="record-head"> <span className="icon-time icon-jimu-time" /> <span className="timer fz12">{data}</span> {superAdmin == 1 && <span className="remark fz16">{username}</span>} {use_car_type !== '2' && <span className="remark fz11">{filedMap.use_car_type[use_car_type]}</span>} {use_car_type === '2' && <span className="remark fz11">{filedMap.require_level[require_level]}</span>} {pay_type !== '0' && <span className="remark fz11">{filedMap.pay_type[pay_type]}</span>} </div> <div className="wrapper wrapper-from-hook"> <span className="jimu-icon jimu-icon-location-point" /> <span className="fz14 txt-from txt-from-hook default ml5">{startName}</span> </div> <div className="wrapper wrapper-from-hook"> <span className="jimu-icon jimu-icon-location-point-red" /> <span className="fz14 txt-from txt-from-hook default ml5">{endName}</span> </div> <div className="car-record-cost"> <p className="main-cost fz16"> <span>{real_pay}</span></p> {Number(tip_fee) > 0 && <p className="fz11">小费{tip_fee}元</p>} {Number(other_fee) > 0 && <p className="fz11">附加费{other_fee}元</p>} </div> </Component> ); } }