tplus-member 3.28.6 → 3.28.10

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