You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							73 lines
						
					
					
						
							2.6 KiB
						
					
					
				
			
		
		
	
	
							73 lines
						
					
					
						
							2.6 KiB
						
					
					
				| "use strict";
 | |
| 
 | |
| Object.defineProperty(exports, "__esModule", {
 | |
|   value: true
 | |
| });
 | |
| exports.get = void 0;
 | |
| 
 | |
| var _flat = require("flat");
 | |
| 
 | |
| var _constants = require("./constants");
 | |
| 
 | |
| var _selectParams = require("./select-params");
 | |
| 
 | |
| var _propertyKeyRegex = require("./property-key-regex");
 | |
| 
 | |
| const TEMP_HOLDING_KEY = 'TEMP_HOLDING_KEY';
 | |
| /**
 | |
|  * @load ./get.doc.md
 | |
|  * @memberof module:flat
 | |
|  * @param {FlattenParams}   params      flatten params from which property has to be taken
 | |
|  * @param {string}          [propertyPath]  name of the property
 | |
|  * @param {GetOptions}      options     options
 | |
|  * @returns {any}                       when property key exists directly it returns what is inside,
 | |
|  *                                      otherwise it tries to find any nested objects and returns
 | |
|  *                                      them
 | |
|  */
 | |
| 
 | |
| const get = (params = {}, propertyPath, options) => {
 | |
|   if (!propertyPath) {
 | |
|     return (0, _flat.unflatten)(params);
 | |
|   } // when object has this key - simply return it
 | |
|   // we cannot rely on typeof params[propertyPath !== 'undefined' because params can actually be
 | |
|   // undefined and in such case if would pass and function would return [undefined]
 | |
| 
 | |
| 
 | |
|   if (Object.keys(params).find(key => key === propertyPath)) {
 | |
|     return params[propertyPath];
 | |
|   }
 | |
| 
 | |
|   const regex = (0, _propertyKeyRegex.propertyKeyRegex)(propertyPath, options);
 | |
|   const selectedParams = (0, _selectParams.selectParams)(params, propertyPath, options);
 | |
|   const nestedProperties = Object.keys(selectedParams).reduce((memo, key, index) => {
 | |
|     let newKey = key.replace(regex, `${TEMP_HOLDING_KEY}${_constants.DELIMITER}`); // when user wants to take allSiblings we have to fix the indexes so nested items from
 | |
|     // different siblings don't overlap
 | |
|     //
 | |
|     // Example for key `nested.1.el`:
 | |
|     //  'nested.0.el.0.value': 'val0.0',
 | |
|     //  'nested.0.el.1.value': 'val0.1',
 | |
|     //  'nested.1.el.0.value': 'val1',
 | |
|     //  'nested.1.el.1.value': 'val2',
 | |
|     //
 | |
|     // has to be changed to:
 | |
|     //  'TEMP_HOLDING_KEY.0.value': 'val0.0',
 | |
|     //  'TEMP_HOLDING_KEY.1.value': 'val0.1',
 | |
|     //  'TEMP_HOLDING_KEY.2.value': 'val1',
 | |
|     //  'TEMP_HOLDING_KEY.3.value': 'val2',
 | |
| 
 | |
|     if (options !== null && options !== void 0 && options.includeAllSiblings) {
 | |
|       newKey = newKey.replace(new RegExp(`${TEMP_HOLDING_KEY}\\${_constants.DELIMITER}(\\d*)`), `${TEMP_HOLDING_KEY}${_constants.DELIMITER}${index}`);
 | |
|     }
 | |
| 
 | |
|     memo[newKey] = selectedParams[key];
 | |
|     return memo;
 | |
|   }, {});
 | |
| 
 | |
|   if (Object.keys(nestedProperties).length) {
 | |
|     return (0, _flat.unflatten)(nestedProperties)[TEMP_HOLDING_KEY];
 | |
|   }
 | |
| 
 | |
|   return undefined;
 | |
| };
 | |
| 
 | |
| exports.get = get; |