tplus-member 1.27.1 → 1.27.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (134) hide show
  1. package/dist/api.js +533 -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 +359 -0
  6. package/dist/controllers/MemberOrderController.js.map +1 -0
  7. package/dist/controllers/OpenCardController.js +289 -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 +144 -0
  12. package/dist/dataProvider/member.js.map +1 -0
  13. package/dist/dataProvider/openCard.js +145 -0
  14. package/dist/dataProvider/openCard.js.map +1 -0
  15. package/dist/domain/member/AuthProcess.js +42 -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 +50 -0
  26. package/dist/domain/member/EffectiveDateChangedProcessor.js.map +1 -0
  27. package/dist/domain/member/GetThisPresentAmountProcessor.js +116 -0
  28. package/dist/domain/member/GetThisPresentAmountProcessor.js.map +1 -0
  29. package/dist/domain/member/InitDataDeductionProcessor.js +68 -0
  30. package/dist/domain/member/InitDataDeductionProcessor.js.map +1 -0
  31. package/dist/domain/member/InitDataProcessor.js +140 -0
  32. package/dist/domain/member/InitDataProcessor.js.map +1 -0
  33. package/dist/domain/member/InitDataProjectProcessor.js +102 -0
  34. package/dist/domain/member/InitDataProjectProcessor.js.map +1 -0
  35. package/dist/domain/member/IsMemberEffectiveProcessor.js +45 -0
  36. package/dist/domain/member/IsMemberEffectiveProcessor.js.map +1 -0
  37. package/dist/domain/member/IsMemberEnableProcessor.js +38 -0
  38. package/dist/domain/member/IsMemberEnableProcessor.js.map +1 -0
  39. package/dist/domain/member/IsMemberExpirationProcessor.js +46 -0
  40. package/dist/domain/member/IsMemberExpirationProcessor.js.map +1 -0
  41. package/dist/domain/member/IsMemberPasswordSameProcessor.js +41 -0
  42. package/dist/domain/member/IsMemberPasswordSameProcessor.js.map +1 -0
  43. package/dist/domain/member/IsMemberStorageForStoreProcessor.js +40 -0
  44. package/dist/domain/member/IsMemberStorageForStoreProcessor.js.map +1 -0
  45. package/dist/domain/member/MemberTypeChangedProcessor.js +120 -0
  46. package/dist/domain/member/MemberTypeChangedProcessor.js.map +1 -0
  47. package/dist/domain/member/MobilephoneChangedProcessor.js +39 -0
  48. package/dist/domain/member/MobilephoneChangedProcessor.js.map +1 -0
  49. package/dist/domain/member/PersonProcesser.js +35 -0
  50. package/dist/domain/member/PersonProcesser.js.map +1 -0
  51. package/dist/domain/member/PriuserdefChangedProcessor.js +50 -0
  52. package/dist/domain/member/PriuserdefChangedProcessor.js.map +1 -0
  53. package/dist/domain/operationLog/AddLogProcessor.js +50 -0
  54. package/dist/domain/operationLog/AddLogProcessor.js.map +1 -0
  55. package/dist/domain/operationLog/OperationConfig.js +34 -0
  56. package/dist/domain/operationLog/OperationConfig.js.map +1 -0
  57. package/dist/domain/operationLog/OperationLog.js +146 -0
  58. package/dist/domain/operationLog/OperationLog.js.map +1 -0
  59. package/dist/index.js +124 -0
  60. package/dist/index.js.map +1 -0
  61. package/dist/member/MemberPhoto.js +268 -0
  62. package/dist/member/MemberPhoto.js.map +1 -0
  63. package/dist/member/MemberShow.js +167 -0
  64. package/dist/member/MemberShow.js.map +1 -0
  65. package/dist/member/ShopMember.js +1096 -0
  66. package/dist/member/ShopMember.js.map +1 -0
  67. package/dist/member/ShopMember.less +605 -0
  68. package/dist/member/api.js +726 -0
  69. package/dist/member/api.js.map +1 -0
  70. package/dist/member/color.less +32 -0
  71. package/dist/member/index.js +843 -0
  72. package/dist/member/index.js.map +1 -0
  73. package/dist/member/index.less +466 -0
  74. package/dist/member/memberTab.js +675 -0
  75. package/dist/member/memberTab.js.map +1 -0
  76. package/dist/memberMenu/changeMemberCard/index.js +268 -0
  77. package/dist/memberMenu/changeMemberCard/index.js.map +1 -0
  78. package/dist/memberMenu/changeMemberCard/style.less +43 -0
  79. package/dist/memberMenu/index.js +826 -0
  80. package/dist/memberMenu/index.js.map +1 -0
  81. package/dist/memberMenu/modifyPass/index.js +207 -0
  82. package/dist/memberMenu/modifyPass/index.js.map +1 -0
  83. package/dist/memberMenu/modifyPass/store.js +357 -0
  84. package/dist/memberMenu/modifyPass/store.js.map +1 -0
  85. package/dist/memberMenu/modifyPass/style.less +91 -0
  86. package/dist/memberMenu/style.less +82 -0
  87. package/dist/socket.js +164 -0
  88. package/dist/socket.js.map +1 -0
  89. package/dist/utils.js +246 -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 +53 -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/viewModels/MemberDeduction.js +862 -0
  106. package/dist/viewModels/MemberDeduction.js.map +1 -0
  107. package/dist/viewModels/MemberOrder.js +248 -0
  108. package/dist/viewModels/MemberOrder.js.map +1 -0
  109. package/dist/viewModels/MemberProject.js +953 -0
  110. package/dist/viewModels/MemberProject.js.map +1 -0
  111. package/dist/viewModels/MemberStore.js +310 -0
  112. package/dist/viewModels/MemberStore.js.map +1 -0
  113. package/dist/views/commonPerson/commonPerson.less +54 -0
  114. package/dist/views/commonPerson/commonPersonModal.js +459 -0
  115. package/dist/views/commonPerson/commonPersonModal.js.map +1 -0
  116. package/dist/views/memberDeduction/MemberDeductionView.js +837 -0
  117. package/dist/views/memberDeduction/MemberDeductionView.js.map +1 -0
  118. package/dist/views/memberDeduction/deductionSuccess.js +62 -0
  119. package/dist/views/memberDeduction/deductionSuccess.js.map +1 -0
  120. package/dist/views/memberDeduction/memberDeduction.less +238 -0
  121. package/dist/views/memberManage/MemberOrderView.js +427 -0
  122. package/dist/views/memberManage/MemberOrderView.js.map +1 -0
  123. package/dist/views/memberManage/memberOrder.less +72 -0
  124. package/dist/views/memberProject/GroupProjectModal.js +676 -0
  125. package/dist/views/memberProject/GroupProjectModal.js.map +1 -0
  126. package/dist/views/memberProject/MemberProjectView.js +578 -0
  127. package/dist/views/memberProject/MemberProjectView.js.map +1 -0
  128. package/dist/views/memberProject/SelectProjectModal.js +330 -0
  129. package/dist/views/memberProject/SelectProjectModal.js.map +1 -0
  130. package/dist/views/memberProject/memberProject.less +334 -0
  131. package/dist/views/memberRecharge/MemberStoreView.js +546 -0
  132. package/dist/views/memberRecharge/MemberStoreView.js.map +1 -0
  133. package/dist/views/memberRecharge/memberStore.less +148 -0
  134. package/package.json +1 -1
@@ -0,0 +1,427 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = undefined;
7
+
8
+ var _getOwnPropertyDescriptor = require('babel-runtime/core-js/object/get-own-property-descriptor');
9
+
10
+ var _getOwnPropertyDescriptor2 = _interopRequireDefault(_getOwnPropertyDescriptor);
11
+
12
+ var _Button3 = require('tinper-bee/dist/Button');
13
+
14
+ var _Button4 = _interopRequireDefault(_Button3);
15
+
16
+ var _keys = require('babel-runtime/core-js/object/keys');
17
+
18
+ var _keys2 = _interopRequireDefault(_keys);
19
+
20
+ var _regenerator = require('babel-runtime/regenerator');
21
+
22
+ var _regenerator2 = _interopRequireDefault(_regenerator);
23
+
24
+ var _asyncToGenerator2 = require('babel-runtime/helpers/asyncToGenerator');
25
+
26
+ var _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2);
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 _dec, _class, _desc, _value, _class2;
49
+
50
+ require('tinper-bee/dist/Button/index.css');
51
+
52
+ var _react = require('react');
53
+
54
+ var _react2 = _interopRequireDefault(_react);
55
+
56
+ var _mutantsAppfx = require('mutants-appfx');
57
+
58
+ var _tplusComponentsTouch = require('tplus-components-touch');
59
+
60
+ var _mutantsMicrofx = require('mutants-microfx');
61
+
62
+ var _mutantsUtil = require('mutants-util');
63
+
64
+ var _mobx = require('mobx');
65
+
66
+ var _mobxReact = require('mobx-react');
67
+
68
+ var _cloneDeep = require('lodash/cloneDeep');
69
+
70
+ var _cloneDeep2 = _interopRequireDefault(_cloneDeep);
71
+
72
+ var _MemberPhoto = require('../../member/MemberPhoto');
73
+
74
+ var _MemberPhoto2 = _interopRequireDefault(_MemberPhoto);
75
+
76
+ require('./memberOrder.less');
77
+
78
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
79
+
80
+ function _applyDecoratedDescriptor(target, property, decorators, descriptor, context) {
81
+ var desc = {};
82
+ Object['ke' + 'ys'](descriptor).forEach(function (key) {
83
+ desc[key] = descriptor[key];
84
+ });
85
+ desc.enumerable = !!desc.enumerable;
86
+ desc.configurable = !!desc.configurable;
87
+
88
+ if ('value' in desc || desc.initializer) {
89
+ desc.writable = true;
90
+ }
91
+
92
+ desc = decorators.slice().reverse().reduce(function (desc, decorator) {
93
+ return decorator(target, property, desc) || desc;
94
+ }, desc);
95
+
96
+ if (context && desc.initializer !== void 0) {
97
+ desc.value = desc.initializer ? desc.initializer.call(context) : void 0;
98
+ desc.initializer = undefined;
99
+ }
100
+
101
+ if (desc.initializer === void 0) {
102
+ Object['define' + 'Property'](target, property, desc);
103
+ desc = null;
104
+ }
105
+
106
+ return desc;
107
+ }
108
+
109
+ var defaultImage = 'https://newretail.static.chanjet.com/default_avatar.png';
110
+ /**
111
+ * func
112
+ * @prop sub save / edit
113
+ * @prop route
114
+ * @prop ck 回掉函数
115
+ */
116
+ var funcs = {
117
+ 'save': {
118
+ sub: 'save',
119
+ route: '/AA/MEMBER',
120
+ // tip:'新增会员成功',
121
+ ck: 'jumpToMemberManager'
122
+ },
123
+ 'edit': {
124
+ sub: 'edit',
125
+ route: '/AA/OPENCARD',
126
+ // tip:'开卡成功',
127
+ ck: 'openCardCk'
128
+ }
129
+ };
130
+
131
+ var _default = (_dec = (0, _mutantsAppfx.injectViewModel)('Voucher'), _dec(_class = (0, _mobxReact.observer)(_class = (_class2 = function (_React$Component) {
132
+ (0, _inherits3.default)(_default, _React$Component);
133
+
134
+ function _default(props, context) {
135
+ (0, _classCallCheck3.default)(this, _default);
136
+
137
+ var _this2 = (0, _possibleConstructorReturn3.default)(this, (_default.__proto__ || (0, _getPrototypeOf2.default)(_default)).call(this, props, context));
138
+
139
+ _this2.cancel = function () {
140
+ _mutantsMicrofx.stores.modalRouter.hide(_this2.func.route);
141
+ };
142
+
143
+ _this2.handleSave = function () {
144
+ _this2.form.validateFields && _this2.form.validateFields(function (err, values) {
145
+ if (err) {
146
+ console.log('校验失败', values, err);
147
+ _this2.error(err, values);
148
+ } else {
149
+ _this2.saveMember();
150
+ console.log('提交成功', values);
151
+ }
152
+ });
153
+ };
154
+
155
+ _this2.handleCancel = function () {
156
+ _this2.cancel();
157
+
158
+ var _ref = _mutantsUtil.platform || {},
159
+ isHorizontalSunMi = _ref.isHorizontalSunMi;
160
+
161
+ isHorizontalSunMi && window.android_setKeyBoard && window.android_setKeyBoard.SetKeyBoardDisplay(0);
162
+ };
163
+
164
+ _this2.func = funcs.save;
165
+ _this2.state = { showModal: false };
166
+ return _this2;
167
+ }
168
+
169
+ (0, _createClass3.default)(_default, [{
170
+ key: 'changeVal',
171
+ value: function () {
172
+ var _ref2 = (0, _asyncToGenerator3.default)( /*#__PURE__*/_regenerator2.default.mark(function _callee(changed) {
173
+ var Assign = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
174
+
175
+ var _this, changeVal, viewModel, controllerEvent;
176
+
177
+ return _regenerator2.default.wrap(function _callee$(_context) {
178
+ while (1) {
179
+ switch (_context.prev = _context.next) {
180
+ case 0:
181
+ _this = this;
182
+ changeVal = this.props.viewModel.changeVal;
183
+ viewModel = this.props.viewModel;
184
+ controllerEvent = this.props.controllerEvent;
185
+
186
+ controllerEvent('change', { changed: changed, Assign: Assign }).then(function () {
187
+ _this.setState({});
188
+ });
189
+
190
+ case 5:
191
+ case 'end':
192
+ return _context.stop();
193
+ }
194
+ }
195
+ }, _callee, this);
196
+ }));
197
+
198
+ function changeVal(_x) {
199
+ return _ref2.apply(this, arguments);
200
+ }
201
+
202
+ return changeVal;
203
+ }()
204
+ }, {
205
+ key: 'saveMember',
206
+ value: function () {
207
+ var _ref3 = (0, _asyncToGenerator3.default)( /*#__PURE__*/_regenerator2.default.mark(function _callee2() {
208
+ var saveMember, _this, viewModel, controllerEvent, verifyResult;
209
+
210
+ return _regenerator2.default.wrap(function _callee2$(_context2) {
211
+ while (1) {
212
+ switch (_context2.prev = _context2.next) {
213
+ case 0:
214
+ saveMember = this.props.viewModel.saveMember;
215
+ _this = this;
216
+ viewModel = this.props.viewModel;
217
+ controllerEvent = this.props.controllerEvent;
218
+ _context2.next = 6;
219
+ return controllerEvent('handleData');
220
+
221
+ case 6:
222
+ verifyResult = _context2.sent;
223
+
224
+ if (viewModel.verify) {
225
+ _context2.next = 9;
226
+ break;
227
+ }
228
+
229
+ return _context2.abrupt('return');
230
+
231
+ case 9:
232
+
233
+ saveMember(this.func.save, function (result) {
234
+ //保存或者编辑会员后处理
235
+ _this[_this.func.ck] && _this[_this.func.ck]();
236
+ });
237
+
238
+ case 10:
239
+ case 'end':
240
+ return _context2.stop();
241
+ }
242
+ }
243
+ }, _callee2, this);
244
+ }));
245
+
246
+ function saveMember() {
247
+ return _ref3.apply(this, arguments);
248
+ }
249
+
250
+ return saveMember;
251
+ }()
252
+ }, {
253
+ key: 'openCardCk',
254
+ value: function openCardCk() {
255
+ _tplusComponentsTouch.Message.success('开卡成功');
256
+ _mutantsMicrofx.stores.modalRouter.hide(this.func.route);
257
+ var ck = _mutantsMicrofx.stores.modalRouter.modals[this.func.route].closeCk;
258
+ ck && ck();
259
+ }
260
+ }, {
261
+ key: 'jumpToMemberManager',
262
+ value: function jumpToMemberManager() {
263
+ _mutantsMicrofx.stores.modalRouter.hide(this.func.route);
264
+ if (!_mutantsMicrofx.stores.drawerStore) return;
265
+ var data = this.props.viewModel.data;
266
+
267
+ if (_mutantsMicrofx.stores.selectMemberStore) {
268
+ _mutantsMicrofx.stores.selectMemberStore.searchValue = data.CardCode || '';
269
+ }
270
+ setTimeout(function () {
271
+ _mutantsMicrofx.stores.drawerStore.init({ title: '会员管理', key: 'member' });
272
+ }, 300);
273
+ }
274
+ }, {
275
+ key: 'componentWillMount',
276
+ value: function componentWillMount() {
277
+ var _this3 = this;
278
+
279
+ var mid = this.props.mid;
280
+ var _props$viewModel = this.props.viewModel,
281
+ data = _props$viewModel.data,
282
+ AddMemberView = _props$viewModel.AddMemberView;
283
+ var viewModel = this.props.viewModel;
284
+
285
+ if (mid && mid == 'OPENCARD') {
286
+ this.func = funcs.edit;
287
+ var _this = this;
288
+ (0, _mobx.when)(function () {
289
+ var keys = (0, _keys2.default)(data);
290
+ return !!keys.length;
291
+ }, function () {
292
+ if (_mutantsMicrofx.stores.selectMemberStore && _mutantsMicrofx.stores.selectMemberStore.curMemberInfo) {
293
+ var editData = _mutantsMicrofx.stores.selectMemberStore.curMemberInfo || {};
294
+ _this.changeVal((0, _cloneDeep2.default)(editData), true);
295
+ }
296
+ });
297
+ };
298
+ // if(mid&&mid=='MEMBER'){
299
+ (0, _mobx.when)(function () {
300
+ return !!(viewModel && viewModel.AddMemberView);
301
+ }, function () {
302
+ var controllerEvent = _this3.props.controllerEvent;
303
+
304
+ controllerEvent('modifyVM', { viewModel: viewModel });
305
+ });
306
+ // }
307
+ }
308
+ }, {
309
+ key: 'getErrorField',
310
+ value: function getErrorField(err) {
311
+ var keys = (0, _keys2.default)(err) || [];
312
+ if (keys.includes('errors')) {
313
+ return err['errors'];
314
+ } else {
315
+ return this.getErrorField(err[keys[0]]);
316
+ }
317
+ }
318
+ }, {
319
+ key: 'error',
320
+ value: function error(err, values) {
321
+ var _props$viewModel2 = this.props.viewModel,
322
+ data = _props$viewModel2.data,
323
+ Headers = _props$viewModel2.AddMemberView.Headers,
324
+ GetMemberReferData = _props$viewModel2.GetMemberReferData;
325
+
326
+ var error = this.getErrorField(err);
327
+ var field = (error[0] || {}).field;
328
+ var title = (Headers.find(function (el) {
329
+ return el.FieldName == field;
330
+ }) || {}).Title || '';
331
+ _tplusComponentsTouch.Message.info('\u8BF7\u8F93\u5165' + title);
332
+ }
333
+
334
+ // 提交
335
+
336
+
337
+ //取消
338
+
339
+ }, {
340
+ key: 'render',
341
+ value: function render() {
342
+ var _this4 = this;
343
+
344
+ var _props = this.props,
345
+ _props$viewModel3 = _props.viewModel,
346
+ data = _props$viewModel3.data,
347
+ Headers = _props$viewModel3.AddMemberView.Headers,
348
+ GetMemberReferData = _props$viewModel3.GetMemberReferData,
349
+ mid = _props.mid;
350
+
351
+ console.log('member_datainfo===', data);
352
+ console.log('member_viewinfo===', Headers);
353
+ console.log('member_viewinfo-contorl===', Headers.map(function (el) {
354
+ return el.ControlType;
355
+ }));
356
+ var imageField = Headers.find(function (el) {
357
+ return el.FieldName == 'ImageFile';
358
+ });
359
+ var isImage = imageField && imageField.Visible;
360
+ var isImageRead = imageField && imageField.ReadOnly;
361
+ var showModal = this.state.showModal;
362
+
363
+ var _ref4 = data || {},
364
+ ImageFile = _ref4.ImageFile;
365
+
366
+ Headers.map(function (item) {
367
+ return item.isUserAndroidKey = item.Title == "会员姓名" ? true : false;
368
+ });
369
+
370
+ return _react2.default.createElement(
371
+ 'div',
372
+ { className: 'memberadd-container' },
373
+ _react2.default.createElement(
374
+ 'div',
375
+ { className: 'image', style: { display: !!isImage ? 'block' : 'none' } },
376
+ _react2.default.createElement('img', { src: ImageFile || defaultImage })
377
+ ),
378
+ !!isImage && !isImageRead && _react2.default.createElement(_tplusComponentsTouch.Ticon, { type: 'bianjixinxi', className: 'editIcon', onClick: function onClick() {
379
+ _this4.setState({ showModal: true });
380
+ } }),
381
+ _react2.default.createElement(_tplusComponentsTouch.CommonForm, {
382
+ ref: function ref(el) {
383
+ _this4.form = el;
384
+ },
385
+ data: data,
386
+ viewInfo: Headers,
387
+ changeVal: function changeVal(changed) {
388
+ _this4.changeVal(changed);
389
+ },
390
+ styles: {
391
+ 'height': !!isImage ? '326px' : '376px',
392
+ 'overflow': 'auto'
393
+ },
394
+ getMemberReferData: GetMemberReferData
395
+ }),
396
+ _react2.default.createElement(
397
+ 'div',
398
+ { className: 'memberadd-submit' },
399
+ _react2.default.createElement(
400
+ _Button4.default,
401
+ { type: 'success', onClick: this.handleSave },
402
+ '\u786E\u5B9A'
403
+ ),
404
+ _react2.default.createElement(
405
+ _Button4.default,
406
+ { type: 'cancel', onClick: this.handleCancel },
407
+ '\u53D6\u6D88'
408
+ )
409
+ ),
410
+ _react2.default.createElement(_MemberPhoto2.default, { titleModal: '头像选择',
411
+ showModal: showModal,
412
+ handleModal: function handleModal() {
413
+ _this4.setState({ showModal: false });
414
+ },
415
+ onOk: function onOk(src) {
416
+ _this4.changeVal({ ImageFile: src || '' });
417
+ _this4.setState({ showModal: false });
418
+ }
419
+ })
420
+ );
421
+ }
422
+ }]);
423
+ return _default;
424
+ }(_react2.default.Component), (_applyDecoratedDescriptor(_class2.prototype, 'changeVal', [_mobx.action], (0, _getOwnPropertyDescriptor2.default)(_class2.prototype, 'changeVal'), _class2.prototype)), _class2)) || _class) || _class);
425
+
426
+ exports.default = _default;
427
+ //# sourceMappingURL=MemberOrderView.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["tplus-member/views/memberManage/MemberOrderView.js"],"names":["defaultImage","funcs","sub","route","ck","observer","props","context","cancel","stores","modalRouter","hide","func","handleSave","form","validateFields","err","values","console","log","error","saveMember","handleCancel","platform","isHorizontalSunMi","window","android_setKeyBoard","SetKeyBoardDisplay","save","state","showModal","changed","Assign","_this","changeVal","viewModel","controllerEvent","then","setState","verifyResult","verify","result","Message","success","modals","closeCk","drawerStore","data","selectMemberStore","searchValue","CardCode","setTimeout","init","title","key","mid","AddMemberView","edit","keys","length","curMemberInfo","editData","includes","getErrorField","Headers","GetMemberReferData","field","find","el","FieldName","Title","info","map","ControlType","imageField","isImage","Visible","isImageRead","ReadOnly","ImageFile","item","isUserAndroidKey","display","src","React","Component","action"],"mappings":"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","file":"MemberOrderView.js","sourcesContent":["import React, { Component } from 'react';\nimport { injectViewModel } from 'mutants-appfx'\nimport { CommonForm, Message,Ticon } from 'tplus-components-touch'\nimport { Button } from 'tinper-bee'\nimport { stores } from 'mutants-microfx'\nimport { platform } from 'mutants-util';\nimport { when, toJS } from 'mobx';\nimport { observer } from 'mobx-react';\nimport { action, runInAction } from 'mobx';\nimport _clonedeep from 'lodash/cloneDeep';\nimport MemberPhoto from '../../member/MemberPhoto';\nimport './memberOrder.less'\n\nconst defaultImage = 'https://newretail.static.chanjet.com/default_avatar.png'\n/**\n * func\n * @prop sub save / edit\n * @prop route \n * @prop ck 回掉函数 \n */\nconst funcs = {\n 'save': {\n sub: 'save',\n route: '/AA/MEMBER',\n // tip:'新增会员成功',\n ck: 'jumpToMemberManager'\n },\n 'edit': {\n sub: 'edit',\n route: '/AA/OPENCARD',\n // tip:'开卡成功',\n ck: 'openCardCk'\n }\n}\n@injectViewModel('Voucher')\n@observer\nexport default class extends React.Component {\n\n constructor(props, context) {\n super(props, context)\n this.func = funcs.save;\n this.state = { showModal: false }\n }\n\n @action\n async changeVal(changed,Assign=false) {\n const _this = this;\n const { viewModel: { changeVal } } = this.props;\n const { viewModel } = this.props;\n const { controllerEvent } = this.props;\n controllerEvent('change', { changed,Assign }).then(() => {\n _this.setState({})\n });\n }\n\n async saveMember() {\n const { viewModel: { saveMember } } = this.props;\n const _this = this;\n const { viewModel } = this.props;\n const { controllerEvent } = this.props;\n const verifyResult = await controllerEvent('handleData');\n if (!viewModel.verify) return;\n\n saveMember(this.func.save, (result) => {\n //保存或者编辑会员后处理\n _this[_this.func.ck] && _this[_this.func.ck]()\n });\n }\n\n openCardCk() {\n Message.success('开卡成功')\n stores.modalRouter.hide(this.func.route);\n const ck = stores.modalRouter.modals[this.func.route].closeCk;\n ck && ck();\n }\n\n jumpToMemberManager() {\n stores.modalRouter.hide(this.func.route);\n if (!stores.drawerStore) return;\n const { viewModel: { data } } = this.props;\n if (stores.selectMemberStore) {\n stores.selectMemberStore.searchValue = data.CardCode || ''\n }\n setTimeout(() => { stores.drawerStore.init({ title: '会员管理', key: 'member' }) }, 300)\n }\n\n componentWillMount() {\n const { mid } = this.props;\n const { viewModel: { data, AddMemberView } } = this.props;\n const { viewModel } = this.props;\n if (mid && mid == 'OPENCARD') {\n this.func = funcs.edit;\n const _this = this;\n when(() => {\n let keys = Object.keys(data);\n return !!keys.length;\n }, () => {\n if (stores.selectMemberStore && stores.selectMemberStore.curMemberInfo) {\n const editData = stores.selectMemberStore.curMemberInfo || {};\n _this.changeVal(_clonedeep(editData),true)\n }\n })\n };\n // if(mid&&mid=='MEMBER'){\n when(() => {\n return !!(viewModel && viewModel.AddMemberView);\n }, () => {\n const { controllerEvent } = this.props;\n controllerEvent('modifyVM', { viewModel });\n })\n // }\n }\n cancel = () => {\n stores.modalRouter.hide(this.func.route)\n }\n\n getErrorField(err) {\n let keys = Object.keys(err) || [];\n if (keys.includes('errors')) {\n return err['errors']\n } else {\n return this.getErrorField(err[keys[0]])\n }\n }\n\n error(err, values) {\n const { viewModel: { data, AddMemberView: { Headers }, GetMemberReferData } } = this.props;\n const error = this.getErrorField(err);\n const field = (error[0] || {}).field;\n const title = (Headers.find(el => el.FieldName == field) || {}).Title || '';\n Message.info(`请输入${title}`)\n }\n\n // 提交\n handleSave = () => {\n this.form.validateFields && this.form.validateFields((err, values) => {\n if (err) {\n console.log('校验失败', values, err);\n this.error(err, values)\n } else {\n this.saveMember();\n console.log('提交成功', values)\n }\n })\n }\n\n //取消\n handleCancel = () => {\n this.cancel()\n const { isHorizontalSunMi } = platform || {};\n isHorizontalSunMi && window.android_setKeyBoard && window.android_setKeyBoard.SetKeyBoardDisplay(0)\n }\n\n render() {\n const { viewModel: { data, AddMemberView: { Headers }, GetMemberReferData }, mid } = this.props;\n console.log('member_datainfo===', data)\n console.log('member_viewinfo===', Headers)\n console.log('member_viewinfo-contorl===', Headers.map((el) => el.ControlType))\n const imageField = Headers.find((el) => el.FieldName == 'ImageFile');\n const isImage = imageField && imageField.Visible;\n const isImageRead = imageField && imageField.ReadOnly;\n const { showModal } = this.state;\n const { ImageFile } = data || {};\n\n Headers.map(item => item.isUserAndroidKey = item.Title == \"会员姓名\"? true : false);\n\n return (\n <div className='memberadd-container'>\n <div className='image' style={{ display: !!isImage ? 'block' : 'none' }}>\n <img src={ImageFile || defaultImage} />\n </div>\n {\n !!isImage && !isImageRead && \n <Ticon type=\"bianjixinxi\" className='editIcon' onClick={() => { this.setState({ showModal: true }) }} />\n }\n <CommonForm\n ref={(el) => { this.form = el }}\n data={data}\n viewInfo={Headers}\n changeVal={(changed) => {\n this.changeVal(changed)\n }}\n styles={{\n 'height': !!isImage ? '326px' : '376px',\n 'overflow': 'auto'\n }}\n getMemberReferData={GetMemberReferData}\n >\n </CommonForm>\n\n <div className='memberadd-submit'>\n <Button type='success' onClick={this.handleSave}>确定</Button>\n <Button type=\"cancel\" onClick={this.handleCancel}>取消</Button>\n </div>\n\n <MemberPhoto titleModal={'头像选择'}\n showModal={showModal}\n handleModal={() => {\n this.setState({ showModal: false })\n }}\n onOk={(src) => {\n this.changeVal({ ImageFile: src || '' })\n this.setState({ showModal: false })\n }}\n />\n </div>)\n }\n}"]}
@@ -0,0 +1,72 @@
1
+ .memberAddModal{
2
+ .u-modal-body{
3
+ overflow:initial!important;
4
+ >section{
5
+ height: 336px!important;
6
+ }
7
+ section{
8
+ background: white;
9
+ }
10
+ }
11
+ .memberadd-submit{
12
+
13
+ }
14
+ .memberadd-container{
15
+ position: relative;
16
+ height: 376px;
17
+ .image{
18
+ width:48px;
19
+ height:48px;
20
+ border:1px solid #EFEFEF;
21
+ border-radius: 50%;
22
+ margin:0 auto;
23
+ margin-top: 2px;
24
+ overflow: hidden;
25
+ img {
26
+ margin: -1px;
27
+ width : 104%;
28
+ height: 104%;
29
+ }
30
+ }
31
+ .editIcon{
32
+ position: absolute;
33
+ top: 27px;
34
+ left: 410px;
35
+ color: #FF8C26;
36
+ }
37
+ .memberadd-submit{
38
+ width:100%;
39
+ height: 46px;
40
+ border-top: 1px solid #E6E6EB!important;
41
+ display: flex;
42
+ justify-content: space-between;
43
+ align-items: center;
44
+ justify-content: flex-end
45
+ }
46
+
47
+ button{
48
+ height:32px;
49
+ font-size:16px;
50
+ margin-left:16px;
51
+ border-radius: 4px;
52
+ line-height: 24px;
53
+ // float: right;
54
+ }
55
+ button[type='success']{
56
+ color:#fff!important;
57
+ // background: var(--modal-btn);
58
+ background: #FF8C26!important;
59
+ border:none!important;
60
+ }
61
+ button[type='cancel']{
62
+ color: #2D2D2D!important;
63
+ background: #FFF!important;
64
+ border: 1px solid #D2D2D7!important;
65
+ margin-right: 16px;
66
+ }
67
+ .u-button:hover {//去掉划过颜色
68
+ background-color: static!important;
69
+ border-color: static!important;
70
+ }
71
+ }
72
+ }