tplus-member 3.31.1 → 3.31.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (57) hide show
  1. package/dist/index.js +6 -1
  2. package/dist/index.js.map +1 -1
  3. package/dist/member/MemberCardList.js +392 -0
  4. package/dist/member/MemberCardList.js.map +1 -0
  5. package/dist/member/MemberShow.js +3 -1
  6. package/dist/member/MemberShow.js.map +1 -1
  7. package/dist/member/ShopMember.js +162 -271
  8. package/dist/member/ShopMember.js.map +1 -1
  9. package/dist/member/ShopMember.less +74 -4
  10. package/dist/member/ShopMemberStorage.js +451 -0
  11. package/dist/member/ShopMemberStorage.js.map +1 -0
  12. package/dist/member/api.js +245 -42
  13. package/dist/member/api.js.map +1 -1
  14. package/dist/member/index.js +2 -0
  15. package/dist/member/index.js.map +1 -1
  16. package/dist/member/memberMenu/bindCard/index.js +295 -0
  17. package/dist/member/memberMenu/bindCard/index.js.map +1 -0
  18. package/dist/member/memberMenu/bindCard/style.less +8 -0
  19. package/dist/member/memberMenu/index.js +503 -352
  20. package/dist/member/memberMenu/index.js.map +1 -1
  21. package/dist/member/memberMenu/modifyPass/index.js +0 -2
  22. package/dist/member/memberMenu/modifyPass/index.js.map +1 -1
  23. package/dist/member/memberMenu/style.less +44 -1
  24. package/dist/member/memberMenuStorage/bindCard/index.js +172 -0
  25. package/dist/member/memberMenuStorage/bindCard/index.js.map +1 -0
  26. package/dist/member/memberMenuStorage/bindCard/style.less +8 -0
  27. package/dist/member/memberMenuStorage/changeMemberCard/index.js +260 -0
  28. package/dist/member/memberMenuStorage/changeMemberCard/index.js.map +1 -0
  29. package/dist/member/memberMenuStorage/changeMemberCard/style.less +43 -0
  30. package/dist/member/memberMenuStorage/index.js +1679 -0
  31. package/dist/member/memberMenuStorage/index.js.map +1 -0
  32. package/dist/member/memberMenuStorage/modifyPass/index.js +420 -0
  33. package/dist/member/memberMenuStorage/modifyPass/index.js.map +1 -0
  34. package/dist/member/memberMenuStorage/modifyPass/store.js +426 -0
  35. package/dist/member/memberMenuStorage/modifyPass/store.js.map +1 -0
  36. package/dist/member/memberMenuStorage/modifyPass/style.less +96 -0
  37. package/dist/member/memberMenuStorage/style.less +130 -0
  38. package/dist/member/memberTab/MemberCardInfo.js +89 -0
  39. package/dist/member/memberTab/MemberCardInfo.js.map +1 -0
  40. package/dist/member/memberTab/MemberManager.js +604 -0
  41. package/dist/member/memberTab/MemberManager.js.map +1 -0
  42. package/dist/member/memberTab/MemberStorage.js +176 -0
  43. package/dist/member/memberTab/MemberStorage.js.map +1 -0
  44. package/dist/member/memberTab/index.js +133 -0
  45. package/dist/member/memberTab/index.js.map +1 -0
  46. package/dist/stores/MemberStore.js +25 -20
  47. package/dist/stores/MemberStore.js.map +1 -1
  48. package/dist/utils.js +15 -1
  49. package/dist/utils.js.map +1 -1
  50. package/dist/viewDoMain/StorageAmountChangedProcessorBlock.js +1 -0
  51. package/dist/viewDoMain/StorageAmountChangedProcessorBlock.js.map +1 -1
  52. package/dist/views/MemberOrderView.js +1 -1
  53. package/dist/views/MemberOrderView.js.map +1 -1
  54. package/dist/views/MemberStoreNew.less +1 -1
  55. package/dist/views/MemberStoreNewView.js +14 -26
  56. package/dist/views/MemberStoreNewView.js.map +1 -1
  57. 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 _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 cardStatusEnumList = {
105
+ ENABLED: "已启用",
106
+ DISABLED: "已停用",
107
+ UNBINDING: "待绑定",
108
+ BINDING: "已绑定",
109
+ INVALIDATION: "已作废",
110
+ EXPIRED: "已过期",
111
+ REFUNDING_CARD: "退卡中",
112
+ REFUNDED_CARD: "已退卡"
113
+ };
114
+
115
+ var memberManager = (0, _mobxReact.observer)(_class = (_temp = _class2 = function (_Component) {
116
+ (0, _inherits3.default)(memberManager, _Component);
117
+
118
+ function memberManager(props) {
119
+ (0, _classCallCheck3.default)(this, memberManager);
120
+
121
+ var _this = (0, _possibleConstructorReturn3.default)(this, (memberManager.__proto__ || (0, _getPrototypeOf2.default)(memberManager)).call(this, props));
122
+
123
+ _initialiseProps.call(_this);
124
+
125
+ var _ref = _mutantsMicrofx.localStore.get('user') || {},
126
+ _ref$loginInfo = _ref.loginInfo;
127
+
128
+ _ref$loginInfo = _ref$loginInfo === undefined ? {} : _ref$loginInfo;
129
+ var IsEnableUMember = _ref$loginInfo.IsEnableUMember;
130
+
131
+ _this.state = { IsEnableUMember: !!IsEnableUMember };
132
+ return _this;
133
+ }
134
+
135
+ // 会员信息
136
+
137
+
138
+ // 智能推荐
139
+
140
+
141
+ // 最近购买
142
+
143
+
144
+ // 会员的卡信息
145
+
146
+
147
+ (0, _createClass3.default)(memberManager, [{
148
+ key: 'render',
149
+ value: function render() {
150
+ var _props = this.props,
151
+ _props$defaultActiveK = _props.defaultActiveKey,
152
+ defaultActiveKey = _props$defaultActiveK === undefined ? '1' : _props$defaultActiveK,
153
+ storeKey = _props.storeKey;
154
+
155
+ return _react2.default.createElement(
156
+ _tabs2.default,
157
+ {
158
+ defaultActiveKey: defaultActiveKey,
159
+ onChange: this.props.onChange,
160
+ className: 'member-table-container'
161
+ },
162
+ this.memberInfoEle({ title: '会员信息', key: '1' }),
163
+ this.rmecommendEle({ title: '智能推荐', key: '2' }),
164
+ this.recentlyEle({ title: '最近购买', key: '3' }),
165
+ this.memberCardInfoEle({ title: '卡信息', 'key': '4' })
166
+ );
167
+ }
168
+ }]);
169
+ return memberManager;
170
+ }(_react.Component), _initialiseProps = function _initialiseProps() {
171
+ var _this2 = this;
172
+
173
+ this.tabHeadHeight = 37;
174
+
175
+ this.dataClear = function (keys, values, columnInfo) {
176
+ var regKey = 'priuserdef';
177
+ var dataSource = [];
178
+ keys.forEach(function (key, index) {
179
+ if (key.includes(regKey)) {
180
+ var _ref2 = columnInfo.find(function (v) {
181
+ return v.FieldName === key;
182
+ }) || {},
183
+ label = _ref2.Title;
184
+
185
+ dataSource.push({ key: key, value: values[index], label: label });
186
+ }
187
+ });
188
+ return dataSource.filter(function (v) {
189
+ return v.label;
190
+ });
191
+ };
192
+
193
+ this.memberInfoEle = function (_ref3) {
194
+ var title = _ref3.title,
195
+ key = _ref3.key;
196
+
197
+ var _ref4 = _mutantsUtil.platform || {},
198
+ isNewRetailBCPos = _ref4.isNewRetailBCPos;
199
+
200
+ var _props2 = _this2.props,
201
+ _props2$member = _props2.member,
202
+ member = _props2$member === undefined ? {} : _props2$member,
203
+ memberTabHeight = _props2.memberTabHeight,
204
+ _props2$memberList = _props2.memberList,
205
+ memberList = _props2$memberList === undefined ? [] : _props2$memberList,
206
+ _props2$columnInfo = _props2.columnInfo,
207
+ columnInfo = _props2$columnInfo === undefined ? [] : _props2$columnInfo,
208
+ _props2$precisionInfo = _props2.precisionInfo,
209
+ precisionInfo = _props2$precisionInfo === undefined ? {} : _props2$precisionInfo,
210
+ getMemberStateStamp = _props2.getMemberStateStamp;
211
+ var IsEnableUMember = _this2.state.IsEnableUMember;
212
+ var _member$DynamicProper = member.DynamicPropertyKeys,
213
+ DynamicPropertyKeys = _member$DynamicProper === undefined ? [] : _member$DynamicProper,
214
+ _member$DynamicProper2 = member.DynamicPropertyValues,
215
+ DynamicPropertyValues = _member$DynamicProper2 === undefined ? [] : _member$DynamicProper2,
216
+ _member$ExpirationDat = member.ExpirationDate,
217
+ ExpirationDate = _member$ExpirationDat === undefined ? '' : _member$ExpirationDat,
218
+ _member$MemberType = member.MemberType;
219
+ _member$MemberType = _member$MemberType === undefined ? {} : _member$MemberType;
220
+ var MemberTypeName = _member$MemberType.Name,
221
+ _member$Sex = member.Sex;
222
+ _member$Sex = _member$Sex === undefined ? {} : _member$Sex;
223
+ var sex = _member$Sex.Name,
224
+ isExpiration = member.isExpiration,
225
+ Uid = member.Uid,
226
+ isUserLogout = member.isUserLogout,
227
+ MemberState = member.MemberState,
228
+ _member$Store = member.Store;
229
+ _member$Store = _member$Store === undefined ? {} : _member$Store;
230
+ var StoreName = _member$Store.Name;
231
+
232
+ var priuserdefData = _this2.dataClear(DynamicPropertyKeys, DynamicPropertyValues, columnInfo);
233
+ var isUMember = IsEnableUMember && Uid > 0; // 判断为u会员
234
+ var isUMemberShow = ['UmemberOpenId', 'UmemberLabel', 'MemberCouponTitle'];
235
+ var memberValues = (0, _extends3.default)({ MemberTypeName: MemberTypeName, sex: sex, StoreName: StoreName }, member);
236
+ var memberInfos = [];
237
+ var memberTabContentHeight = memberTabHeight - _this2.tabHeadHeight;
238
+ var hasMemberInfo = (0, _keys2.default)(memberValues).some(function (v) {
239
+ return memberValues[v];
240
+ });
241
+
242
+ var _enumController$getEn = _mutantsUtil.enumController.getEnumOj(),
243
+ Differentiate = _enumController$getEn.Differentiate;
244
+
245
+ var CC_NOT_DISPLAY = ["Code", "ExpirationDate", "UmemberOpenId", "UmemberLabel"];
246
+
247
+ transform.MemberCouponTitle = Differentiate.COUPON;
248
+ transform.MemberTypeName = Differentiate.MemberTypeName;
249
+ (0, _keys2.default)(transform).forEach(function (v) {
250
+ // 查找CC不需要显示的字段
251
+ var isHaveCCNot = CC_NOT_DISPLAY.find(function (item) {
252
+ return item == v;
253
+ });
254
+ if (isNewRetailBCPos && isHaveCCNot) return;
255
+ if (isUMemberShow.includes(v) && !isNewRetailBCPos && !isUMember) return;
256
+ var memberValue = memberValues[v];
257
+ var precision = precisionInfo[v];
258
+ //let value = formatPrecisionKeys.includes(v) ? (hasMemberInfo ? formatPrecision(memberValue, precision) : undefined) : memberValue;
259
+ var value = !!precision ? hasMemberInfo ? (0, _utils.formatPrecision)(memberValue, precision) : undefined : memberValue;
260
+ v === 'UmemberOpenId' && (value = memberValue ? '已关注' : '未关注');
261
+ var dataItem = { label: '' + transform[v], value: value };
262
+ memberInfos.push(dataItem);
263
+ });
264
+
265
+ //对自定义项的值进行处理。
266
+ if (priuserdefData && priuserdefData.length > 0) {
267
+ priuserdefData.map(function (item) {
268
+ var _ref5 = item || {},
269
+ key = _ref5.key,
270
+ value = _ref5.value;
271
+
272
+ var precision = precisionInfo[key];
273
+ item['value'] = !!precision ? (0, _utils.formatPrecision)(value, precision) : value;
274
+ });
275
+ }
276
+
277
+ memberInfos.push.apply(memberInfos, (0, _toConsumableArray3.default)(priuserdefData)); // 插入会员自定义项
278
+ memberInfos.length % 2 && memberInfos.push({}); //奇数补全
279
+ var formatValue = function formatValue(label, value) {
280
+ var formatDateKeys = ['出生日期', '失效日期', '生效日期'];
281
+ if (formatDateKeys.includes(label)) {
282
+ return (0, _utils.dateFormat)(value);
283
+ } else {
284
+ return value;
285
+ }
286
+ };
287
+ //状态戳
288
+ var iconItems = getMemberStateStamp(member);
289
+ return _react2.default.createElement(
290
+ TabPane,
291
+ { tab: title, key: key },
292
+ _react2.default.createElement(
293
+ 'div',
294
+ { style: { height: memberTabContentHeight, position: 'relative' } },
295
+ _react2.default.createElement(
296
+ _tplusComponentsTouch.TouchScroll,
297
+ { height: memberTabContentHeight },
298
+ !!memberList.length && _react2.default.createElement(
299
+ 'div',
300
+ { className: 'member-info-table' },
301
+ memberInfos.map(function (item, index) {
302
+ return _react2.default.createElement(
303
+ 'div',
304
+ { key: index },
305
+ item.label && _react2.default.createElement(
306
+ 'span',
307
+ null,
308
+ item.label || ''
309
+ ),
310
+ item.label && _react2.default.createElement(
311
+ 'span',
312
+ { 'data-overflow': 'tip' },
313
+ '\uFF1A',
314
+ formatValue(item.label, item.value)
315
+ )
316
+ );
317
+ }),
318
+ !memberInfos.length && _react2.default.createElement(
319
+ 'p',
320
+ { className: 'empty-data' },
321
+ '\u6682\u65E0\u6570\u636E~'
322
+ )
323
+ ),
324
+ !memberList.length && _react2.default.createElement('div', { className: 'empty-data empty-data-img' })
325
+ ),
326
+ iconItems && iconItems.length > 0 && _react2.default.createElement(
327
+ 'div',
328
+ { className: 'memberstate-detail-stamp' },
329
+ iconItems
330
+ )
331
+ )
332
+ );
333
+ };
334
+
335
+ this.rmecommendEle = function (_ref6) {
336
+ var title = _ref6.title,
337
+ key = _ref6.key;
338
+ var _props3 = _this2.props,
339
+ _props3$recommend = _props3.recommend,
340
+ recommends = _props3$recommend === undefined ? [] : _props3$recommend,
341
+ _props3$memberInfo = _props3.memberInfo;
342
+ _props3$memberInfo = _props3$memberInfo === undefined ? {} : _props3$memberInfo;
343
+ var _props3$memberInfo$re = _props3$memberInfo.record,
344
+ record = _props3$memberInfo$re === undefined ? [] : _props3$memberInfo$re,
345
+ _props3$memberInfo$li = _props3$memberInfo.like,
346
+ like = _props3$memberInfo$li === undefined ? [] : _props3$memberInfo$li,
347
+ memberTabHeight = _props3.memberTabHeight,
348
+ initEmpty = _props3.initEmpty;
349
+
350
+ recommends = recommends.filter(function (v) {
351
+ return v;
352
+ });
353
+ recommends.push({ Name: '最近购买', Value: like });
354
+ var recommendInfoHeight = 74;
355
+ var memberTabContentHeight = memberTabHeight - _this2.tabHeadHeight;
356
+ var haveRecord = !!record.length && record.every(function (v) {
357
+ return !!(v && v.value);
358
+ });
359
+ console.log('会员偶发白屏问题:recommends==', recommends);
360
+ var emptyRecommend = recommends.every(function (v) {
361
+ return !(v && v.Value || []).length;
362
+ }) ? _react2.default.createElement(
363
+ 'div',
364
+ { className: 'empty-data' },
365
+ '\u6682\u65E0\u63A8\u8350~'
366
+ ) : null;
367
+ var emptyData = !haveRecord && recommends.every(function (v) {
368
+ return !(v && v.Value || []).length;
369
+ }) ? _react2.default.createElement('div', { className: 'empty-data empty-data-img' }) : null;
370
+ var showInfos = ['最近购买时间', '金额', '平均客单价'];
371
+ var recordFilter = record.filter(function (v) {
372
+ return showInfos.includes(v.name);
373
+ });
374
+ var recommendHeight = haveRecord ? memberTabContentHeight - recommendInfoHeight : memberTabContentHeight;
375
+ return _react2.default.createElement(
376
+ TabPane,
377
+ { tab: title, key: key },
378
+ _react2.default.createElement(
379
+ 'div',
380
+ { className: 'recommend-tab', style: { height: memberTabContentHeight } },
381
+ haveRecord && _react2.default.createElement(
382
+ 'div',
383
+ { className: 'recommend-info' },
384
+ recordFilter.map(function (item, key) {
385
+ return _react2.default.createElement(
386
+ 'span',
387
+ { key: key },
388
+ item.name,
389
+ ': ',
390
+ item.value
391
+ );
392
+ })
393
+ ),
394
+ _react2.default.createElement(
395
+ 'div',
396
+ { className: 'recommend-connent', style: { height: recommendHeight } },
397
+ _react2.default.createElement(
398
+ _tplusComponentsTouch.TouchScroll,
399
+ { height: recommendHeight, key: recommendHeight },
400
+ recommends.map(function (item, index) {
401
+ if (!(item.Value || []).length) return null;
402
+ return _react2.default.createElement(
403
+ 'div',
404
+ { key: index, className: 'detail-content' },
405
+ _react2.default.createElement(
406
+ 'h1',
407
+ null,
408
+ item.Name
409
+ ),
410
+ _react2.default.createElement(_tplusComponentsTouch.CardList, {
411
+ list: item.Value || [],
412
+ maxEmpyt: 5
413
+ })
414
+ );
415
+ })
416
+ ),
417
+ initEmpty && emptyRecommend
418
+ ),
419
+ initEmpty && emptyData
420
+ )
421
+ );
422
+ };
423
+
424
+ this.recentlyEle = function (_ref7) {
425
+ var title = _ref7.title,
426
+ key = _ref7.key;
427
+ var _props4 = _this2.props,
428
+ memberTabHeight = _props4.memberTabHeight,
429
+ _props4$memberInfo = _props4.memberInfo;
430
+ _props4$memberInfo = _props4$memberInfo === undefined ? {} : _props4$memberInfo;
431
+ var _props4$memberInfo$re = _props4$memberInfo.recency,
432
+ recency = _props4$memberInfo$re === undefined ? [] : _props4$memberInfo$re;
433
+
434
+ var theadHeight = 50;
435
+ var tableHeight = memberTabHeight - _this2.tabHeadHeight;
436
+ var dataSource = [];
437
+ var data = recency;
438
+ data.forEach(function (vlaue, i) {
439
+ var index = dataSource.findIndex(function (v) {
440
+ return v.code === vlaue.Code;
441
+ });
442
+ if (~index) {
443
+ dataSource[index].data.push(vlaue);
444
+ } else {
445
+ var _ref8 = vlaue || {},
446
+ Time = _ref8.Time,
447
+ Code = _ref8.Code,
448
+ rest = (0, _objectWithoutProperties3.default)(_ref8, ['Time', 'Code']);
449
+
450
+ var itemValue = { date: Time, code: Code, data: [rest] };
451
+ dataSource.push(itemValue);
452
+ }
453
+ });
454
+
455
+ dataSource.forEach(function (value) {
456
+ // 金额倒序排序
457
+ var itemData = value.data;
458
+ if (itemData.length > 1) {
459
+ itemData.sort(function () {
460
+ var a = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
461
+ var b = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
462
+ return b.Amount - a.Amount;
463
+ });
464
+ }
465
+ });
466
+
467
+ return _react2.default.createElement(
468
+ TabPane,
469
+ { tab: title, key: key },
470
+ !!dataSource.length && _react2.default.createElement(
471
+ 'div',
472
+ { className: 'recently-tab' },
473
+ _react2.default.createElement(
474
+ 'table',
475
+ { className: 'table' },
476
+ _react2.default.createElement(
477
+ 'thead',
478
+ null,
479
+ _react2.default.createElement(
480
+ 'tr',
481
+ null,
482
+ _react2.default.createElement(
483
+ 'th',
484
+ { width: '25%' },
485
+ '\u6D88\u8D39\u65E5\u671F'
486
+ ),
487
+ _react2.default.createElement(
488
+ 'th',
489
+ { width: '25%' },
490
+ '\u5546\u54C1'
491
+ ),
492
+ _react2.default.createElement(
493
+ 'th',
494
+ { width: '25%', style: { textAlign: 'center' } },
495
+ '\u6570\u91CF'
496
+ ),
497
+ _react2.default.createElement(
498
+ 'th',
499
+ { width: '25%', className: 'amount-item' },
500
+ '\u6D88\u8D39\u91D1\u989D'
501
+ )
502
+ )
503
+ ),
504
+ _react2.default.createElement(
505
+ 'tbody',
506
+ { style: { height: tableHeight - theadHeight } },
507
+ _react2.default.createElement(
508
+ _tplusComponentsTouch.TouchScroll,
509
+ null,
510
+ dataSource.map(function (item, key) {
511
+ return item.data.map(function (v, i) {
512
+ return _react2.default.createElement(
513
+ 'tr',
514
+ { key: i },
515
+ !i ? _react2.default.createElement(
516
+ 'td',
517
+ { className: item.data.length === 1 ? 'only-one-data' : '' },
518
+ (0, _utils.dateFormat)(item.date)
519
+ ) : _react2.default.createElement('td', { className: item.data.length - 1 === i ? 'data-border' : '' }),
520
+ _react2.default.createElement(
521
+ 'td',
522
+ { 'data-overflow': 'tip' },
523
+ v.Name
524
+ ),
525
+ _react2.default.createElement(
526
+ 'td',
527
+ { 'data-overflow': 'tip', style: { textAlign: 'center' } },
528
+ v.Quantity
529
+ ),
530
+ _react2.default.createElement(
531
+ 'td',
532
+ { 'data-overflow': 'tip' },
533
+ v.Amount
534
+ )
535
+ );
536
+ });
537
+ })
538
+ )
539
+ )
540
+ )
541
+ ),
542
+ !dataSource.length && _react2.default.createElement(
543
+ 'div',
544
+ { style: { height: tableHeight, position: 'relative' } },
545
+ _react2.default.createElement('div', { className: 'empty-data empty-data-img' })
546
+ )
547
+ );
548
+ };
549
+
550
+ this.memberCardInfoEle = function (_ref9) {
551
+ var title = _ref9.title,
552
+ key = _ref9.key;
553
+ var _props5 = _this2.props,
554
+ _props5$member = _props5.member,
555
+ member = _props5$member === undefined ? {} : _props5$member,
556
+ memberTabHeight = _props5.memberTabHeight,
557
+ _props5$memberList = _props5.memberList,
558
+ memberList = _props5$memberList === undefined ? [] : _props5$memberList,
559
+ _props5$cardInfo = _props5.cardInfo,
560
+ cardInfo = _props5$cardInfo === undefined ? [] : _props5$cardInfo,
561
+ cardTypeEnumList = _props5.cardTypeEnumList,
562
+ storeKey = _props5.storeKey;
563
+
564
+ var memberTabContentHeight = memberTabHeight - _this2.tabHeadHeight;
565
+ var memberCardInfos = [];
566
+
567
+ cardInfo.map(function (item) {
568
+ var StorageCardNo = item.StorageCardNo,
569
+ Name = item.Name,
570
+ _item$TotalStorage = item.TotalStorage,
571
+ TotalStorage = _item$TotalStorage === undefined ? 0 : _item$TotalStorage,
572
+ _item$BalanceStorage = item.BalanceStorage,
573
+ BalanceStorage = _item$BalanceStorage === undefined ? 0 : _item$BalanceStorage,
574
+ CardTypeEnum = item.CardTypeEnum,
575
+ ValidMethodEnum = item.ValidMethodEnum,
576
+ DueDate = item.DueDate,
577
+ CardStatusEnum = item.CardStatusEnum,
578
+ IsSale = item.IsSale;
579
+
580
+ 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)(IsSale === 'SOLD' ? TotalStorage : 0, 2) }, { label: '储值余额', value: (0, _utils.formatPrecision)(IsSale === 'SOLD' ? BalanceStorage : 0, 2) }, { label: '卡状态', value: cardStatusEnumList[CardStatusEnum] }];
581
+ memberCardInfos.push(dataSource);
582
+ });
583
+
584
+ return _react2.default.createElement(
585
+ TabPane,
586
+ { tab: title + '(' + cardInfo.length + ')', key: key },
587
+ _react2.default.createElement(
588
+ 'div',
589
+ { style: { height: memberTabContentHeight, position: 'relative', overflowY: 'auto' } },
590
+ _react2.default.createElement(
591
+ _tplusComponentsTouch.TouchScroll,
592
+ { height: memberTabContentHeight, scrollProgress: function scrollProgress() {} },
593
+ !!cardInfo.length && memberCardInfos.map(function (list, index) {
594
+ return _react2.default.createElement(_MemberCardInfo2.default, { list: list, index: index, key: '卡' + (index + 1), title: '卡' + (index + 1), keyName: 'memberCardInfos', memberList: memberList, storeKey: storeKey });
595
+ }),
596
+ !cardInfo.length && _react2.default.createElement('div', { className: 'empty-data empty-data-img' })
597
+ )
598
+ )
599
+ );
600
+ };
601
+ }, _temp)) || _class;
602
+
603
+ exports.default = memberManager;
604
+ //# sourceMappingURL=MemberManager.js.map
@@ -0,0 +1 @@
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","cardStatusEnumList","ENABLED","DISABLED","UNBINDING","BINDING","INVALIDATION","EXPIRED","REFUNDING_CARD","REFUNDED_CARD","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","CardStatusEnum","IsSale","overflowY","list"],"mappings":"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","file":"MemberManager.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 { TouchScroll, CardList } from 'tplus-components-touch';\r\nimport { formatPrecision, dateFormat } from '../../utils';\r\nimport { enumController, platform } from 'mutants-util';\r\nimport MemberCardInfo from './MemberCardInfo'\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\r\n// 有效期类型\r\nconst validMethodEnum = {\r\n LONG_PERIOD: '长期有效',\r\n ASSIGNMENT_PERIOD: '指定有效期'\r\n}\r\n\r\n// 卡状态\r\nconst cardStatusEnumList = {\r\n ENABLED: \"已启用\", \r\n DISABLED: \"已停用\",\r\n UNBINDING: \"待绑定\",\r\n BINDING: \"已绑定\",\r\n INVALIDATION: \"已作废\",\r\n EXPIRED: \"已过期\",\r\n REFUNDING_CARD: \"退卡中\",\r\n REFUNDED_CARD: \"已退卡\"\r\n }\r\n\r\n@observer\r\nexport default class memberManager extends Component {\r\n tabHeadHeight = 37;\r\n constructor (props) {\r\n super(props)\r\n const {loginInfo: {IsEnableUMember} = {}} = localStore.get('user') || {};\r\n this.state = {IsEnableUMember: !!IsEnableUMember};\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 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 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 // 智能推荐\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 // 最近购买\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 // 会员的卡信息\r\n memberCardInfoEle = ({ title, key }) => {\r\n const { member = {}, memberTabHeight, memberList = [], cardInfo = [], cardTypeEnumList, storeKey} = this.props;\r\n const memberTabContentHeight = memberTabHeight - this.tabHeadHeight;\r\n const memberCardInfos = []\r\n\r\n cardInfo.map(item => {\r\n const { StorageCardNo, Name, TotalStorage = 0, BalanceStorage = 0, CardTypeEnum, ValidMethodEnum, DueDate, CardStatusEnum, IsSale } = item\r\n const dataSource = [\r\n { label: '卡名称', value: Name },\r\n { label: '卡号', value: StorageCardNo },\r\n { label: '卡类型', value: cardTypeEnumList[CardTypeEnum] },\r\n { label: '有效期至', value: ValidMethodEnum === 'LONG_PERIOD' ? '长期有效' : dateFormat(DueDate)},\r\n { label: '储值总额', value: formatPrecision(IsSale === 'SOLD' ? TotalStorage : 0, 2) },\r\n { label: '储值余额', value: formatPrecision(IsSale === 'SOLD' ? BalanceStorage : 0, 2) },\r\n { label: '卡状态', value: cardStatusEnumList[CardStatusEnum] }\r\n ]\r\n memberCardInfos.push(dataSource)\r\n })\r\n\r\n return (\r\n <TabPane tab={title + '('+ cardInfo.length +')'} key={key}>\r\n <div style={{ height: memberTabContentHeight, position: 'relative',overflowY: 'auto' }}>\r\n <TouchScroll height={memberTabContentHeight} scrollProgress={()=>{}}>\r\n {\r\n !!cardInfo.length && \r\n memberCardInfos.map((list, index) => <MemberCardInfo list={list} index={index} key={'卡' + (index + 1)} title={'卡' + (index + 1)} keyName='memberCardInfos' memberList={memberList} storeKey={storeKey} />)\r\n }\r\n {\r\n !cardInfo.length && <div className='empty-data empty-data-img' />\r\n }\r\n </TouchScroll>\r\n </div>\r\n </TabPane>\r\n )\r\n };\r\n\r\n render() {\r\n const {defaultActiveKey = '1', storeKey } = 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 { this.memberCardInfoEle({title: '卡信息', 'key': '4'}) }\r\n </Tabs>\r\n );\r\n }\r\n}"]}