@builttocreate/engine-utils 2.5.0 → 2.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -19,6 +19,10 @@ var _FieldPresentationModes = _interopRequireDefault(require("./constants/FieldP
19
19
 
20
20
  var _DocumentTypes = _interopRequireDefault(require("./constants/DocumentTypes"));
21
21
 
22
+ var _FieldTypes = _interopRequireDefault(require("./constants/FieldTypes"));
23
+
24
+ var _tableHelper = require("./tableHelper");
25
+
22
26
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
23
27
 
24
28
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
@@ -98,6 +102,7 @@ var getDefaultJoyDoc = function getDefaultJoyDoc() {
98
102
  * 1. Valid file inside the document.
99
103
  * 2. Valid page inside document file.
100
104
  * 3. All _id's (page, file, page, fieldPosition, field) are in a valid format
105
+ * 4. Row order of table field is free from duplicate/deletedRow Ids
101
106
  *
102
107
  * @param {Object} doc
103
108
  * @returns {Object}
@@ -153,6 +158,24 @@ var getCleanedJoyDoc = function getCleanedJoyDoc(doc) {
153
158
  } else {
154
159
  nextDoc.files = [getDefaultJoyDocFile()];
155
160
  }
161
+ /**
162
+ * Logic below is used to clean the table field rowOrder by removing the
163
+ * deletedRowIds / duplicateRowIds from the rowOrder.
164
+ **/
165
+
166
+
167
+ if (nextDoc.fields && nextDoc.fields.length > 0) {
168
+ nextDoc.fields = nextDoc.fields.map(function (field) {
169
+ var nextField = _objectSpread({}, field);
170
+
171
+ if (field.type === _FieldTypes["default"].table) {
172
+ var cleanedRoworder = (0, _tableHelper.getCleanedRowOrder)(field.rowOrder, field.value);
173
+ nextField.rowOrder = cleanedRoworder;
174
+ }
175
+
176
+ return nextField;
177
+ });
178
+ }
156
179
 
157
180
  return nextDoc;
158
181
  };
@@ -7,7 +7,7 @@ var _typeof3 = require("@babel/runtime/helpers/typeof");
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
- exports.validFormulaString = exports.spreadOperandRange = exports.sortRows = exports.sortColumns = exports.resolveOperandValue = exports.hasOperandRange = exports.hasCircularOperandReference = exports.handleTableCellChange = exports.handleMoveTableRowUp = exports.handleMoveTableRowDown = exports.handleMoveColumnRight = exports.handleMoveColumnLeft = exports.handleInsertTableRow = exports.handleDuplicateTableRow = exports.handleCreateTableRow = exports.getTemplateColumnOperandLookup = exports.getTargetColumnWithOperand = exports.getTableRowLookupWithPopulatedDropdownCells = exports.getTableFieldRowOrder = exports.getTableFieldLookupKey = exports.getRows = exports.getRowOrder = exports.getRowMap = exports.getRowIndexLookup = exports.getInputGroupRowLookupWithPopulatedDropdownCells = exports.getIndexesFromTableCellOperand = exports.getFormulaResult = exports.getFilteredRowOrder = exports.getDefaultTextColumn = exports.getDefaultRow = exports.getDefaultImageColumn = exports.getDefaultDropdownColumn = exports.getDefaultColumnOption = exports.getColumns = exports.getColumnOrder = exports.getColumnOperand = exports.getCellOperand = exports.generateTableLookupForRows = exports.generateTableLookup = exports.generateTableFieldLookups = exports.generateRowTableLookup = exports.generateInputGroupFields = exports["default"] = void 0;
10
+ exports.validFormulaString = exports.spreadOperandRange = exports.sortRows = exports.sortColumns = exports.resolveOperandValue = exports.hasOperandRange = exports.hasCircularOperandReference = exports.handleTableCellChange = exports.handleMoveTableRowUp = exports.handleMoveTableRowDown = exports.handleMoveColumnRight = exports.handleMoveColumnLeft = exports.handleInsertTableRow = exports.handleDuplicateTableRow = exports.handleCreateTableRow = exports.getTemplateColumnOperandLookup = exports.getTargetColumnWithOperand = exports.getTableRowLookupWithPopulatedDropdownCells = exports.getTableFieldRowOrder = exports.getTableFieldLookupKey = exports.getRows = exports.getRowOrder = exports.getRowMap = exports.getRowIndexLookup = exports.getInputGroupRowLookupWithPopulatedDropdownCells = exports.getIndexesFromTableCellOperand = exports.getFormulaResult = exports.getFilteredRowOrder = exports.getDefaultTextColumn = exports.getDefaultRow = exports.getDefaultImageColumn = exports.getDefaultDropdownColumn = exports.getDefaultColumnOption = exports.getColumns = exports.getColumnOrder = exports.getColumnOperand = exports.getCleanedRowOrder = exports.getCellOperand = exports.generateTableLookupForRows = exports.generateTableLookup = exports.generateTableFieldLookups = exports.generateRowTableLookup = exports.generateInputGroupFields = exports["default"] = void 0;
11
11
 
12
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
13
 
@@ -198,6 +198,53 @@ var getTableFieldRowOrder = function getTableFieldRowOrder(fieldId, fieldSetting
198
198
  return row._id;
199
199
  });
200
200
  };
201
+ /**
202
+ * This method removes the rowIds of the deleted rows (or) any duplicate rowIds
203
+ * from the rowOrder there by returning a cleaned rowOrder
204
+ * @param {*} rowOrder
205
+ * @param {*} rows
206
+ *
207
+ * @returns {Array}
208
+ **/
209
+
210
+
211
+ exports.getTableFieldRowOrder = getTableFieldRowOrder;
212
+
213
+ var getCleanedRowOrder = function getCleanedRowOrder(rowOrder, rows) {
214
+ var nextRowOrder = [];
215
+ /**
216
+ * Step 1: Handle generating or retrieving proper row order.
217
+ */
218
+
219
+ if (rowOrder && rowOrder.length > 0) {
220
+ nextRowOrder = rowOrder;
221
+ } else if (rows && rows.length > 0) {
222
+ rows.forEach(function (row) {
223
+ if (!row.deleted) nextRowOrder.push(row._id);
224
+ });
225
+ }
226
+ /**
227
+ * Step 2: Remove row Ids from rowOrder for rows that no longer exist or have been deleted
228
+ */
229
+
230
+
231
+ var rowLookup = {};
232
+ rows.forEach(function (row) {
233
+ return rowLookup[row._id] = row && !row.deleted;
234
+ });
235
+ nextRowOrder = nextRowOrder.filter(function (rowId) {
236
+ return rowLookup[rowId];
237
+ });
238
+ /**
239
+ * Step 3: Remove any duplicate row Id references in the row order.
240
+ */
241
+
242
+ var filteredNextRowOrder = [];
243
+ nextRowOrder.forEach(function (rowId) {
244
+ if (rowId && filteredNextRowOrder.indexOf(rowId) === -1) filteredNextRowOrder.push(rowId);
245
+ });
246
+ return filteredNextRowOrder;
247
+ };
201
248
  /**
202
249
  * Handle Move Column Left
203
250
  *
@@ -206,7 +253,7 @@ var getTableFieldRowOrder = function getTableFieldRowOrder(fieldId, fieldSetting
206
253
  */
207
254
 
208
255
 
209
- exports.getTableFieldRowOrder = getTableFieldRowOrder;
256
+ exports.getCleanedRowOrder = getCleanedRowOrder;
210
257
 
211
258
  var handleMoveColumnLeft = function handleMoveColumnLeft(columnIndex, callback) {
212
259
  //If first index then ignore
@@ -1161,9 +1208,11 @@ var _default = {
1161
1208
  getCellOperand: getCellOperand,
1162
1209
  getIndexesFromTableCellOperand: getIndexesFromTableCellOperand,
1163
1210
  getRowOrder: getRowOrder,
1211
+ getTableFieldRowOrder: getTableFieldRowOrder,
1212
+ getFilteredRowOrder: getFilteredRowOrder,
1213
+ getCleanedRowOrder: getCleanedRowOrder,
1164
1214
  getRows: getRows,
1165
1215
  sortRows: sortRows,
1166
- getFilteredRowOrder: getFilteredRowOrder,
1167
1216
  getDefaultRow: getDefaultRow,
1168
1217
  getRowMap: getRowMap,
1169
1218
  getDefaultColumnOption: getDefaultColumnOption,
@@ -1179,7 +1228,6 @@ var _default = {
1179
1228
  hasOperandRange: hasOperandRange,
1180
1229
  spreadOperandRange: spreadOperandRange,
1181
1230
  getTableFieldLookupKey: getTableFieldLookupKey,
1182
- getTableFieldRowOrder: getTableFieldRowOrder,
1183
1231
  getTableRowLookupWithPopulatedDropdownCells: getTableRowLookupWithPopulatedDropdownCells,
1184
1232
  getInputGroupRowLookupWithPopulatedDropdownCells: getInputGroupRowLookupWithPopulatedDropdownCells,
1185
1233
  getRowIndexLookup: getRowIndexLookup,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@builttocreate/engine-utils",
3
- "version": "2.5.0",
3
+ "version": "2.5.1",
4
4
  "description": "Utility library for common logic shared across web and mobile",
5
5
  "main": "dist/index.js",
6
6
  "files": [
@@ -54,6 +54,8 @@
54
54
  "moduleNameMapper": {
55
55
  "\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/__mocks__/fileMock.js",
56
56
  "\\.(css|less)$": "<rootDir>/__mocks__/styleMock.js"
57
- }
57
+ },
58
+ "globalSetup":"./jestConfig.js"
59
+
58
60
  }
59
61
  }