Socket
Socket
Sign inDemoInstall

proxima_datareader

Package Overview
Dependencies
18
Maintainers
1
Versions
29
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 1.0.4 to 1.1.0

dist/askUser.js

8

dist/defaults.js

@@ -11,5 +11,9 @@ "use strict";

encodings: ['win1251', 'utf-8', 'ascii', 'base64', 'hex', 'utf8', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'latin1', 'binary'],
searchTypes: ['drugCode', 'drugName']
searchTypes: {
drugCode: 'number',
drugName: 'string'
},
renderTypes: ['total', 'detailed']
};
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZhdWx0cy5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0U291cmNlUGF0aCIsImRlZmF1bHRLZXlzU291cmNlIiwiZW5jb2RpbmdzIiwic2VhcmNoVHlwZXMiXSwibWFwcGluZ3MiOiI7Ozs7OztlQUFlO0FBQ2JBLEVBQUFBLGlCQUFpQixFQUFFLHdDQUROO0FBRWJDLEVBQUFBLGlCQUFpQixFQUFFLHdDQUZOO0FBR2JDLEVBQUFBLFNBQVMsRUFBRSxDQUFDLFNBQUQsRUFBWSxPQUFaLEVBQXFCLE9BQXJCLEVBQThCLFFBQTlCLEVBQXdDLEtBQXhDLEVBQStDLE1BQS9DLEVBQ1QsTUFEUyxFQUNELE9BREMsRUFDUSxTQURSLEVBQ21CLFVBRG5CLEVBQytCLFFBRC9CLEVBQ3lDLFFBRHpDLENBSEU7QUFLYkMsRUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhLFVBQWI7QUFMQSxDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQge1xuICBkZWZhdWx0U291cmNlUGF0aDogJ34vRG9jdW1lbnRzL1Byb3hpbWEvS3lpdmZhcm0vaW5jb21pbmcvJyxcbiAgZGVmYXVsdEtleXNTb3VyY2U6ICd+L0RvY3VtZW50cy9Qcm94aW1hL0t5aXZmYXJtL2NvZGVzLnR4dCcsXG4gIGVuY29kaW5nczogWyd3aW4xMjUxJywgJ3V0Zi04JywgJ2FzY2lpJywgJ2Jhc2U2NCcsICdoZXgnLCAndXRmOCcsXG4gICAgJ3VjczInLCAndWNzLTInLCAndXRmMTZsZScsICd1dGYtMTZsZScsICdsYXRpbjEnLCAnYmluYXJ5J10sXG4gIHNlYXJjaFR5cGVzOiBbJ2RydWdDb2RlJywgJ2RydWdOYW1lJ10sXG59O1xuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZhdWx0cy5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0U291cmNlUGF0aCIsImRlZmF1bHRLZXlzU291cmNlIiwiZW5jb2RpbmdzIiwic2VhcmNoVHlwZXMiLCJkcnVnQ29kZSIsImRydWdOYW1lIiwicmVuZGVyVHlwZXMiXSwibWFwcGluZ3MiOiI7Ozs7OztlQUFlO0FBQ2JBLEVBQUFBLGlCQUFpQixFQUFFLHdDQUROO0FBRWJDLEVBQUFBLGlCQUFpQixFQUFFLHdDQUZOO0FBR2JDLEVBQUFBLFNBQVMsRUFBRSxDQUFDLFNBQUQsRUFBWSxPQUFaLEVBQXFCLE9BQXJCLEVBQThCLFFBQTlCLEVBQXdDLEtBQXhDLEVBQStDLE1BQS9DLEVBQ1QsTUFEUyxFQUNELE9BREMsRUFDUSxTQURSLEVBQ21CLFVBRG5CLEVBQytCLFFBRC9CLEVBQ3lDLFFBRHpDLENBSEU7QUFLYkMsRUFBQUEsV0FBVyxFQUFFO0FBQ1hDLElBQUFBLFFBQVEsRUFBRSxRQURDO0FBRVhDLElBQUFBLFFBQVEsRUFBRTtBQUZDLEdBTEE7QUFTYkMsRUFBQUEsV0FBVyxFQUFFLENBQUMsT0FBRCxFQUFVLFVBQVY7QUFUQSxDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQge1xuICBkZWZhdWx0U291cmNlUGF0aDogJ34vRG9jdW1lbnRzL1Byb3hpbWEvS3lpdmZhcm0vaW5jb21pbmcvJyxcbiAgZGVmYXVsdEtleXNTb3VyY2U6ICd+L0RvY3VtZW50cy9Qcm94aW1hL0t5aXZmYXJtL2NvZGVzLnR4dCcsXG4gIGVuY29kaW5nczogWyd3aW4xMjUxJywgJ3V0Zi04JywgJ2FzY2lpJywgJ2Jhc2U2NCcsICdoZXgnLCAndXRmOCcsXG4gICAgJ3VjczInLCAndWNzLTInLCAndXRmMTZsZScsICd1dGYtMTZsZScsICdsYXRpbjEnLCAnYmluYXJ5J10sXG4gIHNlYXJjaFR5cGVzOiB7XG4gICAgZHJ1Z0NvZGU6ICdudW1iZXInLFxuICAgIGRydWdOYW1lOiAnc3RyaW5nJyxcbiAgfSxcbiAgcmVuZGVyVHlwZXM6IFsndG90YWwnLCAnZGV0YWlsZWQnXSxcbn07XG4iXX0=

@@ -16,3 +16,3 @@ "use strict";

var _readlineSync = _interopRequireDefault(require("readline-sync"));
var _askUser = require("./askUser");

@@ -48,6 +48,21 @@ var _processors = require("./processors");

encodings = _defaults["default"].encodings,
searchTypes = _defaults["default"].searchTypes;
searchTypes = _defaults["default"].searchTypes,
renderTypes = _defaults["default"].renderTypes;
var _default = /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
var emptyAndZerosOnly,
searchParams,
_searchParams,
searchTypeName,
keysDataType,
_getKeysData,
_getKeysData2,
keys,
keysFolder,
newPath,
resFolder,
resFolderFilesList,
jsonFilesList,
dataToRenderPath,
selectedDataPath,
filesSource,

@@ -61,12 +76,3 @@ paths,

encoding,
keysPath,
searchTypePos,
keysFolder,
newPath,
resFolder,
keysContent,
keys,
processedDataName,
processedDataPath,
searchType,
dataStream,

@@ -80,32 +86,14 @@ _args = arguments;

emptyAndZerosOnly = _args.length > 0 && _args[0] !== undefined ? _args[0] : false;
filesSource = _readlineSync["default"].questionPath('Please type files source:', {
exists: true,
isDirectory: true,
defaultInput: defaultSourcePath
});
console.log("".concat(filesSource, "\n"));
paths = (0, _processors.makePaths)(filesSource);
_$partition = _lodash["default"].partition(paths, function (pathToFile) {
return _lodash["default"].isArray(pathToFile);
}), _$partition2 = _slicedToArray(_$partition, 2), emptySources = _$partition2[0], notEmptySources = _$partition2[1]; // const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');
searchParams = (0, _askUser.getSearchParams)(searchTypes);
_encodings = _slicedToArray(encodings, 1), encoding = _encodings[0];
keysPath = _readlineSync["default"].questionPath('\nPlease type search keys source:', {
exists: true,
isFile: true,
defaultInput: defaultKeysSource
});
console.log("".concat(keysPath, "\n"));
searchTypePos = _readlineSync["default"].keyInSelect(searchTypes, 'Please select type of data search:');
if (!(searchTypePos === -1)) {
_context.next = 12;
if (searchParams) {
_context.next = 4;
break;
}
console.log('See you next time )\n');
return _context.abrupt("return");
case 12:
keysFolder = _path["default"].dirname(keysPath);
case 4:
_searchParams = _slicedToArray(searchParams, 2), searchTypeName = _searchParams[0], keysDataType = _searchParams[1];
_getKeysData = (0, _askUser.getKeysData)(searchTypeName, keysDataType, defaultKeysSource), _getKeysData2 = _slicedToArray(_getKeysData, 2), keys = _getKeysData2[0], keysFolder = _getKeysData2[1];
newPath = _path["default"].join(keysFolder, 'processedData');

@@ -115,14 +103,41 @@ resFolder = _fs["default"].existsSync(newPath) ? newPath : _fs["default"].mkdirSync(newPath, {

});
resFolderFilesList = _fs["default"].readdirSync(resFolder);
jsonFilesList = resFolderFilesList.filter(function (fileName) {
return fileName && _path["default"].extname(fileName) === '.json';
});
if (!(jsonFilesList.length > 0)) {
_context.next = 16;
break;
}
dataToRenderPath = (0, _askUser.selectProcessOrRender)(jsonFilesList);
if (!dataToRenderPath) {
_context.next = 16;
break;
}
selectedDataPath = _path["default"].join(resFolder, dataToRenderPath);
(0, _renderers["default"])(selectedDataPath, renderTypes, resFolder);
return _context.abrupt("return");
case 16:
filesSource = (0, _askUser.getFilesSource)(defaultSourcePath);
paths = (0, _processors.makePaths)(filesSource);
_$partition = _lodash["default"].partition(paths, function (pathToFile) {
return _lodash["default"].isArray(pathToFile);
}), _$partition2 = _slicedToArray(_$partition, 2), emptySources = _$partition2[0], notEmptySources = _$partition2[1];
if (!(emptySources.length > 0)) {
_context.next = 18;
_context.next = 22;
break;
}
_context.next = 18;
_context.next = 22;
return (0, _writers.writeDownPaths)(emptySources, resFolder, 'empty');
case 18:
case 22:
if (!emptyAndZerosOnly) {
_context.next = 20;
_context.next = 24;
break;

@@ -133,21 +148,15 @@ }

case 20:
keysContent = _fs["default"].readFileSync(keysPath, 'utf-8');
keys = keysContent.trim().split('\r\n').map(function (key) {
return key.trim();
});
processedDataName = _readlineSync["default"].question('Enter a name for processed data file (default name is "processed"):', {
defaultInput: 'processedData'
});
processedDataPath = _path["default"].join(resFolder, "".concat(processedDataName, ".json"));
case 24:
// const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');
_encodings = _slicedToArray(encodings, 1), encoding = _encodings[0];
processedDataPath = (0, _askUser.getProcessedDataPath)(resFolder);
console.log('\nData-processing is ongoing...\n');
searchType = searchTypes[searchTypePos];
dataStream = (0, _processors.makeDataStream)(notEmptySources, searchType, keys, encoding);
dataStream = (0, _processors.makeDataStream)(notEmptySources, searchTypeName, keys, encoding);
(0, _processors.makeDataSelection)(dataStream).then(function (totalInfo) {
return (0, _processors.writeToJson)(totalInfo, processedDataPath);
}).then(function () {
(0, _renderers["default"])(processedDataPath, resFolder);
(0, _renderers["default"])(processedDataPath, renderTypes, resFolder);
});
case 28:
case 29:
case "end":

@@ -161,2 +170,2 @@ return _context.stop();

exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0U291cmNlUGF0aCIsImRlZmF1bHRWYWx1ZXMiLCJkZWZhdWx0S2V5c1NvdXJjZSIsImVuY29kaW5ncyIsInNlYXJjaFR5cGVzIiwiZW1wdHlBbmRaZXJvc09ubHkiLCJmaWxlc1NvdXJjZSIsInJlYWRsaW5lU3luYyIsInF1ZXN0aW9uUGF0aCIsImV4aXN0cyIsImlzRGlyZWN0b3J5IiwiZGVmYXVsdElucHV0IiwiY29uc29sZSIsImxvZyIsInBhdGhzIiwiXyIsInBhcnRpdGlvbiIsInBhdGhUb0ZpbGUiLCJpc0FycmF5IiwiZW1wdHlTb3VyY2VzIiwibm90RW1wdHlTb3VyY2VzIiwiZW5jb2RpbmciLCJrZXlzUGF0aCIsImlzRmlsZSIsInNlYXJjaFR5cGVQb3MiLCJrZXlJblNlbGVjdCIsImtleXNGb2xkZXIiLCJwYXRoIiwiZGlybmFtZSIsIm5ld1BhdGgiLCJqb2luIiwicmVzRm9sZGVyIiwiZnMiLCJleGlzdHNTeW5jIiwibWtkaXJTeW5jIiwicmVjdXJzaXZlIiwibGVuZ3RoIiwia2V5c0NvbnRlbnQiLCJyZWFkRmlsZVN5bmMiLCJrZXlzIiwidHJpbSIsInNwbGl0IiwibWFwIiwia2V5IiwicHJvY2Vzc2VkRGF0YU5hbWUiLCJxdWVzdGlvbiIsInByb2Nlc3NlZERhdGFQYXRoIiwic2VhcmNoVHlwZSIsImRhdGFTdHJlYW0iLCJ0aGVuIiwidG90YWxJbmZvIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBTUE7O0FBRUE7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBR0VBLGlCLEdBSUVDLG9CLENBSkZELGlCO0lBQ0FFLGlCLEdBR0VELG9CLENBSEZDLGlCO0lBQ0FDLFMsR0FFRUYsb0IsQ0FGRkUsUztJQUNBQyxXLEdBQ0VILG9CLENBREZHLFc7O29GQUdhO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7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LENBM0NqQjtBQTRDUHdCLFVBQUFBLFVBNUNPLEdBNENNLGdDQUFlNUIsZUFBZixFQUFnQzJCLFVBQWhDLEVBQTRDUixJQUE1QyxFQUFrRGxCLFFBQWxELENBNUNOO0FBOENiLDZDQUFrQjJCLFVBQWxCLEVBQ0dDLElBREgsQ0FDUSxVQUFBQyxTQUFTO0FBQUEsbUJBQUksNkJBQVlBLFNBQVosRUFBdUJKLGlCQUF2QixDQUFKO0FBQUEsV0FEakIsRUFFR0csSUFGSCxDQUVRLFlBQU07QUFDVix1Q0FBV0gsaUJBQVgsRUFBOEJmLFNBQTlCO0FBQ0QsV0FKSDs7QUE5Q2E7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBmcyBmcm9tICdmcyc7XG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCAncmVnZW5lcmF0b3ItcnVudGltZSc7XG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHJlYWRsaW5lU3luYyBmcm9tICdyZWFkbGluZS1zeW5jJztcbmltcG9ydCB7XG4gIG1ha2VQYXRocyxcbiAgbWFrZURhdGFTdHJlYW0sXG4gIG1ha2VEYXRhU2VsZWN0aW9uLFxuICB3cml0ZVRvSnNvbixcbn0gZnJvbSAnLi9wcm9jZXNzb3JzJztcbmltcG9ydCBtYWtlUmVuZGVyIGZyb20gJy4vcmVuZGVyZXJzJztcblxuaW1wb3J0IHsgd3JpdGVEb3duUGF0aHMgfSBmcm9tICcuL3dyaXRlcnMnO1xuaW1wb3J0IGRlZmF1bHRWYWx1ZXMgZnJvbSAnLi9kZWZhdWx0cyc7XG5cbmNvbnN0IHtcbiAgZGVmYXVsdFNvdXJjZVBhdGgsXG4gIGRlZmF1bHRLZXlzU291cmNlLFxuICBlbmNvZGluZ3MsXG4gIHNlYXJjaFR5cGVzLFxufSA9IGRlZmF1bHRWYWx1ZXM7XG5cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIChlbXB0eUFuZFplcm9zT25seSA9IGZhbHNlKSA9PiB7XG4gIGNvbnN0IGZpbGVzU291cmNlID0gcmVhZGxpbmVTeW5jLnF1ZXN0aW9uUGF0aCgnUGxlYXNlIHR5cGUgZmlsZXMgc291cmNlOicsIHtcbiAgICBleGlzdHM6IHRydWUsXG4gICAgaXNEaXJlY3Rvcnk6IHRydWUsXG4gICAgZGVmYXVsdElucHV0OiBkZWZhdWx0U291cmNlUGF0aCxcbiAgfSk7XG4gIGNvbnNvbGUubG9nKGAke2ZpbGVzU291cmNlfVxcbmApO1xuXG4gIGNvbnN0IHBhdGhzID0gbWFrZVBhdGhzKGZpbGVzU291cmNlKTtcbiAgY29uc3QgW2VtcHR5U291cmNlcywgbm90RW1wdHlTb3VyY2VzXSA9IF8ucGFydGl0aW9uKHBhdGhzLCBwYXRoVG9GaWxlID0+IF8uaXNBcnJheShwYXRoVG9GaWxlKSk7XG4gIC8vIGNvbnN0IGVuY29kaW5nUG9zID0gcmVhZGxpbmVTeW5jLmtleUluU2VsZWN0KGVuY29kaW5ncywgJ1BsZWFzZSBzZWxlY3QgZmlsZXMgZW5jb2RpbmcnKTtcbiAgY29uc3QgW2VuY29kaW5nXSA9IGVuY29kaW5ncztcblxuICBjb25zdCBrZXlzUGF0aCA9IHJlYWRsaW5lU3luYy5xdWVzdGlvblBhdGgoJ1xcblBsZWFzZSB0eXBlIHNlYXJjaCBrZXlzIHNvdXJjZTonLCB7XG4gICAgZXhpc3RzOiB0cnVlLFxuICAgIGlzRmlsZTogdHJ1ZSxcbiAgICBkZWZhdWx0SW5wdXQ6IGRlZmF1bHRLZXlzU291cmNlLFxuICB9KTtcbiAgY29uc29sZS5sb2coYCR7a2V5c1BhdGh9XFxuYCk7XG4gIGNvbnN0IHNlYXJjaFR5cGVQb3MgPSByZWFkbGluZVN5bmMua2V5SW5TZWxlY3Qoc2VhcmNoVHlwZXMsICdQbGVhc2Ugc2VsZWN0IHR5cGUgb2YgZGF0YSBzZWFyY2g6Jyk7XG5cbiAgaWYgKHNlYXJjaFR5cGVQb3MgPT09IC0xKSB7XG4gICAgY29uc29sZS5sb2coJ1NlZSB5b3UgbmV4dCB0aW1lIClcXG4nKTtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3Qga2V5c0ZvbGRlciA9IHBhdGguZGlybmFtZShrZXlzUGF0aCk7XG4gIGNvbnN0IG5ld1BhdGggPSBwYXRoLmpvaW4oa2V5c0ZvbGRlciwgJ3Byb2Nlc3NlZERhdGEnKTtcbiAgY29uc3QgcmVzRm9sZGVyID0gZnMuZXhpc3RzU3luYyhuZXdQYXRoKSA/IG5ld1BhdGggOiBmcy5ta2RpclN5bmMobmV3UGF0aCwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG5cbiAgaWYgKGVtcHR5U291cmNlcy5sZW5ndGggPiAwKSB7XG4gICAgYXdhaXQgd3JpdGVEb3duUGF0aHMoZW1wdHlTb3VyY2VzLCByZXNGb2xkZXIsICdlbXB0eScpO1xuICB9XG4gIGlmIChlbXB0eUFuZFplcm9zT25seSkge1xuICAgIHJldHVybjtcbiAgfVxuICBjb25zdCBrZXlzQ29udGVudCA9IGZzLnJlYWRGaWxlU3luYyhrZXlzUGF0aCwgJ3V0Zi04Jyk7XG4gIGNvbnN0IGtleXMgPSBrZXlzQ29udGVudC50cmltKCkuc3BsaXQoJ1xcclxcbicpLm1hcChrZXkgPT4ga2V5LnRyaW0oKSk7XG5cbiAgY29uc3QgcHJvY2Vzc2VkRGF0YU5hbWUgPSByZWFkbGluZVN5bmNcbiAgICAucXVlc3Rpb24oJ0VudGVyIGEgbmFtZSBmb3IgcHJvY2Vzc2VkIGRhdGEgZmlsZSAoZGVmYXVsdCBuYW1lIGlzIFwicHJvY2Vzc2VkXCIpOicsIHsgZGVmYXVsdElucHV0OiAncHJvY2Vzc2VkRGF0YScgfSk7XG4gIGNvbnN0IHByb2Nlc3NlZERhdGFQYXRoID0gcGF0aC5qb2luKHJlc0ZvbGRlciwgYCR7cHJvY2Vzc2VkRGF0YU5hbWV9Lmpzb25gKTtcbiAgY29uc29sZS5sb2coJ1xcbkRhdGEtcHJvY2Vzc2luZyBpcyBvbmdvaW5nLi4uXFxuJyk7XG5cbiAgY29uc3Qgc2VhcmNoVHlwZSA9IHNlYXJjaFR5cGVzW3NlYXJjaFR5cGVQb3NdO1xuICBjb25zdCBkYXRhU3RyZWFtID0gbWFrZURhdGFTdHJlYW0obm90RW1wdHlTb3VyY2VzLCBzZWFyY2hUeXBlLCBrZXlzLCBlbmNvZGluZyk7XG5cbiAgbWFrZURhdGFTZWxlY3Rpb24oZGF0YVN0cmVhbSlcbiAgICAudGhlbih0b3RhbEluZm8gPT4gd3JpdGVUb0pzb24odG90YWxJbmZvLCBwcm9jZXNzZWREYXRhUGF0aCkpXG4gICAgLnRoZW4oKCkgPT4ge1xuICAgICAgbWFrZVJlbmRlcihwcm9jZXNzZWREYXRhUGF0aCwgcmVzRm9sZGVyKTtcbiAgICB9KTtcbn07XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0U291cmNlUGF0aCIsImRlZmF1bHRWYWx1ZXMiLCJkZWZhdWx0S2V5c1NvdXJjZSIsImVuY29kaW5ncyIsInNlYXJjaFR5cGVzIiwicmVuZGVyVHlwZXMiLCJlbXB0eUFuZFplcm9zT25seSIsInNlYXJjaFBhcmFtcyIsInNlYXJjaFR5cGVOYW1lIiwia2V5c0RhdGFUeXBlIiwia2V5cyIsImtleXNGb2xkZXIiLCJuZXdQYXRoIiwicGF0aCIsImpvaW4iLCJyZXNGb2xkZXIiLCJmcyIsImV4aXN0c1N5bmMiLCJta2RpclN5bmMiLCJyZWN1cnNpdmUiLCJyZXNGb2xkZXJGaWxlc0xpc3QiLCJyZWFkZGlyU3luYyIsImpzb25GaWxlc0xpc3QiLCJmaWx0ZXIiLCJmaWxlTmFtZSIsImV4dG5hbWUiLCJsZW5ndGgiLCJkYXRhVG9SZW5kZXJQYXRoIiwic2VsZWN0ZWREYXRhUGF0aCIsImZpbGVzU291cmNlIiwicGF0aHMiLCJfIiwicGFydGl0aW9uIiwicGF0aFRvRmlsZSIsImlzQXJyYXkiLCJlbXB0eVNvdXJjZXMiLCJub3RFbXB0eVNvdXJjZXMiLCJlbmNvZGluZyIsInByb2Nlc3NlZERhdGFQYXRoIiwiY29uc29sZSIsImxvZyIsImRhdGFTdHJlYW0iLCJ0aGVuIiwidG90YWxJbmZvIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBT0E7O0FBTUE7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBR0VBLGlCLEdBS0VDLG9CLENBTEZELGlCO0lBQ0FFLGlCLEdBSUVELG9CLENBSkZDLGlCO0lBQ0FDLFMsR0FHRUYsb0IsQ0FIRkUsUztJQUNBQyxXLEdBRUVILG9CLENBRkZHLFc7SUFDQUMsVyxHQUNFSixvQixDQURGSSxXOztvRkFHYTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFB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dXJjZXNDb250ZW50IjpbImltcG9ydCBmcyBmcm9tICdmcyc7XG5pbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCAncmVnZW5lcmF0b3ItcnVudGltZSc7XG5pbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHtcbiAgZ2V0U2VhcmNoUGFyYW1zLFxuICBnZXRLZXlzRGF0YSxcbiAgZ2V0RmlsZXNTb3VyY2UsXG4gIGdldFByb2Nlc3NlZERhdGFQYXRoLFxuICBzZWxlY3RQcm9jZXNzT3JSZW5kZXIsXG59IGZyb20gJy4vYXNrVXNlcic7XG5pbXBvcnQge1xuICBtYWtlUGF0aHMsXG4gIG1ha2VEYXRhU3RyZWFtLFxuICBtYWtlRGF0YVNlbGVjdGlvbixcbiAgd3JpdGVUb0pzb24sXG59IGZyb20gJy4vcHJvY2Vzc29ycyc7XG5pbXBvcnQgbWFrZVJlbmRlciBmcm9tICcuL3JlbmRlcmVycyc7XG5pbXBvcnQgeyB3cml0ZURvd25QYXRocyB9IGZyb20gJy4vd3JpdGVycyc7XG5pbXBvcnQgZGVmYXVsdFZhbHVlcyBmcm9tICcuL2RlZmF1bHRzJztcblxuY29uc3Qge1xuICBkZWZhdWx0U291cmNlUGF0aCxcbiAgZGVmYXVsdEtleXNTb3VyY2UsXG4gIGVuY29kaW5ncyxcbiAgc2VhcmNoVHlwZXMsXG4gIHJlbmRlclR5cGVzLFxufSA9IGRlZmF1bHRWYWx1ZXM7XG5cbmV4cG9ydCBkZWZhdWx0IGFzeW5jIChlbXB0eUFuZFplcm9zT25seSA9IGZhbHNlKSA9PiB7XG4gIGNvbnN0IHNlYXJjaFBhcmFtcyA9IGdldFNlYXJjaFBhcmFtcyhzZWFyY2hUeXBlcyk7XG4gIGlmICghc2VhcmNoUGFyYW1zKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnN0IFtzZWFyY2hUeXBlTmFtZSwga2V5c0RhdGFUeXBlXSA9IHNlYXJjaFBhcmFtcztcbiAgY29uc3QgW2tleXMsIGtleXNGb2xkZXJdID0gZ2V0S2V5c0RhdGEoc2VhcmNoVHlwZU5hbWUsIGtleXNEYXRhVHlwZSwgZGVmYXVsdEtleXNTb3VyY2UpO1xuICBjb25zdCBuZXdQYXRoID0gcGF0aC5qb2luKGtleXNGb2xkZXIsICdwcm9jZXNzZWREYXRhJyk7XG4gIGNvbnN0IHJlc0ZvbGRlciA9IGZzLmV4aXN0c1N5bmMobmV3UGF0aCkgPyBuZXdQYXRoIDogZnMubWtkaXJTeW5jKG5ld1BhdGgsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuXG4gIGNvbnN0IHJlc0ZvbGRlckZpbGVzTGlzdCA9IGZzLnJlYWRkaXJTeW5jKHJlc0ZvbGRlcik7XG4gIGNvbnN0IGpzb25GaWxlc0xpc3QgPSByZXNGb2xkZXJGaWxlc0xpc3RcbiAgICAuZmlsdGVyKGZpbGVOYW1lID0+IGZpbGVOYW1lICYmIHBhdGguZXh0bmFtZShmaWxlTmFtZSkgPT09ICcuanNvbicpO1xuICBpZiAoanNvbkZpbGVzTGlzdC5sZW5ndGggPiAwKSB7XG4gICAgY29uc3QgZGF0YVRvUmVuZGVyUGF0aCA9IHNlbGVjdFByb2Nlc3NPclJlbmRlcihqc29uRmlsZXNMaXN0KTtcbiAgICBpZiAoZGF0YVRvUmVuZGVyUGF0aCkge1xuICAgICAgY29uc3Qgc2VsZWN0ZWREYXRhUGF0aCA9IHBhdGguam9pbihyZXNGb2xkZXIsIGRhdGFUb1JlbmRlclBhdGgpO1xuICAgICAgbWFrZVJlbmRlcihzZWxlY3RlZERhdGFQYXRoLCByZW5kZXJUeXBlcywgcmVzRm9sZGVyKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gIH1cblxuICBjb25zdCBmaWxlc1NvdXJjZSA9IGdldEZpbGVzU291cmNlKGRlZmF1bHRTb3VyY2VQYXRoKTtcbiAgY29uc3QgcGF0aHMgPSBtYWtlUGF0aHMoZmlsZXNTb3VyY2UpO1xuICBjb25zdCBbZW1wdHlTb3VyY2VzLCBub3RFbXB0eVNvdXJjZXNdID0gXy5wYXJ0aXRpb24ocGF0aHMsIHBhdGhUb0ZpbGUgPT4gXy5pc0FycmF5KHBhdGhUb0ZpbGUpKTtcbiAgaWYgKGVtcHR5U291cmNlcy5sZW5ndGggPiAwKSB7XG4gICAgYXdhaXQgd3JpdGVEb3duUGF0aHMoZW1wdHlTb3VyY2VzLCByZXNGb2xkZXIsICdlbXB0eScpO1xuICB9XG4gIGlmIChlbXB0eUFuZFplcm9zT25seSkge1xuICAgIHJldHVybjtcbiAgfVxuICAvLyBjb25zdCBlbmNvZGluZ1BvcyA9IHJlYWRsaW5lU3luYy5rZXlJblNlbGVjdChlbmNvZGluZ3MsICdQbGVhc2Ugc2VsZWN0IGZpbGVzIGVuY29kaW5nJyk7XG4gIGNvbnN0IFtlbmNvZGluZ10gPSBlbmNvZGluZ3M7XG4gIGNvbnN0IHByb2Nlc3NlZERhdGFQYXRoID0gZ2V0UHJvY2Vzc2VkRGF0YVBhdGgocmVzRm9sZGVyKTtcblxuICBjb25zb2xlLmxvZygnXFxuRGF0YS1wcm9jZXNzaW5nIGlzIG9uZ29pbmcuLi5cXG4nKTtcblxuICBjb25zdCBkYXRhU3RyZWFtID0gbWFrZURhdGFTdHJlYW0obm90RW1wdHlTb3VyY2VzLCBzZWFyY2hUeXBlTmFtZSwga2V5cywgZW5jb2RpbmcpO1xuICBtYWtlRGF0YVNlbGVjdGlvbihkYXRhU3RyZWFtKVxuICAgIC50aGVuKHRvdGFsSW5mbyA9PiB3cml0ZVRvSnNvbih0b3RhbEluZm8sIHByb2Nlc3NlZERhdGFQYXRoKSlcbiAgICAudGhlbigoKSA9PiB7XG4gICAgICBtYWtlUmVuZGVyKHByb2Nlc3NlZERhdGFQYXRoLCByZW5kZXJUeXBlcywgcmVzRm9sZGVyKTtcbiAgICB9KTtcbn07XG4iXX0=

@@ -308,2 +308,2 @@ "use strict";

exports.selectZeroMovements = selectZeroMovements;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/processors.js"],"names":["fileTypes","makePaths","source","pathsList","info","fs","statSync","size","isDirectory","isCorrectFormat","includes","dirContent","readdirSync","resContentColl","reduce","acc","name","innerPath","getMatched","strToSearch","searchType","content","split","filter","line","drugCode","countIn","countOut","isSameCode","nameIncludesStr","toLowerCase","isMatched","notZero","Number","lines","length","processData","filePath","totalInfo","chainDrugCode","remains","priceIn","priceOut","dateStart","dateEnd","existedItemInfo","relatedPathInfo","remainsNum","pcsIn","pcsOut","itemInfo","countInTotal","moneyInTotal","countOutTotal","moneyOutTotal","moneyIn","moneyOut","count","makeJsonChunk","data","totalSize","finalStr","_","keys","key","value","jsonStr","JSON","stringify","makeDataStream","pathDataColl","encoding","readablePaths","CustomReader","objectMode","highWaterMark","getContent","Transform","readableObjectMode","writableObjectMode","transform","chunk","enc","cb","str","readFileSync","decoded","iconv","decode","push","selectData","ch","selectedData","map","String","dataColl","pipe","makeDataSelection","dataStream","Promise","resolve","reject","on","dataPair","processedData","newAcc","writeToJson","processedDataPath","objToArr","readableTotalInfo","transformToJson","writableJson","createWriteStream","streamsInPromise","console","log","selectZeroMovements","separatedItems","partition","hasZeros","every","isZero","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,IAAMA,SAAS,GAAG,CAAC,MAAD,EAAS,MAAT,EAAiB,MAAjB,EAAyB,MAAzB,EAAiC,MAAjC,EAAyC,MAAzC,CAAlB;;AAEO,IAAMC,SAAS,GAAG,SAAZA,SAAY,CAACC,MAAD,EAA4B;AAAA,MAAnBC,SAAmB,uEAAP,EAAO;;AACnD,MAAMC,IAAI,GAAGC,eAAGC,QAAH,CAAYJ,MAAZ,CAAb;;AACA,MAAIE,IAAI,CAACG,IAAL,KAAc,CAAlB,EAAqB;AACnB,WAAO,CAAC,CAACL,MAAD,CAAD,CAAP;AACD;;AACD,MAAI,CAACE,IAAI,CAACI,WAAL,EAAL,EAAyB;AACvB,QAAMC,eAAe,GAAGT,SAAS,CAACU,QAAV,CAAmB,mBAAQR,MAAR,CAAnB,CAAxB;AACA,WAAOO,eAAe,GAAG,CAACP,MAAD,CAAH,GAAc,EAApC;AACD;;AACD,MAAMS,UAAU,GAAGN,eAAGO,WAAH,CAAeV,MAAf,CAAnB;;AACA,MAAMW,cAAc,GAAGF,UAAU,CAC9BG,MADoB,CACb,UAACC,GAAD,EAAMC,IAAN,EAAe;AACrB,QAAMC,SAAS,GAAG,gBAAKf,MAAL,EAAac,IAAb,CAAlB;AACA,wCAAWD,GAAX,sBAAmBd,SAAS,CAACgB,SAAD,CAA5B;AACD,GAJoB,EAIlBd,SAJkB,CAAvB;AAKA,SAAOU,cAAP;AACD,CAhBM;;;;AAmBP,IAAMK,UAAU,GAAG,SAAbA,UAAa,CAACC,WAAD,EAAcC,UAAd,EAA0BC,OAA1B;AAAA,SAAsCA,OAAO,CAACC,KAAR,CAAc,IAAd,EAAoBC,MAApB,CAA2B,UAACC,IAAD,EAAU;AAAA,sBAMxFA,IAAI,CAACF,KAAL,CAAW,IAAX,CANwF;AAAA;AAAA,QAE1FG,QAF0F;AAAA,QAG1FT,IAH0F;AAAA,QAI1FU,OAJ0F;AAAA,QAK1FC,QAL0F;;AAO5F,QAAI,CAACX,IAAL,EAAW;AACT,aAAO,KAAP;AACD;;AACD,QAAMY,UAAU,GAAGH,QAAQ,KAAKN,WAAhC;AACA,QAAMU,eAAe,GAAGb,IAAI,CAACc,WAAL,GAAmBpB,QAAnB,CAA4BS,WAAW,CAACW,WAAZ,EAA5B,CAAxB;AACA,QAAMC,SAAS,GAAGX,UAAU,KAAK,UAAf,GAA4BQ,UAA5B,GAAyCC,eAA3D;AACA,QAAMG,OAAO,GAAGC,MAAM,CAACP,OAAD,CAAN,KAAoB,CAApB,IAAyBO,MAAM,CAACN,QAAD,CAAN,KAAqB,CAA9D;AACA,WAAOI,SAAS,IAAIC,OAApB;AACD,GAfwD,EAetDT,MAfsD,CAe/C;AAAA;AAAA,QAAIW,KAAJ;;AAAA,WAAeA,KAAK,CAACC,MAAN,GAAe,CAA9B;AAAA,GAf+C,CAAtC;AAAA,CAAnB;;AAiBA,IAAMC,WAAW,GAAG,SAAdA,WAAc,CAACf,OAAD,EAAUgB,QAAV,EAAoBC,SAApB;AAAA,SAAkCjB,OAAO,CAC1DP,MADmD,CAC5C,UAACC,GAAD,EAAMS,IAAN,EAAe;AAAA,uBAWjBA,IAAI,CAACF,KAAL,CAAW,IAAX,CAXiB;AAAA;AAAA,QAEnBiB,aAFmB;AAAA,QAGnBvB,IAHmB;AAAA,QAInBwB,OAJmB;AAAA,QAKnBd,OALmB;AAAA,QAMnBe,OANmB;AAAA,QAOnBd,QAPmB;AAAA,QAQnBe,QARmB;AAAA,QASnBC,SATmB;AAAA,QAUnBC,OAVmB;;AAarB,QAAMC,eAAe,GAAG9B,GAAG,CAACwB,aAAD,CAAH,IAAsB,EAA9C;AACA,QAAMO,eAAe,GAAGD,eAAe,CAACR,QAAD,CAAf,IAA6B,EAArD;AACA,QAAMU,UAAU,GAAGd,MAAM,CAACO,OAAD,CAAzB;AACA,QAAMQ,KAAK,GAAGf,MAAM,CAACP,OAAD,CAApB;AACA,QAAMuB,MAAM,GAAGhB,MAAM,CAACN,QAAD,CAArB;;AAEA,QAAMuB,QAAQ,uBACXX,aADW,kCAEPM,eAFO;AAGV7B,MAAAA,IAAI,EAAJA,IAHU;AAIVmC,MAAAA,YAAY,EAAE,CAACN,eAAe,CAACM,YAAhB,IAAgC,CAAjC,IAAsCH,KAJ1C;AAKVI,MAAAA,YAAY,EAAE,CAACP,eAAe,CAACO,YAAhB,IAAgC,CAAjC,IAAsCX,OAAO,GAAGO,KALpD;AAMVK,MAAAA,aAAa,EAAE,CAACR,eAAe,CAACQ,aAAhB,IAAiC,CAAlC,IAAuCJ,MAN5C;AAOVK,MAAAA,aAAa,EAAE,CAACT,eAAe,CAACS,aAAhB,IAAiC,CAAlC,IAAuCZ,QAAQ,GAAGO;AAPvD,OAQTZ,QARS,EAQE;AACVG,MAAAA,OAAO,EAAE,CAACM,eAAe,CAACN,OAAhB,IAA2B,CAA5B,IAAiCO,UADhC;AAEVrB,MAAAA,OAAO,EAAE,CAACoB,eAAe,CAACpB,OAAhB,IAA2B,CAA5B,IAAiCsB,KAFhC;AAGVO,MAAAA,OAAO,EAAE,CAACT,eAAe,CAACS,OAAhB,IAA2B,CAA5B,IAAiCd,OAAO,GAAGO,KAH1C;AAIVrB,MAAAA,QAAQ,EAAE,CAACmB,eAAe,CAACnB,QAAhB,IAA4B,CAA7B,IAAkCsB,MAJlC;AAKVO,MAAAA,QAAQ,EAAE,CAACV,eAAe,CAACU,QAAhB,IAA4B,CAA7B,IAAkCd,QAAQ,GAAGO,MAL7C;AAMVN,MAAAA,SAAS,EAATA,SANU;AAOVC,MAAAA,OAAO,EAAPA;AAPU,KARF,GAAd;;AAoBA,2CAAY7B,GAAZ,GAAoBmC,QAApB;AACD,GAzCmD,EAyCjDZ,SAzCiD,CAAlC;AAAA,CAApB;;AA2CA,IAAImB,KAAK,GAAG,CAAZ;;AACA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACC,IAAD,EAAOC,SAAP,EAAqB;AACzCH,EAAAA,KAAK,IAAI,CAAT;AACA,MAAII,QAAQ,GAAG,EAAf;;AAFyC,eAG3BC,mBAAEC,IAAF,CAAOJ,IAAP,CAH2B;AAAA;AAAA,MAGlCK,GAHkC;;AAIzC,MAAMC,KAAK,GAAGN,IAAI,CAACK,GAAD,CAAlB;AACA,MAAME,OAAO,eAAOF,GAAP,gBAAeG,IAAI,CAACC,SAAL,CAAeH,KAAf,CAAf,CAAb;;AACA,UAAQR,KAAR;AACE,SAAK,CAAL;AACEI,MAAAA,QAAQ,cAAOK,OAAP,MAAR;AACA;;AACF,SAAKN,SAAL;AACEC,MAAAA,QAAQ,aAAMK,OAAN,MAAR;AACA;;AACF;AACEL,MAAAA,QAAQ,aAAMK,OAAN,MAAR;AARJ;;AAUA,SAAOL,QAAP;AACD,CAjBD;;AAmBO,IAAMQ,cAAc,GAAG,SAAjBA,cAAiB,CAACC,YAAD,EAAelD,UAAf,EAA2B2C,IAA3B,EAAiCQ,QAAjC,EAA8C;AAC1E,MAAMC,aAAa,GAAG,IAAIC,wBAAJ,CAAiBH,YAAjB,EAA+B;AACnDI,IAAAA,UAAU,EAAE,IADuC;AAEnDC,IAAAA,aAAa,EAAE;AAFoC,GAA/B,CAAtB;AAKA,MAAMC,UAAU,GAAG,IAAIC,iBAAJ,CAAc;AAC/BC,IAAAA,kBAAkB,EAAE,IADW;AAE/BC,IAAAA,kBAAkB,EAAE,IAFW;AAG/BC,IAAAA,SAH+B,qBAGrBC,KAHqB,EAGdC,GAHc,EAGTC,EAHS,EAGL;AACxB,UAAMC,GAAG,GAAG/E,eAAGgF,YAAH,CAAgBJ,KAAK,CAAC,CAAD,CAArB,CAAZ;;AACA,UAAMK,OAAO,GAAGC,KAAK,CAACC,MAAN,CAAaJ,GAAb,EAAkBb,QAAlB,CAAhB;AACA,WAAKkB,IAAL,CAAU,CAACR,KAAK,CAAC,CAAD,CAAN,EAAWK,OAAX,CAAV;AACAH,MAAAA,EAAE;AACH;AAR8B,GAAd,CAAnB;AAWA,MAAMO,UAAU,GAAG,IAAIb,iBAAJ,CAAc;AAC/BC,IAAAA,kBAAkB,EAAE,IADW;AAE/BC,IAAAA,kBAAkB,EAAE,IAFW;AAG/BC,IAAAA,SAH+B,qBAGrBW,EAHqB,EAGjBT,GAHiB,EAGZC,EAHY,EAGR;AAAA,+BACIQ,EADJ;AAAA,UACdtD,QADc;AAAA,UACJsB,IADI;;AAErB,UAAMiC,YAAY,GAAG7B,IAAI,CACtB8B,GADkB,CACd,UAAA7B,GAAG;AAAA,eAAI9C,UAAU,CAAC4E,MAAM,CAAC9B,GAAD,CAAP,EAAc5C,UAAd,EAA0BuC,IAA1B,CAAd;AAAA,OADW,EAElBpC,MAFkB,CAEX,UAAAwE,QAAQ;AAAA,eAAIA,QAAQ,CAAC5D,MAAT,GAAkB,CAAtB;AAAA,OAFG,CAArB;;AAGA,UAAIyD,YAAY,CAACzD,MAAb,GAAsB,CAA1B,EAA6B;AAC3B,aAAKsD,IAAL,CAAU,CAACG,YAAD,EAAevD,QAAf,CAAV;AACD;;AACD8C,MAAAA,EAAE;AACH;AAZ8B,GAAd,CAAnB;AAcA,SAAOX,aAAa,CACjBwB,IADI,CACCpB,UADD,EAEJoB,IAFI,CAECN,UAFD,CAAP;AAGD,CAlCM;;;;AAoCA,IAAMO,iBAAiB,GAAG,SAApBA,iBAAoB,CAAAC,UAAU;AAAA,SAAI,IAAIC,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AAC9E,QAAI/D,SAAS,GAAG,EAAhB;AACA4D,IAAAA,UAAU,CACPI,EADH,CACM,MADN,EACc,UAACC,QAAD,EAAc;AAAA,qCACSA,QADT;AAAA,UACjBX,YADiB;AAAA,UACHvD,QADG;;AAExB,UAAMmE,aAAa,GAAGZ,YAAY,CAAC9E,MAAb,CAAoB,UAACC,GAAD,EAAMgF,QAAN,EAAmB;AAC3D,YAAMU,MAAM,GAAGrE,WAAW,CAAC2D,QAAD,EAAW1D,QAAX,EAAqBtB,GAArB,CAA1B;AACA,eAAO0F,MAAP;AACD,OAHqB,EAGnBnE,SAHmB,CAAtB;AAIAA,MAAAA,SAAS,GAAGkE,aAAZ;AACD,KARH,EASGF,EATH,CASM,KATN,EASa,YAAM;AACfF,MAAAA,OAAO,CAAC9D,SAAD,CAAP;AACD,KAXH,EAYGgE,EAZH,CAYM,OAZN,EAYeD,MAZf;AAaD,GAf8C,CAAJ;AAAA,CAApC;;;;AAiBA,IAAMK,WAAW,GAAG,SAAdA,WAAc,CAACpE,SAAD,EAAYqE,iBAAZ,EAAkC;AAC3D,MAAMC,QAAQ,GAAG9C,mBAAE+B,GAAF,CAAMvD,SAAN,EAAiB,UAAC2B,KAAD,EAAQD,GAAR;AAAA,+BAAoBA,GAApB,EAA0BC,KAA1B;AAAA,GAAjB,CAAjB;;AACA,MAAM4C,iBAAiB,GAAG,IAAIpC,wBAAJ,CAAiBmC,QAAjB,EAA2B;AACnDlC,IAAAA,UAAU,EAAE,IADuC;AAEnDC,IAAAA,aAAa,EAAE;AAFoC,GAA3B,CAA1B;AAKA,MAAMmC,eAAe,GAAG,IAAIjC,iBAAJ,CAAc;AACpCE,IAAAA,kBAAkB,EAAE,IADgB;AAEpCC,IAAAA,SAFoC,4BAEjBE,GAFiB,EAEZC,EAFY,EAER;AAAA;AAAA,UAAjBF,KAAiB;;AAC1B,UAAMtB,IAAI,GAAGD,aAAa,CAACuB,KAAD,EAAQ2B,QAAQ,CAACzE,MAAjB,CAA1B;AACA,WAAKsD,IAAL,CAAU9B,IAAV;AACAwB,MAAAA,EAAE;AACH;AANmC,GAAd,CAAxB;;AASA,MAAM4B,YAAY,GAAG1G,eAAG2G,iBAAH,CAAqBL,iBAArB,CAArB;;AACA,MAAMM,gBAAgB,GAAG,IAAId,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AACxDQ,IAAAA,iBAAiB,CACdb,IADH,CACQc,eADR,EAEGd,IAFH,CAEQe,YAFR,EAGGT,EAHH,CAGM,QAHN,EAGgB,YAAM;AAClBY,MAAAA,OAAO,CAACC,GAAR,6CAAiDR,iBAAjD;AACAP,MAAAA,OAAO;AACR,KANH,EAOGE,EAPH,CAOM,OAPN,EAOeD,MAPf;AAQD,GATwB,CAAzB;AAWA,SAAOY,gBAAP;AACD,CA7BM;;;;AA+BA,IAAMG,mBAAmB,GAAG,SAAtBA,mBAAsB,CAAC9C,YAAD,EAAkB;AACnD,MAAM+C,cAAc,GAAGvD,mBAAEwD,SAAF,CAAYhD,YAAZ,EAA0B,iBAAiB;AAAA;AAAA,QAAbjD,OAAa;;AAChE,QAAMkG,QAAQ,GAAGlG,OAAO,CAACC,KAAR,CAAc,IAAd,EAAoBkG,KAApB,CAA0B,UAAChG,IAAD,EAAU;AAAA,yBAI/CA,IAAI,CAACF,KAAL,CAAW,IAAX,CAJ+C;AAAA;AAAA,UAEjDI,OAFiD;AAAA,UAGjDC,QAHiD;;AAKnD,UAAM8F,MAAM,GAAGxF,MAAM,CAACP,OAAD,CAAN,KAAoB,CAApB,IAAyBO,MAAM,CAACN,QAAD,CAAN,KAAqB,CAA7D;AACA,aAAO8F,MAAP;AACD,KAPgB,CAAjB;AASA,WAAOF,QAAP;AACD,GAXsB,CAAvB;;AADmD,uCAcxBF,cAdwB;AAAA,MAc5CK,UAd4C;AAAA,MAchCC,IAdgC;;AAAA,gBAe5B7D,mBAAE8D,KAAF,CAAQF,UAAR,CAf4B;AAAA;AAAA,MAe5CG,YAf4C;;AAAA,iBAgB/B/D,mBAAE8D,KAAF,CAAQD,IAAR,CAhB+B;AAAA;AAAA,MAgB5CG,SAhB4C;;AAkBnD,SAAO,CAACD,YAAD,EAAeC,SAAf,CAAP;AACD,CAnBM","sourcesContent":["import fs from 'fs';\nimport { Transform } from 'stream';\nimport { join, extname } from 'path';\nimport _ from 'lodash';\nimport * as iconv from 'iconv-lite';\nimport CustomReader from './StreamReader';\nimport 'regenerator-runtime';\n\nconst fileTypes = ['.mdr', '.mwr', '.mmr', '.mdi', '.mwi', '.mmi'];\n\nexport const makePaths = (source, pathsList = []) => {\n  const info = fs.statSync(source);\n  if (info.size === 0) {\n    return [[source]];\n  }\n  if (!info.isDirectory()) {\n    const isCorrectFormat = fileTypes.includes(extname(source));\n    return isCorrectFormat ? [source] : [];\n  }\n  const dirContent = fs.readdirSync(source);\n  const resContentColl = dirContent\n    .reduce((acc, name) => {\n      const innerPath = join(source, name);\n      return [...acc, ...makePaths(innerPath)];\n    }, pathsList);\n  return resContentColl;\n};\n\n\nconst getMatched = (strToSearch, searchType, content) => content.split('\\n').filter((line) => {\n  const [\n    drugCode,\n    name,,\n    countIn,,\n    countOut,\n  ] = line.split('\\t');\n  if (!name) {\n    return false;\n  }\n  const isSameCode = drugCode === strToSearch;\n  const nameIncludesStr = name.toLowerCase().includes(strToSearch.toLowerCase());\n  const isMatched = searchType === 'drugCode' ? isSameCode : nameIncludesStr;\n  const notZero = Number(countIn) !== 0 || Number(countOut) !== 0;\n  return isMatched && notZero;\n}).filter(([, lines]) => lines.length > 0);\n\nconst processData = (content, filePath, totalInfo) => content\n  .reduce((acc, line) => {\n    const [\n      chainDrugCode,\n      name,\n      remains,\n      countIn,\n      priceIn,\n      countOut,\n      priceOut,\n      dateStart,\n      dateEnd,\n    ] = line.split('\\t');\n\n    const existedItemInfo = acc[chainDrugCode] || {};\n    const relatedPathInfo = existedItemInfo[filePath] || {};\n    const remainsNum = Number(remains);\n    const pcsIn = Number(countIn);\n    const pcsOut = Number(countOut);\n\n    const itemInfo = {\n      [chainDrugCode]: {\n        ...existedItemInfo,\n        name,\n        countInTotal: (existedItemInfo.countInTotal || 0) + pcsIn,\n        moneyInTotal: (existedItemInfo.moneyInTotal || 0) + priceIn * pcsIn,\n        countOutTotal: (existedItemInfo.countOutTotal || 0) + pcsOut,\n        moneyOutTotal: (existedItemInfo.moneyOutTotal || 0) + priceOut * pcsOut,\n        [filePath]: {\n          remains: (relatedPathInfo.remains || 0) + remainsNum,\n          countIn: (relatedPathInfo.countIn || 0) + pcsIn,\n          moneyIn: (relatedPathInfo.moneyIn || 0) + priceIn * pcsIn,\n          countOut: (relatedPathInfo.countOut || 0) + pcsOut,\n          moneyOut: (relatedPathInfo.moneyOut || 0) + priceOut * pcsOut,\n          dateStart,\n          dateEnd,\n        },\n      },\n    };\n\n    return { ...acc, ...itemInfo };\n  }, totalInfo);\n\nlet count = 0;\nconst makeJsonChunk = (data, totalSize) => {\n  count += 1;\n  let finalStr = '';\n  const [key] = _.keys(data);\n  const value = data[key];\n  const jsonStr = `\"${key}\":${JSON.stringify(value)}`;\n  switch (count) {\n    case 1:\n      finalStr = `{${jsonStr},`;\n      break;\n    case totalSize:\n      finalStr = `${jsonStr}}`;\n      break;\n    default:\n      finalStr = `${jsonStr},`;\n  }\n  return finalStr;\n};\n\nexport const makeDataStream = (pathDataColl, searchType, keys, encoding) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const getContent = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(chunk, enc, cb) {\n      const str = fs.readFileSync(chunk[0]);\n      const decoded = iconv.decode(str, encoding);\n      this.push([chunk[0], decoded]);\n      cb();\n    },\n  });\n\n  const selectData = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(ch, enc, cb) {\n      const [filePath, data] = ch;\n      const selectedData = keys\n        .map(key => getMatched(String(key), searchType, data))\n        .filter(dataColl => dataColl.length > 0);\n      if (selectedData.length > 0) {\n        this.push([selectedData, filePath]);\n      }\n      cb();\n    },\n  });\n  return readablePaths\n    .pipe(getContent)\n    .pipe(selectData);\n};\n\nexport const makeDataSelection = dataStream => new Promise((resolve, reject) => {\n  let totalInfo = {};\n  dataStream\n    .on('data', (dataPair) => {\n      const [selectedData, filePath] = dataPair;\n      const processedData = selectedData.reduce((acc, dataColl) => {\n        const newAcc = processData(dataColl, filePath, acc);\n        return newAcc;\n      }, totalInfo);\n      totalInfo = processedData;\n    })\n    .on('end', () => {\n      resolve(totalInfo);\n    })\n    .on('error', reject);\n});\n\nexport const writeToJson = (totalInfo, processedDataPath) => {\n  const objToArr = _.map(totalInfo, (value, key) => ({ [key]: value }));\n  const readableTotalInfo = new CustomReader(objToArr, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const transformToJson = new Transform({\n    writableObjectMode: true,\n    transform([chunk], enc, cb) {\n      const data = makeJsonChunk(chunk, objToArr.length);\n      this.push(data);\n      cb();\n    },\n  });\n\n  const writableJson = fs.createWriteStream(processedDataPath);\n  const streamsInPromise = new Promise((resolve, reject) => {\n    readableTotalInfo\n      .pipe(transformToJson)\n      .pipe(writableJson)\n      .on('finish', () => {\n        console.log(`Structured JSON-data are saved in ${processedDataPath}\\n`);\n        resolve();\n      })\n      .on('error', reject);\n  });\n\n  return streamsInPromise;\n};\n\nexport const selectZeroMovements = (pathDataColl) => {\n  const separatedItems = _.partition(pathDataColl, ([, content]) => {\n    const hasZeros = content.split('\\n').every((line) => {\n      const [,,,\n        countIn,,\n        countOut,\n      ] = line.split('\\t');\n      const isZero = Number(countIn) === 0 && Number(countOut) === 0;\n      return isZero;\n    });\n\n    return hasZeros;\n  });\n\n  const [zeroCounts, rest] = separatedItems;\n  const [matchedPaths] = _.unzip(zeroCounts);\n  const [dataPaths] = _.unzip(rest);\n\n  return [matchedPaths, dataPaths];\n};\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/processors.js"],"names":["fileTypes","makePaths","source","pathsList","info","fs","statSync","size","isDirectory","isCorrectFormat","includes","dirContent","readdirSync","resContentColl","reduce","acc","name","innerPath","getMatched","strToSearch","searchType","content","split","filter","line","drugCode","countIn","countOut","isSameCode","nameIncludesStr","toLowerCase","isMatched","notZero","Number","lines","length","processData","filePath","totalInfo","chainDrugCode","remains","priceIn","priceOut","dateStart","dateEnd","existedItemInfo","relatedPathInfo","remainsNum","pcsIn","pcsOut","itemInfo","countInTotal","moneyInTotal","countOutTotal","moneyOutTotal","moneyIn","moneyOut","count","makeJsonChunk","data","totalSize","finalStr","_","keys","key","value","jsonStr","JSON","stringify","makeDataStream","pathDataColl","encoding","readablePaths","CustomReader","objectMode","highWaterMark","getContent","Transform","readableObjectMode","writableObjectMode","transform","chunk","enc","cb","str","readFileSync","decoded","iconv","decode","push","selectData","ch","selectedData","map","String","dataColl","pipe","makeDataSelection","dataStream","Promise","resolve","reject","on","dataPair","processedData","newAcc","writeToJson","processedDataPath","objToArr","readableTotalInfo","transformToJson","writableJson","createWriteStream","streamsInPromise","console","log","selectZeroMovements","separatedItems","partition","hasZeros","every","isZero","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport { Transform } from 'stream';\nimport { join, extname } from 'path';\nimport _ from 'lodash';\nimport * as iconv from 'iconv-lite';\nimport CustomReader from './StreamReader';\nimport 'regenerator-runtime';\n\nconst fileTypes = ['.mdr', '.mwr', '.mmr', '.mdi', '.mwi', '.mmi'];\n\nexport const makePaths = (source, pathsList = []) => {\n  const info = fs.statSync(source);\n  if (info.size === 0) {\n    return [[source]];\n  }\n  if (!info.isDirectory()) {\n    const isCorrectFormat = fileTypes.includes(extname(source));\n    return isCorrectFormat ? [source] : [];\n  }\n  const dirContent = fs.readdirSync(source);\n  const resContentColl = dirContent\n    .reduce((acc, name) => {\n      const innerPath = join(source, name);\n      return [...acc, ...makePaths(innerPath)];\n    }, pathsList);\n  return resContentColl;\n};\n\nconst getMatched = (strToSearch, searchType, content) => content.split('\\n').filter((line) => {\n  const [\n    drugCode,\n    name,,\n    countIn,,\n    countOut,\n  ] = line.split('\\t');\n  if (!name) {\n    return false;\n  }\n  const isSameCode = drugCode === strToSearch;\n  const nameIncludesStr = name.toLowerCase().includes(strToSearch.toLowerCase());\n  const isMatched = searchType === 'drugCode' ? isSameCode : nameIncludesStr;\n  const notZero = Number(countIn) !== 0 || Number(countOut) !== 0;\n  return isMatched && notZero;\n}).filter(([, lines]) => lines.length > 0);\n\nconst processData = (content, filePath, totalInfo) => content\n  .reduce((acc, line) => {\n    const [\n      chainDrugCode,\n      name,\n      remains,\n      countIn,\n      priceIn,\n      countOut,\n      priceOut,\n      dateStart,\n      dateEnd,\n    ] = line.split('\\t');\n\n    const existedItemInfo = acc[chainDrugCode] || {};\n    const relatedPathInfo = existedItemInfo[filePath] || {};\n    const remainsNum = Number(remains);\n    const pcsIn = Number(countIn);\n    const pcsOut = Number(countOut);\n\n    const itemInfo = {\n      [chainDrugCode]: {\n        ...existedItemInfo,\n        name,\n        countInTotal: (existedItemInfo.countInTotal || 0) + pcsIn,\n        moneyInTotal: (existedItemInfo.moneyInTotal || 0) + priceIn * pcsIn,\n        countOutTotal: (existedItemInfo.countOutTotal || 0) + pcsOut,\n        moneyOutTotal: (existedItemInfo.moneyOutTotal || 0) + priceOut * pcsOut,\n        [filePath]: {\n          remains: (relatedPathInfo.remains || 0) + remainsNum,\n          countIn: (relatedPathInfo.countIn || 0) + pcsIn,\n          moneyIn: (relatedPathInfo.moneyIn || 0) + priceIn * pcsIn,\n          countOut: (relatedPathInfo.countOut || 0) + pcsOut,\n          moneyOut: (relatedPathInfo.moneyOut || 0) + priceOut * pcsOut,\n          dateStart,\n          dateEnd,\n        },\n      },\n    };\n\n    return { ...acc, ...itemInfo };\n  }, totalInfo);\n\nlet count = 0;\nconst makeJsonChunk = (data, totalSize) => {\n  count += 1;\n  let finalStr = '';\n  const [key] = _.keys(data);\n  const value = data[key];\n  const jsonStr = `\"${key}\":${JSON.stringify(value)}`;\n  switch (count) {\n    case 1:\n      finalStr = `{${jsonStr},`;\n      break;\n    case totalSize:\n      finalStr = `${jsonStr}}`;\n      break;\n    default:\n      finalStr = `${jsonStr},`;\n  }\n  return finalStr;\n};\n\nexport const makeDataStream = (pathDataColl, searchType, keys, encoding) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const getContent = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(chunk, enc, cb) {\n      const str = fs.readFileSync(chunk[0]);\n      const decoded = iconv.decode(str, encoding);\n      this.push([chunk[0], decoded]);\n      cb();\n    },\n  });\n\n  const selectData = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(ch, enc, cb) {\n      const [filePath, data] = ch;\n      const selectedData = keys\n        .map(key => getMatched(String(key), searchType, data))\n        .filter(dataColl => dataColl.length > 0);\n      if (selectedData.length > 0) {\n        this.push([selectedData, filePath]);\n      }\n      cb();\n    },\n  });\n  return readablePaths\n    .pipe(getContent)\n    .pipe(selectData);\n};\n\nexport const makeDataSelection = dataStream => new Promise((resolve, reject) => {\n  let totalInfo = {};\n  dataStream\n    .on('data', (dataPair) => {\n      const [selectedData, filePath] = dataPair;\n      const processedData = selectedData.reduce((acc, dataColl) => {\n        const newAcc = processData(dataColl, filePath, acc);\n        return newAcc;\n      }, totalInfo);\n      totalInfo = processedData;\n    })\n    .on('end', () => {\n      resolve(totalInfo);\n    })\n    .on('error', reject);\n});\n\nexport const writeToJson = (totalInfo, processedDataPath) => {\n  const objToArr = _.map(totalInfo, (value, key) => ({ [key]: value }));\n  const readableTotalInfo = new CustomReader(objToArr, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const transformToJson = new Transform({\n    writableObjectMode: true,\n    transform([chunk], enc, cb) {\n      const data = makeJsonChunk(chunk, objToArr.length);\n      this.push(data);\n      cb();\n    },\n  });\n\n  const writableJson = fs.createWriteStream(processedDataPath);\n  const streamsInPromise = new Promise((resolve, reject) => {\n    readableTotalInfo\n      .pipe(transformToJson)\n      .pipe(writableJson)\n      .on('finish', () => {\n        console.log(`Structured JSON-data are saved in ${processedDataPath}\\n`);\n        resolve();\n      })\n      .on('error', reject);\n  });\n\n  return streamsInPromise;\n};\n\nexport const selectZeroMovements = (pathDataColl) => {\n  const separatedItems = _.partition(pathDataColl, ([, content]) => {\n    const hasZeros = content.split('\\n').every((line) => {\n      const [,,,\n        countIn,,\n        countOut,\n      ] = line.split('\\t');\n      const isZero = Number(countIn) === 0 && Number(countOut) === 0;\n      return isZero;\n    });\n\n    return hasZeros;\n  });\n\n  const [zeroCounts, rest] = separatedItems;\n  const [matchedPaths] = _.unzip(zeroCounts);\n  const [dataPaths] = _.unzip(rest);\n\n  return [matchedPaths, dataPaths];\n};\n"]}

@@ -8,8 +8,4 @@ "use strict";

var _path = _interopRequireDefault(require("path"));
var _fs = _interopRequireDefault(require("fs"));
var _readlineSync = _interopRequireDefault(require("readline-sync"));
var _stream = require("stream");

@@ -23,2 +19,4 @@

var _askUser = require("../askUser");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }

@@ -38,12 +36,6 @@

var renderAndWrite = function renderAndWrite(content, renderFn, parentFolder) {
var renderAndWrite = function renderAndWrite(content, renderFn, renderedDataPath) {
var data = JSON.parse(content);
var renderedDataColl = renderFn(data);
var renderedDataName = _readlineSync["default"].question('\nEnter a name for rendered data file (default name is "rendered"):', {
defaultInput: 'renderedData'
});
var renderedDataPath = _path["default"].join(parentFolder, "".concat(renderedDataName, ".txt"));
var renderedToDestination = _fs["default"].createWriteStream(renderedDataPath);

@@ -74,3 +66,3 @@

var _default = function _default(processedDataPath, resFolder) {
var _default = function _default(processedDataPath, renderTypes, resFolder) {
var renderFunctions = {

@@ -80,7 +72,12 @@ total: _totalValues["default"],

};
var renderTypes = ['total', 'detailed'];
var params = (0, _askUser.getRenderParams)(renderTypes, resFolder);
var positionNum = _readlineSync["default"].keyInSelect(renderTypes, 'Please select render type:');
if (!params) {
return;
}
var renderType = renderTypes[positionNum];
var _params = _slicedToArray(params, 2),
renderedDataPath = _params[0],
renderType = _params[1];
var render = renderFunctions[renderType];

@@ -92,3 +89,3 @@ var content = '';

}).on('end', function () {
renderAndWrite(content, render, resFolder);
renderAndWrite(content, render, renderedDataPath);
});

@@ -98,2 +95,2 @@ };

exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJlcnMvaW5kZXguanMiXSwibmFtZXMiOlsicmVuZGVyQW5kV3JpdGUiLCJjb250ZW50IiwicmVuZGVyRm4iLCJwYXJlbnRGb2xkZXIiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwicmVuZGVyZWREYXRhQ29sbCIsInJlbmRlcmVkRGF0YU5hbWUiLCJyZWFkbGluZVN5bmMiLCJxdWVzdGlvbiIsImRlZmF1bHRJbnB1dCIsInJlbmRlcmVkRGF0YVBhdGgiLCJwYXRoIiwiam9pbiIsInJlbmRlcmVkVG9EZXN0aW5hdGlvbiIsImZzIiwiY3JlYXRlV3JpdGVTdHJlYW0iLCJtYWtlUmVhZGFibGVSZW5kZXJlZERhdGEiLCJDdXN0b21SZWFkZXIiLCJvYmplY3RNb2RlIiwiaGlnaFdhdGVyTWFyayIsImNvdW50IiwibWFrZUZpbmFsU3RyIiwiVHJhbnNmb3JtIiwid3JpdGFibGVPYmplY3RNb2RlIiwidHJhbnNmb3JtIiwiZW5jIiwiY2IiLCJjaCIsInJlc1N0ciIsImxlbmd0aCIsInB1c2giLCJwaXBlIiwib24iLCJjb25zb2xlIiwibG9nIiwicHJvY2Vzc2VkRGF0YVBhdGgiLCJyZXNGb2xkZXIiLCJyZW5kZXJGdW5jdGlvbnMiLCJ0b3RhbCIsImRldGFpbGVkIiwicmVuZGVyVHlwZXMiLCJwb3NpdGlvbk51bSIsImtleUluU2VsZWN0IiwicmVuZGVyVHlwZSIsInJlbmRlciIsImNyZWF0ZVJlYWRTdHJlYW0iLCJjaHVuayJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsSUFBTUEsY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixDQUFDQyxPQUFELEVBQVVDLFFBQVYsRUFBb0JDLFlBQXBCLEVBQXFDO0FBQzFELE1BQU1DLElBQUksR0FBR0MsSUFBSSxDQUFDQyxLQUFMLENBQVdMLE9BQVgsQ0FBYjtBQUNBLE1BQU1NLGdCQUFnQixHQUFHTCxRQUFRLENBQUNFLElBQUQsQ0FBakM7O0FBQ0EsTUFBTUksZ0JBQWdCLEdBQUdDLHlCQUN0QkMsUUFEc0IsQ0FDYixxRUFEYSxFQUMwRDtBQUMvRUMsSUFBQUEsWUFBWSxFQUFFO0FBRGlFLEdBRDFELENBQXpCOztBQUlBLE1BQU1DLGdCQUFnQixHQUFHQyxpQkFBS0MsSUFBTCxDQUFVWCxZQUFWLFlBQTJCSyxnQkFBM0IsVUFBekI7O0FBQ0EsTUFBTU8scUJBQXFCLEdBQUdDLGVBQUdDLGlCQUFILENBQXFCTCxnQkFBckIsQ0FBOUI7O0FBRUEsTUFBTU0sd0JBQXdCLEdBQUcsSUFBSUMsd0JBQUosQ0FBaUJaLGdCQUFqQixFQUFtQztBQUNsRWEsSUFBQUEsVUFBVSxFQUFFLElBRHNEO0FBRWxFQyxJQUFBQSxhQUFhLEVBQUU7QUFGbUQsR0FBbkMsQ0FBakM7QUFLQSxNQUFJQyxLQUFLLEdBQUcsQ0FBWjtBQUNBLE1BQU1DLFlBQVksR0FBRyxJQUFJQyxpQkFBSixDQUFjO0FBQ2pDQyxJQUFBQSxrQkFBa0IsRUFBRSxJQURhO0FBRWpDQyxJQUFBQSxTQUZpQywyQkFFakJDLEdBRmlCLEVBRVpDLEVBRlksRUFFUjtBQUFBO0FBQUEsVUFBZEMsRUFBYzs7QUFDdkJQLE1BQUFBLEtBQUssSUFBSSxDQUFUO0FBQ0EsVUFBTVEsTUFBTSxHQUFHUixLQUFLLEdBQUdmLGdCQUFnQixDQUFDd0IsTUFBekIsYUFBcUNGLEVBQXJDLFVBQThDQSxFQUE3RDtBQUNBLFdBQUtHLElBQUwsQ0FBVUYsTUFBVjtBQUNBRixNQUFBQSxFQUFFO0FBQ0g7QUFQZ0MsR0FBZCxDQUFyQjtBQVVBVixFQUFBQSx3QkFBd0IsQ0FDckJlLElBREgsQ0FDUVYsWUFEUixFQUVHVSxJQUZILENBRVFsQixxQkFGUixFQUdHbUIsRUFISCxDQUdNLFFBSE4sRUFHZ0IsWUFBTTtBQUNsQkMsSUFBQUEsT0FBTyxDQUFDQyxHQUFSLHNDQUEwQ3hCLGdCQUExQztBQUNBdUIsSUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVksNENBQVo7QUFDRCxHQU5IO0FBT0QsQ0FqQ0Q7O2VBbUNlLGtCQUFDQyxpQkFBRCxFQUFvQkMsU0FBcEIsRUFBa0M7QUFDL0MsTUFBTUMsZUFBZSxHQUFHO0FBQ3RCQyxJQUFBQSxLQUFLLEVBQUxBLHVCQURzQjtBQUV0QkMsSUFBQUEsUUFBUSxFQUFSQTtBQUZzQixHQUF4QjtBQUlBLE1BQU1DLFdBQVcsR0FBRyxDQUFDLE9BQUQsRUFBVSxVQUFWLENBQXBCOztBQUNBLE1BQU1DLFdBQVcsR0FBR2xDLHlCQUFhbUMsV0FBYixDQUF5QkYsV0FBekIsRUFBc0MsNEJBQXRDLENBQXBCOztBQUNBLE1BQU1HLFVBQVUsR0FBR0gsV0FBVyxDQUFDQyxXQUFELENBQTlCO0FBQ0EsTUFBTUcsTUFBTSxHQUFHUCxlQUFlLENBQUNNLFVBQUQsQ0FBOUI7QUFFQSxNQUFJNUMsT0FBTyxHQUFHLEVBQWQ7O0FBQ0FlLGlCQUFHK0IsZ0JBQUgsQ0FBb0JWLGlCQUFwQixFQUNHSCxFQURILENBQ00sTUFETixFQUNjLFVBQUNjLEtBQUQsRUFBVztBQUNyQi9DLElBQUFBLE9BQU8sSUFBSStDLEtBQVg7QUFDRCxHQUhILEVBSUdkLEVBSkgsQ0FJTSxLQUpOLEVBSWEsWUFBTTtBQUNmbEMsSUFBQUEsY0FBYyxDQUFDQyxPQUFELEVBQVU2QyxNQUFWLEVBQWtCUixTQUFsQixDQUFkO0FBQ0QsR0FOSDtBQU9ELEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5pbXBvcnQgcmVhZGxpbmVTeW5jIGZyb20gJ3JlYWRsaW5lLXN5bmMnO1xuaW1wb3J0IHsgVHJhbnNmb3JtIH0gZnJvbSAnc3RyZWFtJztcbmltcG9ydCBDdXN0b21SZWFkZXIgZnJvbSAnLi4vU3RyZWFtUmVhZGVyJztcbmltcG9ydCB0b3RhbCBmcm9tICcuL3RvdGFsVmFsdWVzJztcbmltcG9ydCBkZXRhaWxlZCBmcm9tICcuL2RldGFpbGVkVmFsdWVzJztcblxuY29uc3QgcmVuZGVyQW5kV3JpdGUgPSAoY29udGVudCwgcmVuZGVyRm4sIHBhcmVudEZvbGRlcikgPT4ge1xuICBjb25zdCBkYXRhID0gSlNPTi5wYXJzZShjb250ZW50KTtcbiAgY29uc3QgcmVuZGVyZWREYXRhQ29sbCA9IHJlbmRlckZuKGRhdGEpO1xuICBjb25zdCByZW5kZXJlZERhdGFOYW1lID0gcmVhZGxpbmVTeW5jXG4gICAgLnF1ZXN0aW9uKCdcXG5FbnRlciBhIG5hbWUgZm9yIHJlbmRlcmVkIGRhdGEgZmlsZSAoZGVmYXVsdCBuYW1lIGlzIFwicmVuZGVyZWRcIik6Jywge1xuICAgICAgZGVmYXVsdElucHV0OiAncmVuZGVyZWREYXRhJyxcbiAgICB9KTtcbiAgY29uc3QgcmVuZGVyZWREYXRhUGF0aCA9IHBhdGguam9pbihwYXJlbnRGb2xkZXIsIGAke3JlbmRlcmVkRGF0YU5hbWV9LnR4dGApO1xuICBjb25zdCByZW5kZXJlZFRvRGVzdGluYXRpb24gPSBmcy5jcmVhdGVXcml0ZVN0cmVhbShyZW5kZXJlZERhdGFQYXRoKTtcblxuICBjb25zdCBtYWtlUmVhZGFibGVSZW5kZXJlZERhdGEgPSBuZXcgQ3VzdG9tUmVhZGVyKHJlbmRlcmVkRGF0YUNvbGwsIHtcbiAgICBvYmplY3RNb2RlOiB0cnVlLFxuICAgIGhpZ2hXYXRlck1hcms6IDEsXG4gIH0pO1xuXG4gIGxldCBjb3VudCA9IDA7XG4gIGNvbnN0IG1ha2VGaW5hbFN0ciA9IG5ldyBUcmFuc2Zvcm0oe1xuICAgIHdyaXRhYmxlT2JqZWN0TW9kZTogdHJ1ZSxcbiAgICB0cmFuc2Zvcm0oW2NoXSwgZW5jLCBjYikge1xuICAgICAgY291bnQgKz0gMTtcbiAgICAgIGNvbnN0IHJlc1N0ciA9IGNvdW50IDwgcmVuZGVyZWREYXRhQ29sbC5sZW5ndGggPyBgJHtjaH1cXG5gIDogY2g7XG4gICAgICB0aGlzLnB1c2gocmVzU3RyKTtcbiAgICAgIGNiKCk7XG4gICAgfSxcbiAgfSk7XG5cbiAgbWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhXG4gICAgLnBpcGUobWFrZUZpbmFsU3RyKVxuICAgIC5waXBlKHJlbmRlcmVkVG9EZXN0aW5hdGlvbilcbiAgICAub24oJ2ZpbmlzaCcsICgpID0+IHtcbiAgICAgIGNvbnNvbGUubG9nKGBSZW5kZXJlZCBkYXRhIGFyZSBzYXZlZCBpbiAke3JlbmRlcmVkRGF0YVBhdGh9XFxuYCk7XG4gICAgICBjb25zb2xlLmxvZygnXFxuLS0tLS0tLSBBbGwgZGF0YSBhcmUgcHJvY2Vzc2VkIC0tLS0tLS1cXG4nKTtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IChwcm9jZXNzZWREYXRhUGF0aCwgcmVzRm9sZGVyKSA9PiB7XG4gIGNvbnN0IHJlbmRlckZ1bmN0aW9ucyA9IHtcbiAgICB0b3RhbCxcbiAgICBkZXRhaWxlZCxcbiAgfTtcbiAgY29uc3QgcmVuZGVyVHlwZXMgPSBbJ3RvdGFsJywgJ2RldGFpbGVkJ107XG4gIGNvbnN0IHBvc2l0aW9uTnVtID0gcmVhZGxpbmVTeW5jLmtleUluU2VsZWN0KHJlbmRlclR5cGVzLCAnUGxlYXNlIHNlbGVjdCByZW5kZXIgdHlwZTonKTtcbiAgY29uc3QgcmVuZGVyVHlwZSA9IHJlbmRlclR5cGVzW3Bvc2l0aW9uTnVtXTtcbiAgY29uc3QgcmVuZGVyID0gcmVuZGVyRnVuY3Rpb25zW3JlbmRlclR5cGVdO1xuXG4gIGxldCBjb250ZW50ID0gJyc7XG4gIGZzLmNyZWF0ZVJlYWRTdHJlYW0ocHJvY2Vzc2VkRGF0YVBhdGgpXG4gICAgLm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICBjb250ZW50ICs9IGNodW5rO1xuICAgIH0pXG4gICAgLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJBbmRXcml0ZShjb250ZW50LCByZW5kZXIsIHJlc0ZvbGRlcik7XG4gICAgfSk7XG59O1xuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJlcnMvaW5kZXguanMiXSwibmFtZXMiOlsicmVuZGVyQW5kV3JpdGUiLCJjb250ZW50IiwicmVuZGVyRm4iLCJyZW5kZXJlZERhdGFQYXRoIiwiZGF0YSIsIkpTT04iLCJwYXJzZSIsInJlbmRlcmVkRGF0YUNvbGwiLCJyZW5kZXJlZFRvRGVzdGluYXRpb24iLCJmcyIsImNyZWF0ZVdyaXRlU3RyZWFtIiwibWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhIiwiQ3VzdG9tUmVhZGVyIiwib2JqZWN0TW9kZSIsImhpZ2hXYXRlck1hcmsiLCJjb3VudCIsIm1ha2VGaW5hbFN0ciIsIlRyYW5zZm9ybSIsIndyaXRhYmxlT2JqZWN0TW9kZSIsInRyYW5zZm9ybSIsImVuYyIsImNiIiwiY2giLCJyZXNTdHIiLCJsZW5ndGgiLCJwdXNoIiwicGlwZSIsIm9uIiwiY29uc29sZSIsImxvZyIsInByb2Nlc3NlZERhdGFQYXRoIiwicmVuZGVyVHlwZXMiLCJyZXNGb2xkZXIiLCJyZW5kZXJGdW5jdGlvbnMiLCJ0b3RhbCIsImRldGFpbGVkIiwicGFyYW1zIiwicmVuZGVyVHlwZSIsInJlbmRlciIsImNyZWF0ZVJlYWRTdHJlYW0iLCJjaHVuayJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsSUFBTUEsY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixDQUFDQyxPQUFELEVBQVVDLFFBQVYsRUFBb0JDLGdCQUFwQixFQUF5QztBQUM5RCxNQUFNQyxJQUFJLEdBQUdDLElBQUksQ0FBQ0MsS0FBTCxDQUFXTCxPQUFYLENBQWI7QUFDQSxNQUFNTSxnQkFBZ0IsR0FBR0wsUUFBUSxDQUFDRSxJQUFELENBQWpDOztBQUNBLE1BQU1JLHFCQUFxQixHQUFHQyxlQUFHQyxpQkFBSCxDQUFxQlAsZ0JBQXJCLENBQTlCOztBQUVBLE1BQU1RLHdCQUF3QixHQUFHLElBQUlDLHdCQUFKLENBQWlCTCxnQkFBakIsRUFBbUM7QUFDbEVNLElBQUFBLFVBQVUsRUFBRSxJQURzRDtBQUVsRUMsSUFBQUEsYUFBYSxFQUFFO0FBRm1ELEdBQW5DLENBQWpDO0FBS0EsTUFBSUMsS0FBSyxHQUFHLENBQVo7QUFDQSxNQUFNQyxZQUFZLEdBQUcsSUFBSUMsaUJBQUosQ0FBYztBQUNqQ0MsSUFBQUEsa0JBQWtCLEVBQUUsSUFEYTtBQUVqQ0MsSUFBQUEsU0FGaUMsMkJBRWpCQyxHQUZpQixFQUVaQyxFQUZZLEVBRVI7QUFBQTtBQUFBLFVBQWRDLEVBQWM7O0FBQ3ZCUCxNQUFBQSxLQUFLLElBQUksQ0FBVDtBQUNBLFVBQU1RLE1BQU0sR0FBR1IsS0FBSyxHQUFHUixnQkFBZ0IsQ0FBQ2lCLE1BQXpCLGFBQXFDRixFQUFyQyxVQUE4Q0EsRUFBN0Q7QUFDQSxXQUFLRyxJQUFMLENBQVVGLE1BQVY7QUFDQUYsTUFBQUEsRUFBRTtBQUNIO0FBUGdDLEdBQWQsQ0FBckI7QUFVQVYsRUFBQUEsd0JBQXdCLENBQ3JCZSxJQURILENBQ1FWLFlBRFIsRUFFR1UsSUFGSCxDQUVRbEIscUJBRlIsRUFHR21CLEVBSEgsQ0FHTSxRQUhOLEVBR2dCLFlBQU07QUFDbEJDLElBQUFBLE9BQU8sQ0FBQ0MsR0FBUixzQ0FBMEMxQixnQkFBMUM7QUFDQXlCLElBQUFBLE9BQU8sQ0FBQ0MsR0FBUixDQUFZLDRDQUFaO0FBQ0QsR0FOSDtBQU9ELENBNUJEOztlQThCZSxrQkFBQ0MsaUJBQUQsRUFBb0JDLFdBQXBCLEVBQWlDQyxTQUFqQyxFQUErQztBQUM1RCxNQUFNQyxlQUFlLEdBQUc7QUFDdEJDLElBQUFBLEtBQUssRUFBTEEsdUJBRHNCO0FBRXRCQyxJQUFBQSxRQUFRLEVBQVJBO0FBRnNCLEdBQXhCO0FBSUEsTUFBTUMsTUFBTSxHQUFHLDhCQUFnQkwsV0FBaEIsRUFBNkJDLFNBQTdCLENBQWY7O0FBQ0EsTUFBSSxDQUFDSSxNQUFMLEVBQWE7QUFDWDtBQUNEOztBQVIyRCwrQkFTckJBLE1BVHFCO0FBQUEsTUFTckRqQyxnQkFUcUQ7QUFBQSxNQVNuQ2tDLFVBVG1DOztBQVU1RCxNQUFNQyxNQUFNLEdBQUdMLGVBQWUsQ0FBQ0ksVUFBRCxDQUE5QjtBQUVBLE1BQUlwQyxPQUFPLEdBQUcsRUFBZDs7QUFDQVEsaUJBQUc4QixnQkFBSCxDQUFvQlQsaUJBQXBCLEVBQ0dILEVBREgsQ0FDTSxNQUROLEVBQ2MsVUFBQ2EsS0FBRCxFQUFXO0FBQ3JCdkMsSUFBQUEsT0FBTyxJQUFJdUMsS0FBWDtBQUNELEdBSEgsRUFJR2IsRUFKSCxDQUlNLEtBSk4sRUFJYSxZQUFNO0FBQ2YzQixJQUFBQSxjQUFjLENBQUNDLE9BQUQsRUFBVXFDLE1BQVYsRUFBa0JuQyxnQkFBbEIsQ0FBZDtBQUNELEdBTkg7QUFPRCxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGZzIGZyb20gJ2ZzJztcbmltcG9ydCB7IFRyYW5zZm9ybSB9IGZyb20gJ3N0cmVhbSc7XG5pbXBvcnQgQ3VzdG9tUmVhZGVyIGZyb20gJy4uL1N0cmVhbVJlYWRlcic7XG5pbXBvcnQgdG90YWwgZnJvbSAnLi90b3RhbFZhbHVlcyc7XG5pbXBvcnQgZGV0YWlsZWQgZnJvbSAnLi9kZXRhaWxlZFZhbHVlcyc7XG5pbXBvcnQgeyBnZXRSZW5kZXJQYXJhbXMgfSBmcm9tICcuLi9hc2tVc2VyJztcblxuY29uc3QgcmVuZGVyQW5kV3JpdGUgPSAoY29udGVudCwgcmVuZGVyRm4sIHJlbmRlcmVkRGF0YVBhdGgpID0+IHtcbiAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UoY29udGVudCk7XG4gIGNvbnN0IHJlbmRlcmVkRGF0YUNvbGwgPSByZW5kZXJGbihkYXRhKTtcbiAgY29uc3QgcmVuZGVyZWRUb0Rlc3RpbmF0aW9uID0gZnMuY3JlYXRlV3JpdGVTdHJlYW0ocmVuZGVyZWREYXRhUGF0aCk7XG5cbiAgY29uc3QgbWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhID0gbmV3IEN1c3RvbVJlYWRlcihyZW5kZXJlZERhdGFDb2xsLCB7XG4gICAgb2JqZWN0TW9kZTogdHJ1ZSxcbiAgICBoaWdoV2F0ZXJNYXJrOiAxLFxuICB9KTtcblxuICBsZXQgY291bnQgPSAwO1xuICBjb25zdCBtYWtlRmluYWxTdHIgPSBuZXcgVHJhbnNmb3JtKHtcbiAgICB3cml0YWJsZU9iamVjdE1vZGU6IHRydWUsXG4gICAgdHJhbnNmb3JtKFtjaF0sIGVuYywgY2IpIHtcbiAgICAgIGNvdW50ICs9IDE7XG4gICAgICBjb25zdCByZXNTdHIgPSBjb3VudCA8IHJlbmRlcmVkRGF0YUNvbGwubGVuZ3RoID8gYCR7Y2h9XFxuYCA6IGNoO1xuICAgICAgdGhpcy5wdXNoKHJlc1N0cik7XG4gICAgICBjYigpO1xuICAgIH0sXG4gIH0pO1xuXG4gIG1ha2VSZWFkYWJsZVJlbmRlcmVkRGF0YVxuICAgIC5waXBlKG1ha2VGaW5hbFN0cilcbiAgICAucGlwZShyZW5kZXJlZFRvRGVzdGluYXRpb24pXG4gICAgLm9uKCdmaW5pc2gnLCAoKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyhgUmVuZGVyZWQgZGF0YSBhcmUgc2F2ZWQgaW4gJHtyZW5kZXJlZERhdGFQYXRofVxcbmApO1xuICAgICAgY29uc29sZS5sb2coJ1xcbi0tLS0tLS0gQWxsIGRhdGEgYXJlIHByb2Nlc3NlZCAtLS0tLS0tXFxuJyk7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCAocHJvY2Vzc2VkRGF0YVBhdGgsIHJlbmRlclR5cGVzLCByZXNGb2xkZXIpID0+IHtcbiAgY29uc3QgcmVuZGVyRnVuY3Rpb25zID0ge1xuICAgIHRvdGFsLFxuICAgIGRldGFpbGVkLFxuICB9O1xuICBjb25zdCBwYXJhbXMgPSBnZXRSZW5kZXJQYXJhbXMocmVuZGVyVHlwZXMsIHJlc0ZvbGRlcik7XG4gIGlmICghcGFyYW1zKSB7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnN0IFtyZW5kZXJlZERhdGFQYXRoLCByZW5kZXJUeXBlXSA9IHBhcmFtcztcbiAgY29uc3QgcmVuZGVyID0gcmVuZGVyRnVuY3Rpb25zW3JlbmRlclR5cGVdO1xuXG4gIGxldCBjb250ZW50ID0gJyc7XG4gIGZzLmNyZWF0ZVJlYWRTdHJlYW0ocHJvY2Vzc2VkRGF0YVBhdGgpXG4gICAgLm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICBjb250ZW50ICs9IGNodW5rO1xuICAgIH0pXG4gICAgLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJBbmRXcml0ZShjb250ZW50LCByZW5kZXIsIHJlbmRlcmVkRGF0YVBhdGgpO1xuICAgIH0pO1xufTtcbiJdfQ==
{
"name": "proxima_datareader",
"version": "1.0.4",
"version": "1.1.0",
"description": "data reader & selector 4 incoming data files having 1 of following extensions: \n'.mdr', '.mwr', '.mmr', '.mdi', '.mwi', '.mmi'",

@@ -41,3 +41,4 @@ "scripts": {

"regenerator-runtime": "^0.13.7",
"save": "^2.4.0"
"save": "^2.4.0",
"validator": "^13.1.17"
},

@@ -44,0 +45,0 @@ "repository": {

@@ -6,3 +6,7 @@ export default {

'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'latin1', 'binary'],
searchTypes: ['drugCode', 'drugName'],
searchTypes: {
drugCode: 'number',
drugName: 'string',
},
renderTypes: ['total', 'detailed'],
};

@@ -5,4 +5,10 @@ import fs from 'fs';

import _ from 'lodash';
import readlineSync from 'readline-sync';
import {
getSearchParams,
getKeysData,
getFilesSource,
getProcessedDataPath,
selectProcessOrRender,
} from './askUser';
import {
makePaths,

@@ -14,3 +20,2 @@ makeDataStream,

import makeRender from './renderers';
import { writeDownPaths } from './writers';

@@ -24,33 +29,30 @@ import defaultValues from './defaults';

searchTypes,
renderTypes,
} = defaultValues;
export default async (emptyAndZerosOnly = false) => {
const filesSource = readlineSync.questionPath('Please type files source:', {
exists: true,
isDirectory: true,
defaultInput: defaultSourcePath,
});
console.log(`${filesSource}\n`);
const paths = makePaths(filesSource);
const [emptySources, notEmptySources] = _.partition(paths, pathToFile => _.isArray(pathToFile));
// const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');
const [encoding] = encodings;
const keysPath = readlineSync.questionPath('\nPlease type search keys source:', {
exists: true,
isFile: true,
defaultInput: defaultKeysSource,
});
console.log(`${keysPath}\n`);
const searchTypePos = readlineSync.keyInSelect(searchTypes, 'Please select type of data search:');
if (searchTypePos === -1) {
console.log('See you next time )\n');
const searchParams = getSearchParams(searchTypes);
if (!searchParams) {
return;
}
const keysFolder = path.dirname(keysPath);
const [searchTypeName, keysDataType] = searchParams;
const [keys, keysFolder] = getKeysData(searchTypeName, keysDataType, defaultKeysSource);
const newPath = path.join(keysFolder, 'processedData');
const resFolder = fs.existsSync(newPath) ? newPath : fs.mkdirSync(newPath, { recursive: true });
const resFolderFilesList = fs.readdirSync(resFolder);
const jsonFilesList = resFolderFilesList
.filter(fileName => fileName && path.extname(fileName) === '.json');
if (jsonFilesList.length > 0) {
const dataToRenderPath = selectProcessOrRender(jsonFilesList);
if (dataToRenderPath) {
const selectedDataPath = path.join(resFolder, dataToRenderPath);
makeRender(selectedDataPath, renderTypes, resFolder);
return;
}
}
const filesSource = getFilesSource(defaultSourcePath);
const paths = makePaths(filesSource);
const [emptySources, notEmptySources] = _.partition(paths, pathToFile => _.isArray(pathToFile));
if (emptySources.length > 0) {

@@ -62,18 +64,14 @@ await writeDownPaths(emptySources, resFolder, 'empty');

}
const keysContent = fs.readFileSync(keysPath, 'utf-8');
const keys = keysContent.trim().split('\r\n').map(key => key.trim());
// const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');
const [encoding] = encodings;
const processedDataPath = getProcessedDataPath(resFolder);
const processedDataName = readlineSync
.question('Enter a name for processed data file (default name is "processed"):', { defaultInput: 'processedData' });
const processedDataPath = path.join(resFolder, `${processedDataName}.json`);
console.log('\nData-processing is ongoing...\n');
const searchType = searchTypes[searchTypePos];
const dataStream = makeDataStream(notEmptySources, searchType, keys, encoding);
const dataStream = makeDataStream(notEmptySources, searchTypeName, keys, encoding);
makeDataSelection(dataStream)
.then(totalInfo => writeToJson(totalInfo, processedDataPath))
.then(() => {
makeRender(processedDataPath, resFolder);
makeRender(processedDataPath, renderTypes, resFolder);
});
};

@@ -29,3 +29,2 @@ import fs from 'fs';

const getMatched = (strToSearch, searchType, content) => content.split('\n').filter((line) => {

@@ -32,0 +31,0 @@ const [

@@ -1,4 +0,2 @@

import path from 'path';
import fs from 'fs';
import readlineSync from 'readline-sync';
import { Transform } from 'stream';

@@ -8,11 +6,7 @@ import CustomReader from '../StreamReader';

import detailed from './detailedValues';
import { getRenderParams } from '../askUser';
const renderAndWrite = (content, renderFn, parentFolder) => {
const renderAndWrite = (content, renderFn, renderedDataPath) => {
const data = JSON.parse(content);
const renderedDataColl = renderFn(data);
const renderedDataName = readlineSync
.question('\nEnter a name for rendered data file (default name is "rendered"):', {
defaultInput: 'renderedData',
});
const renderedDataPath = path.join(parentFolder, `${renderedDataName}.txt`);
const renderedToDestination = fs.createWriteStream(renderedDataPath);

@@ -45,3 +39,3 @@

export default (processedDataPath, resFolder) => {
export default (processedDataPath, renderTypes, resFolder) => {
const renderFunctions = {

@@ -51,5 +45,7 @@ total,

};
const renderTypes = ['total', 'detailed'];
const positionNum = readlineSync.keyInSelect(renderTypes, 'Please select render type:');
const renderType = renderTypes[positionNum];
const params = getRenderParams(renderTypes, resFolder);
if (!params) {
return;
}
const [renderedDataPath, renderType] = params;
const render = renderFunctions[renderType];

@@ -63,4 +59,4 @@

.on('end', () => {
renderAndWrite(content, render, resFolder);
renderAndWrite(content, render, renderedDataPath);
});
};
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc