UNPKG

jimu-mobile

Version:

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

269 lines (234 loc) 11.8 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = undefined; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); var _class, _temp; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } // 引用方式: // <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="牛德华" /> var CarRecord = (_temp = _class = function (_Component) { _inherits(CarRecord, _Component); function CarRecord() { _classCallCheck(this, CarRecord); return _possibleConstructorReturn(this, (CarRecord.__proto__ || Object.getPrototypeOf(CarRecord)).apply(this, arguments)); } _createClass(CarRecord, [{ key: 'setDateFormat', value: function setDateFormat(date, fmt) { var 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 (var 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; } // 设置星期格式 }, { key: 'setWeekFormat', value: function setWeekFormat(time) { var week = { zh: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'], en: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'], enlong: ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'] }; var dayCn = week[this.props.weekFormat][time.getDay()]; return dayCn; } // 地址文字截取 }, { key: 'subFontChar', value: function subFontChar(name) { var num = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.props.drsFontLen; var re = /[0-9]|[a-z]|[A-Z]|\./; var length = 0; var 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; } // 名字文字截取 }, { key: 'changeName', value: function changeName(name) { var fontLen = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : this.props.nameFontLen; var subNum = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : this.props.nameSubstrLen; return name.length >= fontLen ? name.substr(0, subNum) + '...' : name; } }, { key: 'render', value: function render() { var _props = this.props, start_name = _props.start_name, end_name = _props.end_name, filedMap = _props.filedMap, create_time = _props.create_time, className = _props.className, use_car_type = _props.use_car_type, require_level = _props.require_level, pay_type = _props.pay_type, real_pay = _props.real_pay, tip_fee = _props.tip_fee, other_fee = _props.other_fee, realname = _props.realname, superAdmin = _props.superAdmin, drsFontLen = _props.drsFontLen, nameFontLen = _props.nameFontLen, nameSubstrLen = _props.nameSubstrLen, weekFormat = _props.weekFormat, weekShow = _props.weekShow, dateFormat = _props.dateFormat, others = _objectWithoutProperties(_props, ['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']); var 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 = (0, _classnames2.default)(_defineProperty({ 'car-record-list': true }, className, className)), Component = this.props.href ? 'a' : 'div'; return _react2.default.createElement( Component, _extends({ className: cls }, others), _react2.default.createElement( 'div', { className: 'record-head' }, _react2.default.createElement('span', { className: 'icon-time icon-jimu-time' }), _react2.default.createElement( 'span', { className: 'timer fz12' }, data ), superAdmin == 1 && _react2.default.createElement( 'span', { className: 'remark fz16' }, username ), use_car_type !== '2' && _react2.default.createElement( 'span', { className: 'remark fz11' }, filedMap.use_car_type[use_car_type] ), use_car_type === '2' && _react2.default.createElement( 'span', { className: 'remark fz11' }, filedMap.require_level[require_level] ), pay_type !== '0' && _react2.default.createElement( 'span', { className: 'remark fz11' }, filedMap.pay_type[pay_type] ) ), _react2.default.createElement( 'div', { className: 'wrapper wrapper-from-hook' }, _react2.default.createElement('span', { className: 'jimu-icon jimu-icon-location-point' }), _react2.default.createElement( 'span', { className: 'fz14 txt-from txt-from-hook default ml5' }, startName ) ), _react2.default.createElement( 'div', { className: 'wrapper wrapper-from-hook' }, _react2.default.createElement('span', { className: 'jimu-icon jimu-icon-location-point-red' }), _react2.default.createElement( 'span', { className: 'fz14 txt-from txt-from-hook default ml5' }, endName ) ), _react2.default.createElement( 'div', { className: 'car-record-cost' }, _react2.default.createElement( 'p', { className: 'main-cost fz16' }, _react2.default.createElement( 'span', null, real_pay ), '\u5143' ), Number(tip_fee) > 0 && _react2.default.createElement( 'p', { className: 'fz11' }, '\u5C0F\u8D39', tip_fee, '\u5143' ), Number(other_fee) > 0 && _react2.default.createElement( 'p', { className: 'fz11' }, '\u9644\u52A0\u8D39', other_fee, '\u5143' ) ) ); } }]); return CarRecord; }(_react.Component), _class.propTypes = { drsFontLen: _propTypes2.default.number, nameFontLen: _propTypes2.default.number, nameSubstrLen: _propTypes2.default.number, weekFormat: _propTypes2.default.string, weekShow: _propTypes2.default.bool, dateFormat: _propTypes2.default.string, className: _propTypes2.default.string, start_name: _propTypes2.default.string.isRequired, end_name: _propTypes2.default.string.isRequired, filedMap: _propTypes2.default.object.isRequired, create_time: _propTypes2.default.number.isRequired, use_car_type: _propTypes2.default.number.isRequired, require_level: _propTypes2.default.number.isRequired, pay_type: _propTypes2.default.number.isRequired, real_pay: _propTypes2.default.number.isRequired, tip_fee: _propTypes2.default.number.isRequired, other_fee: _propTypes2.default.number.isRequired, realname: _propTypes2.default.string.isRequired }, _class.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 }, _temp); exports.default = CarRecord;