tplus-member 3.28.2 → 3.28.7

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