proxima_datareader
Advanced tools
Comparing version 1.3.9 to 1.3.10
@@ -66,2 +66,6 @@ "use strict"; | ||
var getKeysData = function getKeysData(searchType, keysType, defaults) { | ||
if (searchType === 'none') { | ||
return [[], _defaults.defaultValues.getDefaultDir()]; | ||
} | ||
var _getOrWriteDefaults = (0, _defaults.getOrWriteDefaults)(defaults), | ||
@@ -231,2 +235,2 @@ defaultKeysSource = _getOrWriteDefaults.defaultKeysSource; | ||
exports.writeDownPaths = writeDownPaths; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/askUser.js"],"names":["getSearchParams","searchTypes","searchTypeNames","_","keys","searchTypeNamePos","readlineSync","keyInSelect","console","log","searchTypeName","keysDataType","getKeysData","searchType","keysType","defaults","defaultKeysSource","keysFolder","questionPath","exists","isDirectory","defaultInput","filesList","fs","readdirSync","filesWithCodesList","filter","fileName","includes","length","filePos","fileWithCodes","filePath","path","join","keysContent","readFileSync","encoding","chardet","detect","keysContentDecoded","iconv","decode","trim","split","map","key","isNumber","parseInt","isWrongType","message","updatedSource","getFilesSource","defaultSourcePath","filesSource","getProcessedDataPath","resFolder","processedDataName","question","processedDataPath","getRenderParams","renderTypes","positionNum","renderType","renderedDataName","renderedDataPath","selectProcessOrRender","jsonFilesList","processedDataFilePos","writeDownPaths","pathsList","dirName","type","str","itemsList","pathToFile","defaultName","itemsListName","itemsListPath","promises","writeFile"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport * as iconv from 'iconv-lite';\nimport 'regenerator-runtime';\nimport _ from 'lodash';\nimport chardet from 'chardet';\nimport readlineSync from 'readline-sync';\nimport { getOrWriteDefaults } from './defaults';\n\n\nexport const getSearchParams = (searchTypes) => {\n  const searchTypeNames = _.keys(searchTypes);\n  const searchTypeNamePos = readlineSync.keyInSelect(searchTypeNames, 'Please select type of data search:');\n  if (searchTypeNamePos === -1) {\n    console.log('See you next time )\\n');\n    return null;\n  }\n  const searchTypeName = searchTypeNames[searchTypeNamePos];\n  const keysDataType = searchTypes[searchTypeName];\n\n  return [searchTypeName, keysDataType];\n};\n\nexport const getKeysData = (searchType, keysType, defaults) => {\n  const { defaultKeysSource } = getOrWriteDefaults(defaults);\n  const keysFolder = readlineSync.questionPath(`\\nPlease specify search keys source\n  (default is \"${defaultKeysSource}\"):`, {\n    exists: true,\n    isDirectory: true,\n    defaultInput: defaultKeysSource,\n  });\n  console.log(`${keysFolder}\\n`);\n  const filesList = fs.readdirSync(keysFolder);\n  const filesWithCodesList = filesList.filter(fileName => fileName && fileName.includes('codes'));\n  if (filesWithCodesList.length === 0) {\n    return [null, null];\n  }\n  const filePos = readlineSync.keyInSelect(filesWithCodesList, `A list of files with search codes is above.\n  Please select one or CANCEL (0) to stop processing:`);\n  if (filePos === -1) {\n    return [null, null];\n  }\n  const fileWithCodes = filesWithCodesList[filePos];\n  const filePath = path.join(keysFolder, fileWithCodes);\n  const keysContent = fs.readFileSync(filePath);\n  const encoding = chardet.detect(keysContent);\n  const keysContentDecoded = iconv.decode(keysContent, encoding);\n  const keys = keysContentDecoded.trim().split('\\r\\n').map(key => key.trim());\n  const [key] = keys;\n  const isNumber = parseInt(key, 0) > 0;\n  const isWrongType = !key || (keysType === 'number' && !isNumber) || (keysType === 'string' && isNumber);\n\n  if (isWrongType) {\n    const message = `Your search type is \"${searchType}\". So your keys must be of type \"${keysType}\".\n      Your current keys type is \"${isNumber ? 'number' : 'string'}\"`;\n    console.log(message);\n    return getKeysData(searchType, keysType, defaults);\n  }\n  const updatedSource = { defaultKeysSource: keysFolder };\n  getOrWriteDefaults(defaults, updatedSource);\n  return [keys, keysFolder];\n};\n\nexport const getFilesSource = (defaults) => {\n  const { defaultSourcePath } = getOrWriteDefaults(defaults);\n  const filesSource = readlineSync.questionPath(`\\nPlease specify files source\n  (default is \"${defaultSourcePath}\"): `, {\n    exists: true,\n    isDirectory: true,\n    defaultInput: defaultSourcePath,\n  });\n  console.log(`${filesSource}\\n`);\n  const updatedSource = { defaultSourcePath: filesSource };\n  getOrWriteDefaults(defaults, updatedSource);\n  return filesSource;\n};\n\nexport const getProcessedDataPath = (resFolder) => {\n  const processedDataName = readlineSync\n    .question('Enter a name for processed data file (default name is \"processed\"):', { defaultInput: 'processedData' });\n  const processedDataPath = path.join(resFolder, `${processedDataName}.json`);\n\n  return processedDataPath;\n};\n\nexport const getRenderParams = (renderTypes, resFolder) => {\n  const positionNum = readlineSync.keyInSelect(renderTypes, 'Please select render type:');\n  if (positionNum === -1) {\n    console.log('See you next time )\\n');\n    return null;\n  }\n  const renderType = renderTypes[positionNum];\n  const renderedDataName = readlineSync\n    .question('\\nEnter a name for rendered data file (default name is \"rendered\"):', {\n      defaultInput: 'rendered',\n    });\n  const renderedDataPath = path.join(resFolder, `${renderedDataName}.txt`);\n\n  return [renderedDataPath, renderType];\n};\n\nexport const selectProcessOrRender = (jsonFilesList) => {\n  const processedDataFilePos = readlineSync\n    .keyInSelect(jsonFilesList, `List of processed data files is found.\n    You may select 1 of them for rendering or proceed new processing (press \"0\")`);\n\n  return processedDataFilePos === -1 ? null : jsonFilesList[processedDataFilePos];\n};\n\nexport const writeDownPaths = async (pathsList, dirName, type) => { // eslint-disable-line\n  const str = type === 'zeros' ? 'Zero counts' : 'Empty';\n  const itemsList = type === 'zeros' ? pathsList.join('\\n')\n    : pathsList.map(([pathToFile]) => pathToFile).join('\\n');\n  const defaultName = type === 'zeros' ? 'zerosFilesList' : 'emptyFilesList';\n\n  const itemsListName = readlineSync.question(`\\n${str} files detected.\n    Please type a file name to write down their paths (default is \"${defaultName}\"):`, {\n    defaultInput: defaultName,\n  });\n  const itemsListPath = path.join(dirName, `${itemsListName}.txt`);\n  console.log(`${itemsListPath}\\n`);\n  await fs.promises.writeFile(itemsListPath, itemsList, 'utf-8');\n};\n\n// export const modifyPath = (dateStr, filePath) => {\n//   const currentDate = new Date(dateStr);\n//   const dateThreshold = readlineSync.question('Enter threshold date: ');\n// };\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/askUser.js"],"names":["getSearchParams","searchTypes","searchTypeNames","_","keys","searchTypeNamePos","readlineSync","keyInSelect","console","log","searchTypeName","keysDataType","getKeysData","searchType","keysType","defaults","defaultValues","getDefaultDir","defaultKeysSource","keysFolder","questionPath","exists","isDirectory","defaultInput","filesList","fs","readdirSync","filesWithCodesList","filter","fileName","includes","length","filePos","fileWithCodes","filePath","path","join","keysContent","readFileSync","encoding","chardet","detect","keysContentDecoded","iconv","decode","trim","split","map","key","isNumber","parseInt","isWrongType","message","updatedSource","getFilesSource","defaultSourcePath","filesSource","getProcessedDataPath","resFolder","processedDataName","question","processedDataPath","getRenderParams","renderTypes","positionNum","renderType","renderedDataName","renderedDataPath","selectProcessOrRender","jsonFilesList","processedDataFilePos","writeDownPaths","pathsList","dirName","type","str","itemsList","pathToFile","defaultName","itemsListName","itemsListPath","promises","writeFile"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport * as iconv from 'iconv-lite';\nimport 'regenerator-runtime';\nimport _ from 'lodash';\nimport chardet from 'chardet';\nimport readlineSync from 'readline-sync';\nimport { getOrWriteDefaults, defaultValues } from './defaults';\n\n\nexport const getSearchParams = (searchTypes) => {\n  const searchTypeNames = _.keys(searchTypes);\n  const searchTypeNamePos = readlineSync.keyInSelect(searchTypeNames, 'Please select type of data search:');\n  if (searchTypeNamePos === -1) {\n    console.log('See you next time )\\n');\n    return null;\n  }\n  const searchTypeName = searchTypeNames[searchTypeNamePos];\n  const keysDataType = searchTypes[searchTypeName];\n\n  return [searchTypeName, keysDataType];\n};\n\nexport const getKeysData = (searchType, keysType, defaults) => {\n  if (searchType === 'none') {\n    return [[], defaultValues.getDefaultDir()];\n  }\n  const { defaultKeysSource } = getOrWriteDefaults(defaults);\n  const keysFolder = readlineSync.questionPath(`\\nPlease specify search keys source\n  (default is \"${defaultKeysSource}\"):`, {\n    exists: true,\n    isDirectory: true,\n    defaultInput: defaultKeysSource,\n  });\n  console.log(`${keysFolder}\\n`);\n  const filesList = fs.readdirSync(keysFolder);\n  const filesWithCodesList = filesList.filter(fileName => fileName && fileName.includes('codes'));\n  if (filesWithCodesList.length === 0) {\n    return [null, null];\n  }\n  const filePos = readlineSync.keyInSelect(filesWithCodesList, `A list of files with search codes is above.\n  Please select one or CANCEL (0) to stop processing:`);\n  if (filePos === -1) {\n    return [null, null];\n  }\n  const fileWithCodes = filesWithCodesList[filePos];\n  const filePath = path.join(keysFolder, fileWithCodes);\n  const keysContent = fs.readFileSync(filePath);\n  const encoding = chardet.detect(keysContent);\n  const keysContentDecoded = iconv.decode(keysContent, encoding);\n  const keys = keysContentDecoded.trim().split('\\r\\n').map(key => key.trim());\n  const [key] = keys;\n  const isNumber = parseInt(key, 0) > 0;\n  const isWrongType = !key || (keysType === 'number' && !isNumber) || (keysType === 'string' && isNumber);\n\n  if (isWrongType) {\n    const message = `Your search type is \"${searchType}\". So your keys must be of type \"${keysType}\".\n      Your current keys type is \"${isNumber ? 'number' : 'string'}\"`;\n    console.log(message);\n    return getKeysData(searchType, keysType, defaults);\n  }\n  const updatedSource = { defaultKeysSource: keysFolder };\n  getOrWriteDefaults(defaults, updatedSource);\n  return [keys, keysFolder];\n};\n\nexport const getFilesSource = (defaults) => {\n  const { defaultSourcePath } = getOrWriteDefaults(defaults);\n  const filesSource = readlineSync.questionPath(`\\nPlease specify files source\n  (default is \"${defaultSourcePath}\"): `, {\n    exists: true,\n    isDirectory: true,\n    defaultInput: defaultSourcePath,\n  });\n  console.log(`${filesSource}\\n`);\n  const updatedSource = { defaultSourcePath: filesSource };\n  getOrWriteDefaults(defaults, updatedSource);\n  return filesSource;\n};\n\nexport const getProcessedDataPath = (resFolder) => {\n  const processedDataName = readlineSync\n    .question('Enter a name for processed data file (default name is \"processed\"):', { defaultInput: 'processedData' });\n  const processedDataPath = path.join(resFolder, `${processedDataName}.json`);\n\n  return processedDataPath;\n};\n\nexport const getRenderParams = (renderTypes, resFolder) => {\n  const positionNum = readlineSync.keyInSelect(renderTypes, 'Please select render type:');\n  if (positionNum === -1) {\n    console.log('See you next time )\\n');\n    return null;\n  }\n  const renderType = renderTypes[positionNum];\n  const renderedDataName = readlineSync\n    .question('\\nEnter a name for rendered data file (default name is \"rendered\"):', {\n      defaultInput: 'rendered',\n    });\n  const renderedDataPath = path.join(resFolder, `${renderedDataName}.txt`);\n\n  return [renderedDataPath, renderType];\n};\n\nexport const selectProcessOrRender = (jsonFilesList) => {\n  const processedDataFilePos = readlineSync\n    .keyInSelect(jsonFilesList, `List of processed data files is found.\n    You may select 1 of them for rendering or proceed new processing (press \"0\")`);\n\n  return processedDataFilePos === -1 ? null : jsonFilesList[processedDataFilePos];\n};\n\nexport const writeDownPaths = async (pathsList, dirName, type) => { // eslint-disable-line\n  const str = type === 'zeros' ? 'Zero counts' : 'Empty';\n  const itemsList = type === 'zeros' ? pathsList.join('\\n')\n    : pathsList.map(([pathToFile]) => pathToFile).join('\\n');\n  const defaultName = type === 'zeros' ? 'zerosFilesList' : 'emptyFilesList';\n\n  const itemsListName = readlineSync.question(`\\n${str} files detected.\n    Please type a file name to write down their paths (default is \"${defaultName}\"):`, {\n    defaultInput: defaultName,\n  });\n  const itemsListPath = path.join(dirName, `${itemsListName}.txt`);\n  console.log(`${itemsListPath}\\n`);\n  await fs.promises.writeFile(itemsListPath, itemsList, 'utf-8');\n};\n\n// export const modifyPath = (dateStr, filePath) => {\n//   const currentDate = new Date(dateStr);\n//   const dateThreshold = readlineSync.question('Enter threshold date: ');\n// };\n"]} |
@@ -43,6 +43,11 @@ "use strict"; | ||
var notZero = Number(countIn) !== 0 || Number(countOut) !== 0; | ||
if (searchType === 'none') { | ||
return notZero; | ||
} | ||
var isSameCode = drugCode === strToSearch; | ||
var nameIncludesStr = name.toLowerCase().includes(strToSearch.toLowerCase()); | ||
var isMatched = searchType === 'drugCode' ? isSameCode : nameIncludesStr; | ||
var notZero = Number(countIn) !== 0 || Number(countOut) !== 0; | ||
return isMatched && notZero; | ||
@@ -133,2 +138,2 @@ }).filter(function (_ref) { | ||
exports.makeJsonChunk = makeJsonChunk; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/core.js"],"names":["getMatched","strToSearch","searchType","content","split","filter","line","drugCode","name","countIn","countOut","isSameCode","nameIncludesStr","toLowerCase","includes","isMatched","notZero","Number","lines","length","processData","filePath","totalInfo","reduce","acc","chainDrugCode","remains","priceIn","priceOut","dateStart","dateEnd","existedItemInfo","relatedPathInfo","remainsNum","pcsIn","pcsOut","itemInfo","countInTotal","moneyInTotal","countOutTotal","moneyOutTotal","moneyIn","moneyOut","makeJsonChunk","data","totalSize","count","newCount","finalStr","_","keys","key","value","jsonStr","JSON","stringify"],"mappings":"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","sourcesContent":["import _ from 'lodash';\n\n\nexport const 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\nexport const 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\nexport const makeJsonChunk = (data, totalSize, count) => {\n  const newCount = count + 1;\n  let finalStr = '';\n  const [key] = _.keys(data);\n  const value = data[key];\n  const jsonStr = `\"${key}\":${JSON.stringify(value)}`;\n  switch (newCount) {\n    case 1 && totalSize === newCount:\n      finalStr = `{${jsonStr}}`;\n      break;\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, newCount];\n};\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/core.js"],"names":["getMatched","strToSearch","searchType","content","split","filter","line","drugCode","name","countIn","countOut","notZero","Number","isSameCode","nameIncludesStr","toLowerCase","includes","isMatched","lines","length","processData","filePath","totalInfo","reduce","acc","chainDrugCode","remains","priceIn","priceOut","dateStart","dateEnd","existedItemInfo","relatedPathInfo","remainsNum","pcsIn","pcsOut","itemInfo","countInTotal","moneyInTotal","countOutTotal","moneyOutTotal","moneyIn","moneyOut","makeJsonChunk","data","totalSize","count","newCount","finalStr","_","keys","key","value","jsonStr","JSON","stringify"],"mappings":"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","sourcesContent":["import _ from 'lodash';\n\n\nexport const 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 notZero = Number(countIn) !== 0 || Number(countOut) !== 0;\n  if (searchType === 'none') {\n    return notZero;\n  }\n  const isSameCode = drugCode === strToSearch;\n  const nameIncludesStr = name.toLowerCase().includes(strToSearch.toLowerCase());\n  const isMatched = searchType === 'drugCode' ? isSameCode : nameIncludesStr;\n  return isMatched && notZero;\n}).filter(([, lines]) => lines.length > 0);\n\nexport const 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\nexport const makeJsonChunk = (data, totalSize, count) => {\n  const newCount = count + 1;\n  let finalStr = '';\n  const [key] = _.keys(data);\n  const value = data[key];\n  const jsonStr = `\"${key}\":${JSON.stringify(value)}`;\n  switch (newCount) {\n    case 1 && totalSize === newCount:\n      finalStr = `{${jsonStr}}`;\n      break;\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, newCount];\n};\n"]} |
@@ -23,6 +23,3 @@ "use strict"; | ||
getDefaultDir: function getDefaultDir() { | ||
return _path["default"].join(this.homeDir, '/Documents/Proxima/defaults'); | ||
}, | ||
getDefaultValuesPath: function getDefaultValuesPath() { | ||
var defaultDir = this.getDefaultDir(); | ||
var defaultDir = _path["default"].join(this.homeDir, '/Documents/Proxima/defaults'); | ||
@@ -35,2 +32,7 @@ if (!_fs["default"].existsSync(defaultDir)) { | ||
return defaultDir; | ||
}, | ||
getDefaultValuesPath: function getDefaultValuesPath() { | ||
var defaultDir = this.getDefaultDir(); | ||
var defaultValuesPath = _path["default"].join(defaultDir, 'defaultsForDataSelector.json'); | ||
@@ -47,3 +49,4 @@ | ||
drugCode: 'number', | ||
drugName: 'string' | ||
drugName: 'string', | ||
none: null | ||
}, | ||
@@ -82,2 +85,2 @@ renderTypes: ['total', 'detailed'], | ||
exports.getOrWriteDefaults = getOrWriteDefaults; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZhdWx0cy5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0VmFsdWVzIiwiaG9tZURpciIsInByb2Nlc3MiLCJlbnYiLCJIT01FIiwiSE9NRVBBVEgiLCJVU0VSUFJPRklMRSIsImdldERlZmF1bHREaXIiLCJwYXRoIiwiam9pbiIsImdldERlZmF1bHRWYWx1ZXNQYXRoIiwiZGVmYXVsdERpciIsImZzIiwiZXhpc3RzU3luYyIsIm1rZGlyU3luYyIsInJlY3Vyc2l2ZSIsImRlZmF1bHRWYWx1ZXNQYXRoIiwiZGVmYXVsdFNvdXJjZVBhdGgiLCJkZWZhdWx0S2V5c1NvdXJjZSIsImVuY29kaW5ncyIsInNlYXJjaFR5cGVzIiwiZHJ1Z0NvZGUiLCJkcnVnTmFtZSIsInJlbmRlclR5cGVzIiwiZmlsZVR5cGVzIiwiZ2V0T3JXcml0ZURlZmF1bHRzIiwiZGVmYXVsdHMiLCJkYXRhIiwiY29udGVudCIsInJlYWRGaWxlU3luYyIsInByZXZEYXRhIiwiSlNPTiIsInBhcnNlIiwibmV3RGF0YSIsIndyaXRlRmlsZVN5bmMiLCJzdHJpbmdpZnkiLCJlbmNvZGluZyIsImVycm9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7Ozs7Ozs7Ozs7QUFFTyxJQUFNQSxhQUFhLEdBQUc7QUFDM0JDLEVBQUFBLE9BQU8sRUFBRUMsT0FBTyxDQUFDQyxHQUFSLENBQVlDLElBQVosSUFBb0JGLE9BQU8sQ0FBQ0MsR0FBUixDQUFZRSxRQUFoQyxJQUE0Q0gsT0FBTyxDQUFDQyxHQUFSLENBQVlHLFdBRHRDO0FBRTNCQyxFQUFBQSxhQUYyQiwyQkFFWDtBQUNkLFdBQU9DLGlCQUFLQyxJQUFMLENBQVUsS0FBS1IsT0FBZixFQUF3Qiw2QkFBeEIsQ0FBUDtBQUNELEdBSjBCO0FBSzNCUyxFQUFBQSxvQkFMMkIsa0NBS0o7QUFDckIsUUFBTUMsVUFBVSxHQUFHLEtBQUtKLGFBQUwsRUFBbkI7O0FBQ0EsUUFBSSxDQUFDSyxlQUFHQyxVQUFILENBQWNGLFVBQWQsQ0FBTCxFQUFnQztBQUM5QkMscUJBQUdFLFNBQUgsQ0FBYUgsVUFBYixFQUF5QjtBQUFFSSxRQUFBQSxTQUFTLEVBQUU7QUFBYixPQUF6QjtBQUNEOztBQUNELFFBQU1DLGlCQUFpQixHQUFHUixpQkFBS0MsSUFBTCxDQUFVRSxVQUFWLEVBQXNCLDhCQUF0QixDQUExQjs7QUFDQSxXQUFPSyxpQkFBUDtBQUNELEdBWjBCO0FBYTNCQyxFQUFBQSxpQkFBaUIsRUFBRSxrQkFiUTtBQWFZO0FBQ3ZDQyxFQUFBQSxpQkFBaUIsRUFBRSxrQkFkUTtBQWNZO0FBQ3ZDQyxFQUFBQSxTQUFTLEVBQUUsQ0FBQyxTQUFELEVBQVksT0FBWixFQUFxQixPQUFyQixFQUE4QixRQUE5QixFQUF3QyxLQUF4QyxFQUErQyxNQUEvQyxFQUNULE1BRFMsRUFDRCxPQURDLEVBQ1EsU0FEUixFQUNtQixVQURuQixFQUMrQixRQUQvQixFQUN5QyxRQUR6QyxDQWZnQjtBQWlCM0JDLEVBQUFBLFdBQVcsRUFBRTtBQUNYQyxJQUFBQSxRQUFRLEVBQUUsUUFEQztBQUVYQyxJQUFBQSxRQUFRLEVBQUU7QUFGQyxHQWpCYztBQXFCM0JDLEVBQUFBLFdBQVcsRUFBRSxDQUFDLE9BQUQsRUFBVSxVQUFWLENBckJjO0FBc0IzQkMsRUFBQUEsU0FBUyxFQUFFLENBQUMsTUFBRCxFQUFTLE1BQVQsRUFBaUIsTUFBakIsRUFBeUIsTUFBekIsRUFBaUMsTUFBakMsRUFBeUMsTUFBekM7QUF0QmdCLENBQXRCOzs7QUF5QkEsSUFBTUMsa0JBQWtCLEdBQUcsU0FBckJBLGtCQUFxQixDQUFDQyxRQUFELEVBQVdDLElBQVgsRUFBb0I7QUFDcEQsTUFBTVgsaUJBQWlCLEdBQUdVLFFBQVEsQ0FBQ2hCLG9CQUFULEVBQTFCOztBQUVBLE1BQUk7QUFDRixRQUFNa0IsT0FBTyxHQUFHaEIsZUFBR2lCLFlBQUgsQ0FBZ0JiLGlCQUFoQixFQUFtQyxPQUFuQyxDQUFoQjs7QUFDQSxRQUFNYyxRQUFRLEdBQUdDLElBQUksQ0FBQ0MsS0FBTCxDQUFXSixPQUFYLENBQWpCOztBQUNBLFFBQUlELElBQUosRUFBVTtBQUNSLFVBQU1NLE9BQU8sbUNBQVFILFFBQVIsR0FBcUJILElBQXJCLENBQWI7O0FBQ0FmLHFCQUFHc0IsYUFBSCxDQUFpQmxCLGlCQUFqQixFQUFvQ2UsSUFBSSxDQUFDSSxTQUFMLENBQWVGLE9BQWYsQ0FBcEMsRUFBNkQ7QUFBRUcsUUFBQUEsUUFBUSxFQUFFO0FBQVosT0FBN0Q7QUFDRDs7QUFDRCxXQUFPTixRQUFQO0FBQ0QsR0FSRCxDQVFFLE9BQU9PLEtBQVAsRUFBYztBQUNkekIsbUJBQUdzQixhQUFILENBQWlCbEIsaUJBQWpCLEVBQW9DZSxJQUFJLENBQUNJLFNBQUwsQ0FBZVQsUUFBZixDQUFwQyxFQUE4RDtBQUFFVSxNQUFBQSxRQUFRLEVBQUU7QUFBWixLQUE5RDs7QUFDQSxXQUFPVixRQUFQO0FBQ0Q7QUFDRixDQWZNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgZnMgZnJvbSAnZnMnO1xuXG5leHBvcnQgY29uc3QgZGVmYXVsdFZhbHVlcyA9IHtcbiAgaG9tZURpcjogcHJvY2Vzcy5lbnYuSE9NRSB8fCBwcm9jZXNzLmVudi5IT01FUEFUSCB8fCBwcm9jZXNzLmVudi5VU0VSUFJPRklMRSxcbiAgZ2V0RGVmYXVsdERpcigpIHtcbiAgICByZXR1cm4gcGF0aC5qb2luKHRoaXMuaG9tZURpciwgJy9Eb2N1bWVudHMvUHJveGltYS9kZWZhdWx0cycpO1xuICB9LFxuICBnZXREZWZhdWx0VmFsdWVzUGF0aCgpIHtcbiAgICBjb25zdCBkZWZhdWx0RGlyID0gdGhpcy5nZXREZWZhdWx0RGlyKCk7XG4gICAgaWYgKCFmcy5leGlzdHNTeW5jKGRlZmF1bHREaXIpKSB7XG4gICAgICBmcy5ta2RpclN5bmMoZGVmYXVsdERpciwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG4gICAgfVxuICAgIGNvbnN0IGRlZmF1bHRWYWx1ZXNQYXRoID0gcGF0aC5qb2luKGRlZmF1bHREaXIsICdkZWZhdWx0c0ZvckRhdGFTZWxlY3Rvci5qc29uJyk7XG4gICAgcmV0dXJuIGRlZmF1bHRWYWx1ZXNQYXRoO1xuICB9LFxuICBkZWZhdWx0U291cmNlUGF0aDogJ2RlZmF1bHRfZmFrZV9kaXInLCAvLyAnfi9Eb2N1bWVudHMvUHJveGltYS9LeWl2ZmFybS9pbmNvbWluZy8nLFxuICBkZWZhdWx0S2V5c1NvdXJjZTogJ2RlZmF1bHRfZmFrZV9kaXInLCAvLyAnfi9Eb2N1bWVudHMvUHJveGltYS9LeWl2ZmFybS9jb2Rlcy50eHQnLFxuICBlbmNvZGluZ3M6IFsnd2luMTI1MScsICd1dGYtOCcsICdhc2NpaScsICdiYXNlNjQnLCAnaGV4JywgJ3V0ZjgnLFxuICAgICd1Y3MyJywgJ3Vjcy0yJywgJ3V0ZjE2bGUnLCAndXRmLTE2bGUnLCAnbGF0aW4xJywgJ2JpbmFyeSddLFxuICBzZWFyY2hUeXBlczoge1xuICAgIGRydWdDb2RlOiAnbnVtYmVyJyxcbiAgICBkcnVnTmFtZTogJ3N0cmluZycsXG4gIH0sXG4gIHJlbmRlclR5cGVzOiBbJ3RvdGFsJywgJ2RldGFpbGVkJ10sXG4gIGZpbGVUeXBlczogWycubWRyJywgJy5td3InLCAnLm1tcicsICcubWRpJywgJy5td2knLCAnLm1taSddLFxufTtcblxuZXhwb3J0IGNvbnN0IGdldE9yV3JpdGVEZWZhdWx0cyA9IChkZWZhdWx0cywgZGF0YSkgPT4ge1xuICBjb25zdCBkZWZhdWx0VmFsdWVzUGF0aCA9IGRlZmF1bHRzLmdldERlZmF1bHRWYWx1ZXNQYXRoKCk7XG5cbiAgdHJ5IHtcbiAgICBjb25zdCBjb250ZW50ID0gZnMucmVhZEZpbGVTeW5jKGRlZmF1bHRWYWx1ZXNQYXRoLCAndXRmLTgnKTtcbiAgICBjb25zdCBwcmV2RGF0YSA9IEpTT04ucGFyc2UoY29udGVudCk7XG4gICAgaWYgKGRhdGEpIHtcbiAgICAgIGNvbnN0IG5ld0RhdGEgPSB7IC4uLnByZXZEYXRhLCAuLi5kYXRhIH07XG4gICAgICBmcy53cml0ZUZpbGVTeW5jKGRlZmF1bHRWYWx1ZXNQYXRoLCBKU09OLnN0cmluZ2lmeShuZXdEYXRhKSwgeyBlbmNvZGluZzogJ3V0Zi04JyB9KTtcbiAgICB9XG4gICAgcmV0dXJuIHByZXZEYXRhO1xuICB9IGNhdGNoIChlcnJvcikge1xuICAgIGZzLndyaXRlRmlsZVN5bmMoZGVmYXVsdFZhbHVlc1BhdGgsIEpTT04uc3RyaW5naWZ5KGRlZmF1bHRzKSwgeyBlbmNvZGluZzogJ3V0Zi04JyB9KTtcbiAgICByZXR1cm4gZGVmYXVsdHM7XG4gIH1cbn07XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZhdWx0cy5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0VmFsdWVzIiwiaG9tZURpciIsInByb2Nlc3MiLCJlbnYiLCJIT01FIiwiSE9NRVBBVEgiLCJVU0VSUFJPRklMRSIsImdldERlZmF1bHREaXIiLCJkZWZhdWx0RGlyIiwicGF0aCIsImpvaW4iLCJmcyIsImV4aXN0c1N5bmMiLCJta2RpclN5bmMiLCJyZWN1cnNpdmUiLCJnZXREZWZhdWx0VmFsdWVzUGF0aCIsImRlZmF1bHRWYWx1ZXNQYXRoIiwiZGVmYXVsdFNvdXJjZVBhdGgiLCJkZWZhdWx0S2V5c1NvdXJjZSIsImVuY29kaW5ncyIsInNlYXJjaFR5cGVzIiwiZHJ1Z0NvZGUiLCJkcnVnTmFtZSIsIm5vbmUiLCJyZW5kZXJUeXBlcyIsImZpbGVUeXBlcyIsImdldE9yV3JpdGVEZWZhdWx0cyIsImRlZmF1bHRzIiwiZGF0YSIsImNvbnRlbnQiLCJyZWFkRmlsZVN5bmMiLCJwcmV2RGF0YSIsIkpTT04iLCJwYXJzZSIsIm5ld0RhdGEiLCJ3cml0ZUZpbGVTeW5jIiwic3RyaW5naWZ5IiwiZW5jb2RpbmciLCJlcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOzs7Ozs7Ozs7O0FBRU8sSUFBTUEsYUFBYSxHQUFHO0FBQzNCQyxFQUFBQSxPQUFPLEVBQUVDLE9BQU8sQ0FBQ0MsR0FBUixDQUFZQyxJQUFaLElBQW9CRixPQUFPLENBQUNDLEdBQVIsQ0FBWUUsUUFBaEMsSUFBNENILE9BQU8sQ0FBQ0MsR0FBUixDQUFZRyxXQUR0QztBQUUzQkMsRUFBQUEsYUFGMkIsMkJBRVg7QUFDZCxRQUFNQyxVQUFVLEdBQUdDLGlCQUFLQyxJQUFMLENBQVUsS0FBS1QsT0FBZixFQUF3Qiw2QkFBeEIsQ0FBbkI7O0FBQ0EsUUFBSSxDQUFDVSxlQUFHQyxVQUFILENBQWNKLFVBQWQsQ0FBTCxFQUFnQztBQUM5QkcscUJBQUdFLFNBQUgsQ0FBYUwsVUFBYixFQUF5QjtBQUFFTSxRQUFBQSxTQUFTLEVBQUU7QUFBYixPQUF6QjtBQUNEOztBQUNELFdBQU9OLFVBQVA7QUFDRCxHQVIwQjtBQVMzQk8sRUFBQUEsb0JBVDJCLGtDQVNKO0FBQ3JCLFFBQU1QLFVBQVUsR0FBRyxLQUFLRCxhQUFMLEVBQW5COztBQUNBLFFBQU1TLGlCQUFpQixHQUFHUCxpQkFBS0MsSUFBTCxDQUFVRixVQUFWLEVBQXNCLDhCQUF0QixDQUExQjs7QUFDQSxXQUFPUSxpQkFBUDtBQUNELEdBYjBCO0FBYzNCQyxFQUFBQSxpQkFBaUIsRUFBRSxrQkFkUTtBQWNZO0FBQ3ZDQyxFQUFBQSxpQkFBaUIsRUFBRSxrQkFmUTtBQWVZO0FBQ3ZDQyxFQUFBQSxTQUFTLEVBQUUsQ0FBQyxTQUFELEVBQVksT0FBWixFQUFxQixPQUFyQixFQUE4QixRQUE5QixFQUF3QyxLQUF4QyxFQUErQyxNQUEvQyxFQUNULE1BRFMsRUFDRCxPQURDLEVBQ1EsU0FEUixFQUNtQixVQURuQixFQUMrQixRQUQvQixFQUN5QyxRQUR6QyxDQWhCZ0I7QUFrQjNCQyxFQUFBQSxXQUFXLEVBQUU7QUFDWEMsSUFBQUEsUUFBUSxFQUFFLFFBREM7QUFFWEMsSUFBQUEsUUFBUSxFQUFFLFFBRkM7QUFHWEMsSUFBQUEsSUFBSSxFQUFFO0FBSEssR0FsQmM7QUF1QjNCQyxFQUFBQSxXQUFXLEVBQUUsQ0FBQyxPQUFELEVBQVUsVUFBVixDQXZCYztBQXdCM0JDLEVBQUFBLFNBQVMsRUFBRSxDQUFDLE1BQUQsRUFBUyxNQUFULEVBQWlCLE1BQWpCLEVBQXlCLE1BQXpCLEVBQWlDLE1BQWpDLEVBQXlDLE1BQXpDO0FBeEJnQixDQUF0Qjs7O0FBMkJBLElBQU1DLGtCQUFrQixHQUFHLFNBQXJCQSxrQkFBcUIsQ0FBQ0MsUUFBRCxFQUFXQyxJQUFYLEVBQW9CO0FBQ3BELE1BQU1aLGlCQUFpQixHQUFHVyxRQUFRLENBQUNaLG9CQUFULEVBQTFCOztBQUVBLE1BQUk7QUFDRixRQUFNYyxPQUFPLEdBQUdsQixlQUFHbUIsWUFBSCxDQUFnQmQsaUJBQWhCLEVBQW1DLE9BQW5DLENBQWhCOztBQUNBLFFBQU1lLFFBQVEsR0FBR0MsSUFBSSxDQUFDQyxLQUFMLENBQVdKLE9BQVgsQ0FBakI7O0FBQ0EsUUFBSUQsSUFBSixFQUFVO0FBQ1IsVUFBTU0sT0FBTyxtQ0FBUUgsUUFBUixHQUFxQkgsSUFBckIsQ0FBYjs7QUFDQWpCLHFCQUFHd0IsYUFBSCxDQUFpQm5CLGlCQUFqQixFQUFvQ2dCLElBQUksQ0FBQ0ksU0FBTCxDQUFlRixPQUFmLENBQXBDLEVBQTZEO0FBQUVHLFFBQUFBLFFBQVEsRUFBRTtBQUFaLE9BQTdEO0FBQ0Q7O0FBQ0QsV0FBT04sUUFBUDtBQUNELEdBUkQsQ0FRRSxPQUFPTyxLQUFQLEVBQWM7QUFDZDNCLG1CQUFHd0IsYUFBSCxDQUFpQm5CLGlCQUFqQixFQUFvQ2dCLElBQUksQ0FBQ0ksU0FBTCxDQUFlVCxRQUFmLENBQXBDLEVBQThEO0FBQUVVLE1BQUFBLFFBQVEsRUFBRTtBQUFaLEtBQTlEOztBQUNBLFdBQU9WLFFBQVA7QUFDRDtBQUNGLENBZk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCBmcyBmcm9tICdmcyc7XG5cbmV4cG9ydCBjb25zdCBkZWZhdWx0VmFsdWVzID0ge1xuICBob21lRGlyOiBwcm9jZXNzLmVudi5IT01FIHx8IHByb2Nlc3MuZW52LkhPTUVQQVRIIHx8IHByb2Nlc3MuZW52LlVTRVJQUk9GSUxFLFxuICBnZXREZWZhdWx0RGlyKCkge1xuICAgIGNvbnN0IGRlZmF1bHREaXIgPSBwYXRoLmpvaW4odGhpcy5ob21lRGlyLCAnL0RvY3VtZW50cy9Qcm94aW1hL2RlZmF1bHRzJyk7XG4gICAgaWYgKCFmcy5leGlzdHNTeW5jKGRlZmF1bHREaXIpKSB7XG4gICAgICBmcy5ta2RpclN5bmMoZGVmYXVsdERpciwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG4gICAgfVxuICAgIHJldHVybiBkZWZhdWx0RGlyO1xuICB9LFxuICBnZXREZWZhdWx0VmFsdWVzUGF0aCgpIHtcbiAgICBjb25zdCBkZWZhdWx0RGlyID0gdGhpcy5nZXREZWZhdWx0RGlyKCk7XG4gICAgY29uc3QgZGVmYXVsdFZhbHVlc1BhdGggPSBwYXRoLmpvaW4oZGVmYXVsdERpciwgJ2RlZmF1bHRzRm9yRGF0YVNlbGVjdG9yLmpzb24nKTtcbiAgICByZXR1cm4gZGVmYXVsdFZhbHVlc1BhdGg7XG4gIH0sXG4gIGRlZmF1bHRTb3VyY2VQYXRoOiAnZGVmYXVsdF9mYWtlX2RpcicsIC8vICd+L0RvY3VtZW50cy9Qcm94aW1hL0t5aXZmYXJtL2luY29taW5nLycsXG4gIGRlZmF1bHRLZXlzU291cmNlOiAnZGVmYXVsdF9mYWtlX2RpcicsIC8vICd+L0RvY3VtZW50cy9Qcm94aW1hL0t5aXZmYXJtL2NvZGVzLnR4dCcsXG4gIGVuY29kaW5nczogWyd3aW4xMjUxJywgJ3V0Zi04JywgJ2FzY2lpJywgJ2Jhc2U2NCcsICdoZXgnLCAndXRmOCcsXG4gICAgJ3VjczInLCAndWNzLTInLCAndXRmMTZsZScsICd1dGYtMTZsZScsICdsYXRpbjEnLCAnYmluYXJ5J10sXG4gIHNlYXJjaFR5cGVzOiB7XG4gICAgZHJ1Z0NvZGU6ICdudW1iZXInLFxuICAgIGRydWdOYW1lOiAnc3RyaW5nJyxcbiAgICBub25lOiBudWxsLFxuICB9LFxuICByZW5kZXJUeXBlczogWyd0b3RhbCcsICdkZXRhaWxlZCddLFxuICBmaWxlVHlwZXM6IFsnLm1kcicsICcubXdyJywgJy5tbXInLCAnLm1kaScsICcubXdpJywgJy5tbWknXSxcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRPcldyaXRlRGVmYXVsdHMgPSAoZGVmYXVsdHMsIGRhdGEpID0+IHtcbiAgY29uc3QgZGVmYXVsdFZhbHVlc1BhdGggPSBkZWZhdWx0cy5nZXREZWZhdWx0VmFsdWVzUGF0aCgpO1xuXG4gIHRyeSB7XG4gICAgY29uc3QgY29udGVudCA9IGZzLnJlYWRGaWxlU3luYyhkZWZhdWx0VmFsdWVzUGF0aCwgJ3V0Zi04Jyk7XG4gICAgY29uc3QgcHJldkRhdGEgPSBKU09OLnBhcnNlKGNvbnRlbnQpO1xuICAgIGlmIChkYXRhKSB7XG4gICAgICBjb25zdCBuZXdEYXRhID0geyAuLi5wcmV2RGF0YSwgLi4uZGF0YSB9O1xuICAgICAgZnMud3JpdGVGaWxlU3luYyhkZWZhdWx0VmFsdWVzUGF0aCwgSlNPTi5zdHJpbmdpZnkobmV3RGF0YSksIHsgZW5jb2Rpbmc6ICd1dGYtOCcgfSk7XG4gICAgfVxuICAgIHJldHVybiBwcmV2RGF0YTtcbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBmcy53cml0ZUZpbGVTeW5jKGRlZmF1bHRWYWx1ZXNQYXRoLCBKU09OLnN0cmluZ2lmeShkZWZhdWx0cyksIHsgZW5jb2Rpbmc6ICd1dGYtOCcgfSk7XG4gICAgcmV0dXJuIGRlZmF1bHRzO1xuICB9XG59O1xuIl19 |
@@ -44,3 +44,3 @@ "use strict"; | ||
var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { | ||
var searchTypes, renderTypes, fileTypes, searchParams, _searchParams, searchTypeName, keysDataType, _getKeysData, _getKeysData2, keys, keysFolder, newPath, resFolder, resFolderFilesList, jsonFilesList, fileToRender, selectedDataPath, filesSource, paths, _$partition, _$partition2, emptySources, notEmptySources, processedDataPath, dataStream, totalInfo; | ||
var searchTypes, renderTypes, fileTypes, searchParams, _searchParams, searchTypeName, keysDataType, _getKeysData, _getKeysData2, keys, keysFolder, resFolder, resFolderFilesList, jsonFilesList, fileToRender, selectedDataPath, filesSource, paths, _$partition, _$partition2, emptySources, notEmptySources, processedDataPath, dataStream, totalInfo; | ||
@@ -74,6 +74,11 @@ return regeneratorRuntime.wrap(function _callee$(_context) { | ||
case 9: | ||
newPath = _path["default"].join(keysFolder, 'processedData'); | ||
resFolder = _fs["default"].existsSync(newPath) ? newPath : _fs["default"].mkdirSync(newPath, { | ||
recursive: true | ||
}); | ||
resFolder = _path["default"].join(keysFolder, 'processedData'); | ||
if (!_fs["default"].existsSync(resFolder)) { | ||
_fs["default"].mkdirSync(resFolder, { | ||
recursive: true | ||
}); | ||
} | ||
console.log(resFolder); | ||
resFolderFilesList = _fs["default"].readdirSync(resFolder); | ||
@@ -85,3 +90,3 @@ jsonFilesList = resFolderFilesList.filter(function (fileName) { | ||
if (!(jsonFilesList.length > 0)) { | ||
_context.next = 19; | ||
_context.next = 20; | ||
break; | ||
@@ -93,3 +98,3 @@ } | ||
if (!fileToRender) { | ||
_context.next = 19; | ||
_context.next = 20; | ||
break; | ||
@@ -102,3 +107,3 @@ } | ||
case 19: | ||
case 20: | ||
filesSource = (0, _askUser.getFilesSource)(_defaults.defaultValues); | ||
@@ -111,10 +116,10 @@ paths = (0, _processors.makePaths)(filesSource, fileTypes); | ||
if (!(emptySources.length > 0)) { | ||
_context.next = 25; | ||
_context.next = 26; | ||
break; | ||
} | ||
_context.next = 25; | ||
_context.next = 26; | ||
return (0, _askUser.writeDownPaths)(emptySources, resFolder, 'empty'); | ||
case 25: | ||
case 26: | ||
// const encodingPos = readlineSync.keyInSelect(encodings, 'Please select files encoding'); | ||
@@ -125,10 +130,10 @@ // const [encoding] = encodings; | ||
dataStream = (0, _processors.makeDataStream)(notEmptySources, searchTypeName, keys); | ||
_context.next = 30; | ||
_context.next = 31; | ||
return (0, _processors.makeStructuredData)(dataStream); | ||
case 30: | ||
case 31: | ||
totalInfo = _context.sent; | ||
if (!(_lodash["default"].size(totalInfo) === 0)) { | ||
_context.next = 34; | ||
_context.next = 35; | ||
break; | ||
@@ -140,10 +145,10 @@ } | ||
case 34: | ||
_context.next = 36; | ||
case 35: | ||
_context.next = 37; | ||
return (0, _processors.writeToJson)(totalInfo, processedDataPath); | ||
case 36: | ||
case 37: | ||
(0, _renderers["default"])(processedDataPath, renderTypes, resFolder); | ||
case 37: | ||
case 38: | ||
case "end": | ||
@@ -180,2 +185,2 @@ return _context.stop(); | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJhcHAiLCJzZWFyY2hUeXBlcyIsImRlZmF1bHRWYWx1ZXMiLCJyZW5kZXJUeXBlcyIsImZpbGVUeXBlcyIsInNlYXJjaFBhcmFtcyIsInNlYXJjaFR5cGVOYW1lIiwia2V5c0RhdGFUeXBlIiwia2V5cyIsImtleXNGb2xkZXIiLCJjb25zb2xlIiwibG9nIiwibmV3UGF0aCIsInBhdGgiLCJqb2luIiwicmVzRm9sZGVyIiwiZnMiLCJleGlzdHNTeW5jIiwibWtkaXJTeW5jIiwicmVjdXJzaXZlIiwicmVzRm9sZGVyRmlsZXNMaXN0IiwicmVhZGRpclN5bmMiLCJqc29uRmlsZXNMaXN0IiwiZmlsdGVyIiwiZmlsZU5hbWUiLCJleHRuYW1lIiwibGVuZ3RoIiwiZmlsZVRvUmVuZGVyIiwic2VsZWN0ZWREYXRhUGF0aCIsImZpbGVzU291cmNlIiwicGF0aHMiLCJfIiwicGFydGl0aW9uIiwicGF0aFRvRmlsZSIsImlzQXJyYXkiLCJlbXB0eVNvdXJjZXMiLCJub3RFbXB0eVNvdXJjZXMiLCJwcm9jZXNzZWREYXRhUGF0aCIsImRhdGFTdHJlYW0iLCJ0b3RhbEluZm8iLCJzaXplIiwiZXJyIiwiRXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFDQTs7QUFRQTs7QUFNQTs7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHQSxJQUFNQSxHQUFHO0FBQUEscUVBQUc7QUFBQTs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUdSQyxZQUFBQSxXQUhRLEdBTU5DLHVCQU5NLENBR1JELFdBSFEsRUFJUkUsV0FKUSxHQU1ORCx1QkFOTSxDQUlSQyxXQUpRLEVBS1JDLFNBTFEsR0FNTkYsdUJBTk0sQ0FLUkUsU0FMUTtBQVFKQyxZQUFBQSxZQVJJLEdBUVcsOEJBQWdCSixXQUFoQixDQVJYOztBQUFBLGdCQVNMSSxZQVRLO0FBQUE7QUFBQTtBQUFBOztBQUFBOztBQUFBO0FBQUEsMkNB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QSxVQUFBQSxHQUFHLFdBQUgsQ0FBWSxVQUFDeUMsR0FBRCxFQUFTO0FBQ25CL0IsWUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVk4QixHQUFaO0FBQ0Esa0JBQU0sSUFBSUMsS0FBSixDQUFVRCxHQUFWLENBQU47QUFDRCxXQUhEOztBQURhO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgJ3JlZ2VuZXJhdG9yLXJ1bnRpbWUnO1xuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7XG4gIGdldFNlYXJjaFBhcmFtcyxcbiAgZ2V0S2V5c0RhdGEsXG4gIGdldEZpbGVzU291cmNlLFxuICBnZXRQcm9jZXNzZWREYXRhUGF0aCxcbiAgc2VsZWN0UHJvY2Vzc09yUmVuZGVyLFxuICB3cml0ZURvd25QYXRocyxcbn0gZnJvbSAnLi9hc2tVc2VyJztcbmltcG9ydCB7XG4gIG1ha2VQYXRocyxcbiAgbWFrZURhdGFTdHJlYW0sXG4gIG1ha2VTdHJ1Y3R1cmVkRGF0YSxcbiAgd3JpdGVUb0pzb24sXG59IGZyb20gJy4vcHJvY2Vzc29ycyc7XG5pbXBvcnQgbWFrZVJlbmRlciBmcm9tICcuL3JlbmRlcmVycyc7XG5pbXBvcnQgeyBkZWZhdWx0VmFsdWVzIH0gZnJvbSAnLi9kZWZhdWx0cyc7XG5cblxuY29uc3QgYXBwID0gYXN5bmMgKCkgPT4ge1xuICBjb25zdCB7XG4gICAgLy8gZW5jb2RpbmdzLFxuICAgIHNlYXJjaFR5cGVzLFxuICAgIHJlbmRlclR5cGVzLFxuICAgIGZpbGVUeXBlcyxcbiAgfSA9IGRlZmF1bHRWYWx1ZXM7XG5cbiAgY29uc3Qgc2VhcmNoUGFyYW1zID0gZ2V0U2VhcmNoUGFyYW1zKHNlYXJjaFR5cGVzKTtcbiAgaWYgKCFzZWFyY2hQYXJhbXMpIHtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3QgW3NlYXJjaFR5cGVOYW1lLCBrZXlzRGF0YVR5cGVdID0gc2VhcmNoUGFyYW1zO1xuICBjb25zdCBba2V5cywga2V5c0ZvbGRlcl0gPSBnZXRLZXlzRGF0YShzZWFyY2hUeXBlTmFtZSwga2V5c0RhdGFUeXBlLCBkZWZhdWx0VmFsdWVzKTtcbiAgaWYgKCFrZXlzKSB7XG4gICAgY29uc29sZS5sb2coJ1RoZXJlIGFyZSBubyBmaWxlcyB3aXRoIHNlYXJjaCBjb2Rlcy4gUGxlYXNlIHNlbGVjdCBvciBtYWtlIG9uZSBhbmQgdHJ5IGFnYWluJyk7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnN0IG5ld1BhdGggPSBwYXRoLmpvaW4oa2V5c0ZvbGRlciwgJ3Byb2Nlc3NlZERhdGEnKTtcbiAgY29uc3QgcmVzRm9sZGVyID0gZnMuZXhpc3RzU3luYyhuZXdQYXRoKSA/IG5ld1BhdGggOiBmcy5ta2RpclN5bmMobmV3UGF0aCwgeyByZWN1cnNpdmU6IHRydWUgfSk7XG5cbiAgY29uc3QgcmVzRm9sZGVyRmlsZXNMaXN0ID0gZnMucmVhZGRpclN5bmMocmVzRm9sZGVyKTtcbiAgY29uc3QganNvbkZpbGVzTGlzdCA9IHJlc0ZvbGRlckZpbGVzTGlzdFxuICAgIC5maWx0ZXIoZmlsZU5hbWUgPT4gZmlsZU5hbWUgJiYgcGF0aC5leHRuYW1lKGZpbGVOYW1lKSA9PT0gJy5qc29uJyk7XG4gIGlmIChqc29uRmlsZXNMaXN0Lmxlbmd0aCA+IDApIHtcbiAgICBjb25zdCBmaWxlVG9SZW5kZXIgPSBzZWxlY3RQcm9jZXNzT3JSZW5kZXIoanNvbkZpbGVzTGlzdCk7XG4gICAgaWYgKGZpbGVUb1JlbmRlcikge1xuICAgICAgY29uc3Qgc2VsZWN0ZWREYXRhUGF0aCA9IHBhdGguam9pbihyZXNGb2xkZXIsIGZpbGVUb1JlbmRlcik7XG4gICAgICBtYWtlUmVuZGVyKHNlbGVjdGVkRGF0YVBhdGgsIHJlbmRlclR5cGVzLCByZXNGb2xkZXIpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGZpbGVzU291cmNlID0gZ2V0RmlsZXNTb3VyY2UoZGVmYXVsdFZhbHVlcyk7XG4gIGNvbnN0IHBhdGhzID0gbWFrZVBhdGhzKGZpbGVzU291cmNlLCBmaWxlVHlwZXMpO1xuICBjb25zdCBbZW1wdHlTb3VyY2VzLCBub3RFbXB0eVNvdXJjZXNdID0gXy5wYXJ0aXRpb24ocGF0aHMsIHBhdGhUb0ZpbGUgPT4gXy5pc0FycmF5KHBhdGhUb0ZpbGUpKTtcbiAgaWYgKGVtcHR5U291cmNlcy5sZW5ndGggPiAwKSB7XG4gICAgYXdhaXQgd3JpdGVEb3duUGF0aHMoZW1wdHlTb3VyY2VzLCByZXNGb2xkZXIsICdlbXB0eScpO1xuICB9XG4gIC8vIGNvbnN0IGVuY29kaW5nUG9zID0gcmVhZGxpbmVTeW5jLmtleUluU2VsZWN0KGVuY29kaW5ncywgJ1BsZWFzZSBzZWxlY3QgZmlsZXMgZW5jb2RpbmcnKTtcbiAgLy8gY29uc3QgW2VuY29kaW5nXSA9IGVuY29kaW5ncztcbiAgY29uc3QgcHJvY2Vzc2VkRGF0YVBhdGggPSBnZXRQcm9jZXNzZWREYXRhUGF0aChyZXNGb2xkZXIpO1xuXG4gIGNvbnNvbGUubG9nKCdcXG5EYXRhLXByb2Nlc3NpbmcgaXMgb25nb2luZy4uLlxcbicpO1xuXG4gIGNvbnN0IGRhdGFTdHJlYW0gPSBtYWtlRGF0YVN0cmVhbShub3RFbXB0eVNvdXJjZXMsIHNlYXJjaFR5cGVOYW1lLCBrZXlzKTtcbiAgY29uc3QgdG90YWxJbmZvID0gYXdhaXQgbWFrZVN0cnVjdHVyZWREYXRhKGRhdGFTdHJlYW0pO1xuICBpZiAoXy5zaXplKHRvdGFsSW5mbykgPT09IDApIHtcbiAgICBjb25zb2xlLmxvZygnTm8gZGF0YSBpcyBmb3VuZFxcbicpO1xuICAgIHJldHVybjtcbiAgfVxuICBhd2FpdCB3cml0ZVRvSnNvbih0b3RhbEluZm8sIHByb2Nlc3NlZERhdGFQYXRoKTtcbiAgbWFrZVJlbmRlcihwcm9jZXNzZWREYXRhUGF0aCwgcmVuZGVyVHlwZXMsIHJlc0ZvbGRlcik7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBhc3luYyAoKSA9PiB7XG4gIGFwcCgpLmNhdGNoKChlcnIpID0+IHtcbiAgICBjb25zb2xlLmxvZyhlcnIpO1xuICAgIHRocm93IG5ldyBFcnJvcihlcnIpO1xuICB9KTtcbn07XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJhcHAiLCJzZWFyY2hUeXBlcyIsImRlZmF1bHRWYWx1ZXMiLCJyZW5kZXJUeXBlcyIsImZpbGVUeXBlcyIsInNlYXJjaFBhcmFtcyIsInNlYXJjaFR5cGVOYW1lIiwia2V5c0RhdGFUeXBlIiwia2V5cyIsImtleXNGb2xkZXIiLCJjb25zb2xlIiwibG9nIiwicmVzRm9sZGVyIiwicGF0aCIsImpvaW4iLCJmcyIsImV4aXN0c1N5bmMiLCJta2RpclN5bmMiLCJyZWN1cnNpdmUiLCJyZXNGb2xkZXJGaWxlc0xpc3QiLCJyZWFkZGlyU3luYyIsImpzb25GaWxlc0xpc3QiLCJmaWx0ZXIiLCJmaWxlTmFtZSIsImV4dG5hbWUiLCJsZW5ndGgiLCJmaWxlVG9SZW5kZXIiLCJzZWxlY3RlZERhdGFQYXRoIiwiZmlsZXNTb3VyY2UiLCJwYXRocyIsIl8iLCJwYXJ0aXRpb24iLCJwYXRoVG9GaWxlIiwiaXNBcnJheSIsImVtcHR5U291cmNlcyIsIm5vdEVtcHR5U291cmNlcyIsInByb2Nlc3NlZERhdGFQYXRoIiwiZGF0YVN0cmVhbSIsInRvdGFsSW5mbyIsInNpemUiLCJlcnIiLCJFcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQVFBOztBQU1BOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUdBLElBQU1BLEdBQUc7QUFBQSxxRUFBRztBQUFBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBR1JDLFlBQUFBLFdBSFEsR0FNTkMsdUJBTk0sQ0FHUkQsV0FIUSxFQUlSRSxXQUpRLEdBTU5ELHVCQU5NLENBSVJDLFdBSlEsRUFLUkMsU0FMUSxHQU1ORix1QkFOTSxDQUtSRSxTQUxRO0FBUUpDLFlBQUFBLFlBUkksR0FRVyw4QkFBZ0JKLFdBQWhCLENBUlg7O0FBQUEsZ0JBU0xJLFlBVEs7QUFBQTtBQUFBO0FBQUE7O0FBQUE7O0FBQUE7QUFBQSwyQ0FZNkJBLFlBWjdC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QTtBQUFBO0FBQUE7QUFBQTtBQUNiQSxVQUFBQSxHQUFHLFdBQUgsQ0FBWSxVQUFDd0MsR0FBRCxFQUFTO0FBQ25COUIsWUFBQUEsT0FBTyxDQUFDQyxHQUFSLENBQVk2QixHQUFaO0FBQ0Esa0JBQU0sSUFBSUMsS0FBSixDQUFVRCxHQUFWLENBQU47QUFDRCxXQUhEOztBQURhO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZnMgZnJvbSAnZnMnO1xuaW1wb3J0IHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgJ3JlZ2VuZXJhdG9yLXJ1bnRpbWUnO1xuaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7XG4gIGdldFNlYXJjaFBhcmFtcyxcbiAgZ2V0S2V5c0RhdGEsXG4gIGdldEZpbGVzU291cmNlLFxuICBnZXRQcm9jZXNzZWREYXRhUGF0aCxcbiAgc2VsZWN0UHJvY2Vzc09yUmVuZGVyLFxuICB3cml0ZURvd25QYXRocyxcbn0gZnJvbSAnLi9hc2tVc2VyJztcbmltcG9ydCB7XG4gIG1ha2VQYXRocyxcbiAgbWFrZURhdGFTdHJlYW0sXG4gIG1ha2VTdHJ1Y3R1cmVkRGF0YSxcbiAgd3JpdGVUb0pzb24sXG59IGZyb20gJy4vcHJvY2Vzc29ycyc7XG5pbXBvcnQgbWFrZVJlbmRlciBmcm9tICcuL3JlbmRlcmVycyc7XG5pbXBvcnQgeyBkZWZhdWx0VmFsdWVzIH0gZnJvbSAnLi9kZWZhdWx0cyc7XG5cblxuY29uc3QgYXBwID0gYXN5bmMgKCkgPT4ge1xuICBjb25zdCB7XG4gICAgLy8gZW5jb2RpbmdzLFxuICAgIHNlYXJjaFR5cGVzLFxuICAgIHJlbmRlclR5cGVzLFxuICAgIGZpbGVUeXBlcyxcbiAgfSA9IGRlZmF1bHRWYWx1ZXM7XG5cbiAgY29uc3Qgc2VhcmNoUGFyYW1zID0gZ2V0U2VhcmNoUGFyYW1zKHNlYXJjaFR5cGVzKTtcbiAgaWYgKCFzZWFyY2hQYXJhbXMpIHtcbiAgICByZXR1cm47XG4gIH1cbiAgY29uc3QgW3NlYXJjaFR5cGVOYW1lLCBrZXlzRGF0YVR5cGVdID0gc2VhcmNoUGFyYW1zO1xuICBjb25zdCBba2V5cywga2V5c0ZvbGRlcl0gPSBnZXRLZXlzRGF0YShzZWFyY2hUeXBlTmFtZSwga2V5c0RhdGFUeXBlLCBkZWZhdWx0VmFsdWVzKTtcbiAgaWYgKCFrZXlzKSB7XG4gICAgY29uc29sZS5sb2coJ1RoZXJlIGFyZSBubyBmaWxlcyB3aXRoIHNlYXJjaCBjb2Rlcy4gUGxlYXNlIHNlbGVjdCBvciBtYWtlIG9uZSBhbmQgdHJ5IGFnYWluJyk7XG4gICAgcmV0dXJuO1xuICB9XG4gIGNvbnN0IHJlc0ZvbGRlciA9IHBhdGguam9pbihrZXlzRm9sZGVyLCAncHJvY2Vzc2VkRGF0YScpO1xuICBpZiAoIWZzLmV4aXN0c1N5bmMocmVzRm9sZGVyKSkge1xuICAgIGZzLm1rZGlyU3luYyhyZXNGb2xkZXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuICB9XG5cbiAgY29uc29sZS5sb2cocmVzRm9sZGVyKTtcbiAgY29uc3QgcmVzRm9sZGVyRmlsZXNMaXN0ID0gZnMucmVhZGRpclN5bmMocmVzRm9sZGVyKTtcbiAgY29uc3QganNvbkZpbGVzTGlzdCA9IHJlc0ZvbGRlckZpbGVzTGlzdFxuICAgIC5maWx0ZXIoZmlsZU5hbWUgPT4gZmlsZU5hbWUgJiYgcGF0aC5leHRuYW1lKGZpbGVOYW1lKSA9PT0gJy5qc29uJyk7XG4gIGlmIChqc29uRmlsZXNMaXN0Lmxlbmd0aCA+IDApIHtcbiAgICBjb25zdCBmaWxlVG9SZW5kZXIgPSBzZWxlY3RQcm9jZXNzT3JSZW5kZXIoanNvbkZpbGVzTGlzdCk7XG4gICAgaWYgKGZpbGVUb1JlbmRlcikge1xuICAgICAgY29uc3Qgc2VsZWN0ZWREYXRhUGF0aCA9IHBhdGguam9pbihyZXNGb2xkZXIsIGZpbGVUb1JlbmRlcik7XG4gICAgICBtYWtlUmVuZGVyKHNlbGVjdGVkRGF0YVBhdGgsIHJlbmRlclR5cGVzLCByZXNGb2xkZXIpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgfVxuXG4gIGNvbnN0IGZpbGVzU291cmNlID0gZ2V0RmlsZXNTb3VyY2UoZGVmYXVsdFZhbHVlcyk7XG4gIGNvbnN0IHBhdGhzID0gbWFrZVBhdGhzKGZpbGVzU291cmNlLCBmaWxlVHlwZXMpO1xuICBjb25zdCBbZW1wdHlTb3VyY2VzLCBub3RFbXB0eVNvdXJjZXNdID0gXy5wYXJ0aXRpb24ocGF0aHMsIHBhdGhUb0ZpbGUgPT4gXy5pc0FycmF5KHBhdGhUb0ZpbGUpKTtcbiAgaWYgKGVtcHR5U291cmNlcy5sZW5ndGggPiAwKSB7XG4gICAgYXdhaXQgd3JpdGVEb3duUGF0aHMoZW1wdHlTb3VyY2VzLCByZXNGb2xkZXIsICdlbXB0eScpO1xuICB9XG4gIC8vIGNvbnN0IGVuY29kaW5nUG9zID0gcmVhZGxpbmVTeW5jLmtleUluU2VsZWN0KGVuY29kaW5ncywgJ1BsZWFzZSBzZWxlY3QgZmlsZXMgZW5jb2RpbmcnKTtcbiAgLy8gY29uc3QgW2VuY29kaW5nXSA9IGVuY29kaW5ncztcbiAgY29uc3QgcHJvY2Vzc2VkRGF0YVBhdGggPSBnZXRQcm9jZXNzZWREYXRhUGF0aChyZXNGb2xkZXIpO1xuXG4gIGNvbnNvbGUubG9nKCdcXG5EYXRhLXByb2Nlc3NpbmcgaXMgb25nb2luZy4uLlxcbicpO1xuICBjb25zdCBkYXRhU3RyZWFtID0gbWFrZURhdGFTdHJlYW0obm90RW1wdHlTb3VyY2VzLCBzZWFyY2hUeXBlTmFtZSwga2V5cyk7XG4gIGNvbnN0IHRvdGFsSW5mbyA9IGF3YWl0IG1ha2VTdHJ1Y3R1cmVkRGF0YShkYXRhU3RyZWFtKTtcbiAgaWYgKF8uc2l6ZSh0b3RhbEluZm8pID09PSAwKSB7XG4gICAgY29uc29sZS5sb2coJ05vIGRhdGEgaXMgZm91bmRcXG4nKTtcbiAgICByZXR1cm47XG4gIH1cbiAgYXdhaXQgd3JpdGVUb0pzb24odG90YWxJbmZvLCBwcm9jZXNzZWREYXRhUGF0aCk7XG4gIG1ha2VSZW5kZXIocHJvY2Vzc2VkRGF0YVBhdGgsIHJlbmRlclR5cGVzLCByZXNGb2xkZXIpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgYXN5bmMgKCkgPT4ge1xuICBhcHAoKS5jYXRjaCgoZXJyKSA9PiB7XG4gICAgY29uc29sZS5sb2coZXJyKTtcbiAgICB0aHJvdyBuZXcgRXJyb3IoZXJyKTtcbiAgfSk7XG59O1xuIl19 |
@@ -113,5 +113,5 @@ "use strict"; | ||
var selectedData = keys.reduce(function (acc, key) { | ||
var selectedData = keys.length > 0 ? keys.reduce(function (acc, key) { | ||
return [].concat(_toConsumableArray(acc), _toConsumableArray((0, _core.getMatched)(String(key), searchType, data))); | ||
}, []); | ||
}, []) : (0, _core.getMatched)('', searchType, data); | ||
@@ -221,2 +221,2 @@ if (selectedData.length > 0) { | ||
exports.selectZeroMovements = selectZeroMovements; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/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","readablePaths","CustomReader","objectMode","highWaterMark","encoding","getContent","Transform","readableObjectMode","writableObjectMode","transform","chunk","enc","cb","str","readFileSync","chardet","detect","decoded","iconv","decode","push","selectData","ch","filePath","data","selectedData","key","String","length","pipe","makeStructuredData","dataStream","Promise","resolve","reject","totalInfo","on","dataPair","processedData","writeToJson","processedDataPath","objToArr","_","map","value","readableTotalInfo","count","transformToJson","newCount","writableJson","createWriteStream","streamsInPromise","console","log","selectZeroMovements","separatedItems","partition","content","hasZeros","split","every","line","countIn","countOut","isZero","Number","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport { Transform } from 'stream';\nimport path from 'path';\nimport _ from 'lodash';\nimport * as iconv from 'iconv-lite';\nimport chardet from 'chardet';\nimport CustomReader from './StreamReader';\nimport { getMatched, processData, makeJsonChunk } from './core';\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) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  let encoding;\n  const getContent = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(chunk, enc, cb) {\n      const str = fs.readFileSync(chunk[0]);\n      if (!encoding) {\n        encoding = chardet.detect(str);\n      }\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        .reduce((acc, key) => [...acc, ...getMatched(String(key), searchType, data)], []);\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 makeStructuredData = dataStream => new Promise((resolve, reject) => {\n  let totalInfo = {};\n  dataStream\n    .on('data', (dataPair) => {\n      const [selectedData, filePath] = dataPair;\n      const processedData = processData(selectedData, filePath, 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  let count = 0;\n  const transformToJson = new Transform({\n    writableObjectMode: true,\n    transform([chunk], enc, cb) {\n      const [data, newCount] = makeJsonChunk(chunk, objToArr.length, count);\n      count = newCount;\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":["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","readablePaths","CustomReader","objectMode","highWaterMark","encoding","getContent","Transform","readableObjectMode","writableObjectMode","transform","chunk","enc","cb","str","readFileSync","chardet","detect","decoded","iconv","decode","push","selectData","ch","filePath","data","selectedData","length","key","String","pipe","makeStructuredData","dataStream","Promise","resolve","reject","totalInfo","on","dataPair","processedData","writeToJson","processedDataPath","objToArr","_","map","value","readableTotalInfo","count","transformToJson","newCount","writableJson","createWriteStream","streamsInPromise","console","log","selectZeroMovements","separatedItems","partition","content","hasZeros","split","every","line","countIn","countOut","isZero","Number","zeroCounts","rest","unzip","matchedPaths","dataPaths"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport { Transform } from 'stream';\nimport path from 'path';\nimport _ from 'lodash';\nimport * as iconv from 'iconv-lite';\nimport chardet from 'chardet';\nimport CustomReader from './StreamReader';\nimport { getMatched, processData, makeJsonChunk } from './core';\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) => {\n  const readablePaths = new CustomReader(pathDataColl, {\n    objectMode: true,\n    highWaterMark: 1,\n  });\n\n  let encoding;\n  const getContent = new Transform({\n    readableObjectMode: true,\n    writableObjectMode: true,\n    transform(chunk, enc, cb) {\n      const str = fs.readFileSync(chunk[0]);\n      if (!encoding) {\n        encoding = chardet.detect(str);\n      }\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.length > 0\n        ? keys.reduce((acc, key) => [...acc, ...getMatched(String(key), searchType, data)], [])\n        : getMatched('', searchType, data);\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 makeStructuredData = dataStream => new Promise((resolve, reject) => {\n  let totalInfo = {};\n  dataStream\n    .on('data', (dataPair) => {\n      const [selectedData, filePath] = dataPair;\n      const processedData = processData(selectedData, filePath, 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  let count = 0;\n  const transformToJson = new Transform({\n    writableObjectMode: true,\n    transform([chunk], enc, cb) {\n      const [data, newCount] = makeJsonChunk(chunk, objToArr.length, count);\n      count = newCount;\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"]} |
@@ -12,2 +12,4 @@ "use strict"; | ||
var _names = _interopRequireDefault(require("./names")); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } | ||
@@ -60,5 +62,9 @@ | ||
var propNamesStr = _lodash["default"].keys(fromSourceInfo).join('\t'); | ||
var propNamesStr = _lodash["default"].keys(fromSourceInfo).map(function (key) { | ||
return _names["default"][key]; | ||
}).join('\t'); | ||
var headersStr = "drugCode\t".concat(totalValuesNames.join('\t'), "\tsource\t").concat(propNamesStr); | ||
var headersStr = "".concat(_names["default"].drugCode, "\t").concat(totalValuesNames.map(function (key) { | ||
return _names["default"][key]; | ||
}).join('\t'), "\t").concat(_names["default"].source, "\t").concat(propNamesStr); | ||
return "".concat(headersStr, "\n").concat(totalDataStr, "\t").concat(dataStr); | ||
@@ -76,2 +82,2 @@ } | ||
exports["default"] = _default; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJlcnMvZGV0YWlsZWRWYWx1ZXMuanMiXSwibmFtZXMiOlsiZGF0YSIsImhhc0hlYWRlcnMiLCJkcnVnQ29kZXMiLCJfIiwia2V5cyIsInJlbmRlcmVkSW5mb0NvbGwiLCJtYXAiLCJkcnVnQ29kZSIsImRydWdEYXRhIiwicHJlZGljYXRlIiwia2V5IiwiaXNQbGFpbk9iamVjdCIsInBhcnRpdGlvbiIsInRvdGFsVmFsdWVzTmFtZXMiLCJwYXRoTmFtZXMiLCJ0b3RhbERhdGEiLCJuYW1lIiwidG90YWxEYXRhU3RyIiwiam9pbiIsImRldGFpbGVkRGF0YSIsInNvdXJjZSIsImZyb21Tb3VyY2VJbmZvIiwiaW5mb0NvbGwiLCJ0b0FycmF5IiwiZmlsZU5hbWUiLCJkYXRhU3RyIiwicHJvcE5hbWVzU3RyIiwiaGVhZGVyc1N0ciIsImRldGFpbGVkRGF0YVN0ciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7O2VBRWUsa0JBQUNBLElBQUQsRUFBVTtBQUN2QjtBQUNBLE1BQUlDLFVBQVUsR0FBRyxLQUFqQjs7QUFDQSxNQUFNQyxTQUFTLEdBQUdDLG1CQUFFQyxJQUFGLENBQU9KLElBQVAsQ0FBbEI7O0FBQ0EsTUFBTUssZ0JBQWdCLEdBQUdILFNBQVMsQ0FBQ0ksR0FBVixDQUFjLFVBQUNDLFFBQUQsRUFBYztBQUNuRCxRQUFNQyxRQUFRLEdBQUdSLElBQUksQ0FBQ08sUUFBRCxDQUFyQjs7QUFDQSxRQUFNRSxTQUFTLEdBQUcsU0FBWkEsU0FBWSxDQUFBQyxHQUFHO0FBQUEsYUFBSSxDQUFDUCxtQkFBRVEsYUFBRixDQUFnQkgsUUFBUSxDQUFDRSxHQUFELENBQXhCLENBQUw7QUFBQSxLQUFyQjs7QUFGbUQsc0JBR2JQLG1CQUFFUyxTQUFGLENBQVlULG1CQUFFQyxJQUFGLENBQU9JLFFBQVAsQ0FBWixFQUE4QkMsU0FBOUIsQ0FIYTtBQUFBO0FBQUEsUUFHNUNJLGdCQUg0QztBQUFBLFFBRzFCQyxTQUgwQjs7QUFJbkQsUUFBTUMsU0FBUyxHQUFHRixnQkFBZ0IsQ0FBQ1AsR0FBakIsQ0FBcUIsVUFBQVUsSUFBSTtBQUFBLGFBQUlSLFFBQVEsQ0FBQ1EsSUFBRCxDQUFaO0FBQUEsS0FBekIsQ0FBbEI7QUFDQSxRQUFNQyxZQUFZLGFBQU1WLFFBQU4sZUFBbUJRLFNBQVMsQ0FBQ0csSUFBVixDQUFlLElBQWYsQ0FBbkIsQ0FBbEI7QUFFQSxRQUFNQyxZQUFZLEdBQUdMLFNBQVMsQ0FBQ1IsR0FBVixDQUFjLFVBQUNjLE1BQUQsRUFBWTtBQUM3QyxVQUFNQyxjQUFjLEdBQUdiLFFBQVEsQ0FBQ1ksTUFBRCxDQUEvQjs7QUFDQSxVQUFNRSxRQUFRLEdBQUduQixtQkFBRW9CLE9BQUYsQ0FBVUYsY0FBVixDQUFqQjs7QUFDQSxVQUFNRyxRQUFRLEdBQUcsb0JBQVNKLE1BQVQsQ0FBakI7QUFDQSxVQUFNSyxPQUFPLGFBQU1ELFFBQU4sZUFBbUJGLFFBQVEsQ0FBQ0osSUFBVCxDQUFjLElBQWQsQ0FBbkIsQ0FBYjs7QUFFQSxVQUFJLENBQUNqQixVQUFMLEVBQWlCO0FBQ2ZBLFFBQUFBLFVBQVUsR0FBRyxJQUFiOztBQUNBLFlBQU15QixZQUFZLEdBQUd2QixtQkFBRUMsSUFBRixDQUFPaUIsY0FBUCxFQUF1QkgsSUFBdkIsQ0FBNEIsSUFBNUIsQ0FBckI7O0FBQ0EsWUFBTVMsVUFBVSx1QkFBZ0JkLGdCQUFnQixDQUFDSyxJQUFqQixDQUFzQixJQUF0QixDQUFoQix1QkFBd0RRLFlBQXhELENBQWhCO0FBQ0EseUJBQVVDLFVBQVYsZUFBeUJWLFlBQXpCLGVBQTBDUSxPQUExQztBQUNEOztBQUNELHVCQUFVUixZQUFWLGVBQTJCUSxPQUEzQjtBQUNELEtBYm9CLENBQXJCO0FBZUEsUUFBTUcsZUFBZSxHQUFHVCxZQUFZLENBQUNELElBQWIsQ0FBa0IsSUFBbEIsQ0FBeEI7QUFFQSxXQUFPVSxlQUFQO0FBQ0QsR0F6QndCLENBQXpCO0FBMkJBLFNBQU92QixnQkFBUDtBQUNELEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgYmFzZW5hbWUgfSBmcm9tICdwYXRoJztcblxuZXhwb3J0IGRlZmF1bHQgKGRhdGEpID0+IHtcbiAgLy8gY29uc29sZS5sb2coY29udGVudCk7XG4gIGxldCBoYXNIZWFkZXJzID0gZmFsc2U7XG4gIGNvbnN0IGRydWdDb2RlcyA9IF8ua2V5cyhkYXRhKTtcbiAgY29uc3QgcmVuZGVyZWRJbmZvQ29sbCA9IGRydWdDb2Rlcy5tYXAoKGRydWdDb2RlKSA9PiB7XG4gICAgY29uc3QgZHJ1Z0RhdGEgPSBkYXRhW2RydWdDb2RlXTtcbiAgICBjb25zdCBwcmVkaWNhdGUgPSBrZXkgPT4gIV8uaXNQbGFpbk9iamVjdChkcnVnRGF0YVtrZXldKTtcbiAgICBjb25zdCBbdG90YWxWYWx1ZXNOYW1lcywgcGF0aE5hbWVzXSA9IF8ucGFydGl0aW9uKF8ua2V5cyhkcnVnRGF0YSksIHByZWRpY2F0ZSk7XG4gICAgY29uc3QgdG90YWxEYXRhID0gdG90YWxWYWx1ZXNOYW1lcy5tYXAobmFtZSA9PiBkcnVnRGF0YVtuYW1lXSk7XG4gICAgY29uc3QgdG90YWxEYXRhU3RyID0gYCR7ZHJ1Z0NvZGV9XFx0JHt0b3RhbERhdGEuam9pbignXFx0Jyl9YDtcblxuICAgIGNvbnN0IGRldGFpbGVkRGF0YSA9IHBhdGhOYW1lcy5tYXAoKHNvdXJjZSkgPT4ge1xuICAgICAgY29uc3QgZnJvbVNvdXJjZUluZm8gPSBkcnVnRGF0YVtzb3VyY2VdO1xuICAgICAgY29uc3QgaW5mb0NvbGwgPSBfLnRvQXJyYXkoZnJvbVNvdXJjZUluZm8pO1xuICAgICAgY29uc3QgZmlsZU5hbWUgPSBiYXNlbmFtZShzb3VyY2UpO1xuICAgICAgY29uc3QgZGF0YVN0ciA9IGAke2ZpbGVOYW1lfVxcdCR7aW5mb0NvbGwuam9pbignXFx0Jyl9YDtcblxuICAgICAgaWYgKCFoYXNIZWFkZXJzKSB7XG4gICAgICAgIGhhc0hlYWRlcnMgPSB0cnVlO1xuICAgICAgICBjb25zdCBwcm9wTmFtZXNTdHIgPSBfLmtleXMoZnJvbVNvdXJjZUluZm8pLmpvaW4oJ1xcdCcpO1xuICAgICAgICBjb25zdCBoZWFkZXJzU3RyID0gYGRydWdDb2RlXFx0JHt0b3RhbFZhbHVlc05hbWVzLmpvaW4oJ1xcdCcpfVxcdHNvdXJjZVxcdCR7cHJvcE5hbWVzU3RyfWA7XG4gICAgICAgIHJldHVybiBgJHtoZWFkZXJzU3RyfVxcbiR7dG90YWxEYXRhU3RyfVxcdCR7ZGF0YVN0cn1gO1xuICAgICAgfVxuICAgICAgcmV0dXJuIGAke3RvdGFsRGF0YVN0cn1cXHQke2RhdGFTdHJ9YDtcbiAgICB9KTtcblxuICAgIGNvbnN0IGRldGFpbGVkRGF0YVN0ciA9IGRldGFpbGVkRGF0YS5qb2luKCdcXG4nKTtcblxuICAgIHJldHVybiBkZXRhaWxlZERhdGFTdHI7XG4gIH0pO1xuXG4gIHJldHVybiByZW5kZXJlZEluZm9Db2xsO1xufTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yZW5kZXJlcnMvZGV0YWlsZWRWYWx1ZXMuanMiXSwibmFtZXMiOlsiZGF0YSIsImhhc0hlYWRlcnMiLCJkcnVnQ29kZXMiLCJfIiwia2V5cyIsInJlbmRlcmVkSW5mb0NvbGwiLCJtYXAiLCJkcnVnQ29kZSIsImRydWdEYXRhIiwicHJlZGljYXRlIiwia2V5IiwiaXNQbGFpbk9iamVjdCIsInBhcnRpdGlvbiIsInRvdGFsVmFsdWVzTmFtZXMiLCJwYXRoTmFtZXMiLCJ0b3RhbERhdGEiLCJuYW1lIiwidG90YWxEYXRhU3RyIiwiam9pbiIsImRldGFpbGVkRGF0YSIsInNvdXJjZSIsImZyb21Tb3VyY2VJbmZvIiwiaW5mb0NvbGwiLCJ0b0FycmF5IiwiZmlsZU5hbWUiLCJkYXRhU3RyIiwicHJvcE5hbWVzU3RyIiwibmFtZXMiLCJoZWFkZXJzU3RyIiwiZGV0YWlsZWREYXRhU3RyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7ZUFFZSxrQkFBQ0EsSUFBRCxFQUFVO0FBQ3ZCO0FBQ0EsTUFBSUMsVUFBVSxHQUFHLEtBQWpCOztBQUNBLE1BQU1DLFNBQVMsR0FBR0MsbUJBQUVDLElBQUYsQ0FBT0osSUFBUCxDQUFsQjs7QUFDQSxNQUFNSyxnQkFBZ0IsR0FBR0gsU0FBUyxDQUFDSSxHQUFWLENBQWMsVUFBQ0MsUUFBRCxFQUFjO0FBQ25ELFFBQU1DLFFBQVEsR0FBR1IsSUFBSSxDQUFDTyxRQUFELENBQXJCOztBQUNBLFFBQU1FLFNBQVMsR0FBRyxTQUFaQSxTQUFZLENBQUFDLEdBQUc7QUFBQSxhQUFJLENBQUNQLG1CQUFFUSxhQUFGLENBQWdCSCxRQUFRLENBQUNFLEdBQUQsQ0FBeEIsQ0FBTDtBQUFBLEtBQXJCOztBQUZtRCxzQkFHYlAsbUJBQUVTLFNBQUYsQ0FBWVQsbUJBQUVDLElBQUYsQ0FBT0ksUUFBUCxDQUFaLEVBQThCQyxTQUE5QixDQUhhO0FBQUE7QUFBQSxRQUc1Q0ksZ0JBSDRDO0FBQUEsUUFHMUJDLFNBSDBCOztBQUluRCxRQUFNQyxTQUFTLEdBQUdGLGdCQUFnQixDQUFDUCxHQUFqQixDQUFxQixVQUFBVSxJQUFJO0FBQUEsYUFBSVIsUUFBUSxDQUFDUSxJQUFELENBQVo7QUFBQSxLQUF6QixDQUFsQjtBQUNBLFFBQU1DLFlBQVksYUFBTVYsUUFBTixlQUFtQlEsU0FBUyxDQUFDRyxJQUFWLENBQWUsSUFBZixDQUFuQixDQUFsQjtBQUVBLFFBQU1DLFlBQVksR0FBR0wsU0FBUyxDQUFDUixHQUFWLENBQWMsVUFBQ2MsTUFBRCxFQUFZO0FBQzdDLFVBQU1DLGNBQWMsR0FBR2IsUUFBUSxDQUFDWSxNQUFELENBQS9COztBQUNBLFVBQU1FLFFBQVEsR0FBR25CLG1CQUFFb0IsT0FBRixDQUFVRixjQUFWLENBQWpCOztBQUNBLFVBQU1HLFFBQVEsR0FBRyxvQkFBU0osTUFBVCxDQUFqQjtBQUNBLFVBQU1LLE9BQU8sYUFBTUQsUUFBTixlQUFtQkYsUUFBUSxDQUFDSixJQUFULENBQWMsSUFBZCxDQUFuQixDQUFiOztBQUVBLFVBQUksQ0FBQ2pCLFVBQUwsRUFBaUI7QUFDZkEsUUFBQUEsVUFBVSxHQUFHLElBQWI7O0FBQ0EsWUFBTXlCLFlBQVksR0FBR3ZCLG1CQUFFQyxJQUFGLENBQU9pQixjQUFQLEVBQXVCZixHQUF2QixDQUEyQixVQUFBSSxHQUFHO0FBQUEsaUJBQUlpQixrQkFBTWpCLEdBQU4sQ0FBSjtBQUFBLFNBQTlCLEVBQThDUSxJQUE5QyxDQUFtRCxJQUFuRCxDQUFyQjs7QUFDQSxZQUFNVSxVQUFVLGFBQU1ELGtCQUFNcEIsUUFBWixlQUF5Qk0sZ0JBQWdCLENBQ3REUCxHQURzQyxDQUNsQyxVQUFBSSxHQUFHO0FBQUEsaUJBQUlpQixrQkFBTWpCLEdBQU4sQ0FBSjtBQUFBLFNBRCtCLEVBQ2ZRLElBRGUsQ0FDVixJQURVLENBQXpCLGVBQ3lCUyxrQkFBTVAsTUFEL0IsZUFDMENNLFlBRDFDLENBQWhCO0FBRUEseUJBQVVFLFVBQVYsZUFBeUJYLFlBQXpCLGVBQTBDUSxPQUExQztBQUNEOztBQUNELHVCQUFVUixZQUFWLGVBQTJCUSxPQUEzQjtBQUNELEtBZG9CLENBQXJCO0FBZ0JBLFFBQU1JLGVBQWUsR0FBR1YsWUFBWSxDQUFDRCxJQUFiLENBQWtCLElBQWxCLENBQXhCO0FBRUEsV0FBT1csZUFBUDtBQUNELEdBMUJ3QixDQUF6QjtBQTRCQSxTQUFPeEIsZ0JBQVA7QUFDRCxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IGJhc2VuYW1lIH0gZnJvbSAncGF0aCc7XG5pbXBvcnQgbmFtZXMgZnJvbSAnLi9uYW1lcyc7XG5cbmV4cG9ydCBkZWZhdWx0IChkYXRhKSA9PiB7XG4gIC8vIGNvbnNvbGUubG9nKGNvbnRlbnQpO1xuICBsZXQgaGFzSGVhZGVycyA9IGZhbHNlO1xuICBjb25zdCBkcnVnQ29kZXMgPSBfLmtleXMoZGF0YSk7XG4gIGNvbnN0IHJlbmRlcmVkSW5mb0NvbGwgPSBkcnVnQ29kZXMubWFwKChkcnVnQ29kZSkgPT4ge1xuICAgIGNvbnN0IGRydWdEYXRhID0gZGF0YVtkcnVnQ29kZV07XG4gICAgY29uc3QgcHJlZGljYXRlID0ga2V5ID0+ICFfLmlzUGxhaW5PYmplY3QoZHJ1Z0RhdGFba2V5XSk7XG4gICAgY29uc3QgW3RvdGFsVmFsdWVzTmFtZXMsIHBhdGhOYW1lc10gPSBfLnBhcnRpdGlvbihfLmtleXMoZHJ1Z0RhdGEpLCBwcmVkaWNhdGUpO1xuICAgIGNvbnN0IHRvdGFsRGF0YSA9IHRvdGFsVmFsdWVzTmFtZXMubWFwKG5hbWUgPT4gZHJ1Z0RhdGFbbmFtZV0pO1xuICAgIGNvbnN0IHRvdGFsRGF0YVN0ciA9IGAke2RydWdDb2RlfVxcdCR7dG90YWxEYXRhLmpvaW4oJ1xcdCcpfWA7XG5cbiAgICBjb25zdCBkZXRhaWxlZERhdGEgPSBwYXRoTmFtZXMubWFwKChzb3VyY2UpID0+IHtcbiAgICAgIGNvbnN0IGZyb21Tb3VyY2VJbmZvID0gZHJ1Z0RhdGFbc291cmNlXTtcbiAgICAgIGNvbnN0IGluZm9Db2xsID0gXy50b0FycmF5KGZyb21Tb3VyY2VJbmZvKTtcbiAgICAgIGNvbnN0IGZpbGVOYW1lID0gYmFzZW5hbWUoc291cmNlKTtcbiAgICAgIGNvbnN0IGRhdGFTdHIgPSBgJHtmaWxlTmFtZX1cXHQke2luZm9Db2xsLmpvaW4oJ1xcdCcpfWA7XG5cbiAgICAgIGlmICghaGFzSGVhZGVycykge1xuICAgICAgICBoYXNIZWFkZXJzID0gdHJ1ZTtcbiAgICAgICAgY29uc3QgcHJvcE5hbWVzU3RyID0gXy5rZXlzKGZyb21Tb3VyY2VJbmZvKS5tYXAoa2V5ID0+IG5hbWVzW2tleV0pLmpvaW4oJ1xcdCcpO1xuICAgICAgICBjb25zdCBoZWFkZXJzU3RyID0gYCR7bmFtZXMuZHJ1Z0NvZGV9XFx0JHt0b3RhbFZhbHVlc05hbWVzXG4gICAgICAgICAgLm1hcChrZXkgPT4gbmFtZXNba2V5XSkuam9pbignXFx0Jyl9XFx0JHtuYW1lcy5zb3VyY2V9XFx0JHtwcm9wTmFtZXNTdHJ9YDtcbiAgICAgICAgcmV0dXJuIGAke2hlYWRlcnNTdHJ9XFxuJHt0b3RhbERhdGFTdHJ9XFx0JHtkYXRhU3RyfWA7XG4gICAgICB9XG4gICAgICByZXR1cm4gYCR7dG90YWxEYXRhU3RyfVxcdCR7ZGF0YVN0cn1gO1xuICAgIH0pO1xuXG4gICAgY29uc3QgZGV0YWlsZWREYXRhU3RyID0gZGV0YWlsZWREYXRhLmpvaW4oJ1xcbicpO1xuXG4gICAgcmV0dXJuIGRldGFpbGVkRGF0YVN0cjtcbiAgfSk7XG5cbiAgcmV0dXJuIHJlbmRlcmVkSW5mb0NvbGw7XG59O1xuIl19 |
{ | ||
"name": "proxima_datareader", | ||
"version": "1.3.9", | ||
"version": "1.3.10", | ||
"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": { |
@@ -8,3 +8,3 @@ import fs from 'fs'; | ||
import readlineSync from 'readline-sync'; | ||
import { getOrWriteDefaults } from './defaults'; | ||
import { getOrWriteDefaults, defaultValues } from './defaults'; | ||
@@ -26,2 +26,5 @@ | ||
export const getKeysData = (searchType, keysType, defaults) => { | ||
if (searchType === 'none') { | ||
return [[], defaultValues.getDefaultDir()]; | ||
} | ||
const { defaultKeysSource } = getOrWriteDefaults(defaults); | ||
@@ -28,0 +31,0 @@ const keysFolder = readlineSync.questionPath(`\nPlease specify search keys source |
@@ -14,6 +14,9 @@ import _ from 'lodash'; | ||
} | ||
const notZero = Number(countIn) !== 0 || Number(countOut) !== 0; | ||
if (searchType === 'none') { | ||
return notZero; | ||
} | ||
const isSameCode = drugCode === strToSearch; | ||
const nameIncludesStr = name.toLowerCase().includes(strToSearch.toLowerCase()); | ||
const isMatched = searchType === 'drugCode' ? isSameCode : nameIncludesStr; | ||
const notZero = Number(countIn) !== 0 || Number(countOut) !== 0; | ||
return isMatched && notZero; | ||
@@ -20,0 +23,0 @@ }).filter(([, lines]) => lines.length > 0); |
@@ -7,9 +7,10 @@ import path from 'path'; | ||
getDefaultDir() { | ||
return path.join(this.homeDir, '/Documents/Proxima/defaults'); | ||
const defaultDir = path.join(this.homeDir, '/Documents/Proxima/defaults'); | ||
if (!fs.existsSync(defaultDir)) { | ||
fs.mkdirSync(defaultDir, { recursive: true }); | ||
} | ||
return defaultDir; | ||
}, | ||
getDefaultValuesPath() { | ||
const defaultDir = this.getDefaultDir(); | ||
if (!fs.existsSync(defaultDir)) { | ||
fs.mkdirSync(defaultDir, { recursive: true }); | ||
} | ||
const defaultValuesPath = path.join(defaultDir, 'defaultsForDataSelector.json'); | ||
@@ -25,2 +26,3 @@ return defaultValuesPath; | ||
drugName: 'string', | ||
none: null, | ||
}, | ||
@@ -27,0 +29,0 @@ renderTypes: ['total', 'detailed'], |
@@ -41,5 +41,8 @@ import fs from 'fs'; | ||
} | ||
const newPath = path.join(keysFolder, 'processedData'); | ||
const resFolder = fs.existsSync(newPath) ? newPath : fs.mkdirSync(newPath, { recursive: true }); | ||
const resFolder = path.join(keysFolder, 'processedData'); | ||
if (!fs.existsSync(resFolder)) { | ||
fs.mkdirSync(resFolder, { recursive: true }); | ||
} | ||
console.log(resFolder); | ||
const resFolderFilesList = fs.readdirSync(resFolder); | ||
@@ -68,3 +71,2 @@ const jsonFilesList = resFolderFilesList | ||
console.log('\nData-processing is ongoing...\n'); | ||
const dataStream = makeDataStream(notEmptySources, searchTypeName, keys); | ||
@@ -71,0 +73,0 @@ const totalInfo = await makeStructuredData(dataStream); |
@@ -57,4 +57,5 @@ import fs from 'fs'; | ||
const [filePath, data] = ch; | ||
const selectedData = keys | ||
.reduce((acc, key) => [...acc, ...getMatched(String(key), searchType, data)], []); | ||
const selectedData = keys.length > 0 | ||
? keys.reduce((acc, key) => [...acc, ...getMatched(String(key), searchType, data)], []) | ||
: getMatched('', searchType, data); | ||
if (selectedData.length > 0) { | ||
@@ -61,0 +62,0 @@ this.push([selectedData, filePath]); |
import _ from 'lodash'; | ||
import { basename } from 'path'; | ||
import names from './names'; | ||
@@ -23,4 +24,5 @@ export default (data) => { | ||
hasHeaders = true; | ||
const propNamesStr = _.keys(fromSourceInfo).join('\t'); | ||
const headersStr = `drugCode\t${totalValuesNames.join('\t')}\tsource\t${propNamesStr}`; | ||
const propNamesStr = _.keys(fromSourceInfo).map(key => names[key]).join('\t'); | ||
const headersStr = `${names.drugCode}\t${totalValuesNames | ||
.map(key => names[key]).join('\t')}\t${names.source}\t${propNamesStr}`; | ||
return `${headersStr}\n${totalDataStr}\t${dataStr}`; | ||
@@ -27,0 +29,0 @@ } |
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
28
17
139772
1448