codify-images 1.0.1 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cli.js CHANGED
@@ -1,3 +1,3 @@
1
1
  #!/usr/bin/env node
2
- "use strict";var _chalk=require("chalk");var _package=require("../package.json");var _commander=require("commander");var _fs=require("fs");var _2=require("../");var _path=require("path");const generateStart=options=>{return options.es===6?"":"module.exports = {\n"};const generateLine=(name,data,options)=>{const adjustedData=`'${data}'`;const indentType=options.indentType==="tab"?"\t":" ";const indent=indentType.repeat(options.indentCount);return options.es===6?`export const ${name} = ${adjustedData};`:`${indent}${name}: ${adjustedData}`};const generateLineEnding=(options,last)=>{return options.es!==6&&!last?",\n":"\n"};const generateEnd=options=>{return options.es!==6?"};\n":""};const writeOutput=(outputPath,output,options)=>{if(!(0,_fs.existsSync)(options.output)){(0,_fs.mkdirSync)(options.output)}(0,_fs.writeFileSync)(outputPath,output,{encoding:"utf-8"})};const logStart=message=>{console.log((0,_chalk.yellow)(message));console.group()};const logInfo=message=>{console.log((0,_chalk.blue)(message))};const logError=message=>{console.error(`error: ${(0,_chalk.red)(message)}`);console.groupEnd()};const logProcessed=(path,name)=>{logInfo(`processed image (${path} => ${name})`)};const logEnd=message=>{console.groupEnd();console.log((0,_chalk.green)(message))};const generate=options=>{logStart((0,_chalk.yellow)(`generating exports (${options.input}) ...`));let output=generateStart(options);const images=(0,_2.codifyImagesSync)(options.input,{log:logProcessed});if(images.length===0){throw new Error("no images available at input path.")}const keys=Object.keys(images);for(const index in keys){const key=keys[index];const data=images[key];output+=generateLine(key,data,options);output+=generateLineEnding(options,index===keys.length-1);logInfo(`writing export (${key})`)}output+=generateEnd(options);const outputPath=(0,_path.resolve)(options.output,"images.js");writeOutput(outputPath,output,options);logEnd(`exports generated (${outputPath})`)};const customParseInt=value=>{const parsedValue=parseInt(value,10);if(isNaN(parsedValue)){throw new _commander.InvalidArgumentError("Must be valid integer.")}else if(parsedValue<=0){throw new _commander.InvalidArgumentError("Must be positive integer.")}return parsedValue};const customResolve=value=>{try{return(0,_path.resolve)(value)}catch(_){throw new _commander.InvalidArgumentError("Must be valid.")}};const main=()=>{const program=new _commander.Command(_package.name);program.version(_package.version).showHelpAfterError().configureOutput({outputError:(message,write)=>write((0,_chalk.red)(message))}).argument("<input path>","path to where image files reside",value=>{const path=customResolve(value);try{const stat=(0,_fs.statSync)(path);if(!stat.isDirectory()){throw new _commander.InvalidArgumentError("Must be directory.")}return path}catch(_){throw new _commander.InvalidArgumentError("Must exist.")}}).option("-o, --output <path>","path to write generated files",value=>customResolve(value),"generated").option("-e, --es <version>","ESM version to generate",value=>{const parsedValue=customParseInt(value,10);const choicesEs=[5,6];if(!choicesEs.includes(parsedValue)){const choices=choicesEs.join(", ");throw new _commander.InvalidArgumentError(`Allowed choices are ${choices}.`)}return parsedValue},6).option("-c, --indent-count <count>","number of indent elements to output",value=>customParseInt(value,10),1).addOption(new _commander.Option("-t, --indent-type <type>","type of indent to output").choices(["tab","space"]).default("tab")).action((_,opts)=>{if(opts.output==="generated"){opts.output=(0,_path.resolve)(opts.output)}}).parse(process.argv);const programOptions=program.opts();const programArguments=program.processedArgs;const options={input:programArguments[0],...programOptions};generate(options)};try{main()}catch(err){logError(err);process.exit(1)}
3
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../bin/cli.js"],"names":["generateStart","options","es","generateLine","name","data","adjustedData","indentType","indent","repeat","indentCount","generateLineEnding","last","generateEnd","writeOutput","outputPath","output","encoding","logStart","message","console","log","group","logInfo","logError","error","groupEnd","logProcessed","path","logEnd","generate","input","images","length","Error","keys","Object","index","key","customParseInt","value","parsedValue","parseInt","isNaN","InvalidArgumentError","customResolve","_","main","program","Command","cliName","version","cliVersion","showHelpAfterError","configureOutput","outputError","write","argument","stat","isDirectory","option","choicesEs","includes","choices","join","addOption","Option","default","action","opts","parse","process","argv","programOptions","programArguments","processedArgs","err","exit"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { blue, green, red, yellow } from 'chalk';\nimport { name as cliName, version as cliVersion } from '../package.json';\nimport { Command, InvalidArgumentError, Option } from 'commander';\nimport { existsSync, mkdirSync, statSync, writeFileSync } from 'fs';\nimport { codifyImagesSync } from '../';\nimport { resolve } from 'path';\n\nconst generateStart = options => {\n  return options.es === 6 ? '' : 'module.exports = {\\n';\n};\n\nconst generateLine = (name, data, options) => {\n  const adjustedData = `'${data}'`;\n  const indentType = options.indentType === 'tab' ? '\\t' : ' ';\n  const indent = indentType.repeat(options.indentCount);\n\n  return options.es === 6 ?\n    `export const ${name} = ${adjustedData};` :\n    `${indent}${name}: ${adjustedData}`;\n};\n\nconst generateLineEnding = (options, last) => {\n  return options.es !== 6 && !last ? ',\\n' : '\\n';\n};\n\nconst generateEnd = options => {\n  return options.es !== 6 ? '};\\n' : '';\n};\n\nconst writeOutput = (outputPath, output, options) => {\n  if (!existsSync(options.output)) {\n    mkdirSync(options.output);\n  }\n\n  writeFileSync(outputPath, output, { encoding: 'utf-8' });\n};\n\nconst logStart = message => {\n  console.log(yellow(message));\n  console.group();\n};\n\nconst logInfo = message => {\n  console.log(blue(message));\n};\n\nconst logError = message => {\n  console.error(`error: ${red(message)}`);\n  console.groupEnd();\n};\n\nconst logProcessed = (path, name) => {\n  logInfo(`processed image (${path} => ${name})`);\n};\n\nconst logEnd = message => {\n  console.groupEnd();\n  console.log(green(message));\n};\n\nconst generate = options => {\n  logStart(yellow(`generating exports (${options.input}) ...`));\n\n  let output = generateStart(options);\n  const images = codifyImagesSync(options.input, { log: logProcessed });\n\n  if (images.length === 0) {\n    throw new Error('no images available at input path.');\n  }\n\n  const keys = Object.keys(images);\n\n  for (const index in keys) {\n    const key = keys[index];\n    const data = images[key];\n\n    output += generateLine(key, data, options);\n    output += generateLineEnding(options, index === keys.length - 1);\n\n    logInfo(`writing export (${key})`);\n  }\n\n  output += generateEnd(options);\n\n  const outputPath = resolve(options.output, 'images.js');\n\n  writeOutput(outputPath, output, options);\n  logEnd(`exports generated (${outputPath})`);\n};\n\nconst customParseInt = value => {\n  const parsedValue = parseInt(value, 10);\n\n  if (isNaN(parsedValue)) {\n    throw new InvalidArgumentError('Must be valid integer.');\n  } else if (parsedValue <= 0) {\n    throw new InvalidArgumentError('Must be positive integer.');\n  }\n\n  return parsedValue;\n};\n\nconst customResolve = value => {\n  try {\n    return resolve(value);\n  } catch (_) {\n    throw new InvalidArgumentError('Must be valid.');\n  }\n};\n\nconst main = () => {\n  const program = new Command(cliName);\n\n  program\n    .version(cliVersion)\n    .showHelpAfterError()\n    .configureOutput({ outputError: (message, write) => write(red(message)) })\n    .argument(\n      '<input path>',\n      'path to where image files reside',\n      value => {\n        const path = customResolve(value);\n\n        try {\n          const stat = statSync(path);\n\n          if (!stat.isDirectory()) {\n            throw new InvalidArgumentError('Must be directory.');\n          }\n\n          return path;\n        } catch (_) {\n          throw new InvalidArgumentError('Must exist.');\n        }\n      }\n    )\n    .option(\n      '-o, --output <path>',\n      'path to write generated files',\n      value => customResolve(value),\n      'generated'\n    )\n    .option(\n      '-e, --es <version>',\n      'ESM version to generate',\n      value => {\n        const parsedValue = customParseInt(value, 10);\n        const choicesEs = [5, 6];\n\n        if (!choicesEs.includes(parsedValue)) {\n          const choices = choicesEs.join(', ');\n\n          throw new InvalidArgumentError(`Allowed choices are ${choices}.`);\n        }\n\n        return parsedValue;\n      },\n      6\n    )\n    .option(\n      '-c, --indent-count <count>',\n      'number of indent elements to output',\n      value => customParseInt(value, 10),\n      1\n    )\n    .addOption(\n      new Option('-t, --indent-type <type>', 'type of indent to output')\n        .choices(['tab', 'space'])\n        .default('tab')\n    )\n    .action((_, opts) => {\n      if (opts.output === 'generated') {\n        opts.output = resolve(opts.output);\n      }\n    })\n    .parse(process.argv);\n\n  const programOptions = program.opts();\n  const programArguments = program.processedArgs;\n  const options = { input: programArguments[0], ...programOptions };\n\n  generate(options);\n};\n\ntry {\n  main();\n} catch (err) {\n  logError(err);\n  process.exit(1);\n}\n"]}
2
+ "use strict";var _chalk=require("chalk");var _package=require("../package.json");var _commander=require("commander");var _fs=require("fs");var _2=require("../");var _path=require("path");const generateStart=options=>{return options.es===6?"":"module.exports = {\n"};const generateLine=(name,data,options)=>{const adjustedData=`'${data}'`;const indentType=options.indentType==="tab"?"\t":" ";const indent=indentType.repeat(options.indentCount);return options.es===6?`export const ${name} = ${adjustedData};`:`${indent}${name}: ${adjustedData}`};const generateLineEnding=(options,last)=>{return options.es!==6&&!last?",\n":"\n"};const generateEnd=options=>{return options.es!==6?"};\n":""};const writeOutput=(outputPath,output,options)=>{if(!(0,_fs.existsSync)(options.output)){(0,_fs.mkdirSync)(options.output)}(0,_fs.writeFileSync)(outputPath,output,{encoding:"utf-8"})};const logStart=message=>{console.log((0,_chalk.yellow)(message));console.group()};const logInfo=message=>{console.log((0,_chalk.blue)(message))};const logError=message=>{console.error(`error: ${(0,_chalk.red)(message)}`);console.groupEnd()};const logProcessed=(path,name)=>{logInfo(`processed image (${path} => ${name})`)};const logEnd=message=>{console.groupEnd();console.log((0,_chalk.green)(message))};const generate=options=>{logStart((0,_chalk.yellow)(`generating exports (${options.input}) ...`));let output=generateStart(options);const images=(0,_2.codifyImagesSync)(options.input,{log:logProcessed,forceBase64:options.forceBase64});if(images.length===0){throw new Error("no images available at input path.")}const keys=Object.keys(images);for(const index in keys){const key=keys[index];const data=images[key];output+=generateLine(key,data,options);output+=generateLineEnding(options,index===keys.length-1);logInfo(`writing export (${key})`)}output+=generateEnd(options);const outputPath=(0,_path.resolve)(options.output,"images.js");writeOutput(outputPath,output,options);logEnd(`exports generated (${outputPath})`)};const customParseInt=value=>{const parsedValue=parseInt(value,10);if(isNaN(parsedValue)){throw new _commander.InvalidArgumentError("Must be valid integer.")}else if(parsedValue<=0){throw new _commander.InvalidArgumentError("Must be positive integer.")}return parsedValue};const customResolve=value=>{try{return(0,_path.resolve)(value)}catch(_){throw new _commander.InvalidArgumentError("Must be valid.")}};const main=()=>{const program=new _commander.Command(_package.name);program.version(_package.version).showHelpAfterError().configureOutput({outputError:(message,write)=>write((0,_chalk.red)(message))}).argument("<input path>","path to where image files reside",value=>{const path=customResolve(value);try{const stat=(0,_fs.statSync)(path);if(!stat.isDirectory()){throw new _commander.InvalidArgumentError("Must be directory.")}return path}catch(_){throw new _commander.InvalidArgumentError("Must exist.")}}).option("-f, --force-base64 ","force all image output to be base64 encoded",false).option("-o, --output <path>","path to write generated files",value=>customResolve(value),"generated").option("-e, --es <version>","ESM version to generate",value=>{const parsedValue=customParseInt(value,10);const choicesEs=[5,6];if(!choicesEs.includes(parsedValue)){const choices=choicesEs.join(", ");throw new _commander.InvalidArgumentError(`Allowed choices are ${choices}.`)}return parsedValue},6).option("-c, --indent-count <count>","number of indent elements to output",value=>customParseInt(value,10),1).addOption(new _commander.Option("-t, --indent-type <type>","type of indent to output").choices(["tab","space"]).default("tab")).action((_,opts)=>{if(opts.output==="generated"){opts.output=(0,_path.resolve)(opts.output)}}).parse(process.argv);const programOptions=program.opts();const programArguments=program.processedArgs;const options={input:programArguments[0],...programOptions};generate(options)};try{main()}catch(err){logError(err);process.exit(1)}
3
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../bin/cli.js"],"names":["generateStart","options","es","generateLine","name","data","adjustedData","indentType","indent","repeat","indentCount","generateLineEnding","last","generateEnd","writeOutput","outputPath","output","encoding","logStart","message","console","log","group","logInfo","logError","error","groupEnd","logProcessed","path","logEnd","generate","input","images","forceBase64","length","Error","keys","Object","index","key","customParseInt","value","parsedValue","parseInt","isNaN","InvalidArgumentError","customResolve","_","main","program","Command","cliName","version","cliVersion","showHelpAfterError","configureOutput","outputError","write","argument","stat","isDirectory","option","choicesEs","includes","choices","join","addOption","Option","default","action","opts","parse","process","argv","programOptions","programArguments","processedArgs","err","exit"],"mappings":"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","sourcesContent":["#!/usr/bin/env node\n\nimport { blue, green, red, yellow } from 'chalk';\nimport { name as cliName, version as cliVersion } from '../package.json';\nimport { Command, InvalidArgumentError, Option } from 'commander';\nimport { existsSync, mkdirSync, statSync, writeFileSync } from 'fs';\nimport { codifyImagesSync } from '../';\nimport { resolve } from 'path';\n\nconst generateStart = options => {\n  return options.es === 6 ? '' : 'module.exports = {\\n';\n};\n\nconst generateLine = (name, data, options) => {\n  const adjustedData = `'${data}'`;\n  const indentType = options.indentType === 'tab' ? '\\t' : ' ';\n  const indent = indentType.repeat(options.indentCount);\n\n  return options.es === 6 ?\n    `export const ${name} = ${adjustedData};` :\n    `${indent}${name}: ${adjustedData}`;\n};\n\nconst generateLineEnding = (options, last) => {\n  return options.es !== 6 && !last ? ',\\n' : '\\n';\n};\n\nconst generateEnd = options => {\n  return options.es !== 6 ? '};\\n' : '';\n};\n\nconst writeOutput = (outputPath, output, options) => {\n  if (!existsSync(options.output)) {\n    mkdirSync(options.output);\n  }\n\n  writeFileSync(outputPath, output, { encoding: 'utf-8' });\n};\n\nconst logStart = message => {\n  console.log(yellow(message));\n  console.group();\n};\n\nconst logInfo = message => {\n  console.log(blue(message));\n};\n\nconst logError = message => {\n  console.error(`error: ${red(message)}`);\n  console.groupEnd();\n};\n\nconst logProcessed = (path, name) => {\n  logInfo(`processed image (${path} => ${name})`);\n};\n\nconst logEnd = message => {\n  console.groupEnd();\n  console.log(green(message));\n};\n\nconst generate = options => {\n  logStart(yellow(`generating exports (${options.input}) ...`));\n\n  let output = generateStart(options);\n  const images = codifyImagesSync(\n    options.input,\n    { log: logProcessed, forceBase64: options.forceBase64 }\n  );\n\n  if (images.length === 0) {\n    throw new Error('no images available at input path.');\n  }\n\n  const keys = Object.keys(images);\n\n  for (const index in keys) {\n    const key = keys[index];\n    const data = images[key];\n\n    output += generateLine(key, data, options);\n    output += generateLineEnding(options, index === keys.length - 1);\n\n    logInfo(`writing export (${key})`);\n  }\n\n  output += generateEnd(options);\n\n  const outputPath = resolve(options.output, 'images.js');\n\n  writeOutput(outputPath, output, options);\n  logEnd(`exports generated (${outputPath})`);\n};\n\nconst customParseInt = value => {\n  const parsedValue = parseInt(value, 10);\n\n  if (isNaN(parsedValue)) {\n    throw new InvalidArgumentError('Must be valid integer.');\n  } else if (parsedValue <= 0) {\n    throw new InvalidArgumentError('Must be positive integer.');\n  }\n\n  return parsedValue;\n};\n\nconst customResolve = value => {\n  try {\n    return resolve(value);\n  } catch (_) {\n    throw new InvalidArgumentError('Must be valid.');\n  }\n};\n\nconst main = () => {\n  const program = new Command(cliName);\n\n  program\n    .version(cliVersion)\n    .showHelpAfterError()\n    .configureOutput({ outputError: (message, write) => write(red(message)) })\n    .argument(\n      '<input path>',\n      'path to where image files reside',\n      value => {\n        const path = customResolve(value);\n\n        try {\n          const stat = statSync(path);\n\n          if (!stat.isDirectory()) {\n            throw new InvalidArgumentError('Must be directory.');\n          }\n\n          return path;\n        } catch (_) {\n          throw new InvalidArgumentError('Must exist.');\n        }\n      }\n    )\n    .option(\n      '-f, --force-base64 ',\n      'force all image output to be base64 encoded',\n      false\n    )\n    .option(\n      '-o, --output <path>',\n      'path to write generated files',\n      value => customResolve(value),\n      'generated'\n    )\n    .option(\n      '-e, --es <version>',\n      'ESM version to generate',\n      value => {\n        const parsedValue = customParseInt(value, 10);\n        const choicesEs = [5, 6];\n\n        if (!choicesEs.includes(parsedValue)) {\n          const choices = choicesEs.join(', ');\n\n          throw new InvalidArgumentError(`Allowed choices are ${choices}.`);\n        }\n\n        return parsedValue;\n      },\n      6\n    )\n    .option(\n      '-c, --indent-count <count>',\n      'number of indent elements to output',\n      value => customParseInt(value, 10),\n      1\n    )\n    .addOption(\n      new Option('-t, --indent-type <type>', 'type of indent to output')\n        .choices(['tab', 'space'])\n        .default('tab')\n    )\n    .action((_, opts) => {\n      if (opts.output === 'generated') {\n        opts.output = resolve(opts.output);\n      }\n    })\n    .parse(process.argv);\n\n  const programOptions = program.opts();\n  const programArguments = program.processedArgs;\n  const options = { input: programArguments[0], ...programOptions };\n\n  generate(options);\n};\n\ntry {\n  main();\n} catch (err) {\n  logError(err);\n  process.exit(1);\n}\n"]}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.codifyImagesSync=exports.codifyImages=void 0;var _path=require("path");var _fs=require("fs");var _lodash=_interopRequireDefault(require("lodash.camelcase"));var _miniSvgDataUri=_interopRequireDefault(require("mini-svg-data-uri"));function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}const svgExtension=".svg";const supportedMimeTypes={".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".svg":"image/svg+xml"};const isObject=value=>{return Object.prototype.toString.call(value)==="[object Object]"};const getFormat=isSvg=>{return isSvg?"utf-8":"base64"};const sanitizeFileData=data=>{return data.replace(/[\r\n]+/gm,"")};const buildDataUri=(isSvg,source,mime,format)=>{return isSvg?(0,_miniSvgDataUri.default)(source).replace(/'/g,"\""):`data:${mime};${format},${source}`};const isSupported=(file,extension)=>{return extension!==file&&supportedMimeTypes[extension]!==undefined};const getImageDataUri=(path,mime,isSvg)=>{const format=getFormat(isSvg);const source=sanitizeFileData((0,_fs.readFileSync)(path,format));return buildDataUri(isSvg,source,mime,format)};const processFile=(path,file,extension)=>{const mime=supportedMimeTypes[extension];const isSvg=mime===supportedMimeTypes[svgExtension];const filePath=(0,_path.resolve)(path,file);return{path:filePath,name:(0,_lodash.default)((0,_path.basename)(file)),data:getImageDataUri(filePath,mime,isSvg)}};const processFiles=(path,files,options)=>{const images={};for(const file of files){var _options$log;const extension=(0,_path.extname)(file);if(!isSupported(file,extension)){continue}const image=processFile(path,file,extension);images[image.name]=image.data;options===null||options===void 0?void 0:(_options$log=options.log)===null||_options$log===void 0?void 0:_options$log.call(options,image)}return images};const codifyImagesSync=(path,options={})=>{if(!isObject(options)){options={}}const files=(0,_fs.readdirSync)(path);return processFiles(path,files,options)};exports.codifyImagesSync=codifyImagesSync;const codifyImages=(path,options={})=>{return new Promise((resolve,reject)=>{try{resolve(codifyImagesSync(path,options))}catch(err){reject(err)}})};exports.codifyImages=codifyImages;
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2RpZnktaW1hZ2VzLmpzIl0sIm5hbWVzIjpbInN2Z0V4dGVuc2lvbiIsInN1cHBvcnRlZE1pbWVUeXBlcyIsImlzT2JqZWN0IiwidmFsdWUiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJ0b1N0cmluZyIsImNhbGwiLCJnZXRGb3JtYXQiLCJpc1N2ZyIsInNhbml0aXplRmlsZURhdGEiLCJkYXRhIiwicmVwbGFjZSIsImJ1aWxkRGF0YVVyaSIsInNvdXJjZSIsIm1pbWUiLCJmb3JtYXQiLCJpc1N1cHBvcnRlZCIsImZpbGUiLCJleHRlbnNpb24iLCJ1bmRlZmluZWQiLCJnZXRJbWFnZURhdGFVcmkiLCJwYXRoIiwicHJvY2Vzc0ZpbGUiLCJmaWxlUGF0aCIsIm5hbWUiLCJwcm9jZXNzRmlsZXMiLCJmaWxlcyIsIm9wdGlvbnMiLCJpbWFnZXMiLCJpbWFnZSIsImxvZyIsImNvZGlmeUltYWdlc1N5bmMiLCJjb2RpZnlJbWFnZXMiLCJQcm9taXNlIiwicmVzb2x2ZSIsInJlamVjdCIsImVyciJdLCJtYXBwaW5ncyI6IjJIQUFBLDBCQUNBLHNCQUNBLGdFQUNBLHlFLGtGQUVBLEtBQU1BLENBQUFBLFlBQVksQ0FBRyxNQUFyQixDQUNBLEtBQU1DLENBQUFBLGtCQUFrQixDQUFHLENBQ3pCLE9BQVEsWUFEaUIsQ0FFekIsUUFBUyxZQUZnQixDQUd6QixPQUFRLFdBSGlCLENBSXpCLE9BQVEsV0FKaUIsQ0FLekIsUUFBUyxZQUxnQixDQU16QixPQUFRLGVBTmlCLENBQTNCLENBU0EsS0FBTUMsQ0FBQUEsUUFBUSxDQUFHQyxLQUFLLEVBQUksQ0FDeEIsTUFBT0MsQ0FBQUEsTUFBTSxDQUFDQyxTQUFQLENBQWlCQyxRQUFqQixDQUEwQkMsSUFBMUIsQ0FBK0JKLEtBQS9CLElBQTBDLGlCQUNsRCxDQUZELENBSUEsS0FBTUssQ0FBQUEsU0FBUyxDQUFHQyxLQUFLLEVBQUksQ0FDekIsTUFBT0EsQ0FBQUEsS0FBSyxDQUFHLE9BQUgsQ0FBYSxRQUMxQixD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Q0FBRyxvQkFBWUwsSUFBWixDQUFkLENBRUEsTUFBT0ksQ0FBQUEsWUFBWSxDQUFDSixJQUFELENBQU9LLEtBQVAsQ0FBY0MsT0FBZCxDQUNwQixDQVJNLEMsMENBVUEsS0FBTUssQ0FBQUEsWUFBWSxDQUFHLENBQUNYLElBQUQsQ0FBT00sT0FBTyxDQUFHLEVBQWpCLEdBQXdCLENBQ2xELE1BQU8sSUFBSU0sQ0FBQUEsT0FBSixDQUFZLENBQUNDLE9BQUQsQ0FBVUMsTUFBVixHQUFxQixDQUN0QyxHQUFJLENBQ0ZELE9BQU8sQ0FBQ0gsZ0JBQWdCLENBQUNWLElBQUQsQ0FBT00sT0FBUCxDQUFqQixDQUNSLENBQUMsTUFBT1MsR0FBUCxDQUFZLENBQ1pELE1BQU0sQ0FBQ0MsR0FBRCxDQUNQLENBQ0YsQ0FOTSxDQU9SLENBUk0sQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJhc2VuYW1lLCBleHRuYW1lLCByZXNvbHZlIGFzIHJlc29sdmVQYXRoIH0gZnJvbSAncGF0aCc7XG5pbXBvcnQgeyByZWFkZGlyU3luYywgcmVhZEZpbGVTeW5jIH0gZnJvbSAnZnMnO1xuaW1wb3J0IGNhbWVsQ2FzZSBmcm9tICdsb2Rhc2guY2FtZWxjYXNlJztcbmltcG9ydCBzdmdUb01pbmlEYXRhVVJJIGZyb20gJ21pbmktc3ZnLWRhdGEtdXJpJztcblxuY29uc3Qgc3ZnRXh0ZW5zaW9uID0gJy5zdmcnO1xuY29uc3Qgc3VwcG9ydGVkTWltZVR5cGVzID0ge1xuICAnLmpwZyc6ICdpbWFnZS9qcGVnJyxcbiAgJy5qcGVnJzogJ2ltYWdlL2pwZWcnLFxuICAnLnBuZyc6ICdpbWFnZS9wbmcnLFxuICAnLmdpZic6ICdpbWFnZS9naWYnLFxuICAnLndlYnAnOiAnaW1hZ2Uvd2VicCcsXG4gICcuc3ZnJzogJ2ltYWdlL3N2Zyt4bWwnXG59O1xuXG5jb25zdCBpc09iamVjdCA9IHZhbHVlID0+IHtcbiAgcmV0dXJuIE9iamVjdC5wcm90b3R5cGUudG9TdHJpbmcuY2FsbCh2YWx1ZSkgPT09ICdbb2JqZWN0IE9iamVjdF0nO1xufTtcblxuY29uc3QgZ2V0Rm9ybWF0ID0gaXNTdmcgPT4ge1xuICByZXR1cm4gaXNTdmcgPyAndXRmLTgnIDogJ2Jhc2U2NCc7XG59O1xuXG5jb25zdCBzYW5pdGl6ZUZpbGVEYXRhID0gZGF0YSA9PiB7XG4gIHJldHVybiBkYXRhLnJlcGxhY2UoL1tcXHJcXG5dKy9nbSwgJycpO1xufTtcblxuY29uc3QgYnVpbGREYXRhVXJpID0gKGlzU3ZnLCBzb3VyY2UsIG1pbWUsIGZvcm1hdCkgPT4ge1xuICByZXR1cm4gaXNTdmcgP1xuICAgIHN2Z1RvTWluaURhdGFVUkkoc291cmNlKS5yZXBsYWNlKC8nL2csICdcIicpIDpcbiAgICBgZGF0YToke21pbWV9OyR7Zm9ybWF0fSwke3NvdXJjZX1gO1xufTtcblxuY29uc3QgaXNTdXBwb3J0ZWQgPSAoZmlsZSwgZXh0ZW5zaW9uKSA9PiB7XG4gIHJldHVybiBleHRlbnNpb24gIT09IGZpbGUgJiYgc3VwcG9ydGVkTWltZVR5cGVzW2V4dGVuc2lvbl0gIT09IHVuZGVmaW5lZDtcbn07XG5cbmNvbnN0IGdldEltYWdlRGF0YVVyaSA9IChwYXRoLCBtaW1lLCBpc1N2ZykgPT4ge1xuICBjb25zdCBmb3JtYXQgPSBnZXRGb3JtYXQoaXNTdmcpO1xuICBjb25zdCBzb3VyY2UgPSBzYW5pdGl6ZUZpbGVEYXRhKHJlYWRGaWxlU3luYyhwYXRoLCBmb3JtYXQpKTtcblxuICByZXR1cm4gYnVpbGREYXRhVXJpKGlzU3ZnLCBzb3VyY2UsIG1pbWUsIGZvcm1hdCk7XG59O1xuXG5jb25zdCBwcm9jZXNzRmlsZSA9IChwYXRoLCBmaWxlLCBleHRlbnNpb24pID0+IHtcbiAgY29uc3QgbWltZSA9IHN1cHBvcnRlZE1pbWVUeXBlc1tleHRlbnNpb25dO1xuICBjb25zdCBpc1N2ZyA9IG1pbWUgPT09IHN1cHBvcnRlZE1pbWVUeXBlc1tzdmdFeHRlbnNpb25dO1xuICBjb25zdCBmaWxlUGF0aCA9IHJlc29sdmVQYXRoKHBhdGgsIGZpbGUpO1xuXG4gIHJldHVybiB7XG4gICAgcGF0aDogZmlsZVBhdGgsXG4gICAgbmFtZTogY2FtZWxDYXNlKGJhc2VuYW1lKGZpbGUpKSxcbiAgICBkYXRhOiBnZXRJbWFnZURhdGFVcmkoZmlsZVBhdGgsIG1pbWUsIGlzU3ZnKVxuICB9O1xufTtcblxuY29uc3QgcHJvY2Vzc0ZpbGVzID0gKHBhdGgsIGZpbGVzLCBvcHRpb25zKSA9PiB7XG4gIGNvbnN0IGltYWdlcyA9IHt9O1xuXG4gIGZvciAoY29uc3QgZmlsZSBvZiBmaWxlcykge1xuICAgIGNvbnN0IGV4dGVuc2lvbiA9IGV4dG5hbWUoZmlsZSk7XG5cbiAgICBpZiAoIWlzU3VwcG9ydGVkKGZpbGUsIGV4dGVuc2lvbikpIHtcbiAgICAgIGNvbnRpbnVlO1xuICAgIH1cblxuICAgIGNvbnN0IGltYWdlID0gcHJvY2Vzc0ZpbGUocGF0aCwgZmlsZSwgZXh0ZW5zaW9uKTtcblxuICAgIGltYWdlc1tpbWFnZS5uYW1lXSA9IGltYWdlLmRhdGE7XG5cbiAgICBvcHRpb25zPy5sb2c/LihpbWFnZSk7XG4gIH1cblxuICByZXR1cm4gaW1hZ2VzO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvZGlmeUltYWdlc1N5bmMgPSAocGF0aCwgb3B0aW9ucyA9IHt9KSA9PiB7XG4gIGlmICghaXNPYmplY3Qob3B0aW9ucykpIHtcbiAgICBvcHRpb25zID0ge307XG4gIH1cblxuICBjb25zdCBmaWxlcyA9IHJlYWRkaXJTeW5jKHBhdGgpO1xuXG4gIHJldHVybiBwcm9jZXNzRmlsZXMocGF0aCwgZmlsZXMsIG9wdGlvbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvZGlmeUltYWdlcyA9IChwYXRoLCBvcHRpb25zID0ge30pID0+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB0cnkge1xuICAgICAgcmVzb2x2ZShjb2RpZnlJbWFnZXNTeW5jKHBhdGgsIG9wdGlvbnMpKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIHJlamVjdChlcnIpO1xuICAgIH1cbiAgfSk7XG59O1xuIl19
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.codifyImagesSync=exports.codifyImages=void 0;var _path=require("path");var _fs=require("fs");var _lodash=_interopRequireDefault(require("lodash.camelcase"));var _miniSvgDataUri=_interopRequireDefault(require("mini-svg-data-uri"));function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}const svgExtension=".svg";const supportedMimeTypes={".jpg":"image/jpeg",".jpeg":"image/jpeg",".png":"image/png",".gif":"image/gif",".webp":"image/webp",".svg":"image/svg+xml"};const isObject=value=>{return Object.prototype.toString.call(value)==="[object Object]"};const getFormat=(isSvg,options)=>{return isSvg&&(options===null||options===void 0?void 0:options.forceBase64)!==true?"utf-8":"base64"};const sanitizeFileData=data=>{return data.replace(/[\r\n]+/gm,"")};const buildDataUri=(isSvg,source,mime,format,options)=>{return isSvg&&(options===null||options===void 0?void 0:options.forceBase64)!==true?(0,_miniSvgDataUri.default)(source).replace(/'/g,"\""):`data:${mime};${format},${source}`};const isSupported=(file,extension)=>{return extension!==file&&supportedMimeTypes[extension]!==undefined};const getImageDataUri=(path,mime,isSvg,options)=>{const format=getFormat(isSvg,options);const source=sanitizeFileData((0,_fs.readFileSync)(path,format));return buildDataUri(isSvg,source,mime,format,options)};const processFile=(path,file,extension,options)=>{const mime=supportedMimeTypes[extension];const isSvg=mime===supportedMimeTypes[svgExtension];const filePath=(0,_path.resolve)(path,file);return{path:filePath,name:(0,_lodash.default)((0,_path.basename)(file)),data:getImageDataUri(filePath,mime,isSvg,options)}};const processFiles=(path,files,options)=>{const images={};for(const file of files){var _options$log;const extension=(0,_path.extname)(file);if(!isSupported(file,extension)){continue}const image=processFile(path,file,extension,options);images[image.name]=image.data;options===null||options===void 0?void 0:(_options$log=options.log)===null||_options$log===void 0?void 0:_options$log.call(options,image)}return images};const codifyImagesSync=(path,options={})=>{if(!isObject(options)){options=null}const files=(0,_fs.readdirSync)(path);return processFiles(path,files,options)};exports.codifyImagesSync=codifyImagesSync;const codifyImages=(path,options={})=>{return new Promise((resolve,reject)=>{try{resolve(codifyImagesSync(path,options))}catch(err){reject(err)}})};exports.codifyImages=codifyImages;
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9jb2RpZnktaW1hZ2VzLmpzIl0sIm5hbWVzIjpbInN2Z0V4dGVuc2lvbiIsInN1cHBvcnRlZE1pbWVUeXBlcyIsImlzT2JqZWN0IiwidmFsdWUiLCJPYmplY3QiLCJwcm90b3R5cGUiLCJ0b1N0cmluZyIsImNhbGwiLCJnZXRGb3JtYXQiLCJpc1N2ZyIsIm9wdGlvbnMiLCJmb3JjZUJhc2U2NCIsInNhbml0aXplRmlsZURhdGEiLCJkYXRhIiwicmVwbGFjZSIsImJ1aWxkRGF0YVVyaSIsInNvdXJjZSIsIm1pbWUiLCJmb3JtYXQiLCJpc1N1cHBvcnRlZCIsImZpbGUiLCJleHRlbnNpb24iLCJ1bmRlZmluZWQiLCJnZXRJbWFnZURhdGFVcmkiLCJwYXRoIiwicHJvY2Vzc0ZpbGUiLCJmaWxlUGF0aCIsIm5hbWUiLCJwcm9jZXNzRmlsZXMiLCJmaWxlcyIsImltYWdlcyIsImltYWdlIiwibG9nIiwiY29kaWZ5SW1hZ2VzU3luYyIsImNvZGlmeUltYWdlcyIsIlByb21pc2UiLCJyZXNvbHZlIiwicmVqZWN0IiwiZXJyIl0sIm1hcHBpbmdzIjoiMkhBQUEsMEJBQ0Esc0JBQ0EsZ0VBQ0EseUUsa0ZBRUEsS0FBTUEsQ0FBQUEsWUFBWSxDQUFHLE1BQXJCLENBQ0EsS0FBTUMsQ0FBQUEsa0JBQWtCLENBQUcsQ0FDekIsT0FBUSxZQURpQixDQUV6QixRQUFTLFlBRmdCLENBR3pCLE9BQVEsV0FIaUIsQ0FJekIsT0FBUSxXQUppQixDQUt6QixRQUFTLFlBTGdCLENBTXpCLE9BQVEsZUFOaUIsQ0FBM0IsQ0FTQSxLQUFNQyxDQUFBQSxRQUFRLENBQUdDLEtBQUssRUFBSSxDQUN4QixNQUFPQyxDQUFBQSxNQUFNLENBQUNDLFNBQVAsQ0FBaUJDLFFBQWpCLENBQTBCQyxJQUExQixDQUErQkosS0FBL0IsSUFBMEMsaUJBQ2xELENBRkQsQ0FJQSxLQUFNSyxDQUFBQSxTQUFTLENBQUcsQ0FBQ0MsS0FBRCxDQUFRQyxPQUFSLEdBQW9CLENBQ3BDLE1BQU9ELENB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QUVBSCxPQUFPLE9BQVAsRUFBQUEsT0FBTyxTQUFQLHNCQUFBQSxPQUFPLENBQUVzQixHQUFULHlEQUFBdEIsT0FBTyxDQUFRcUIsS0FBUixDQUNSLENBRUQsTUFBT0QsQ0FBQUEsTUFDUixDQWxCRCxDQW9CTyxLQUFNRyxDQUFBQSxnQkFBZ0IsQ0FBRyxDQUFDVCxJQUFELENBQU9kLE9BQU8sQ0FBRyxFQUFqQixHQUF3QixDQUN0RCxHQUFJLENBQUNSLFFBQVEsQ0FBQ1EsT0FBRCxDQUFiLENBQXdCLENBQ3RCQSxPQUFPLENBQUcsSUFDWCxDQUVELEtBQU1tQixDQUFBQSxLQUFLLENBQUcsb0JBQVlMLElBQVosQ0FBZCxDQUVBLE1BQU9JLENBQUFBLFlBQVksQ0FBQ0osSUFBRCxDQUFPSyxLQUFQLENBQWNuQixPQUFkLENBQ3BCLENBUk0sQywwQ0FVQSxLQUFNd0IsQ0FBQUEsWUFBWSxDQUFHLENBQUNWLElBQUQsQ0FBT2QsT0FBTyxDQUFHLEVBQWpCLEdBQXdCLENBQ2xELE1BQU8sSUFBSXlCLENBQUFBLE9BQUosQ0FBWSxDQUFDQyxPQUFELENBQVVDLE1BQVYsR0FBcUIsQ0FDdEMsR0FBSSxDQUNGRCxPQUFPLENBQUNILGdCQUFnQixDQUFDVCxJQUFELENBQU9kLE9BQVAsQ0FBakIsQ0FDUixDQUFDLE1BQU80QixHQUFQLENBQVksQ0FDWkQsTUFBTSxDQUFDQyxHQUFELENBQ1AsQ0FDRixDQU5NLENBT1IsQ0FSTSxDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYmFzZW5hbWUsIGV4dG5hbWUsIHJlc29sdmUgYXMgcmVzb2x2ZVBhdGggfSBmcm9tICdwYXRoJztcbmltcG9ydCB7IHJlYWRkaXJTeW5jLCByZWFkRmlsZVN5bmMgfSBmcm9tICdmcyc7XG5pbXBvcnQgY2FtZWxDYXNlIGZyb20gJ2xvZGFzaC5jYW1lbGNhc2UnO1xuaW1wb3J0IHN2Z1RvTWluaURhdGFVUkkgZnJvbSAnbWluaS1zdmctZGF0YS11cmknO1xuXG5jb25zdCBzdmdFeHRlbnNpb24gPSAnLnN2Zyc7XG5jb25zdCBzdXBwb3J0ZWRNaW1lVHlwZXMgPSB7XG4gICcuanBnJzogJ2ltYWdlL2pwZWcnLFxuICAnLmpwZWcnOiAnaW1hZ2UvanBlZycsXG4gICcucG5nJzogJ2ltYWdlL3BuZycsXG4gICcuZ2lmJzogJ2ltYWdlL2dpZicsXG4gICcud2VicCc6ICdpbWFnZS93ZWJwJyxcbiAgJy5zdmcnOiAnaW1hZ2Uvc3ZnK3htbCdcbn07XG5cbmNvbnN0IGlzT2JqZWN0ID0gdmFsdWUgPT4ge1xuICByZXR1cm4gT2JqZWN0LnByb3RvdHlwZS50b1N0cmluZy5jYWxsKHZhbHVlKSA9PT0gJ1tvYmplY3QgT2JqZWN0XSc7XG59O1xuXG5jb25zdCBnZXRGb3JtYXQgPSAoaXNTdmcsIG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIGlzU3ZnICYmIG9wdGlvbnM/LmZvcmNlQmFzZTY0ICE9PSB0cnVlID8gJ3V0Zi04JyA6ICdiYXNlNjQnO1xufTtcblxuY29uc3Qgc2FuaXRpemVGaWxlRGF0YSA9IGRhdGEgPT4ge1xuICByZXR1cm4gZGF0YS5yZXBsYWNlKC9bXFxyXFxuXSsvZ20sICcnKTtcbn07XG5cbmNvbnN0IGJ1aWxkRGF0YVVyaSA9IChpc1N2Zywgc291cmNlLCBtaW1lLCBmb3JtYXQsIG9wdGlvbnMpID0+IHtcbiAgcmV0dXJuIGlzU3ZnICYmIG9wdGlvbnM/LmZvcmNlQmFzZTY0ICE9PSB0cnVlID9cbiAgICBzdmdUb01pbmlEYXRhVVJJKHNvdXJjZSkucmVwbGFjZSgvJy9nLCAnXCInKSA6XG4gICAgYGRhdGE6JHttaW1lfTske2Zvcm1hdH0sJHtzb3VyY2V9YDtcbn07XG5cbmNvbnN0IGlzU3VwcG9ydGVkID0gKGZpbGUsIGV4dGVuc2lvbikgPT4ge1xuICByZXR1cm4gZXh0ZW5zaW9uICE9PSBmaWxlICYmIHN1cHBvcnRlZE1pbWVUeXBlc1tleHRlbnNpb25dICE9PSB1bmRlZmluZWQ7XG59O1xuXG5jb25zdCBnZXRJbWFnZURhdGFVcmkgPSAocGF0aCwgbWltZSwgaXNTdmcsIG9wdGlvbnMpID0+IHtcbiAgY29uc3QgZm9ybWF0ID0gZ2V0Rm9ybWF0KGlzU3ZnLCBvcHRpb25zKTtcbiAgY29uc3Qgc291cmNlID0gc2FuaXRpemVGaWxlRGF0YShyZWFkRmlsZVN5bmMocGF0aCwgZm9ybWF0KSk7XG5cbiAgcmV0dXJuIGJ1aWxkRGF0YVVyaShpc1N2Zywgc291cmNlLCBtaW1lLCBmb3JtYXQsIG9wdGlvbnMpO1xufTtcblxuY29uc3QgcHJvY2Vzc0ZpbGUgPSAocGF0aCwgZmlsZSwgZXh0ZW5zaW9uLCBvcHRpb25zKSA9PiB7XG4gIGNvbnN0IG1pbWUgPSBzdXBwb3J0ZWRNaW1lVHlwZXNbZXh0ZW5zaW9uXTtcbiAgY29uc3QgaXNTdmcgPSBtaW1lID09PSBzdXBwb3J0ZWRNaW1lVHlwZXNbc3ZnRXh0ZW5zaW9uXTtcbiAgY29uc3QgZmlsZVBhdGggPSByZXNvbHZlUGF0aChwYXRoLCBmaWxlKTtcblxuICByZXR1cm4ge1xuICAgIHBhdGg6IGZpbGVQYXRoLFxuICAgIG5hbWU6IGNhbWVsQ2FzZShiYXNlbmFtZShmaWxlKSksXG4gICAgZGF0YTogZ2V0SW1hZ2VEYXRhVXJpKGZpbGVQYXRoLCBtaW1lLCBpc1N2Zywgb3B0aW9ucylcbiAgfTtcbn07XG5cbmNvbnN0IHByb2Nlc3NGaWxlcyA9IChwYXRoLCBmaWxlcywgb3B0aW9ucykgPT4ge1xuICBjb25zdCBpbWFnZXMgPSB7fTtcblxuICBmb3IgKGNvbnN0IGZpbGUgb2YgZmlsZXMpIHtcbiAgICBjb25zdCBleHRlbnNpb24gPSBleHRuYW1lKGZpbGUpO1xuXG4gICAgaWYgKCFpc1N1cHBvcnRlZChmaWxlLCBleHRlbnNpb24pKSB7XG4gICAgICBjb250aW51ZTtcbiAgICB9XG5cbiAgICBjb25zdCBpbWFnZSA9IHByb2Nlc3NGaWxlKHBhdGgsIGZpbGUsIGV4dGVuc2lvbiwgb3B0aW9ucyk7XG5cbiAgICBpbWFnZXNbaW1hZ2UubmFtZV0gPSBpbWFnZS5kYXRhO1xuXG4gICAgb3B0aW9ucz8ubG9nPy4oaW1hZ2UpO1xuICB9XG5cbiAgcmV0dXJuIGltYWdlcztcbn07XG5cbmV4cG9ydCBjb25zdCBjb2RpZnlJbWFnZXNTeW5jID0gKHBhdGgsIG9wdGlvbnMgPSB7fSkgPT4ge1xuICBpZiAoIWlzT2JqZWN0KG9wdGlvbnMpKSB7XG4gICAgb3B0aW9ucyA9IG51bGw7XG4gIH1cblxuICBjb25zdCBmaWxlcyA9IHJlYWRkaXJTeW5jKHBhdGgpO1xuXG4gIHJldHVybiBwcm9jZXNzRmlsZXMocGF0aCwgZmlsZXMsIG9wdGlvbnMpO1xufTtcblxuZXhwb3J0IGNvbnN0IGNvZGlmeUltYWdlcyA9IChwYXRoLCBvcHRpb25zID0ge30pID0+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB0cnkge1xuICAgICAgcmVzb2x2ZShjb2RpZnlJbWFnZXNTeW5jKHBhdGgsIG9wdGlvbnMpKTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIHJlamVjdChlcnIpO1xuICAgIH1cbiAgfSk7XG59O1xuIl19
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "codify-images",
3
- "version": "1.0.1",
4
- "description": "Convert directory of images to encoded JavaScript variables",
3
+ "version": "1.1.0",
4
+ "description": "Quick and easy tool for converting a set of images into inline JavaScript",
5
5
  "main": "dist/index.js",
6
6
  "bin": {
7
7
  "codify-images": "./dist/cli.js"