codify-images 2.0.2 → 2.0.3

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/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) 2023 Devon Powell
3
+ Copyright (c) 2024 Devon Powell
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
package/README.md CHANGED
@@ -4,7 +4,6 @@
4
4
  [![Version][Version Badge]][Version Package]
5
5
  [![Release][Release Badge]][Release Workflow]
6
6
  [![Coverage][Coverage Badge]][Coverage Report]
7
- [![Vulnerabilities][Vulnerabilities Badge]][Vulnerabilities Report]
8
7
  [![Node Version][Node Version Badge]](package.json#L72)
9
8
 
10
9
  Quick and easy tool for converting a set of images into inline JavaScript.
@@ -133,22 +132,22 @@ npm test
133
132
  npm run test:unit
134
133
  ```
135
134
 
136
- ### Formatting
135
+ ### Fixing
137
136
 
138
- Execute formatters via `npm`.
137
+ Execute fixers via `npm`.
139
138
 
140
139
  ```console
141
140
  # javascript, markdown and package.json
142
- npm run format
141
+ npm run fix
143
142
 
144
143
  # javascript only
145
- npm run format:js
144
+ npm run fix:js
146
145
 
147
146
  # markdown only
148
- npm run format:md
147
+ npm run fix:md
149
148
 
150
149
  # package.json only
151
- npm run format:pkg
150
+ npm run fix:pkg
152
151
  ```
153
152
 
154
153
  ### Building
@@ -168,6 +167,4 @@ npm run build
168
167
  [Release Workflow]: https://github.com/devpow112/codify-images/actions/workflows/release.yml?query=branch%3Amain
169
168
  [Coverage Badge]: https://img.shields.io/coveralls/github/devpow112/codify-images/main?label=Coverage
170
169
  [Coverage Report]: https://coveralls.io/github/devpow112/codify-images?branch=main
171
- [Vulnerabilities Badge]: https://img.shields.io/snyk/vulnerabilities/github/devpow112/codify-images?label=Vulnerabilities
172
- [Vulnerabilities Report]: https://snyk.io/test/github/devpow112/codify-images
173
170
  [Mini SVG Data]: https://www.npmjs.com/package/mini-svg-data-uri
package/dist/coa.js CHANGED
@@ -1,2 +1,2 @@
1
1
  "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.setUpProgram=void 0;var _package=require("../package.json");var _commander=require("commander");var _fs=require("fs");var _chalk=_interopRequireDefault(require("chalk"));var _codifyImages=require("./codify-images.js");var _mkdirp=require("mkdirp");var _path=require("path");function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{default:obj}}const{blue,green,red,yellow}=_chalk.default;const mkdirpSync=_mkdirp.mkdirp.sync;const generateStart=options=>{let output=options.banner===true?"// auto-generated\n":"";if(options.es===5){output+="module.exports = {\n"}return output};const generateLine=(name,data,options)=>{const adjustedData=options.doubleQuotes!==true?`'${data.replace(/'/g,"\\'")}'`:`"${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)=>{mkdirpSync(options.output);(0,_fs.writeFileSync)(outputPath,output,{encoding:"utf-8"})};const logStart=message=>{console.log(yellow(message));console.group()};const logInfo=message=>{console.log(blue(message))};const logError=message=>{console.groupEnd();console.log(red(`error: ${message}`))};const logProcessed=(path,name)=>{logInfo(`processed image (${path} => ${name})`)};const logEnd=message=>{console.groupEnd();console.log(green(message))};const generate=options=>{logStart(yellow(`generating exports (${options.input}) ...`));let output=generateStart(options);const images=(0,_codifyImages.codifyImagesSync)(options.input,{log:logProcessed,svgMode:options.svgMode});if(Object.keys(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 setUpProgram=program=>{program.name(_package.name).version(_package.version).showHelpAfterError().configureOutput({outputError:(message,write)=>write(red(message))}).argument("<input path>","path to where image files reside",value=>{try{const path=(0,_path.resolve)(value);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("-d, --double-quotes","Use double quotes for output instead of single quotes",false).option("-o, --output <path>","path to write generated files",value=>(0,_path.resolve)(value),"generated").option("-e, --es <version>","version of ESM to generate",value=>{const parsedValue=customParseInt(value);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),1).option("-B, --no-banner","do not include banner comment at top of generated file").addOption(new _commander.Option("-t, --indent-type <type>","type of indent to output").choices(["tab","space"]).default("tab")).addOption(new _commander.Option("-s, --svg-mode <mode>","output mode to use for SVG images").choices(["base64","uri","mini","mini-srcset"]).default("base64")).action((input,opts)=>{if(opts.output==="generated"){opts.output=(0,_path.resolve)(opts.output)}try{generate({input,...opts})}catch(err){logError(err.message);throw err}})};exports.setUpProgram=setUpProgram;
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_package","require","_commander","_fs","_chalk","_interopRequireDefault","_codifyImages","_mkdirp","_path","obj","__esModule","default","blue","green","red","yellow","chalk","mkdirpSync","mkdirp","sync","generateStart","options","output","banner","es","generateLine","name","data","adjustedData","doubleQuotes","replace","indentType","indent","repeat","indentCount","generateLineEnding","last","generateEnd","writeOutput","outputPath","writeFileSync","encoding","logStart","message","console","log","group","logInfo","logError","groupEnd","logProcessed","path","logEnd","generate","input","images","codifyImagesSync","svgMode","Object","keys","length","Error","index","key","resolve","customParseInt","value","parsedValue","parseInt","isNaN","InvalidArgumentError","setUpProgram","program","cliName","version","cliVersion","showHelpAfterError","configureOutput","outputError","write","argument","stat","statSync","isDirectory","_","option","choicesEs","includes","choices","join","addOption","Option","action","opts","err","exports"],"sources":["../src/coa.js"],"sourcesContent":["import { name as cliName, version as cliVersion } from '../package.json';\nimport { InvalidArgumentError, Option } from 'commander';\nimport { statSync, writeFileSync } from 'fs';\nimport chalk from 'chalk';\nimport { codifyImagesSync } from './codify-images.js';\nimport { mkdirp } from 'mkdirp';\nimport { resolve } from 'path';\n\nconst { blue, green, red, yellow } = chalk;\nconst mkdirpSync = mkdirp.sync;\n\nconst generateStart = options => {\n  let output = options.banner === true ? '// auto-generated\\n' : '';\n\n  if (options.es === 5) {\n    output += 'module.exports = {\\n';\n  }\n\n  return output;\n};\n\nconst generateLine = (name, data, options) => {\n  const adjustedData = options.doubleQuotes !== true ?\n    `'${data.replace(/'/g, '\\\\\\'')}'` :\n    `\"${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  mkdirpSync(options.output);\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.groupEnd();\n  console.log(red(`error: ${message}`));\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, svgMode: options.svgMode }\n  );\n\n  if (Object.keys(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\nexport const setUpProgram = program => {\n  program\n    .name(cliName)\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        try {\n          const path = resolve(value);\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      '-d, --double-quotes',\n      'Use double quotes for output instead of single quotes',\n      false\n    )\n    .option(\n      '-o, --output <path>',\n      'path to write generated files',\n      value => resolve(value),\n      'generated'\n    )\n    .option(\n      '-e, --es <version>',\n      'version of ESM to generate',\n      value => {\n        const parsedValue = customParseInt(value);\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),\n      1\n    )\n    .option(\n      '-B, --no-banner',\n      'do not include banner comment at top of generated file'\n    )\n    .addOption(\n      new Option('-t, --indent-type <type>', 'type of indent to output')\n        .choices(['tab', 'space'])\n        .default('tab')\n    )\n    .addOption(\n      new Option('-s, --svg-mode <mode>', 'output mode to use for SVG images')\n        .choices(['base64', 'uri', 'mini', 'mini-srcset'])\n        .default('base64')\n    )\n    .action((input, opts) => {\n      if (opts.output === 'generated') {\n        opts.output = resolve(opts.output);\n      }\n\n      try {\n        generate({ input, ...opts });\n      } catch (err) {\n        logError(err.message);\n\n        throw err;\n      }\n    });\n};\n"],"mappings":"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"}
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_package","require","_commander","_fs","_chalk","_interopRequireDefault","_codifyImages","_mkdirp","_path","obj","__esModule","default","blue","green","red","yellow","chalk","mkdirpSync","mkdirp","sync","generateStart","options","output","banner","es","generateLine","name","data","adjustedData","doubleQuotes","replace","indentType","indent","repeat","indentCount","generateLineEnding","last","generateEnd","writeOutput","outputPath","writeFileSync","encoding","logStart","message","console","log","group","logInfo","logError","groupEnd","logProcessed","path","logEnd","generate","input","images","codifyImagesSync","svgMode","Object","keys","length","Error","index","key","resolve","customParseInt","value","parsedValue","parseInt","isNaN","InvalidArgumentError","setUpProgram","program","cliName","version","cliVersion","showHelpAfterError","configureOutput","outputError","write","argument","stat","statSync","isDirectory","_","option","choicesEs","includes","choices","join","addOption","Option","action","opts","err","exports"],"sources":["../src/coa.js"],"sourcesContent":["import { name as cliName, version as cliVersion } from '../package.json';\nimport { InvalidArgumentError, Option } from 'commander';\nimport { statSync, writeFileSync } from 'fs';\nimport chalk from 'chalk';\nimport { codifyImagesSync } from './codify-images.js';\nimport { mkdirp } from 'mkdirp';\nimport { resolve } from 'path';\n\nconst { blue, green, red, yellow } = chalk;\nconst mkdirpSync = mkdirp.sync;\n\nconst generateStart = options => {\n  let output = options.banner === true ? '// auto-generated\\n' : '';\n\n  if (options.es === 5) {\n    output += 'module.exports = {\\n';\n  }\n\n  return output;\n};\n\nconst generateLine = (name, data, options) => {\n  const adjustedData = options.doubleQuotes !== true ?\n    `'${data.replace(/'/g, '\\\\\\'')}'` :\n    `\"${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  mkdirpSync(options.output);\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.groupEnd();\n  console.log(red(`error: ${message}`));\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, svgMode: options.svgMode }\n  );\n\n  if (Object.keys(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\nexport const setUpProgram = program => {\n  program\n    .name(cliName)\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        try {\n          const path = resolve(value);\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      '-d, --double-quotes',\n      'Use double quotes for output instead of single quotes',\n      false\n    )\n    .option(\n      '-o, --output <path>',\n      'path to write generated files',\n      value => resolve(value),\n      'generated'\n    )\n    .option(\n      '-e, --es <version>',\n      'version of ESM to generate',\n      value => {\n        const parsedValue = customParseInt(value);\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),\n      1\n    )\n    .option(\n      '-B, --no-banner',\n      'do not include banner comment at top of generated file'\n    )\n    .addOption(\n      new Option('-t, --indent-type <type>', 'type of indent to output')\n        .choices(['tab', 'space'])\n        .default('tab')\n    )\n    .addOption(\n      new Option('-s, --svg-mode <mode>', 'output mode to use for SVG images')\n        .choices(['base64', 'uri', 'mini', 'mini-srcset'])\n        .default('base64')\n    )\n    .action((input, opts) => {\n      if (opts.output === 'generated') {\n        opts.output = resolve(opts.output);\n      }\n\n      try {\n        generate({ input, ...opts });\n      } catch (err) {\n        logError(err.message);\n\n        throw err;\n      }\n    });\n};\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.default=exports.codifyImagesSync=exports.codifyImages=void 0;var errors=_interopRequireWildcard(require("./errors.js"));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}}function _getRequireWildcardCache(nodeInterop){if(typeof WeakMap!=="function")return null;var cacheBabelInterop=new WeakMap;var cacheNodeInterop=new WeakMap;return(_getRequireWildcardCache=function(nodeInterop){return nodeInterop?cacheNodeInterop:cacheBabelInterop})(nodeInterop)}function _interopRequireWildcard(obj,nodeInterop){if(!nodeInterop&&obj&&obj.__esModule){return obj}if(obj===null||typeof obj!=="object"&&typeof obj!=="function"){return{default:obj}}var cache=_getRequireWildcardCache(nodeInterop);if(cache&&cache.has(obj)){return cache.get(obj)}var newObj={};var hasPropertyDescriptor=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var key in obj){if(key!=="default"&&Object.prototype.hasOwnProperty.call(obj,key)){var desc=hasPropertyDescriptor?Object.getOwnPropertyDescriptor(obj,key):null;if(desc&&(desc.get||desc.set)){Object.defineProperty(newObj,key,desc)}else{newObj[key]=obj[key]}}}newObj.default=obj;if(cache){cache.set(obj,newObj)}return newObj}const{InvalidPathError,InvalidSvgModeError,UnsupportedTypeError}=errors;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 svgModes=["base64","uri","mini","mini-srcset"];const isObject=value=>{return Object.prototype.toString.call(value)==="[object Object]"};const getEncoding=(isSvg,options)=>{if(isSvg){return options.svgMode}return"base64"};const getFormat=encoding=>{switch(encoding){case"mini":case"mini-srcset":case"uri":return"utf-8";default:return"base64";}};const sanitizeFileData=data=>{return data.replace(/[\r\n]+/gm,"")};const buildDataUri=(source,mime,encoding)=>{if(encoding==="uri"){return`data:${mime};${encodeURIComponent(source)}`}else if(encoding==="mini"){return(0,_miniSvgDataUri.default)(source)}else if(encoding==="mini-srcset"){return _miniSvgDataUri.default.toSrcset(source)}return`data:${mime};${encoding},${source}`};const isSupported=extension=>{return supportedMimeTypes[extension]!==undefined};const getImageDataUri=(path,mime,isSvg,options)=>{const encoding=getEncoding(isSvg,options);const format=getFormat(encoding);const source=sanitizeFileData((0,_fs.readFileSync)(path,format));return buildDataUri(source,mime,encoding)};const processFile=(path,extension,options)=>{const mime=supportedMimeTypes[extension];const isSvg=mime===supportedMimeTypes[svgExtension];return{path,name:(0,_lodash.default)((0,_path.basename)(path)),data:getImageDataUri(path,mime,isSvg,options)}};const processFiles=(path,files,options)=>{const images={};for(const file of files){const filePath=(0,_path.join)(path,file);const extension=(0,_path.extname)(filePath);if(!isSupported(extension)){if(options.ignoreUnsupportedTypes===true){continue}else{throw new UnsupportedTypeError(extension)}}const image=processFile(filePath,extension,options);images[image.name]=image.data;options.log?.(image.path,image.name)}return images};const hasObjectProperty=(options,property)=>{return Object.prototype.hasOwnProperty.call(options,property)};const sanitizeOptions=options=>{if(!isObject(options)){options={}}if(!hasObjectProperty(options,"ignoreUnsupportedTypes")){options.ignoreUnsupportedTypes=true}else{options.ignoreUnsupportedTypes=options.ignoreUnsupportedTypes===true}if(!hasObjectProperty(options,"svgMode")){options.svgMode="base64"}else if(!svgModes.includes(options.svgMode)){throw new InvalidSvgModeError(options.svgMode)}return options};const codifyImagesSync=(path,options={})=>{let files;try{files=(0,_fs.readdirSync)((0,_path.resolve)(path))}catch(_){throw new InvalidPathError(path)}return processFiles(path,files,sanitizeOptions(options))};exports.codifyImagesSync=codifyImagesSync;const codifyImages=(path,options={})=>{return new Promise((resolve,reject)=>{try{resolve(codifyImagesSync(path,sanitizeOptions(options)))}catch(err){reject(err)}})};exports.codifyImages=codifyImages;var _default={codifyImages,codifyImagesSync};exports.default=_default;
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["errors","_interopRequireWildcard","require","_path","_fs","_lodash","_interopRequireDefault","_miniSvgDataUri","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","InvalidPathError","InvalidSvgModeError","UnsupportedTypeError","svgExtension","supportedMimeTypes","svgModes","isObject","value","toString","getEncoding","isSvg","options","svgMode","getFormat","encoding","sanitizeFileData","data","replace","buildDataUri","source","mime","encodeURIComponent","svgToMiniDataURI","toSrcset","isSupported","extension","undefined","getImageDataUri","path","format","readFileSync","processFile","name","camelCase","basename","processFiles","files","images","file","filePath","join","extname","ignoreUnsupportedTypes","image","log","hasObjectProperty","property","sanitizeOptions","includes","codifyImagesSync","readdirSync","resolvePath","_","exports","codifyImages","Promise","resolve","reject","err","_default"],"sources":["../src/codify-images.js"],"sourcesContent":["import * as errors from './errors.js';\nimport { basename, extname, join, resolve as resolvePath } from 'path';\nimport { readdirSync, readFileSync } from 'fs';\nimport camelCase from 'lodash.camelcase';\nimport svgToMiniDataURI from 'mini-svg-data-uri';\n\nconst { InvalidPathError, InvalidSvgModeError, UnsupportedTypeError } = errors;\n\nconst svgExtension = '.svg';\nconst supportedMimeTypes = {\n  '.jpg': 'image/jpeg',\n  '.jpeg': 'image/jpeg',\n  '.png': 'image/png',\n  '.gif': 'image/gif',\n  '.webp': 'image/webp',\n  '.svg': 'image/svg+xml'\n};\nconst svgModes = ['base64', 'uri', 'mini', 'mini-srcset'];\n\nconst isObject = value => {\n  return Object.prototype.toString.call(value) === '[object Object]';\n};\n\nconst getEncoding = (isSvg, options) => {\n  if (isSvg) {\n    return options.svgMode;\n  }\n\n  return 'base64';\n};\n\nconst getFormat = encoding => {\n  switch (encoding) {\n    case 'mini':\n    case 'mini-srcset':\n    case 'uri':\n      return 'utf-8';\n    default:\n      return 'base64';\n  }\n};\n\nconst sanitizeFileData = data => {\n  return data.replace(/[\\r\\n]+/gm, '');\n};\n\nconst buildDataUri = (source, mime, encoding) => {\n  if (encoding === 'uri') {\n    return `data:${mime};${encodeURIComponent(source)}`;\n  } else if (encoding === 'mini') {\n    return svgToMiniDataURI(source);\n  } else if (encoding === 'mini-srcset') {\n    return svgToMiniDataURI.toSrcset(source);\n  }\n\n  return `data:${mime};${encoding},${source}`;\n};\n\nconst isSupported = extension => {\n  return supportedMimeTypes[extension] !== undefined;\n};\n\nconst getImageDataUri = (path, mime, isSvg, options) => {\n  const encoding = getEncoding(isSvg, options);\n  const format = getFormat(encoding);\n  const source = sanitizeFileData(readFileSync(path, format));\n\n  return buildDataUri(source, mime, encoding);\n};\n\nconst processFile = (path, extension, options) => {\n  const mime = supportedMimeTypes[extension];\n  const isSvg = mime === supportedMimeTypes[svgExtension];\n\n  return {\n    path,\n    name: camelCase(basename(path)),\n    data: getImageDataUri(path, mime, isSvg, options)\n  };\n};\n\nconst processFiles = (path, files, options) => {\n  const images = {};\n\n  for (const file of files) {\n    const filePath = join(path, file);\n    const extension = extname(filePath);\n\n    if (!isSupported(extension)) {\n      if (options.ignoreUnsupportedTypes === true) {\n        continue;\n      } else {\n        throw new UnsupportedTypeError(extension);\n      }\n    }\n\n    const image = processFile(filePath, extension, options);\n\n    images[image.name] = image.data;\n\n    options.log?.(image.path, image.name);\n  }\n\n  return images;\n};\n\nconst hasObjectProperty = (options, property) => {\n  return Object.prototype.hasOwnProperty.call(options, property);\n};\n\nconst sanitizeOptions = options => {\n  if (!isObject(options)) {\n    options = {};\n  }\n\n  if (!hasObjectProperty(options, 'ignoreUnsupportedTypes')) {\n    options.ignoreUnsupportedTypes = true;\n  } else {\n    options.ignoreUnsupportedTypes = options.ignoreUnsupportedTypes === true;\n  }\n\n  if (!hasObjectProperty(options, 'svgMode')) {\n    options.svgMode = 'base64';\n  } else if (!svgModes.includes(options.svgMode)) {\n    throw new InvalidSvgModeError(options.svgMode);\n  }\n\n  return options;\n};\n\nexport const codifyImagesSync = (path, options = {}) => {\n  let files;\n\n  try {\n    files = readdirSync(resolvePath(path));\n  } catch (_) {\n    throw new InvalidPathError(path);\n  }\n\n  return processFiles(path, files, sanitizeOptions(options));\n};\n\nexport const codifyImages = (path, options = {}) => {\n  return new Promise((resolve, reject) => {\n    try {\n      resolve(codifyImagesSync(path, sanitizeOptions(options)));\n    } catch (err) {\n      reject(err);\n    }\n  });\n};\n\nexport default {\n  codifyImages,\n  codifyImagesSync\n};\n"],"mappings":"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"}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.default=exports.codifyImagesSync=exports.codifyImages=void 0;var errors=_interopRequireWildcard(require("./errors.js"));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}}function _getRequireWildcardCache(nodeInterop){if(typeof WeakMap!=="function")return null;var cacheBabelInterop=new WeakMap;var cacheNodeInterop=new WeakMap;return(_getRequireWildcardCache=function(nodeInterop){return nodeInterop?cacheNodeInterop:cacheBabelInterop})(nodeInterop)}function _interopRequireWildcard(obj,nodeInterop){if(!nodeInterop&&obj&&obj.__esModule){return obj}if(obj===null||typeof obj!=="object"&&typeof obj!=="function"){return{default:obj}}var cache=_getRequireWildcardCache(nodeInterop);if(cache&&cache.has(obj)){return cache.get(obj)}var newObj={};var hasPropertyDescriptor=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var key in obj){if(key!=="default"&&Object.prototype.hasOwnProperty.call(obj,key)){var desc=hasPropertyDescriptor?Object.getOwnPropertyDescriptor(obj,key):null;if(desc&&(desc.get||desc.set)){Object.defineProperty(newObj,key,desc)}else{newObj[key]=obj[key]}}}newObj.default=obj;if(cache){cache.set(obj,newObj)}return newObj}const{InvalidPathError,InvalidSvgModeError,UnsupportedTypeError}=errors;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 svgModes=["base64","uri","mini","mini-srcset"];const isObject=value=>{return Object.prototype.toString.call(value)==="[object Object]"};const getEncoding=(isSvg,options)=>{if(isSvg){return options.svgMode}return"base64"};const getFormat=encoding=>{switch(encoding){case"mini":case"mini-srcset":case"uri":return"utf-8";default:return"base64"}};const sanitizeFileData=data=>{return data.replace(/[\r\n]+/gm,"")};const buildDataUri=(source,mime,encoding)=>{if(encoding==="uri"){return`data:${mime};${encodeURIComponent(source)}`}else if(encoding==="mini"){return(0,_miniSvgDataUri.default)(source)}else if(encoding==="mini-srcset"){return _miniSvgDataUri.default.toSrcset(source)}return`data:${mime};${encoding},${source}`};const isSupported=extension=>{return supportedMimeTypes[extension]!==undefined};const getImageDataUri=(path,mime,isSvg,options)=>{const encoding=getEncoding(isSvg,options);const format=getFormat(encoding);const source=sanitizeFileData((0,_fs.readFileSync)(path,format));return buildDataUri(source,mime,encoding)};const processFile=(path,extension,options)=>{const mime=supportedMimeTypes[extension];const isSvg=mime===supportedMimeTypes[svgExtension];return{path,name:(0,_lodash.default)((0,_path.basename)(path)),data:getImageDataUri(path,mime,isSvg,options)}};const processFiles=(path,files,options)=>{const images={};for(const file of files){const filePath=(0,_path.join)(path,file);const extension=(0,_path.extname)(filePath);if(!isSupported(extension)){if(options.ignoreUnsupportedTypes===true){continue}else{throw new UnsupportedTypeError(extension)}}const image=processFile(filePath,extension,options);images[image.name]=image.data;options.log?.(image.path,image.name)}return images};const hasObjectProperty=(options,property)=>{return Object.prototype.hasOwnProperty.call(options,property)};const sanitizeOptions=options=>{if(!isObject(options)){options={}}if(!hasObjectProperty(options,"ignoreUnsupportedTypes")){options.ignoreUnsupportedTypes=true}else{options.ignoreUnsupportedTypes=options.ignoreUnsupportedTypes===true}if(!hasObjectProperty(options,"svgMode")){options.svgMode="base64"}else if(!svgModes.includes(options.svgMode)){throw new InvalidSvgModeError(options.svgMode)}return options};const codifyImagesSync=(path,options={})=>{let files;try{files=(0,_fs.readdirSync)((0,_path.resolve)(path))}catch(_){throw new InvalidPathError(path)}return processFiles(path,files,sanitizeOptions(options))};exports.codifyImagesSync=codifyImagesSync;const codifyImages=(path,options={})=>{return new Promise((resolve,reject)=>{try{resolve(codifyImagesSync(path,sanitizeOptions(options)))}catch(err){reject(err)}})};exports.codifyImages=codifyImages;var _default={codifyImages,codifyImagesSync};exports.default=_default;
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["errors","_interopRequireWildcard","require","_path","_fs","_lodash","_interopRequireDefault","_miniSvgDataUri","obj","__esModule","default","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","InvalidPathError","InvalidSvgModeError","UnsupportedTypeError","svgExtension","supportedMimeTypes","svgModes","isObject","value","toString","getEncoding","isSvg","options","svgMode","getFormat","encoding","sanitizeFileData","data","replace","buildDataUri","source","mime","encodeURIComponent","svgToMiniDataURI","toSrcset","isSupported","extension","undefined","getImageDataUri","path","format","readFileSync","processFile","name","camelCase","basename","processFiles","files","images","file","filePath","join","extname","ignoreUnsupportedTypes","image","log","hasObjectProperty","property","sanitizeOptions","includes","codifyImagesSync","readdirSync","resolvePath","_","exports","codifyImages","Promise","resolve","reject","err","_default"],"sources":["../src/codify-images.js"],"sourcesContent":["import * as errors from './errors.js';\nimport { basename, extname, join, resolve as resolvePath } from 'path';\nimport { readdirSync, readFileSync } from 'fs';\nimport camelCase from 'lodash.camelcase';\nimport svgToMiniDataURI from 'mini-svg-data-uri';\n\nconst { InvalidPathError, InvalidSvgModeError, UnsupportedTypeError } = errors;\n\nconst svgExtension = '.svg';\nconst supportedMimeTypes = {\n  '.jpg': 'image/jpeg',\n  '.jpeg': 'image/jpeg',\n  '.png': 'image/png',\n  '.gif': 'image/gif',\n  '.webp': 'image/webp',\n  '.svg': 'image/svg+xml'\n};\nconst svgModes = ['base64', 'uri', 'mini', 'mini-srcset'];\n\nconst isObject = value => {\n  return Object.prototype.toString.call(value) === '[object Object]';\n};\n\nconst getEncoding = (isSvg, options) => {\n  if (isSvg) {\n    return options.svgMode;\n  }\n\n  return 'base64';\n};\n\nconst getFormat = encoding => {\n  switch (encoding) {\n    case 'mini':\n    case 'mini-srcset':\n    case 'uri':\n      return 'utf-8';\n    default:\n      return 'base64';\n  }\n};\n\nconst sanitizeFileData = data => {\n  return data.replace(/[\\r\\n]+/gm, '');\n};\n\nconst buildDataUri = (source, mime, encoding) => {\n  if (encoding === 'uri') {\n    return `data:${mime};${encodeURIComponent(source)}`;\n  } else if (encoding === 'mini') {\n    return svgToMiniDataURI(source);\n  } else if (encoding === 'mini-srcset') {\n    return svgToMiniDataURI.toSrcset(source);\n  }\n\n  return `data:${mime};${encoding},${source}`;\n};\n\nconst isSupported = extension => {\n  return supportedMimeTypes[extension] !== undefined;\n};\n\nconst getImageDataUri = (path, mime, isSvg, options) => {\n  const encoding = getEncoding(isSvg, options);\n  const format = getFormat(encoding);\n  const source = sanitizeFileData(readFileSync(path, format));\n\n  return buildDataUri(source, mime, encoding);\n};\n\nconst processFile = (path, extension, options) => {\n  const mime = supportedMimeTypes[extension];\n  const isSvg = mime === supportedMimeTypes[svgExtension];\n\n  return {\n    path,\n    name: camelCase(basename(path)),\n    data: getImageDataUri(path, mime, isSvg, options)\n  };\n};\n\nconst processFiles = (path, files, options) => {\n  const images = {};\n\n  for (const file of files) {\n    const filePath = join(path, file);\n    const extension = extname(filePath);\n\n    if (!isSupported(extension)) {\n      if (options.ignoreUnsupportedTypes === true) {\n        continue;\n      } else {\n        throw new UnsupportedTypeError(extension);\n      }\n    }\n\n    const image = processFile(filePath, extension, options);\n\n    images[image.name] = image.data;\n\n    options.log?.(image.path, image.name);\n  }\n\n  return images;\n};\n\nconst hasObjectProperty = (options, property) => {\n  return Object.prototype.hasOwnProperty.call(options, property);\n};\n\nconst sanitizeOptions = options => {\n  if (!isObject(options)) {\n    options = {};\n  }\n\n  if (!hasObjectProperty(options, 'ignoreUnsupportedTypes')) {\n    options.ignoreUnsupportedTypes = true;\n  } else {\n    options.ignoreUnsupportedTypes = options.ignoreUnsupportedTypes === true;\n  }\n\n  if (!hasObjectProperty(options, 'svgMode')) {\n    options.svgMode = 'base64';\n  } else if (!svgModes.includes(options.svgMode)) {\n    throw new InvalidSvgModeError(options.svgMode);\n  }\n\n  return options;\n};\n\nexport const codifyImagesSync = (path, options = {}) => {\n  let files;\n\n  try {\n    files = readdirSync(resolvePath(path));\n  } catch (_) {\n    throw new InvalidPathError(path);\n  }\n\n  return processFiles(path, files, sanitizeOptions(options));\n};\n\nexport const codifyImages = (path, options = {}) => {\n  return new Promise((resolve, reject) => {\n    try {\n      resolve(codifyImagesSync(path, sanitizeOptions(options)));\n    } catch (err) {\n      reject(err);\n    }\n  });\n};\n\nexport default {\n  codifyImages,\n  codifyImagesSync\n};\n"],"mappings":"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"}
package/dist/errors.js CHANGED
@@ -1,2 +1,2 @@
1
1
  "use strict";Object.defineProperty(exports,"__esModule",{value:true});exports.UnsupportedTypeError=exports.InvalidSvgModeError=exports.InvalidPathError=void 0;class CodifyError extends Error{constructor(message,code,exitCode=1){super(message);this.code=`codifyImages.${code}`;this.exitCode=exitCode;this.nestedError=undefined}}class UnsupportedTypeError extends CodifyError{constructor(extension){super(`Type '${extension}' is not a supported image format`,"unsupportedTypeError");Error.captureStackTrace(this,this.constructor);this.name=this.constructor.name}}exports.UnsupportedTypeError=UnsupportedTypeError;class InvalidPathError extends CodifyError{constructor(path){super(`Path '${path}' is not a valid path`,"invalidPathError");Error.captureStackTrace(this,this.constructor);this.name=this.constructor.name}}exports.InvalidPathError=InvalidPathError;class InvalidSvgModeError extends CodifyError{constructor(mode){super(`SVG mode '${mode}' is not a valid mode`,"invalidSvgModeError");Error.captureStackTrace(this,this.constructor);this.name=this.constructor.name}}exports.InvalidSvgModeError=InvalidSvgModeError;
2
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDb2RpZnlFcnJvciIsIkVycm9yIiwiY29uc3RydWN0b3IiLCJtZXNzYWdlIiwiY29kZSIsImV4aXRDb2RlIiwibmVzdGVkRXJyb3IiLCJ1bmRlZmluZWQiLCJVbnN1cHBvcnRlZFR5cGVFcnJvciIsImV4dGVuc2lvbiIsImNhcHR1cmVTdGFja1RyYWNlIiwibmFtZSIsImV4cG9ydHMiLCJJbnZhbGlkUGF0aEVycm9yIiwicGF0aCIsIkludmFsaWRTdmdNb2RlRXJyb3IiLCJtb2RlIl0sInNvdXJjZXMiOlsiLi4vc3JjL2Vycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjbGFzcyBDb2RpZnlFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZSwgY29kZSwgZXhpdENvZGUgPSAxKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG5cbiAgICB0aGlzLmNvZGUgPSBgY29kaWZ5SW1hZ2VzLiR7Y29kZX1gO1xuICAgIHRoaXMuZXhpdENvZGUgPSBleGl0Q29kZTtcbiAgICB0aGlzLm5lc3RlZEVycm9yID0gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBVbnN1cHBvcnRlZFR5cGVFcnJvciBleHRlbmRzIENvZGlmeUVycm9yIHtcbiAgY29uc3RydWN0b3IoZXh0ZW5zaW9uKSB7XG4gICAgc3VwZXIoXG4gICAgICBgVHlwZSAnJHtleHRlbnNpb259JyBpcyBub3QgYSBzdXBwb3J0ZWQgaW1hZ2UgZm9ybWF0YCxcbiAgICAgICd1bnN1cHBvcnRlZFR5cGVFcnJvcidcbiAgICApO1xuXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG5cbiAgICB0aGlzLm5hbWUgPSB0aGlzLmNvbnN0cnVjdG9yLm5hbWU7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEludmFsaWRQYXRoRXJyb3IgZXh0ZW5kcyBDb2RpZnlFcnJvciB7XG4gIGNvbnN0cnVjdG9yKHBhdGgpIHtcbiAgICBzdXBlcihgUGF0aCAnJHtwYXRofScgaXMgbm90IGEgdmFsaWQgcGF0aGAsICdpbnZhbGlkUGF0aEVycm9yJyk7XG5cbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcblxuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgSW52YWxpZFN2Z01vZGVFcnJvciBleHRlbmRzIENvZGlmeUVycm9yIHtcbiAgY29uc3RydWN0b3IobW9kZSkge1xuICAgIHN1cGVyKGBTVkcgbW9kZSAnJHttb2RlfScgaXMgbm90IGEgdmFsaWQgbW9kZWAsICdpbnZhbGlkU3ZnTW9kZUVycm9yJyk7XG5cbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcblxuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiK0pBQUEsS0FBTSxDQUFBQSxXQUFXLFFBQVMsQ0FBQUMsS0FBTSxDQUM5QkMsV0FBV0EsQ0FBQ0MsT0FBTyxDQUFFQyxJQUFJLENBQUVDLFFBQVEsQ0FBRyxDQUFDLENBQUUsQ0FDdkMsS0FBSyxDQUFDRixPQUFPLENBQUMsQ0FFZCxJQUFJLENBQUNDLElBQUksQ0FBSSxnQkFBZUEsSUFBSyxFQUFDLENBQ2xDLElBQUksQ0FBQ0MsUUFBUSxDQUFHQSxRQUFRLENBQ3hCLElBQUksQ0FBQ0MsV0FBVyxDQUFHQyxTQUNyQixDQUNGLENBRU8sS0FBTSxDQUFBQyxvQkFBb0IsUUFBUyxDQUFBUixXQUFZLENBQ3BERSxXQUFXQSxDQUFDTyxTQUFTLENBQUUsQ0FDckIsS0FBSyxDQUNGLFNBQVFBLFNBQVUsbUNBQWtDLENBQ3JELHNCQUFzQixDQUN2QixDQUVEUixLQUFLLENBQUNTLGlCQUFpQixDQUFDLElBQUksQ0FBRSxJQUFJLENBQUNSLFdBQVcsQ0FBQyxDQUUvQyxJQUFJLENBQUNTLElBQUksQ0FBRyxJQUFJLENBQUNULFdBQVcsQ0FBQ1MsSUFDL0IsQ0FDRixDQUFDQyxPQUFBLENBQUFKLG9CQUFBLENBQUFBLG9CQUFBLENBRU0sS0FBTSxDQUFBSyxnQkFBZ0IsUUFBUyxDQUFBYixXQUFZLENBQ2hERSxXQUFXQSxDQUFDWSxJQUFJLENBQUUsQ0FDaEIsS0FBSyxDQUFFLFNBQVFBLElBQUssdUJBQXNCLENBQUUsa0JBQWtCLENBQUMsQ0FFL0RiLEtBQUssQ0FBQ1MsaUJBQWlCLENBQUMsSUFBSSxDQUFFLElBQUksQ0FBQ1IsV0FBVyxDQUFDLENBRS9DLElBQUksQ0FBQ1MsSUFBSSxDQUFHLElBQUksQ0FBQ1QsV0FBVyxDQUFDUyxJQUMvQixDQUNGLENBQUNDLE9BQUEsQ0FBQUMsZ0JBQUEsQ0FBQUEsZ0JBQUEsQ0FFTSxLQUFNLENBQUFFLG1CQUFtQixRQUFTLENBQUFmLFdBQVksQ0FDbkRFLFdBQVdBLENBQUNjLElBQUksQ0FBRSxDQUNoQixLQUFLLENBQUUsYUFBWUEsSUFBSyx1QkFBc0IsQ0FBRSxxQkFBcUIsQ0FBQyxDQUV0RWYsS0FBSyxDQUFDUyxpQkFBaUIsQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFDUixXQUFXLENBQUMsQ0FFL0MsSUFBSSxDQUFDUyxJQUFJLENBQUcsSUFBSSxDQUFDVCxXQUFXLENBQUNTLElBQy9CLENBQ0YsQ0FBQ0MsT0FBQSxDQUFBRyxtQkFBQSxDQUFBQSxtQkFBQSJ9
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJDb2RpZnlFcnJvciIsIkVycm9yIiwiY29uc3RydWN0b3IiLCJtZXNzYWdlIiwiY29kZSIsImV4aXRDb2RlIiwibmVzdGVkRXJyb3IiLCJ1bmRlZmluZWQiLCJVbnN1cHBvcnRlZFR5cGVFcnJvciIsImV4dGVuc2lvbiIsImNhcHR1cmVTdGFja1RyYWNlIiwibmFtZSIsImV4cG9ydHMiLCJJbnZhbGlkUGF0aEVycm9yIiwicGF0aCIsIkludmFsaWRTdmdNb2RlRXJyb3IiLCJtb2RlIl0sInNvdXJjZXMiOlsiLi4vc3JjL2Vycm9ycy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjbGFzcyBDb2RpZnlFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZSwgY29kZSwgZXhpdENvZGUgPSAxKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG5cbiAgICB0aGlzLmNvZGUgPSBgY29kaWZ5SW1hZ2VzLiR7Y29kZX1gO1xuICAgIHRoaXMuZXhpdENvZGUgPSBleGl0Q29kZTtcbiAgICB0aGlzLm5lc3RlZEVycm9yID0gdW5kZWZpbmVkO1xuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBVbnN1cHBvcnRlZFR5cGVFcnJvciBleHRlbmRzIENvZGlmeUVycm9yIHtcbiAgY29uc3RydWN0b3IoZXh0ZW5zaW9uKSB7XG4gICAgc3VwZXIoXG4gICAgICBgVHlwZSAnJHtleHRlbnNpb259JyBpcyBub3QgYSBzdXBwb3J0ZWQgaW1hZ2UgZm9ybWF0YCxcbiAgICAgICd1bnN1cHBvcnRlZFR5cGVFcnJvcidcbiAgICApO1xuXG4gICAgRXJyb3IuY2FwdHVyZVN0YWNrVHJhY2UodGhpcywgdGhpcy5jb25zdHJ1Y3Rvcik7XG5cbiAgICB0aGlzLm5hbWUgPSB0aGlzLmNvbnN0cnVjdG9yLm5hbWU7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIEludmFsaWRQYXRoRXJyb3IgZXh0ZW5kcyBDb2RpZnlFcnJvciB7XG4gIGNvbnN0cnVjdG9yKHBhdGgpIHtcbiAgICBzdXBlcihgUGF0aCAnJHtwYXRofScgaXMgbm90IGEgdmFsaWQgcGF0aGAsICdpbnZhbGlkUGF0aEVycm9yJyk7XG5cbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcblxuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZTtcbiAgfVxufVxuXG5leHBvcnQgY2xhc3MgSW52YWxpZFN2Z01vZGVFcnJvciBleHRlbmRzIENvZGlmeUVycm9yIHtcbiAgY29uc3RydWN0b3IobW9kZSkge1xuICAgIHN1cGVyKGBTVkcgbW9kZSAnJHttb2RlfScgaXMgbm90IGEgdmFsaWQgbW9kZWAsICdpbnZhbGlkU3ZnTW9kZUVycm9yJyk7XG5cbiAgICBFcnJvci5jYXB0dXJlU3RhY2tUcmFjZSh0aGlzLCB0aGlzLmNvbnN0cnVjdG9yKTtcblxuICAgIHRoaXMubmFtZSA9IHRoaXMuY29uc3RydWN0b3IubmFtZTtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiK0pBQUEsS0FBTSxDQUFBQSxXQUFXLFFBQVMsQ0FBQUMsS0FBTSxDQUM5QkMsV0FBV0EsQ0FBQ0MsT0FBTyxDQUFFQyxJQUFJLENBQUVDLFFBQVEsQ0FBRyxDQUFDLENBQUUsQ0FDdkMsS0FBSyxDQUFDRixPQUFPLENBQUMsQ0FFZCxJQUFJLENBQUNDLElBQUksQ0FBSSxnQkFBZUEsSUFBSyxFQUFDLENBQ2xDLElBQUksQ0FBQ0MsUUFBUSxDQUFHQSxRQUFRLENBQ3hCLElBQUksQ0FBQ0MsV0FBVyxDQUFHQyxTQUNyQixDQUNGLENBRU8sS0FBTSxDQUFBQyxvQkFBb0IsUUFBUyxDQUFBUixXQUFZLENBQ3BERSxXQUFXQSxDQUFDTyxTQUFTLENBQUUsQ0FDckIsS0FBSyxDQUNGLFNBQVFBLFNBQVUsbUNBQWtDLENBQ3JELHNCQUNGLENBQUMsQ0FFRFIsS0FBSyxDQUFDUyxpQkFBaUIsQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFDUixXQUFXLENBQUMsQ0FFL0MsSUFBSSxDQUFDUyxJQUFJLENBQUcsSUFBSSxDQUFDVCxXQUFXLENBQUNTLElBQy9CLENBQ0YsQ0FBQ0MsT0FBQSxDQUFBSixvQkFBQSxDQUFBQSxvQkFBQSxDQUVNLEtBQU0sQ0FBQUssZ0JBQWdCLFFBQVMsQ0FBQWIsV0FBWSxDQUNoREUsV0FBV0EsQ0FBQ1ksSUFBSSxDQUFFLENBQ2hCLEtBQUssQ0FBRSxTQUFRQSxJQUFLLHVCQUFzQixDQUFFLGtCQUFrQixDQUFDLENBRS9EYixLQUFLLENBQUNTLGlCQUFpQixDQUFDLElBQUksQ0FBRSxJQUFJLENBQUNSLFdBQVcsQ0FBQyxDQUUvQyxJQUFJLENBQUNTLElBQUksQ0FBRyxJQUFJLENBQUNULFdBQVcsQ0FBQ1MsSUFDL0IsQ0FDRixDQUFDQyxPQUFBLENBQUFDLGdCQUFBLENBQUFBLGdCQUFBLENBRU0sS0FBTSxDQUFBRSxtQkFBbUIsUUFBUyxDQUFBZixXQUFZLENBQ25ERSxXQUFXQSxDQUFDYyxJQUFJLENBQUUsQ0FDaEIsS0FBSyxDQUFFLGFBQVlBLElBQUssdUJBQXNCLENBQUUscUJBQXFCLENBQUMsQ0FFdEVmLEtBQUssQ0FBQ1MsaUJBQWlCLENBQUMsSUFBSSxDQUFFLElBQUksQ0FBQ1IsV0FBVyxDQUFDLENBRS9DLElBQUksQ0FBQ1MsSUFBSSxDQUFHLElBQUksQ0FBQ1QsV0FBVyxDQUFDUyxJQUMvQixDQUNGLENBQUNDLE9BQUEsQ0FBQUcsbUJBQUEsQ0FBQUEsbUJBQUEifQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "codify-images",
3
- "version": "2.0.2",
3
+ "version": "2.0.3",
4
4
  "description": "Quick and easy tool for converting a set of images into inline JavaScript",
5
5
  "keywords": [
6
6
  "image",
@@ -12,13 +12,13 @@
12
12
  },
13
13
  "repository": {
14
14
  "type": "git",
15
- "url": "https://github.com/devpow112/codify-images.git"
15
+ "url": "git+https://github.com/devpow112/codify-images.git"
16
16
  },
17
17
  "license": "MIT",
18
18
  "author": "Devon Powell <devon.f.powell@gmail.com>",
19
19
  "main": "dist/codify-images.js",
20
20
  "bin": {
21
- "codify-images": "./dist/cli.js"
21
+ "codify-images": "dist/cli.js"
22
22
  },
23
23
  "directories": {
24
24
  "test": "test"
@@ -29,44 +29,44 @@
29
29
  "scripts": {
30
30
  "prebuild": "rimraf dist/",
31
31
  "build": "babel --verbose --out-dir dist src",
32
- "lint": "run-s -s lint:git lint:js lint:md lint:pkg",
33
- "lint:js": "eslint .",
34
- "lint:md": "markdownlint .",
32
+ "lint": "run-s -s lint:git lint:js lint:md",
33
+ "lint:js": "eslint . --ext .js,.mjs,.cjs --ignore-path .gitignore",
34
+ "lint:md": "markdownlint . --ignore-path .gitignore",
35
35
  "lint:git": "commitlint --from origin/main --to HEAD",
36
36
  "lint:pkg": "sort-package-json --check",
37
- "format": "run-s -s format:js format:md format:pkg",
38
- "format:js": "npm run -s lint:js -- --fix",
39
- "format:md": "npm run -s lint:md -- --fix",
40
- "format:pkg": "sort-package-json",
37
+ "fix": "run-s -s fix:js fix:md fix:pkg",
38
+ "fix:js": "npm run -s lint:js -- --fix",
39
+ "fix:md": "npm run -s lint:md -- --fix",
40
+ "fix:pkg": "npm pkg fix && sort-package-json",
41
41
  "pretest": "rimraf test/.temp/",
42
42
  "test": "run-s -s lint test:unit",
43
43
  "test:unit": "nyc mocha test/unit/*.test.js"
44
44
  },
45
45
  "dependencies": {
46
46
  "chalk": "^4.1.2",
47
- "commander": "^11.1.0",
47
+ "commander": "^12.0.0",
48
48
  "lodash.camelcase": "^4.3.0",
49
49
  "mini-svg-data-uri": "^1.4.4",
50
50
  "mkdirp": "^3.0.1"
51
51
  },
52
52
  "devDependencies": {
53
- "@babel/cli": "^7.23.0",
54
- "@babel/register": "^7.22.15",
55
- "@commitlint/cli": "^17.7.2",
56
- "@devpow112/babel-config": "^1.1.2",
57
- "@devpow112/commitlint-config": "^2.0.0",
58
- "@devpow112/eslint-config": "^2.0.1",
59
- "@devpow112/semantic-release-config": "^2.1.2",
53
+ "@babel/cli": "^7.23.9",
54
+ "@babel/register": "^7.23.7",
55
+ "@commitlint/cli": "^18.6.1",
56
+ "@devpow112/babel-config": "^1.2.1",
57
+ "@devpow112/commitlint-config": "^2.0.1",
58
+ "@devpow112/eslint-config": "^2.0.3",
59
+ "@devpow112/semantic-release-config": "^2.2.3",
60
60
  "chai": "^4.3.10",
61
- "eslint": "^8.51.0",
62
- "markdownlint-cli": "^0.37.0",
63
- "mocha": "^10.2.0",
61
+ "eslint": "^8.57.0",
62
+ "markdownlint-cli": "^0.39.0",
63
+ "mocha": "^10.3.0",
64
64
  "npm-run-all": "^4.1.5",
65
65
  "nyc": "^15.1.0",
66
66
  "rimraf": "^5.0.5",
67
- "semantic-release": "^21.1.2",
68
- "sinon": "^16.1.0",
69
- "sort-package-json": "^2.6.0"
67
+ "semantic-release": "^23.0.3",
68
+ "sinon": "^17.0.1",
69
+ "sort-package-json": "^2.8.0"
70
70
  },
71
71
  "engines": {
72
72
  "node": ">=18"