proxima_datareader
Advanced tools
Comparing version 1.5.0 to 1.5.1
@@ -54,3 +54,3 @@ "use strict"; | ||
var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { | ||
var searchTypes, renderTypes, fileTypes, messages, searchParams, _searchParams, searchTypeName, keysDataType, _getKeysData, _getKeysData2, keys, keysFolder, resFolder, functionNames, processingType, resFolderFilesList, jsonFilesList, fileToRender, selectedDataPath, _params, filesSource, paths, _$partition, _$partition2, emptySources, notEmptySources, processedDataPath, processData, totalInfo, params; | ||
var searchTypes, renderTypes, fileTypes, messages, searchParams, _searchParams, searchTypeName, keysDataType, _getKeysData, _getKeysData2, keys, keysFolder, resFolder, resFolderFilesList, jsonFilesList, fileToRender, selectedDataPath, _params, filesSource, paths, _$partition, _$partition2, emptySources, notEmptySources, processedDataPath, functionNames, processingType, totalInfo, params; | ||
@@ -93,13 +93,2 @@ return regeneratorRuntime.wrap(function _callee$(_context) { | ||
functionNames = _lodash["default"].keys(calculators); | ||
processingType = (0, _askUser.selectProcessingType)(functionNames); | ||
if (processingType) { | ||
_context.next = 16; | ||
break; | ||
} | ||
return _context.abrupt("return"); | ||
case 16: | ||
resFolderFilesList = _fs["default"].readdirSync(resFolder); | ||
@@ -111,3 +100,3 @@ jsonFilesList = resFolderFilesList.filter(function (fileName) { | ||
if (!(jsonFilesList.length > 0)) { | ||
_context.next = 25; | ||
_context.next = 23; | ||
break; | ||
@@ -119,3 +108,3 @@ } | ||
if (!fileToRender) { | ||
_context.next = 25; | ||
_context.next = 23; | ||
break; | ||
@@ -126,6 +115,15 @@ } | ||
_params = (0, _askUser.getRenderParams)(renderTypes, resFolder); | ||
(0, _rendering["default"])(selectedDataPath, _params, processingType); | ||
if (_params) { | ||
_context.next = 21; | ||
break; | ||
} | ||
return _context.abrupt("return"); | ||
case 25: | ||
case 21: | ||
(0, _rendering["default"])(selectedDataPath, _params); | ||
return _context.abrupt("return"); | ||
case 23: | ||
filesSource = (0, _askUser.getFilesSource)(_defaults.defaultValues); | ||
@@ -138,27 +136,37 @@ paths = (0, _processors.makePaths)(filesSource, fileTypes); | ||
if (!(emptySources.length > 0)) { | ||
_context.next = 31; | ||
_context.next = 29; | ||
break; | ||
} | ||
_context.next = 31; | ||
_context.next = 29; | ||
return (0, _askUser.writeDownPaths)(emptySources, resFolder, 'empty'); | ||
case 31: | ||
case 29: | ||
// const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding'); | ||
// const [encoding] = encodings; | ||
processedDataPath = (0, _askUser.getProcessedDataPath)(resFolder); | ||
functionNames = _lodash["default"].keys(calculators); | ||
processingType = (0, _askUser.selectProcessingType)(functionNames); | ||
if (processingType) { | ||
_context.next = 34; | ||
break; | ||
} | ||
return _context.abrupt("return"); | ||
case 34: | ||
messages.onGoing(); | ||
_context.next = 35; | ||
_context.next = 37; | ||
return (0, _processors.makeDataStream)(notEmptySources, searchTypeName, keys, resFolder); | ||
case 35: | ||
processData = calculators[processingType]; | ||
_context.next = 38; | ||
return (0, _processors.makeStructuredData)(resFolder, processData); | ||
case 37: | ||
_context.next = 39; | ||
return (0, _processors.makeStructuredData)(resFolder, processingType); | ||
case 38: | ||
case 39: | ||
totalInfo = _context.sent; | ||
if (!(_lodash["default"].size(totalInfo) === 0)) { | ||
_context.next = 42; | ||
_context.next = 43; | ||
break; | ||
@@ -170,11 +178,11 @@ } | ||
case 42: | ||
_context.next = 44; | ||
case 43: | ||
_context.next = 45; | ||
return (0, _processors.writeToJson)(totalInfo, processedDataPath); | ||
case 44: | ||
case 45: | ||
params = (0, _askUser.getRenderParams)(renderTypes, resFolder); | ||
if (params) { | ||
_context.next = 47; | ||
_context.next = 48; | ||
break; | ||
@@ -185,6 +193,6 @@ } | ||
case 47: | ||
(0, _rendering["default"])(processedDataPath, params, processingType); | ||
case 48: | ||
(0, _rendering["default"])(processedDataPath, params); | ||
case 48: | ||
case 49: | ||
case "end": | ||
@@ -221,2 +229,2 @@ return _context.stop(); | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["app","searchTypes","defaultValues","renderTypes","fileTypes","messages","names","searchParams","searchTypeName","keysDataType","keys","keysFolder","noCodes","resFolder","path","join","fs","existsSync","mkdirSync","recursive","functionNames","_","calculators","processingType","resFolderFilesList","readdirSync","jsonFilesList","filter","fileName","extname","length","fileToRender","selectedDataPath","params","filesSource","paths","partition","pathToFile","isArray","emptySources","notEmptySources","processedDataPath","onGoing","processData","totalInfo","size","noData","err","console","log","Error"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport 'regenerator-runtime';\nimport _ from 'lodash';\nimport {\n  getSearchParams,\n  getKeysData,\n  getFilesSource,\n  getProcessedDataPath,\n  selectProcessOrRender,\n  writeDownPaths,\n  selectProcessingType,\n  getRenderParams,\n} from './askUser';\nimport {\n  makePaths,\n  makeDataStream,\n  makeStructuredData,\n  writeToJson,\n} from './processing/processors';\nimport * as calculators from './processing/calculations';\nimport makeRender from './rendering';\nimport names from './rendering/names';\nimport { defaultValues } from './defaults';\n\n\nconst app = async () => {\n  const {\n    // encodings,\n    searchTypes,\n    renderTypes,\n    fileTypes,\n  } = defaultValues;\n\n  const { messages } = names;\n\n  const searchParams = getSearchParams(searchTypes);\n  if (!searchParams) {\n    return;\n  }\n  const [searchTypeName, keysDataType] = searchParams;\n  const [keys, keysFolder] = getKeysData(searchTypeName, keysDataType, defaultValues);\n  if (!keys) {\n    messages.noCodes();\n    return;\n  }\n  const resFolder = path.join(keysFolder, 'processedData');\n  if (!fs.existsSync(resFolder)) {\n    fs.mkdirSync(resFolder, { recursive: true });\n  }\n\n  const functionNames = _.keys(calculators);\n  const processingType = selectProcessingType(functionNames);\n  if (!processingType) {\n    return;\n  }\n\n  const resFolderFilesList = fs.readdirSync(resFolder);\n  const jsonFilesList = resFolderFilesList\n    .filter(fileName => fileName && path.extname(fileName) === '.json');\n  if (jsonFilesList.length > 0) {\n    const fileToRender = selectProcessOrRender(jsonFilesList);\n    if (fileToRender) {\n      const selectedDataPath = path.join(resFolder, fileToRender);\n      const params = getRenderParams(renderTypes, resFolder);\n      makeRender(selectedDataPath, params, processingType);\n      return;\n    }\n  }\n\n  const filesSource = getFilesSource(defaultValues);\n  const paths = makePaths(filesSource, fileTypes);\n  const [emptySources, notEmptySources] = _.partition(paths, pathToFile => _.isArray(pathToFile));\n  if (emptySources.length > 0) {\n    await writeDownPaths(emptySources, resFolder, 'empty');\n  }\n  // const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');\n  // const [encoding] = encodings;\n  const processedDataPath = getProcessedDataPath(resFolder);\n\n  messages.onGoing();\n  await makeDataStream(notEmptySources, searchTypeName, keys, resFolder);\n  const processData = calculators[processingType];\n  const totalInfo = await makeStructuredData(resFolder, processData);\n  if (_.size(totalInfo) === 0) {\n    messages.noData();\n    return;\n  }\n  await writeToJson(totalInfo, processedDataPath);\n  const params = getRenderParams(renderTypes, resFolder);\n  if (!params) {\n    return;\n  }\n  makeRender(processedDataPath, params, processingType);\n};\n\nexport default async () => {\n  app().catch((err) => {\n    console.log(err);\n    throw new Error(err);\n  });\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":["app","searchTypes","defaultValues","renderTypes","fileTypes","messages","names","searchParams","searchTypeName","keysDataType","keys","keysFolder","noCodes","resFolder","path","join","fs","existsSync","mkdirSync","recursive","resFolderFilesList","readdirSync","jsonFilesList","filter","fileName","extname","length","fileToRender","selectedDataPath","params","filesSource","paths","_","partition","pathToFile","isArray","emptySources","notEmptySources","processedDataPath","functionNames","calculators","processingType","onGoing","totalInfo","size","noData","err","console","log","Error"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport 'regenerator-runtime';\nimport _ from 'lodash';\nimport {\n  getSearchParams,\n  getKeysData,\n  getFilesSource,\n  getProcessedDataPath,\n  selectProcessOrRender,\n  writeDownPaths,\n  selectProcessingType,\n  getRenderParams,\n} from './askUser';\nimport {\n  makePaths,\n  makeDataStream,\n  makeStructuredData,\n  writeToJson,\n} from './processing/processors';\nimport * as calculators from './processing/calculations';\nimport makeRender from './rendering';\nimport names from './rendering/names';\nimport { defaultValues } from './defaults';\n\n\nconst app = async () => {\n  const {\n    // encodings,\n    searchTypes,\n    renderTypes,\n    fileTypes,\n  } = defaultValues;\n\n  const { messages } = names;\n\n  const searchParams = getSearchParams(searchTypes);\n  if (!searchParams) {\n    return;\n  }\n  const [searchTypeName, keysDataType] = searchParams;\n  const [keys, keysFolder] = getKeysData(searchTypeName, keysDataType, defaultValues);\n  if (!keys) {\n    messages.noCodes();\n    return;\n  }\n  const resFolder = path.join(keysFolder, 'processedData');\n  if (!fs.existsSync(resFolder)) {\n    fs.mkdirSync(resFolder, { recursive: true });\n  }\n\n  const resFolderFilesList = fs.readdirSync(resFolder);\n  const jsonFilesList = resFolderFilesList\n    .filter(fileName => fileName && path.extname(fileName) === '.json');\n  if (jsonFilesList.length > 0) {\n    const fileToRender = selectProcessOrRender(jsonFilesList);\n    if (fileToRender) {\n      const selectedDataPath = path.join(resFolder, fileToRender);\n      const params = getRenderParams(renderTypes, resFolder);\n      if (!params) {\n        return;\n      }\n      makeRender(selectedDataPath, params);\n      return;\n    }\n  }\n\n  const filesSource = getFilesSource(defaultValues);\n  const paths = makePaths(filesSource, fileTypes);\n  const [emptySources, notEmptySources] = _.partition(paths, pathToFile => _.isArray(pathToFile));\n  if (emptySources.length > 0) {\n    await writeDownPaths(emptySources, resFolder, 'empty');\n  }\n  // const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding');\n  // const [encoding] = encodings;\n  const processedDataPath = getProcessedDataPath(resFolder);\n  const functionNames = _.keys(calculators);\n  const processingType = selectProcessingType(functionNames);\n  if (!processingType) {\n    return;\n  }\n  messages.onGoing();\n  await makeDataStream(notEmptySources, searchTypeName, keys, resFolder);\n\n  const totalInfo = await makeStructuredData(resFolder, processingType);\n  if (_.size(totalInfo) === 0) {\n    messages.noData();\n    return;\n  }\n  await writeToJson(totalInfo, processedDataPath);\n  const params = getRenderParams(renderTypes, resFolder);\n  if (!params) {\n    return;\n  }\n  makeRender(processedDataPath, params);\n};\n\nexport default async () => {\n  app().catch((err) => {\n    console.log(err);\n    throw new Error(err);\n  });\n};\n"]} |
@@ -20,2 +20,4 @@ "use strict"; | ||
var calculators = _interopRequireWildcard(require("./calculations")); | ||
var _StreamReader = _interopRequireDefault(require("./StreamReader")); | ||
@@ -98,3 +100,3 @@ | ||
var makeStructuredData = function makeStructuredData(resFolder, processData) { | ||
var makeStructuredData = function makeStructuredData(resFolder, processingType) { | ||
return new Promise(function (resolve, reject) { | ||
@@ -105,3 +107,5 @@ var totalInfo = {}; | ||
if (!processData) { | ||
var processDataFn = calculators[processingType]; | ||
if (!processDataFn) { | ||
resolve(totalInfo); | ||
@@ -117,5 +121,9 @@ return; | ||
processData(filePath, selectedData, totalInfo); | ||
processDataFn(filePath, selectedData, totalInfo); | ||
}).on('end', function () { | ||
resolve(totalInfo); | ||
var data = { | ||
processedBy: processingType, | ||
totalInfo: totalInfo | ||
}; | ||
resolve(data); | ||
}).on('error', reject); | ||
@@ -183,2 +191,2 @@ }); | ||
exports.selectZeroMovements = selectZeroMovements; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/processing/processors.js"],"names":["makePaths","source","fileTypes","pathsList","info","fs","statSync","size","isDirectory","fileExt","path","extname","isCorrectFormat","includes","dirContent","readdirSync","resContentColl","reduce","acc","name","innerPath","join","makeDataStream","pathDataColl","searchType","keys","resFolder","readablePaths","CustomReader","objectMode","highWaterMark","writeColl","createWriteStream","Promise","resolve","reject","pipe","streams","getContent","selectData","on","makeStructuredData","processData","totalInfo","readable","createReadStream","dataPair","split","filePath","selectedData","writeToJson","processedDataPath","objToArr","_","map","value","key","readableTotalInfo","writableJson","streamsInPromise","transformToJson","console","log","selectZeroMovements","separatedItems","partition","content","hasZeros","every","line","countIn","countOut","isZero","Number","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport _ from 'lodash';\nimport split from 'split';\nimport * as streams from './transformStreams';\nimport CustomReader from './StreamReader';\nimport 'regenerator-runtime';\n\n\nexport const makePaths = (source, fileTypes, pathsList = []) => {\n  const info = fs.statSync(source);\n  if (info.size === 0) {\n    return [[source]];\n  }\n  if (!info.isDirectory()) {\n    const fileExt = path.extname(source);\n    const isCorrectFormat = fileTypes.includes(fileExt);\n    return isCorrectFormat ? [source] : [];\n  }\n  const dirContent = fs.readdirSync(source);\n  const resContentColl = dirContent\n    .reduce((acc, name) => {\n      const innerPath = path.join(source, name);\n      return [...acc, ...makePaths(innerPath, fileTypes)];\n    }, pathsList);\n  return resContentColl;\n};\n\nexport const makeDataStream = (pathDataColl, searchType, keys, resFolder) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const writeColl = fs.createWriteStream(`${resFolder}/temp_data.txt`);\n  return new Promise((resolve, reject) => {\n    readablePaths\n      .pipe(streams.getContent())\n      .pipe(streams.selectData(keys, searchType))\n      .pipe(writeColl)\n      .on('finish', () => {\n        resolve();\n      })\n      .on('error', reject);\n  });\n};\n\nexport const makeStructuredData = (resFolder, processData) => new Promise((resolve, reject) => {\n  const totalInfo = {};\n  const readable = fs.createReadStream(`${resFolder}/temp_data.txt`);\n  if (!processData) {\n    resolve(totalInfo);\n    return;\n  }\n  readable\n    .pipe(split())\n    .on('data', (dataPair) => {\n      const [filePath, selectedData] = dataPair.split('---');\n      processData(filePath, selectedData, totalInfo);\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 writableJson = fs.createWriteStream(processedDataPath);\n  const streamsInPromise = new Promise((resolve, reject) => {\n    readableTotalInfo\n      .pipe(streams.transformToJson(objToArr))\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/processing/processors.js"],"names":["makePaths","source","fileTypes","pathsList","info","fs","statSync","size","isDirectory","fileExt","path","extname","isCorrectFormat","includes","dirContent","readdirSync","resContentColl","reduce","acc","name","innerPath","join","makeDataStream","pathDataColl","searchType","keys","resFolder","readablePaths","CustomReader","objectMode","highWaterMark","writeColl","createWriteStream","Promise","resolve","reject","pipe","streams","getContent","selectData","on","makeStructuredData","processingType","totalInfo","readable","createReadStream","processDataFn","calculators","dataPair","split","filePath","selectedData","data","processedBy","writeToJson","processedDataPath","objToArr","_","map","value","key","readableTotalInfo","writableJson","streamsInPromise","transformToJson","console","log","selectZeroMovements","separatedItems","partition","content","hasZeros","every","line","countIn","countOut","isZero","Number","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport _ from 'lodash';\nimport split from 'split';\nimport * as streams from './transformStreams';\nimport * as calculators from './calculations';\nimport CustomReader from './StreamReader';\nimport 'regenerator-runtime';\n\n\nexport const makePaths = (source, fileTypes, pathsList = []) => {\n  const info = fs.statSync(source);\n  if (info.size === 0) {\n    return [[source]];\n  }\n  if (!info.isDirectory()) {\n    const fileExt = path.extname(source);\n    const isCorrectFormat = fileTypes.includes(fileExt);\n    return isCorrectFormat ? [source] : [];\n  }\n  const dirContent = fs.readdirSync(source);\n  const resContentColl = dirContent\n    .reduce((acc, name) => {\n      const innerPath = path.join(source, name);\n      return [...acc, ...makePaths(innerPath, fileTypes)];\n    }, pathsList);\n  return resContentColl;\n};\n\nexport const makeDataStream = (pathDataColl, searchType, keys, resFolder) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  const writeColl = fs.createWriteStream(`${resFolder}/temp_data.txt`);\n  return new Promise((resolve, reject) => {\n    readablePaths\n      .pipe(streams.getContent())\n      .pipe(streams.selectData(keys, searchType))\n      .pipe(writeColl)\n      .on('finish', () => {\n        resolve();\n      })\n      .on('error', reject);\n  });\n};\n\nexport const makeStructuredData = (resFolder, processingType) => new Promise((resolve, reject) => {\n  const totalInfo = {};\n  const readable = fs.createReadStream(`${resFolder}/temp_data.txt`);\n  const processDataFn = calculators[processingType];\n  if (!processDataFn) {\n    resolve(totalInfo);\n    return;\n  }\n  readable\n    .pipe(split())\n    .on('data', (dataPair) => {\n      const [filePath, selectedData] = dataPair.split('---');\n      processDataFn(filePath, selectedData, totalInfo);\n    })\n    .on('end', () => {\n      const data = { processedBy: processingType, totalInfo };\n      resolve(data);\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 writableJson = fs.createWriteStream(processedDataPath);\n  const streamsInPromise = new Promise((resolve, reject) => {\n    readableTotalInfo\n      .pipe(streams.transformToJson(objToArr))\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"]} |
@@ -34,5 +34,19 @@ "use strict"; | ||
var renderAndWrite = function renderAndWrite(content, renderFn, renderedDataPath) { | ||
var renderFunctions = { | ||
processByStores: { | ||
total: _totalValues["default"].bind(null, 'brNick'), | ||
detailed: _detailedByStores["default"] | ||
}, | ||
processByChainDrugCodes: { | ||
total: _totalValues["default"].bind(null, 'chainDrugCode'), | ||
detailed: _detailedByChainCodes["default"] | ||
} | ||
}; | ||
var renderAndWrite = function renderAndWrite(content, renderedDataPath, renderType) { | ||
var data = JSON.parse(content); | ||
var renderedDataColl = renderFn(data); | ||
var processedBy = data.processedBy, | ||
totalInfo = data.totalInfo; | ||
var render = renderFunctions[processedBy][renderType]; | ||
var renderedDataColl = render(totalInfo); | ||
@@ -51,14 +65,3 @@ var renderedToDestination = _fs["default"].createWriteStream(renderedDataPath); | ||
var _default = function _default(processedDataPath, params, renderingType) { | ||
var renderFunctions = { | ||
processByStores: { | ||
total: _totalValues["default"].bind(null, 'brNick'), | ||
detailed: _detailedByStores["default"] | ||
}, | ||
processByChainDrugCodes: { | ||
total: _totalValues["default"].bind(null, 'chainDrugCode'), | ||
detailed: _detailedByChainCodes["default"] | ||
} | ||
}; | ||
var _default = function _default(processedDataPath, params) { | ||
var _params = _slicedToArray(params, 2), | ||
@@ -68,3 +71,2 @@ renderedDataPath = _params[0], | ||
var render = renderFunctions[renderingType][renderType]; | ||
var content = ''; | ||
@@ -75,3 +77,3 @@ | ||
}).on('end', function () { | ||
renderAndWrite(content, render, renderedDataPath); | ||
renderAndWrite(content, renderedDataPath, renderType); | ||
}); | ||
@@ -81,2 +83,2 @@ }; | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJpbmcvaW5kZXguanMiXSwibmFtZXMiOlsicmVuZGVyQW5kV3JpdGUiLCJjb250ZW50IiwicmVuZGVyRm4iLCJyZW5kZXJlZERhdGFQYXRoIiwiZGF0YSIsIkpTT04iLCJwYXJzZSIsInJlbmRlcmVkRGF0YUNvbGwiLCJyZW5kZXJlZFRvRGVzdGluYXRpb24iLCJmcyIsImNyZWF0ZVdyaXRlU3RyZWFtIiwibWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhIiwiQ3VzdG9tUmVhZGVyIiwib2JqZWN0TW9kZSIsImhpZ2hXYXRlck1hcmsiLCJwaXBlIiwib24iLCJjb25zb2xlIiwibG9nIiwicHJvY2Vzc2VkRGF0YVBhdGgiLCJwYXJhbXMiLCJyZW5kZXJpbmdUeXBlIiwicmVuZGVyRnVuY3Rpb25zIiwicHJvY2Vzc0J5U3RvcmVzIiwidG90YWwiLCJiaW5kIiwiZGV0YWlsZWQiLCJkZXRhaWxlZEJ5U3RvcmVzIiwicHJvY2Vzc0J5Q2hhaW5EcnVnQ29kZXMiLCJkZXRhaWxlZEJ5Q29kZXMiLCJyZW5kZXJUeXBlIiwicmVuZGVyIiwiY3JlYXRlUmVhZFN0cmVhbSIsImNodW5rIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHQSxJQUFNQSxjQUFjLEdBQUcsU0FBakJBLGNBQWlCLENBQUNDLE9BQUQsRUFBVUMsUUFBVixFQUFvQkMsZ0JBQXBCLEVBQXlDO0FBQzlELE1BQU1DLElBQUksR0FBR0MsSUFBSSxDQUFDQyxLQUFMLENBQVdMLE9BQVgsQ0FBYjtBQUNBLE1BQU1NLGdCQUFnQixHQUFHTCxRQUFRLENBQUNFLElBQUQsQ0FBakM7O0FBQ0EsTUFBTUkscUJBQXFCLEdBQUdDLGVBQUdDLGlCQUFILENBQXFCUCxnQkFBckIsQ0FBOUI7O0FBRUEsTUFBTVEsd0JBQXdCLEdBQUcsSUFBSUMsd0JBQUosQ0FBaUJMLGdCQUFqQixFQUFtQztBQUNsRU0sSUFBQUEsVUFBVSxFQUFFLElBRHNEO0FBRWxFQyxJQUFBQSxhQUFhLEVBQUU7QUFGbUQsR0FBbkMsQ0FBakM7QUFLQUgsRUFBQUEsd0JBQXdCLENBQ3JCSSxJQURILENBQ1Esb0NBQWFSLGdCQUFiLENBRFIsRUFFR1EsSUFGSCxDQUVRUCxxQkFGUixFQUdHUSxFQUhILENBR00sUUFITixFQUdnQixZQUFNO0FBQ2xCQyxJQUFBQSxPQUFPLENBQUNDLEdBQVIsc0NBQTBDZixnQkFBMUM7QUFDQWMsSUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVksNENBQVo7QUFDRCxHQU5IO0FBT0QsQ0FqQkQ7O2VBbUJlLGtCQUFDQyxpQkFBRCxFQUFvQkMsTUFBcEIsRUFBNEJDLGFBQTVCLEVBQThDO0FBQzNELE1BQU1DLGVBQWUsR0FBRztBQUN0QkMsSUFBQUEsZUFBZSxFQUFFO0FBQ2ZDLE1BQUFBLEtBQUssRUFBRUEsd0JBQU1DLElBQU4sQ0FBVyxJQUFYLEVBQWlCLFFBQWpCLENBRFE7QUFFZkMsTUFBQUEsUUFBUSxFQUFFQztBQUZLLEtBREs7QUFLdEJDLElBQUFBLHVCQUF1QixFQUFFO0FBQ3ZCSixNQUFBQSxLQUFLLEVBQUVBLHdCQUFNQyxJQUFOLENBQVcsSUFBWCxFQUFpQixlQUFqQixDQURnQjtBQUV2QkMsTUFBQUEsUUFBUSxFQUFFRztBQUZhO0FBTEgsR0FBeEI7O0FBRDJELCtCQVdwQlQsTUFYb0I7QUFBQSxNQVdwRGpCLGdCQVhvRDtBQUFBLE1BV2xDMkIsVUFYa0M7O0FBWTNELE1BQU1DLE1BQU0sR0FBR1QsZUFBZSxDQUFDRCxhQUFELENBQWYsQ0FBK0JTLFVBQS9CLENBQWY7QUFFQSxNQUFJN0IsT0FBTyxHQUFHLEVBQWQ7O0FBQ0FRLGlCQUFHdUIsZ0JBQUgsQ0FBb0JiLGlCQUFwQixFQUNHSCxFQURILENBQ00sTUFETixFQUNjLFVBQUNpQixLQUFELEVBQVc7QUFDckJoQyxJQUFBQSxPQUFPLElBQUlnQyxLQUFYO0FBQ0QsR0FISCxFQUlHakIsRUFKSCxDQUlNLEtBSk4sRUFJYSxZQUFNO0FBQ2ZoQixJQUFBQSxjQUFjLENBQUNDLE9BQUQsRUFBVThCLE1BQVYsRUFBa0I1QixnQkFBbEIsQ0FBZDtBQUNELEdBTkg7QUFPRCxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGZzIGZyb20gJ2ZzJztcbmltcG9ydCB7IG1ha2VGaW5hbFN0ciB9IGZyb20gJy4uL3Byb2Nlc3NpbmcvdHJhbnNmb3JtU3RyZWFtcyc7XG5pbXBvcnQgQ3VzdG9tUmVhZGVyIGZyb20gJy4uL3Byb2Nlc3NpbmcvU3RyZWFtUmVhZGVyJztcbmltcG9ydCB0b3RhbCBmcm9tICcuL3RvdGFsVmFsdWVzJztcbmltcG9ydCBkZXRhaWxlZEJ5Q29kZXMgZnJvbSAnLi9kZXRhaWxlZEJ5Q2hhaW5Db2Rlcyc7XG5pbXBvcnQgZGV0YWlsZWRCeVN0b3JlcyBmcm9tICcuL2RldGFpbGVkQnlTdG9yZXMnO1xuXG5cbmNvbnN0IHJlbmRlckFuZFdyaXRlID0gKGNvbnRlbnQsIHJlbmRlckZuLCByZW5kZXJlZERhdGFQYXRoKSA9PiB7XG4gIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKGNvbnRlbnQpO1xuICBjb25zdCByZW5kZXJlZERhdGFDb2xsID0gcmVuZGVyRm4oZGF0YSk7XG4gIGNvbnN0IHJlbmRlcmVkVG9EZXN0aW5hdGlvbiA9IGZzLmNyZWF0ZVdyaXRlU3RyZWFtKHJlbmRlcmVkRGF0YVBhdGgpO1xuXG4gIGNvbnN0IG1ha2VSZWFkYWJsZVJlbmRlcmVkRGF0YSA9IG5ldyBDdXN0b21SZWFkZXIocmVuZGVyZWREYXRhQ29sbCwge1xuICAgIG9iamVjdE1vZGU6IHRydWUsXG4gICAgaGlnaFdhdGVyTWFyazogMSxcbiAgfSk7XG5cbiAgbWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhXG4gICAgLnBpcGUobWFrZUZpbmFsU3RyKHJlbmRlcmVkRGF0YUNvbGwpKVxuICAgIC5waXBlKHJlbmRlcmVkVG9EZXN0aW5hdGlvbilcbiAgICAub24oJ2ZpbmlzaCcsICgpID0+IHtcbiAgICAgIGNvbnNvbGUubG9nKGBSZW5kZXJlZCBkYXRhIGFyZSBzYXZlZCBpbiAke3JlbmRlcmVkRGF0YVBhdGh9XFxuYCk7XG4gICAgICBjb25zb2xlLmxvZygnXFxuLS0tLS0tLSBBbGwgZGF0YSBhcmUgcHJvY2Vzc2VkIC0tLS0tLS1cXG4nKTtcbiAgICB9KTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IChwcm9jZXNzZWREYXRhUGF0aCwgcGFyYW1zLCByZW5kZXJpbmdUeXBlKSA9PiB7XG4gIGNvbnN0IHJlbmRlckZ1bmN0aW9ucyA9IHtcbiAgICBwcm9jZXNzQnlTdG9yZXM6IHtcbiAgICAgIHRvdGFsOiB0b3RhbC5iaW5kKG51bGwsICdick5pY2snKSxcbiAgICAgIGRldGFpbGVkOiBkZXRhaWxlZEJ5U3RvcmVzLFxuICAgIH0sXG4gICAgcHJvY2Vzc0J5Q2hhaW5EcnVnQ29kZXM6IHtcbiAgICAgIHRvdGFsOiB0b3RhbC5iaW5kKG51bGwsICdjaGFpbkRydWdDb2RlJyksXG4gICAgICBkZXRhaWxlZDogZGV0YWlsZWRCeUNvZGVzLFxuICAgIH0sXG4gIH07XG4gIGNvbnN0IFtyZW5kZXJlZERhdGFQYXRoLCByZW5kZXJUeXBlXSA9IHBhcmFtcztcbiAgY29uc3QgcmVuZGVyID0gcmVuZGVyRnVuY3Rpb25zW3JlbmRlcmluZ1R5cGVdW3JlbmRlclR5cGVdO1xuXG4gIGxldCBjb250ZW50ID0gJyc7XG4gIGZzLmNyZWF0ZVJlYWRTdHJlYW0ocHJvY2Vzc2VkRGF0YVBhdGgpXG4gICAgLm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICBjb250ZW50ICs9IGNodW5rO1xuICAgIH0pXG4gICAgLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJBbmRXcml0ZShjb250ZW50LCByZW5kZXIsIHJlbmRlcmVkRGF0YVBhdGgpO1xuICAgIH0pO1xufTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJpbmcvaW5kZXguanMiXSwibmFtZXMiOlsicmVuZGVyRnVuY3Rpb25zIiwicHJvY2Vzc0J5U3RvcmVzIiwidG90YWwiLCJiaW5kIiwiZGV0YWlsZWQiLCJkZXRhaWxlZEJ5U3RvcmVzIiwicHJvY2Vzc0J5Q2hhaW5EcnVnQ29kZXMiLCJkZXRhaWxlZEJ5Q29kZXMiLCJyZW5kZXJBbmRXcml0ZSIsImNvbnRlbnQiLCJyZW5kZXJlZERhdGFQYXRoIiwicmVuZGVyVHlwZSIsImRhdGEiLCJKU09OIiwicGFyc2UiLCJwcm9jZXNzZWRCeSIsInRvdGFsSW5mbyIsInJlbmRlciIsInJlbmRlcmVkRGF0YUNvbGwiLCJyZW5kZXJlZFRvRGVzdGluYXRpb24iLCJmcyIsImNyZWF0ZVdyaXRlU3RyZWFtIiwibWFrZVJlYWRhYmxlUmVuZGVyZWREYXRhIiwiQ3VzdG9tUmVhZGVyIiwib2JqZWN0TW9kZSIsImhpZ2hXYXRlck1hcmsiLCJwaXBlIiwib24iLCJjb25zb2xlIiwibG9nIiwicHJvY2Vzc2VkRGF0YVBhdGgiLCJwYXJhbXMiLCJjcmVhdGVSZWFkU3RyZWFtIiwiY2h1bmsiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7OztBQUVBLElBQU1BLGVBQWUsR0FBRztBQUN0QkMsRUFBQUEsZUFBZSxFQUFFO0FBQ2ZDLElBQUFBLEtBQUssRUFBRUEsd0JBQU1DLElBQU4sQ0FBVyxJQUFYLEVBQWlCLFFBQWpCLENBRFE7QUFFZkMsSUFBQUEsUUFBUSxFQUFFQztBQUZLLEdBREs7QUFLdEJDLEVBQUFBLHVCQUF1QixFQUFFO0FBQ3ZCSixJQUFBQSxLQUFLLEVBQUVBLHdCQUFNQyxJQUFOLENBQVcsSUFBWCxFQUFpQixlQUFqQixDQURnQjtBQUV2QkMsSUFBQUEsUUFBUSxFQUFFRztBQUZhO0FBTEgsQ0FBeEI7O0FBV0EsSUFBTUMsY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixDQUFDQyxPQUFELEVBQVVDLGdCQUFWLEVBQTRCQyxVQUE1QixFQUEyQztBQUNoRSxNQUFNQyxJQUFJLEdBQUdDLElBQUksQ0FBQ0MsS0FBTCxDQUFXTCxPQUFYLENBQWI7QUFEZ0UsTUFFeERNLFdBRndELEdBRTdCSCxJQUY2QixDQUV4REcsV0FGd0Q7QUFBQSxNQUUzQ0MsU0FGMkMsR0FFN0JKLElBRjZCLENBRTNDSSxTQUYyQztBQUdoRSxNQUFNQyxNQUFNLEdBQUdqQixlQUFlLENBQUNlLFdBQUQsQ0FBZixDQUE2QkosVUFBN0IsQ0FBZjtBQUNBLE1BQU1PLGdCQUFnQixHQUFHRCxNQUFNLENBQUNELFNBQUQsQ0FBL0I7O0FBQ0EsTUFBTUcscUJBQXFCLEdBQUdDLGVBQUdDLGlCQUFILENBQXFCWCxnQkFBckIsQ0FBOUI7O0FBRUEsTUFBTVksd0JBQXdCLEdBQUcsSUFBSUMsd0JBQUosQ0FBaUJMLGdCQUFqQixFQUFtQztBQUNsRU0sSUFBQUEsVUFBVSxFQUFFLElBRHNEO0FBRWxFQyxJQUFBQSxhQUFhLEVBQUU7QUFGbUQsR0FBbkMsQ0FBakM7QUFLQUgsRUFBQUEsd0JBQXdCLENBQ3JCSSxJQURILENBQ1Esb0NBQWFSLGdCQUFiLENBRFIsRUFFR1EsSUFGSCxDQUVRUCxxQkFGUixFQUdHUSxFQUhILENBR00sUUFITixFQUdnQixZQUFNO0FBQ2xCQyxJQUFBQSxPQUFPLENBQUNDLEdBQVIsc0NBQTBDbkIsZ0JBQTFDO0FBQ0FrQixJQUFBQSxPQUFPLENBQUNDLEdBQVIsQ0FBWSw0Q0FBWjtBQUNELEdBTkg7QUFPRCxDQW5CRDs7ZUFxQmUsa0JBQUNDLGlCQUFELEVBQW9CQyxNQUFwQixFQUErQjtBQUFBLCtCQUNMQSxNQURLO0FBQUEsTUFDckNyQixnQkFEcUM7QUFBQSxNQUNuQkMsVUFEbUI7O0FBRTVDLE1BQUlGLE9BQU8sR0FBRyxFQUFkOztBQUNBVyxpQkFBR1ksZ0JBQUgsQ0FBb0JGLGlCQUFwQixFQUNHSCxFQURILENBQ00sTUFETixFQUNjLFVBQUNNLEtBQUQsRUFBVztBQUNyQnhCLElBQUFBLE9BQU8sSUFBSXdCLEtBQVg7QUFDRCxHQUhILEVBSUdOLEVBSkgsQ0FJTSxLQUpOLEVBSWEsWUFBTTtBQUNmbkIsSUFBQUEsY0FBYyxDQUFDQyxPQUFELEVBQVVDLGdCQUFWLEVBQTRCQyxVQUE1QixDQUFkO0FBQ0QsR0FOSDtBQU9ELEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHsgbWFrZUZpbmFsU3RyIH0gZnJvbSAnLi4vcHJvY2Vzc2luZy90cmFuc2Zvcm1TdHJlYW1zJztcbmltcG9ydCBDdXN0b21SZWFkZXIgZnJvbSAnLi4vcHJvY2Vzc2luZy9TdHJlYW1SZWFkZXInO1xuaW1wb3J0IHRvdGFsIGZyb20gJy4vdG90YWxWYWx1ZXMnO1xuaW1wb3J0IGRldGFpbGVkQnlDb2RlcyBmcm9tICcuL2RldGFpbGVkQnlDaGFpbkNvZGVzJztcbmltcG9ydCBkZXRhaWxlZEJ5U3RvcmVzIGZyb20gJy4vZGV0YWlsZWRCeVN0b3Jlcyc7XG5cbmNvbnN0IHJlbmRlckZ1bmN0aW9ucyA9IHtcbiAgcHJvY2Vzc0J5U3RvcmVzOiB7XG4gICAgdG90YWw6IHRvdGFsLmJpbmQobnVsbCwgJ2JyTmljaycpLFxuICAgIGRldGFpbGVkOiBkZXRhaWxlZEJ5U3RvcmVzLFxuICB9LFxuICBwcm9jZXNzQnlDaGFpbkRydWdDb2Rlczoge1xuICAgIHRvdGFsOiB0b3RhbC5iaW5kKG51bGwsICdjaGFpbkRydWdDb2RlJyksXG4gICAgZGV0YWlsZWQ6IGRldGFpbGVkQnlDb2RlcyxcbiAgfSxcbn07XG5cbmNvbnN0IHJlbmRlckFuZFdyaXRlID0gKGNvbnRlbnQsIHJlbmRlcmVkRGF0YVBhdGgsIHJlbmRlclR5cGUpID0+IHtcbiAgY29uc3QgZGF0YSA9IEpTT04ucGFyc2UoY29udGVudCk7XG4gIGNvbnN0IHsgcHJvY2Vzc2VkQnksIHRvdGFsSW5mbyB9ID0gZGF0YTtcbiAgY29uc3QgcmVuZGVyID0gcmVuZGVyRnVuY3Rpb25zW3Byb2Nlc3NlZEJ5XVtyZW5kZXJUeXBlXTtcbiAgY29uc3QgcmVuZGVyZWREYXRhQ29sbCA9IHJlbmRlcih0b3RhbEluZm8pO1xuICBjb25zdCByZW5kZXJlZFRvRGVzdGluYXRpb24gPSBmcy5jcmVhdGVXcml0ZVN0cmVhbShyZW5kZXJlZERhdGFQYXRoKTtcblxuICBjb25zdCBtYWtlUmVhZGFibGVSZW5kZXJlZERhdGEgPSBuZXcgQ3VzdG9tUmVhZGVyKHJlbmRlcmVkRGF0YUNvbGwsIHtcbiAgICBvYmplY3RNb2RlOiB0cnVlLFxuICAgIGhpZ2hXYXRlck1hcms6IDEsXG4gIH0pO1xuXG4gIG1ha2VSZWFkYWJsZVJlbmRlcmVkRGF0YVxuICAgIC5waXBlKG1ha2VGaW5hbFN0cihyZW5kZXJlZERhdGFDb2xsKSlcbiAgICAucGlwZShyZW5kZXJlZFRvRGVzdGluYXRpb24pXG4gICAgLm9uKCdmaW5pc2gnLCAoKSA9PiB7XG4gICAgICBjb25zb2xlLmxvZyhgUmVuZGVyZWQgZGF0YSBhcmUgc2F2ZWQgaW4gJHtyZW5kZXJlZERhdGFQYXRofVxcbmApO1xuICAgICAgY29uc29sZS5sb2coJ1xcbi0tLS0tLS0gQWxsIGRhdGEgYXJlIHByb2Nlc3NlZCAtLS0tLS0tXFxuJyk7XG4gICAgfSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCAocHJvY2Vzc2VkRGF0YVBhdGgsIHBhcmFtcykgPT4ge1xuICBjb25zdCBbcmVuZGVyZWREYXRhUGF0aCwgcmVuZGVyVHlwZV0gPSBwYXJhbXM7XG4gIGxldCBjb250ZW50ID0gJyc7XG4gIGZzLmNyZWF0ZVJlYWRTdHJlYW0ocHJvY2Vzc2VkRGF0YVBhdGgpXG4gICAgLm9uKCdkYXRhJywgKGNodW5rKSA9PiB7XG4gICAgICBjb250ZW50ICs9IGNodW5rO1xuICAgIH0pXG4gICAgLm9uKCdlbmQnLCAoKSA9PiB7XG4gICAgICByZW5kZXJBbmRXcml0ZShjb250ZW50LCByZW5kZXJlZERhdGFQYXRoLCByZW5kZXJUeXBlKTtcbiAgICB9KTtcbn07XG4iXX0= |
{ | ||
"name": "proxima_datareader", | ||
"version": "1.5.0", | ||
"version": "1.5.1", | ||
"description": "data reader & selector 4 incoming data files having 1 of following extensions: \n'.mdr', '.mwr', '.mmr', '.mdi', '.mwi', '.mmi'", | ||
@@ -5,0 +5,0 @@ "scripts": { |
@@ -52,8 +52,2 @@ import fs from 'fs'; | ||
const functionNames = _.keys(calculators); | ||
const processingType = selectProcessingType(functionNames); | ||
if (!processingType) { | ||
return; | ||
} | ||
const resFolderFilesList = fs.readdirSync(resFolder); | ||
@@ -67,3 +61,6 @@ const jsonFilesList = resFolderFilesList | ||
const params = getRenderParams(renderTypes, resFolder); | ||
makeRender(selectedDataPath, params, processingType); | ||
if (!params) { | ||
return; | ||
} | ||
makeRender(selectedDataPath, params); | ||
return; | ||
@@ -82,7 +79,11 @@ } | ||
const processedDataPath = getProcessedDataPath(resFolder); | ||
const functionNames = _.keys(calculators); | ||
const processingType = selectProcessingType(functionNames); | ||
if (!processingType) { | ||
return; | ||
} | ||
messages.onGoing(); | ||
await makeDataStream(notEmptySources, searchTypeName, keys, resFolder); | ||
const processData = calculators[processingType]; | ||
const totalInfo = await makeStructuredData(resFolder, processData); | ||
const totalInfo = await makeStructuredData(resFolder, processingType); | ||
if (_.size(totalInfo) === 0) { | ||
@@ -97,3 +98,3 @@ messages.noData(); | ||
} | ||
makeRender(processedDataPath, params, processingType); | ||
makeRender(processedDataPath, params); | ||
}; | ||
@@ -100,0 +101,0 @@ |
@@ -6,2 +6,3 @@ import fs from 'fs'; | ||
import * as streams from './transformStreams'; | ||
import * as calculators from './calculations'; | ||
import CustomReader from './StreamReader'; | ||
@@ -49,6 +50,7 @@ import 'regenerator-runtime'; | ||
export const makeStructuredData = (resFolder, processData) => new Promise((resolve, reject) => { | ||
export const makeStructuredData = (resFolder, processingType) => new Promise((resolve, reject) => { | ||
const totalInfo = {}; | ||
const readable = fs.createReadStream(`${resFolder}/temp_data.txt`); | ||
if (!processData) { | ||
const processDataFn = calculators[processingType]; | ||
if (!processDataFn) { | ||
resolve(totalInfo); | ||
@@ -61,6 +63,7 @@ return; | ||
const [filePath, selectedData] = dataPair.split('---'); | ||
processData(filePath, selectedData, totalInfo); | ||
processDataFn(filePath, selectedData, totalInfo); | ||
}) | ||
.on('end', () => { | ||
resolve(totalInfo); | ||
const data = { processedBy: processingType, totalInfo }; | ||
resolve(data); | ||
}) | ||
@@ -67,0 +70,0 @@ .on('error', reject); |
@@ -8,6 +8,18 @@ import fs from 'fs'; | ||
const renderFunctions = { | ||
processByStores: { | ||
total: total.bind(null, 'brNick'), | ||
detailed: detailedByStores, | ||
}, | ||
processByChainDrugCodes: { | ||
total: total.bind(null, 'chainDrugCode'), | ||
detailed: detailedByCodes, | ||
}, | ||
}; | ||
const renderAndWrite = (content, renderFn, renderedDataPath) => { | ||
const renderAndWrite = (content, renderedDataPath, renderType) => { | ||
const data = JSON.parse(content); | ||
const renderedDataColl = renderFn(data); | ||
const { processedBy, totalInfo } = data; | ||
const render = renderFunctions[processedBy][renderType]; | ||
const renderedDataColl = render(totalInfo); | ||
const renderedToDestination = fs.createWriteStream(renderedDataPath); | ||
@@ -29,16 +41,4 @@ | ||
export default (processedDataPath, params, renderingType) => { | ||
const renderFunctions = { | ||
processByStores: { | ||
total: total.bind(null, 'brNick'), | ||
detailed: detailedByStores, | ||
}, | ||
processByChainDrugCodes: { | ||
total: total.bind(null, 'chainDrugCode'), | ||
detailed: detailedByCodes, | ||
}, | ||
}; | ||
export default (processedDataPath, params) => { | ||
const [renderedDataPath, renderType] = params; | ||
const render = renderFunctions[renderingType][renderType]; | ||
let content = ''; | ||
@@ -50,4 +50,4 @@ fs.createReadStream(processedDataPath) | ||
.on('end', () => { | ||
renderAndWrite(content, render, renderedDataPath); | ||
renderAndWrite(content, renderedDataPath, renderType); | ||
}); | ||
}; |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
177502
1817
0