1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 | import { rowUtilFunObj } from './row-util';
|
7 | import { isArray } from 'tinper-sparrow/src/util';
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 |
|
18 |
|
19 | var setValue = function setValue(fieldName, value, ctx, options) {
|
20 |
|
21 | if (arguments.length === 1) {
|
22 | value = fieldName;
|
23 | fieldName = '$data';
|
24 | }
|
25 | var oldValue = this.getValue(fieldName);
|
26 | if (typeof oldValue == 'undefined' || oldValue === null) oldValue = '';
|
27 | if (rowUtilFunObj.eq(oldValue, value)) return;
|
28 | var event = {
|
29 | eventType: 'dataTableEvent',
|
30 | dataTable: this.parent.id,
|
31 | rowId: this.rowId,
|
32 | field: fieldName,
|
33 | oldValue: oldValue,
|
34 | newValue: value,
|
35 | ctx: ctx || ""
|
36 | };
|
37 | var flag = this.parent.triggerReturn(DataTable.ON_BEFORE_VALUE_CHANGE, event);
|
38 | if (!flag) {
|
39 | rowUtilFunObj._triggerChange(this, fieldName, oldValue, ctx);
|
40 | return;
|
41 | }
|
42 | rowUtilFunObj._getField(this, fieldName)['value'] = value;
|
43 | rowUtilFunObj._triggerChange(this, fieldName, oldValue, ctx);
|
44 | };
|
45 |
|
46 |
|
47 | var setChildValue = function setChildValue(fieldName, value) {
|
48 | var nameArr = fieldName.split('.');
|
49 | var _name = nameArr[0];
|
50 | var _field = this.data[_name];
|
51 | for (var i = 0, count = nameArr.length; i < count; i++) {
|
52 |
|
53 | if (i == count - 1) {
|
54 | if (_field['value'] instanceof u.DataTable) {
|
55 |
|
56 | } else {
|
57 | this.setValue(fieldName, value);
|
58 | }
|
59 | } else {
|
60 | if (_field && _field['value'] instanceof u.DataTable) {
|
61 | var row = _field['value'].getCurrentRow();
|
62 | if (row) row.setChildValue(fieldName.replace(_name + '.', ''), value);
|
63 | } else {
|
64 | _name = nameArr[i + 1];
|
65 | _field = _field[_name];
|
66 | }
|
67 | }
|
68 | }
|
69 | };
|
70 |
|
71 |
|
72 | var setChildSimpleDataByRowId = function setChildSimpleDataByRowId(rowId, data) {
|
73 | var rowIdArr = rowId.split('.');
|
74 | var rowIdLength = rowIdArr.length;
|
75 | if (rowIdLength > 1) {
|
76 | var _childField = rowIdArr[0];
|
77 | var _childObj = this.data[_childField];
|
78 | if (_childObj && _childObj['value'] instanceof u.DataTable) {
|
79 | var rowId = rowIdArr[1];
|
80 | var row = null;
|
81 | if (rowId) row = _childObj['value'].getRowByRowId(rowId);
|
82 | if (row) {
|
83 | if (rowIdArr.length == 2) {
|
84 | row.setSimpleData(data);
|
85 | } else {
|
86 | row.setChildSimpleDataByRowId(fieldName.replace(_childField + '.' + rowId + '.', ''), data);
|
87 | }
|
88 | }
|
89 | }
|
90 | }
|
91 | };
|
92 |
|
93 |
|
94 |
|
95 |
|
96 |
|
97 |
|
98 |
|
99 |
|
100 |
|
101 |
|
102 |
|
103 | var _setData = function _setData(rowObj, sourceData, targetData, subscribe, parentKey, options) {
|
104 | for (var key in sourceData) {
|
105 |
|
106 |
|
107 | if (options && !options.fieldFlag) {
|
108 | if (!rowObj.parent.getMeta(key)) {
|
109 | continue;
|
110 | }
|
111 | }
|
112 | var _parentKey = parentKey || null;
|
113 |
|
114 | targetData[key] = targetData[key] || {};
|
115 | var valueObj = sourceData[key];
|
116 |
|
117 |
|
118 |
|
119 |
|
120 |
|
121 |
|
122 |
|
123 |
|
124 |
|
125 |
|
126 | if (valueObj == null || (typeof valueObj === 'undefined' ? 'undefined' : babelHelpers['typeof'](valueObj)) != 'object') {
|
127 |
|
128 | if (!targetData[key].isChild) {
|
129 | targetData[key]['value'] = rowObj.formatValue(key, valueObj);
|
130 | }
|
131 | if (subscribe === true && oldValue !== targetData[key]['value']) {
|
132 | rowUtilFunObj._triggerChange(rowObj, key, oldValue);
|
133 | }
|
134 | } else {
|
135 | if (valueObj.error) {
|
136 | if (u.showMessageDialog) u.showMessageDialog({
|
137 | title: "警告",
|
138 | msg: valueObj.error,
|
139 | backdrop: true
|
140 | });else alert(valueObj.error);
|
141 | } else if (valueObj.value || valueObj.value === null || valueObj.meta || valueObj.value === '' || valueObj.value === '0' || valueObj.value === 0) {
|
142 | var oldValue = targetData[key]['value'];
|
143 | targetData[key]['value'] = rowObj.formatValue(key, valueObj.value);
|
144 | if (subscribe === true && oldValue !== targetData[key]['value']) {
|
145 | rowUtilFunObj._triggerChange(rowObj, key, oldValue);
|
146 | }
|
147 | for (var k in valueObj.meta) {
|
148 | rowObj.setMeta(key, k, valueObj.meta[k]);
|
149 | }
|
150 | } else if (isArray(valueObj)) {
|
151 | targetData[key].isChild = true;
|
152 |
|
153 | var _key = _parentKey == null ? key : _parentKey + '.' + key;
|
154 | var ns = rowObj.parent.ns === '' ? key : rowObj.parent.ns + '.' + _key;
|
155 | if (rowObj.parent.meta[_key]) {
|
156 | var meta = rowObj.parent.meta[_key]['meta'];
|
157 | targetData[key].value = new u.DataTable({
|
158 | root: rowObj.parent.root,
|
159 | ns: ns,
|
160 | meta: meta
|
161 | });
|
162 | targetData[key].value.setSimpleData(valueObj);
|
163 | }
|
164 | } else {
|
165 | _parentKey = _parentKey == null ? key : _parentKey + '.' + key;
|
166 | _setData(rowObj, valueObj, targetData[key], null, _parentKey, options);
|
167 | }
|
168 | }
|
169 |
|
170 | }
|
171 | };
|
172 |
|
173 |
|
174 |
|
175 |
|
176 |
|
177 |
|
178 |
|
179 |
|
180 |
|
181 |
|
182 |
|
183 |
|
184 |
|
185 |
|
186 |
|
187 |
|
188 |
|
189 |
|
190 |
|
191 | var setData = function setData(data, subscribe, options) {
|
192 | var sourceData = data.data,
|
193 | targetData = this.data;
|
194 | if (this.parent.root.strict != true) {
|
195 | _setData(this, sourceData, targetData, subscribe, null, options);
|
196 | this.setStatus(data.status);
|
197 | return;
|
198 | }
|
199 |
|
200 |
|
201 | var meta = this.parent.meta;
|
202 | for (var key in meta) {
|
203 | var oldValue = newValue = null;
|
204 |
|
205 | if (meta[key]['type'] && meta[key]['type'] === 'child') {
|
206 | targetData[key].isChild = true;
|
207 |
|
208 | var ns = this.parent.ns === '' ? key : this.parent.ns + '.' + key;
|
209 | var meta = this.parent.meta[key]['meta'];
|
210 | targetData[key].value = new u.DataTable({
|
211 | root: this.parent.root,
|
212 | ns: ns,
|
213 | meta: meta
|
214 | });
|
215 | if (babelHelpers['typeof'](sourceData[key]) === 'object') targetData[key].value.setSimpleData(sourceData[key]);
|
216 | }
|
217 |
|
218 | else if (key.indexOf('.') != -1) {
|
219 | var keys = key.split('.');
|
220 | var _fieldValue = sourceData;
|
221 | var _targetField = targetData;
|
222 | for (var i = 0; i < keys.length; i++) {
|
223 | _fieldValue = _fieldValue || {};
|
224 | _fieldValue = _fieldValue[keys[i]];
|
225 | _targetField = _targetField[keys[i]];
|
226 | }
|
227 | oldValue = _targetField['value'];
|
228 | _targetField['value'] = this.formatValue(key, _fieldValue);
|
229 | newValue = _targetField['value'];
|
230 | }
|
231 |
|
232 | else if (sourceData[key] == null || babelHelpers['typeof'](sourceData[key]) != 'object') {
|
233 | oldValue = targetData[key]['value'];
|
234 | targetData[key]['value'] = this.formatValue(key, sourceData[key]);
|
235 | newValue = targetData[key]['value'];
|
236 | } else {
|
237 | var valueObj = sourceData[key];
|
238 | if (valueObj.error) {
|
239 | if (u.showMessageDialog) u.showMessageDialog({
|
240 | title: "警告",
|
241 | msg: valueObj.error,
|
242 | backdrop: true
|
243 | });else alert(valueObj.error);
|
244 | } else if (valueObj.value || valueObj.value === null || valueObj.meta) {
|
245 | oldValue = targetData[key]['value'];
|
246 | targetData[key]['value'] = this.formatValue(key, valueObj.value);
|
247 | newValue = targetData[key]['value'];
|
248 | for (var k in valueObj.meta) {
|
249 | this.setMeta(key, k, valueObj.meta[k]);
|
250 | }
|
251 | }
|
252 | }
|
253 | if (subscribe === true && oldValue !== newValue) {
|
254 | rowUtilFunObj._triggerChange(this, key, oldValue);
|
255 | }
|
256 | }
|
257 | };
|
258 |
|
259 |
|
260 | var updateRow = function updateRow(row) {
|
261 | this.setData(row);
|
262 | };
|
263 |
|
264 |
|
265 |
|
266 |
|
267 |
|
268 |
|
269 |
|
270 |
|
271 | var setStatus = function setStatus(status) {
|
272 | this.status = status;
|
273 | if (status == Row.STATUS.NORMAL) {
|
274 |
|
275 | var data = this.data;
|
276 | for (var field in data) {
|
277 | var value = data[field].value;
|
278 | data[field].baseValue = value;
|
279 | }
|
280 | }
|
281 | };
|
282 |
|
283 |
|
284 |
|
285 |
|
286 |
|
287 |
|
288 | var resetValue = function resetValue() {
|
289 | var data = this.data;
|
290 | for (var field in data) {
|
291 | var value = data[field].baseValue;
|
292 | this.setValue(field, value);
|
293 | }
|
294 | };
|
295 |
|
296 | export var rowDataFunObj = {
|
297 | setValue: setValue,
|
298 | setChildValue: setChildValue,
|
299 | setChildSimpleDataByRowId: setChildSimpleDataByRowId,
|
300 | setData: setData,
|
301 | updateRow: updateRow,
|
302 | setStatus: setStatus,
|
303 | resetValue: resetValue
|
304 | }; |
\ | No newline at end of file |