123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166 |
- import { a as _inherits, b as _classCallCheck, c as _possibleConstructorReturn, d as _getPrototypeOf, e as _createClass } from '../inherits-6cb67931.js';
- import React, { Component } from 'react';
- import { s as styleInject } from '../style-inject.es-1f59c1d0.js';
- import { _ as _defineProperty } from '../defineProperty-18999f8e.js';
- import { c as classnames } from '../index-e3cf212a.js';
- import { a as addImageProcess } from '../utils-6b513b37.js';
-
- var img = "";
-
- var css = ".ConsumeListView_wrapper__wlJjh {\n display: flex;\n justify-content: center;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR {\n padding: 0;\n margin: 0;\n display: flex;\n flex-wrap: wrap;\n padding-top: 10px;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR li {\n list-style: none;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_consumeItem__1QGpJ {\n margin: 0 6px 10px;\n text-align: center;\n position: relative;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_consumeItem__1QGpJ .ConsumeListView_kingdomIcon__1nBe5 {\n position: absolute;\n width: 24px;\n height: 22px;\n left: -6px;\n top: -12px;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_consumeItem__1QGpJ .ConsumeListView_avatar__1H-E5 {\n margin: 0 auto 4px;\n width: 36px;\n height: 36px;\n background-size: cover;\n border-radius: 50%;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_consumeItem__1QGpJ .ConsumeListView_gray__3do1I {\n color: #9b9b9b;\n font-size: 12px;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_toggle__3eBTC {\n margin: 0 6px 10px;\n width: 36px;\n height: 36px;\n line-height: 36px;\n background-color: #ececec;\n border-radius: 50%;\n color: #a8adb6;\n cursor: pointer;\n background-image: url();\n background-position: center;\n}\n.ConsumeListView_wrapper__wlJjh .ConsumeListView_consumelist__2dMCR .ConsumeListView_toggle__3eBTC.ConsumeListView_expand__3l80q {\n transform: rotate(180deg);\n}\n";
- var styles = {
- "wrapper": "ConsumeListView_wrapper__wlJjh",
- "consumelist": "ConsumeListView_consumelist__2dMCR",
- "consumeItem": "ConsumeListView_consumeItem__1QGpJ",
- "kingdomIcon": "ConsumeListView_kingdomIcon__1nBe5",
- "avatar": "ConsumeListView_avatar__1H-E5",
- "gray": "ConsumeListView_gray__3do1I",
- "toggle": "ConsumeListView_toggle__3eBTC",
- "expand": "ConsumeListView_expand__3l80q"
- };
- styleInject(css);
-
- var DEFAULT_AVATAR = '//links-comment.oss-cn-beijing.aliyuncs.com/comment/20180820/Kgka4_oU1.jpeg';
-
- var ConsumeListView =
-
- function (_Component) {
- _inherits(ConsumeListView, _Component);
-
- function ConsumeListView() {
- _classCallCheck(this, ConsumeListView);
-
- return _possibleConstructorReturn(this, _getPrototypeOf(ConsumeListView).apply(this, arguments));
- }
-
- _createClass(ConsumeListView, [{
- key: "renderConsumeItem",
- value: function renderConsumeItem() {
- var _this$props = this.props,
- dataSource = _this$props.dataSource,
- isToggle = _this$props.isToggle,
- onConsumeItemClick = _this$props.onConsumeItemClick,
- showLength = _this$props.showLength,
- listLength = _this$props.listLength,
- options = _this$props.options;
- var kingdomWidth = options.kingdomWidth,
- kingdomHeight = options.kingdomHeight,
- kingdomPosition = options.kingdomPosition,
- avatarSize = options.avatarSize,
- avatarMarginLeftAndRight = options.avatarMarginLeftAndRight;
- var renderData = dataSource;
-
- if (!isToggle && listLength > showLength) {
- renderData = dataSource.slice(0, showLength - 1);
- }
-
- return renderData.map(function (v, i) {
- var kingdom = null;
-
- if (i === 0) {
- kingdom = React.createElement("img", {
- className: styles.kingdomIcon,
- src: img,
- alt: "reward top user",
- style: {
- width: "".concat(kingdomWidth, "px"),
- height: "".concat(kingdomHeight, "px"),
- left: "".concat(kingdomPosition[0], "px"),
- top: "".concat(kingdomPosition[1], "px")
- }
- });
- }
-
- return React.createElement("li", {
- key: v.id,
- className: styles.consumeItem,
- style: {
- margin: "0 ".concat(avatarMarginLeftAndRight, "px 10px")
- }
- }, kingdom, React.createElement("div", {
- className: styles.avatar,
- onClick: function onClick(e) {
- return onConsumeItemClick(e, v);
- },
- style: {
- backgroundImage: "url(".concat(addImageProcess(v.user_avatar || DEFAULT_AVATAR, {
- small: true
- }), ")"),
- width: "".concat(avatarSize, "px"),
- height: "".concat(avatarSize, "px")
- }
- }), React.createElement("span", {
- className: styles.gray
- }));
- });
- }
- }, {
- key: "renderToggleButton",
- value: function renderToggleButton() {
- var _this$props2 = this.props,
- isToggle = _this$props2.isToggle,
- onToggleChange = _this$props2.onToggleChange,
- listLength = _this$props2.listLength,
- showLength = _this$props2.showLength,
- options = _this$props2.options;
- var avatarSize = options.avatarSize,
- avatarMarginLeftAndRight = options.avatarMarginLeftAndRight;
-
- if (listLength <= showLength) {
- return null;
- }
-
- return React.createElement("li", {
- onClick: function onClick() {
- return onToggleChange();
- },
- className: classnames(styles.toggle, _defineProperty({}, styles.expand, isToggle)),
- style: {
- width: "".concat(avatarSize, "px"),
- height: "".concat(avatarSize, "px"),
- lineHeight: "".concat(avatarSize, "px"),
- margin: "0 ".concat(avatarMarginLeftAndRight, "px 10px")
- }
- });
- }
- }, {
- key: "render",
- value: function render() {
- var _this$props3 = this.props,
- showLength = _this$props3.showLength,
- options = _this$props3.options;
- var avatarSize = options.avatarSize,
- avatarMarginLeftAndRight = options.avatarMarginLeftAndRight;
- return React.createElement("div", {
- className: styles.wrapper
- }, React.createElement("ul", {
- className: styles.consumelist,
- style: {
- width: "calc(".concat(avatarMarginLeftAndRight * 2 + avatarSize, "px * ").concat(showLength, ")")
- }
- }, this.renderConsumeItem(), this.renderToggleButton()));
- }
- }]);
-
- return ConsumeListView;
- }(Component);
-
- ConsumeListView.defaultProps = {
- isToggle: false,
- onToggleChange: function onToggleChange() {},
- onConsumeItemClick: function onConsumeItemClick() {},
- dataSource: [],
- listLength: 0,
- showLength: 6,
- options: {
- avatarSize: 36,
- avatarMarginLeftAndRight: 6,
- kingdomWidth: 24,
- kingdomHeight: 22,
- kingdomPosition: [-6, -12]
- }
- };
-
- export default ConsumeListView;
-
|