Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@icon-magic/distribute

Package Overview
Dependencies
Maintainers
3
Versions
20
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@icon-magic/distribute - npm Package Compare versions

Comparing version 2.2.11-beta.0 to 2.3.0-beta.0

dist/test/fixtures/input/wordmark/build/iconrc.json

3

dist/src/create-icon-template.d.ts

@@ -6,3 +6,4 @@ import { Asset } from '@icon-magic/icon-models';

* @param outputPath path to write to
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
*/
export declare function createHbs(assets: Asset[], outputPath: string): Promise<void>;
export declare function createHbs(assets: Asset[], outputPath: string, doNotRemoveSuffix: boolean): Promise<void>;
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.createHbs = void 0;
const ember_template_recast_1 = require("ember-template-recast");
const fs = require("fs-extra");

@@ -11,4 +13,5 @@ const path = require("path");

* @param outputPath path to write to
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
*/
async function createHbs(assets, outputPath) {
async function createHbs(assets, outputPath, doNotRemoveSuffix) {
for (const asset of assets) {

@@ -23,17 +26,30 @@ const doc = new xmldom_1.DOMParser();

const id = el.getAttributeNode('id');
const iconName = id ? id.value : '';
let iconName = id ? id.value : '';
// Strip id
el.removeAttribute('id');
// add splattributes to the hbs file
xml.documentElement.setAttribute('...attributes', '');
await fs.mkdirp(outputPath);
const template = serializeToString(xml);
const { code } = ember_template_recast_1.transform({
template,
plugin(env) {
const { builders: b } = env.syntax;
return {
ElementNode(node) {
if (node.tag === 'svg') {
// add splattributes to the hbs file
node.attributes.unshift(b.attr('...attributes', b.text('')));
}
},
};
}
});
// Remove the "-mixed" suffix from the name. File will have same name as light version.
if (!doNotRemoveSuffix && asset.colorScheme === 'mixed') {
iconName = iconName.replace(/-mixed$/, '');
}
// xmldom and other dom substitutions (like jsdom) add ...attributes="" and
// the string replace below is an ugly hack to remove the empty string
fs.writeFile(path.join(outputPath, `${iconName}.hbs`), serializeToString(xml).replace(/...attributes=\"\"/g, '...attributes'), (err) => {
if (err)
throw err;
});
fs.writeFileSync(path.join(outputPath, `${iconName}.hbs`), code);
}
}
exports.createHbs = createHbs;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWljb24tdGVtcGxhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY3JlYXRlLWljb24tdGVtcGxhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQSwrQkFBK0I7QUFDL0IsNkJBQTZCO0FBQzdCLG1DQUFrRDtBQUdsRCxNQUFNLGlCQUFpQixHQUFHLElBQUksc0JBQWEsRUFBRSxDQUFDLGlCQUFpQixDQUFDO0FBRWhFOzs7O0dBSUc7QUFDSSxLQUFLLFVBQVUsU0FBUyxDQUM3QixNQUFlLEVBQ2YsVUFBa0I7SUFFbEIsS0FBSyxNQUFNLEtBQUssSUFBSSxNQUFNLEVBQUU7UUFDMUIsTUFBTSxHQUFHLEdBQUcsSUFBSSxrQkFBUyxFQUFFLENBQUM7UUFDNUIsaUZBQWlGO1FBQ2pGLDBCQUEwQjtRQUMxQixNQUFNLFFBQVEsR0FBRyxNQUFNLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUMzQywrQ0FBK0M7UUFDL0MsTUFBTSxHQUFHLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxRQUFrQixFQUFFLGVBQWUsQ0FBQyxDQUFDO1FBQ3JFLE1BQU0sRUFBRSxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUM7UUFDL0IsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ3JDLE1BQU0sUUFBUSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3BDLFdBQVc7UUFDWCxFQUFFLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRXpCLG9DQUFvQztRQUNwQyxHQUFHLENBQUMsZUFBZSxDQUFDLFlBQVksQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDdEQsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRTVCLDJFQUEyRTtRQUMzRSxzRUFBc0U7UUFDdEUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxHQUFHLFFBQVEsTUFBTSxDQUFDLEVBQUUsaUJBQWlCLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLHFCQUFxQixFQUFFLGVBQWUsQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDckksSUFBSSxHQUFHO2dCQUFFLE1BQU0sR0FBRyxDQUFDO1FBQ3JCLENBQUMsQ0FBQyxDQUFDO0tBQ0o7QUFDSCxDQUFDO0FBM0JELDhCQTJCQyIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICdAaWNvbi1tYWdpYy9pY29uLW1vZGVscyc7XG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcy1leHRyYSc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuaW1wb3J0IHsgRE9NUGFyc2VyLCBYTUxTZXJpYWxpemVyIH0gZnJvbSAneG1sZG9tJztcblxuXG5jb25zdCBzZXJpYWxpemVUb1N0cmluZyA9IG5ldyBYTUxTZXJpYWxpemVyKCkuc2VyaWFsaXplVG9TdHJpbmc7XG5cbi8qKlxuICogU2F2ZXMgc3ZnIGFzc2V0cyBhcyBoYW5kbGViYXJzIGZpbGVzXG4gKiBAcGFyYW0gYXNzZXRzIFNWRyBhc3NldHMgdG8gY29udmVydFxuICogQHBhcmFtIG91dHB1dFBhdGggcGF0aCB0byB3cml0ZSB0b1xuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY3JlYXRlSGJzKFxuICBhc3NldHM6IEFzc2V0W10sXG4gIG91dHB1dFBhdGg6IHN0cmluZyxcbik6IFByb21pc2U8dm9pZD4ge1xuICBmb3IgKGNvbnN0IGFzc2V0IG9mIGFzc2V0cykge1xuICAgIGNvbnN0IGRvYyA9IG5ldyBET01QYXJzZXIoKTtcbiAgICAvLyBHZXQgY29udGVudHMgb2YgdGhlIGFzc2V0LCBzaW5jZSBpdCdzIGFuIFNWRyB0aGUgY29udGVudCB3aWxsIGJlIGluIFhNTCBmb3JtYXRcbiAgICAvLyBDb250ZW50IEJ1ZmZlciB8IHN0cmluZ1xuICAgIGNvbnN0IGNvbnRlbnRzID0gYXdhaXQgYXNzZXQuZ2V0Q29udGVudHMoKTtcbiAgICAvLyBQYXJzZSBYTUwgZnJvbSBhIHN0cmluZyBpbnRvIGEgRE9NIERvY3VtZW50LlxuICAgIGNvbnN0IHhtbCA9IGRvYy5wYXJzZUZyb21TdHJpbmcoY29udGVudHMgYXMgc3RyaW5nLCAnaW1hZ2Uvc3ZnK3htbCcpO1xuICAgIGNvbnN0IGVsID0geG1sLmRvY3VtZW50RWxlbWVudDtcbiAgICBjb25zdCBpZCA9IGVsLmdldEF0dHJpYnV0ZU5vZGUoJ2lkJyk7XG4gICAgY29uc3QgaWNvbk5hbWUgPSBpZCA/IGlkLnZhbHVlIDogJyc7XG4gICAgLy8gU3RyaXAgaWRcbiAgICBlbC5yZW1vdmVBdHRyaWJ1dGUoJ2lkJyk7XG5cbiAgICAvLyBhZGQgc3BsYXR0cmlidXRlcyB0byB0aGUgaGJzIGZpbGVcbiAgICB4bWwuZG9jdW1lbnRFbGVtZW50LnNldEF0dHJpYnV0ZSgnLi4uYXR0cmlidXRlcycsICcnKTtcbiAgICBhd2FpdCBmcy5ta2RpcnAob3V0cHV0UGF0aCk7XG5cbiAgICAvLyB4bWxkb20gYW5kIG90aGVyIGRvbSBzdWJzdGl0dXRpb25zIChsaWtlIGpzZG9tKSBhZGQgLi4uYXR0cmlidXRlcz1cIlwiIGFuZFxuICAgIC8vIHRoZSBzdHJpbmcgcmVwbGFjZSBiZWxvdyBpcyBhbiB1Z2x5IGhhY2sgdG8gcmVtb3ZlIHRoZSBlbXB0eSBzdHJpbmdcbiAgICBmcy53cml0ZUZpbGUocGF0aC5qb2luKG91dHB1dFBhdGgsIGAke2ljb25OYW1lfS5oYnNgKSwgc2VyaWFsaXplVG9TdHJpbmcoeG1sKS5yZXBsYWNlKC8uLi5hdHRyaWJ1dGVzPVxcXCJcXFwiL2csICcuLi5hdHRyaWJ1dGVzJyksIChlcnIpID0+IHtcbiAgICAgIGlmIChlcnIpIHRocm93IGVycjtcbiAgICB9KTtcbiAgfVxufVxuXG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWljb24tdGVtcGxhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY3JlYXRlLWljb24tdGVtcGxhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsaUVBQWtEO0FBQ2xELCtCQUErQjtBQUMvQiw2QkFBNkI7QUFDN0IsbUNBQWtEO0FBRWxELE1BQU0saUJBQWlCLEdBQUcsSUFBSSxzQkFBYSxFQUFFLENBQUMsaUJBQWlCLENBQUM7QUFFaEU7Ozs7O0dBS0c7QUFDSSxLQUFLLFVBQVUsU0FBUyxDQUM3QixNQUFlLEVBQ2YsVUFBa0IsRUFDbEIsaUJBQTBCO0lBRTFCLEtBQUssTUFBTSxLQUFLLElBQUksTUFBTSxFQUFFO1FBQzFCLE1BQU0sR0FBRyxHQUFHLElBQUksa0JBQVMsRUFBRSxDQUFDO1FBQzVCLGlGQUFpRjtRQUNqRiwwQkFBMEI7UUFDMUIsTUFBTSxRQUFRLEdBQUcsTUFBTSxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDM0MsK0NBQStDO1FBQy9DLE1BQU0sR0FBRyxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUMsUUFBa0IsRUFBRSxlQUFlLENBQUMsQ0FBQztRQUNyRSxNQUFNLEVBQUUsR0FBRyxHQUFHLENBQUMsZUFBZSxDQUFDO1FBQy9CLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNyQyxJQUFJLFFBQVEsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNsQyxXQUFXO1FBQ1gsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV6QixNQUFNLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN4QyxNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsaUNBQVMsQ0FBQztZQUN6QixRQUFRO1lBQ1IsTUFBTSxDQUFDLEdBQUc7Z0JBQ1IsTUFBTSxFQUFFLFFBQVEsRUFBRSxDQUFDLEVBQUUsR0FBRyxHQUFHLENBQUMsTUFBTSxDQUFDO2dCQUVuQyxPQUFPO29CQUNMLFdBQVcsQ0FBQyxJQUFJO3dCQUNkLElBQUksSUFBSSxDQUFDLEdBQUcsS0FBSyxLQUFLLEVBQUU7NEJBQ3RCLG9DQUFvQzs0QkFDcEMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7eUJBQzlEO29CQUNILENBQUM7aUJBQ0YsQ0FBQztZQUNKLENBQUM7U0FDRixDQUFDLENBQUM7UUFFSCx1RkFBdUY7UUFDdkYsSUFBSSxDQUFDLGlCQUFpQixJQUFJLEtBQUssQ0FBQyxXQUFXLEtBQUssT0FBTyxFQUFFO1lBQ3ZELFFBQVEsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztTQUM1QztRQUdELDJFQUEyRTtRQUMzRSxzRUFBc0U7UUFDdEUsRUFBRSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxHQUFHLFFBQVEsTUFBTSxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FDbEU7QUFDSCxDQUFDO0FBN0NELDhCQTZDQyIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICdAaWNvbi1tYWdpYy9pY29uLW1vZGVscyc7XG5pbXBvcnQgeyB0cmFuc2Zvcm0gfSBmcm9tICdlbWJlci10ZW1wbGF0ZS1yZWNhc3QnO1xuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMtZXh0cmEnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcbmltcG9ydCB7IERPTVBhcnNlciwgWE1MU2VyaWFsaXplciB9IGZyb20gJ3htbGRvbSc7XG5cbmNvbnN0IHNlcmlhbGl6ZVRvU3RyaW5nID0gbmV3IFhNTFNlcmlhbGl6ZXIoKS5zZXJpYWxpemVUb1N0cmluZztcblxuLyoqXG4gKiBTYXZlcyBzdmcgYXNzZXRzIGFzIGhhbmRsZWJhcnMgZmlsZXNcbiAqIEBwYXJhbSBhc3NldHMgU1ZHIGFzc2V0cyB0byBjb252ZXJ0XG4gKiBAcGFyYW0gb3V0cHV0UGF0aCBwYXRoIHRvIHdyaXRlIHRvXG4gKiBAcGFyYW0gZG9Ob3RSZW1vdmVTdWZmaXggYm9vbGVhbiwgd2hlbiB0cnVlIHdpbGwga2VlcCB0aGUgXCItbWl4ZWRcIiBzdWZmaXggaW4gZmlsZSBuYW1lIHdoZW4gZGlzdHJpYnV0aW5nIHRvIGhicy5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGNyZWF0ZUhicyhcbiAgYXNzZXRzOiBBc3NldFtdLFxuICBvdXRwdXRQYXRoOiBzdHJpbmcsXG4gIGRvTm90UmVtb3ZlU3VmZml4OiBib29sZWFuXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgZm9yIChjb25zdCBhc3NldCBvZiBhc3NldHMpIHtcbiAgICBjb25zdCBkb2MgPSBuZXcgRE9NUGFyc2VyKCk7XG4gICAgLy8gR2V0IGNvbnRlbnRzIG9mIHRoZSBhc3NldCwgc2luY2UgaXQncyBhbiBTVkcgdGhlIGNvbnRlbnQgd2lsbCBiZSBpbiBYTUwgZm9ybWF0XG4gICAgLy8gQ29udGVudCBCdWZmZXIgfCBzdHJpbmdcbiAgICBjb25zdCBjb250ZW50cyA9IGF3YWl0IGFzc2V0LmdldENvbnRlbnRzKCk7XG4gICAgLy8gUGFyc2UgWE1MIGZyb20gYSBzdHJpbmcgaW50byBhIERPTSBEb2N1bWVudC5cbiAgICBjb25zdCB4bWwgPSBkb2MucGFyc2VGcm9tU3RyaW5nKGNvbnRlbnRzIGFzIHN0cmluZywgJ2ltYWdlL3N2Zyt4bWwnKTtcbiAgICBjb25zdCBlbCA9IHhtbC5kb2N1bWVudEVsZW1lbnQ7XG4gICAgY29uc3QgaWQgPSBlbC5nZXRBdHRyaWJ1dGVOb2RlKCdpZCcpO1xuICAgIGxldCBpY29uTmFtZSA9IGlkID8gaWQudmFsdWUgOiAnJztcbiAgICAvLyBTdHJpcCBpZFxuICAgIGVsLnJlbW92ZUF0dHJpYnV0ZSgnaWQnKTtcblxuICAgIGNvbnN0IHRlbXBsYXRlID0gc2VyaWFsaXplVG9TdHJpbmcoeG1sKTtcbiAgICBjb25zdCB7IGNvZGUgfSA9IHRyYW5zZm9ybSh7XG4gICAgICB0ZW1wbGF0ZSxcbiAgICAgIHBsdWdpbihlbnYpIHtcbiAgICAgICAgY29uc3QgeyBidWlsZGVyczogYiB9ID0gZW52LnN5bnRheDtcblxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIEVsZW1lbnROb2RlKG5vZGUpIHtcbiAgICAgICAgICAgIGlmIChub2RlLnRhZyA9PT0gJ3N2ZycpIHtcbiAgICAgICAgICAgICAgLy8gYWRkIHNwbGF0dHJpYnV0ZXMgdG8gdGhlIGhicyBmaWxlXG4gICAgICAgICAgICAgIG5vZGUuYXR0cmlidXRlcy51bnNoaWZ0KGIuYXR0cignLi4uYXR0cmlidXRlcycsIGIudGV4dCgnJykpKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9LFxuICAgICAgICB9O1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgLy8gUmVtb3ZlIHRoZSBcIi1taXhlZFwiIHN1ZmZpeCBmcm9tIHRoZSBuYW1lLiBGaWxlIHdpbGwgaGF2ZSBzYW1lIG5hbWUgYXMgbGlnaHQgdmVyc2lvbi5cbiAgICBpZiAoIWRvTm90UmVtb3ZlU3VmZml4ICYmIGFzc2V0LmNvbG9yU2NoZW1lID09PSAnbWl4ZWQnKSB7XG4gICAgICBpY29uTmFtZSA9IGljb25OYW1lLnJlcGxhY2UoLy1taXhlZCQvLCAnJyk7XG4gICAgfVxuXG5cbiAgICAvLyB4bWxkb20gYW5kIG90aGVyIGRvbSBzdWJzdGl0dXRpb25zIChsaWtlIGpzZG9tKSBhZGQgLi4uYXR0cmlidXRlcz1cIlwiIGFuZFxuICAgIC8vIHRoZSBzdHJpbmcgcmVwbGFjZSBiZWxvdyBpcyBhbiB1Z2x5IGhhY2sgdG8gcmVtb3ZlIHRoZSBlbXB0eSBzdHJpbmdcbiAgICBmcy53cml0ZUZpbGVTeW5jKHBhdGguam9pbihvdXRwdXRQYXRoLCBgJHtpY29uTmFtZX0uaGJzYCksIGNvZGUpO1xuICB9XG59XG5cbiJdfQ==
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.createImageSet = void 0;
const logger_1 = require("@icon-magic/logger");

@@ -107,2 +108,2 @@ const fs = require("fs-extra");

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-image-set.js","sourceRoot":"","sources":["../../src/create-image-set.ts"],"names":[],"mappings":"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","sourcesContent":["import { Asset, IconSet } from '@icon-magic/icon-models';\nimport { Logger } from '@icon-magic/logger';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport { getAssetResolutionFromName, getIconFlavorsByType } from './utils';\n\nconst LOGGER = new Logger('icon-magic:distribute:create-image-set');\nconst IOS_SUPPORTED_RESOLUTIONS = [1, 2, 3];\n\ninterface ContentImage {\n  idiom: string;\n  scale: string;\n  filename: string;\n}\n\n// TODO: populate this interface as needed\n// from https://developer.apple.com/library/archive/documentation/Xcode/Reference/xcode_ref-Asset_Catalog_Format/ImageSetType.html\ninterface AssetCatalog {\n  images?: ContentImage[];\n}\n\n/**\n * Creates an imageSet which is needed for iOS\n * This consists of the assets in different resolutions and a corresponding\n * Content.json file\n * @param icon the icon for which the imageSet needs to be created\n * @param outputPath output directory path to copy the assets to\n */\nexport async function createImageSet(iconSet: IconSet, outputPath: string) {\n  for (const icon of iconSet.hash.values()) {\n    LOGGER.debug(`Creating imageSet for ${icon.iconName}`);\n    const assets = getIconFlavorsByType(icon, 'png');\n    const promises = [];\n    const ASSET_CATALOG = 'Contents.json'; // as defined for iOS\n    let iconOutputPath = outputPath;\n\n    // prepend the outputPath with the category so output icons are categorized\n    // by category name\n    if (icon.category) {\n      iconOutputPath = path.join(iconOutputPath, icon.category);\n    }\n\n    for (const asset of assets) {\n      // if the asset is not a supported ios resolution, then do nothing\n      if (!isSupportedResolution(asset)) {\n        continue;\n      }\n\n      // Example .x/y/23/filled-24x12@2.png -> filled-24x12@2.png\n      const assetPathBasename = path.basename(asset.getPath());\n\n      // This will be the name the file is saved as\n      let assetNameForCatalog = `${icon.iconName}_${assetPathBasename}`.replace(/-/g, '_');\n\n      /* This will be the folder the files are saved in\n       * Usually for ios every variant gets its own folder\n       * But we want dark and light assets (which are technically separate variants)\n       * to be in the same folder so we use `imageset` if available\n       * `imageset` is a name grouping that's shared across light and dark assets\n      */\n      let assetImagesetForCatalog = asset.imageset ?\n        `${icon.iconName}_${asset.imageset}`.replace(/-/g, '_') : `${assetNameForCatalog.split('@')[0]}`;\n\n      // if the category is present, prepend it to the name\n      if (icon.category) {\n        assetNameForCatalog = `${icon.category}_${assetNameForCatalog}`;\n        assetImagesetForCatalog = `${icon.category}_${assetImagesetForCatalog}`;\n      }\n\n      const outputIconDir = path.join(\n        iconOutputPath,\n        `${assetImagesetForCatalog}.imageset`\n      );\n\n      await fs.mkdirp(outputIconDir);\n\n      const assetCatalogPath = path.join(outputIconDir, ASSET_CATALOG);\n      let images: ContentImage[];\n      if (fs.existsSync(assetCatalogPath)) {\n        const assetCatalogContents: AssetCatalog = await loadJSONFile(\n          assetCatalogPath\n        );\n        images = assetCatalogContents.images || [];\n      } else {\n        images = [];\n      }\n\n      promises.push(\n        fs.copy(asset.getPath(), path.join(outputIconDir, assetNameForCatalog))\n      );\n\n      // update the assetCatalog if it doesn't contain the asset already\n      const doesImageExist = images.find(\n        img => img.filename === assetNameForCatalog\n      );\n      if (!doesImageExist) {\n        images.push({\n          idiom: 'universal',\n          scale: getAssetResolutionFromName(asset, true),\n          filename: assetNameForCatalog,\n          ...(asset.colorScheme === 'dark' && {\n            appearances: [\n              {\n                appearance: 'luminosity',\n                value: 'dark'\n              }\n            ]\n          }),\n        });\n        await writeJSONfile(assetCatalogPath, { images });\n      }\n    }\n    await Promise.all(promises);\n  }\n}\n\n/**\n * Loads a JSON from a file.\n * @param filePath The filename to load.\n * @returns The JSON contents as an object\n */\nasync function loadJSONFile(filePath: string): Promise<object> {\n  return JSON.parse(await fs.readFile(filePath, 'utf8'));\n}\n\n/**\n * Writes JSON to file\n * @param filePath The filePath to write to\n * @returns Promise to the writeFile operation\n */\nasync function writeJSONfile(filePath: string, data: object): Promise<void> {\n  return fs.writeFile(`${path.join(filePath)}`, JSON.stringify(data, null, 2));\n}\n\n/**\n * Checks if the asset is among the supported resolutions by looking at the name\n * of the asset\n * @param asset the asset to check if it's in a supported resolution\n */\nfunction isSupportedResolution(asset: Asset) {\n  const assetResolution = Number(asset.name.split('@').pop());\n  return assetResolution\n    ? IOS_SUPPORTED_RESOLUTIONS.includes(Number(assetResolution))\n    : true;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-image-set.js","sourceRoot":"","sources":["../../src/create-image-set.ts"],"names":[],"mappings":"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","sourcesContent":["import { Asset, IconSet } from '@icon-magic/icon-models';\nimport { Logger } from '@icon-magic/logger';\nimport * as fs from 'fs-extra';\nimport * as path from 'path';\n\nimport { getAssetResolutionFromName, getIconFlavorsByType } from './utils';\n\nconst LOGGER = new Logger('icon-magic:distribute:create-image-set');\nconst IOS_SUPPORTED_RESOLUTIONS = [1, 2, 3];\n\ninterface ContentImage {\n  idiom: string;\n  scale: string;\n  filename: string;\n}\n\n// TODO: populate this interface as needed\n// from https://developer.apple.com/library/archive/documentation/Xcode/Reference/xcode_ref-Asset_Catalog_Format/ImageSetType.html\ninterface AssetCatalog {\n  images?: ContentImage[];\n}\n\n/**\n * Creates an imageSet which is needed for iOS\n * This consists of the assets in different resolutions and a corresponding\n * Content.json file\n * @param icon the icon for which the imageSet needs to be created\n * @param outputPath output directory path to copy the assets to\n */\nexport async function createImageSet(iconSet: IconSet, outputPath: string) {\n  for (const icon of iconSet.hash.values()) {\n    LOGGER.debug(`Creating imageSet for ${icon.iconName}`);\n    const assets = getIconFlavorsByType(icon, 'png');\n    const promises = [];\n    const ASSET_CATALOG = 'Contents.json'; // as defined for iOS\n    let iconOutputPath = outputPath;\n\n    // prepend the outputPath with the category so output icons are categorized\n    // by category name\n    if (icon.category) {\n      iconOutputPath = path.join(iconOutputPath, icon.category);\n    }\n\n    for (const asset of assets) {\n      // if the asset is not a supported ios resolution, then do nothing\n      if (!isSupportedResolution(asset)) {\n        continue;\n      }\n\n      // Example .x/y/23/filled-24x12@2.png -> filled-24x12@2.png\n      const assetPathBasename = path.basename(asset.getPath());\n\n      // This will be the name the file is saved as\n      let assetNameForCatalog = `${icon.iconName}_${assetPathBasename}`.replace(/-/g, '_');\n\n      /* This will be the folder the files are saved in\n       * Usually for ios every variant gets its own folder\n       * But we want dark and light assets (which are technically separate variants)\n       * to be in the same folder so we use `imageset` if available\n       * `imageset` is a name grouping that's shared across light and dark assets\n      */\n      let assetImagesetForCatalog = asset.imageset ?\n        `${icon.iconName}_${asset.imageset}`.replace(/-/g, '_') : `${assetNameForCatalog.split('@')[0]}`;\n\n      // if the category is present, prepend it to the name\n      if (icon.category) {\n        assetNameForCatalog = `${icon.category}_${assetNameForCatalog}`;\n        assetImagesetForCatalog = `${icon.category}_${assetImagesetForCatalog}`;\n      }\n\n      const outputIconDir = path.join(\n        iconOutputPath,\n        `${assetImagesetForCatalog}.imageset`\n      );\n\n      await fs.mkdirp(outputIconDir);\n\n      const assetCatalogPath = path.join(outputIconDir, ASSET_CATALOG);\n      let images: ContentImage[];\n      if (fs.existsSync(assetCatalogPath)) {\n        const assetCatalogContents: AssetCatalog = await loadJSONFile(\n          assetCatalogPath\n        );\n        images = assetCatalogContents.images || [];\n      } else {\n        images = [];\n      }\n\n      promises.push(\n        fs.copy(asset.getPath(), path.join(outputIconDir, assetNameForCatalog))\n      );\n\n      // update the assetCatalog if it doesn't contain the asset already\n      const doesImageExist = images.find(\n        img => img.filename === assetNameForCatalog\n      );\n      if (!doesImageExist) {\n        images.push({\n          idiom: 'universal',\n          scale: getAssetResolutionFromName(asset, true),\n          filename: assetNameForCatalog,\n          ...(asset.colorScheme === 'dark' && {\n            appearances: [\n              {\n                appearance: 'luminosity',\n                value: 'dark'\n              }\n            ]\n          }),\n        });\n        await writeJSONfile(assetCatalogPath, { images });\n      }\n    }\n    await Promise.all(promises);\n  }\n}\n\n/**\n * Loads a JSON from a file.\n * @param filePath The filename to load.\n * @returns The JSON contents as an object\n */\nasync function loadJSONFile(filePath: string): Promise<object> {\n  return JSON.parse(await fs.readFile(filePath, 'utf8'));\n}\n\n/**\n * Writes JSON to file\n * @param filePath The filePath to write to\n * @returns Promise to the writeFile operation\n */\nasync function writeJSONfile(filePath: string, data: object): Promise<void> {\n  return fs.writeFile(`${path.join(filePath)}`, JSON.stringify(data, null, 2));\n}\n\n/**\n * Checks if the asset is among the supported resolutions by looking at the name\n * of the asset\n * @param asset the asset to check if it's in a supported resolution\n */\nfunction isSupportedResolution(asset: Asset) {\n  const assetResolution = Number(asset.name.split('@').pop());\n  return assetResolution\n    ? IOS_SUPPORTED_RESOLUTIONS.includes(Number(assetResolution))\n    : true;\n}\n"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.partitionAssetsForSprite = exports.writeSpriteToFile = exports.appendToSvgDoc = exports.createSVGDoc = exports.addToSprite = void 0;
const icon_models_1 = require("@icon-magic/icon-models");

@@ -196,2 +197,2 @@ const logger_1 = require("@icon-magic/logger");

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 } from '@icon-magic/logger';\nimport { DOMImplementation, DOMParser, XMLSerializer } from 'xmldom';\n\nimport { compareStrings, removeResolutionFromName } from './utils';\n\nconst LOGGER = new 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 } from '@icon-magic/logger';\nimport { DOMImplementation, DOMParser, XMLSerializer } from 'xmldom';\n\nimport { compareStrings, removeResolutionFromName } from './utils';\n\nconst LOGGER = new 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"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.distributeByResolution = void 0;
const logger_1 = require("@icon-magic/logger");

@@ -55,2 +56,2 @@ const fs = require("fs-extra");

exports.distributeByResolution = distributeByResolution;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdHJpYnV0ZS1ieS1yZXNvbHV0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Rpc3RyaWJ1dGUtYnktcmVzb2x1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLCtDQUE0QztBQUM1QywrQkFBK0I7QUFDL0IsNkJBQTZCO0FBRTdCLG1DQUEyRTtBQUMzRSxNQUFNLE1BQU0sR0FBRyxJQUFJLGVBQU0sQ0FBQyxnREFBZ0QsQ0FBQyxDQUFDO0FBRTVFLE1BQU0sZ0JBQWdCLEdBQUcsSUFBSSxDQUFDO0FBRTlCOzs7Ozs7R0FNRztBQUNJLEtBQUssVUFBVSxzQkFBc0IsQ0FDMUMsT0FBZ0IsRUFDaEIsVUFBa0I7SUFFbEIsS0FBSyxNQUFNLElBQUksSUFBSSxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFO1FBQ3hDLE1BQU0sQ0FBQyxLQUFLLENBQUMsOEJBQThCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBQzVELE1BQU0sTUFBTSxHQUFHLDRCQUFvQixDQUFDLElBQUksRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNsRCxJQUFJLGFBQWEsQ0FBQztRQUNsQiwrQ0FBK0M7UUFDL0MsTUFBTSxRQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ3BCLEtBQUssTUFBTSxLQUFLLElBQUksTUFBTSxFQUFFO1lBQzFCLGdEQUFnRDtZQUNoRCxhQUFhLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUUsa0NBQTBCLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUV6RSxpREFBaUQ7WUFDakQsc0NBQXNDO1lBQ3RDLElBQUksU0FBUyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ3pDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDL0IsU0FBUyxHQUFHLEdBQUcsUUFBUSxJQUFJLFNBQVMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7WUFFdkUscURBQXFEO1lBQ3JELElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDakIsU0FBUyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsSUFBSSxTQUFTLEVBQUUsQ0FBQzthQUM3QztZQUVELDRFQUE0RTtZQUM1RSx3QkFBd0I7WUFDeEIsTUFBTSxVQUFVLEdBQ2QsQ0FBQyxJQUFJLENBQUMsVUFBVTtnQkFDZCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUk7Z0JBQ3BCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztnQkFDbEMsZ0JBQWdCLENBQUM7WUFFbkIsU0FBUyxHQUFHLEdBQUcsVUFBVSxJQUFJLFNBQVMsRUFBRSxDQUFDO1lBRXpDLGlFQUFpRTtZQUNqRSxTQUFTLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsR0FBRyxDQUFDLENBQUM7WUFFekMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1lBRS9CLHFFQUFxRTtZQUNyRSxZQUFZO1lBQ1oseUVBQXlFO1lBQ3pFLHlEQUF5RDtZQUN6RCxRQUFRLENBQUMsSUFBSSxDQUNYLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLFNBQVMsQ0FBQyxDQUFDLENBQzlELENBQUM7U0FDSDtRQUNELE1BQU0sT0FBTyxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsQ0FBQztLQUM3QjtBQUNILENBQUM7QUFsREQsd0RBa0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvblNldCB9IGZyb20gJ0BpY29uLW1hZ2ljL2ljb24tbW9kZWxzJztcbmltcG9ydCB7IExvZ2dlciB9IGZyb20gJ0BpY29uLW1hZ2ljL2xvZ2dlcic7XG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcy1leHRyYSc7XG5pbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQgeyBnZXRBc3NldFJlc29sdXRpb25Gcm9tTmFtZSwgZ2V0SWNvbkZsYXZvcnNCeVR5cGUgfSBmcm9tICcuL3V0aWxzJztcbmNvbnN0IExPR0dFUiA9IG5ldyBMb2dnZXIoJ2ljb24tbWFnaWM6ZGlzdHJpYnV0ZTpkaXN0cmlidXRlLWJ5LXJlc29sdXRpb24nKTtcblxuY29uc3QgSUNPTl9OQU1FX1BSRUZJWCA9ICdpYyc7XG5cbi8qKlxuICogRGlzdHJpYnV0ZXMgaWNvbnMgaW50byBkaWZmZXJlbnQgZm9sZGVycyBiYXNlZCBvbiB0aGUgcmVzb2x1dGlvblxuICogVGhpcyBpcyBuZWVkZWQgZm9yIEFuZHJvaWRcbiAqIEBwYXJhbSBpY29uU2V0IHNldCBvZiBpY29ucyB0byBiZSBtb3ZlZCB0byB0aGUgb3V0cHV0IGZvbGRlclxuICogQHBhcmFtIG91dHB1dFBhdGggb3V0cHV0IGRpcmVjdG9yeSB3aGVyZSB0aGUgZGlmZmVyZW50IGZvbGRlcnMgYXJlIGNyZWF0ZWRcbiAqIGZvciBlYWNoIHJlc29sdXRpb25cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGRpc3RyaWJ1dGVCeVJlc29sdXRpb24oXG4gIGljb25TZXQ6IEljb25TZXQsXG4gIG91dHB1dFBhdGg6IHN0cmluZ1xuKSB7XG4gIGZvciAoY29uc3QgaWNvbiBvZiBpY29uU2V0Lmhhc2gudmFsdWVzKCkpIHtcbiAgICBMT0dHRVIuZGVidWcoYGRpc3RyaWJ1dGVCeVJlc29sdXRpb24gZm9yICR7aWNvbi5pY29uTmFtZX1gKTtcbiAgICBjb25zdCBhc3NldHMgPSBnZXRJY29uRmxhdm9yc0J5VHlwZShpY29uLCAnd2VicCcpO1xuICAgIGxldCBvdXRwdXRJY29uRGlyO1xuICAgIC8vIGNvcHkgYWxsIGFzc2V0cyB0byB0aGUgb3V0cHV0IGljb24gZGlyZWN0b3J5XG4gICAgY29uc3QgcHJvbWlzZXMgPSBbXTtcbiAgICBmb3IgKGNvbnN0IGFzc2V0IG9mIGFzc2V0cykge1xuICAgICAgLy8gdGhlIG91dHB1dCBmb2xkZXIgaXMgdGhlIGZvbGRlciBieSByZXNvbHV0aW9uXG4gICAgICBvdXRwdXRJY29uRGlyID0gcGF0aC5qb2luKG91dHB1dFBhdGgsIGdldEFzc2V0UmVzb2x1dGlvbkZyb21OYW1lKGFzc2V0KSk7XG5cbiAgICAgIC8vIGdldCB0aGUgYXNzZXQgbmFtZSBieSBwcmVwZW5kaW5nIHRoZSBpY29uIG5hbWVcbiAgICAgIC8vIGFsc28gbWFraW5nIGJvdGggb2YgdGhlbSBrZWJhYiBjYXNlXG4gICAgICBsZXQgYXNzZXROYW1lID0gYXNzZXQubmFtZS5zcGxpdCgnQCcpWzBdO1xuICAgICAgY29uc3QgaWNvbk5hbWUgPSBpY29uLmljb25OYW1lO1xuICAgICAgYXNzZXROYW1lID0gYCR7aWNvbk5hbWV9XyR7YXNzZXROYW1lfSR7cGF0aC5leHRuYW1lKGFzc2V0LmdldFBhdGgoKSl9YDtcblxuICAgICAgLy8gaWYgdGhlIGNhdGVnb3J5IGlzIHByZXNlbnQsIHByZXBlbmQgaXQgdG8gdGhlIG5hbWVcbiAgICAgIGlmIChpY29uLmNhdGVnb3J5KSB7XG4gICAgICAgIGFzc2V0TmFtZSA9IGAke2ljb24uY2F0ZWdvcnl9XyR7YXNzZXROYW1lfWA7XG4gICAgICB9XG5cbiAgICAgIC8vIGJ5IGRlZmF1bHQgdGhlIGljb24gcHJlZml4IGlzIElDT05fTkFNRV9QUkVGSVggd2hpY2ggY2FuIGJlIG92ZXJyaWRkZW4gaW5cbiAgICAgIC8vIHRoZSBkaXN0cmlidXRlIGNvbmZpZ1xuICAgICAgY29uc3QgbmFtZVByZWZpeCA9XG4gICAgICAgIChpY29uLmRpc3RyaWJ1dGUgJiZcbiAgICAgICAgICBpY29uLmRpc3RyaWJ1dGUud2VicCAmJlxuICAgICAgICAgIGljb24uZGlzdHJpYnV0ZS53ZWJwLm5hbWVQcmVmaXgpIHx8XG4gICAgICAgIElDT05fTkFNRV9QUkVGSVg7XG5cbiAgICAgIGFzc2V0TmFtZSA9IGAke25hbWVQcmVmaXh9XyR7YXNzZXROYW1lfWA7XG5cbiAgICAgIC8vIHJlcGxhY2UgYWxsIC0gd2l0aCBfIGluIHRoZSBuYW1lIHRvIGZvbGxvdyBhbmRyb2lkIGNvbnZlbnRpb25zXG4gICAgICBhc3NldE5hbWUgPSBhc3NldE5hbWUucmVwbGFjZSgvLS9nLCAnXycpO1xuXG4gICAgICBhd2FpdCBmcy5ta2RpcnAob3V0cHV0SWNvbkRpcik7XG5cbiAgICAgIC8vIGFwcGVuZCB0aGUgaWNvbiBuYW1lIHRvIHRoZSBhc3NldCBzaW5jZSBhbGwgaWNvbnMgZ28gaW50byBhIHNpbmdsZVxuICAgICAgLy8gZGlyZWN0b3J5XG4gICAgICAvLyBUT0RPOiBoYXZlIGljb25zIGhhdmUgYSBjYXRlZ29yeSBmaWVsZCBpbiB0aGVpciBjb25maWcgYW5kIHByZXBlbmQgdGhlXG4gICAgICAvLyBjYXRlZ29yeSB0byB0aGUgYXNzZXQgbmFtZS4gRWc6IG5hdl9pY29uTmFtZV9hc3NldE5hbWVcbiAgICAgIHByb21pc2VzLnB1c2goXG4gICAgICAgIGZzLmNvcHkoYXNzZXQuZ2V0UGF0aCgpLCBwYXRoLmpvaW4ob3V0cHV0SWNvbkRpciwgYXNzZXROYW1lKSlcbiAgICAgICk7XG4gICAgfVxuICAgIGF3YWl0IFByb21pc2UuYWxsKHByb21pc2VzKTtcbiAgfVxufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlzdHJpYnV0ZS1ieS1yZXNvbHV0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Rpc3RyaWJ1dGUtYnktcmVzb2x1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrQ0FBNEM7QUFDNUMsK0JBQStCO0FBQy9CLDZCQUE2QjtBQUU3QixtQ0FBMkU7QUFDM0UsTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFNLENBQUMsZ0RBQWdELENBQUMsQ0FBQztBQUU1RSxNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQztBQUU5Qjs7Ozs7O0dBTUc7QUFDSSxLQUFLLFVBQVUsc0JBQXNCLENBQzFDLE9BQWdCLEVBQ2hCLFVBQWtCO0lBRWxCLEtBQUssTUFBTSxJQUFJLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsRUFBRTtRQUN4QyxNQUFNLENBQUMsS0FBSyxDQUFDLDhCQUE4QixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUM1RCxNQUFNLE1BQU0sR0FBRyw0QkFBb0IsQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDbEQsSUFBSSxhQUFhLENBQUM7UUFDbEIsK0NBQStDO1FBQy9DLE1BQU0sUUFBUSxHQUFHLEVBQUUsQ0FBQztRQUNwQixLQUFLLE1BQU0sS0FBSyxJQUFJLE1BQU0sRUFBRTtZQUMxQixnREFBZ0Q7WUFDaEQsYUFBYSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLGtDQUEwQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFFekUsaURBQWlEO1lBQ2pELHNDQUFzQztZQUN0QyxJQUFJLFNBQVMsR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN6QyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO1lBQy9CLFNBQVMsR0FBRyxHQUFHLFFBQVEsSUFBSSxTQUFTLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDO1lBRXZFLHFEQUFxRDtZQUNyRCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ2pCLFNBQVMsR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLElBQUksU0FBUyxFQUFFLENBQUM7YUFDN0M7WUFFRCw0RUFBNEU7WUFDNUUsd0JBQXdCO1lBQ3hCLE1BQU0sVUFBVSxHQUNkLENBQUMsSUFBSSxDQUFDLFVBQVU7Z0JBQ2QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJO2dCQUNwQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7Z0JBQ2xDLGdCQUFnQixDQUFDO1lBRW5CLFNBQVMsR0FBRyxHQUFHLFVBQVUsSUFBSSxTQUFTLEVBQUUsQ0FBQztZQUV6QyxpRUFBaUU7WUFDakUsU0FBUyxHQUFHLFNBQVMsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBRXpDLE1BQU0sRUFBRSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztZQUUvQixxRUFBcUU7WUFDckUsWUFBWTtZQUNaLHlFQUF5RTtZQUN6RSx5REFBeUQ7WUFDekQsUUFBUSxDQUFDLElBQUksQ0FDWCxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUM5RCxDQUFDO1NBQ0g7UUFDRCxNQUFNLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7S0FDN0I7QUFDSCxDQUFDO0FBbERELHdEQWtEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25TZXQgfSBmcm9tICdAaWNvbi1tYWdpYy9pY29uLW1vZGVscyc7XG5pbXBvcnQgeyBMb2dnZXIgfSBmcm9tICdAaWNvbi1tYWdpYy9sb2dnZXInO1xuaW1wb3J0ICogYXMgZnMgZnJvbSAnZnMtZXh0cmEnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHsgZ2V0QXNzZXRSZXNvbHV0aW9uRnJvbU5hbWUsIGdldEljb25GbGF2b3JzQnlUeXBlIH0gZnJvbSAnLi91dGlscyc7XG5jb25zdCBMT0dHRVIgPSBuZXcgTG9nZ2VyKCdpY29uLW1hZ2ljOmRpc3RyaWJ1dGU6ZGlzdHJpYnV0ZS1ieS1yZXNvbHV0aW9uJyk7XG5cbmNvbnN0IElDT05fTkFNRV9QUkVGSVggPSAnaWMnO1xuXG4vKipcbiAqIERpc3RyaWJ1dGVzIGljb25zIGludG8gZGlmZmVyZW50IGZvbGRlcnMgYmFzZWQgb24gdGhlIHJlc29sdXRpb25cbiAqIFRoaXMgaXMgbmVlZGVkIGZvciBBbmRyb2lkXG4gKiBAcGFyYW0gaWNvblNldCBzZXQgb2YgaWNvbnMgdG8gYmUgbW92ZWQgdG8gdGhlIG91dHB1dCBmb2xkZXJcbiAqIEBwYXJhbSBvdXRwdXRQYXRoIG91dHB1dCBkaXJlY3Rvcnkgd2hlcmUgdGhlIGRpZmZlcmVudCBmb2xkZXJzIGFyZSBjcmVhdGVkXG4gKiBmb3IgZWFjaCByZXNvbHV0aW9uXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBkaXN0cmlidXRlQnlSZXNvbHV0aW9uKFxuICBpY29uU2V0OiBJY29uU2V0LFxuICBvdXRwdXRQYXRoOiBzdHJpbmdcbikge1xuICBmb3IgKGNvbnN0IGljb24gb2YgaWNvblNldC5oYXNoLnZhbHVlcygpKSB7XG4gICAgTE9HR0VSLmRlYnVnKGBkaXN0cmlidXRlQnlSZXNvbHV0aW9uIGZvciAke2ljb24uaWNvbk5hbWV9YCk7XG4gICAgY29uc3QgYXNzZXRzID0gZ2V0SWNvbkZsYXZvcnNCeVR5cGUoaWNvbiwgJ3dlYnAnKTtcbiAgICBsZXQgb3V0cHV0SWNvbkRpcjtcbiAgICAvLyBjb3B5IGFsbCBhc3NldHMgdG8gdGhlIG91dHB1dCBpY29uIGRpcmVjdG9yeVxuICAgIGNvbnN0IHByb21pc2VzID0gW107XG4gICAgZm9yIChjb25zdCBhc3NldCBvZiBhc3NldHMpIHtcbiAgICAgIC8vIHRoZSBvdXRwdXQgZm9sZGVyIGlzIHRoZSBmb2xkZXIgYnkgcmVzb2x1dGlvblxuICAgICAgb3V0cHV0SWNvbkRpciA9IHBhdGguam9pbihvdXRwdXRQYXRoLCBnZXRBc3NldFJlc29sdXRpb25Gcm9tTmFtZShhc3NldCkpO1xuXG4gICAgICAvLyBnZXQgdGhlIGFzc2V0IG5hbWUgYnkgcHJlcGVuZGluZyB0aGUgaWNvbiBuYW1lXG4gICAgICAvLyBhbHNvIG1ha2luZyBib3RoIG9mIHRoZW0ga2ViYWIgY2FzZVxuICAgICAgbGV0IGFzc2V0TmFtZSA9IGFzc2V0Lm5hbWUuc3BsaXQoJ0AnKVswXTtcbiAgICAgIGNvbnN0IGljb25OYW1lID0gaWNvbi5pY29uTmFtZTtcbiAgICAgIGFzc2V0TmFtZSA9IGAke2ljb25OYW1lfV8ke2Fzc2V0TmFtZX0ke3BhdGguZXh0bmFtZShhc3NldC5nZXRQYXRoKCkpfWA7XG5cbiAgICAgIC8vIGlmIHRoZSBjYXRlZ29yeSBpcyBwcmVzZW50LCBwcmVwZW5kIGl0IHRvIHRoZSBuYW1lXG4gICAgICBpZiAoaWNvbi5jYXRlZ29yeSkge1xuICAgICAgICBhc3NldE5hbWUgPSBgJHtpY29uLmNhdGVnb3J5fV8ke2Fzc2V0TmFtZX1gO1xuICAgICAgfVxuXG4gICAgICAvLyBieSBkZWZhdWx0IHRoZSBpY29uIHByZWZpeCBpcyBJQ09OX05BTUVfUFJFRklYIHdoaWNoIGNhbiBiZSBvdmVycmlkZGVuIGluXG4gICAgICAvLyB0aGUgZGlzdHJpYnV0ZSBjb25maWdcbiAgICAgIGNvbnN0IG5hbWVQcmVmaXggPVxuICAgICAgICAoaWNvbi5kaXN0cmlidXRlICYmXG4gICAgICAgICAgaWNvbi5kaXN0cmlidXRlLndlYnAgJiZcbiAgICAgICAgICBpY29uLmRpc3RyaWJ1dGUud2VicC5uYW1lUHJlZml4KSB8fFxuICAgICAgICBJQ09OX05BTUVfUFJFRklYO1xuXG4gICAgICBhc3NldE5hbWUgPSBgJHtuYW1lUHJlZml4fV8ke2Fzc2V0TmFtZX1gO1xuXG4gICAgICAvLyByZXBsYWNlIGFsbCAtIHdpdGggXyBpbiB0aGUgbmFtZSB0byBmb2xsb3cgYW5kcm9pZCBjb252ZW50aW9uc1xuICAgICAgYXNzZXROYW1lID0gYXNzZXROYW1lLnJlcGxhY2UoLy0vZywgJ18nKTtcblxuICAgICAgYXdhaXQgZnMubWtkaXJwKG91dHB1dEljb25EaXIpO1xuXG4gICAgICAvLyBhcHBlbmQgdGhlIGljb24gbmFtZSB0byB0aGUgYXNzZXQgc2luY2UgYWxsIGljb25zIGdvIGludG8gYSBzaW5nbGVcbiAgICAgIC8vIGRpcmVjdG9yeVxuICAgICAgLy8gVE9ETzogaGF2ZSBpY29ucyBoYXZlIGEgY2F0ZWdvcnkgZmllbGQgaW4gdGhlaXIgY29uZmlnIGFuZCBwcmVwZW5kIHRoZVxuICAgICAgLy8gY2F0ZWdvcnkgdG8gdGhlIGFzc2V0IG5hbWUuIEVnOiBuYXZfaWNvbk5hbWVfYXNzZXROYW1lXG4gICAgICBwcm9taXNlcy5wdXNoKFxuICAgICAgICBmcy5jb3B5KGFzc2V0LmdldFBhdGgoKSwgcGF0aC5qb2luKG91dHB1dEljb25EaXIsIGFzc2V0TmFtZSkpXG4gICAgICApO1xuICAgIH1cbiAgICBhd2FpdCBQcm9taXNlLmFsbChwcm9taXNlcyk7XG4gIH1cbn1cbiJdfQ==

@@ -7,4 +7,6 @@ import { IconSet } from '@icon-magic/icon-models';

* @param groupByCategory (for sprite creation) whether to group by the category attribute
* @param colorScheme array of strings matching the colorScheme attributes of the icon i.e: `light`, `dark`, `mixed`.
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
* @returns promise after completion
*/
export declare function distributeSvg(iconSet: IconSet, outputPath: string, groupByCategory: boolean, outputAsHbs: boolean): Promise<void>;
export declare function distributeSvg(iconSet: IconSet, outputPath: string, groupByCategory: boolean, outputAsHbs: boolean, colorScheme: string[], doNotRemoveSuffix: boolean): Promise<void>;
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.distributeSvg = void 0;
const logger_1 = require("@icon-magic/logger");

@@ -15,5 +16,7 @@ const fs = require("fs-extra");

* @param groupByCategory (for sprite creation) whether to group by the category attribute
* @param colorScheme array of strings matching the colorScheme attributes of the icon i.e: `light`, `dark`, `mixed`.
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
* @returns promise after completion
*/
async function distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs) {
async function distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs, colorScheme, doNotRemoveSuffix) {
// Sort icons so it looks pretty in .diff

@@ -26,4 +29,15 @@ const icons = sortIcons(iconSet.hash.values());

for (const icon of icons) {
LOGGER.debug(`calling distributeSvg on ${icon.iconName}: ${icon.iconPath}`);
LOGGER.debug(`calling distributeSvg on ${icon.iconName}: ${icon.iconPath} with colorScheme: ${colorScheme}`);
if (!doNotRemoveSuffix && colorScheme.includes('mixed')) {
LOGGER.warn(`Warning: By default the "-mixed" suffix is trimmed from the file name when distributed to hbs. The file name will be the SAME as the light variant. Use the --doNotRemoveSuffix flag to keep the "-mixed" in the file name.`);
}
const assets = utils_1.getIconFlavorsByType(icon, 'svg');
// Further filter the icons by matching the assets's colorScheme to the commander option --colorScheme
const assetsByColorScheme = assets.filter(asset => {
if (asset.colorScheme) {
return colorScheme.includes(asset.colorScheme);
}
// Light variants can either have colorScheme: `light`, null, or undefined
return colorScheme.includes('light');
});
const distributeConfig = icon.distribute;

@@ -37,4 +51,4 @@ const svgConfig = distributeConfig && distributeConfig.svg;

const { assetsToAddToSprite, assetsNoSprite } = variantsToFilter && variantsToFilter.length
? create_sprite_1.partitionAssetsForSprite(assets, variantsToFilter)
: { assetsToAddToSprite: assets, assetsNoSprite: assets };
? create_sprite_1.partitionAssetsForSprite(assetsByColorScheme, variantsToFilter)
: { assetsToAddToSprite: assetsByColorScheme, assetsNoSprite: assetsByColorScheme };
const iconHasSpriteConfig = !(distributeConfig &&

@@ -48,3 +62,3 @@ svgConfig &&

: outputPath;
await create_icon_template_1.createHbs(assets, destPath);
await create_icon_template_1.createHbs(assetsByColorScheme, destPath, doNotRemoveSuffix);
}

@@ -105,2 +119,2 @@ catch (e) {

}
//# 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 } 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 = new 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        const destPath =\n        icon.category && groupByCategory\n          ? path.join(outputPath, icon.category)\n          : outputPath;\n        await createHbs(assets, destPath);\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"]}
//# 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 } 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 = new 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 * @param colorScheme array of strings matching the colorScheme attributes of the icon i.e: `light`, `dark`, `mixed`.\n * @param doNotRemoveSuffix boolean, when true will keep the \"-mixed\" suffix in file name when distributing to hbs.\n * @returns promise after completion\n */\nexport async function distributeSvg(\n  iconSet: IconSet,\n  outputPath: string,\n  groupByCategory: boolean,\n  outputAsHbs: boolean,\n  colorScheme: string[],\n  doNotRemoveSuffix: 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} with colorScheme: ${colorScheme}`);\n    if (!doNotRemoveSuffix && colorScheme.includes('mixed')){\n      LOGGER.warn(`Warning: By default the \"-mixed\" suffix is trimmed from the file name when distributed to hbs. The file name will be the SAME as the light variant. Use the --doNotRemoveSuffix flag to keep the \"-mixed\" in the file name.`);\n    }\n\n    const assets = getIconFlavorsByType(icon, 'svg');\n\n    // Further filter the icons by matching the assets's colorScheme to the commander option --colorScheme\n    const assetsByColorScheme = assets.filter(asset => {\n      if (asset.colorScheme) {\n        return colorScheme.includes(asset.colorScheme);\n      }\n      // Light variants can either have colorScheme: `light`, null, or undefined\n      return colorScheme.includes('light');\n    });\n\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(assetsByColorScheme, variantsToFilter)\n        : { assetsToAddToSprite: assetsByColorScheme, assetsNoSprite: assetsByColorScheme };\n\n    const iconHasSpriteConfig = !(\n      distributeConfig &&\n      svgConfig &&\n      !svgConfig.toSprite\n    );\n    if (outputAsHbs) {\n      try {\n        const destPath =\n        icon.category && groupByCategory\n          ? path.join(outputPath, icon.category)\n          : outputPath;\n        await createHbs(assetsByColorScheme, destPath, doNotRemoveSuffix);\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"]}

@@ -9,5 +9,7 @@ import { IconConfigHash } from '@icon-magic/icon-models';

* @param groupByCategory (for sprite creation) whether to group by the category attribute
* @param colorScheme array of strings matching the colorScheme attributes of the icon ie: `light`, `dark`, `mixed`.
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
* @retuns promise after completion
*/
export declare function distributeByType(iconConfig: IconConfigHash, outputPath: string, type?: ICON_TYPES, groupByCategory?: boolean, outputAsHbs?: boolean): Promise<void>;
export declare function distributeByType(iconConfig: IconConfigHash, outputPath: string, type?: ICON_TYPES, groupByCategory?: boolean, outputAsHbs?: boolean, colorScheme?: string[], doNotRemoveSuffix?: boolean): Promise<void>;
export {};
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.distributeByType = void 0;
const icon_models_1 = require("@icon-magic/icon-models");

@@ -15,6 +16,8 @@ const logger_1 = require("@icon-magic/logger");

* @param groupByCategory (for sprite creation) whether to group by the category attribute
* @param colorScheme array of strings matching the colorScheme attributes of the icon ie: `light`, `dark`, `mixed`.
* @param doNotRemoveSuffix boolean, when true will keep the "-mixed" suffix in file name when distributing to hbs.
* @retuns promise after completion
*/
async function distributeByType(iconConfig, outputPath, type = 'all', groupByCategory = true, outputAsHbs = false) {
LOGGER.debug(`entering distribute with ${type}`);
async function distributeByType(iconConfig, outputPath, type = 'all', groupByCategory = true, outputAsHbs = false, colorScheme = ['light', 'dark'], doNotRemoveSuffix = false) {
LOGGER.debug(`entering distribute with ${type} and colorSchemes: ${colorScheme}`);
const iconSet = new icon_models_1.IconSet(iconConfig, true);

@@ -31,3 +34,3 @@ switch (type) {

case 'svg': {
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs);
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs, colorScheme, doNotRemoveSuffix);
break;

@@ -38,3 +41,3 @@ }

await distribute_by_resolution_1.distributeByResolution(iconSet, outputPath);
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs);
await distribute_svg_1.distributeSvg(iconSet, outputPath, groupByCategory, outputAsHbs, colorScheme, doNotRemoveSuffix);
}

@@ -44,2 +47,2 @@ }

exports.distributeByType = distributeByType;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5REFBa0U7QUFDbEUsK0NBQTRDO0FBRTVDLHlEQUFvRDtBQUNwRCx5RUFBb0U7QUFDcEUscURBQWlEO0FBRWpELE1BQU0sTUFBTSxHQUFHLElBQUksZUFBTSxDQUFDLDZCQUE2QixDQUFDLENBQUM7QUFHekQ7Ozs7Ozs7R0FPRztBQUNJLEtBQUssVUFBVSxnQkFBZ0IsQ0FDcEMsVUFBMEIsRUFDMUIsVUFBa0IsRUFDbEIsT0FBbUIsS0FBSyxFQUN4QixlQUFlLEdBQUcsSUFBSSxFQUN0QixXQUFXLEdBQUcsS0FBSztJQUVuQixNQUFNLENBQUMsS0FBSyxDQUFDLDRCQUE0QixJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBQ2pELE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDOUMsUUFBUSxJQUFJLEVBQUU7UUFDWixLQUFLLEtBQUssQ0FBQyxDQUFDO1lBQ1YsTUFBTSxpQ0FBYyxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztZQUMxQyxNQUFNO1NBQ1A7UUFDRCxLQUFLLE1BQU0sQ0FBQyxDQUFDO1lBQ1gsTUFBTSxpREFBc0IsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDbEQsTUFBTTtTQUNQO1FBQ0QsS0FBSyxLQUFLLENBQUMsQ0FBQztZQUNWLE1BQU0sOEJBQWEsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxXQUFXLENBQUMsQ0FBQztZQUN2RSxNQUFNO1NBQ1A7UUFDRCxPQUFPLENBQUMsQ0FBQztZQUNQLE1BQU0saUNBQWMsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDMUMsTUFBTSxpREFBc0IsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDbEQsTUFBTSw4QkFBYSxDQUFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1NBQ3hFO0tBQ0Y7QUFDSCxDQUFDO0FBNUJELDRDQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25Db25maWdIYXNoLCBJY29uU2V0IH0gZnJvbSAnQGljb24tbWFnaWMvaWNvbi1tb2RlbHMnO1xuaW1wb3J0IHsgTG9nZ2VyIH0gZnJvbSAnQGljb24tbWFnaWMvbG9nZ2VyJztcblxuaW1wb3J0IHsgY3JlYXRlSW1hZ2VTZXQgfSBmcm9tICcuL2NyZWF0ZS1pbWFnZS1zZXQnO1xuaW1wb3J0IHsgZGlzdHJpYnV0ZUJ5UmVzb2x1dGlvbiB9IGZyb20gJy4vZGlzdHJpYnV0ZS1ieS1yZXNvbHV0aW9uJztcbmltcG9ydCB7IGRpc3RyaWJ1dGVTdmcgfSBmcm9tICcuL2Rpc3RyaWJ1dGUtc3ZnJztcblxuY29uc3QgTE9HR0VSID0gbmV3IExvZ2dlcignaWNvbi1tYWdpYzpkaXN0cmlidXRlOmluZGV4Jyk7XG50eXBlIElDT05fVFlQRVMgPSAnc3ZnJyB8ICdwbmcnIHwgJ3dlYnAnIHwgJ2FsbCc7XG5cbi8qKlxuICogRGlzdHJpYnV0ZXMgYSBzZXQgb2YgaWNvbnMgdG8gdGhlIG91dHB1dCBmb2xkZXIgYmFzZWQgb24gdGhlIGZsYWdcbiAqIEBwYXJhbSBpY29uU2V0IHNldCBvZiBpY29ucyB0byBiZSBtb3ZlZCB0byB0aGUgb3V0cHV0IGZvbGRlclxuICogQHBhcmFtIG91dHB1dFBhdGggb3V0cHV0IGRpcmVjdG9yeSBwYXRoIHRvIGNvcHkgdGhlIGFzc2V0cyB0b1xuICogQHBhcmFtIHR5cGUgc3ZnLCBwbmcsIHdlYnAsIGFsbFxuICogQHBhcmFtIGdyb3VwQnlDYXRlZ29yeSAoZm9yIHNwcml0ZSBjcmVhdGlvbikgd2hldGhlciB0byBncm91cCBieSB0aGUgY2F0ZWdvcnkgYXR0cmlidXRlXG4gKiBAcmV0dW5zIHByb21pc2UgYWZ0ZXIgY29tcGxldGlvblxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gZGlzdHJpYnV0ZUJ5VHlwZShcbiAgaWNvbkNvbmZpZzogSWNvbkNvbmZpZ0hhc2gsXG4gIG91dHB1dFBhdGg6IHN0cmluZyxcbiAgdHlwZTogSUNPTl9UWVBFUyA9ICdhbGwnLFxuICBncm91cEJ5Q2F0ZWdvcnkgPSB0cnVlLFxuICBvdXRwdXRBc0hicyA9IGZhbHNlXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgTE9HR0VSLmRlYnVnKGBlbnRlcmluZyBkaXN0cmlidXRlIHdpdGggJHt0eXBlfWApO1xuICBjb25zdCBpY29uU2V0ID0gbmV3IEljb25TZXQoaWNvbkNvbmZpZywgdHJ1ZSk7XG4gIHN3aXRjaCAodHlwZSkge1xuICAgIGNhc2UgJ3BuZyc6IHtcbiAgICAgIGF3YWl0IGNyZWF0ZUltYWdlU2V0KGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgJ3dlYnAnOiB7XG4gICAgICBhd2FpdCBkaXN0cmlidXRlQnlSZXNvbHV0aW9uKGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgJ3N2Zyc6IHtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVTdmcoaWNvblNldCwgb3V0cHV0UGF0aCwgZ3JvdXBCeUNhdGVnb3J5LCBvdXRwdXRBc0hicyk7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgZGVmYXVsdDoge1xuICAgICAgYXdhaXQgY3JlYXRlSW1hZ2VTZXQoaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBhd2FpdCBkaXN0cmlidXRlQnlSZXNvbHV0aW9uKGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYXdhaXQgZGlzdHJpYnV0ZVN2ZyhpY29uU2V0LCBvdXRwdXRQYXRoLCBncm91cEJ5Q2F0ZWdvcnksIG91dHB1dEFzSGJzKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEseURBQWtFO0FBQ2xFLCtDQUE0QztBQUU1Qyx5REFBb0Q7QUFDcEQseUVBQW9FO0FBQ3BFLHFEQUFpRDtBQUVqRCxNQUFNLE1BQU0sR0FBRyxJQUFJLGVBQU0sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO0FBR3pEOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxnQkFBZ0IsQ0FDcEMsVUFBMEIsRUFDMUIsVUFBa0IsRUFDbEIsT0FBbUIsS0FBSyxFQUN4QixlQUFlLEdBQUcsSUFBSSxFQUN0QixXQUFXLEdBQUcsS0FBSyxFQUNuQixjQUF3QixDQUFDLE9BQU8sRUFBRSxNQUFNLENBQUMsRUFDekMsaUJBQWlCLEdBQUcsS0FBSztJQUV6QixNQUFNLENBQUMsS0FBSyxDQUFDLDRCQUE0QixJQUFJLHNCQUFzQixXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQ2xGLE1BQU0sT0FBTyxHQUFHLElBQUkscUJBQU8sQ0FBQyxVQUFVLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDOUMsUUFBUSxJQUFJLEVBQUU7UUFDWixLQUFLLEtBQUssQ0FBQyxDQUFDO1lBQ1YsTUFBTSxpQ0FBYyxDQUFDLE9BQU8sRUFBRSxVQUFVLENBQUMsQ0FBQztZQUMxQyxNQUFNO1NBQ1A7UUFDRCxLQUFLLE1BQU0sQ0FBQyxDQUFDO1lBQ1gsTUFBTSxpREFBc0IsQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUM7WUFDbEQsTUFBTTtTQUNQO1FBQ0QsS0FBSyxLQUFLLENBQUMsQ0FBQztZQUNWLE1BQU0sOEJBQWEsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLGlCQUFpQixDQUFDLENBQUM7WUFDdkcsTUFBTTtTQUNQO1FBQ0QsT0FBTyxDQUFDLENBQUM7WUFDUCxNQUFNLGlDQUFjLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQzFDLE1BQU0saURBQXNCLENBQUMsT0FBTyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1lBQ2xELE1BQU0sOEJBQWEsQ0FBQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLGlCQUFpQixDQUFDLENBQUM7U0FDeEc7S0FDRjtBQUNILENBQUM7QUE5QkQsNENBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbkNvbmZpZ0hhc2gsIEljb25TZXQgfSBmcm9tICdAaWNvbi1tYWdpYy9pY29uLW1vZGVscyc7XG5pbXBvcnQgeyBMb2dnZXIgfSBmcm9tICdAaWNvbi1tYWdpYy9sb2dnZXInO1xuXG5pbXBvcnQgeyBjcmVhdGVJbWFnZVNldCB9IGZyb20gJy4vY3JlYXRlLWltYWdlLXNldCc7XG5pbXBvcnQgeyBkaXN0cmlidXRlQnlSZXNvbHV0aW9uIH0gZnJvbSAnLi9kaXN0cmlidXRlLWJ5LXJlc29sdXRpb24nO1xuaW1wb3J0IHsgZGlzdHJpYnV0ZVN2ZyB9IGZyb20gJy4vZGlzdHJpYnV0ZS1zdmcnO1xuXG5jb25zdCBMT0dHRVIgPSBuZXcgTG9nZ2VyKCdpY29uLW1hZ2ljOmRpc3RyaWJ1dGU6aW5kZXgnKTtcbnR5cGUgSUNPTl9UWVBFUyA9ICdzdmcnIHwgJ3BuZycgfCAnd2VicCcgfCAnYWxsJztcblxuLyoqXG4gKiBEaXN0cmlidXRlcyBhIHNldCBvZiBpY29ucyB0byB0aGUgb3V0cHV0IGZvbGRlciBiYXNlZCBvbiB0aGUgZmxhZ1xuICogQHBhcmFtIGljb25TZXQgc2V0IG9mIGljb25zIHRvIGJlIG1vdmVkIHRvIHRoZSBvdXRwdXQgZm9sZGVyXG4gKiBAcGFyYW0gb3V0cHV0UGF0aCBvdXRwdXQgZGlyZWN0b3J5IHBhdGggdG8gY29weSB0aGUgYXNzZXRzIHRvXG4gKiBAcGFyYW0gdHlwZSBzdmcsIHBuZywgd2VicCwgYWxsXG4gKiBAcGFyYW0gZ3JvdXBCeUNhdGVnb3J5IChmb3Igc3ByaXRlIGNyZWF0aW9uKSB3aGV0aGVyIHRvIGdyb3VwIGJ5IHRoZSBjYXRlZ29yeSBhdHRyaWJ1dGVcbiAqIEBwYXJhbSBjb2xvclNjaGVtZSBhcnJheSBvZiBzdHJpbmdzIG1hdGNoaW5nIHRoZSBjb2xvclNjaGVtZSBhdHRyaWJ1dGVzIG9mIHRoZSBpY29uIGllOiBgbGlnaHRgLCBgZGFya2AsIGBtaXhlZGAuXG4gKiBAcGFyYW0gZG9Ob3RSZW1vdmVTdWZmaXggYm9vbGVhbiwgd2hlbiB0cnVlIHdpbGwga2VlcCB0aGUgXCItbWl4ZWRcIiBzdWZmaXggaW4gZmlsZSBuYW1lIHdoZW4gZGlzdHJpYnV0aW5nIHRvIGhicy5cbiAqIEByZXR1bnMgcHJvbWlzZSBhZnRlciBjb21wbGV0aW9uXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBkaXN0cmlidXRlQnlUeXBlKFxuICBpY29uQ29uZmlnOiBJY29uQ29uZmlnSGFzaCxcbiAgb3V0cHV0UGF0aDogc3RyaW5nLFxuICB0eXBlOiBJQ09OX1RZUEVTID0gJ2FsbCcsXG4gIGdyb3VwQnlDYXRlZ29yeSA9IHRydWUsXG4gIG91dHB1dEFzSGJzID0gZmFsc2UsXG4gIGNvbG9yU2NoZW1lOiBzdHJpbmdbXSA9IFsnbGlnaHQnLCAnZGFyayddLFxuICBkb05vdFJlbW92ZVN1ZmZpeCA9IGZhbHNlXG4pOiBQcm9taXNlPHZvaWQ+IHtcbiAgTE9HR0VSLmRlYnVnKGBlbnRlcmluZyBkaXN0cmlidXRlIHdpdGggJHt0eXBlfSBhbmQgY29sb3JTY2hlbWVzOiAke2NvbG9yU2NoZW1lfWApO1xuICBjb25zdCBpY29uU2V0ID0gbmV3IEljb25TZXQoaWNvbkNvbmZpZywgdHJ1ZSk7XG4gIHN3aXRjaCAodHlwZSkge1xuICAgIGNhc2UgJ3BuZyc6IHtcbiAgICAgIGF3YWl0IGNyZWF0ZUltYWdlU2V0KGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgJ3dlYnAnOiB7XG4gICAgICBhd2FpdCBkaXN0cmlidXRlQnlSZXNvbHV0aW9uKGljb25TZXQsIG91dHB1dFBhdGgpO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgJ3N2Zyc6IHtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVTdmcoaWNvblNldCwgb3V0cHV0UGF0aCwgZ3JvdXBCeUNhdGVnb3J5LCBvdXRwdXRBc0hicywgY29sb3JTY2hlbWUsIGRvTm90UmVtb3ZlU3VmZml4KTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBkZWZhdWx0OiB7XG4gICAgICBhd2FpdCBjcmVhdGVJbWFnZVNldChpY29uU2V0LCBvdXRwdXRQYXRoKTtcbiAgICAgIGF3YWl0IGRpc3RyaWJ1dGVCeVJlc29sdXRpb24oaWNvblNldCwgb3V0cHV0UGF0aCk7XG4gICAgICBhd2FpdCBkaXN0cmlidXRlU3ZnKGljb25TZXQsIG91dHB1dFBhdGgsIGdyb3VwQnlDYXRlZ29yeSwgb3V0cHV0QXNIYnMsIGNvbG9yU2NoZW1lLCBkb05vdFJlbW92ZVN1ZmZpeCk7XG4gICAgfVxuICB9XG59XG4iXX0=
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.compareStrings = exports.removeResolutionFromName = exports.getIconFlavorsByType = exports.getAssetResolutionFromName = void 0;
/**

@@ -84,2 +85,2 @@ * The resolution of an asset is within the assets name as "@resolution"

exports.compareStrings = compareStrings;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFFQTs7Ozs7OztHQU9HO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQ3hDLEtBQVksRUFDWixVQUFvQjtJQUVwQixJQUFJLFVBQVUsQ0FBQztJQUNmLElBQUksS0FBSyxDQUFDO0lBQ1YsUUFBUSxJQUFJLEVBQUU7UUFDWixLQUFLLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDNUIsVUFBVSxHQUFHLGVBQWUsQ0FBQztZQUM3QixLQUFLLEdBQUcsTUFBTSxDQUFDO1lBQ2YsTUFBTTtTQUNQO1FBQ0QsS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQzFCLFVBQVUsR0FBRyxlQUFlLENBQUM7WUFDN0IsS0FBSyxHQUFHLElBQUksQ0FBQztZQUNiLE1BQU07U0FDUDtRQUNELEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUMxQixVQUFVLEdBQUcsZ0JBQWdCLENBQUM7WUFDOUIsS0FBSyxHQUFHLElBQUksQ0FBQztZQUNiLE1BQU07U0FDUDtRQUNELEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUMxQixVQUFVLEdBQUcsaUJBQWlCLENBQUM7WUFDL0IsS0FBSyxHQUFHLElBQUksQ0FBQztZQUNiLE1BQU07U0FDUDtRQUNELE9BQU8sQ0FBQyxDQUFDO1lBQ1AsVUFBVSxHQUFHLGtCQUFrQixDQUFDO1lBQ2hDLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDYixNQUFNO1NBQ1A7S0FDRjtJQUNELE9BQU8sVUFBVSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQztBQUN6QyxDQUFDO0FBbENELGdFQWtDQztBQUVEOzs7Ozs7R0FNRztBQUNILFNBQWdCLG9CQUFvQixDQUFDLElBQVUsRUFBRSxJQUFnQjtJQUMvRCxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQztTQUNyQyxNQUFNLENBQUMsQ0FBQyxNQUFjLEVBQUUsRUFBRTtRQUN6QixPQUFPLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUMsQ0FBQztTQUNELEdBQUcsQ0FBQyxDQUFDLE1BQWMsRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFVLENBQUMsQ0FBQyxDQUFDLGlGQUFpRjtBQUNoSixDQUFDO0FBTkQsb0RBTUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0Isd0JBQXdCLENBQUMsUUFBZ0I7SUFDdkQsT0FBTyxRQUFRLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLHFCQUFxQixFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUM7QUFDekYsQ0FBQztBQUZELDREQUVDO0FBRUQ7Ozs7O0dBS0c7QUFDSCxTQUFnQixjQUFjLENBQUMsT0FBZSxFQUFFLE9BQWU7SUFDN0QsSUFBSSxPQUFPLEdBQUcsT0FBTyxFQUFFO1FBQ3JCLE9BQU8sQ0FBQyxDQUFDLENBQUM7S0FDWDtJQUNELElBQUksT0FBTyxHQUFHLE9BQU8sRUFBRTtRQUNyQixPQUFPLENBQUMsQ0FBQztLQUNWO0lBQ0QsT0FBTyxDQUFDLENBQUM7QUFDWCxDQUFDO0FBUkQsd0NBUUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3NldCwgRmxhdm9yLCBGbGF2b3JUeXBlLCBJY29uIH0gZnJvbSAnQGljb24tbWFnaWMvaWNvbi1tb2RlbHMnO1xuXG4vKipcbiAqIFRoZSByZXNvbHV0aW9uIG9mIGFuIGFzc2V0IGlzIHdpdGhpbiB0aGUgYXNzZXRzIG5hbWUgYXMgXCJAcmVzb2x1dGlvblwiXG4gKiBUaGlzIGZ1bmN0aW9uIG1hdGNoZXMgdGhlIG5hbWUgYWdhaW5zdCBkaWZmZXJlbnQgcmVzb2x1dGlvbnMgYW5kIHJldHVybnMgdGhlXG4gKiBhcHByb3ByaWF0ZSBzY2FsZSBvciByZXNvbHV0aW9uXG4gKiBAcGFyYW0gYXNzZXQgdGhlIGFzc2V0IHdob3NlIHJlc29sdXRpb24gbmVlZHMgdG8gYmUgZGV0ZXJtaW5lZFxuICogQHBhcmFtIGdldEFzU2NhbGUgQm9vbGVhbiBmb3IgcmV0dXJuaW5nIHRoZSBzY2FsZSBpbnN0ZWFkIG9mIHRoZSByZXNvbHV0aW9uXG4gKiBAcmV0dXJucyBlaXRoZXIgdGhlIHJlc29sdXRpb24gb3Igc2NhbGUgZGVwZW5kaW5nIG9uIHRoZSBib29sZWFuIGdldEFzU2NhbGVcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEFzc2V0UmVzb2x1dGlvbkZyb21OYW1lKFxuICBhc3NldDogQXNzZXQsXG4gIGdldEFzU2NhbGU/OiBCb29sZWFuXG4pOiBzdHJpbmcge1xuICBsZXQgcmVzb2x1dGlvbjtcbiAgbGV0IHNjYWxlO1xuICBzd2l0Y2ggKHRydWUpIHtcbiAgICBjYXNlIC9AMS41Ly50ZXN0KGFzc2V0Lm5hbWUpOiB7XG4gICAgICByZXNvbHV0aW9uID0gJ2RyYXdhYmxlLWhkcGknO1xuICAgICAgc2NhbGUgPSAnMS41eCc7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAvQDEvLnRlc3QoYXNzZXQubmFtZSk6IHtcbiAgICAgIHJlc29sdXRpb24gPSAnZHJhd2FibGUtbWRwaSc7XG4gICAgICBzY2FsZSA9ICcxeCc7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgY2FzZSAvQDIvLnRlc3QoYXNzZXQubmFtZSk6IHtcbiAgICAgIHJlc29sdXRpb24gPSAnZHJhd2FibGUteGhkcGknO1xuICAgICAgc2NhbGUgPSAnMngnO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgL0AzLy50ZXN0KGFzc2V0Lm5hbWUpOiB7XG4gICAgICByZXNvbHV0aW9uID0gJ2RyYXdhYmxlLXh4aGRwaSc7XG4gICAgICBzY2FsZSA9ICczeCc7XG4gICAgICBicmVhaztcbiAgICB9XG4gICAgZGVmYXVsdDoge1xuICAgICAgcmVzb2x1dGlvbiA9ICdkcmF3YWJsZS14eHhoZHBpJztcbiAgICAgIHNjYWxlID0gJzR4JztcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgfVxuICByZXR1cm4gZ2V0QXNTY2FsZSA/IHNjYWxlIDogcmVzb2x1dGlvbjtcbn1cblxuLyoqXG4gKiBFdmVyeSBpY29uIGhhcyBhIHNldCBvZiBmbGF2b3JzIGFuZCBlYWNoIGZsYXZvciBjYW4gaGF2ZSBvbmUgb3IgbW9yZSB0eXBlcy5cbiAqIFRoaXMgZnVuY3Rpb24gcmV0dXJucyB0aG9zZSBmbGF2b3JzIHRoYXQgY29udGFpbiBhIGNlcnRhaW4gdHlwZVxuICogQHBhcmFtIGljb24gSWNvbiB3aG9zZSBmbGF2b3JzIGFyZSB0byBiZSByZXR1cm5lZFxuICogQHBhcmFtIHR5cGUgVGhlIHR5cGUgdG8gd2hpY2ggdG8gZmlsdGVyIHRoZSBpY29uJ3MgZmxhdm9ycyBieVxuICogQHJldHVybnMgYSBsaXN0IG9mIGZsYXZvcnMgdGhhdCBjb250YWluIGFzc2V0cyBvZiBcInR5cGVcIlxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0SWNvbkZsYXZvcnNCeVR5cGUoaWNvbjogSWNvbiwgdHlwZTogRmxhdm9yVHlwZSk6IEFzc2V0W10ge1xuICByZXR1cm4gQXJyYXkuZnJvbShpY29uLmZsYXZvcnMudmFsdWVzKCkpXG4gICAgLmZpbHRlcigoZmxhdm9yOiBGbGF2b3IpID0+IHtcbiAgICAgIHJldHVybiBmbGF2b3IudHlwZXMuaGFzKHR5cGUpO1xuICAgIH0pXG4gICAgLm1hcCgoZmxhdm9yOiBGbGF2b3IpID0+IGZsYXZvci50eXBlcy5nZXQodHlwZSkgYXMgQXNzZXQpOyAvLyB0eXBlIGNhc3RpbmcgaGVyZSBhcyB3ZSBoYXZlIGNoZWNrZWQgZm9yIHdoZXRoZXIgdGhlIGZsYXZvciBoYXMgdGhlIHR5cGUgYWJvdmVcbn1cblxuLyoqXG4gKiBTdHJpcHMgcmVzb2x1dGlvbiBmcm9tIGljb24gbmFtZVxuICogQHBhcmFtIGljb25OYW1lIG5hbWUgdG8gc3RyaXAgcmVzb2x1dGlvbiBmcm9tXG4gKiBAcmV0dXJucyBhIHN0cmluZyB3aXRoIHRoZSByZXNvbHV0aW9uIHN0cmlwcGVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW1vdmVSZXNvbHV0aW9uRnJvbU5hbWUoaWNvbk5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gIHJldHVybiBpY29uTmFtZS5pbmNsdWRlcygnQCcpID8gaWNvbk5hbWUucmVwbGFjZSgvKC0pP0BbMC05XSguWzAtOV0pPy8sICcnKSA6IGljb25OYW1lO1xufVxuXG4vKipcbiAqIENvbXBhcmVzIHR3byBzdHJpbmdzXG4gKiBAcGFyYW0gbmFtZU9uZSBzdHJpbmcgdG8gY29tcGFyZVxuICogQHBhcmFtIG5hbWVUd28gc3RyaW5nIHRvIGNvbXBhcmVcbiAqIEByZXR1cm5zIGEgbnVtYmVyIGZyb20gd2hpY2ggc3RyaW5ncyB3aWxsIGJlIHNvcnRlZCBhZ2FpbnN0XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjb21wYXJlU3RyaW5ncyhuYW1lT25lOiBzdHJpbmcsIG5hbWVUd286IHN0cmluZyk6IG51bWJlciB7XG4gIGlmIChuYW1lT25lIDwgbmFtZVR3bykge1xuICAgIHJldHVybiAtMTtcbiAgfVxuICBpZiAobmFtZU9uZSA+IG5hbWVUd28pIHtcbiAgICByZXR1cm4gMTtcbiAgfVxuICByZXR1cm4gMDtcbn0iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUE7Ozs7Ozs7R0FPRztBQUNILFNBQWdCLDBCQUEwQixDQUN4QyxLQUFZLEVBQ1osVUFBb0I7SUFFcEIsSUFBSSxVQUFVLENBQUM7SUFDZixJQUFJLEtBQUssQ0FBQztJQUNWLFFBQVEsSUFBSSxFQUFFO1FBQ1osS0FBSyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBQzVCLFVBQVUsR0FBRyxlQUFlLENBQUM7WUFDN0IsS0FBSyxHQUFHLE1BQU0sQ0FBQztZQUNmLE1BQU07U0FDUDtRQUNELEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztZQUMxQixVQUFVLEdBQUcsZUFBZSxDQUFDO1lBQzdCLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDYixNQUFNO1NBQ1A7UUFDRCxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDMUIsVUFBVSxHQUFHLGdCQUFnQixDQUFDO1lBQzlCLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDYixNQUFNO1NBQ1A7UUFDRCxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDMUIsVUFBVSxHQUFHLGlCQUFpQixDQUFDO1lBQy9CLEtBQUssR0FBRyxJQUFJLENBQUM7WUFDYixNQUFNO1NBQ1A7UUFDRCxPQUFPLENBQUMsQ0FBQztZQUNQLFVBQVUsR0FBRyxrQkFBa0IsQ0FBQztZQUNoQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1lBQ2IsTUFBTTtTQUNQO0tBQ0Y7SUFDRCxPQUFPLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7QUFDekMsQ0FBQztBQWxDRCxnRUFrQ0M7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixvQkFBb0IsQ0FBQyxJQUFVLEVBQUUsSUFBZ0I7SUFDL0QsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7U0FDckMsTUFBTSxDQUFDLENBQUMsTUFBYyxFQUFFLEVBQUU7UUFDekIsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDLENBQUM7U0FDRCxHQUFHLENBQUMsQ0FBQyxNQUFjLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBVSxDQUFDLENBQUMsQ0FBQyxpRkFBaUY7QUFDaEosQ0FBQztBQU5ELG9EQU1DO0FBRUQ7Ozs7R0FJRztBQUNILFNBQWdCLHdCQUF3QixDQUFDLFFBQWdCO0lBQ3ZELE9BQU8sUUFBUSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDO0FBQ3pGLENBQUM7QUFGRCw0REFFQztBQUVEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsY0FBYyxDQUFDLE9BQWUsRUFBRSxPQUFlO0lBQzdELElBQUksT0FBTyxHQUFHLE9BQU8sRUFBRTtRQUNyQixPQUFPLENBQUMsQ0FBQyxDQUFDO0tBQ1g7SUFDRCxJQUFJLE9BQU8sR0FBRyxPQUFPLEVBQUU7UUFDckIsT0FBTyxDQUFDLENBQUM7S0FDVjtJQUNELE9BQU8sQ0FBQyxDQUFDO0FBQ1gsQ0FBQztBQVJELHdDQVFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXNzZXQsIEZsYXZvciwgRmxhdm9yVHlwZSwgSWNvbiB9IGZyb20gJ0BpY29uLW1hZ2ljL2ljb24tbW9kZWxzJztcblxuLyoqXG4gKiBUaGUgcmVzb2x1dGlvbiBvZiBhbiBhc3NldCBpcyB3aXRoaW4gdGhlIGFzc2V0cyBuYW1lIGFzIFwiQHJlc29sdXRpb25cIlxuICogVGhpcyBmdW5jdGlvbiBtYXRjaGVzIHRoZSBuYW1lIGFnYWluc3QgZGlmZmVyZW50IHJlc29sdXRpb25zIGFuZCByZXR1cm5zIHRoZVxuICogYXBwcm9wcmlhdGUgc2NhbGUgb3IgcmVzb2x1dGlvblxuICogQHBhcmFtIGFzc2V0IHRoZSBhc3NldCB3aG9zZSByZXNvbHV0aW9uIG5lZWRzIHRvIGJlIGRldGVybWluZWRcbiAqIEBwYXJhbSBnZXRBc1NjYWxlIEJvb2xlYW4gZm9yIHJldHVybmluZyB0aGUgc2NhbGUgaW5zdGVhZCBvZiB0aGUgcmVzb2x1dGlvblxuICogQHJldHVybnMgZWl0aGVyIHRoZSByZXNvbHV0aW9uIG9yIHNjYWxlIGRlcGVuZGluZyBvbiB0aGUgYm9vbGVhbiBnZXRBc1NjYWxlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRBc3NldFJlc29sdXRpb25Gcm9tTmFtZShcbiAgYXNzZXQ6IEFzc2V0LFxuICBnZXRBc1NjYWxlPzogQm9vbGVhblxuKTogc3RyaW5nIHtcbiAgbGV0IHJlc29sdXRpb247XG4gIGxldCBzY2FsZTtcbiAgc3dpdGNoICh0cnVlKSB7XG4gICAgY2FzZSAvQDEuNS8udGVzdChhc3NldC5uYW1lKToge1xuICAgICAgcmVzb2x1dGlvbiA9ICdkcmF3YWJsZS1oZHBpJztcbiAgICAgIHNjYWxlID0gJzEuNXgnO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgL0AxLy50ZXN0KGFzc2V0Lm5hbWUpOiB7XG4gICAgICByZXNvbHV0aW9uID0gJ2RyYXdhYmxlLW1kcGknO1xuICAgICAgc2NhbGUgPSAnMXgnO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgL0AyLy50ZXN0KGFzc2V0Lm5hbWUpOiB7XG4gICAgICByZXNvbHV0aW9uID0gJ2RyYXdhYmxlLXhoZHBpJztcbiAgICAgIHNjYWxlID0gJzJ4JztcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgICBjYXNlIC9AMy8udGVzdChhc3NldC5uYW1lKToge1xuICAgICAgcmVzb2x1dGlvbiA9ICdkcmF3YWJsZS14eGhkcGknO1xuICAgICAgc2NhbGUgPSAnM3gnO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGRlZmF1bHQ6IHtcbiAgICAgIHJlc29sdXRpb24gPSAnZHJhd2FibGUteHh4aGRwaSc7XG4gICAgICBzY2FsZSA9ICc0eCc7XG4gICAgICBicmVhaztcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGdldEFzU2NhbGUgPyBzY2FsZSA6IHJlc29sdXRpb247XG59XG5cbi8qKlxuICogRXZlcnkgaWNvbiBoYXMgYSBzZXQgb2YgZmxhdm9ycyBhbmQgZWFjaCBmbGF2b3IgY2FuIGhhdmUgb25lIG9yIG1vcmUgdHlwZXMuXG4gKiBUaGlzIGZ1bmN0aW9uIHJldHVybnMgdGhvc2UgZmxhdm9ycyB0aGF0IGNvbnRhaW4gYSBjZXJ0YWluIHR5cGVcbiAqIEBwYXJhbSBpY29uIEljb24gd2hvc2UgZmxhdm9ycyBhcmUgdG8gYmUgcmV0dXJuZWRcbiAqIEBwYXJhbSB0eXBlIFRoZSB0eXBlIHRvIHdoaWNoIHRvIGZpbHRlciB0aGUgaWNvbidzIGZsYXZvcnMgYnlcbiAqIEByZXR1cm5zIGEgbGlzdCBvZiBmbGF2b3JzIHRoYXQgY29udGFpbiBhc3NldHMgb2YgXCJ0eXBlXCJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEljb25GbGF2b3JzQnlUeXBlKGljb246IEljb24sIHR5cGU6IEZsYXZvclR5cGUpOiBBc3NldFtdIHtcbiAgcmV0dXJuIEFycmF5LmZyb20oaWNvbi5mbGF2b3JzLnZhbHVlcygpKVxuICAgIC5maWx0ZXIoKGZsYXZvcjogRmxhdm9yKSA9PiB7XG4gICAgICByZXR1cm4gZmxhdm9yLnR5cGVzLmhhcyh0eXBlKTtcbiAgICB9KVxuICAgIC5tYXAoKGZsYXZvcjogRmxhdm9yKSA9PiBmbGF2b3IudHlwZXMuZ2V0KHR5cGUpIGFzIEFzc2V0KTsgLy8gdHlwZSBjYXN0aW5nIGhlcmUgYXMgd2UgaGF2ZSBjaGVja2VkIGZvciB3aGV0aGVyIHRoZSBmbGF2b3IgaGFzIHRoZSB0eXBlIGFib3ZlXG59XG5cbi8qKlxuICogU3RyaXBzIHJlc29sdXRpb24gZnJvbSBpY29uIG5hbWVcbiAqIEBwYXJhbSBpY29uTmFtZSBuYW1lIHRvIHN0cmlwIHJlc29sdXRpb24gZnJvbVxuICogQHJldHVybnMgYSBzdHJpbmcgd2l0aCB0aGUgcmVzb2x1dGlvbiBzdHJpcHBlZFxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVtb3ZlUmVzb2x1dGlvbkZyb21OYW1lKGljb25OYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICByZXR1cm4gaWNvbk5hbWUuaW5jbHVkZXMoJ0AnKSA/IGljb25OYW1lLnJlcGxhY2UoLygtKT9AWzAtOV0oLlswLTldKT8vLCAnJykgOiBpY29uTmFtZTtcbn1cblxuLyoqXG4gKiBDb21wYXJlcyB0d28gc3RyaW5nc1xuICogQHBhcmFtIG5hbWVPbmUgc3RyaW5nIHRvIGNvbXBhcmVcbiAqIEBwYXJhbSBuYW1lVHdvIHN0cmluZyB0byBjb21wYXJlXG4gKiBAcmV0dXJucyBhIG51bWJlciBmcm9tIHdoaWNoIHN0cmluZ3Mgd2lsbCBiZSBzb3J0ZWQgYWdhaW5zdFxuICovXG5leHBvcnQgZnVuY3Rpb24gY29tcGFyZVN0cmluZ3MobmFtZU9uZTogc3RyaW5nLCBuYW1lVHdvOiBzdHJpbmcpOiBudW1iZXIge1xuICBpZiAobmFtZU9uZSA8IG5hbWVUd28pIHtcbiAgICByZXR1cm4gLTE7XG4gIH1cbiAgaWYgKG5hbWVPbmUgPiBuYW1lVHdvKSB7XG4gICAgcmV0dXJuIDE7XG4gIH1cbiAgcmV0dXJuIDA7XG59Il19

@@ -5,2 +5,3 @@ "use strict";

const assert = require("assert");
const recast = require("ember-template-recast");
const fs = require("fs-extra");

@@ -308,2 +309,43 @@ const path = require("path");

});
it('...attributes comes before certain attributes in hbs files', async () => {
try {
const files = fs.readdirSync(`${output}/its-ui`);
assert.ok(files.includes('animal-small.hbs'));
assert.ok(files.includes('animal-large.hbs'));
const content = fs.readFileSync(`${output}/animal-small.hbs`, 'utf8');
const ast = recast.parse(content);
if (ast.body[0].type === 'ElementNode') {
const attrs = ast.body[0].attributes;
const firstAttr = attrs[0];
assert.ok(firstAttr.name === '...attributes');
}
}
catch (err) {
assert.ok(false, err);
}
});
it('it trims "-mixed" from end of hbs file name', async () => {
const iconSetWordmark = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/wordmark')));
await src_1.distributeByType(iconSetWordmark, `${output}/wordmark`, 'svg', false, true, ['mixed'], false);
try {
const files = fs.readdirSync(`${output}/wordmark`);
assert.ok(files.includes('wordmark-large.hbs'));
assert.ok(files.includes('wordmark-medium.hbs'));
}
catch (err) {
assert.ok(false, err);
}
});
it('it does not trim "-mixed" from end of hbs file name', async () => {
const iconSetWordmark = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/wordmark')));
await src_1.distributeByType(iconSetWordmark, `${output}/wordmark/untrimmed`, 'svg', false, true, ['mixed'], true);
try {
const files = fs.readdirSync(`${output}/wordmark/untrimmed`);
assert.ok(files.includes('wordmark-large-mixed.hbs'));
assert.ok(files.includes('wordmark-medium-mixed.hbs'));
}
catch (err) {
assert.ok(false, err);
}
});
it('sprites are always arranged alphabetically', async () => {

@@ -330,2 +372,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;oBAEF,MAAM,kBAAkB,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC;oBACxF,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,qDAAqD,CAAC,CAAC;oBACpG,MAAM,CAAC,EAAE,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,KAA4B,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,KAAK,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,QAAQ,CAAC,CAAC,CAAC;oBAEnI,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,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC7E,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;QACtD,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAC7C,MAAM,OAAO,GAAG,YAAY,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAEhE,MAAM,sBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QACtD,IAAI;YACF,MAAM,QAAQ,GAAG,GAAG,MAAM,0EAA0E,CAAC;YACrG,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAC3B,MAAM,CAAC,EAAE,CAAC,GAAG,QAAQ,oBAAoB,CAAC,CAAC;gBAC3C,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;gBACvC,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,EACnC,6BAA6B,CAC9B,CAAC;gBAEF,MAAM,kBAAkB,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC;gBACxF,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,kBAAkB,CAAC,EAAE,qDAAqD,CAAC,CAAC;gBACpG,MAAM,SAAS,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC,KAA4B,EAAE,EAAE,CACzE,KAAK,CAAC,QAAQ,KAAK,2DAA2D,CAC/E,CAAC;gBAEF,MAAM,CAAC,EAAE,CAAC,OAAO,SAAS,KAAK,QAAQ,EAAE,6BAA6B,CAAC,CAAC;gBACxE,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,uBAAuB,CAAC,CAAC;gBAErE,MAAM,CAAC,EAAE,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,KAA4B,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,KAAK,mDAAmD,CAAC,CAAC,CAAC;gBAE7I,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,OAAO,CAAC,mDAAmD,CAAC,GAAG,CAAC,CAAC,EACvE,+DAA+D,CAChE,CAAC;gBACF,MAAM,CAAC,EAAE,CACP,KAAK,CAAC,OAAO,CAAC,2DAA2D,CAAC,GAAG,CAAC,CAAC,EAC/E,uEAAuE,CACxE,CAAC;aACH;iBAAM;gBACL,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,qBAAqB,QAAQ,EAAE,CAAC,CAAC;aACnD;SACF;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvB;IACH,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,mBAAmB,EAAE,KAAK,IAAI,EAAE;QACjC,MAAM,aAAa,GAAG,YAAY,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC;QACvG,MAAM,sBAAgB,CAAC,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QAClE,IAAI;YACF,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACrC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC;YAC9C,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC;SAC/C;QAAC,OAAO,GAAG,EAAE;YACZ,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SACvB;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,aAAa,GAAG,YAAY,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC;QACvG,MAAM,sBAAgB,CAAC,aAAa,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACjE,IAAI;YACF,MAAM,KAAK,GAAG,EAAE,CAAC,WAAW,CAAC,GAAG,MAAM,SAAS,CAAC,CAAC;YACjD,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC;YAC9C,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC;SAC/C;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\n          const contentsJsonImages = fs.readJsonSync(path.join(iconPath, 'Contents.json')).images;\n          assert.ok(Array.isArray(contentsJsonImages), 'Contents.json is filled with an array called images');\n          assert.ok(contentsJsonImages.find((entry: { filename: string; }) => entry.filename === `${icon.category}_${icon.iconName}@2.png`));\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('Moves all dark .png files to the output directory as expected', async () => {\n    const input = path.resolve(FIXTURES, 'input/company');\n    const output = path.resolve(FIXTURES, 'out');\n    const iconSet = configReader.getIconConfigSet(new Array(input));\n\n    await distributeByType(iconSet, output, 'png', false);\n    try {\n      const iconPath = `${output}/entity-backgrounds/entity-backgrounds_company_default_2048x512.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\n        const contentsJsonImages = fs.readJsonSync(path.join(iconPath, 'Contents.json')).images;\n        assert.ok(Array.isArray(contentsJsonImages), 'Contents.json is filled with an array called images');\n        const darkImage = contentsJsonImages.find((entry: { filename: string; }) =>\n          entry.filename === `entity-backgrounds_company_default_on_dark_2048x512@2.png`\n        );\n\n        assert.ok(typeof darkImage === 'object', 'Dark icons in contents.json');\n        assert.ok(darkImage.appearances.length > 0, 'Has appearances array');\n\n        assert.ok(contentsJsonImages.find((entry: { filename: string; }) => entry.filename === `entity-backgrounds_company_default_2048x512@2.png`));\n\n        assert.ok(\n          files.indexOf(`entity-backgrounds_company_default_2048x512@2.png`) > -1,\n          `entity-backgrounds_company_default_2048x512@2.png was created`\n        );\n        assert.ok(\n          files.indexOf(`entity-backgrounds_company_default_on_dark_2048x512@2.png`) > -1,\n          `entity-backgrounds_company_default_on_dark_2048x512@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  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', false, true);\n    try {\n      const files = fs.readdirSync(output);\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('creates hbs files and distributes by category', 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}/its-ui`);\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"]}
//# 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 recast  from 'ember-template-recast';\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\n          const contentsJsonImages = fs.readJsonSync(path.join(iconPath, 'Contents.json')).images;\n          assert.ok(Array.isArray(contentsJsonImages), 'Contents.json is filled with an array called images');\n          assert.ok(contentsJsonImages.find((entry: { filename: string; }) => entry.filename === `${icon.category}_${icon.iconName}@2.png`));\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('Moves all dark .png files to the output directory as expected', async () => {\n    const input = path.resolve(FIXTURES, 'input/company');\n    const output = path.resolve(FIXTURES, 'out');\n    const iconSet = configReader.getIconConfigSet(new Array(input));\n\n    await distributeByType(iconSet, output, 'png', false);\n    try {\n      const iconPath = `${output}/entity-backgrounds/entity-backgrounds_company_default_2048x512.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\n        const contentsJsonImages = fs.readJsonSync(path.join(iconPath, 'Contents.json')).images;\n        assert.ok(Array.isArray(contentsJsonImages), 'Contents.json is filled with an array called images');\n        const darkImage = contentsJsonImages.find((entry: { filename: string; }) =>\n          entry.filename === `entity-backgrounds_company_default_on_dark_2048x512@2.png`\n        );\n\n        assert.ok(typeof darkImage === 'object', 'Dark icons in contents.json');\n        assert.ok(darkImage.appearances.length > 0, 'Has appearances array');\n\n        assert.ok(contentsJsonImages.find((entry: { filename: string; }) => entry.filename === `entity-backgrounds_company_default_2048x512@2.png`));\n\n        assert.ok(\n          files.indexOf(`entity-backgrounds_company_default_2048x512@2.png`) > -1,\n          `entity-backgrounds_company_default_2048x512@2.png was created`\n        );\n        assert.ok(\n          files.indexOf(`entity-backgrounds_company_default_on_dark_2048x512@2.png`) > -1,\n          `entity-backgrounds_company_default_on_dark_2048x512@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  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', false, true);\n    try {\n      const files = fs.readdirSync(output);\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('creates hbs files and distributes by category', 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}/its-ui`);\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('...attributes comes before certain attributes in hbs files', async () => {\n    try {\n      const files = fs.readdirSync(`${output}/its-ui`);\n      assert.ok(files.includes('animal-small.hbs'));\n      assert.ok(files.includes('animal-large.hbs'));\n\n      const content = fs.readFileSync(`${output}/animal-small.hbs`, 'utf8');\n      const ast = recast.parse(content);\n\n      if (ast.body[0].type === 'ElementNode') {\n        const attrs = ast.body[0].attributes;\n        const firstAttr = attrs[0];\n        assert.ok(firstAttr.name === '...attributes');\n      }\n\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n\n  it('it trims \"-mixed\" from end of hbs file name', async () => {\n    const iconSetWordmark = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/wordmark')));\n    await distributeByType(iconSetWordmark, `${output}/wordmark`, 'svg', false, true, ['mixed'], false);\n    try {\n      const files = fs.readdirSync(`${output}/wordmark`);\n      assert.ok(files.includes('wordmark-large.hbs'));\n      assert.ok(files.includes('wordmark-medium.hbs'));\n    } catch (err) {\n      assert.ok(false, err);\n    }\n  });\n\n  it('it does not trim \"-mixed\" from end of hbs file name', async () => {\n    const iconSetWordmark = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/wordmark')));\n    await distributeByType(iconSetWordmark, `${output}/wordmark/untrimmed`, 'svg', false, true, ['mixed'], true);\n    try {\n      const files = fs.readdirSync(`${output}/wordmark/untrimmed`);\n      assert.ok(files.includes('wordmark-large-mixed.hbs'));\n      assert.ok(files.includes('wordmark-medium-mixed.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.11-beta.0",
"version": "2.3.0-beta.0",
"description": "Icon magic distribute package.",

@@ -21,8 +21,9 @@ "main": "dist/src/index.js",

"dependencies": {
"@icon-magic/config-reader": "^2.2.9-beta.0",
"@icon-magic/icon-models": "^2.2.9-beta.0",
"@icon-magic/logger": "^2.2.9-beta.0",
"@icon-magic/config-reader": "^2.3.0-beta.0",
"@icon-magic/icon-models": "^2.3.0-beta.0",
"@icon-magic/logger": "^2.3.0-beta.0",
"@types/xmldom": "^0.1.29",
"ember-template-recast": "^5.0.3",
"xmldom": "^0.5.0"
}
}
import { Asset } from '@icon-magic/icon-models';
import { transform } from 'ember-template-recast';
import * as fs from 'fs-extra';

@@ -7,3 +8,2 @@ import * as path from 'path';

const serializeToString = new XMLSerializer().serializeToString;

@@ -34,2 +34,20 @@

el.removeAttribute('id');
const template = serializeToString(xml);
const { code } = transform({
template,
plugin(env) {
const { builders: b } = env.syntax;
return {
ElementNode(node) {
if (node.tag === 'svg') {
// add splattributes to the hbs file
node.attributes.unshift(b.attr('...attributes', b.text('')));
}
},
};
}
});
// Remove the "-mixed" suffix from the name. File will have same name as light version.

@@ -40,11 +58,8 @@ if (!doNotRemoveSuffix && asset.colorScheme === 'mixed') {

// add splattributes to the hbs file
xml.documentElement.setAttribute('...attributes', '');
await fs.mkdirp(outputPath);
// xmldom and other dom substitutions (like jsdom) add ...attributes="" and
// the string replace below is an ugly hack to remove the empty string
fs.writeFileSync(path.join(outputPath, `${iconName}.hbs`), serializeToString(xml).replace(/...attributes=\"\"/g, '...attributes'));
fs.writeFileSync(path.join(outputPath, `${iconName}.hbs`), code);
}
}
import * as configReader from '@icon-magic/config-reader';
import * as assert from 'assert';
import * as recast from 'ember-template-recast';
import * as fs from 'fs-extra';

@@ -340,2 +341,23 @@ import * as path from 'path';

it('...attributes comes before certain attributes in hbs files', async () => {
try {
const files = fs.readdirSync(`${output}/its-ui`);
assert.ok(files.includes('animal-small.hbs'));
assert.ok(files.includes('animal-large.hbs'));
const content = fs.readFileSync(`${output}/animal-small.hbs`, 'utf8');
const ast = recast.parse(content);
if (ast.body[0].type === 'ElementNode') {
const attrs = ast.body[0].attributes;
const firstAttr = attrs[0];
assert.ok(firstAttr.name === '...attributes');
}
} catch (err) {
assert.ok(false, err);
}
});
it('it trims "-mixed" from end of hbs file name', async () => {

@@ -342,0 +364,0 @@ const iconSetWordmark = configReader.getIconConfigSet(new Array(path.resolve(FIXTURES, 'input/wordmark')));

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc