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