@icon-magic/distribute
Advanced tools
Comparing version 2.2.5-beta.0 to 2.2.6-beta.0
@@ -196,2 +196,2 @@ "use strict"; | ||
exports.partitionAssetsForSprite = partitionAssetsForSprite; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-sprite.js","sourceRoot":"","sources":["../../src/create-sprite.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Asset,\n  SpriteConfig,\n  saveContentToFile\n} from '@icon-magic/icon-models';\nimport { Logger, logger } from '@icon-magic/logger';\nimport { DOMImplementation, DOMParser, XMLSerializer } from 'xmldom';\n\nimport { compareStrings, removeResolutionFromName } from './utils';\n\nconst LOGGER: Logger = logger('icon-magic:distribute:create-sprite');\nconst serializeToString = new XMLSerializer().serializeToString;\n\n/**\n * Creates a sprite and appends SVG icons\n * @param spriteName name of sprite file\n * @param assets assets to add to svg\n * @param groupByCategory (for sprite creation) whether to group by the category attribute\n * @param category the category of icon\n * @param spriteNames object for mapping sprite name to (and storing) svg document and element\n */\nexport async function addToSprite(\n  spriteName: string,\n  assets: Asset[],\n  groupByCategory: boolean,\n  category: string,\n  spriteNames: SpriteConfig\n): Promise<void> {\n  let DOCUMENT, svgEl;\n  const promises: void[] = [];\n  // If there's no existing sprite with that name\n  if (!spriteNames.hasOwnProperty(spriteName)) {\n    // Create a new Document and SVG element for the sprite\n    ({ DOCUMENT, svgEl } = createSVGDoc(spriteName));\n    // Store the Document and the SVGEl\n    // We need the Document because we we're using methods like\n    // `createElement` and `getElementById` that can only be\n    // called on the Document\n    spriteNames[spriteName] = { DOCUMENT, svgEl };\n  } else {\n    // If one exists, grab the document and the containing <svg> element\n    ({ DOCUMENT, svgEl } = spriteNames[spriteName]);\n  }\n\n  // Sort assets (variants) within the icon first\n  const sortedAssets = assets.sort((assetOne: Asset, assetTwo: Asset) => {\n    return compareStrings(assetOne.name, assetTwo.name);\n  });\n\n  /** Add the svg assets to the containing <svg> element.\n    * Because the containing <svg> element is within the Document\n    * the asset will also be added to the Document/\n    */\n  for (const asset of sortedAssets) {\n    promises.push(\n      await appendToSvgDoc(\n        asset,\n        DOCUMENT,\n        svgEl,\n        groupByCategory && category ? category : ''\n      )\n    );\n  }\n  await Promise.all(promises);\n}\n\n/**\n * Creates an SVG Document and sets its attributes\n * @param spriteName name of sprite file\n * @returns object with created SVG Document and its child svg element\n */\nexport function createSVGDoc(spriteName: string): { DOCUMENT: Document; svgEl: SVGSVGElement } {\n  LOGGER.debug(`in create svg doc`);\n  const DOM = new DOMImplementation();\n  const doctype = DOM.createDocumentType(\n    'svg',\n    '-//W3C//DTD SVG 1.1//EN',\n    'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'\n  );\n  const SVG_NS = 'http://www.w3.org/2000/svg';\n  // Create an SVG Document and set its doctype\n  const DOCUMENT = DOM.createDocument(SVG_NS, 'svg', doctype);\n  // Create SVG element\n  const svgEl = DOCUMENT.createElementNS(SVG_NS, 'svg');\n  svgEl.setAttribute('xmlns', 'http://www.w3.org/2000/svg');\n  svgEl.setAttribute('xmlns:xlink', 'http://www.w3.org/1999/xlink');\n  svgEl.setAttribute('version', '1.1');\n  svgEl.setAttribute('id', spriteName);\n\n  // Add <svg> element to SVG Document\n  DOCUMENT.appendChild(svgEl);\n  LOGGER.debug(`creating svg document ${DOCUMENT}`);\n  return { DOCUMENT, svgEl };\n}\n\n/**\n * Looks for <defs> elements with an ID in Document\n * @param doc the Document to look in\n * @param category to look for as an ID attribute\n * @returns found <defs> element or null if there's none\n */\nfunction findDefs(doc: Document, category: string): Element | null {\n  // Get all child nodes of the document that are <defs>\n  const nodes = [].slice.call(doc.getElementsByTagName('defs'));\n  // Look for a <defs> element with the ID and return if found\n  for (const elem of nodes) {\n    if (!elem) continue;\n    const id = elem.getAttributeNode('id');\n    if (id && id.value === category) {\n      return elem;\n    }\n  }\n  return null;\n}\n\n/**\n * Creates <defs> element and sets ID attribute\n * @param doc Document element to do the creation\n * @param category ID to set on the <defs>\n * @returns newly created <defs> element\n */\nfunction createDefs(doc: Document, category: string): HTMLElement {\n  LOGGER.debug(`entering createDefs with ${category}`);\n  // Create a <defs> element\n  const defs = doc.createElement('defs');\n  // Set it's ID to be the icon's category e.g 'ui'\n  defs.setAttribute('id', category);\n  return defs;\n}\n\n/**\n * Appends icon to element\n * @param parent element to append to\n * @param asset the asset whose contents need to be added\n */\nasync function appendIcon(parent: Element, asset: Asset): Promise<void> {\n  LOGGER.debug(`appending ${asset.name} icon`);\n  const doc = new DOMParser();\n  // Get contents of the asset, since it's an SVG the content will be in XML format\n  // Content Buffer | string\n  const contents = await asset.getContents();\n  // Parse XML from a string into a DOM Document.\n  const xml = doc.parseFromString(contents as string, 'image/svg+xml');\n  // Append the root node of the DOM document to the parent element\n  await parent.appendChild(xml.documentElement);\n}\n\n/**\n * Appends icon to element\n * @param parent element to append to\n * @param asset the asset whose contents need to be added\n */\nexport async function appendToSvgDoc(\n  asset: Asset,\n  doc: Document,\n  svgEl: SVGSVGElement,\n  category: string\n): Promise<void> {\n  LOGGER.debug(`The category is ${category}`);\n  // If there's a category property, we want to append the icon to a <defs> element\n  // where the value of its ID is the category\n  if (category) {\n    // TODO: #28 Replace this with getElementById, which right now doesn't find the <defs> with the ID\n    // Check if there is an existing <defs> tag with the ID set to the category\n    let def = findDefs(doc, category);\n    LOGGER.debug(`The <defs> is ${def}`);\n    // If there isn't create one and append the <defs> to the svg element\n    if (!def) {\n      def = createDefs(doc, category);\n      svgEl.appendChild(def);\n    }\n    // Then append the actual icon (asset) to the <defs>\n    return await appendIcon(def, asset);\n  } else {\n    // If there's no category just append to (anywhere) in the svg element\n    return await appendIcon(svgEl, asset);\n  }\n}\n\nfunction removeSVGResolution(svgEl: SVGSVGElement): SVGSVGElement {\n  const children = svgEl.getElementsByTagName('svg');\n  let svgs = [].slice.call(children);\n  svgs = svgs.filter((icon: Element) => {\n    const id = icon.getAttributeNode('id');\n    if (id && id.value) {\n      const newId = removeResolutionFromName(id.value);\n      icon.setAttribute('id', newId);\n    }\n  });\n  return svgEl;\n}\n/**\n * Saves svg elements stored in an object as a file\n * @param spriteNames object for mapping sprite name to (and storing) svg document and element\n * @param outputPath path to write to\n */\nexport async function writeSpriteToFile(\n  spriteNames: SpriteConfig,\n  outputPath: string\n): Promise<void> {\n  // Go through all the stored sprites\n  for (const spriteName in spriteNames) {\n    // Get the svg element\n    const svgEl = removeSVGResolution(spriteNames[spriteName].svgEl);\n    // Write it to file\n    await saveContentToFile(\n      outputPath,\n      spriteName,\n      serializeToString(svgEl),\n      'svg'\n    );\n  }\n}\n\n/**\n * Partitions list of assets by whether it should be added to a sprite\n * @param assets list of assets to partition\n * @returns object with assets to be added to sprite and assets not to be\n * added\n */\nexport function partitionAssetsForSprite(\n  assets: Asset[],\n  variantsToFilter: string[]\n): { assetsToAddToSprite: Asset[]; assetsNoSprite: Asset[] } {\n  // Create two arrays: 1 with assets to go in sprite and other with assets\n  // that won't be added to the sprite\n  const [assetsToAddToSprite, assetsNoSprite] = assets.reduce(\n    (result: Asset[][], asset: Asset) => {\n      result[variantsToFilter.includes(asset.name) ? 0 : 1].push(asset);\n      return result;\n    },\n    [[], []]\n  );\n  return {\n    assetsToAddToSprite,\n    assetsNoSprite\n  };\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-sprite.js","sourceRoot":"","sources":["../../src/create-sprite.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Asset,\n  SpriteConfig,\n  saveContentToFile\n} from '@icon-magic/icon-models';\nimport { Logger, logger } from '@icon-magic/logger';\nimport { DOMImplementation, DOMParser, XMLSerializer } from 'xmldom';\n\nimport { compareStrings, removeResolutionFromName } from './utils';\n\nconst LOGGER: Logger = logger('icon-magic:distribute:create-sprite');\nconst serializeToString = new XMLSerializer().serializeToString;\n\n/**\n * Creates a sprite and appends SVG icons\n * @param spriteName name of sprite file\n * @param assets assets to add to svg\n * @param groupByCategory (for sprite creation) whether to group by the category attribute\n * @param category the category of icon\n * @param spriteNames object for mapping sprite name to (and storing) svg document and element\n */\nexport async function addToSprite(\n  spriteName: string,\n  assets: Asset[],\n  groupByCategory: boolean,\n  category: string,\n  spriteNames: SpriteConfig\n): Promise<void> {\n  let DOCUMENT, svgEl;\n  const promises: void[] = [];\n  // If there's no existing sprite with that name\n  if (!spriteNames.hasOwnProperty(spriteName)) {\n    // Create a new Document and SVG element for the sprite\n    ({ DOCUMENT, svgEl } = createSVGDoc(spriteName));\n    // Store the Document and the SVGEl\n    // We need the Document because we we're using methods like\n    // `createElement` and `getElementById` that can only be\n    // called on the Document\n    spriteNames[spriteName] = { DOCUMENT, svgEl };\n  } else {\n    // If one exists, grab the document and the containing <svg> element\n    ({ DOCUMENT, svgEl } = spriteNames[spriteName]);\n  }\n\n  // Sort assets (variants) within the icon first\n  const sortedAssets = assets.sort((assetOne: Asset, assetTwo: Asset) => {\n    return compareStrings(assetOne.name, assetTwo.name);\n  });\n\n  /** Add the svg assets to the containing <svg> element.\n    * Because the containing <svg> element is within the Document\n    * the asset will also be added to the Document/\n    */\n  for (const asset of sortedAssets) {\n    promises.push(\n      await appendToSvgDoc(\n        asset,\n        DOCUMENT,\n        svgEl,\n        groupByCategory && category ? category : ''\n      )\n    );\n  }\n  await Promise.all(promises);\n}\n\n/**\n * Creates an SVG Document and sets its attributes\n * @param spriteName name of sprite file\n * @returns object with created SVG Document and its child svg element\n */\nexport function createSVGDoc(spriteName: string): { DOCUMENT: Document; svgEl: SVGSVGElement } {\n  LOGGER.debug(`in create svg doc`);\n  const DOM = new DOMImplementation();\n  const doctype = DOM.createDocumentType(\n    'svg',\n    '-//W3C//DTD SVG 1.1//EN',\n    'http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd'\n  );\n  const SVG_NS = 'http://www.w3.org/2000/svg';\n  // Create an SVG Document and set its doctype\n  const DOCUMENT = DOM.createDocument(SVG_NS, 'svg', doctype);\n  // Create SVG element\n  const svgEl = DOCUMENT.createElementNS(SVG_NS, 'svg');\n  svgEl.setAttribute('xmlns', 'http://www.w3.org/2000/svg');\n  svgEl.setAttribute('xmlns:xlink', 'http://www.w3.org/1999/xlink');\n  svgEl.setAttribute('version', '1.1');\n  svgEl.setAttribute('id', spriteName);\n  \n  // Add <svg> element to SVG Document\n  DOCUMENT.appendChild(svgEl);\n  LOGGER.debug(`creating svg document ${DOCUMENT}`);\n  return { DOCUMENT, svgEl };\n}\n\n/**\n * Looks for <defs> elements with an ID in Document\n * @param doc the Document to look in\n * @param category to look for as an ID attribute\n * @returns found <defs> element or null if there's none\n */\nfunction findDefs(doc: Document, category: string): Element | null {\n  // Get all child nodes of the document that are <defs>\n  const nodes = [].slice.call(doc.getElementsByTagName('defs'));\n  // Look for a <defs> element with the ID and return if found\n  for (const elem of nodes) {\n    if (!elem) continue;\n    const id = elem.getAttributeNode('id');\n    if (id && id.value === category) {\n      return elem;\n    }\n  }\n  return null;\n}\n\n/**\n * Creates <defs> element and sets ID attribute\n * @param doc Document element to do the creation\n * @param category ID to set on the <defs>\n * @returns newly created <defs> element\n */\nfunction createDefs(doc: Document, category: string): HTMLElement {\n  LOGGER.debug(`entering createDefs with ${category}`);\n  // Create a <defs> element\n  const defs = doc.createElement('defs');\n  // Set it's ID to be the icon's category e.g 'ui'\n  defs.setAttribute('id', category);\n  return defs;\n}\n\n/**\n * Appends icon to element\n * @param parent element to append to\n * @param asset the asset whose contents need to be added\n */\nasync function appendIcon(parent: Element, asset: Asset): Promise<void> {\n  LOGGER.debug(`appending ${asset.name} icon`);\n  const doc = new DOMParser();\n  // Get contents of the asset, since it's an SVG the content will be in XML format\n  // Content Buffer | string\n  const contents = await asset.getContents();\n  // Parse XML from a string into a DOM Document.\n  const xml = doc.parseFromString(contents as string, 'image/svg+xml');\n  // Append the root node of the DOM document to the parent element\n  await parent.appendChild(xml.documentElement);\n}\n\n/**\n * Appends icon to element\n * @param parent element to append to\n * @param asset the asset whose contents need to be added\n */\nexport async function appendToSvgDoc(\n  asset: Asset,\n  doc: Document,\n  svgEl: SVGSVGElement,\n  category: string\n): Promise<void> {\n  LOGGER.debug(`The category is ${category}`);\n  // If there's a category property, we want to append the icon to a <defs> element\n  // where the value of its ID is the category\n  if (category) {\n    // TODO: #28 Replace this with getElementById, which right now doesn't find the <defs> with the ID\n    // Check if there is an existing <defs> tag with the ID set to the category\n    let def = findDefs(doc, category);\n    LOGGER.debug(`The <defs> is ${def}`);\n    // If there isn't create one and append the <defs> to the svg element\n    if (!def) {\n      def = createDefs(doc, category);\n      svgEl.appendChild(def);\n    }\n    // Then append the actual icon (asset) to the <defs>\n    return await appendIcon(def, asset);\n  } else {\n    // If there's no category just append to (anywhere) in the svg element\n    return await appendIcon(svgEl, asset);\n  }\n}\n\nfunction removeSVGResolution(svgEl: SVGSVGElement): SVGSVGElement {\n  const children = svgEl.getElementsByTagName('svg');\n  let svgs = [].slice.call(children);\n  svgs = svgs.filter((icon: Element) => {\n    const id = icon.getAttributeNode('id');\n    if (id && id.value) {\n      const newId = removeResolutionFromName(id.value);\n      icon.setAttribute('id', newId);\n    }\n  });\n  return svgEl;\n}\n/**\n * Saves svg elements stored in an object as a file\n * @param spriteNames object for mapping sprite name to (and storing) svg document and element\n * @param outputPath path to write to\n */\nexport async function writeSpriteToFile(\n  spriteNames: SpriteConfig,\n  outputPath: string\n): Promise<void> {\n  // Go through all the stored sprites\n  for (const spriteName in spriteNames) {\n    // Get the svg element\n    const svgEl = removeSVGResolution(spriteNames[spriteName].svgEl);\n    // Write it to file\n    await saveContentToFile(\n      outputPath,\n      spriteName,\n      serializeToString(svgEl),\n      'svg'\n    );\n  }\n}\n\n/**\n * Partitions list of assets by whether it should be added to a sprite\n * @param assets list of assets to partition\n * @returns object with assets to be added to sprite and assets not to be\n * added\n */\nexport function partitionAssetsForSprite(\n  assets: Asset[],\n  variantsToFilter: string[]\n): { assetsToAddToSprite: Asset[]; assetsNoSprite: Asset[] } {\n  // Create two arrays: 1 with assets to go in sprite and other with assets\n  // that won't be added to the sprite\n  const [assetsToAddToSprite, assetsNoSprite] = assets.reduce(\n    (result: Asset[][], asset: Asset) => {\n      result[variantsToFilter.includes(asset.name) ? 0 : 1].push(asset);\n      return result;\n    },\n    [[], []]\n  );\n  return {\n    assetsToAddToSprite,\n    assetsNoSprite\n  };\n}\n"]} |
@@ -9,2 +9,2 @@ import { IconSet } from '@icon-magic/icon-models'; | ||
*/ | ||
export declare function distributeSvg(iconSet: IconSet, outputPath: string, groupByCategory: boolean): Promise<void>; | ||
export declare function distributeSvg(iconSet: IconSet, outputPath: string, groupByCategory: boolean, outputAsHbs: boolean): Promise<void>; |
@@ -6,2 +6,3 @@ "use strict"; | ||
const path = require("path"); | ||
const create_icon_template_1 = require("./create-icon-template"); | ||
const create_sprite_1 = require("./create-sprite"); | ||
@@ -17,3 +18,3 @@ const utils_1 = require("./utils"); | ||
*/ | ||
async function distributeSvg(iconSet, outputPath, groupByCategory) { | ||
async function distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs) { | ||
// Sort icons so it looks pretty in .diff | ||
@@ -41,3 +42,11 @@ const icons = sortIcons(iconSet.hash.values()); | ||
!svgConfig.toSprite); | ||
if (iconHasSpriteConfig) { | ||
if (outputAsHbs) { | ||
try { | ||
await create_icon_template_1.createHbs(assets, outputPath); | ||
} | ||
catch (e) { | ||
LOGGER.debug(`There was an issue creating the hbs file: ${e}`); | ||
} | ||
} | ||
else if (iconHasSpriteConfig) { | ||
// By default, if there is no distribute config, add to the sprite | ||
@@ -92,2 +101,2 @@ // Default spriteName is `icons` | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"distribute-svg.js","sourceRoot":"","sources":["../../src/distribute-svg.ts"],"names":[],"mappings":"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","sourcesContent":["import { Asset, Icon, IconSet, SpriteConfig } from '@icon-magic/icon-models';\nimport { Logger, logger } from '@icon-magic/logger';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport {\n  addToSprite,\n  partitionAssetsForSprite,\n  writeSpriteToFile\n} from './create-sprite';\nimport { compareStrings, getIconFlavorsByType } from './utils';\n\nconst LOGGER: Logger = logger('icon-magic:distribute:distribute-svg');\n\n/**\n *\n * @param iconSet set of icons to be moved to the output folder or added to sprite\n * @param outputPath path to move to\n * @param groupByCategory (for sprite creation) whether to group by the category attribute\n * @returns promise after completion\n */\nexport async function distributeSvg(\n  iconSet: IconSet,\n  outputPath: string,\n  groupByCategory: boolean\n): Promise<void> {\n  // Sort icons so it looks pretty in .diff\n  const icons = sortIcons(iconSet.hash.values());\n  // Keep track of the sprites that have been created so we know when to create\n  // a new one and when to append to an existing document\n  const spriteNames: SpriteConfig = {};\n  const promises: void[] = [];\n  for (const icon of icons) {\n    LOGGER.debug(`calling distributeSvg on ${icon.iconName}: ${icon.iconPath}`);\n    const assets = getIconFlavorsByType(icon, 'svg');\n    const distributeConfig = icon.distribute;\n    const svgConfig = distributeConfig && distributeConfig.svg;\n\n    // variantsToFilter can be defined on distribute or on distribute.svg\n    const iconVariantsToFilter =\n      distributeConfig && distributeConfig.variantsToFilter;\n    const svgVariantsToFilter = svgConfig && svgConfig.variantsToFilter;\n    const variantsToFilter = svgVariantsToFilter || iconVariantsToFilter;\n\n    // If icon has defined the assets to go to sprite\n    const { assetsToAddToSprite, assetsNoSprite } =\n      variantsToFilter && variantsToFilter.length\n        ? partitionAssetsForSprite(assets, variantsToFilter)\n        : { assetsToAddToSprite: assets, assetsNoSprite: assets };\n\n    const iconHasSpriteConfig = !(\n      distributeConfig &&\n      svgConfig &&\n      !svgConfig.toSprite\n    );\n\n    if (iconHasSpriteConfig) {\n      // By default, if there is no distribute config, add to the sprite\n      // Default spriteName is `icons`\n      const iconSpriteNames =\n        svgConfig && svgConfig.spriteNames ? svgConfig.spriteNames : ['icons'];\n      for (const spriteName of iconSpriteNames) {\n        promises.push(\n          await addToSprite(\n            spriteName,\n            assetsToAddToSprite,\n            groupByCategory,\n            icon.category,\n            spriteNames\n          )\n        );\n      }\n    } else {\n      // Just copy the files to the output\n      // If the groupByCategory flag is available,\n      // put them in a folder that matches the icon category\n      const destPath =\n        icon.category && groupByCategory\n          ? path.join(outputPath, icon.category)\n          : outputPath;\n      await copyIconAssetSvgs(icon.iconName, assetsNoSprite, destPath);\n    }\n  }\n  await Promise.all(promises).then(async () => {\n    // After we've gone through all the icons, write the sprites to a file\n    await writeSpriteToFile(spriteNames, outputPath);\n  });\n}\n\n/**\n * Moves the svg assets of an icon to the outputPath\n * @param iconName name of icon whose assets should be moved\n * @param assets to be moved\n * @param outputPath path to move to\n */\nasync function copyIconAssetSvgs(\n  iconName: string,\n  assets: Asset[],\n  outputPath: string\n) {\n  const outputIconDir = path.join(outputPath, iconName);\n  await fs.mkdirp(outputIconDir);\n  // copy all assets to the output icon directory\n  const promises = [];\n  for (const asset of assets) {\n    promises.push(\n      fs.copy(\n        asset.getPath(),\n        path.join(outputIconDir, path.basename(asset.getPath()))\n      )\n    );\n  }\n  return Promise.all(promises);\n}\n\n/**\n * Sorts a set of icons by property iconName\n * @param icons set of icons to sort\n * @returns sorted array of icons\n */\nfunction sortIcons(icons: IterableIterator<Icon>): Array<Icon> {\n  return Array.from(icons).sort((iconOne: Icon, iconTwo: Icon) => {\n    return compareStrings(iconOne.iconName, iconTwo.iconName);\n  });\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"distribute-svg.js","sourceRoot":"","sources":["../../src/distribute-svg.ts"],"names":[],"mappings":"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","sourcesContent":["import { Asset, Icon, IconSet, SpriteConfig } from '@icon-magic/icon-models';\nimport { Logger, logger } from '@icon-magic/logger';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport { createHbs } from './create-icon-template';\nimport {\n  addToSprite,\n  partitionAssetsForSprite,\n  writeSpriteToFile\n} from './create-sprite';\nimport { compareStrings, getIconFlavorsByType } from './utils';\n\nconst LOGGER: Logger = logger('icon-magic:distribute:distribute-svg');\n\n/**\n *\n * @param iconSet set of icons to be moved to the output folder or added to sprite\n * @param outputPath path to move to\n * @param groupByCategory (for sprite creation) whether to group by the category attribute\n * @returns promise after completion\n */\nexport async function distributeSvg(\n  iconSet: IconSet,\n  outputPath: string,\n  groupByCategory: boolean,\n  outputAsHbs: boolean,\n): Promise<void> {\n  // Sort icons so it looks pretty in .diff\n  const icons = sortIcons(iconSet.hash.values());\n  // Keep track of the sprites that have been created so we know when to create\n  // a new one and when to append to an existing document\n  const spriteNames: SpriteConfig = {};\n  const promises: void[] = [];\n  for (const icon of icons) {\n    LOGGER.debug(`calling distributeSvg on ${icon.iconName}: ${icon.iconPath}`);\n    const assets = getIconFlavorsByType(icon, 'svg');\n    const distributeConfig = icon.distribute;\n    const svgConfig = distributeConfig && distributeConfig.svg;\n    // variantsToFilter can be defined on distribute or on distribute.svg\n    const iconVariantsToFilter =\n      distributeConfig && distributeConfig.variantsToFilter;\n    const svgVariantsToFilter = svgConfig && svgConfig.variantsToFilter;\n    const variantsToFilter = svgVariantsToFilter || iconVariantsToFilter;\n\n    // If icon has defined the assets to go to sprite\n    const { assetsToAddToSprite, assetsNoSprite } =\n      variantsToFilter && variantsToFilter.length\n        ? partitionAssetsForSprite(assets, variantsToFilter)\n        : { assetsToAddToSprite: assets, assetsNoSprite: assets };\n\n    const iconHasSpriteConfig = !(\n      distributeConfig &&\n      svgConfig &&\n      !svgConfig.toSprite\n    );\n    if (outputAsHbs) {\n      try {\n        await createHbs(assets, outputPath);\n      }\n      catch(e) {\n        LOGGER.debug(`There was an issue creating the hbs file: ${e}`);\n      }\n    }\n    else if (iconHasSpriteConfig) {\n      // By default, if there is no distribute config, add to the sprite\n      // Default spriteName is `icons`\n      const iconSpriteNames =\n        svgConfig && svgConfig.spriteNames ? svgConfig.spriteNames : ['icons'];\n      for (const spriteName of iconSpriteNames) {\n        promises.push(\n          await addToSprite(\n            spriteName,\n            assetsToAddToSprite,\n            groupByCategory,\n            icon.category,\n            spriteNames\n          )\n        );\n      }\n    } else {\n      // Just copy the files to the output\n      // If the groupByCategory flag is available,\n      // put them in a folder that matches the icon category\n      const destPath =\n        icon.category && groupByCategory\n          ? path.join(outputPath, icon.category)\n          : outputPath;\n      await copyIconAssetSvgs(icon.iconName, assetsNoSprite, destPath);\n    }\n  }\n  await Promise.all(promises).then(async () => {\n    // After we've gone through all the icons, write the sprites to a file\n    await writeSpriteToFile(spriteNames, outputPath);\n  });\n}\n\n/**\n * Moves the svg assets of an icon to the outputPath\n * @param iconName name of icon whose assets should be moved\n * @param assets to be moved\n * @param outputPath path to move to\n */\nasync function copyIconAssetSvgs(\n  iconName: string,\n  assets: Asset[],\n  outputPath: string\n) {\n  const outputIconDir = path.join(outputPath, iconName);\n  await fs.mkdirp(outputIconDir);\n  // copy all assets to the output icon directory\n  const promises = [];\n  for (const asset of assets) {\n    promises.push(\n      fs.copy(\n        asset.getPath(),\n        path.join(outputIconDir, path.basename(asset.getPath()))\n      )\n    );\n  }\n  return Promise.all(promises);\n}\n\n/**\n * Sorts a set of icons by property iconName\n * @param icons set of icons to sort\n * @returns sorted array of icons\n */\nfunction sortIcons(icons: IterableIterator<Icon>): Array<Icon> {\n  return Array.from(icons).sort((iconOne: Icon, iconTwo: Icon) => {\n    return compareStrings(iconOne.iconName, iconTwo.iconName);\n  });\n}\n"]} |
@@ -11,3 +11,3 @@ import { IconConfigHash } from '@icon-magic/icon-models'; | ||
*/ | ||
export declare function distributeByType(iconConfig: IconConfigHash, outputPath: string, type?: ICON_TYPES, groupByCategory?: boolean): Promise<void>; | ||
export declare function distributeByType(iconConfig: IconConfigHash, outputPath: string, type?: ICON_TYPES, groupByCategory?: boolean, outputAsHbs?: boolean): Promise<void>; | ||
export {}; |
@@ -17,3 +17,3 @@ "use strict"; | ||
*/ | ||
async function distributeByType(iconConfig, outputPath, type = 'all', groupByCategory = true) { | ||
async function distributeByType(iconConfig, outputPath, type = 'all', groupByCategory = true, outputAsHbs = false) { | ||
LOGGER.debug(`entering distribute with ${type}`); | ||
@@ -31,3 +31,3 @@ const iconSet = new icon_models_1.IconSet(iconConfig, true); | ||
case 'svg': { | ||
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory); | ||
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs); | ||
break; | ||
@@ -38,3 +38,3 @@ } | ||
await distribute_by_resolution_1.distributeByResolution(iconSet, outputPath); | ||
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory); | ||
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs); | ||
} | ||
@@ -44,2 +44,2 @@ } | ||
exports.distributeByType = distributeByType; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5REFBa0U7QUFDbEUsK0NBQW9EO0FBRXBELHlEQUFvRDtBQUNwRCx5RUFBb0U7QUFDcEUscURBQWlEO0FBRWpELE1BQU0sTUFBTSxHQUFXLGVBQU0sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBRzdEOzs7Ozs7O0dBT0c7QUFDSSxLQUFLLFVBQVUsZ0JBQWdCLENBQ3BDLFVBQTBCLEVBQzFCLFVBQWtCLEVBQ2xCLE9BQW1CLEtBQUssRUFDeEIsZUFBZSxHQUFHLElBQUk7SUFFdEIsTUFBTSxDQUFDLEtBQUssQ0FBQyw0QkFBNEIsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNqRCxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFPLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlDLFFBQVEsSUFBSSxFQUFFO1FBQ1osS0FBSyxLQUFLLENBQUMsQ0FBQztZQUNWLE1BQU0saUNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDMUMsTUFBTTtTQUNQO1FBQ0QsS0FBSyxNQUFNLENBQUMsQ0FBQztZQUNYLE1BQU0saURBQXNCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQ2xELE1BQU07U0FDUDtRQUNELEtBQUssS0FBSyxDQUFDLENBQUM7WUFDVixNQUFNLDhCQUFhLENBQUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLENBQUMsQ0FBQztZQUMxRCxNQUFNO1NBQ1A7UUFDRCxPQUFPLENBQUMsQ0FBQztZQUNQLE1BQU0saUNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDMUMsTUFBTSxpREFBc0IsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDbEQsTUFBTSw4QkFBYSxDQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxDQUFDLENBQUM7U0FDM0Q7S0FDRjtBQUNILENBQUM7QUEzQkQsNENBMkJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbkNvbmZpZ0hhc2gsIEljb25TZXQgfSBmcm9tICdAaWNvbi1tYWdpYy9pY29uLW1vZGVscyc7XG5pbXBvcnQgeyBMb2dnZXIsIGxvZ2dlciB9IGZyb20gJ0BpY29uLW1hZ2ljL2xvZ2dlcic7XG5cbmltcG9ydCB7IGNyZWF0ZUltYWdlU2V0IH0gZnJvbSAnLi9jcmVhdGUtaW1hZ2Utc2V0JztcbmltcG9ydCB7IGRpc3RyaWJ1dGVCeVJlc29sdXRpb24gfSBmcm9tICcuL2Rpc3RyaWJ1dGUtYnktcmVzb2x1dGlvbic7XG5pbXBvcnQgeyBkaXN0cmlidXRlU3ZnIH0gZnJvbSAnLi9kaXN0cmlidXRlLXN2Zyc7XG5cbmNvbnN0IExPR0dFUjogTG9nZ2VyID0gbG9nZ2VyKCdpY29uLW1hZ2ljOmRpc3RyaWJ1dGU6aW5kZXgnKTtcbnR5cGUgSUNPTl9UWVBFUyA9ICdzdmcnIHwgJ3BuZycgfCAnd2VicCcgfCAnYWxsJztcblxuLyoqXG4gKiBEaXN0cmlidXRlcyBhIHNldCBvZiBpY29ucyB0byB0aGUgb3V0cHV0IGZvbGRlciBiYXNlZCBvbiB0aGUgZmxhZ1xuICogQHBhcmFtIGljb25TZXQgc2V0IG9mIGljb25zIHRvIGJlIG1vdmVkIHRvIHRoZSBvdXRwdXQgZm9sZGVyXG4gKiBAcGFyYW0gb3V0cHV0UGF0aCBvdXRwdXQgZGlyZWN0b3J5IHBhdGggdG8gY29weSB0aGUgYXNzZXRzIHRvXG4gKiBAcGFyYW0gdHlwZSBzdmcsIHBuZywgd2VicCwgYWxsXG4gKiBAcGFyYW0gZ3JvdXBCeUNhdGVnb3J5IChmb3Igc3ByaXRlIGNyZWF0aW9uKSB3aGV0aGVyIHRvIGdyb3VwIGJ5IHRoZSBjYXRlZ29yeSBhdHRyaWJ1dGVcbiAqIEByZXR1bnMgcHJvbWlzZSBhZnRlciBjb21wbGV0aW9uXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBkaXN0cmlidXRlQnlUeXBlKFxuICBpY29uQ29uZmlnOiBJY29uQ29uZmlnSGFzaCxcbiAgb3V0cHV0UGF0aDogc3RyaW5nLFxuICB0eXBlOiBJQ09OX1RZUEVTID0gJ2FsbCcsXG4gIGdyb3VwQnlDYXRlZ29yeSA9IHRydWVcbik6IFByb21pc2U8dm9pZD4ge1xuICBMT0dHRVIuZGVidWcoYGVudGVyaW5nIGRpc3RyaWJ1dGUgd2l0aCAke3R5cGV9YCk7XG4gIGNvbnN0IGljb25TZXQgPSBuZXcgSWNvblNldChpY29uQ29uZmlnLCB0cnVlKTtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAncG5nJzoge1xuICAgICAgYXdhaXQgY3JlYXRlSW1hZ2VTZXQoaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAnd2VicCc6IHtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVCeVJlc29sdXRpb24oaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAnc3ZnJzoge1xuICAgICAgYXdhaXQgZGlzdHJpYnV0ZVN2ZyhpY29uU2V0LCBvdXRwdXRQYXRoLCBncm91cEJ5Q2F0ZWdvcnkpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGRlZmF1bHQ6IHtcbiAgICAgIGF3YWl0IGNyZWF0ZUltYWdlU2V0KGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYXdhaXQgZGlzdHJpYnV0ZUJ5UmVzb2x1dGlvbihpY29uU2V0LCBvdXRwdXRQYXRoKTtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVTdmcoaWNvblNldCwgb3V0cHV0UGF0aCwgZ3JvdXBCeUNhdGVnb3J5KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5REFBa0U7QUFDbEUsK0NBQW9EO0FBRXBELHlEQUFvRDtBQUNwRCx5RUFBb0U7QUFDcEUscURBQWlEO0FBRWpELE1BQU0sTUFBTSxHQUFXLGVBQU0sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBRzdEOzs7Ozs7O0dBT0c7QUFDSSxLQUFLLFVBQVUsZ0JBQWdCLENBQ3BDLFVBQTBCLEVBQzFCLFVBQWtCLEVBQ2xCLE9BQW1CLEtBQUssRUFDeEIsZUFBZSxHQUFHLElBQUksRUFDdEIsV0FBVyxHQUFHLEtBQUs7SUFFbkIsTUFBTSxDQUFDLEtBQUssQ0FBQyw0QkFBNEIsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNqRCxNQUFNLE9BQU8sR0FBRyxJQUFJLHFCQUFPLENBQUMsVUFBVSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzlDLFFBQVEsSUFBSSxFQUFFO1FBQ1osS0FBSyxLQUFLLENBQUMsQ0FBQztZQUNWLE1BQU0saUNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDMUMsTUFBTTtTQUNQO1FBQ0QsS0FBSyxNQUFNLENBQUMsQ0FBQztZQUNYLE1BQU0saURBQXNCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQ2xELE1BQU07U0FDUDtRQUNELEtBQUssS0FBSyxDQUFDLENBQUM7WUFDVixNQUFNLDhCQUFhLENBQUMsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsV0FBVyxDQUFDLENBQUM7WUFDdkUsTUFBTTtTQUNQO1FBQ0QsT0FBTyxDQUFDLENBQUM7WUFDUCxNQUFNLGlDQUFjLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzFDLE1BQU0saURBQXNCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQ2xELE1BQU0sOEJBQWEsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQztTQUN4RTtLQUNGO0FBQ0gsQ0FBQztBQTVCRCw0Q0E0QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJY29uQ29uZmlnSGFzaCwgSWNvblNldCB9IGZyb20gJ0BpY29uLW1hZ2ljL2ljb24tbW9kZWxzJztcbmltcG9ydCB7IExvZ2dlciwgbG9nZ2VyIH0gZnJvbSAnQGljb24tbWFnaWMvbG9nZ2VyJztcblxuaW1wb3J0IHsgY3JlYXRlSW1hZ2VTZXQgfSBmcm9tICcuL2NyZWF0ZS1pbWFnZS1zZXQnO1xuaW1wb3J0IHsgZGlzdHJpYnV0ZUJ5UmVzb2x1dGlvbiB9IGZyb20gJy4vZGlzdHJpYnV0ZS1ieS1yZXNvbHV0aW9uJztcbmltcG9ydCB7IGRpc3RyaWJ1dGVTdmcgfSBmcm9tICcuL2Rpc3RyaWJ1dGUtc3ZnJztcblxuY29uc3QgTE9HR0VSOiBMb2dnZXIgPSBsb2dnZXIoJ2ljb24tbWFnaWM6ZGlzdHJpYnV0ZTppbmRleCcpO1xudHlwZSBJQ09OX1RZUEVTID0gJ3N2ZycgfCAncG5nJyB8ICd3ZWJwJyB8ICdhbGwnO1xuXG4vKipcbiAqIERpc3RyaWJ1dGVzIGEgc2V0IG9mIGljb25zIHRvIHRoZSBvdXRwdXQgZm9sZGVyIGJhc2VkIG9uIHRoZSBmbGFnXG4gKiBAcGFyYW0gaWNvblNldCBzZXQgb2YgaWNvbnMgdG8gYmUgbW92ZWQgdG8gdGhlIG91dHB1dCBmb2xkZXJcbiAqIEBwYXJhbSBvdXRwdXRQYXRoIG91dHB1dCBkaXJlY3RvcnkgcGF0aCB0byBjb3B5IHRoZSBhc3NldHMgdG9cbiAqIEBwYXJhbSB0eXBlIHN2ZywgcG5nLCB3ZWJwLCBhbGxcbiAqIEBwYXJhbSBncm91cEJ5Q2F0ZWdvcnkgKGZvciBzcHJpdGUgY3JlYXRpb24pIHdoZXRoZXIgdG8gZ3JvdXAgYnkgdGhlIGNhdGVnb3J5IGF0dHJpYnV0ZVxuICogQHJldHVucyBwcm9taXNlIGFmdGVyIGNvbXBsZXRpb25cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRpc3RyaWJ1dGVCeVR5cGUoXG4gIGljb25Db25maWc6IEljb25Db25maWdIYXNoLFxuICBvdXRwdXRQYXRoOiBzdHJpbmcsXG4gIHR5cGU6IElDT05fVFlQRVMgPSAnYWxsJyxcbiAgZ3JvdXBCeUNhdGVnb3J5ID0gdHJ1ZSxcbiAgb3V0cHV0QXNIYnMgPSBmYWxzZSxcbik6IFByb21pc2U8dm9pZD4ge1xuICBMT0dHRVIuZGVidWcoYGVudGVyaW5nIGRpc3RyaWJ1dGUgd2l0aCAke3R5cGV9YCk7XG4gIGNvbnN0IGljb25TZXQgPSBuZXcgSWNvblNldChpY29uQ29uZmlnLCB0cnVlKTtcbiAgc3dpdGNoICh0eXBlKSB7XG4gICAgY2FzZSAncG5nJzoge1xuICAgICAgYXdhaXQgY3JlYXRlSW1hZ2VTZXQoaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAnd2VicCc6IHtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVCeVJlc29sdXRpb24oaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAnc3ZnJzoge1xuICAgICAgYXdhaXQgZGlzdHJpYnV0ZVN2ZyhpY29uU2V0LCBvdXRwdXRQYXRoLCBncm91cEJ5Q2F0ZWdvcnksIG91dHB1dEFzSGJzKTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBkZWZhdWx0OiB7XG4gICAgICBhd2FpdCBjcmVhdGVJbWFnZVNldChpY29uU2V0LCBvdXRwdXRQYXRoKTtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVCeVJlc29sdXRpb24oaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBhd2FpdCBkaXN0cmlidXRlU3ZnKGljb25TZXQsIG91dHB1dFBhdGgsIGdyb3VwQnlDYXRlZ29yeSwgb3V0cHV0QXNIYnMpO1xuICAgIH1cbiAgfVxufVxuIl19 |
@@ -252,2 +252,15 @@ "use strict"; | ||
}); | ||
it('creates hbs files', async () => { | ||
const iconSetAnimal = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/animal'))); | ||
await src_1.distributeByType(iconSetAnimal, output, 'svg', true, true); | ||
try { | ||
const files = fs.readdirSync(output); | ||
console.log(files); | ||
assert.ok(files.includes('animal-small.hbs')); | ||
assert.ok(files.includes('animal-large.hbs')); | ||
} | ||
catch (err) { | ||
assert.ok(false, err); | ||
} | ||
}); | ||
it('sprites are always arranged alphabetically', async () => { | ||
@@ -274,2 +287,2 @@ await src_1.distributeByType(iconSet, output, 'svg', true); | ||
}); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index-test.js","sourceRoot":"","sources":["../../test/index-test.ts"],"names":[],"mappings":";;AAAA,0DAA0D;AAC1D,iCAAiC;AACjC,+BAA+B;AAC/B,6BAA6B;AAC7B,mCAAmC;AAEnC,gCAA0C;AAE1C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;AACzE,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;AAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC7C,MAAM,OAAO,GAAG,YAAY,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;AAEhE,QAAQ,CAAC,8BAA8B,EAAE;IACvC,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,GAAG,MAAM,mBAAmB,CAAC;QAC9C,IAAI;YACF,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAC3B,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,oBAAoB,CAAC,CAAC;aAC5C;iBAAM;gBACL,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,QAAQ,wBAAwB,CAAC,CAAC;aACvD;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,GAAG,YAAY,QAAQ,EAAE,CAAC,CAAC;SAChD;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QACvD,MAAM,QAAQ,GAAG,GAAG,MAAM,mBAAmB,CAAC;QAC9C,MAAM,KAAK,GAAG;YACZ;gBACE,QAAQ,EAAE,kCAAkC;aAC7C;YACD;gBACE,QAAQ,EAAE,mCAAmC;aAC9C;YACD;gBACE,QAAQ,EAAE,oCAAoC;aAC/C;YACD;gBACE,QAAQ,EAAE,kCAAkC;aAC7C;YACD;gBACE,QAAQ,EAAE,kCAAkC;aAC7C;YACD;gBACE,QAAQ,EAAE,kCAAkC;aAC7C;YACD;gBACE,QAAQ,EAAE,oCAAoC;aAC/C;YACD;gBACE,QAAQ,EAAE,oCAAoC;aAC/C;SACF,CAAC;QACF,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QACvC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,OAAO,CAAC,EACvC,YAAY,IAAI,CAAC,QAAQ,OAAO,CACjC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8CAA8C,EAAE,KAAK,IAAI,EAAE;QAC5D,MAAM,KAAK,GAAG;YACZ;gBACE,QAAQ,EAAE,uBAAuB;gBACjC,QAAQ,EAAE,SAAS;aACpB;YACD;gBACE,QAAQ,EAAE,uBAAuB;gBACjC,QAAQ,EAAE,UAAU;aACrB;YACD;gBACE,QAAQ,EAAE,uBAAuB;gBACjC,QAAQ,EAAE,WAAW;aACtB;YACD;gBACE,QAAQ,EAAE,uBAAuB;gBACjC,QAAQ,EAAE,SAAS;aACpB;SACF,CAAC;QACF,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAEtD,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI;gBACF,MAAM,QAAQ,GAAG,GAAG,MAAM,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,WAAW,CAAC;gBACzF,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;oBAC3B,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,oBAAoB,CAAC,CAAC;oBAC3C,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;oBACvC,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,EACnC,6BAA6B,CAC9B,CAAC;oBACF,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,QAAQ,CAAC,GAAG,CAAC,CAAC,EAC7D,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,oBAAoB,CACtD,CAAC;iBACH;qBAAM;oBACL,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,qBAAqB,QAAQ,EAAE,CAAC,CAAC;iBACnD;aACF;YAAC,OAAO,GAAG,EAAE;gBACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;aACvB;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,KAAK,IAAI,EAAE;QACxC,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACrD,MAAM,WAAW,GAAG;YAClB;gBACE,IAAI,EAAE,WAAW;aAClB;YACD;gBACE,IAAI,EAAE,aAAa;aACpB;YACD;gBACE,IAAI,EAAE,aAAa;aACpB;YACD;gBACE,IAAI,EAAE,aAAa;aACpB;SACF,CAAC;QACF,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACtB,IAAI;gBACF,IAAI,EAAE,CAAC,UAAU,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE;oBACxC,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;iBACjC;qBAAM;oBACL,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,oBAAoB,CAAC,CAAC;iBAC5C;aACF;YAAC,OAAO,GAAG,EAAE;gBACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,uBAAuB,GAAG,EAAE,CAAC,CAAC;aACpD;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gDAAgD,EAAE,KAAK,IAAI,EAAE;QAC9D,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACrD,MAAM,WAAW,GAAG;YAClB;gBACE,IAAI,EAAE,OAAO;gBACb,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,SAAS;aACpB;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,KAAK;aAChB;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,KAAK;aAChB;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,EAAE,EAAE,aAAa;gBACjB,QAAQ,EAAE,KAAK;aAChB;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,KAAK;aAChB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,SAAS;aACpB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,WAAW;aACtB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,oBAAoB;gBACxB,QAAQ,EAAE,WAAW;aACtB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,mBAAmB;gBACvB,QAAQ,EAAE,WAAW;aACtB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,UAAU;aACrB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,SAAS;aACpB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,iBAAiB;gBACrB,QAAQ,EAAE,SAAS;aACpB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,eAAe;gBACnB,QAAQ,EAAE,WAAW;aACtB;YACD;gBACE,IAAI,EAAE,SAAS;gBACf,EAAE,EAAE,gBAAgB;gBACpB,QAAQ,EAAE,WAAW;aACtB;SACF,CAAC;QACF,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACtB,IAAI;gBACF,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC,IAAI,MAAM,EAAE,MAAM,CAAC,CAAC;gBACnE,MAAM,GAAG,GAAG,IAAI,kBAAS,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;gBAC5D,MAAM,SAAS,GAAG,GAAG,CAAC,eAAe,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;gBAC7D,MAAM,CAAC,EAAE,CAAC,SAAS,IAAI,SAAS,CAAC,KAAK,KAAK,CAAC,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;gBAEjE,MAAM,IAAI,GAAG,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;gBAC5C,MAAM,CAAC,EAAE,CACP,IAAI,IAAI,IAAI,CAAC,OAAO,KAAK,MAAM,EAC/B,sCAAsC,CACvC,CAAC;gBACF,MAAM,CAAC,EAAE,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,uBAAuB,CAAC,CAAC;aAC9D;YAAC,OAAO,GAAG,EAAE;gBACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,GAAG,SAAS,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;aAC/C;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,IAAI;YACF,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,MAAM,YAAY,EAAE,MAAM,CAAC,CAAC;YAC/D,MAAM,GAAG,GAAG,IAAI,kBAAS,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAC5D,MAAM,IAAI,GAAG,GAAG,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAC7C,uBAAuB;YACvB,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,8BAA8B,CAAC,CAAC;YAC7D,MAAM,MAAM,GAAG;gBACb,aAAa;gBACb,eAAe;gBACf,eAAe;gBACf,iBAAiB;gBACjB,iBAAiB;aAClB,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAClB,MAAM,CAAC,EAAE,CACP,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC,EACtB,qCAAqC,CACtC,CAAC;YACJ,CAAC,CAAC,CAAC;SACJ;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvB;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACjE,IAAI;YACF,MAAM,QAAQ,GAAG,GAAG,MAAM,sBAAsB,CAAC;YACjD,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YACvC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC;SACzC;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvB;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACrD,IAAI;YACF,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,GAAG,MAAM,iBAAiB,EAAE,MAAM,CAAC,CAAC;YACpE,MAAM,GAAG,GAAG,IAAI,kBAAS,EAAE,CAAC,eAAe,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAC5D,MAAM,IAAI,GAAG,GAAG,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAC7C,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,2BAA2B,CAAC,CAAC;YAC1D,MAAM,MAAM,GAAG;gBACb,cAAc;gBACd,cAAc;aACf,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAClB,MAAM,CAAC,EAAE,CACP,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC,EACtB,qCAAqC,CACtC,CAAC;YACJ,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,KAAK,CACV,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,cAAc,CAAC,cAAc,CAAC,EAClC,iCAAiC,CAClC,CAAC;SACH;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvB;IACH,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import * as configReader from '@icon-magic/config-reader';\nimport * as assert from 'assert';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\nimport { DOMParser } from 'xmldom';\n\nimport { distributeByType } from '../src';\n\nconst FIXTURES = path.resolve(__dirname, '..', '..', 'test', 'fixtures');\nconst input = path.resolve(FIXTURES, 'input');\nconst output = path.resolve(FIXTURES, 'out');\nconst iconSet = configReader.getIconConfigSet(new Array(input));\n\ndescribe('distribute works as expected', function () {\n  it('Moves all .webp files to the right output directory', async () => {\n    await distributeByType(iconSet, output, 'webp', false);\n    const iconPath = `${output}/drawable-xxxhdpi`;\n    try {\n      if (fs.existsSync(iconPath)) {\n        assert.ok(`${iconPath} dir was generated`);\n      } else {\n        assert.ok(false, `${iconPath} dir was not generated`);\n      }\n    } catch (err) {\n      assert.ok(false, `${err} reading ${iconPath}`);\n    }\n  });\n\n  it('.webp files are in the right output directory', async () => {\n    await distributeByType(iconSet, output, 'webp', false);\n    const iconPath = `${output}/drawable-xxxhdpi`;\n    const icons = [\n      {\n        iconName: 'ic_ui_icon_filled_1_filled_24x12'\n      },\n      {\n        iconName: 'ic_uix_icon_filled_2_filled_24x12'\n      },\n      {\n        iconName: 'ic_uixx_icon_filled_3_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_1_filled_60x60'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_4_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_4_filled_60x60'\n      },\n      {\n        iconName: 'ic_ui_icon_2_filled_6_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_2_filled_6_filled_60x60'\n      }\n    ];\n    const files = fs.readdirSync(iconPath);\n    icons.forEach(icon => {\n      assert.ok(\n        files.includes(`${icon.iconName}.webp`),\n        `includes ${icon.iconName}.webp`\n      );\n    });\n  });\n\n  it('Moves all .png files to the output directory', async () => {\n    const icons = [\n      {\n        iconName: 'filled_1_filled_24x12',\n        category: 'ui-icon'\n      },\n      {\n        iconName: 'filled_2_filled_24x12',\n        category: 'uix-icon'\n      },\n      {\n        iconName: 'filled_3_filled_24x12',\n        category: 'uixx-icon'\n      },\n      {\n        iconName: 'filled_1_filled_60x60',\n        category: 'ui-icon'\n      }\n    ];\n    await distributeByType(iconSet, output, 'png', false);\n\n    icons.forEach(icon => {\n      try {\n        const iconPath = `${output}/${icon.category}/${icon.category}_${icon.iconName}.imageset`;\n        if (fs.existsSync(iconPath)) {\n          assert.ok(`${iconPath} dir was generated`);\n          const files = fs.readdirSync(iconPath);\n          assert.ok(\n            files.indexOf('Contents.json') > -1,\n            'Contents.json was generated'\n          );\n          assert.ok(\n            files.indexOf(`${icon.category}_${icon.iconName}@2.png`) > -1,\n            `${icon.category}_${icon.iconName}@2.png was created`\n          );\n        } else {\n          assert.ok(false, `Missing files for ${iconPath}`);\n        }\n      } catch (err) {\n        assert.ok(false, err);\n      }\n    });\n  });\n\n  it('creates the sprite files', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    const spritePaths = [\n      {\n        path: 'icons.svg'\n      },\n      {\n        path: 'icons-1.svg'\n      },\n      {\n        path: 'icons-2.svg'\n      },\n      {\n        path: 'icons-3.svg'\n      }\n    ];\n    spritePaths.forEach(p => {\n      try {\n        if (fs.existsSync(`${output}/${p.path}`)) {\n          assert.ok(`${p} was generated`);\n        } else {\n          assert.ok(false, `${p} was not generated`);\n        }\n      } catch (err) {\n        assert.ok(false, `${p} was not generated: ${err}`);\n      }\n    });\n  });\n\n  it('sprite files contain defs with category for ID', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    const spritePaths = [\n      {\n        path: 'icons',\n        id: 'a-home-filled-1',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons',\n        id: 'point-default',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'point-default-2',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'ads-default',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'ads-default-2',\n        category: 'app'\n      },\n      {\n        path: 'icons-2',\n        id: 'b-home-filled-4',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-8',\n        category: 'ui-icon-2'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-88-9',\n        category: 'ui-icon-3'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-889',\n        category: 'ui-icon-2'\n      },\n      {\n        path: 'icons-2',\n        id: 'home-filled-2',\n        category: 'uix-icon'\n      },\n      {\n        path: 'icons-2',\n        id: 'home-filled-333',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-333',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-3',\n        category: 'uixx-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-33',\n        category: 'uixx-icon'\n      }\n    ];\n    spritePaths.forEach(p => {\n      try {\n        const content = fs.readFileSync(`${output}/${p.path}.svg`, 'utf8');\n        const doc = new DOMParser().parseFromString(content, 'svg');\n        const docIdNode = doc.documentElement.getAttributeNode('id');\n        assert.ok(docIdNode && docIdNode.value === p.path, 'svg has ID');\n\n        const defs = doc.getElementById(p.category);\n        assert.ok(\n          defs && defs.tagName === 'defs',\n          'has <defs> element with the right ID'\n        );\n        assert.ok(doc.getElementById(p.id), 'has SVG with right ID');\n      } catch (err) {\n        assert.ok(false, `${err} with ${p.category}`);\n      }\n    });\n  });\n\n  it('it only puts 5 variants into the sprite', async () => {\n    try {\n      const content = fs.readFileSync(`${output}/icons.svg`, 'utf8');\n      const doc = new DOMParser().parseFromString(content, 'svg');\n      const svgs = doc.getElementsByTagName('svg');\n      // 2 icons + parent svg\n      assert.ok(svgs.length === 6, 'Only five variants in sprite');\n      const svgIDs = [\n        'ads-default',\n        'ads-default-2',\n        'point-default',\n        'point-default-2',\n        'a-home-filled-1'\n      ];\n      svgIDs.forEach(id => {\n        assert.ok(\n          doc.getElementById(id),\n          'puts the right variants into sprite'\n        );\n      });\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('copies svg assets with no sprite config to output', async () => {\n    try {\n      const iconPath = `${output}/ui-icon/achievement`;\n      const files = fs.readdirSync(iconPath);\n      assert.ok(files.includes('filled.svg'));\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('sprites are always arranged alphabetically', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    try {\n      const content = fs.readFileSync(`${output}/test-icons.svg`, 'utf8');\n      const doc = new DOMParser().parseFromString(content, 'svg');\n      const svgs = doc.getElementsByTagName('svg');\n      assert.ok(svgs.length === 3, 'Only 2 variants in sprite');\n      const svgIDs = [\n        'animal-small',\n        'animal-large',\n      ];\n      svgIDs.forEach(id => {\n        assert.ok(\n          doc.getElementById(id),\n          'puts the right variants into sprite'\n        );\n      });\n\n      assert.equal(\n        svgs[1],\n        doc.getElementById('animal-large'),\n        'should be sorted alphabetically'\n      );\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n});\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index-test.js","sourceRoot":"","sources":["../../test/index-test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as configReader from '@icon-magic/config-reader';\nimport * as assert from 'assert';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\nimport { DOMParser } from 'xmldom';\n\nimport { distributeByType } from '../src';\n\nconst FIXTURES = path.resolve(__dirname, '..', '..', 'test', 'fixtures');\nconst input = path.resolve(FIXTURES, 'input');\nconst output = path.resolve(FIXTURES, 'out');\nconst iconSet = configReader.getIconConfigSet(new Array(input));\n\ndescribe('distribute works as expected', function () {\n  it('Moves all .webp files to the right output directory', async () => {\n    await distributeByType(iconSet, output, 'webp', false);\n    const iconPath = `${output}/drawable-xxxhdpi`;\n    try {\n      if (fs.existsSync(iconPath)) {\n        assert.ok(`${iconPath} dir was generated`);\n      } else {\n        assert.ok(false, `${iconPath} dir was not generated`);\n      }\n    } catch (err) {\n      assert.ok(false, `${err} reading ${iconPath}`);\n    }\n  });\n\n  it('.webp files are in the right output directory', async () => {\n    await distributeByType(iconSet, output, 'webp', false);\n    const iconPath = `${output}/drawable-xxxhdpi`;\n    const icons = [\n      {\n        iconName: 'ic_ui_icon_filled_1_filled_24x12'\n      },\n      {\n        iconName: 'ic_uix_icon_filled_2_filled_24x12'\n      },\n      {\n        iconName: 'ic_uixx_icon_filled_3_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_1_filled_60x60'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_4_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_filled_4_filled_60x60'\n      },\n      {\n        iconName: 'ic_ui_icon_2_filled_6_filled_24x12'\n      },\n      {\n        iconName: 'ic_ui_icon_2_filled_6_filled_60x60'\n      }\n    ];\n    const files = fs.readdirSync(iconPath);\n    icons.forEach(icon => {\n      assert.ok(\n        files.includes(`${icon.iconName}.webp`),\n        `includes ${icon.iconName}.webp`\n      );\n    });\n  });\n\n  it('Moves all .png files to the output directory', async () => {\n    const icons = [\n      {\n        iconName: 'filled_1_filled_24x12',\n        category: 'ui-icon'\n      },\n      {\n        iconName: 'filled_2_filled_24x12',\n        category: 'uix-icon'\n      },\n      {\n        iconName: 'filled_3_filled_24x12',\n        category: 'uixx-icon'\n      },\n      {\n        iconName: 'filled_1_filled_60x60',\n        category: 'ui-icon'\n      }\n    ];\n    await distributeByType(iconSet, output, 'png', false);\n\n    icons.forEach(icon => {\n      try {\n        const iconPath = `${output}/${icon.category}/${icon.category}_${icon.iconName}.imageset`;\n        if (fs.existsSync(iconPath)) {\n          assert.ok(`${iconPath} dir was generated`);\n          const files = fs.readdirSync(iconPath);\n          assert.ok(\n            files.indexOf('Contents.json') > -1,\n            'Contents.json was generated'\n          );\n          assert.ok(\n            files.indexOf(`${icon.category}_${icon.iconName}@2.png`) > -1,\n            `${icon.category}_${icon.iconName}@2.png was created`\n          );\n        } else {\n          assert.ok(false, `Missing files for ${iconPath}`);\n        }\n      } catch (err) {\n        assert.ok(false, err);\n      }\n    });\n  });\n\n  it('creates the sprite files', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    const spritePaths = [\n      {\n        path: 'icons.svg'\n      },\n      {\n        path: 'icons-1.svg'\n      },\n      {\n        path: 'icons-2.svg'\n      },\n      {\n        path: 'icons-3.svg'\n      }\n    ];\n    spritePaths.forEach(p => {\n      try {\n        if (fs.existsSync(`${output}/${p.path}`)) {\n          assert.ok(`${p} was generated`);\n        } else {\n          assert.ok(false, `${p} was not generated`);\n        }\n      } catch (err) {\n        assert.ok(false, `${p} was not generated: ${err}`);\n      }\n    });\n  });\n\n  it('sprite files contain defs with category for ID', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    const spritePaths = [\n      {\n        path: 'icons',\n        id: 'a-home-filled-1',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons',\n        id: 'point-default',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'point-default-2',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'ads-default',\n        category: 'app'\n      },\n      {\n        path: 'icons',\n        id: 'ads-default-2',\n        category: 'app'\n      },\n      {\n        path: 'icons-2',\n        id: 'b-home-filled-4',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-8',\n        category: 'ui-icon-2'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-88-9',\n        category: 'ui-icon-3'\n      },\n      {\n        path: 'icons-1',\n        id: 'c-home-filled-889',\n        category: 'ui-icon-2'\n      },\n      {\n        path: 'icons-2',\n        id: 'home-filled-2',\n        category: 'uix-icon'\n      },\n      {\n        path: 'icons-2',\n        id: 'home-filled-333',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-333',\n        category: 'ui-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-3',\n        category: 'uixx-icon'\n      },\n      {\n        path: 'icons-3',\n        id: 'home-filled-33',\n        category: 'uixx-icon'\n      }\n    ];\n    spritePaths.forEach(p => {\n      try {\n        const content = fs.readFileSync(`${output}/${p.path}.svg`, 'utf8');\n        const doc = new DOMParser().parseFromString(content, 'svg');\n        const docIdNode = doc.documentElement.getAttributeNode('id');\n        assert.ok(docIdNode && docIdNode.value === p.path, 'svg has ID');\n\n        const defs = doc.getElementById(p.category);\n        assert.ok(\n          defs && defs.tagName === 'defs',\n          'has <defs> element with the right ID'\n        );\n        assert.ok(doc.getElementById(p.id), 'has SVG with right ID');\n      } catch (err) {\n        assert.ok(false, `${err} with ${p.category}`);\n      }\n    });\n  });\n\n  it('it only puts 5 variants into the sprite', async () => {\n    try {\n      const content = fs.readFileSync(`${output}/icons.svg`, 'utf8');\n      const doc = new DOMParser().parseFromString(content, 'svg');\n      const svgs = doc.getElementsByTagName('svg');\n      // 2 icons + parent svg\n      assert.ok(svgs.length === 6, 'Only five variants in sprite');\n      const svgIDs = [\n        'ads-default',\n        'ads-default-2',\n        'point-default',\n        'point-default-2',\n        'a-home-filled-1'\n      ];\n      svgIDs.forEach(id => {\n        assert.ok(\n          doc.getElementById(id),\n          'puts the right variants into sprite'\n        );\n      });\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('copies svg assets with no sprite config to output', async () => {\n    try {\n      const iconPath = `${output}/ui-icon/achievement`;\n      const files = fs.readdirSync(iconPath);\n      assert.ok(files.includes('filled.svg'));\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('creates hbs files', async () => {\n    const iconSetAnimal = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/animal')));\n    await distributeByType(iconSetAnimal, output, 'svg', true, true);\n    try {\n      const files = fs.readdirSync(output);\n      console.log(files);\n      assert.ok(files.includes('animal-small.hbs'));\n      assert.ok(files.includes('animal-large.hbs'));\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('sprites are always arranged alphabetically', async () => {\n    await distributeByType(iconSet, output, 'svg', true);\n    try {\n      const content = fs.readFileSync(`${output}/test-icons.svg`, 'utf8');\n      const doc = new DOMParser().parseFromString(content, 'svg');\n      const svgs = doc.getElementsByTagName('svg');\n      assert.ok(svgs.length === 3, 'Only 2 variants in sprite');\n      const svgIDs = [\n        'animal-small',\n        'animal-large',\n      ];\n      svgIDs.forEach(id => {\n        assert.ok(\n          doc.getElementById(id),\n          'puts the right variants into sprite'\n        );\n      });\n\n      assert.equal(\n        svgs[1],\n        doc.getElementById('animal-large'),\n        'should be sorted alphabetically'\n      );\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n});\n"]} |
{ | ||
"name": "@icon-magic/distribute", | ||
"version": "2.2.5-beta.0", | ||
"version": "2.2.6-beta.0", | ||
"description": "Icon magic distribute package.", | ||
@@ -27,3 +27,3 @@ "main": "dist/src/index.js", | ||
}, | ||
"gitHead": "ca3f750fff0bb01195bb83fcc91fc2d4f4219b73" | ||
"gitHead": "6f85501b1d779b78e6540d339ded4fea6e357c38" | ||
} |
@@ -89,3 +89,3 @@ import { | ||
svgEl.setAttribute('id', spriteName); | ||
// Add <svg> element to SVG Document | ||
@@ -92,0 +92,0 @@ DOCUMENT.appendChild(svgEl); |
@@ -6,2 +6,3 @@ import { Asset, Icon, IconSet, SpriteConfig } from '@icon-magic/icon-models'; | ||
import { createHbs } from './create-icon-template'; | ||
import { | ||
@@ -26,3 +27,4 @@ addToSprite, | ||
outputPath: string, | ||
groupByCategory: boolean | ||
groupByCategory: boolean, | ||
outputAsHbs: boolean, | ||
): Promise<void> { | ||
@@ -40,3 +42,2 @@ // Sort icons so it looks pretty in .diff | ||
const svgConfig = distributeConfig && distributeConfig.svg; | ||
// variantsToFilter can be defined on distribute or on distribute.svg | ||
@@ -59,4 +60,11 @@ const iconVariantsToFilter = | ||
); | ||
if (iconHasSpriteConfig) { | ||
if (outputAsHbs) { | ||
try { | ||
await createHbs(assets, outputPath); | ||
} | ||
catch(e) { | ||
LOGGER.debug(`There was an issue creating the hbs file: ${e}`); | ||
} | ||
} | ||
else if (iconHasSpriteConfig) { | ||
// By default, if there is no distribute config, add to the sprite | ||
@@ -63,0 +71,0 @@ // Default spriteName is `icons` |
@@ -23,3 +23,4 @@ import { IconConfigHash, IconSet } from '@icon-magic/icon-models'; | ||
type: ICON_TYPES = 'all', | ||
groupByCategory = true | ||
groupByCategory = true, | ||
outputAsHbs = false, | ||
): Promise<void> { | ||
@@ -38,3 +39,3 @@ LOGGER.debug(`entering distribute with ${type}`); | ||
case 'svg': { | ||
await distributeSvg(iconSet, outputPath, groupByCategory); | ||
await distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs); | ||
break; | ||
@@ -45,5 +46,5 @@ } | ||
await distributeByResolution(iconSet, outputPath); | ||
await distributeSvg(iconSet, outputPath, groupByCategory); | ||
await distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs); | ||
} | ||
} | ||
} |
@@ -268,2 +268,15 @@ import * as configReader from '@icon-magic/config-reader'; | ||
it('creates hbs files', async () => { | ||
const iconSetAnimal = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/animal'))); | ||
await distributeByType(iconSetAnimal, output, 'svg', true, true); | ||
try { | ||
const files = fs.readdirSync(output); | ||
console.log(files); | ||
assert.ok(files.includes('animal-small.hbs')); | ||
assert.ok(files.includes('animal-large.hbs')); | ||
} catch (err) { | ||
assert.ok(false, err); | ||
} | ||
}); | ||
it('sprites are always arranged alphabetically', async () => { | ||
@@ -270,0 +283,0 @@ await distributeByType(iconSet, output, 'svg', true); |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
285
3533
4173839
6