tplus-member 3.28.1 → 3.28.6
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/member/ShopMember.less +17 -6
- package/dist/member/api.js +60 -57
- package/dist/member/api.js.map +1 -1
- package/dist/member/index.js +6 -9
- package/dist/member/index.js.map +1 -1
- package/dist/views/MemberStoreNew.less +0 -2
- package/package.json +28 -29
- package/dist/domain/member/AuthProcess.js +0 -40
- package/dist/domain/member/AuthProcess.js.map +0 -1
- package/dist/domain/member/CardCodeChangedProcessor.js +0 -35
- package/dist/domain/member/CardCodeChangedProcessor.js.map +0 -1
- package/dist/domain/member/CheckCardCodeAndCodeProcessor.js +0 -48
- package/dist/domain/member/CheckCardCodeAndCodeProcessor.js.map +0 -1
- package/dist/domain/member/CheckMobilephoneFormatProcessor.js +0 -38
- package/dist/domain/member/CheckMobilephoneFormatProcessor.js.map +0 -1
- package/dist/domain/member/CheckPresentAmountProcessor.js +0 -99
- package/dist/domain/member/CheckPresentAmountProcessor.js.map +0 -1
- package/dist/domain/member/EffectiveDateChangedProcessor.js +0 -57
- package/dist/domain/member/EffectiveDateChangedProcessor.js.map +0 -1
- package/dist/domain/member/GetThisPresentAmountProcessor.js +0 -112
- package/dist/domain/member/GetThisPresentAmountProcessor.js.map +0 -1
- package/dist/domain/member/InitDataProcessor.js +0 -153
- package/dist/domain/member/InitDataProcessor.js.map +0 -1
- package/dist/domain/member/IsMemberEffectiveProcessor.js +0 -45
- package/dist/domain/member/IsMemberEffectiveProcessor.js.map +0 -1
- package/dist/domain/member/IsMemberEnableProcessor.js +0 -42
- package/dist/domain/member/IsMemberEnableProcessor.js.map +0 -1
- package/dist/domain/member/IsMemberExpirationProcessor.js +0 -46
- package/dist/domain/member/IsMemberExpirationProcessor.js.map +0 -1
- package/dist/domain/member/IsMemberPasswordSameProcessor.js +0 -41
- package/dist/domain/member/IsMemberPasswordSameProcessor.js.map +0 -1
- package/dist/domain/member/IsMemberStorageForStoreProcessor.js +0 -46
- package/dist/domain/member/IsMemberStorageForStoreProcessor.js.map +0 -1
- package/dist/domain/member/MemberTypeChangedProcessor.js +0 -127
- package/dist/domain/member/MemberTypeChangedProcessor.js.map +0 -1
- package/dist/domain/member/MobilephoneChangedProcessor.js +0 -39
- package/dist/domain/member/MobilephoneChangedProcessor.js.map +0 -1
- package/dist/domain/member/PersonProcesser.js +0 -35
- package/dist/domain/member/PersonProcesser.js.map +0 -1
- package/dist/domain/member/PriuserdefChangedProcessor.js +0 -50
- package/dist/domain/member/PriuserdefChangedProcessor.js.map +0 -1
- package/dist/domain/operationLog/AddLogProcessor.js +0 -46
- package/dist/domain/operationLog/AddLogProcessor.js.map +0 -1
- package/dist/domain/operationLog/OperationConfig.js +0 -34
- package/dist/domain/operationLog/OperationConfig.js.map +0 -1
- package/dist/domain/operationLog/OperationLog.js +0 -170
- package/dist/domain/operationLog/OperationLog.js.map +0 -1
- package/dist/member/ShopMember.js +0 -1087
- package/dist/member/ShopMember.js.map +0 -1
- package/dist/member/memberMenu/changeMemberCard/index.js +0 -260
- package/dist/member/memberMenu/changeMemberCard/index.js.map +0 -1
- package/dist/member/memberMenu/index.js +0 -720
- package/dist/member/memberMenu/index.js.map +0 -1
- package/dist/member/memberMenu/modifyPass/index.js +0 -391
- package/dist/member/memberMenu/modifyPass/index.js.map +0 -1
- package/dist/member/memberMenu/modifyPass/store.js +0 -330
- package/dist/member/memberMenu/modifyPass/store.js.map +0 -1
- package/dist/member/memberTab.js +0 -560
- package/dist/member/memberTab.js.map +0 -1
- package/dist/stores/MemberStore.js +0 -536
- package/dist/stores/MemberStore.js.map +0 -1
- package/dist/stores/index.js +0 -16
- package/dist/stores/index.js.map +0 -1
- package/dist/viewController/MemberOrderViewController.js +0 -144
- package/dist/viewController/MemberOrderViewController.js.map +0 -1
- package/dist/viewDoMain/CheckMemberProcessorBlock.js +0 -56
- package/dist/viewDoMain/CheckMemberProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/CheckMemberStorageProcessorBlock.js +0 -85
- package/dist/viewDoMain/CheckMemberStorageProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/CheckSelectMemberProcessorBlock.js +0 -69
- package/dist/viewDoMain/CheckSelectMemberProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/CheckUpdatePasswordProcessorBlock.js +0 -44
- package/dist/viewDoMain/CheckUpdatePasswordProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/MemberDataChangedProcessorBlock.js +0 -66
- package/dist/viewDoMain/MemberDataChangedProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/MemberDataPreSaveProcessorBlock.js +0 -79
- package/dist/viewDoMain/MemberDataPreSaveProcessorBlock.js.map +0 -1
- package/dist/viewDoMain/StorageAmountChangedProcessorBlock.js +0 -136
- package/dist/viewDoMain/StorageAmountChangedProcessorBlock.js.map +0 -1
- package/dist/viewModels/memberVoucher.js +0 -269
- package/dist/viewModels/memberVoucher.js.map +0 -1
- package/dist/views/MemberOrderView.js +0 -438
- package/dist/views/MemberOrderView.js.map +0 -1
- package/dist/views/MemberStoreNewView.js +0 -538
- package/dist/views/MemberStoreNewView.js.map +0 -1
- package/dist/views/MemberStoreView.js +0 -441
- package/dist/views/MemberStoreView.js.map +0 -1
- package/dist/views/MemberStoreViewContainer.js +0 -72
- package/dist/views/MemberStoreViewContainer.js.map +0 -1
- package/dist/views/PresetDetailView.js +0 -88
- package/dist/views/PresetDetailView.js.map +0 -1
package/dist/member/memberTab.js
DELETED
@@ -1,560 +0,0 @@
|
|
1
|
-
'use strict';
|
2
|
-
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
4
|
-
value: true
|
5
|
-
});
|
6
|
-
exports.default = undefined;
|
7
|
-
|
8
|
-
var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
|
9
|
-
|
10
|
-
var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
|
11
|
-
|
12
|
-
var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
|
13
|
-
|
14
|
-
var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
|
15
|
-
|
16
|
-
var _keys = require('babel-runtime/core-js/object/keys');
|
17
|
-
|
18
|
-
var _keys2 = _interopRequireDefault(_keys);
|
19
|
-
|
20
|
-
var _extends2 = require('babel-runtime/helpers/extends');
|
21
|
-
|
22
|
-
var _extends3 = _interopRequireDefault(_extends2);
|
23
|
-
|
24
|
-
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
|
25
|
-
|
26
|
-
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
|
27
|
-
|
28
|
-
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
|
29
|
-
|
30
|
-
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
|
31
|
-
|
32
|
-
var _createClass2 = require('babel-runtime/helpers/createClass');
|
33
|
-
|
34
|
-
var _createClass3 = _interopRequireDefault(_createClass2);
|
35
|
-
|
36
|
-
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
|
37
|
-
|
38
|
-
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
|
39
|
-
|
40
|
-
var _inherits2 = require('babel-runtime/helpers/inherits');
|
41
|
-
|
42
|
-
var _inherits3 = _interopRequireDefault(_inherits2);
|
43
|
-
|
44
|
-
var _tabs = require('antd/es/tabs');
|
45
|
-
|
46
|
-
var _tabs2 = _interopRequireDefault(_tabs);
|
47
|
-
|
48
|
-
var _class, _class2, _temp, _initialiseProps;
|
49
|
-
|
50
|
-
require('antd/es/tabs/style');
|
51
|
-
|
52
|
-
var _react = require('react');
|
53
|
-
|
54
|
-
var _react2 = _interopRequireDefault(_react);
|
55
|
-
|
56
|
-
var _mobxReact = require('mobx-react');
|
57
|
-
|
58
|
-
var _mutantsMicrofx = require('mutants-microfx');
|
59
|
-
|
60
|
-
var _tplusComponentsTouch = require('tplus-components-touch');
|
61
|
-
|
62
|
-
var _utils = require('../utils');
|
63
|
-
|
64
|
-
var _propTypes = require('prop-types');
|
65
|
-
|
66
|
-
var _propTypes2 = _interopRequireDefault(_propTypes);
|
67
|
-
|
68
|
-
var _mutantsUtil = require('mutants-util');
|
69
|
-
|
70
|
-
require('./ShopMember.less');
|
71
|
-
|
72
|
-
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
73
|
-
|
74
|
-
var TabPane = _tabs2.default.TabPane;
|
75
|
-
|
76
|
-
|
77
|
-
var transform = {
|
78
|
-
Code: '会员编号',
|
79
|
-
CardCode: '会员卡号',
|
80
|
-
Name: '会员姓名',
|
81
|
-
MemberTypeName: '会员类型',
|
82
|
-
Mobilephone: '手机号',
|
83
|
-
Telephone: '联系电话',
|
84
|
-
StoreName: '开卡门店',
|
85
|
-
sex: '性别',
|
86
|
-
BirthDate: '出生日期',
|
87
|
-
TotalIntegral: '累计积分',
|
88
|
-
BalanceIntegral: '积分余额',
|
89
|
-
BalanceStorage: '当前总余额',
|
90
|
-
TotalStorage: '储值总额', // 字段存疑
|
91
|
-
TotalBegin: '期初余额',
|
92
|
-
EffectiveDate: '生效日期',
|
93
|
-
ExpirationDate: '失效日期',
|
94
|
-
UmemberOpenId: '是否关注微信号',
|
95
|
-
UmemberLabel: '会员标签',
|
96
|
-
MemberCouponTitle: '优惠券',
|
97
|
-
Memo: '备注'
|
98
|
-
};
|
99
|
-
|
100
|
-
var MemberTab = (0, _mobxReact.observer)(_class = (_temp = _class2 = function (_Component) {
|
101
|
-
(0, _inherits3.default)(MemberTab, _Component);
|
102
|
-
|
103
|
-
function MemberTab(props) {
|
104
|
-
(0, _classCallCheck3.default)(this, MemberTab);
|
105
|
-
|
106
|
-
var _this = (0, _possibleConstructorReturn3.default)(this, (MemberTab.__proto__ || (0, _getPrototypeOf2.default)(MemberTab)).call(this, props));
|
107
|
-
|
108
|
-
_initialiseProps.call(_this);
|
109
|
-
|
110
|
-
var _ref = _mutantsMicrofx.localStore.get('user') || {},
|
111
|
-
_ref$loginInfo = _ref.loginInfo;
|
112
|
-
|
113
|
-
_ref$loginInfo = _ref$loginInfo === undefined ? {} : _ref$loginInfo;
|
114
|
-
var IsEnableUMember = _ref$loginInfo.IsEnableUMember;
|
115
|
-
|
116
|
-
_this.state = { IsEnableUMember: !!IsEnableUMember };
|
117
|
-
return _this;
|
118
|
-
}
|
119
|
-
|
120
|
-
(0, _createClass3.default)(MemberTab, [{
|
121
|
-
key: 'componentDidMount',
|
122
|
-
value: function componentDidMount() {
|
123
|
-
this.overflowTip = new _tplusComponentsTouch.OverflowTip({
|
124
|
-
target: '.member-content-tab',
|
125
|
-
format: function format(text) {
|
126
|
-
text = text || '';
|
127
|
-
var colonStr = ':';
|
128
|
-
if (text.startsWith(colonStr)) {
|
129
|
-
return text.split(colonStr)[1];
|
130
|
-
}
|
131
|
-
return text;
|
132
|
-
}
|
133
|
-
});
|
134
|
-
}
|
135
|
-
}, {
|
136
|
-
key: 'componentDidUpdate',
|
137
|
-
value: function componentDidUpdate() {
|
138
|
-
if (this.overflowTip && !this.overflowTip.containerDom) {
|
139
|
-
this.overflowTip.update();
|
140
|
-
}
|
141
|
-
}
|
142
|
-
}, {
|
143
|
-
key: 'componentWillUnmount',
|
144
|
-
value: function componentWillUnmount() {
|
145
|
-
this.overflowTip.destroy();
|
146
|
-
}
|
147
|
-
}, {
|
148
|
-
key: 'render',
|
149
|
-
value: function render() {
|
150
|
-
var _props$defaultActiveK = this.props.defaultActiveKey,
|
151
|
-
defaultActiveKey = _props$defaultActiveK === undefined ? '1' : _props$defaultActiveK;
|
152
|
-
|
153
|
-
return _react2.default.createElement(
|
154
|
-
_tabs2.default,
|
155
|
-
{
|
156
|
-
defaultActiveKey: defaultActiveKey,
|
157
|
-
onChange: this.props.onChange,
|
158
|
-
className: 'member-table-container'
|
159
|
-
},
|
160
|
-
this.memberInfoEle({ title: '会员信息', key: '1' }),
|
161
|
-
this.rmecommendEle({ title: '智能推荐', key: '2' }),
|
162
|
-
this.recentlyEle({ title: '最近购买', key: '3' })
|
163
|
-
);
|
164
|
-
}
|
165
|
-
}]);
|
166
|
-
return MemberTab;
|
167
|
-
}(_react.Component), _class2.propTypes = {
|
168
|
-
memberTabHeight: _propTypes2.default.number,
|
169
|
-
defaultActiveKey: _propTypes2.default.any,
|
170
|
-
memberList: _propTypes2.default.array,
|
171
|
-
columnInfo: _propTypes2.default.array,
|
172
|
-
member: _propTypes2.default.object,
|
173
|
-
memberInfo: _propTypes2.default.object,
|
174
|
-
precisionInfo: _propTypes2.default.object,
|
175
|
-
initEmpty: _propTypes2.default.bool,
|
176
|
-
onChange: _propTypes2.default.func
|
177
|
-
}, _initialiseProps = function _initialiseProps() {
|
178
|
-
var _this2 = this;
|
179
|
-
|
180
|
-
this.tabHeadHeight = 37;
|
181
|
-
|
182
|
-
this.dataClear = function (keys, values, columnInfo) {
|
183
|
-
var regKey = 'priuserdef';
|
184
|
-
var dataSource = [];
|
185
|
-
keys.forEach(function (key, index) {
|
186
|
-
if (key.includes(regKey)) {
|
187
|
-
var _ref2 = columnInfo.find(function (v) {
|
188
|
-
return v.FieldName === key;
|
189
|
-
}) || {},
|
190
|
-
label = _ref2.Title;
|
191
|
-
|
192
|
-
dataSource.push({ key: key, value: values[index], label: label });
|
193
|
-
}
|
194
|
-
});
|
195
|
-
return dataSource.filter(function (v) {
|
196
|
-
return v.label;
|
197
|
-
});
|
198
|
-
};
|
199
|
-
|
200
|
-
this.memberInfoEle = function (_ref3) {
|
201
|
-
var title = _ref3.title,
|
202
|
-
key = _ref3.key;
|
203
|
-
|
204
|
-
var _ref4 = _mutantsUtil.platform || {},
|
205
|
-
isNewRetailBCPos = _ref4.isNewRetailBCPos;
|
206
|
-
|
207
|
-
var _props = _this2.props,
|
208
|
-
_props$member = _props.member,
|
209
|
-
member = _props$member === undefined ? {} : _props$member,
|
210
|
-
memberTabHeight = _props.memberTabHeight,
|
211
|
-
_props$memberList = _props.memberList,
|
212
|
-
memberList = _props$memberList === undefined ? [] : _props$memberList,
|
213
|
-
_props$columnInfo = _props.columnInfo,
|
214
|
-
columnInfo = _props$columnInfo === undefined ? [] : _props$columnInfo,
|
215
|
-
_props$precisionInfo = _props.precisionInfo,
|
216
|
-
precisionInfo = _props$precisionInfo === undefined ? {} : _props$precisionInfo,
|
217
|
-
getMemberStateStamp = _props.getMemberStateStamp;
|
218
|
-
var IsEnableUMember = _this2.state.IsEnableUMember;
|
219
|
-
var _member$DynamicProper = member.DynamicPropertyKeys,
|
220
|
-
DynamicPropertyKeys = _member$DynamicProper === undefined ? [] : _member$DynamicProper,
|
221
|
-
_member$DynamicProper2 = member.DynamicPropertyValues,
|
222
|
-
DynamicPropertyValues = _member$DynamicProper2 === undefined ? [] : _member$DynamicProper2,
|
223
|
-
_member$ExpirationDat = member.ExpirationDate,
|
224
|
-
ExpirationDate = _member$ExpirationDat === undefined ? '' : _member$ExpirationDat,
|
225
|
-
_member$MemberType = member.MemberType;
|
226
|
-
_member$MemberType = _member$MemberType === undefined ? {} : _member$MemberType;
|
227
|
-
var MemberTypeName = _member$MemberType.Name,
|
228
|
-
_member$Sex = member.Sex;
|
229
|
-
_member$Sex = _member$Sex === undefined ? {} : _member$Sex;
|
230
|
-
var sex = _member$Sex.Name,
|
231
|
-
isExpiration = member.isExpiration,
|
232
|
-
Uid = member.Uid,
|
233
|
-
isUserLogout = member.isUserLogout,
|
234
|
-
MemberState = member.MemberState,
|
235
|
-
_member$Store = member.Store;
|
236
|
-
_member$Store = _member$Store === undefined ? {} : _member$Store;
|
237
|
-
var StoreName = _member$Store.Name;
|
238
|
-
|
239
|
-
var priuserdefData = _this2.dataClear(DynamicPropertyKeys, DynamicPropertyValues, columnInfo);
|
240
|
-
var isUMember = IsEnableUMember && Uid > 0; // 判断为u会员
|
241
|
-
var isUMemberShow = ['UmemberOpenId', 'UmemberLabel', 'MemberCouponTitle'];
|
242
|
-
var memberValues = (0, _extends3.default)({ MemberTypeName: MemberTypeName, sex: sex, StoreName: StoreName }, member);
|
243
|
-
var memberInfos = [];
|
244
|
-
var memberTabContentHeight = memberTabHeight - _this2.tabHeadHeight;
|
245
|
-
var hasMemberInfo = (0, _keys2.default)(memberValues).some(function (v) {
|
246
|
-
return memberValues[v];
|
247
|
-
});
|
248
|
-
|
249
|
-
var _enumController$getEn = _mutantsUtil.enumController.getEnumOj(),
|
250
|
-
Differentiate = _enumController$getEn.Differentiate;
|
251
|
-
|
252
|
-
var CC_NOT_DISPLAY = ["Code", "ExpirationDate", "UmemberOpenId", "UmemberLabel"];
|
253
|
-
|
254
|
-
transform.MemberCouponTitle = Differentiate.COUPON;
|
255
|
-
transform.MemberTypeName = Differentiate.MemberTypeName;
|
256
|
-
(0, _keys2.default)(transform).forEach(function (v) {
|
257
|
-
// 查找CC不需要显示的字段
|
258
|
-
var isHaveCCNot = CC_NOT_DISPLAY.find(function (item) {
|
259
|
-
return item == v;
|
260
|
-
});
|
261
|
-
if (isNewRetailBCPos && isHaveCCNot) return;
|
262
|
-
if (isUMemberShow.includes(v) && !isNewRetailBCPos && !isUMember) return;
|
263
|
-
var memberValue = memberValues[v];
|
264
|
-
var precision = precisionInfo[v];
|
265
|
-
//let value = formatPrecisionKeys.includes(v) ? (hasMemberInfo ? formatPrecision(memberValue, precision) : undefined) : memberValue;
|
266
|
-
var value = !!precision ? hasMemberInfo ? (0, _utils.formatPrecision)(memberValue, precision) : undefined : memberValue;
|
267
|
-
v === 'UmemberOpenId' && (value = memberValue ? '已关注' : '未关注');
|
268
|
-
var dataItem = { label: '' + transform[v], value: value };
|
269
|
-
memberInfos.push(dataItem);
|
270
|
-
});
|
271
|
-
|
272
|
-
//对自定义项的值进行处理。
|
273
|
-
if (priuserdefData && priuserdefData.length > 0) {
|
274
|
-
priuserdefData.map(function (item) {
|
275
|
-
var _ref5 = item || {},
|
276
|
-
key = _ref5.key,
|
277
|
-
value = _ref5.value;
|
278
|
-
|
279
|
-
var precision = precisionInfo[key];
|
280
|
-
item['value'] = !!precision ? (0, _utils.formatPrecision)(value, precision) : value;
|
281
|
-
});
|
282
|
-
}
|
283
|
-
|
284
|
-
memberInfos.push.apply(memberInfos, (0, _toConsumableArray3.default)(priuserdefData)); // 插入会员自定义项
|
285
|
-
memberInfos.length % 2 && memberInfos.push({}); //奇数补全
|
286
|
-
|
287
|
-
var formatValue = function formatValue(label, value) {
|
288
|
-
var formatDateKeys = ['出生日期', '失效日期', '生效日期'];
|
289
|
-
if (formatDateKeys.includes(label)) {
|
290
|
-
return (0, _utils.dateFormat)(value);
|
291
|
-
} else {
|
292
|
-
return value;
|
293
|
-
}
|
294
|
-
};
|
295
|
-
//状态戳
|
296
|
-
var iconItems = getMemberStateStamp(member);
|
297
|
-
return _react2.default.createElement(
|
298
|
-
TabPane,
|
299
|
-
{ tab: title, key: key },
|
300
|
-
_react2.default.createElement(
|
301
|
-
'div',
|
302
|
-
{ style: { height: memberTabContentHeight, position: 'relative' } },
|
303
|
-
_react2.default.createElement(
|
304
|
-
_tplusComponentsTouch.TouchScroll,
|
305
|
-
{ height: memberTabContentHeight },
|
306
|
-
!!memberList.length && _react2.default.createElement(
|
307
|
-
'div',
|
308
|
-
{ className: 'member-info-table' },
|
309
|
-
memberInfos.map(function (item, index) {
|
310
|
-
return _react2.default.createElement(
|
311
|
-
'div',
|
312
|
-
{ key: index },
|
313
|
-
item.label && _react2.default.createElement(
|
314
|
-
'span',
|
315
|
-
null,
|
316
|
-
item.label || ''
|
317
|
-
),
|
318
|
-
item.label && _react2.default.createElement(
|
319
|
-
'span',
|
320
|
-
{ 'data-overflow': 'tip' },
|
321
|
-
'\uFF1A',
|
322
|
-
formatValue(item.label, item.value)
|
323
|
-
)
|
324
|
-
);
|
325
|
-
}),
|
326
|
-
!memberInfos.length && _react2.default.createElement(
|
327
|
-
'p',
|
328
|
-
{ className: 'empty-data' },
|
329
|
-
'\u6682\u65E0\u6570\u636E~'
|
330
|
-
)
|
331
|
-
),
|
332
|
-
!memberList.length && _react2.default.createElement('div', { className: 'empty-data empty-data-img' })
|
333
|
-
),
|
334
|
-
iconItems && iconItems.length > 0 && _react2.default.createElement(
|
335
|
-
'div',
|
336
|
-
{ className: 'memberstate-detail-stamp' },
|
337
|
-
iconItems
|
338
|
-
)
|
339
|
-
)
|
340
|
-
);
|
341
|
-
};
|
342
|
-
|
343
|
-
this.rmecommendEle = function (_ref6) {
|
344
|
-
var title = _ref6.title,
|
345
|
-
key = _ref6.key;
|
346
|
-
var _props2 = _this2.props,
|
347
|
-
_props2$recommend = _props2.recommend,
|
348
|
-
recommends = _props2$recommend === undefined ? [] : _props2$recommend,
|
349
|
-
_props2$memberInfo = _props2.memberInfo;
|
350
|
-
_props2$memberInfo = _props2$memberInfo === undefined ? {} : _props2$memberInfo;
|
351
|
-
var _props2$memberInfo$re = _props2$memberInfo.record,
|
352
|
-
record = _props2$memberInfo$re === undefined ? [] : _props2$memberInfo$re,
|
353
|
-
_props2$memberInfo$li = _props2$memberInfo.like,
|
354
|
-
like = _props2$memberInfo$li === undefined ? [] : _props2$memberInfo$li,
|
355
|
-
memberTabHeight = _props2.memberTabHeight,
|
356
|
-
initEmpty = _props2.initEmpty;
|
357
|
-
|
358
|
-
recommends = recommends.filter(function (v) {
|
359
|
-
return v;
|
360
|
-
});
|
361
|
-
recommends.push({ Name: '最近购买', Value: like });
|
362
|
-
var recommendInfoHeight = 74;
|
363
|
-
var memberTabContentHeight = memberTabHeight - _this2.tabHeadHeight;
|
364
|
-
var haveRecord = !!record.length && record.every(function (v) {
|
365
|
-
return !!(v && v.value);
|
366
|
-
});
|
367
|
-
console.log('会员偶发白屏问题:recommends==', recommends);
|
368
|
-
var emptyRecommend = recommends.every(function (v) {
|
369
|
-
return !(v && v.Value || []).length;
|
370
|
-
}) ? _react2.default.createElement(
|
371
|
-
'div',
|
372
|
-
{ className: 'empty-data' },
|
373
|
-
'\u6682\u65E0\u63A8\u8350~'
|
374
|
-
) : null;
|
375
|
-
var emptyData = !haveRecord && recommends.every(function (v) {
|
376
|
-
return !(v && v.Value || []).length;
|
377
|
-
}) ? _react2.default.createElement('div', { className: 'empty-data empty-data-img' }) : null;
|
378
|
-
var showInfos = ['最近购买时间', '金额', '平均客单价'];
|
379
|
-
var recordFilter = record.filter(function (v) {
|
380
|
-
return showInfos.includes(v.name);
|
381
|
-
});
|
382
|
-
var recommendHeight = haveRecord ? memberTabContentHeight - recommendInfoHeight : memberTabContentHeight;
|
383
|
-
return _react2.default.createElement(
|
384
|
-
TabPane,
|
385
|
-
{ tab: title, key: key },
|
386
|
-
_react2.default.createElement(
|
387
|
-
'div',
|
388
|
-
{ className: 'recommend-tab', style: { height: memberTabContentHeight } },
|
389
|
-
haveRecord && _react2.default.createElement(
|
390
|
-
'div',
|
391
|
-
{ className: 'recommend-info' },
|
392
|
-
recordFilter.map(function (item, key) {
|
393
|
-
return _react2.default.createElement(
|
394
|
-
'span',
|
395
|
-
{ key: key },
|
396
|
-
item.name,
|
397
|
-
': ',
|
398
|
-
item.value
|
399
|
-
);
|
400
|
-
})
|
401
|
-
),
|
402
|
-
_react2.default.createElement(
|
403
|
-
'div',
|
404
|
-
{ className: 'recommend-connent', style: { height: recommendHeight } },
|
405
|
-
_react2.default.createElement(
|
406
|
-
_tplusComponentsTouch.TouchScroll,
|
407
|
-
{ height: recommendHeight, key: recommendHeight },
|
408
|
-
recommends.map(function (item, index) {
|
409
|
-
if (!(item.Value || []).length) return null;
|
410
|
-
return _react2.default.createElement(
|
411
|
-
'div',
|
412
|
-
{ key: index, className: 'detail-content' },
|
413
|
-
_react2.default.createElement(
|
414
|
-
'h1',
|
415
|
-
null,
|
416
|
-
item.Name
|
417
|
-
),
|
418
|
-
_react2.default.createElement(_tplusComponentsTouch.CardList, {
|
419
|
-
list: item.Value || [],
|
420
|
-
maxEmpyt: 5
|
421
|
-
})
|
422
|
-
);
|
423
|
-
})
|
424
|
-
),
|
425
|
-
initEmpty && emptyRecommend
|
426
|
-
),
|
427
|
-
initEmpty && emptyData
|
428
|
-
)
|
429
|
-
);
|
430
|
-
};
|
431
|
-
|
432
|
-
this.recentlyEle = function (_ref7) {
|
433
|
-
var title = _ref7.title,
|
434
|
-
key = _ref7.key;
|
435
|
-
var _props3 = _this2.props,
|
436
|
-
memberTabHeight = _props3.memberTabHeight,
|
437
|
-
_props3$memberInfo = _props3.memberInfo;
|
438
|
-
_props3$memberInfo = _props3$memberInfo === undefined ? {} : _props3$memberInfo;
|
439
|
-
var _props3$memberInfo$re = _props3$memberInfo.recency,
|
440
|
-
recency = _props3$memberInfo$re === undefined ? [] : _props3$memberInfo$re;
|
441
|
-
|
442
|
-
var theadHeight = 50;
|
443
|
-
var tableHeight = memberTabHeight - _this2.tabHeadHeight;
|
444
|
-
var dataSource = [];
|
445
|
-
var data = recency;
|
446
|
-
data.forEach(function (vlaue, i) {
|
447
|
-
var index = dataSource.findIndex(function (v) {
|
448
|
-
return v.code === vlaue.Code;
|
449
|
-
});
|
450
|
-
if (~index) {
|
451
|
-
dataSource[index].data.push(vlaue);
|
452
|
-
} else {
|
453
|
-
var _ref8 = vlaue || {},
|
454
|
-
Time = _ref8.Time,
|
455
|
-
Code = _ref8.Code,
|
456
|
-
rest = (0, _objectWithoutProperties3.default)(_ref8, ['Time', 'Code']);
|
457
|
-
|
458
|
-
var itemValue = { date: Time, code: Code, data: [rest] };
|
459
|
-
dataSource.push(itemValue);
|
460
|
-
}
|
461
|
-
});
|
462
|
-
|
463
|
-
dataSource.forEach(function (value) {
|
464
|
-
// 金额倒序排序
|
465
|
-
var itemData = value.data;
|
466
|
-
if (itemData.length > 1) {
|
467
|
-
itemData.sort(function () {
|
468
|
-
var a = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
469
|
-
var b = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
470
|
-
return b.Amount - a.Amount;
|
471
|
-
});
|
472
|
-
}
|
473
|
-
});
|
474
|
-
|
475
|
-
return _react2.default.createElement(
|
476
|
-
TabPane,
|
477
|
-
{ tab: title, key: key },
|
478
|
-
!!dataSource.length && _react2.default.createElement(
|
479
|
-
'div',
|
480
|
-
{ className: 'recently-tab' },
|
481
|
-
_react2.default.createElement(
|
482
|
-
'table',
|
483
|
-
{ className: 'table' },
|
484
|
-
_react2.default.createElement(
|
485
|
-
'thead',
|
486
|
-
null,
|
487
|
-
_react2.default.createElement(
|
488
|
-
'tr',
|
489
|
-
null,
|
490
|
-
_react2.default.createElement(
|
491
|
-
'th',
|
492
|
-
{ width: '25%' },
|
493
|
-
'\u6D88\u8D39\u65E5\u671F'
|
494
|
-
),
|
495
|
-
_react2.default.createElement(
|
496
|
-
'th',
|
497
|
-
{ width: '25%' },
|
498
|
-
'\u5546\u54C1'
|
499
|
-
),
|
500
|
-
_react2.default.createElement(
|
501
|
-
'th',
|
502
|
-
{ width: '25%', style: { textAlign: 'center' } },
|
503
|
-
'\u6570\u91CF'
|
504
|
-
),
|
505
|
-
_react2.default.createElement(
|
506
|
-
'th',
|
507
|
-
{ width: '25%', className: 'amount-item' },
|
508
|
-
'\u6D88\u8D39\u91D1\u989D'
|
509
|
-
)
|
510
|
-
)
|
511
|
-
),
|
512
|
-
_react2.default.createElement(
|
513
|
-
'tbody',
|
514
|
-
{ style: { height: tableHeight - theadHeight } },
|
515
|
-
_react2.default.createElement(
|
516
|
-
_tplusComponentsTouch.TouchScroll,
|
517
|
-
null,
|
518
|
-
dataSource.map(function (item, key) {
|
519
|
-
return item.data.map(function (v, i) {
|
520
|
-
return _react2.default.createElement(
|
521
|
-
'tr',
|
522
|
-
{ key: i },
|
523
|
-
!i ? _react2.default.createElement(
|
524
|
-
'td',
|
525
|
-
{ className: item.data.length === 1 ? 'only-one-data' : '' },
|
526
|
-
(0, _utils.dateFormat)(item.date)
|
527
|
-
) : _react2.default.createElement('td', { className: item.data.length - 1 === i ? 'data-border' : '' }),
|
528
|
-
_react2.default.createElement(
|
529
|
-
'td',
|
530
|
-
{ 'data-overflow': 'tip' },
|
531
|
-
v.Name
|
532
|
-
),
|
533
|
-
_react2.default.createElement(
|
534
|
-
'td',
|
535
|
-
{ 'data-overflow': 'tip', style: { textAlign: 'center' } },
|
536
|
-
v.Quantity
|
537
|
-
),
|
538
|
-
_react2.default.createElement(
|
539
|
-
'td',
|
540
|
-
{ 'data-overflow': 'tip' },
|
541
|
-
v.Amount
|
542
|
-
)
|
543
|
-
);
|
544
|
-
});
|
545
|
-
})
|
546
|
-
)
|
547
|
-
)
|
548
|
-
)
|
549
|
-
),
|
550
|
-
!dataSource.length && _react2.default.createElement(
|
551
|
-
'div',
|
552
|
-
{ style: { height: tableHeight, position: 'relative' } },
|
553
|
-
_react2.default.createElement('div', { className: 'empty-data empty-data-img' })
|
554
|
-
)
|
555
|
-
);
|
556
|
-
};
|
557
|
-
}, _temp)) || _class;
|
558
|
-
|
559
|
-
exports.default = MemberTab;
|
560
|
-
//# sourceMappingURL=memberTab.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["tplus-member/member/memberTab.js"],"names":["TabPane","transform","Code","CardCode","Name","MemberTypeName","Mobilephone","Telephone","StoreName","sex","BirthDate","TotalIntegral","BalanceIntegral","BalanceStorage","TotalStorage","TotalBegin","EffectiveDate","ExpirationDate","UmemberOpenId","UmemberLabel","MemberCouponTitle","Memo","MemberTab","observer","props","localStore","get","loginInfo","IsEnableUMember","state","overflowTip","OverflowTip","target","format","text","colonStr","startsWith","split","containerDom","update","destroy","defaultActiveKey","onChange","memberInfoEle","title","key","rmecommendEle","recentlyEle","Component","propTypes","memberTabHeight","PropTypes","number","any","memberList","array","columnInfo","member","object","memberInfo","precisionInfo","initEmpty","bool","func","tabHeadHeight","dataClear","keys","values","regKey","dataSource","forEach","index","includes","find","v","FieldName","label","Title","push","value","filter","platform","isNewRetailBCPos","getMemberStateStamp","DynamicPropertyKeys","DynamicPropertyValues","MemberType","Sex","isExpiration","Uid","isUserLogout","MemberState","Store","priuserdefData","isUMember","isUMemberShow","memberValues","memberInfos","memberTabContentHeight","hasMemberInfo","some","enumController","getEnumOj","Differentiate","CC_NOT_DISPLAY","COUPON","isHaveCCNot","item","memberValue","precision","undefined","dataItem","length","map","formatValue","formatDateKeys","iconItems","height","position","recommend","recommends","record","like","Value","recommendInfoHeight","haveRecord","every","console","log","emptyRecommend","emptyData","showInfos","recordFilter","name","recommendHeight","recency","theadHeight","tableHeight","data","vlaue","i","findIndex","code","Time","rest","itemValue","date","itemData","sort","a","b","Amount","textAlign","Quantity"],"mappings":"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","file":"memberTab.js","sourcesContent":["import React, { Component } from 'react';\r\nimport { Tabs } from 'antd';\r\nimport { observer } from 'mobx-react';\r\nimport { localStore } from 'mutants-microfx';\r\nimport { OverflowTip, TouchScroll, CardList } from 'tplus-components-touch';\r\nimport { formatPrecision, dateFormat } from '../utils';\r\nimport PropTypes from 'prop-types';\r\nimport { enumController, platform } from 'mutants-util';\r\nimport './ShopMember.less';\r\n\r\nconst { TabPane } = Tabs;\r\n\r\nlet transform = {\r\n Code: '会员编号',\r\n CardCode: '会员卡号',\r\n Name: '会员姓名',\r\n MemberTypeName: '会员类型',\r\n Mobilephone: '手机号',\r\n Telephone: '联系电话',\r\n StoreName:'开卡门店',\r\n sex: '性别',\r\n BirthDate: '出生日期',\r\n TotalIntegral: '累计积分',\r\n BalanceIntegral: '积分余额',\r\n BalanceStorage: '当前总余额',\r\n TotalStorage: '储值总额', // 字段存疑\r\n TotalBegin: '期初余额',\r\n EffectiveDate: '生效日期',\r\n ExpirationDate: '失效日期',\r\n UmemberOpenId: '是否关注微信号',\r\n UmemberLabel: '会员标签',\r\n MemberCouponTitle: '优惠券',\r\n Memo: '备注',\r\n};\r\n\r\n@observer\r\nexport default class MemberTab extends Component {\r\n\r\n static propTypes = {\r\n memberTabHeight: PropTypes.number,\r\n defaultActiveKey: PropTypes.any,\r\n memberList: PropTypes.array,\r\n columnInfo: PropTypes.array,\r\n member: PropTypes.object,\r\n memberInfo: PropTypes.object,\r\n precisionInfo: PropTypes.object,\r\n initEmpty: PropTypes.bool,\r\n onChange: PropTypes.func,\r\n };\r\n\r\n tabHeadHeight = 37;\r\n\r\n constructor(props){\r\n super(props);\r\n\r\n const {loginInfo: {IsEnableUMember} = {}} = localStore.get('user') || {};\r\n this.state = {IsEnableUMember: !!IsEnableUMember};\r\n }\r\n\r\n componentDidMount() {\r\n this.overflowTip = new OverflowTip({\r\n target: '.member-content-tab',\r\n format(text) {\r\n text = text || '';\r\n const colonStr = ':';\r\n if (text.startsWith(colonStr)) {\r\n return text.split(colonStr)[1];\r\n }\r\n return text;\r\n }\r\n });\r\n }\r\n\r\n componentDidUpdate() {\r\n if (this.overflowTip && !this.overflowTip.containerDom) {\r\n this.overflowTip.update();\r\n }\r\n }\r\n\r\n componentWillUnmount() {\r\n this.overflowTip.destroy();\r\n }\r\n\r\n dataClear = (keys, values, columnInfo) => {\r\n const regKey = 'priuserdef';\r\n const dataSource = [];\r\n keys.forEach((key, index) => {\r\n if (key.includes(regKey)) {\r\n const {Title: label} = columnInfo.find(v => v.FieldName === key) || {};\r\n dataSource.push({key, value: values[index], label});\r\n }\r\n });\r\n return dataSource.filter(v => v.label);\r\n }\r\n\r\n memberInfoEle = ({ title, key }) => {\r\n let { isNewRetailBCPos } = platform || {};\r\n const { member = {}, memberTabHeight, memberList = [], columnInfo = [], precisionInfo = {}, getMemberStateStamp} = this.props;\r\n const {IsEnableUMember} = this.state;\r\n const { DynamicPropertyKeys = [], DynamicPropertyValues = [], ExpirationDate = '', MemberType: { Name: MemberTypeName } = {},\r\n Sex: { Name: sex } = {}, isExpiration, Uid, isUserLogout, MemberState, Store: { Name : StoreName } = {} } = member;\r\n let priuserdefData = this.dataClear(DynamicPropertyKeys, DynamicPropertyValues, columnInfo);\r\n const isUMember = IsEnableUMember && Uid > 0; // 判断为u会员\r\n const isUMemberShow = ['UmemberOpenId', 'UmemberLabel', 'MemberCouponTitle'];\r\n const memberValues = { MemberTypeName, sex, StoreName , ...member};\r\n const memberInfos = [];\r\n const memberTabContentHeight = memberTabHeight - this.tabHeadHeight;\r\n const hasMemberInfo = Object.keys(memberValues).some(v => memberValues[v]);\r\n const { Differentiate } = enumController.getEnumOj();\r\n\r\n const CC_NOT_DISPLAY = [\"Code\", \"ExpirationDate\", \"UmemberOpenId\", \"UmemberLabel\"];\r\n\r\n transform.MemberCouponTitle = Differentiate.COUPON;\r\n transform.MemberTypeName = Differentiate.MemberTypeName;\r\n Object.keys(transform).forEach(v => {\r\n // 查找CC不需要显示的字段\r\n const isHaveCCNot = CC_NOT_DISPLAY.find(item => item == v);\r\n if (isNewRetailBCPos && isHaveCCNot) return;\r\n if (isUMemberShow.includes(v) && !isNewRetailBCPos &&!isUMember ) return;\r\n const memberValue = memberValues[v];\r\n const precision = precisionInfo[v];\r\n //let value = formatPrecisionKeys.includes(v) ? (hasMemberInfo ? formatPrecision(memberValue, precision) : undefined) : memberValue;\r\n let value = !!precision ? (hasMemberInfo ? formatPrecision(memberValue, precision) : undefined) : memberValue;\r\n (v === 'UmemberOpenId') && (value = memberValue ? '已关注' : '未关注');\r\n const dataItem = { label: `${transform[v]}`, value };\r\n memberInfos.push(dataItem);\r\n });\r\n\r\n //对自定义项的值进行处理。\r\n if (priuserdefData && priuserdefData.length > 0) {\r\n priuserdefData.map(item => {\r\n let { key, value } = item || {};\r\n let precision = precisionInfo[key];\r\n item['value'] = !!precision ? formatPrecision(value, precision) : value;\r\n })\r\n }\r\n\r\n memberInfos.push(...priuserdefData) // 插入会员自定义项\r\n memberInfos.length % 2 && memberInfos.push({}); //奇数补全\r\n\r\n const formatValue = (label, value) => {\r\n const formatDateKeys = ['出生日期', '失效日期', '生效日期'];\r\n if (formatDateKeys.includes(label)) {\r\n return dateFormat(value);\r\n } else {\r\n return value;\r\n }\r\n }\r\n //状态戳\r\n let iconItems = getMemberStateStamp(member);\r\n return (\r\n <TabPane tab={title} key={key}>\r\n <div style={{ height: memberTabContentHeight, position: 'relative' }}>\r\n <TouchScroll height={memberTabContentHeight} >\r\n {\r\n !!memberList.length && <div className='member-info-table'>\r\n {\r\n memberInfos.map((item, index) => <div key={index}>\r\n {item.label && <span>{item.label || ''}</span>}\r\n {item.label && <span data-overflow='tip'>:{formatValue(item.label, item.value)}</span>}\r\n </div>)\r\n }\r\n {\r\n !memberInfos.length && <p className='empty-data'>暂无数据~</p>\r\n }\r\n </div>\r\n }\r\n {\r\n !memberList.length && <div className='empty-data empty-data-img' />\r\n }\r\n </TouchScroll>\r\n {\r\n iconItems && iconItems.length > 0 &&\r\n <div className='memberstate-detail-stamp'>\r\n {iconItems}\r\n </div>\r\n }\r\n </div>\r\n </TabPane >)\r\n };\r\n\r\n rmecommendEle = ({ title, key }) => {\r\n let { recommend: recommends = [], memberInfo: { record = [], like = [] } = {}, memberTabHeight, initEmpty } = this.props;\r\n recommends = recommends.filter(v => v);\r\n recommends.push({ Name: '最近购买', Value: like });\r\n const recommendInfoHeight = 74;\r\n const memberTabContentHeight = memberTabHeight - this.tabHeadHeight;\r\n const haveRecord = !!record.length && record.every(v => !!(v && v.value));\r\n console.log('会员偶发白屏问题:recommends==', recommends)\r\n const emptyRecommend = recommends.every(v => !((v && v.Value) || []).length) ? <div className='empty-data'>暂无推荐~</div> : null;\r\n const emptyData = (!haveRecord && recommends.every(v => !((v && v.Value) || []).length)) ? <div className='empty-data empty-data-img' /> : null;\r\n const showInfos = ['最近购买时间', '金额', '平均客单价']\r\n const recordFilter = record.filter(v => showInfos.includes(v.name));\r\n const recommendHeight = haveRecord ? memberTabContentHeight - recommendInfoHeight : memberTabContentHeight;\r\n return <TabPane tab={title} key={key}>\r\n <div className='recommend-tab' style={{height: memberTabContentHeight}}>\r\n {haveRecord && <div className='recommend-info'>\r\n {recordFilter.map((item, key) => <span key={key}>{item.name}: {item.value}</span>)}\r\n </div>}\r\n <div className='recommend-connent' style={{height: recommendHeight}}>\r\n <TouchScroll height={recommendHeight} key={recommendHeight}>\r\n {recommends.map((item, index) => {\r\n if (!(item.Value || []).length) return null;\r\n return <div key={index} className='detail-content'>\r\n <h1>{item.Name}</h1>\r\n <CardList\r\n list={item.Value || []}\r\n maxEmpyt={5}\r\n />\r\n </div>\r\n })}\r\n </TouchScroll>\r\n {initEmpty && emptyRecommend}\r\n </div>\r\n {initEmpty && emptyData}\r\n </div>\r\n </TabPane>;\r\n };\r\n\r\n recentlyEle = ({ title, key }) => {\r\n const {memberTabHeight, memberInfo: {recency = []} = {}} = this.props;\r\n const theadHeight = 50;\r\n const tableHeight = memberTabHeight - this.tabHeadHeight;\r\n const dataSource = [];\r\n const data = recency;\r\n data.forEach((vlaue, i) => {\r\n const index = dataSource.findIndex(v => v.code === vlaue.Code);\r\n if (~index) {\r\n dataSource[index].data.push(vlaue);\r\n } else {\r\n const { Time, Code, ...rest } = vlaue || {};\r\n const itemValue = { date: Time, code: Code, data: [rest] };\r\n dataSource.push(itemValue);\r\n }\r\n });\r\n\r\n dataSource.forEach(value => {\r\n // 金额倒序排序\r\n const itemData = value.data;\r\n if (itemData.length > 1) {\r\n itemData.sort((a = {}, b = {}) => b.Amount - a.Amount);\r\n }\r\n });\r\n\r\n return <TabPane tab={title} key={key}>\r\n {!!dataSource.length && <div className='recently-tab'>\r\n <table className='table'>\r\n <thead>\r\n <tr>\r\n <th width='25%'>消费日期</th>\r\n <th width='25%'>商品</th>\r\n <th width='25%' style={{textAlign: 'center'}}>数量</th>\r\n <th width='25%' className='amount-item'>消费金额</th>\r\n </tr>\r\n </thead>\r\n <tbody style={{height: tableHeight - theadHeight}}>\r\n <TouchScroll>\r\n {dataSource.map((item, key) => {\r\n return item.data.map((v, i) =>\r\n <tr key={i}>\r\n {!i ?\r\n <td className={item.data.length === 1 ? 'only-one-data' : ''}>{dateFormat(item.date)}</td> :\r\n <td className={item.data.length - 1 === i ? 'data-border' : ''}/>\r\n }\r\n <td data-overflow='tip'>{v.Name}</td>\r\n <td data-overflow='tip' style={{textAlign: 'center'}}>{v.Quantity}</td>\r\n <td data-overflow='tip'>{v.Amount}</td>\r\n </tr>\r\n );\r\n })}\r\n </TouchScroll>\r\n </tbody>\r\n </table>\r\n </div>}\r\n {!dataSource.length && <div style={{height: tableHeight, position: 'relative'}}><div className='empty-data empty-data-img' /></div>}\r\n </TabPane>;\r\n };\r\n\r\n render() {\r\n const {defaultActiveKey = '1' } = this.props;\r\n return (\r\n <Tabs\r\n defaultActiveKey={defaultActiveKey}\r\n onChange={this.props.onChange}\r\n className=\"member-table-container\"\r\n >\r\n {this.memberInfoEle({ title: '会员信息', key: '1' })}\r\n {this.rmecommendEle({ title: '智能推荐', key: '2' })}\r\n {this.recentlyEle({ title: '最近购买', key: '3' })}\r\n </Tabs>\r\n );\r\n }\r\n}\r\n"]}
|