@icon-magic/icon-models
Advanced tools
Comparing version 2.5.0-beta.0 to 2.6.0-beta.0
@@ -75,4 +75,4 @@ "use strict"; | ||
} | ||
if (config.generateSourceHash) { | ||
this.generateSourceHash = config.generateSourceHash; | ||
if (this.generateSourceHash) { | ||
config.generateSourceHash = this.generateSourceHash; | ||
} | ||
@@ -100,2 +100,2 @@ if (this.imageset) { | ||
exports.Asset = Asset; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQTRDO0FBQzVDLDZCQUE2QjtBQUc3Qix5Q0FBZ0Q7QUFFaEQ7OztHQUdHO0FBQ0gsTUFBYSxLQUFLO0lBV2hCOzs7OztPQUtHO0lBQ0gsWUFBWSxRQUFnQixFQUFFLE1BQW1CO1FBQy9DLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxlQUFNLENBQUMsOEJBQThCLENBQUMsQ0FBQztRQUV6RCw4Q0FBOEM7UUFDOUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDOUIsTUFBTSxJQUFJLEtBQUssQ0FDYix5REFBeUQsUUFBUSxFQUFFLENBQ3BFLENBQUM7U0FDSDtRQUNELElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBRXpCLHlFQUF5RTtRQUN6RSxrQkFBa0I7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFFckUsZUFBZTtRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUV4QixzREFBc0Q7UUFDdEQsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFO1lBQ25CLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQztTQUNqQztRQUNELElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRTtZQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUM7U0FDakM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxXQUFXLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO1NBQ3ZDO1FBRUQsNkRBQTZEO1FBQzdELElBQUksTUFBTSxDQUFDLGVBQWUsRUFBRTtZQUMxQixJQUFJLENBQUMsZUFBZSxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUM7U0FDL0M7UUFDRCxJQUFJLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRTtZQUM3QixJQUFJLENBQUMsa0JBQWtCLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDO1NBQ3JEO1FBQ0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsU0FBUyxJQUFJLENBQUMsSUFBSSxlQUFlLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRDs7T0FFRztJQUNILE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsT0FBTyxDQUFDLElBQVk7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELFdBQVcsQ0FBQyxRQUFnQjtRQUMxQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUMzQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxjQUFjO1FBQ1osTUFBTSxNQUFNLEdBQWdCO1lBQzFCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtTQUNoQixDQUFDO1FBQ0YsSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ3hCLE1BQU0sQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztTQUMvQztRQUNELElBQUksTUFBTSxDQUFDLGtCQUFrQixFQUFFO1lBQzdCLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUM7U0FDckQ7UUFDRCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDakIsTUFBTSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO1NBQ2pDO1FBQ0QsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLE1BQU0sQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztTQUN2QztRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxXQUFXO1FBQ2YseURBQXlEO1FBQ3pELElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUNmLFdBQVcsSUFBSSxDQUFDLE9BQU8sRUFBRSxnQ0FBZ0MsQ0FDMUQsQ0FBQztZQUNGLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSx1QkFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZEO1FBQ0QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7Q0FDRjtBQTlHRCxzQkE4R0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2dnZXIgfSBmcm9tICdAaWNvbi1tYWdpYy9sb2dnZXInO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHsgQXNzZXRDb25maWcsIENvbnRlbnQgfSBmcm9tICcuL2ludGVyZmFjZSc7XG5pbXBvcnQgeyBnZXRGaWxlQ29udGVudHMgfSBmcm9tICcuL3V0aWxzL2ZpbGVzJztcblxuLyoqXG4gKiBUaGlzIGNsYXNzIGFic3RyYWN0cyB0aGUgc21hbGxlc3Qgc2V0IG9mIGluZm9ybWF0aW9uIHBlcnRhaW5zIHRvIGFuIGFzc2V0XG4gKiBmaWxlIGluIG1lbW9yeVxuICovXG5leHBvcnQgY2xhc3MgQXNzZXQge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNvbnRlbnRzOiBDb250ZW50IHwgdW5kZWZpbmVkO1xuICBpY29uUGF0aDogc3RyaW5nO1xuICBidWlsZFNvdXJjZUhhc2g/OiBzdHJpbmc7XG4gIGdlbmVyYXRlU291cmNlSGFzaD86IHN0cmluZztcbiAgaW1hZ2VzZXQ/OiBzdHJpbmc7XG4gIGNvbG9yU2NoZW1lPzogc3RyaW5nO1xuICBwcm90ZWN0ZWQgcGF0aDogc3RyaW5nO1xuICBwcml2YXRlIExPR0dFUjogTG9nZ2VyO1xuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IGFzc2V0XG4gICAqIEBwYXJhbSBpY29uUGF0aCBBYnNvbHV0ZSBwYXRoIG9mIHRoZSBpY29uIGZvbGRlciB3aGljaCB0aGlzIGFzc2V0IGJlbG9uZ3NcbiAgICogICAgICAgICAgICAgICAgIHRvIEFsbCBwYXRocyBpbiB0aGUgYXNzZXQgYXJlIHJlbGF0aXZlIHRvIHRoaXMgaWNvblBhdGhcbiAgICogQHBhcmFtIGNvbmZpZyBhIGNvbmZpZyBvYmplY3QgdG8gc2V0IHRoZSBpbml0aWFsIHByb3BlcnRpZXMgb2YgdGhlIGFzc2V0XG4gICAqL1xuICBjb25zdHJ1Y3RvcihpY29uUGF0aDogc3RyaW5nLCBjb25maWc6IEFzc2V0Q29uZmlnKSB7XG4gICAgdGhpcy5MT0dHRVIgPSBuZXcgTG9nZ2VyKCdpY29uLW1hZ2ljOmljb24tbW9kZWxzOmFzc2V0Jyk7XG5cbiAgICAvLyBpZiBpY29uUGF0aCBpcyBub3QgYWJzb2x1dGUsIHRocm93IGFuIGVycm9yXG4gICAgaWYgKCFwYXRoLmlzQWJzb2x1dGUoaWNvblBhdGgpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBBc3NldENyZWF0aW9uRXJyb3I6IGljb25QYXRoIG11c3QgYWx3YXlzIGJlIGFic29sdXRlOiAke2ljb25QYXRofWBcbiAgICAgICk7XG4gICAgfVxuICAgIHRoaXMuaWNvblBhdGggPSBpY29uUGF0aDtcblxuICAgIC8vIGlmIHRoZSBhc3NldCBkb2VzIG5vdCBoYXZlIGEgbmFtZSwgdGhlbiBzZXQgdGhlIG5hbWUgdG8gYmUgdGhlIG5hbWUgb2ZcbiAgICAvLyB0aGUgZmlsZSBpdHNlbGZcbiAgICB0aGlzLm5hbWUgPSBjb25maWcubmFtZSA/IGNvbmZpZy5uYW1lIDogcGF0aC5wYXJzZShjb25maWcucGF0aCkubmFtZTtcblxuICAgIC8vIHNldCB0aGUgcGF0aFxuICAgIHRoaXMucGF0aCA9IGNvbmZpZy5wYXRoO1xuXG4gICAgLy8gc2V0IHRoZSBjb250ZW50cyBvbmx5IGlmIGl0IGlzIHBhc3NlZCBpbiB0aGUgY29uZmlnXG4gICAgaWYgKGNvbmZpZy5jb250ZW50cykge1xuICAgICAgdGhpcy5jb250ZW50cyA9IGNvbmZpZy5jb250ZW50cztcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5pbWFnZXNldCkge1xuICAgICAgdGhpcy5pbWFnZXNldCA9IGNvbmZpZy5pbWFnZXNldDtcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5jb2xvclNjaGVtZSkge1xuICAgICAgdGhpcy5jb2xvclNjaGVtZSA9IGNvbmZpZy5jb2xvclNjaGVtZTtcbiAgICB9XG5cbiAgICAvLyBpZiBhIHNvdXJjZSBoYXMgaXMgcGFzc2VkIGluLCBzZXQgaXQgb24gdGhlIGFzc2V0J3MgY29uZmlnXG4gICAgaWYgKGNvbmZpZy5idWlsZFNvdXJjZUhhc2gpIHtcbiAgICAgIHRoaXMuYnVpbGRTb3VyY2VIYXNoID0gY29uZmlnLmJ1aWxkU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5nZW5lcmF0ZVNvdXJjZUhhc2gpIHtcbiAgICAgIHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoID0gY29uZmlnLmdlbmVyYXRlU291cmNlSGFzaDtcbiAgICB9XG4gICAgdGhpcy5MT0dHRVIuZGVidWcoYEFzc2V0ICR7dGhpcy5uYW1lfSBjcmVhdGVkIGluICR7dGhpcy5pY29uUGF0aH1gKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAcmV0dXJucyBUaGUgcGF0aCBvIGFuIGFzc2V0IHdoaWNoIGlzIGFsd2F5cyByZWxhdGl2ZSB0byB0aGUgaWNvbnBhdGhcbiAgICovXG4gIGdldFBhdGgoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gcGF0aC5yZXNvbHZlKHRoaXMuaWNvblBhdGgsIHRoaXMucGF0aCk7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgcGF0aCBwcm9wZXJ0eSB0byBhIHBhdGggcGFzc2VkIGluXG4gICAqL1xuICBzZXRQYXRoKHBhdGg6IHN0cmluZykge1xuICAgIHRoaXMucGF0aCA9IHBhdGg7XG4gIH1cblxuICBzZXRJbWFnZVNldChpbWFnZXNldDogc3RyaW5nKSB7XG4gICAgdGhpcy5pbWFnZXNldCA9IGltYWdlc2V0O1xuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHRoZSBBc3NldCBkYXRhIHRoYXQgbmVlZHMgdG8gYmUgc3RvcmVkIGluIHRoZSBjb25maWcgZmlsZVxuICAgKi9cbiAgZ2V0QXNzZXRDb25maWcoKTogQXNzZXRDb25maWcge1xuICAgIGNvbnN0IGNvbmZpZzogQXNzZXRDb25maWcgPSB7XG4gICAgICBuYW1lOiB0aGlzLm5hbWUsXG4gICAgICBwYXRoOiB0aGlzLnBhdGgsXG4gICAgfTtcbiAgICBpZiAodGhpcy5idWlsZFNvdXJjZUhhc2gpIHtcbiAgICAgIGNvbmZpZy5idWlsZFNvdXJjZUhhc2ggPSB0aGlzLmJ1aWxkU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5nZW5lcmF0ZVNvdXJjZUhhc2gpIHtcbiAgICAgIHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoID0gY29uZmlnLmdlbmVyYXRlU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKHRoaXMuaW1hZ2VzZXQpIHtcbiAgICAgIGNvbmZpZy5pbWFnZXNldCA9IHRoaXMuaW1hZ2VzZXQ7XG4gICAgfVxuICAgIGlmICh0aGlzLmNvbG9yU2NoZW1lKSB7XG4gICAgICBjb25maWcuY29sb3JTY2hlbWUgPSB0aGlzLmNvbG9yU2NoZW1lO1xuICAgIH1cbiAgICByZXR1cm4gY29uZmlnO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHVybnMgdGhlIGNvbnRlbnQgc3RvcmVkIGluIHRoZSBwYXRoIG9mIHRoaXMgYXNzZXRcbiAgICovXG4gIGFzeW5jIGdldENvbnRlbnRzKCk6IFByb21pc2U8Q29udGVudD4ge1xuICAgIC8vIGlmIGl0IGlzbid0IGFscmVhZHkgcmV0cmlldmVkLCByZWFkIHRoZSBmaWxlIGZyb20gZGlza1xuICAgIGlmICghdGhpcy5jb250ZW50cykge1xuICAgICAgdGhpcy5MT0dHRVIuZGVidWcoXG4gICAgICAgIGBSZWFkaW5nICR7dGhpcy5nZXRQYXRoKCl9J3MgZmlsZSBjb250ZW50cyBmcm9tIHRoZSBkaXNrYFxuICAgICAgKTtcbiAgICAgIHRoaXMuY29udGVudHMgPSBhd2FpdCBnZXRGaWxlQ29udGVudHModGhpcy5nZXRQYXRoKCkpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5jb250ZW50cztcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXNzZXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQTRDO0FBQzVDLDZCQUE2QjtBQUc3Qix5Q0FBZ0Q7QUFFaEQ7OztHQUdHO0FBQ0gsTUFBYSxLQUFLO0lBV2hCOzs7OztPQUtHO0lBQ0gsWUFBWSxRQUFnQixFQUFFLE1BQW1CO1FBQy9DLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxlQUFNLENBQUMsOEJBQThCLENBQUMsQ0FBQztRQUV6RCw4Q0FBOEM7UUFDOUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDOUIsTUFBTSxJQUFJLEtBQUssQ0FDYix5REFBeUQsUUFBUSxFQUFFLENBQ3BFLENBQUM7U0FDSDtRQUNELElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBRXpCLHlFQUF5RTtRQUN6RSxrQkFBa0I7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUM7UUFFckUsZUFBZTtRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUV4QixzREFBc0Q7UUFDdEQsSUFBSSxNQUFNLENBQUMsUUFBUSxFQUFFO1lBQ25CLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQztTQUNqQztRQUNELElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRTtZQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUM7U0FDakM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxXQUFXLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDO1NBQ3ZDO1FBRUQsNkRBQTZEO1FBQzdELElBQUksTUFBTSxDQUFDLGVBQWUsRUFBRTtZQUMxQixJQUFJLENBQUMsZUFBZSxHQUFHLE1BQU0sQ0FBQyxlQUFlLENBQUM7U0FDL0M7UUFDRCxJQUFJLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRTtZQUM3QixJQUFJLENBQUMsa0JBQWtCLEdBQUcsTUFBTSxDQUFDLGtCQUFrQixDQUFDO1NBQ3JEO1FBQ0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsU0FBUyxJQUFJLENBQUMsSUFBSSxlQUFlLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ3RFLENBQUM7SUFFRDs7T0FFRztJQUNILE9BQU87UUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsT0FBTyxDQUFDLElBQVk7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7SUFDbkIsQ0FBQztJQUVELFdBQVcsQ0FBQyxRQUFnQjtRQUMxQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUMzQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxjQUFjO1FBQ1osTUFBTSxNQUFNLEdBQWdCO1lBQzFCLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtTQUNoQixDQUFDO1FBQ0YsSUFBSSxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ3hCLE1BQU0sQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztTQUMvQztRQUNELElBQUksSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQzNCLE1BQU0sQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUM7U0FDckQ7UUFDRCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDakIsTUFBTSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO1NBQ2pDO1FBQ0QsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLE1BQU0sQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztTQUN2QztRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2hCLENBQUM7SUFFRDs7T0FFRztJQUNILEtBQUssQ0FBQyxXQUFXO1FBQ2YseURBQXlEO1FBQ3pELElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUNmLFdBQVcsSUFBSSxDQUFDLE9BQU8sRUFBRSxnQ0FBZ0MsQ0FDMUQsQ0FBQztZQUNGLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSx1QkFBZSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1NBQ3ZEO1FBQ0QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7Q0FDRjtBQTlHRCxzQkE4R0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBMb2dnZXIgfSBmcm9tICdAaWNvbi1tYWdpYy9sb2dnZXInO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHsgQXNzZXRDb25maWcsIENvbnRlbnQgfSBmcm9tICcuL2ludGVyZmFjZSc7XG5pbXBvcnQgeyBnZXRGaWxlQ29udGVudHMgfSBmcm9tICcuL3V0aWxzL2ZpbGVzJztcblxuLyoqXG4gKiBUaGlzIGNsYXNzIGFic3RyYWN0cyB0aGUgc21hbGxlc3Qgc2V0IG9mIGluZm9ybWF0aW9uIHBlcnRhaW5zIHRvIGFuIGFzc2V0XG4gKiBmaWxlIGluIG1lbW9yeVxuICovXG5leHBvcnQgY2xhc3MgQXNzZXQge1xuICBuYW1lOiBzdHJpbmc7XG4gIGNvbnRlbnRzOiBDb250ZW50IHwgdW5kZWZpbmVkO1xuICBpY29uUGF0aDogc3RyaW5nO1xuICBidWlsZFNvdXJjZUhhc2g/OiBzdHJpbmc7XG4gIGdlbmVyYXRlU291cmNlSGFzaD86IHN0cmluZztcbiAgaW1hZ2VzZXQ/OiBzdHJpbmc7XG4gIGNvbG9yU2NoZW1lPzogc3RyaW5nO1xuICBwcm90ZWN0ZWQgcGF0aDogc3RyaW5nO1xuICBwcml2YXRlIExPR0dFUjogTG9nZ2VyO1xuXG4gIC8qKlxuICAgKiBDcmVhdGVzIGEgbmV3IGFzc2V0XG4gICAqIEBwYXJhbSBpY29uUGF0aCBBYnNvbHV0ZSBwYXRoIG9mIHRoZSBpY29uIGZvbGRlciB3aGljaCB0aGlzIGFzc2V0IGJlbG9uZ3NcbiAgICogICAgICAgICAgICAgICAgIHRvIEFsbCBwYXRocyBpbiB0aGUgYXNzZXQgYXJlIHJlbGF0aXZlIHRvIHRoaXMgaWNvblBhdGhcbiAgICogQHBhcmFtIGNvbmZpZyBhIGNvbmZpZyBvYmplY3QgdG8gc2V0IHRoZSBpbml0aWFsIHByb3BlcnRpZXMgb2YgdGhlIGFzc2V0XG4gICAqL1xuICBjb25zdHJ1Y3RvcihpY29uUGF0aDogc3RyaW5nLCBjb25maWc6IEFzc2V0Q29uZmlnKSB7XG4gICAgdGhpcy5MT0dHRVIgPSBuZXcgTG9nZ2VyKCdpY29uLW1hZ2ljOmljb24tbW9kZWxzOmFzc2V0Jyk7XG5cbiAgICAvLyBpZiBpY29uUGF0aCBpcyBub3QgYWJzb2x1dGUsIHRocm93IGFuIGVycm9yXG4gICAgaWYgKCFwYXRoLmlzQWJzb2x1dGUoaWNvblBhdGgpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGBBc3NldENyZWF0aW9uRXJyb3I6IGljb25QYXRoIG11c3QgYWx3YXlzIGJlIGFic29sdXRlOiAke2ljb25QYXRofWBcbiAgICAgICk7XG4gICAgfVxuICAgIHRoaXMuaWNvblBhdGggPSBpY29uUGF0aDtcblxuICAgIC8vIGlmIHRoZSBhc3NldCBkb2VzIG5vdCBoYXZlIGEgbmFtZSwgdGhlbiBzZXQgdGhlIG5hbWUgdG8gYmUgdGhlIG5hbWUgb2ZcbiAgICAvLyB0aGUgZmlsZSBpdHNlbGZcbiAgICB0aGlzLm5hbWUgPSBjb25maWcubmFtZSA/IGNvbmZpZy5uYW1lIDogcGF0aC5wYXJzZShjb25maWcucGF0aCkubmFtZTtcblxuICAgIC8vIHNldCB0aGUgcGF0aFxuICAgIHRoaXMucGF0aCA9IGNvbmZpZy5wYXRoO1xuXG4gICAgLy8gc2V0IHRoZSBjb250ZW50cyBvbmx5IGlmIGl0IGlzIHBhc3NlZCBpbiB0aGUgY29uZmlnXG4gICAgaWYgKGNvbmZpZy5jb250ZW50cykge1xuICAgICAgdGhpcy5jb250ZW50cyA9IGNvbmZpZy5jb250ZW50cztcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5pbWFnZXNldCkge1xuICAgICAgdGhpcy5pbWFnZXNldCA9IGNvbmZpZy5pbWFnZXNldDtcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5jb2xvclNjaGVtZSkge1xuICAgICAgdGhpcy5jb2xvclNjaGVtZSA9IGNvbmZpZy5jb2xvclNjaGVtZTtcbiAgICB9XG5cbiAgICAvLyBpZiBhIHNvdXJjZSBoYXMgaXMgcGFzc2VkIGluLCBzZXQgaXQgb24gdGhlIGFzc2V0J3MgY29uZmlnXG4gICAgaWYgKGNvbmZpZy5idWlsZFNvdXJjZUhhc2gpIHtcbiAgICAgIHRoaXMuYnVpbGRTb3VyY2VIYXNoID0gY29uZmlnLmJ1aWxkU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKGNvbmZpZy5nZW5lcmF0ZVNvdXJjZUhhc2gpIHtcbiAgICAgIHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoID0gY29uZmlnLmdlbmVyYXRlU291cmNlSGFzaDtcbiAgICB9XG4gICAgdGhpcy5MT0dHRVIuZGVidWcoYEFzc2V0ICR7dGhpcy5uYW1lfSBjcmVhdGVkIGluICR7dGhpcy5pY29uUGF0aH1gKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAcmV0dXJucyBUaGUgcGF0aCBvIGFuIGFzc2V0IHdoaWNoIGlzIGFsd2F5cyByZWxhdGl2ZSB0byB0aGUgaWNvbnBhdGhcbiAgICovXG4gIGdldFBhdGgoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gcGF0aC5yZXNvbHZlKHRoaXMuaWNvblBhdGgsIHRoaXMucGF0aCk7XG4gIH1cblxuICAvKipcbiAgICogU2V0cyB0aGUgcGF0aCBwcm9wZXJ0eSB0byBhIHBhdGggcGFzc2VkIGluXG4gICAqL1xuICBzZXRQYXRoKHBhdGg6IHN0cmluZykge1xuICAgIHRoaXMucGF0aCA9IHBhdGg7XG4gIH1cblxuICBzZXRJbWFnZVNldChpbWFnZXNldDogc3RyaW5nKSB7XG4gICAgdGhpcy5pbWFnZXNldCA9IGltYWdlc2V0O1xuICB9XG5cbiAgLyoqXG4gICAqIEByZXR1cm5zIHRoZSBBc3NldCBkYXRhIHRoYXQgbmVlZHMgdG8gYmUgc3RvcmVkIGluIHRoZSBjb25maWcgZmlsZVxuICAgKi9cbiAgZ2V0QXNzZXRDb25maWcoKTogQXNzZXRDb25maWcge1xuICAgIGNvbnN0IGNvbmZpZzogQXNzZXRDb25maWcgPSB7XG4gICAgICBuYW1lOiB0aGlzLm5hbWUsXG4gICAgICBwYXRoOiB0aGlzLnBhdGgsXG4gICAgfTtcbiAgICBpZiAodGhpcy5idWlsZFNvdXJjZUhhc2gpIHtcbiAgICAgIGNvbmZpZy5idWlsZFNvdXJjZUhhc2ggPSB0aGlzLmJ1aWxkU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoKSB7XG4gICAgICBjb25maWcuZ2VuZXJhdGVTb3VyY2VIYXNoID0gdGhpcy5nZW5lcmF0ZVNvdXJjZUhhc2g7XG4gICAgfVxuICAgIGlmICh0aGlzLmltYWdlc2V0KSB7XG4gICAgICBjb25maWcuaW1hZ2VzZXQgPSB0aGlzLmltYWdlc2V0O1xuICAgIH1cbiAgICBpZiAodGhpcy5jb2xvclNjaGVtZSkge1xuICAgICAgY29uZmlnLmNvbG9yU2NoZW1lID0gdGhpcy5jb2xvclNjaGVtZTtcbiAgICB9XG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXR1cm5zIHRoZSBjb250ZW50IHN0b3JlZCBpbiB0aGUgcGF0aCBvZiB0aGlzIGFzc2V0XG4gICAqL1xuICBhc3luYyBnZXRDb250ZW50cygpOiBQcm9taXNlPENvbnRlbnQ+IHtcbiAgICAvLyBpZiBpdCBpc24ndCBhbHJlYWR5IHJldHJpZXZlZCwgcmVhZCB0aGUgZmlsZSBmcm9tIGRpc2tcbiAgICBpZiAoIXRoaXMuY29udGVudHMpIHtcbiAgICAgIHRoaXMuTE9HR0VSLmRlYnVnKFxuICAgICAgICBgUmVhZGluZyAke3RoaXMuZ2V0UGF0aCgpfSdzIGZpbGUgY29udGVudHMgZnJvbSB0aGUgZGlza2BcbiAgICAgICk7XG4gICAgICB0aGlzLmNvbnRlbnRzID0gYXdhaXQgZ2V0RmlsZUNvbnRlbnRzKHRoaXMuZ2V0UGF0aCgpKTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuY29udGVudHM7XG4gIH1cbn1cbiJdfQ== |
@@ -49,2 +49,18 @@ "use strict"; | ||
let flavorTypes; | ||
const config = { | ||
name: this.name, | ||
path: `./${path.relative(this.iconPath, this.getPath())}`, | ||
}; | ||
if (this.buildSourceHash) { | ||
config.buildSourceHash = this.buildSourceHash; | ||
} | ||
if (this.generateSourceHash) { | ||
config.generateSourceHash = this.generateSourceHash; | ||
} | ||
if (this.imageset) { | ||
config.imageset = this.imageset; | ||
} | ||
if (this.colorScheme) { | ||
config.colorScheme = this.colorScheme; | ||
} | ||
// return only flavor data | ||
@@ -56,15 +72,8 @@ if (this.types) { | ||
} | ||
config.types = flavorTypes; | ||
} | ||
return { | ||
name: this.name, | ||
path: `./${path.relative(this.iconPath, this.getPath())}`, | ||
buildSourceHash: this.buildSourceHash, | ||
generateSourceHash: this.generateSourceHash, | ||
imageset: this.imageset, | ||
colorScheme: this.colorScheme, | ||
types: flavorTypes | ||
}; | ||
return config; | ||
} | ||
} | ||
exports.Flavor = Flavor; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdm9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZsYXZvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2QkFBNkI7QUFFN0IsbUNBQWdDO0FBR2hDOzs7OztHQUtHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsYUFBSztJQUcvQjs7Ozs7T0FLRztJQUNILFlBQVksUUFBZ0IsRUFBRSxNQUFvQjtRQUNoRCxpQ0FBaUM7UUFDakMsS0FBSyxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUN4QixJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUU7WUFDaEIsNENBQTRDO1lBQzVDLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLFlBQVksR0FBRyxDQUFDLEVBQUU7Z0JBQ2xDLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQ3hCLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDdkQsSUFBSSxLQUFLLEVBQUU7d0JBQ1QsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsSUFBSSxhQUFLLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7cUJBQzVDO2lCQUNGO2dCQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO2FBQ3BCO2lCQUFNO2dCQUNMLDRDQUE0QztnQkFDNUMsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO2FBQzNCO1NBQ0Y7YUFBTTtZQUNMLHdCQUF3QjtZQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsU0FBUztRQUNQLElBQUksV0FBVyxDQUFDO1FBQ2hCLDBCQUEwQjtRQUMxQixJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDZCxXQUFXLEdBQUcsRUFBRSxDQUFDO1lBQ2pCLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO2dCQUNyQyxXQUFXLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO2FBQzNDO1NBQ0Y7UUFDRCxPQUFPO1lBQ0wsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsSUFBSSxFQUFFLEtBQUssSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxFQUFFO1lBQ3pELGVBQWUsRUFBRSxJQUFJLENBQUMsZUFBZTtZQUNyQyxrQkFBa0IsRUFBRSxJQUFJLENBQUMsa0JBQWtCO1lBQzNDLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUTtZQUN2QixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsS0FBSyxFQUFFLFdBQVc7U0FDbkIsQ0FBQztJQUNKLENBQUM7Q0FDRjtBQXZERCx3QkF1REMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQgeyBBc3NldCB9IGZyb20gJy4vYXNzZXQnO1xuaW1wb3J0IHsgRmxhdm9yQ29uZmlnIH0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuXG4vKipcbiAqIEluIGl0J3Mgc2ltcGxpc3QgZGVmaW5pdGlvbiwgYSBGbGF2b3IgaXMgYW4gQXNzZXQgd2l0aCB0eXBlcyBUaGlzIGNsYXNzXG4gKiBjb250YWlucyBBc3NldHMgZm9yIGFsbCB0aGUgZGlmZmVyZW50IHR5cGVzIGluIHdoaWNoIGl0IGNhbiBleGlzdCBGb3JcbiAqIGV4YW1wbGUsIGEgRmxhdm9yIGNvbnNpc3RzIG9mIGl0J3Mgc291cmNlIHN2ZyBhcyB3ZWxsIGFzIHBhdGhzIHRvIGl0J3MgcG5nXG4gKiBhbmQgd2VicCBhc3NldHNcbiAqL1xuZXhwb3J0IGNsYXNzIEZsYXZvciBleHRlbmRzIEFzc2V0IHtcbiAgdHlwZXM6IE1hcDxzdHJpbmcsIEFzc2V0PjtcblxuICAvKipcbiAgICpcbiAgICogQHBhcmFtIGljb25QYXRoIEFic29sdXRlIHBhdGggdG8gdGhlIGljb24gZGlyZWN0b3J5IG9mIHdoaWNoIHRoaXMgZmxhdm9yIGlzXG4gICAqIGEgcGFydCBvZlxuICAgKiBAcGFyYW0gY29uZmlnIGNvbmZpZyBwb3JwZXJ0aWVzIGZvciBpbnN0YW50aWF0aW5nIHRoZSBGbGF2b3JcbiAgICovXG4gIGNvbnN0cnVjdG9yKGljb25QYXRoOiBzdHJpbmcsIGNvbmZpZzogRmxhdm9yQ29uZmlnKSB7XG4gICAgLy8gb25seSBmbGF2b3JzIGhhdmUgYSBzb3VyY2VIYXNoXG4gICAgc3VwZXIoaWNvblBhdGgsIGNvbmZpZyk7XG4gICAgaWYgKGNvbmZpZy50eXBlcykge1xuICAgICAgLy9pZiB0eXBlcyBpcyBhbiBvYmplY3QsIGNvbnZlcnQgaXQgdG8gYSBtYXBcbiAgICAgIGlmICghKGNvbmZpZy50eXBlcyBpbnN0YW5jZW9mIE1hcCkpIHtcbiAgICAgICAgY29uc3QgdHlwZXMgPSBuZXcgTWFwKCk7XG4gICAgICAgIGZvciAoY29uc3QgW2tleSwgYXNzZXRdIG9mIE9iamVjdC5lbnRyaWVzKGNvbmZpZy50eXBlcykpIHtcbiAgICAgICAgICBpZiAoYXNzZXQpIHtcbiAgICAgICAgICAgIHR5cGVzLnNldChrZXksIG5ldyBBc3NldChpY29uUGF0aCwgYXNzZXQpKTtcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy50eXBlcyA9IHR5cGVzO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gaWYgaXQncyBhbHJlYWR5IGEgbWFwLCBhc3NpZ24gaXQgdG8gdHlwZXNcbiAgICAgICAgdGhpcy50eXBlcyA9IGNvbmZpZy50eXBlcztcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgLy8gY3JlYXRlIGEgYW4gZW1wdHkgbWFwXG4gICAgICB0aGlzLnR5cGVzID0gbmV3IE1hcCgpO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBQb3B1bGF0ZXMgRmxhdm9yQ29uZmlnIHdpdGggZmxhdm9yIGRhdGEgdGhhdCBuZWVkcyB0byBiZSBzdG9yZWQgYW5kXG4gICAqIEByZXR1cm5zIEZsYXZvckNvbmZpZyBvYmplY3QgdG8gYmUgc2V0IGFzIHRoZSBjb25maWdcbiAgICovXG4gIGdldENvbmZpZygpOiBGbGF2b3JDb25maWcge1xuICAgIGxldCBmbGF2b3JUeXBlcztcbiAgICAvLyByZXR1cm4gb25seSBmbGF2b3IgZGF0YVxuICAgIGlmICh0aGlzLnR5cGVzKSB7XG4gICAgICBmbGF2b3JUeXBlcyA9IHt9O1xuICAgICAgZm9yIChjb25zdCBba2V5LCBhc3NldF0gb2YgdGhpcy50eXBlcykge1xuICAgICAgICBmbGF2b3JUeXBlc1trZXldID0gYXNzZXQuZ2V0QXNzZXRDb25maWcoKTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIHBhdGg6IGAuLyR7cGF0aC5yZWxhdGl2ZSh0aGlzLmljb25QYXRoLCB0aGlzLmdldFBhdGgoKSl9YCxcbiAgICAgIGJ1aWxkU291cmNlSGFzaDogdGhpcy5idWlsZFNvdXJjZUhhc2gsXG4gICAgICBnZW5lcmF0ZVNvdXJjZUhhc2g6IHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoLFxuICAgICAgaW1hZ2VzZXQ6IHRoaXMuaW1hZ2VzZXQsXG4gICAgICBjb2xvclNjaGVtZTogdGhpcy5jb2xvclNjaGVtZSxcbiAgICAgIHR5cGVzOiBmbGF2b3JUeXBlc1xuICAgIH07XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdm9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZsYXZvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSw2QkFBNkI7QUFFN0IsbUNBQWdDO0FBR2hDOzs7OztHQUtHO0FBQ0gsTUFBYSxNQUFPLFNBQVEsYUFBSztJQUcvQjs7Ozs7T0FLRztJQUNILFlBQVksUUFBZ0IsRUFBRSxNQUFvQjtRQUNoRCxpQ0FBaUM7UUFDakMsS0FBSyxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUN4QixJQUFJLE1BQU0sQ0FBQyxLQUFLLEVBQUU7WUFDaEIsNENBQTRDO1lBQzVDLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLFlBQVksR0FBRyxDQUFDLEVBQUU7Z0JBQ2xDLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7Z0JBQ3hCLEtBQUssTUFBTSxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsSUFBSSxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRTtvQkFDdkQsSUFBSSxLQUFLLEVBQUU7d0JBQ1QsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsSUFBSSxhQUFLLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7cUJBQzVDO2lCQUNGO2dCQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO2FBQ3BCO2lCQUFNO2dCQUNMLDRDQUE0QztnQkFDNUMsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO2FBQzNCO1NBQ0Y7YUFBTTtZQUNMLHdCQUF3QjtZQUN4QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsU0FBUztRQUNQLElBQUksV0FBVyxDQUFDO1FBRWhCLE1BQU0sTUFBTSxHQUFpQjtZQUMzQixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUk7WUFDZixJQUFJLEVBQUUsS0FBSyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLEVBQUU7U0FDMUQsQ0FBQztRQUNGLElBQUksSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUN4QixNQUFNLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7U0FDL0M7UUFDRCxJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUMzQixNQUFNLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDO1NBQ3JEO1FBQ0QsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLE1BQU0sQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQztTQUNqQztRQUNELElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixNQUFNLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7U0FDdkM7UUFDRCwwQkFBMEI7UUFDMUIsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2QsV0FBVyxHQUFHLEVBQUUsQ0FBQztZQUNqQixLQUFLLE1BQU0sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtnQkFDckMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQzthQUMzQztZQUNELE1BQU0sQ0FBQyxLQUFLLEdBQUcsV0FBVyxDQUFDO1NBQzVCO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztDQUNGO0FBakVELHdCQWlFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7IEFzc2V0IH0gZnJvbSAnLi9hc3NldCc7XG5pbXBvcnQgeyBGbGF2b3JDb25maWcgfSBmcm9tICcuL2ludGVyZmFjZSc7XG5cbi8qKlxuICogSW4gaXQncyBzaW1wbGlzdCBkZWZpbml0aW9uLCBhIEZsYXZvciBpcyBhbiBBc3NldCB3aXRoIHR5cGVzIFRoaXMgY2xhc3NcbiAqIGNvbnRhaW5zIEFzc2V0cyBmb3IgYWxsIHRoZSBkaWZmZXJlbnQgdHlwZXMgaW4gd2hpY2ggaXQgY2FuIGV4aXN0IEZvclxuICogZXhhbXBsZSwgYSBGbGF2b3IgY29uc2lzdHMgb2YgaXQncyBzb3VyY2Ugc3ZnIGFzIHdlbGwgYXMgcGF0aHMgdG8gaXQncyBwbmdcbiAqIGFuZCB3ZWJwIGFzc2V0c1xuICovXG5leHBvcnQgY2xhc3MgRmxhdm9yIGV4dGVuZHMgQXNzZXQge1xuICB0eXBlczogTWFwPHN0cmluZywgQXNzZXQ+O1xuXG4gIC8qKlxuICAgKlxuICAgKiBAcGFyYW0gaWNvblBhdGggQWJzb2x1dGUgcGF0aCB0byB0aGUgaWNvbiBkaXJlY3Rvcnkgb2Ygd2hpY2ggdGhpcyBmbGF2b3IgaXNcbiAgICogYSBwYXJ0IG9mXG4gICAqIEBwYXJhbSBjb25maWcgY29uZmlnIHBvcnBlcnRpZXMgZm9yIGluc3RhbnRpYXRpbmcgdGhlIEZsYXZvclxuICAgKi9cbiAgY29uc3RydWN0b3IoaWNvblBhdGg6IHN0cmluZywgY29uZmlnOiBGbGF2b3JDb25maWcpIHtcbiAgICAvLyBvbmx5IGZsYXZvcnMgaGF2ZSBhIHNvdXJjZUhhc2hcbiAgICBzdXBlcihpY29uUGF0aCwgY29uZmlnKTtcbiAgICBpZiAoY29uZmlnLnR5cGVzKSB7XG4gICAgICAvL2lmIHR5cGVzIGlzIGFuIG9iamVjdCwgY29udmVydCBpdCB0byBhIG1hcFxuICAgICAgaWYgKCEoY29uZmlnLnR5cGVzIGluc3RhbmNlb2YgTWFwKSkge1xuICAgICAgICBjb25zdCB0eXBlcyA9IG5ldyBNYXAoKTtcbiAgICAgICAgZm9yIChjb25zdCBba2V5LCBhc3NldF0gb2YgT2JqZWN0LmVudHJpZXMoY29uZmlnLnR5cGVzKSkge1xuICAgICAgICAgIGlmIChhc3NldCkge1xuICAgICAgICAgICAgdHlwZXMuc2V0KGtleSwgbmV3IEFzc2V0KGljb25QYXRoLCBhc3NldCkpO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICB0aGlzLnR5cGVzID0gdHlwZXM7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICAvLyBpZiBpdCdzIGFscmVhZHkgYSBtYXAsIGFzc2lnbiBpdCB0byB0eXBlc1xuICAgICAgICB0aGlzLnR5cGVzID0gY29uZmlnLnR5cGVzO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAvLyBjcmVhdGUgYSBhbiBlbXB0eSBtYXBcbiAgICAgIHRoaXMudHlwZXMgPSBuZXcgTWFwKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFBvcHVsYXRlcyBGbGF2b3JDb25maWcgd2l0aCBmbGF2b3IgZGF0YSB0aGF0IG5lZWRzIHRvIGJlIHN0b3JlZCBhbmRcbiAgICogQHJldHVybnMgRmxhdm9yQ29uZmlnIG9iamVjdCB0byBiZSBzZXQgYXMgdGhlIGNvbmZpZ1xuICAgKi9cbiAgZ2V0Q29uZmlnKCk6IEZsYXZvckNvbmZpZyB7XG4gICAgbGV0IGZsYXZvclR5cGVzO1xuXG4gICAgY29uc3QgY29uZmlnOiBGbGF2b3JDb25maWcgPSB7XG4gICAgICBuYW1lOiB0aGlzLm5hbWUsXG4gICAgICBwYXRoOiBgLi8ke3BhdGgucmVsYXRpdmUodGhpcy5pY29uUGF0aCwgdGhpcy5nZXRQYXRoKCkpfWAsXG4gICAgfTtcbiAgICBpZiAodGhpcy5idWlsZFNvdXJjZUhhc2gpIHtcbiAgICAgIGNvbmZpZy5idWlsZFNvdXJjZUhhc2ggPSB0aGlzLmJ1aWxkU291cmNlSGFzaDtcbiAgICB9XG4gICAgaWYgKHRoaXMuZ2VuZXJhdGVTb3VyY2VIYXNoKSB7XG4gICAgICBjb25maWcuZ2VuZXJhdGVTb3VyY2VIYXNoID0gdGhpcy5nZW5lcmF0ZVNvdXJjZUhhc2g7XG4gICAgfVxuICAgIGlmICh0aGlzLmltYWdlc2V0KSB7XG4gICAgICBjb25maWcuaW1hZ2VzZXQgPSB0aGlzLmltYWdlc2V0O1xuICAgIH1cbiAgICBpZiAodGhpcy5jb2xvclNjaGVtZSkge1xuICAgICAgY29uZmlnLmNvbG9yU2NoZW1lID0gdGhpcy5jb2xvclNjaGVtZTtcbiAgICB9XG4gICAgLy8gcmV0dXJuIG9ubHkgZmxhdm9yIGRhdGFcbiAgICBpZiAodGhpcy50eXBlcykge1xuICAgICAgZmxhdm9yVHlwZXMgPSB7fTtcbiAgICAgIGZvciAoY29uc3QgW2tleSwgYXNzZXRdIG9mIHRoaXMudHlwZXMpIHtcbiAgICAgICAgZmxhdm9yVHlwZXNba2V5XSA9IGFzc2V0LmdldEFzc2V0Q29uZmlnKCk7XG4gICAgICB9XG4gICAgICBjb25maWcudHlwZXMgPSBmbGF2b3JUeXBlcztcbiAgICB9XG4gICAgcmV0dXJuIGNvbmZpZztcbiAgfVxufVxuIl19 |
@@ -142,2 +142,2 @@ "use strict"; | ||
exports.Icon = Icon; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.js","sourceRoot":"","sources":["../../src/icon.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from '@icon-magic/logger';\nimport * as path from 'path';\n\nimport { Asset } from './asset';\nimport { Flavor } from './flavor';\nimport {\n  AssetResolution,\n  AssetSize,\n  BuildConfig,\n  DistributeConfig,\n  FlavorConfig,\n  GenerateConfig,\n  IconConfig,\n  MetaData\n} from './interface';\nimport { exists, isTypeSVG } from './utils/files';\n\n/**\n * Encapsulates what an Icon means It is referenced by a path to it's directory\n * and the directory of icons can be assumed to contain all the different\n * variants and flavors in which the icon is available, in all of it's different\n * types. The config itself is generally more concise and human readable but this\n * class supplements it by providing methods on it and filling in the gaps where\n * they don't exist\n */\nexport class Icon {\n  private LOGGER: Logger;\n  iconPath!: string;\n  variants: Asset[];\n  sourceConfigFile!: string;\n  sizes!: AssetSize[];\n  resolutions!: AssetResolution[];\n  iconName!: string;\n  labels!: string[];\n  category!: string;\n  flavors: Map<string, Flavor>;\n  outputPath!: string;\n  build?: BuildConfig;\n  generate?: GenerateConfig;\n  distribute?: DistributeConfig;\n  metadata?: MetaData;\n\n  /**\n   * Creates an Icon instance by creating sub classes for it's variants and\n   * flavors\n   * @param config Config read from a config file containing all the icon's\n   * information\n   * @param skipVariantCheck if true, skips the check to verify the existence of\n   * variants. This flag is normally set false for generate configs that don't\n   * have variants anymore\n   */\n  constructor(config: IconConfig, skipVariantCheck?: boolean) {\n    this.LOGGER = new Logger('icon-magic:icon-models:icon');\n\n    // copy over all the properties in the config\n    for (const key of Object.keys(config)) {\n      this[key] = config[key];\n    }\n\n    // sets a name to the icon if it doesn't exist already\n    if (!config.iconName) {\n      this.iconName = path.parse(config.iconPath).name;\n    }\n\n    // iterate through the variants and create Asset instances for each variant\n    const variants: Asset[] = [];\n    for (const variant of config.variants) {\n      if (!(variant instanceof Asset)) {\n        const variantAsset = new Asset(config.iconPath, variant);\n\n        // only check the variants if the flag is true\n        if (!skipVariantCheck) {\n          // check to see if the file exists\n          if (!exists(variantAsset.getPath())) {\n            this.LOGGER.error(\n              `MissingVariantError: Variant ${variantAsset.getPath()} missing for icon ${\n                this.iconPath\n              }`\n            );\n            continue;\n          }\n\n          // check that the asset is an svg file\n          if (!isTypeSVG(variantAsset.getPath())) {\n            this.LOGGER.error(\n              `InvalidVariantError: Variant ${variantAsset.getPath()} of ${\n                this.iconPath\n              } should be an SVG file`\n            );\n            continue;\n          }\n        }\n\n        variants.push(variantAsset);\n      }\n    }\n\n    // if there are no valid variants, throw an error\n    if (!variants.length) {\n      throw new Error(\n        `NoValidVariantsError: ${this.iconPath} does not have any valid variants`\n      );\n    }\n\n    this.variants = variants;\n\n    // if the config has flavors, create Flavor instances for each flavor\n    const flavors: Map<string, Flavor> = new Map();\n    for (const flavor of config.flavors || []) {\n      if (!(flavor instanceof Flavor)) {\n        const tmpFlavor = new Flavor(config.iconPath, flavor);\n        flavors.set(tmpFlavor.name, tmpFlavor);\n      }\n    }\n    this.flavors = flavors;\n  }\n\n  /**\n   * @returns the path to output the processed icons\n   */\n  getIconOutputPath(): string {\n    const iconOutputPath = path.join(this.outputPath, this.iconName);\n\n    // unless it's absolute, the outputPath is relative to the cwd\n    return path.isAbsolute(iconOutputPath)\n      ? iconOutputPath\n      : path.join(process.cwd(), iconOutputPath);\n  }\n\n  /**\n   * @returns a path by appending '/build' to the icon's outputPath\n   */\n  getBuildOutputPath(): string {\n    return path.join(this.getIconOutputPath(), 'build');\n  }\n\n  /**\n   * Populates object with all Icon data as an object so it can be written to the output\n   * directory and\n   * @returns object to be set as the config\n   */\n  getConfig(): IconConfig {\n    this.LOGGER.debug(`Creating the config for ${this.iconPath}`);\n    // copy all properties have to be defined\n    const config: IconConfig = {\n      iconPath: '.', // we assume that the config will be written to the icon directory itself\n      variants: [], // by instantiaing variants to be an empty array\n      sourceConfigFile: path.relative(this.iconPath, this.sourceConfigFile), // again, we resolve this path w.r.t. the icon directory\n      sizes: this.sizes,\n      resolutions: this.resolutions,\n      iconName: this.iconName,\n      outputPath: this.outputPath\n    };\n\n    // fill out the variant data by getting the config from each\n    for (const variant of this.variants) {\n      config.variants.push(variant.getAssetConfig());\n    }\n\n    // if there are flavors, iterate and add each one\n    if (this.flavors) {\n      const flavors: FlavorConfig[] = [];\n      for (const flavor of this.flavors.values()) {\n        flavors.push(flavor.getConfig());\n      }\n      config.flavors = flavors;\n    }\n\n    //copy over the rest of the properties only if they exist\n    if (this.labels) {\n      config.labels = this.labels;\n    }\n    if (this.category) {\n      config.category = this.category;\n    }\n    if (this.metadata) {\n      config.metadata = this.metadata;\n    }\n    if (this.build) {\n      config.build = this.build;\n    }\n    if (this.generate) {\n      config.generate = this.generate;\n    }\n    if (this.distribute) {\n      config.distribute = this.distribute;\n    }\n\n    // return the object\n    return config;\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.js","sourceRoot":"","sources":["../../src/icon.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from '@icon-magic/logger';\nimport * as path from 'path';\n\nimport { Asset } from './asset';\nimport { Flavor } from './flavor';\nimport {\n  AssetResolution,\n  AssetSize,\n  BuildConfig,\n  DistributeConfig,\n  FlavorConfig,\n  GenerateConfig,\n  IconConfig,\n  MetaData\n} from './interface';\nimport { exists, isTypeSVG } from './utils/files';\n\n/**\n * Encapsulates what an Icon means It is referenced by a path to it's directory\n * and the directory of icons can be assumed to contain all the different\n * variants and flavors in which the icon is available, in all of it's different\n * types. The config itself is generally more concise and human readable but this\n * class supplements it by providing methods on it and filling in the gaps where\n * they don't exist\n */\nexport class Icon {\n  private LOGGER: Logger;\n  iconPath!: string;\n  variants: Asset[];\n  sourceConfigFile!: string;\n  sizes!: AssetSize[];\n  resolutions!: AssetResolution[];\n  iconName!: string;\n  labels!: string[];\n  category!: string;\n  flavors: Map<string, Flavor>;\n  outputPath!: string;\n  build?: BuildConfig;\n  generate?: GenerateConfig;\n  distribute?: DistributeConfig;\n  metadata?: MetaData;\n\n  /**\n   * Creates an Icon instance by creating sub classes for it's variants and\n   * flavors\n   * @param config Config read from a config file containing all the icon's\n   * information\n   * @param skipVariantCheck if true, skips the check to verify the existence of\n   * variants. This flag is normally set false for generate configs that don't\n   * have variants anymore\n   */\n  constructor(config: IconConfig, skipVariantCheck?: boolean) {\n    this.LOGGER = new Logger('icon-magic:icon-models:icon');\n\n    // copy over all the properties in the config\n    for (const key of Object.keys(config)) {\n      this[key] = config[key];\n    }\n\n    // sets a name to the icon if it doesn't exist already\n    if (!config.iconName) {\n      this.iconName = path.parse(config.iconPath).name;\n    }\n\n    // iterate through the variants and create Asset instances for each variant\n    const variants: Asset[] = [];\n    for (const variant of config.variants) {\n      if (!(variant instanceof Asset)) {\n        const variantAsset = new Asset(config.iconPath, variant);\n\n        // only check the variants if the flag is true\n        if (!skipVariantCheck) {\n          // check to see if the file exists\n          if (!exists(variantAsset.getPath())) {\n            this.LOGGER.error(\n              `MissingVariantError: Variant ${variantAsset.getPath()} missing for icon ${\n                this.iconPath\n              }`\n            );\n            continue;\n          }\n\n          // check that the asset is an svg file\n          if (!isTypeSVG(variantAsset.getPath())) {\n            this.LOGGER.error(\n              `InvalidVariantError: Variant ${variantAsset.getPath()} of ${\n                this.iconPath\n              } should be an SVG file`\n            );\n            continue;\n          }\n        }\n\n        variants.push(variantAsset);\n      }\n    }\n\n    // if there are no valid variants, throw an error\n    if (!variants.length) {\n      throw new Error(\n        `NoValidVariantsError: ${this.iconPath} does not have any valid variants`\n      );\n    }\n\n    this.variants = variants;\n\n    // if the config has flavors, create Flavor instances for each flavor\n    const flavors: Map<string, Flavor> = new Map();\n    for (const flavor of config.flavors || []) {\n      if (!(flavor instanceof Flavor)) {\n        const tmpFlavor = new Flavor(config.iconPath, flavor);\n        flavors.set(tmpFlavor.name, tmpFlavor);\n      }\n    }\n    this.flavors = flavors;\n  }\n\n  /**\n   * @returns the path to output the processed icons\n   */\n  getIconOutputPath(): string {\n    const iconOutputPath = path.join(this.outputPath, this.iconName);\n\n    // unless it's absolute, the outputPath is relative to the cwd\n    return path.isAbsolute(iconOutputPath)\n      ? iconOutputPath\n      : path.join(process.cwd(), iconOutputPath);\n  }\n\n  /**\n   * @returns a path by appending '/build' to the icon's outputPath\n   */\n  getBuildOutputPath(): string {\n    return path.join(this.getIconOutputPath(), 'build');\n  }\n\n  /**\n   * Populates object with all Icon data as an object so it can be written to the output\n   * directory and\n   * @returns object to be set as the config\n   */\n  getConfig(): IconConfig {\n    this.LOGGER.debug(`Creating the config for ${this.iconPath}`);\n    // copy all properties have to be defined\n    const config: IconConfig = {\n      iconPath: '.', // we assume that the config will be written to the icon directory itself\n      variants: [], // by instantiating variants to be an empty array\n      sourceConfigFile: path.relative(this.iconPath, this.sourceConfigFile), // again, we resolve this path w.r.t. the icon directory\n      sizes: this.sizes,\n      resolutions: this.resolutions,\n      iconName: this.iconName,\n      outputPath: this.outputPath\n    };\n\n    // fill out the variant data by getting the config from each\n    for (const variant of this.variants) {\n      config.variants.push(variant.getAssetConfig());\n    }\n\n    // if there are flavors, iterate and add each one\n    if (this.flavors) {\n      const flavors: FlavorConfig[] = [];\n      for (const flavor of this.flavors.values()) {\n        flavors.push(flavor.getConfig());\n      }\n      config.flavors = flavors;\n    }\n\n    //copy over the rest of the properties only if they exist\n    if (this.labels) {\n      config.labels = this.labels;\n    }\n    if (this.category) {\n      config.category = this.category;\n    }\n    if (this.metadata) {\n      config.metadata = this.metadata;\n    }\n    if (this.build) {\n      config.build = this.build;\n    }\n    if (this.generate) {\n      config.generate = this.generate;\n    }\n    if (this.distribute) {\n      config.distribute = this.distribute;\n    }\n\n    // return the object\n    return config;\n  }\n}\n"]} |
@@ -5,5 +5,5 @@ export { Asset } from './asset'; | ||
export { IconSet } from './icon-set'; | ||
export { applyPluginsOnAsset } from './plugin-manager'; | ||
export { applyPluginsOnAsset, applyPluginOnAssets } from './plugin-manager'; | ||
export * from './interface'; | ||
export * from './utils/files'; | ||
export * from './utils/hash'; |
@@ -13,3 +13,3 @@ "use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.applyPluginsOnAsset = exports.IconSet = exports.Icon = exports.Flavor = exports.Asset = void 0; | ||
exports.applyPluginOnAssets = exports.applyPluginsOnAsset = exports.IconSet = exports.Icon = exports.Flavor = exports.Asset = void 0; | ||
var asset_1 = require("./asset"); | ||
@@ -25,5 +25,6 @@ Object.defineProperty(exports, "Asset", { enumerable: true, get: function () { return asset_1.Asset; } }); | ||
Object.defineProperty(exports, "applyPluginsOnAsset", { enumerable: true, get: function () { return plugin_manager_1.applyPluginsOnAsset; } }); | ||
Object.defineProperty(exports, "applyPluginOnAssets", { enumerable: true, get: function () { return plugin_manager_1.applyPluginOnAssets; } }); | ||
__exportStar(require("./interface"), exports); | ||
__exportStar(require("./utils/files"), exports); | ||
__exportStar(require("./utils/hash"), exports); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLGlDQUFnQztBQUF2Qiw4RkFBQSxLQUFLLE9BQUE7QUFDZCxtQ0FBa0M7QUFBekIsZ0dBQUEsTUFBTSxPQUFBO0FBQ2YsK0JBQThCO0FBQXJCLDRGQUFBLElBQUksT0FBQTtBQUNiLHVDQUFxQztBQUE1QixtR0FBQSxPQUFPLE9BQUE7QUFFaEIsbURBQXVEO0FBQTlDLHFIQUFBLG1CQUFtQixPQUFBO0FBQzVCLDhDQUE0QjtBQUU1QixnREFBOEI7QUFDOUIsK0NBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQXNzZXQgfSBmcm9tICcuL2Fzc2V0JztcbmV4cG9ydCB7IEZsYXZvciB9IGZyb20gJy4vZmxhdm9yJztcbmV4cG9ydCB7IEljb24gfSBmcm9tICcuL2ljb24nO1xuZXhwb3J0IHsgSWNvblNldCB9IGZyb20gJy4vaWNvbi1zZXQnO1xuXG5leHBvcnQgeyBhcHBseVBsdWdpbnNPbkFzc2V0IH0gZnJvbSAnLi9wbHVnaW4tbWFuYWdlcic7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvZmlsZXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9oYXNoJztcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLGlDQUFnQztBQUF2Qiw4RkFBQSxLQUFLLE9BQUE7QUFDZCxtQ0FBa0M7QUFBekIsZ0dBQUEsTUFBTSxPQUFBO0FBQ2YsK0JBQThCO0FBQXJCLDRGQUFBLElBQUksT0FBQTtBQUNiLHVDQUFxQztBQUE1QixtR0FBQSxPQUFPLE9BQUE7QUFFaEIsbURBQTRFO0FBQW5FLHFIQUFBLG1CQUFtQixPQUFBO0FBQUUscUhBQUEsbUJBQW1CLE9BQUE7QUFDakQsOENBQTRCO0FBRTVCLGdEQUE4QjtBQUM5QiwrQ0FBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBBc3NldCB9IGZyb20gJy4vYXNzZXQnO1xuZXhwb3J0IHsgRmxhdm9yIH0gZnJvbSAnLi9mbGF2b3InO1xuZXhwb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5leHBvcnQgeyBJY29uU2V0IH0gZnJvbSAnLi9pY29uLXNldCc7XG5cbmV4cG9ydCB7IGFwcGx5UGx1Z2luc09uQXNzZXQsIGFwcGx5UGx1Z2luT25Bc3NldHMgfSBmcm9tICcuL3BsdWdpbi1tYW5hZ2VyJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlJztcblxuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlcyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2hhc2gnO1xuIl19 |
@@ -25,2 +25,6 @@ /// <reference types="node" /> | ||
variantsToFilter: string[]; | ||
outputAsHbs: { | ||
imageHrefHelper?: string; | ||
pathToTheImageAsset?: string; | ||
}; | ||
} | ||
@@ -84,3 +88,3 @@ interface WebpOptions { | ||
export interface DistributeConfig { | ||
variantsToFilter: string[]; | ||
variantsToFilter?: string[]; | ||
svg?: SVGOptions; | ||
@@ -87,0 +91,0 @@ webp?: WebpOptions; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4nO1xuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICcuL2Fzc2V0JztcbmltcG9ydCB7IEZsYXZvciB9IGZyb20gJy4vZmxhdm9yJztcblxuaW50ZXJmYWNlIFdpZHRoSGVpZ2h0IHtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIEFzc2V0U2l6ZSA9IG51bWJlciB8IFdpZHRoSGVpZ2h0O1xuZXhwb3J0IHR5cGUgQXNzZXRSZXNvbHV0aW9uID0gbnVtYmVyO1xuZXhwb3J0IHR5cGUgQ29udGVudCA9IEJ1ZmZlciB8IHN0cmluZztcblxuZXhwb3J0IGludGVyZmFjZSBBc3NldENvbmZpZyB7XG4gIG5hbWU/OiBzdHJpbmc7XG4gIHBhdGg6IHN0cmluZztcbiAgY29udGVudHM/OiBDb250ZW50O1xuICBpbWFnZXNldD86IHN0cmluZztcbiAgY29sb3JTY2hlbWU/OiBzdHJpbmc7XG4gIGJ1aWxkU291cmNlSGFzaD86IHN0cmluZztcbiAgZ2VuZXJhdGVTb3VyY2VIYXNoPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgU1ZHT3B0aW9ucyB7XG4gIHRvU3ByaXRlPzogYm9vbGVhbjtcbiAgc3ByaXRlTmFtZXM/OiBzdHJpbmdbXTtcbiAgdmFyaWFudHNUb0ZpbHRlcjogc3RyaW5nW107XG59XG5cbmludGVyZmFjZSBXZWJwT3B0aW9ucyB7XG4gIG5hbWVQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3ByaXRlQ29uZmlnIHtcbiAgW2NvZGU6IHN0cmluZ106IHtcbiAgICBET0NVTUVOVDogRG9jdW1lbnQ7XG4gICAgc3ZnRWw6IFNWR1NWR0VsZW1lbnQ7XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIEl0ZXJhbnQgPSBzdHJpbmdbXTtcbmV4cG9ydCB0eXBlIEZsYXZvclR5cGUgPSAnc3ZnJyB8ICdwbmcnIHwgJ3dlYnAnIHwgJ3dlYnBGbGlwJyB8ICdwbmdGbGlwJztcbmV4cG9ydCB0eXBlIEZsYXZvclR5cGVNYXAgPSB7IFtLIGluIEZsYXZvclR5cGVdPzogQXNzZXRDb25maWcgfTtcblxuZXhwb3J0IGludGVyZmFjZSBGbGF2b3JDb25maWcgZXh0ZW5kcyBBc3NldENvbmZpZyB7XG4gIHR5cGVzPzogRmxhdm9yVHlwZU1hcDtcbn1cblxuZXhwb3J0IHR5cGUgUGx1Z2luRnVuY3Rpb25UeXBlPFQ+ID0gKFxuICBmbGF2b3I6IFQsXG4gIGljb246IEljb24sXG4gIHBhcmFtcz86IG9iamVjdCAvLyBzZXQgb2YgaXRlcmFudCB2YWx1ZXMgdG8gYmUgcGFzc2VkIGludG8gdGhlIHBsdWdpblxuKSA9PiBQcm9taXNlPFQ+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsdWdpbjxUPiB7XG4gIG5hbWU6IHN0cmluZztcbiAgZm46IFBsdWdpbkZ1bmN0aW9uVHlwZTxUPjtcbiAgaXRlcmFudHM/OiBJdGVyYW50OyAvLyB0aGUgY29uZmlnIHByb3BlcsOfdGllcyBvbiB3aGljaCBpdCBuZWVkcyB0byByZWN1bHJzaXZlbHkgaXRlcmF0ZSB0aHJvdWdoXG4gIHBhcmFtcz86IG9iamVjdDtcbiAgd3JpdGVUb091dHB1dD86IGJvb2xlYW47IC8vIERvIG5vdCBzZXQgdW5sZXNzIGZvciBkZWJ1Z2dpbmcgdGhlIHBsdWdpbi4gQnkgZGVmYXVsdCwgdGhpcyBpcyBzZXQgdG8gdHJ1ZSBmb3IgdGhlIGxhc3QgcGx1Z2luIG9mIGVhY2ggc3RlcCAtIGJ1aWxkLCBnZW5lcmF0ZSwgZXRjXG59XG5cbmV4cG9ydCB0eXBlIEJ1aWxkUGx1Z2luID0gUGx1Z2luPEFzc2V0PjtcbmV4cG9ydCB0eXBlIEdlbmVyYXRlUGx1Z2luID0gUGx1Z2luPEZsYXZvcj47XG5cbi8qKlxuICogUHJvcGVydGllcyByZWxhdGVkIHRvIHRoZSBidWlsZCBwaGFzZSBvZiBhbiBpY29uXG4gKiBQbGVhc2UgcmVmZXIgdG8gcGFja2FnZXMvYnVpbGQvUkVBRE1FLm1kIGZvciBtb3JlIGRldGFpbHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCdWlsZENvbmZpZyB7XG4gIHBsdWdpbnM/OiBCdWlsZFBsdWdpbltdO1xufVxuXG4vKipcbiAqIFN1cHBvcnRlZCB0eXBlcyBmb3IgZ2VuZXJhdGlvbiBhcmUgc3ZnIGFuZCByYXN0ZXJcbiAqIFJhc3RlciBoZXJlIHJlcHJlc2VudHMgLnBuZyBhbmQgLndlYnBcbiAqL1xuZXhwb3J0IHR5cGUgR2VuZXJhdGVUeXBlID0gJ3N2ZycgfCAncmFzdGVyJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIHJlbGF0ZWQgdG8gYSBzaW5nbGUgZ2VuZXJhdGlvbiB0eXBlXG4gKi9cbmludGVyZmFjZSBHZW5lcmF0ZVR5cGVDb25maWcge1xuICBuYW1lOiBHZW5lcmF0ZVR5cGU7XG4gIHBsdWdpbnM/OiBHZW5lcmF0ZVBsdWdpbltdO1xufVxuXG4vKipcbiAqIFByb3BlcnRpZXMgcmVsYXRlZCB0byB0aGUgZ2VuZXJhdGlvbiBvZiBhbiBpY29uIGZyb20gLnN2ZyBpbnRvIG11bHRpcGxlXG4gKiB0eXBlcygucG5nLCAud2VicClcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHZW5lcmF0ZUNvbmZpZyB7XG4gIHR5cGVzOiBHZW5lcmF0ZVR5cGVDb25maWdbXTtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIHJlbGF0ZWQgdG8gdGhlIGRpc3RyaWJ1dGlvbiBvZiB0aGUgaWNvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIERpc3RyaWJ1dGVDb25maWcge1xuICB2YXJpYW50c1RvRmlsdGVyOiBzdHJpbmdbXTtcbiAgc3ZnPzogU1ZHT3B0aW9ucztcbiAgd2VicD86IFdlYnBPcHRpb25zO1xufVxuXG4vKipcbiAqIEFuIG9iamVjdCBjb250YWluaW5nIGFueSBtZXRhIGluZm9ybWF0aW9uIGFib3V0IHRoZSBpY29uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTWV0YURhdGEge1xuICBuYW1lU2l6ZU1hcHBpbmc/OiB7IFtuYW1lOiBzdHJpbmddOiBBc3NldFNpemUgfTtcbiAgW2tleTogc3RyaW5nXTogYW55O1xufVxuXG4vKipcbiAqIFByb3BlcnRpZXMgcmVsYXRlZCB0byBhbiBJY29uXG4gKiBUaGlzIHNob3VsZCByZXByZXNlbnQgdGhlIGNvbmZpZyBzY2hlbWEgYXQgYWxsIHRpbWVzXG4gKi9cbmV4cG9ydCB0eXBlIEljb25Db25maWcgPSB7XG4gIGljb25QYXRoOiBzdHJpbmc7XG4gIHZhcmlhbnRzOiBBc3NldENvbmZpZ1tdO1xuICBzb3VyY2VDb25maWdGaWxlOiBzdHJpbmc7XG4gIHNpemVzOiBBc3NldFNpemVbXTtcbiAgcmVzb2x1dGlvbnM6IEFzc2V0UmVzb2x1dGlvbltdO1xuICBpY29uTmFtZT86IHN0cmluZztcbiAgbGFiZWxzPzogc3RyaW5nW107XG4gIGNhdGVnb3J5Pzogc3RyaW5nO1xuICBmbGF2b3JzPzogRmxhdm9yQ29uZmlnW107XG4gIG91dHB1dFBhdGg6IHN0cmluZzsgLy8gcGF0aCB3aGVyZSB0aGUgZ2VuZXJhdGVkIGFzc2V0cyBnb1xuICBidWlsZD86IEJ1aWxkQ29uZmlnO1xuICBnZW5lcmF0ZT86IEdlbmVyYXRlQ29uZmlnO1xuICBkaXN0cmlidXRlPzogRGlzdHJpYnV0ZUNvbmZpZztcbiAgbWV0YWRhdGE/OiBNZXRhRGF0YTtcbiAgcnRsRmxpcD86IGJvb2xlYW47XG59O1xuXG4vKipcbiAqIEEgbWFwIGNvbnRhaW5pbmcgYSBwYXRoIHRvIHRoZSBpY29ucyBhbmQgdGhlaXIgcmVzcGVjdGl2ZSBjb25maWcgSlNPTnNcbiAqL1xuZXhwb3J0IHR5cGUgSWNvbkNvbmZpZ0hhc2ggPSBNYXA8c3RyaW5nLCBJY29uQ29uZmlnPjtcblxuLyoqXG4gKiBBIG1hcCBjb250YWluaW5nIGEgcGF0aCB0byB0aGUgaWNvbnMgYW5kIHRoZWlyIHJlc3BlY3RpdmUgSWNvbiBjbGFzc1xuICogaW5zdGFuY2VzXG4gKi9cbmV4cG9ydCB0eXBlIEljb25TZXRIYXNoID0gTWFwPHN0cmluZywgSWNvbj47XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4nO1xuaW1wb3J0IHsgQXNzZXQgfSBmcm9tICcuL2Fzc2V0JztcbmltcG9ydCB7IEZsYXZvciB9IGZyb20gJy4vZmxhdm9yJztcblxuaW50ZXJmYWNlIFdpZHRoSGVpZ2h0IHtcbiAgd2lkdGg6IG51bWJlcjtcbiAgaGVpZ2h0OiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIEFzc2V0U2l6ZSA9IG51bWJlciB8IFdpZHRoSGVpZ2h0O1xuZXhwb3J0IHR5cGUgQXNzZXRSZXNvbHV0aW9uID0gbnVtYmVyO1xuZXhwb3J0IHR5cGUgQ29udGVudCA9IEJ1ZmZlciB8IHN0cmluZztcblxuZXhwb3J0IGludGVyZmFjZSBBc3NldENvbmZpZyB7XG4gIG5hbWU/OiBzdHJpbmc7XG4gIHBhdGg6IHN0cmluZztcbiAgY29udGVudHM/OiBDb250ZW50O1xuICBpbWFnZXNldD86IHN0cmluZztcbiAgY29sb3JTY2hlbWU/OiBzdHJpbmc7XG4gIGJ1aWxkU291cmNlSGFzaD86IHN0cmluZztcbiAgZ2VuZXJhdGVTb3VyY2VIYXNoPzogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgU1ZHT3B0aW9ucyB7XG4gIHRvU3ByaXRlPzogYm9vbGVhbjtcbiAgc3ByaXRlTmFtZXM/OiBzdHJpbmdbXTtcbiAgdmFyaWFudHNUb0ZpbHRlcjogc3RyaW5nW107XG4gIG91dHB1dEFzSGJzOiB7XG4gICAgaW1hZ2VIcmVmSGVscGVyPzogc3RyaW5nO1xuICAgIHBhdGhUb1RoZUltYWdlQXNzZXQ/OiBzdHJpbmc7XG4gIH07XG59XG5cbmludGVyZmFjZSBXZWJwT3B0aW9ucyB7XG4gIG5hbWVQcmVmaXg/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU3ByaXRlQ29uZmlnIHtcbiAgW2NvZGU6IHN0cmluZ106IHtcbiAgICBET0NVTUVOVDogRG9jdW1lbnQ7XG4gICAgc3ZnRWw6IFNWR1NWR0VsZW1lbnQ7XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIEl0ZXJhbnQgPSBzdHJpbmdbXTtcbmV4cG9ydCB0eXBlIEZsYXZvclR5cGUgPSAnc3ZnJyB8ICdwbmcnIHwgJ3dlYnAnIHwgJ3dlYnBGbGlwJyB8ICdwbmdGbGlwJztcbmV4cG9ydCB0eXBlIEZsYXZvclR5cGVNYXAgPSB7IFtLIGluIEZsYXZvclR5cGVdPzogQXNzZXRDb25maWcgfTtcblxuZXhwb3J0IGludGVyZmFjZSBGbGF2b3JDb25maWcgZXh0ZW5kcyBBc3NldENvbmZpZyB7XG4gIHR5cGVzPzogRmxhdm9yVHlwZU1hcDtcbn1cblxuZXhwb3J0IHR5cGUgUGx1Z2luRnVuY3Rpb25UeXBlPFQ+ID0gKFxuICBmbGF2b3I6IFQsXG4gIGljb246IEljb24sXG4gIHBhcmFtcz86IG9iamVjdCAvLyBzZXQgb2YgaXRlcmFudCB2YWx1ZXMgdG8gYmUgcGFzc2VkIGludG8gdGhlIHBsdWdpblxuKSA9PiBQcm9taXNlPFQ+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFBsdWdpbjxUPiB7XG4gIG5hbWU6IHN0cmluZztcbiAgZm46IFBsdWdpbkZ1bmN0aW9uVHlwZTxUPjtcbiAgaXRlcmFudHM/OiBJdGVyYW50OyAvLyB0aGUgY29uZmlnIHByb3BlcsOfdGllcyBvbiB3aGljaCBpdCBuZWVkcyB0byByZWN1bHJzaXZlbHkgaXRlcmF0ZSB0aHJvdWdoXG4gIHBhcmFtcz86IG9iamVjdDtcbiAgd3JpdGVUb091dHB1dD86IGJvb2xlYW47IC8vIERvIG5vdCBzZXQgdW5sZXNzIGZvciBkZWJ1Z2dpbmcgdGhlIHBsdWdpbi4gQnkgZGVmYXVsdCwgdGhpcyBpcyBzZXQgdG8gdHJ1ZSBmb3IgdGhlIGxhc3QgcGx1Z2luIG9mIGVhY2ggc3RlcCAtIGJ1aWxkLCBnZW5lcmF0ZSwgZXRjXG59XG5cbmV4cG9ydCB0eXBlIEJ1aWxkUGx1Z2luID0gUGx1Z2luPEFzc2V0PjtcbmV4cG9ydCB0eXBlIEdlbmVyYXRlUGx1Z2luID0gUGx1Z2luPEZsYXZvcj47XG5cbi8qKlxuICogUHJvcGVydGllcyByZWxhdGVkIHRvIHRoZSBidWlsZCBwaGFzZSBvZiBhbiBpY29uXG4gKiBQbGVhc2UgcmVmZXIgdG8gcGFja2FnZXMvYnVpbGQvUkVBRE1FLm1kIGZvciBtb3JlIGRldGFpbHNcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBCdWlsZENvbmZpZyB7XG4gIHBsdWdpbnM/OiBCdWlsZFBsdWdpbltdO1xufVxuXG4vKipcbiAqIFN1cHBvcnRlZCB0eXBlcyBmb3IgZ2VuZXJhdGlvbiBhcmUgc3ZnIGFuZCByYXN0ZXJcbiAqIFJhc3RlciBoZXJlIHJlcHJlc2VudHMgLnBuZyBhbmQgLndlYnBcbiAqL1xuZXhwb3J0IHR5cGUgR2VuZXJhdGVUeXBlID0gJ3N2ZycgfCAncmFzdGVyJztcblxuLyoqXG4gKiBQcm9wZXJ0aWVzIHJlbGF0ZWQgdG8gYSBzaW5nbGUgZ2VuZXJhdGlvbiB0eXBlXG4gKi9cbmludGVyZmFjZSBHZW5lcmF0ZVR5cGVDb25maWcge1xuICBuYW1lOiBHZW5lcmF0ZVR5cGU7XG4gIHBsdWdpbnM/OiBHZW5lcmF0ZVBsdWdpbltdO1xufVxuXG4vKipcbiAqIFByb3BlcnRpZXMgcmVsYXRlZCB0byB0aGUgZ2VuZXJhdGlvbiBvZiBhbiBpY29uIGZyb20gLnN2ZyBpbnRvIG11bHRpcGxlXG4gKiB0eXBlcygucG5nLCAud2VicClcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHZW5lcmF0ZUNvbmZpZyB7XG4gIHR5cGVzOiBHZW5lcmF0ZVR5cGVDb25maWdbXTtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIHJlbGF0ZWQgdG8gdGhlIGRpc3RyaWJ1dGlvbiBvZiB0aGUgaWNvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIERpc3RyaWJ1dGVDb25maWcge1xuICB2YXJpYW50c1RvRmlsdGVyPzogc3RyaW5nW107XG4gIHN2Zz86IFNWR09wdGlvbnM7XG4gIHdlYnA/OiBXZWJwT3B0aW9ucztcbn1cblxuLyoqXG4gKiBBbiBvYmplY3QgY29udGFpbmluZyBhbnkgbWV0YSBpbmZvcm1hdGlvbiBhYm91dCB0aGUgaWNvblxuICovXG5leHBvcnQgaW50ZXJmYWNlIE1ldGFEYXRhIHtcbiAgbmFtZVNpemVNYXBwaW5nPzogeyBbbmFtZTogc3RyaW5nXTogQXNzZXRTaXplIH07XG4gIFtrZXk6IHN0cmluZ106IGFueTtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIHJlbGF0ZWQgdG8gYW4gSWNvblxuICogVGhpcyBzaG91bGQgcmVwcmVzZW50IHRoZSBjb25maWcgc2NoZW1hIGF0IGFsbCB0aW1lc1xuICovXG5leHBvcnQgdHlwZSBJY29uQ29uZmlnID0ge1xuICBpY29uUGF0aDogc3RyaW5nO1xuICB2YXJpYW50czogQXNzZXRDb25maWdbXTtcbiAgc291cmNlQ29uZmlnRmlsZTogc3RyaW5nO1xuICBzaXplczogQXNzZXRTaXplW107XG4gIHJlc29sdXRpb25zOiBBc3NldFJlc29sdXRpb25bXTtcbiAgaWNvbk5hbWU/OiBzdHJpbmc7XG4gIGxhYmVscz86IHN0cmluZ1tdO1xuICBjYXRlZ29yeT86IHN0cmluZztcbiAgZmxhdm9ycz86IEZsYXZvckNvbmZpZ1tdO1xuICBvdXRwdXRQYXRoOiBzdHJpbmc7IC8vIHBhdGggd2hlcmUgdGhlIGdlbmVyYXRlZCBhc3NldHMgZ29cbiAgYnVpbGQ/OiBCdWlsZENvbmZpZztcbiAgZ2VuZXJhdGU/OiBHZW5lcmF0ZUNvbmZpZztcbiAgZGlzdHJpYnV0ZT86IERpc3RyaWJ1dGVDb25maWc7XG4gIG1ldGFkYXRhPzogTWV0YURhdGE7XG4gIHJ0bEZsaXA/OiBib29sZWFuO1xufTtcblxuLyoqXG4gKiBBIG1hcCBjb250YWluaW5nIGEgcGF0aCB0byB0aGUgaWNvbnMgYW5kIHRoZWlyIHJlc3BlY3RpdmUgY29uZmlnIEpTT05zXG4gKi9cbmV4cG9ydCB0eXBlIEljb25Db25maWdIYXNoID0gTWFwPHN0cmluZywgSWNvbkNvbmZpZz47XG5cbi8qKlxuICogQSBtYXAgY29udGFpbmluZyBhIHBhdGggdG8gdGhlIGljb25zIGFuZCB0aGVpciByZXNwZWN0aXZlIEljb24gY2xhc3NcbiAqIGluc3RhbmNlc1xuICovXG5leHBvcnQgdHlwZSBJY29uU2V0SGFzaCA9IE1hcDxzdHJpbmcsIEljb24+O1xuIl19 |
@@ -1,4 +0,2 @@ | ||
import { Asset } from './asset'; | ||
import { Flavor } from './flavor'; | ||
import { Icon } from './icon'; | ||
import { Asset, Flavor, Icon } from '.'; | ||
import { BuildPlugin, GeneratePlugin, Iterant } from './interface'; | ||
@@ -18,2 +16,3 @@ /** | ||
export declare function applyPluginsOnAsset(asset: Asset | Flavor, icon: Icon, plugins: BuildPlugin[] | GeneratePlugin[]): Promise<Flavor[]>; | ||
export declare function applyPluginOnAssets(icon: Icon, plugin: BuildPlugin | GeneratePlugin, type: RegExp, hashing: boolean): Promise<void>; | ||
/** | ||
@@ -20,0 +19,0 @@ * A util to go through the icon, locate the iterants |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.getAllPropCombinations = exports.applyPluginsOnAsset = void 0; | ||
exports.getAllPropCombinations = exports.applyPluginOnAssets = exports.applyPluginsOnAsset = void 0; | ||
const logger_1 = require("@icon-magic/logger"); | ||
const path = require("path"); | ||
const _1 = require("."); | ||
const files_1 = require("./utils/files"); | ||
@@ -41,2 +42,32 @@ const prop_combinator_1 = require("./utils/prop-combinator"); | ||
exports.applyPluginsOnAsset = applyPluginsOnAsset; | ||
async function applyPluginOnAssets(icon, plugin, type, hashing) { | ||
// make a deep clone of the flavors so it doesn't change if the plugin alters | ||
//flavors on the icon | ||
const originalFlavors = [...icon.flavors.values()]; | ||
// iterate over all the plugins, applying them one at a time | ||
for (const iconFlavor of originalFlavors) { | ||
if (hashing) { | ||
// Check if generate has been run on this flavor already | ||
const flavorName = path.basename(iconFlavor.name); | ||
// Create the output directory | ||
const outputPath = icon.getIconOutputPath(); | ||
// Find the flavors in the config from the initial run that match the flavorName | ||
const savedFlavorConfigs = await _1.hasAssetBeenProcessed(icon, outputPath, flavorName, iconFlavor, type); | ||
if (savedFlavorConfigs && savedFlavorConfigs.length) { | ||
// Make flavors from the already written config | ||
savedFlavorConfigs.forEach(async (savedFlavorConfig) => { | ||
// Create new Flavor from the config we retrieved, so it's copied over | ||
// when the iconrc is written | ||
if (savedFlavorConfig.name) { | ||
icon.flavors.set(savedFlavorConfig.name, new _1.Flavor(outputPath, savedFlavorConfig)); | ||
} | ||
}); | ||
LOGGER.info(`${icon.iconName}'s ${flavorName} has been generated. Skipping that step. Turn hashing off if you don't want this.`); | ||
continue; | ||
} | ||
} | ||
await applySinglePluginOnAsset(iconFlavor, icon, plugin); | ||
} | ||
} | ||
exports.applyPluginOnAssets = applyPluginOnAssets; | ||
/** | ||
@@ -91,5 +122,10 @@ * This is the most basic plugin application function It applies one plugin on | ||
if (plugin.writeToOutput) { | ||
// This feature is incorrect when the plugin returns the same flavor with | ||
//appended as it needs to iterate over the types and print the content of | ||
//the type instead of the actual flavor. However, that won't be required if | ||
//we end up addressing this issue https://github.com/linkedin/icon-magic/issues/319 | ||
for (const outputFlavor of output) { | ||
if (outputFlavor.contents) { | ||
promises.push(files_1.saveContentToFile(path.join(icon.iconPath, 'tmp'), outputFlavor.name, outputFlavor.contents, 'svg')); | ||
const svgTypeFlavor = outputFlavor.types ? outputFlavor.types.get('svg') : null; | ||
if (svgTypeFlavor) { | ||
promises.push(files_1.saveContentToFile(path.join(icon.iconPath, 'tmp', plugin.name), svgTypeFlavor.name, await svgTypeFlavor.getContents(), 'svg')); | ||
} | ||
@@ -124,2 +160,2 @@ } | ||
exports.getAllPropCombinations = getAllPropCombinations; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-manager.js","sourceRoot":"","sources":["../../src/plugin-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from '@icon-magic/logger';\nimport * as path from 'path';\n\nimport { Asset } from './asset';\nimport { Flavor } from './flavor';\nimport { Icon } from './icon';\nimport { BuildPlugin, GeneratePlugin, Iterant } from './interface';\nimport { saveContentToFile } from './utils/files';\nimport { propCombinator } from './utils/prop-combinator';\nconst LOGGER = new Logger('icon-magic:icon-models:plugin-manager');\n\n/**\n * Applies the set of plugins on the given asset and returns all the\n * assets/flavors generated after applying the set of plugins. This function\n * calls applySinglePluginOnAsset and stores the output in a matrix It applies\n * the next plugin on all of the assets generated by the previous plugin\n * @param asset The asset on which to apply the set of plugins\n * @param icon The icon, to be passed into the plugin for reference and/or\n * metadata\n * @param plugins the list of plugins to be applied on this asset\n * @returns a promise with an array of all the assets generated by applying all\n * the plugins\n */\nexport async function applyPluginsOnAsset(\n  asset: Asset | Flavor,\n  icon: Icon,\n  plugins: BuildPlugin[] | GeneratePlugin[]\n): Promise<Flavor[]> {\n  // create a two dimensional matrix that stores the result of each plugin\n  const pluginResults: Flavor[][] = [];\n\n  // iterate over all the plugins, applying them one at a time\n  for (const [index, plugin] of plugins.entries()) {\n    pluginResults[index] = new Array();\n    LOGGER.debug(\n      `applyPluginsOnAsset: Applying ${plugin.name} on ${asset.name}`\n    );\n    // if it is the first plugin, then set the plugin input as the asset itself\n    // push the asset into an array as we iterate over it in the next step\n    const pluginInput: Flavor[] = pluginResults[index - 1] || new Array(asset);\n\n    // for each input asset, run the plugin and add the results to the matrix\n    for (const input of pluginInput) {\n      const output = await applySinglePluginOnAsset(\n        input,\n        icon,\n        plugin\n      );\n\n      pluginResults[index] = pluginResults[index].concat(output);\n    }\n  }\n  // return the contents of the last result\n  return pluginResults[plugins.length - 1];\n}\n\n/**\n * This is the most basic plugin application function It applies one plugin on\n * one asset, simple but... it needs to the plugin on all possible combinations\n * of the iterants Therefore, it checks the icon config for the following\n * 1) Iterants - are config properties over which this function iterates over\n *    and applies the plugin\n * 2) If it does not have any iterants, then the plugin function is applied on\n *    the asset itself\n * @param asset The asset on which the plugin needs to be applied\n * @param icon The icon containing the iterants\n * @param plugin The function that is applied on the asset\n * @returns A promise of containing all the\n */\nasync function applySinglePluginOnAsset(\n  asset: Asset | Flavor,\n  icon: Icon,\n  plugin: BuildPlugin | GeneratePlugin,\n): Promise<Flavor[]> {\n  let output: Flavor[] = new Array();\n  if (plugin.iterants) {\n    for (const propCombo of getAllPropCombinations(icon, plugin.iterants) ||\n      []) {\n      LOGGER.debug(\n        `applySinglePluginOnFlavor: Applying ${plugin.name} on ${asset.name} with`\n      );\n      let pluginOutput;\n      try {\n        pluginOutput = await plugin.fn.call(\n          icon,\n          asset,\n          icon,\n          Object.assign(plugin.params || {}, { propCombo: propCombo })\n        );\n      } catch (e) {\n        LOGGER.error(\n          `PluginError: Error while running ${plugin.name} on ${icon.iconPath}`\n        );\n        LOGGER.error(e);\n      }\n      if (pluginOutput) {\n        output = output.concat(pluginOutput);\n      }\n    }\n  } else {\n    // when the plugin does not have any or iterants\n    LOGGER.debug('Running the plugin without iterants');\n    let pluginOutput;\n    try {\n      pluginOutput = await plugin.fn.call(\n        icon,\n        asset,\n        icon,\n        plugin.params\n      );\n    } catch (e) {\n      LOGGER.error(\n        `PluginError: Error while running ${plugin.name} on ${icon.iconPath}`\n      );\n      LOGGER.error(e);\n    }\n    if (pluginOutput) {\n      output = output.concat(pluginOutput);\n    }\n  }\n\n  const promises = [];\n  if (plugin.writeToOutput) {\n    for (const outputFlavor of output) {\n      if (outputFlavor.contents) {\n        promises.push(\n          saveContentToFile(\n            path.join(icon.iconPath, 'tmp'),\n            outputFlavor.name,\n            outputFlavor.contents,\n            'svg'\n          )\n        );\n      }\n    }\n  }\n  await Promise.all(promises);\n  return output;\n}\n\n/**\n * A util to go through the icon, locate the iterants\n * @param icon the object containing the iterants\n * @param iterants the set of properties on the icon on whose values the plugin\n * needs to iterate\n * @returns an array of objects, where the keys are the iterant names and values\n * are iterant values\n */\nexport function getAllPropCombinations(icon: Icon, iterants: Iterant) {\n  const props = {};\n  for (const iterant of iterants) {\n    if (!icon.hasOwnProperty(iterant)) {\n      throw new Error(\n        `Could not find ${iterant} in the config file of ${icon.iconName}`\n      );\n    }\n    let iterantValues = icon[iterant];\n    if (!(iterantValues instanceof Array)) {\n      iterantValues = new Array(iterantValues);\n    }\n    props[iterant] = iterantValues;\n  }\n  return propCombinator(props);\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-manager.js","sourceRoot":"","sources":["../../src/plugin-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { Logger } from '@icon-magic/logger';\nimport * as path from 'path';\n\nimport { Asset, Flavor, FlavorConfig, Icon, hasAssetBeenProcessed } from '.';\nimport { BuildPlugin, GeneratePlugin, Iterant } from './interface';\nimport { saveContentToFile } from './utils/files';\nimport { propCombinator } from './utils/prop-combinator';\nconst LOGGER = new Logger('icon-magic:icon-models:plugin-manager');\n\n/**\n * Applies the set of plugins on the given asset and returns all the\n * assets/flavors generated after applying the set of plugins. This function\n * calls applySinglePluginOnAsset and stores the output in a matrix It applies\n * the next plugin on all of the assets generated by the previous plugin\n * @param asset The asset on which to apply the set of plugins\n * @param icon The icon, to be passed into the plugin for reference and/or\n * metadata\n * @param plugins the list of plugins to be applied on this asset\n * @returns a promise with an array of all the assets generated by applying all\n * the plugins\n */\nexport async function applyPluginsOnAsset(\n  asset: Asset | Flavor,\n  icon: Icon,\n  plugins: BuildPlugin[] | GeneratePlugin[]\n): Promise<Flavor[]> {\n  // create a two dimensional matrix that stores the result of each plugin\n  const pluginResults: Flavor[][] = [];\n\n  // iterate over all the plugins, applying them one at a time\n  for (const [index, plugin] of plugins.entries()) {\n    pluginResults[index] = new Array();\n    LOGGER.debug(\n      `applyPluginsOnAsset: Applying ${plugin.name} on ${asset.name}`\n    );\n    // if it is the first plugin, then set the plugin input as the asset itself\n    // push the asset into an array as we iterate over it in the next step\n    const pluginInput: Flavor[] = pluginResults[index - 1] || new Array(asset);\n\n    // for each input asset, run the plugin and add the results to the matrix\n    for (const input of pluginInput) {\n      const output = await applySinglePluginOnAsset(\n        input,\n        icon,\n        plugin\n      );\n\n      pluginResults[index] = pluginResults[index].concat(output);\n    }\n  }\n  // return the contents of the last result\n  return pluginResults[plugins.length - 1];\n}\n\nexport async function applyPluginOnAssets(icon: Icon, plugin: BuildPlugin | GeneratePlugin, type: RegExp, hashing: boolean) {\n  // make a deep clone of the flavors so it doesn't change if the plugin alters\n  //flavors on the icon\n  const originalFlavors = [...icon.flavors.values()];\n\n  // iterate over all the plugins, applying them one at a time\n  for (const iconFlavor of originalFlavors)  {\n\n    if (hashing) {\n      // Check if generate has been run on this flavor already\n      const flavorName: string = path.basename(iconFlavor.name);\n      // Create the output directory\n      const outputPath = icon.getIconOutputPath();\n      // Find the flavors in the config from the initial run that match the flavorName\n      const savedFlavorConfigs = await hasAssetBeenProcessed(\n        icon,\n        outputPath,\n        flavorName,\n        iconFlavor,\n        type\n      );\n\n      if (savedFlavorConfigs && savedFlavorConfigs.length) {\n        // Make flavors from the already written config\n        savedFlavorConfigs.forEach(\n          async (savedFlavorConfig: FlavorConfig) => {\n            // Create new Flavor from the config we retrieved, so it's copied over\n            // when the iconrc is written\n            if (savedFlavorConfig.name) {\n              icon.flavors.set(savedFlavorConfig.name, new Flavor(\n                outputPath,\n                savedFlavorConfig\n              ));\n            }\n          }\n        );\n        LOGGER.info(\n          `${icon.iconName}'s ${flavorName} has been generated. Skipping that step. Turn hashing off if you don't want this.`\n        );\n        continue;\n      }\n    }\n\n    await applySinglePluginOnAsset(\n      iconFlavor,\n      icon,\n      plugin\n    );\n  }\n}\n\n\n/**\n * This is the most basic plugin application function It applies one plugin on\n * one asset, simple but... it needs to the plugin on all possible combinations\n * of the iterants Therefore, it checks the icon config for the following\n * 1) Iterants - are config properties over which this function iterates over\n *    and applies the plugin\n * 2) If it does not have any iterants, then the plugin function is applied on\n *    the asset itself\n * @param asset The asset on which the plugin needs to be applied\n * @param icon The icon containing the iterants\n * @param plugin The function that is applied on the asset\n * @returns A promise of containing all the\n */\nasync function applySinglePluginOnAsset(\n  asset: Asset | Flavor,\n  icon: Icon,\n  plugin: BuildPlugin | GeneratePlugin,\n): Promise<Flavor[]> {\n  let output: Flavor[] = new Array();\n  if (plugin.iterants) {\n    for (const propCombo of getAllPropCombinations(icon, plugin.iterants) ||\n      []) {\n      LOGGER.debug(\n        `applySinglePluginOnFlavor: Applying ${plugin.name} on ${asset.name} with`\n      );\n      let pluginOutput;\n      try {\n        pluginOutput = await plugin.fn.call(\n          icon,\n          asset,\n          icon,\n          Object.assign(plugin.params || {}, { propCombo: propCombo })\n        );\n      } catch (e) {\n        LOGGER.error(\n          `PluginError: Error while running ${plugin.name} on ${icon.iconPath}`\n        );\n        LOGGER.error(e);\n      }\n      if (pluginOutput) {\n        output = output.concat(pluginOutput);\n      }\n    }\n  } else {\n    // when the plugin does not have any or iterants\n    LOGGER.debug('Running the plugin without iterants');\n    let pluginOutput;\n    try {\n      pluginOutput = await plugin.fn.call(\n        icon,\n        asset,\n        icon,\n        plugin.params\n      );\n    } catch (e) {\n      LOGGER.error(\n        `PluginError: Error while running ${plugin.name} on ${icon.iconPath}`\n      );\n      LOGGER.error(e);\n    }\n    if (pluginOutput) {\n      output = output.concat(pluginOutput);\n    }\n  }\n\n  const promises = [];\n  if (plugin.writeToOutput) {\n    // This feature is incorrect when the plugin returns the same flavor with\n    //appended as it needs to iterate over the types and print the content of\n    //the type instead of the actual flavor. However, that won't be required if\n    //we end up addressing this issue https://github.com/linkedin/icon-magic/issues/319\n    for (const outputFlavor of output) {\n      const svgTypeFlavor = outputFlavor.types ? outputFlavor.types.get('svg') : null;\n      if (svgTypeFlavor) {\n        promises.push(\n          saveContentToFile(\n            path.join(icon.iconPath, 'tmp', plugin.name),\n            svgTypeFlavor.name,\n            await svgTypeFlavor.getContents(),\n            'svg'\n          )\n        );\n      }\n    }\n  }\n  await Promise.all(promises);\n  return output;\n}\n\n/**\n * A util to go through the icon, locate the iterants\n * @param icon the object containing the iterants\n * @param iterants the set of properties on the icon on whose values the plugin\n * needs to iterate\n * @returns an array of objects, where the keys are the iterant names and values\n * are iterant values\n */\nexport function getAllPropCombinations(icon: Icon, iterants: Iterant) {\n  const props = {};\n  for (const iterant of iterants) {\n    if (!icon.hasOwnProperty(iterant)) {\n      throw new Error(\n        `Could not find ${iterant} in the config file of ${icon.iconName}`\n      );\n    }\n    let iterantValues = icon[iterant];\n    if (!(iterantValues instanceof Array)) {\n      iterantValues = new Array(iterantValues);\n    }\n    props[iterant] = iterantValues;\n  }\n  return propCombinator(props);\n}\n"]} |
/// <reference types="node" /> | ||
import { Flavor, FlavorConfig, Icon } from '..'; | ||
/** | ||
@@ -17,1 +18,11 @@ * Creates a hash from a string or Buffer | ||
export declare function compareAssetHashes(currentAssetHash: string | undefined, savedAssetHash: string | undefined): Promise<boolean>; | ||
/** | ||
* Checks the config to see if the asset has been generated before i.e if it is | ||
* saved in the config flavors. | ||
* @param outputPath the output path of the icon, where the output of generate would | ||
* be written to. | ||
* @param flavorName the name of the asset currently being processed in generate | ||
* @param flavor the asset currently being processed in generate | ||
* @returns the config of the saved asset, if present | ||
*/ | ||
export declare function hasAssetBeenProcessed(icon: Icon, outputPath: string, flavorName: string, flavor: Flavor, type: RegExp): Promise<FlavorConfig[] | null>; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.compareAssetHashes = exports.createHash = void 0; | ||
exports.hasAssetBeenProcessed = exports.compareAssetHashes = exports.createHash = void 0; | ||
const config_reader_1 = require("@icon-magic/config-reader"); | ||
const crypto = require("crypto"); | ||
const fs_1 = require("fs"); | ||
const path = require("path"); | ||
/** | ||
@@ -29,2 +32,54 @@ * Creates a hash from a string or Buffer | ||
exports.compareAssetHashes = compareAssetHashes; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9oYXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlDQUFpQztBQUVqQzs7OztHQUlHO0FBQ0gsU0FBZ0IsVUFBVSxDQUFDLFFBQXlCO0lBQ2xELE9BQU8sTUFBTTtTQUNWLFVBQVUsQ0FBQyxLQUFLLENBQUM7U0FDakIsTUFBTSxDQUFDLFFBQVEsQ0FBQztTQUNoQixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDbkIsQ0FBQztBQUxELGdDQUtDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNJLEtBQUssVUFBVSxrQkFBa0IsQ0FDdEMsZ0JBQW9DLEVBQ3BDLGNBQWtDO0lBRWxDLE9BQU8sQ0FBQyxDQUFDLGNBQWMsSUFBSSxnQkFBZ0IsS0FBSyxjQUFjLENBQUM7QUFDakUsQ0FBQztBQUxELGdEQUtDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgY3J5cHRvIGZyb20gJ2NyeXB0byc7XG5cbi8qKlxuICogQ3JlYXRlcyBhIGhhc2ggZnJvbSBhIHN0cmluZyBvciBCdWZmZXJcbiAqIEBwYXJhbSBjb250ZW50cyB0aGUgc3RyaW5nIG9yIEJ1ZmZlciB0byBjcmVhdGUgdGhlIGhhc2ggZnJvbVxuICogQHJldHVybnMgaGFzaCBvZiB0aGUgcGFzc2VkIGluIHN0cmluZyBvciBCdWZmZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUhhc2goY29udGVudHM6IHN0cmluZyB8IEJ1ZmZlcik6IHN0cmluZyB7XG4gIHJldHVybiBjcnlwdG9cbiAgICAuY3JlYXRlSGFzaCgnbWQ1JylcbiAgICAudXBkYXRlKGNvbnRlbnRzKVxuICAgIC5kaWdlc3QoJ2hleCcpO1xufVxuXG4vKipcbiAqIENoZWNrcyBpZiB0aGUgYHNvdXJjZUhhc2hgIG9mIHRoZSBzYXZlZCBhc3NldCBtYXRjaGVzIHRoZSBjb21wdXRlZCBoYXNoIG9mXG4gKiB0aGUgYXNzZXQgdGhhdCdzIGFib3V0IHRvIGJlIHRha2VuIHRocm91Z2ggdGhlIGdlbmVyYXRpb24gcHJvY2Vzcy5cbiAqIEBwYXJhbSBjdXJyZW50QXNzZXRIYXNoIHRoZSBoYXNoIG9mIGFzc2V0IGJlaW5nIHByb2Nlc3NlZCBpbiB0aGUgZ2VuZXJhdGUgc3RlcFxuICogQHBhcmFtIHNhdmVkQXNzZXRIYXNoIHRoZSBoYXNoIG9mIHRoZSBzYXZlZCBhc3NldCB0aGF0J3Mgd3JpdHRlbiB0byB0aGUgb3V0cHV0IHBhdGhcbiAqIEByZXR1cm5zIEEgcHJvbWlzZSB0aGF0IHJlc29sdmVzIHRvIGEgQm9vbGVhbiB3aGljaCBzdGF0ZXMgd2hldGhlciB0aGUgc2F2ZWQgYXNzZXQgYW5kIHRoZSBjdXJyZW50XG4gKiBhc3NldCBhcmUgdGhlIHNhbWUuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjb21wYXJlQXNzZXRIYXNoZXMoXG4gIGN1cnJlbnRBc3NldEhhc2g6IHN0cmluZyB8IHVuZGVmaW5lZCxcbiAgc2F2ZWRBc3NldEhhc2g6IHN0cmluZyB8IHVuZGVmaW5lZFxuKTogUHJvbWlzZTxib29sZWFuPiB7XG4gIHJldHVybiAhIXNhdmVkQXNzZXRIYXNoICYmIGN1cnJlbnRBc3NldEhhc2ggPT09IHNhdmVkQXNzZXRIYXNoO1xufVxuIl19 | ||
/** | ||
* Checks the config to see if the asset has been generated before i.e if it is | ||
* saved in the config flavors. | ||
* @param outputPath the output path of the icon, where the output of generate would | ||
* be written to. | ||
* @param flavorName the name of the asset currently being processed in generate | ||
* @param flavor the asset currently being processed in generate | ||
* @returns the config of the saved asset, if present | ||
*/ | ||
async function hasAssetBeenProcessed(icon, outputPath, flavorName, flavor, type) { | ||
try { | ||
// Try and open the config file in the output path | ||
const iconrc = await config_reader_1.loadConfigFile(path.join(outputPath, 'iconrc.json')); | ||
if (iconrc) { | ||
// Look for flavors in the config that matches the current flavor going through | ||
// the generation process | ||
const savedFlavorConfigs = iconrc['flavors'].filter((storedFlavor) => { | ||
// does the flavor name match | ||
const doesFlavorNameMatch = RegExp(`^${flavorName}\\b`).test(storedFlavor.name); | ||
const doFlavorTypesMatch = Object.keys(storedFlavor.types).every(flavType => { | ||
return flavType.match(type); | ||
}); | ||
return doesFlavorNameMatch && doFlavorTypesMatch; | ||
}); | ||
if (savedFlavorConfigs.length) { | ||
// Check if all the flavors in the config have hashes that match | ||
// the current flavor we are looking at | ||
let allFlavorsMatch = false; | ||
for (const config of savedFlavorConfigs) { | ||
// Check source (build output) | ||
const buildOutputPath = path.resolve(icon.getBuildOutputPath(), `${flavor.name}.svg`); | ||
const flavorContent = fs_1.readFileSync(buildOutputPath, 'utf8'); | ||
allFlavorsMatch = await compareAssetHashes(createHash(flavorContent), config.generateSourceHash); | ||
if (!allFlavorsMatch) { | ||
break; | ||
} | ||
} | ||
// Flavors (webp, png, minified svg) with the same source svg already exists, no need to run generate again | ||
if (allFlavorsMatch) { | ||
return savedFlavorConfigs; | ||
} | ||
} | ||
} | ||
} | ||
catch (e) { | ||
// If we get here then the icon has not been generated before, we don't have to | ||
// do anything, just let it generate | ||
return null; | ||
} | ||
return null; | ||
} | ||
exports.hasAssetBeenProcessed = hasAssetBeenProcessed; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGFzaC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9oYXNoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZEQUEyRDtBQUMzRCxpQ0FBaUM7QUFDakMsMkJBQWtDO0FBQ2xDLDZCQUE2QjtBQVE3Qjs7OztHQUlHO0FBQ0gsU0FBZ0IsVUFBVSxDQUFDLFFBQXlCO0lBQ2xELE9BQU8sTUFBTTtTQUNWLFVBQVUsQ0FBQyxLQUFLLENBQUM7U0FDakIsTUFBTSxDQUFDLFFBQVEsQ0FBQztTQUNoQixNQUFNLENBQUMsS0FBSyxDQUFDLENBQUM7QUFDbkIsQ0FBQztBQUxELGdDQUtDO0FBRUQ7Ozs7Ozs7R0FPRztBQUNJLEtBQUssVUFBVSxrQkFBa0IsQ0FDdEMsZ0JBQW9DLEVBQ3BDLGNBQWtDO0lBRWxDLE9BQU8sQ0FBQyxDQUFDLGNBQWMsSUFBSSxnQkFBZ0IsS0FBSyxjQUFjLENBQUM7QUFDakUsQ0FBQztBQUxELGdEQUtDO0FBRUQ7Ozs7Ozs7O0dBUUc7QUFDSyxLQUFLLFVBQVUscUJBQXFCLENBQzFDLElBQVUsRUFDVixVQUFrQixFQUNsQixVQUFrQixFQUNsQixNQUFjLEVBQ2QsSUFBWTtJQUVaLElBQUk7UUFDRixrREFBa0Q7UUFDbEQsTUFBTSxNQUFNLEdBQUcsTUFBTSw4QkFBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQyxDQUFDLENBQUM7UUFDMUUsSUFBSSxNQUFNLEVBQUU7WUFDViwrRUFBK0U7WUFDL0UseUJBQXlCO1lBQ3pCLE1BQU0sa0JBQWtCLEdBQW1CLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxNQUFNLENBQ2pFLENBQUMsWUFBb0IsRUFBRSxFQUFFO2dCQUN2Qiw2QkFBNkI7Z0JBQzdCLE1BQU0sbUJBQW1CLEdBQUcsTUFBTSxDQUFDLElBQUksVUFBVSxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQzFELFlBQVksQ0FBQyxJQUFJLENBQ2xCLENBQUM7Z0JBQ0YsTUFBTSxrQkFBa0IsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLENBQzlELFFBQVEsQ0FBQyxFQUFFO29CQUNULE9BQU8sUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDOUIsQ0FBQyxDQUNGLENBQUM7Z0JBQ0YsT0FBTyxtQkFBbUIsSUFBSSxrQkFBa0IsQ0FBQztZQUNuRCxDQUFDLENBQ0YsQ0FBQztZQUNGLElBQUksa0JBQWtCLENBQUMsTUFBTSxFQUFFO2dCQUM3QixnRUFBZ0U7Z0JBQ2hFLHVDQUF1QztnQkFDdkMsSUFBSSxlQUFlLEdBQUcsS0FBSyxDQUFDO2dCQUM1QixLQUFLLE1BQU0sTUFBTSxJQUFJLGtCQUFrQixFQUFFO29CQUN2Qyw4QkFBOEI7b0JBQzlCLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLEVBQUUsR0FBRyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsQ0FBQztvQkFDdEYsTUFBTSxhQUFhLEdBQUcsaUJBQVksQ0FBQyxlQUFlLEVBQUUsTUFBTSxDQUFDLENBQUM7b0JBQzVELGVBQWUsR0FBRyxNQUFNLGtCQUFrQixDQUN4QyxVQUFVLENBQUMsYUFBYSxDQUFDLEVBQ3pCLE1BQU0sQ0FBQyxrQkFBa0IsQ0FDMUIsQ0FBQztvQkFDRixJQUFJLENBQUMsZUFBZSxFQUFFO3dCQUNwQixNQUFNO3FCQUNQO2lCQUNGO2dCQUNELDJHQUEyRztnQkFDM0csSUFBSSxlQUFlLEVBQUU7b0JBQ25CLE9BQU8sa0JBQWtCLENBQUM7aUJBQzNCO2FBQ0Y7U0FDRjtLQUNGO0lBQUMsT0FBTyxDQUFDLEVBQUU7UUFDViwrRUFBK0U7UUFDL0Usb0NBQW9DO1FBQ3BDLE9BQU8sSUFBSSxDQUFDO0tBQ2I7SUFDRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUF2REEsc0RBdURBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgbG9hZENvbmZpZ0ZpbGUgfSBmcm9tICdAaWNvbi1tYWdpYy9jb25maWctcmVhZGVyJztcbmltcG9ydCAqIGFzIGNyeXB0byBmcm9tICdjcnlwdG8nO1xuaW1wb3J0IHsgcmVhZEZpbGVTeW5jIH0gZnJvbSAnZnMnO1xuaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtcbiAgRmxhdm9yLFxuICBGbGF2b3JDb25maWcsXG4gIEljb25cbn0gZnJvbSAnLi4nO1xuXG4vKipcbiAqIENyZWF0ZXMgYSBoYXNoIGZyb20gYSBzdHJpbmcgb3IgQnVmZmVyXG4gKiBAcGFyYW0gY29udGVudHMgdGhlIHN0cmluZyBvciBCdWZmZXIgdG8gY3JlYXRlIHRoZSBoYXNoIGZyb21cbiAqIEByZXR1cm5zIGhhc2ggb2YgdGhlIHBhc3NlZCBpbiBzdHJpbmcgb3IgQnVmZmVyXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVIYXNoKGNvbnRlbnRzOiBzdHJpbmcgfCBCdWZmZXIpOiBzdHJpbmcge1xuICByZXR1cm4gY3J5cHRvXG4gICAgLmNyZWF0ZUhhc2goJ21kNScpXG4gICAgLnVwZGF0ZShjb250ZW50cylcbiAgICAuZGlnZXN0KCdoZXgnKTtcbn1cblxuLyoqXG4gKiBDaGVja3MgaWYgdGhlIGBzb3VyY2VIYXNoYCBvZiB0aGUgc2F2ZWQgYXNzZXQgbWF0Y2hlcyB0aGUgY29tcHV0ZWQgaGFzaCBvZlxuICogdGhlIGFzc2V0IHRoYXQncyBhYm91dCB0byBiZSB0YWtlbiB0aHJvdWdoIHRoZSBnZW5lcmF0aW9uIHByb2Nlc3MuXG4gKiBAcGFyYW0gY3VycmVudEFzc2V0SGFzaCB0aGUgaGFzaCBvZiBhc3NldCBiZWluZyBwcm9jZXNzZWQgaW4gdGhlIGdlbmVyYXRlIHN0ZXBcbiAqIEBwYXJhbSBzYXZlZEFzc2V0SGFzaCB0aGUgaGFzaCBvZiB0aGUgc2F2ZWQgYXNzZXQgdGhhdCdzIHdyaXR0ZW4gdG8gdGhlIG91dHB1dCBwYXRoXG4gKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byBhIEJvb2xlYW4gd2hpY2ggc3RhdGVzIHdoZXRoZXIgdGhlIHNhdmVkIGFzc2V0IGFuZCB0aGUgY3VycmVudFxuICogYXNzZXQgYXJlIHRoZSBzYW1lLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY29tcGFyZUFzc2V0SGFzaGVzKFxuICBjdXJyZW50QXNzZXRIYXNoOiBzdHJpbmcgfCB1bmRlZmluZWQsXG4gIHNhdmVkQXNzZXRIYXNoOiBzdHJpbmcgfCB1bmRlZmluZWRcbik6IFByb21pc2U8Ym9vbGVhbj4ge1xuICByZXR1cm4gISFzYXZlZEFzc2V0SGFzaCAmJiBjdXJyZW50QXNzZXRIYXNoID09PSBzYXZlZEFzc2V0SGFzaDtcbn1cblxuLyoqXG4gKiBDaGVja3MgdGhlIGNvbmZpZyB0byBzZWUgaWYgdGhlIGFzc2V0IGhhcyBiZWVuIGdlbmVyYXRlZCBiZWZvcmUgaS5lIGlmIGl0IGlzXG4gKiBzYXZlZCBpbiB0aGUgY29uZmlnIGZsYXZvcnMuXG4gKiBAcGFyYW0gb3V0cHV0UGF0aCB0aGUgb3V0cHV0IHBhdGggb2YgdGhlIGljb24sIHdoZXJlIHRoZSBvdXRwdXQgb2YgZ2VuZXJhdGUgd291bGRcbiAqIGJlIHdyaXR0ZW4gdG8uXG4gKiBAcGFyYW0gZmxhdm9yTmFtZSB0aGUgbmFtZSBvZiB0aGUgYXNzZXQgY3VycmVudGx5IGJlaW5nIHByb2Nlc3NlZCBpbiBnZW5lcmF0ZVxuICogQHBhcmFtIGZsYXZvciB0aGUgYXNzZXQgY3VycmVudGx5IGJlaW5nIHByb2Nlc3NlZCBpbiBnZW5lcmF0ZVxuICogQHJldHVybnMgdGhlIGNvbmZpZyBvZiB0aGUgc2F2ZWQgYXNzZXQsIGlmIHByZXNlbnRcbiAqL1xuIGV4cG9ydCBhc3luYyBmdW5jdGlvbiBoYXNBc3NldEJlZW5Qcm9jZXNzZWQoXG4gIGljb246IEljb24sXG4gIG91dHB1dFBhdGg6IHN0cmluZyxcbiAgZmxhdm9yTmFtZTogc3RyaW5nLFxuICBmbGF2b3I6IEZsYXZvcixcbiAgdHlwZTogUmVnRXhwXG4pOiBQcm9taXNlPEZsYXZvckNvbmZpZ1tdIHwgbnVsbD4ge1xuICB0cnkge1xuICAgIC8vIFRyeSBhbmQgb3BlbiB0aGUgY29uZmlnIGZpbGUgaW4gdGhlIG91dHB1dCBwYXRoXG4gICAgY29uc3QgaWNvbnJjID0gYXdhaXQgbG9hZENvbmZpZ0ZpbGUocGF0aC5qb2luKG91dHB1dFBhdGgsICdpY29ucmMuanNvbicpKTtcbiAgICBpZiAoaWNvbnJjKSB7XG4gICAgICAvLyBMb29rIGZvciBmbGF2b3JzIGluIHRoZSBjb25maWcgdGhhdCBtYXRjaGVzIHRoZSBjdXJyZW50IGZsYXZvciBnb2luZyB0aHJvdWdoXG4gICAgICAvLyB0aGUgZ2VuZXJhdGlvbiBwcm9jZXNzXG4gICAgICBjb25zdCBzYXZlZEZsYXZvckNvbmZpZ3M6IEZsYXZvckNvbmZpZ1tdID0gaWNvbnJjWydmbGF2b3JzJ10uZmlsdGVyKFxuICAgICAgICAoc3RvcmVkRmxhdm9yOiBGbGF2b3IpID0+IHtcbiAgICAgICAgICAvLyBkb2VzIHRoZSBmbGF2b3IgbmFtZSBtYXRjaFxuICAgICAgICAgIGNvbnN0IGRvZXNGbGF2b3JOYW1lTWF0Y2ggPSBSZWdFeHAoYF4ke2ZsYXZvck5hbWV9XFxcXGJgKS50ZXN0KFxuICAgICAgICAgICAgc3RvcmVkRmxhdm9yLm5hbWVcbiAgICAgICAgICApO1xuICAgICAgICAgIGNvbnN0IGRvRmxhdm9yVHlwZXNNYXRjaCA9IE9iamVjdC5rZXlzKHN0b3JlZEZsYXZvci50eXBlcykuZXZlcnkoXG4gICAgICAgICAgICBmbGF2VHlwZSA9PiB7XG4gICAgICAgICAgICAgIHJldHVybiBmbGF2VHlwZS5tYXRjaCh0eXBlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICApO1xuICAgICAgICAgIHJldHVybiBkb2VzRmxhdm9yTmFtZU1hdGNoICYmIGRvRmxhdm9yVHlwZXNNYXRjaDtcbiAgICAgICAgfVxuICAgICAgKTtcbiAgICAgIGlmIChzYXZlZEZsYXZvckNvbmZpZ3MubGVuZ3RoKSB7XG4gICAgICAgIC8vIENoZWNrIGlmIGFsbCB0aGUgZmxhdm9ycyBpbiB0aGUgY29uZmlnIGhhdmUgaGFzaGVzIHRoYXQgbWF0Y2hcbiAgICAgICAgLy8gdGhlIGN1cnJlbnQgZmxhdm9yIHdlIGFyZSBsb29raW5nIGF0XG4gICAgICAgIGxldCBhbGxGbGF2b3JzTWF0Y2ggPSBmYWxzZTtcbiAgICAgICAgZm9yIChjb25zdCBjb25maWcgb2Ygc2F2ZWRGbGF2b3JDb25maWdzKSB7XG4gICAgICAgICAgLy8gQ2hlY2sgc291cmNlIChidWlsZCBvdXRwdXQpXG4gICAgICAgICAgY29uc3QgYnVpbGRPdXRwdXRQYXRoID0gcGF0aC5yZXNvbHZlKGljb24uZ2V0QnVpbGRPdXRwdXRQYXRoKCksIGAke2ZsYXZvci5uYW1lfS5zdmdgKTtcbiAgICAgICAgICBjb25zdCBmbGF2b3JDb250ZW50ID0gcmVhZEZpbGVTeW5jKGJ1aWxkT3V0cHV0UGF0aCwgJ3V0ZjgnKTtcbiAgICAgICAgICBhbGxGbGF2b3JzTWF0Y2ggPSBhd2FpdCBjb21wYXJlQXNzZXRIYXNoZXMoXG4gICAgICAgICAgICBjcmVhdGVIYXNoKGZsYXZvckNvbnRlbnQpLFxuICAgICAgICAgICAgY29uZmlnLmdlbmVyYXRlU291cmNlSGFzaFxuICAgICAgICAgICk7XG4gICAgICAgICAgaWYgKCFhbGxGbGF2b3JzTWF0Y2gpIHtcbiAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICAvLyBGbGF2b3JzICh3ZWJwLCBwbmcsIG1pbmlmaWVkIHN2Zykgd2l0aCB0aGUgc2FtZSBzb3VyY2Ugc3ZnIGFscmVhZHkgZXhpc3RzLCBubyBuZWVkIHRvIHJ1biBnZW5lcmF0ZSBhZ2FpblxuICAgICAgICBpZiAoYWxsRmxhdm9yc01hdGNoKSB7XG4gICAgICAgICAgcmV0dXJuIHNhdmVkRmxhdm9yQ29uZmlncztcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCAoZSkge1xuICAgIC8vIElmIHdlIGdldCBoZXJlIHRoZW4gdGhlIGljb24gaGFzIG5vdCBiZWVuIGdlbmVyYXRlZCBiZWZvcmUsIHdlIGRvbid0IGhhdmUgdG9cbiAgICAvLyBkbyBhbnl0aGluZywganVzdCBsZXQgaXQgZ2VuZXJhdGVcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuICByZXR1cm4gbnVsbDtcbn1cbiJdfQ== |
@@ -87,6 +87,2 @@ "use strict"; | ||
name: 'filled-a', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
"colorScheme": undefined, | ||
"imageset": undefined, | ||
types: sampleExt | ||
@@ -97,4 +93,2 @@ }, | ||
name: 'filled-b', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -105,4 +99,2 @@ }, | ||
name: 'someOtherName-a', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -113,4 +105,2 @@ }, | ||
name: 'someOtherName-b', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -131,2 +121,2 @@ } | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRlYWwtaWNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Rlc3QvaGVscGVycy9pZGVhbC1pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZCQUE2QjtBQUU3QixtQ0FVbUI7QUFDbkIscUVBQXVFO0FBRXZFLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxVQUFVLENBQUMsQ0FBQztBQUUvRSxNQUFNLFNBQVMsR0FBa0I7SUFDL0IsR0FBRyxFQUFFO1FBQ0gsSUFBSSxFQUFFLGNBQWM7UUFDcEIsSUFBSSxFQUFFLGdCQUFnQjtLQUN2QjtJQUNELEdBQUcsRUFBRTtRQUNILElBQUksRUFBRSxjQUFjO1FBQ3BCLElBQUksRUFBRSxnQkFBZ0I7S0FDdkI7SUFDRCxJQUFJLEVBQUU7UUFDSixJQUFJLEVBQUUsZUFBZTtRQUNyQixJQUFJLEVBQUUsaUJBQWlCO0tBQ3hCO0NBQ0YsQ0FBQztBQUVGLE1BQU0sWUFBWSxHQUFrQjtJQUNsQztRQUNFLElBQUksRUFBRSxJQUFJO1FBQ1YsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFZLEVBQUUsSUFBVSxFQUFFLE1BQWUsRUFBa0IsRUFBRTtZQUN0RSxPQUFPLElBQUksV0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQzlCLElBQUksRUFBRSxzQ0FBb0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQztnQkFDOUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUU7Z0JBQ3JCLFFBQVEsRUFBRSxJQUFJO2FBQ2YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNELFFBQVEsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUN6QixhQUFhLEVBQUUsSUFBSTtLQUNwQjtJQUNEO1FBQ0UsSUFBSSxFQUFFLElBQUk7UUFDVixFQUFFLEVBQUUsS0FBSyxFQUFF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Y2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBwYXRoIGZyb20gJ3BhdGgnO1xuXG5pbXBvcnQge1xuICBBc3NldCxcbiAgQXNzZXRDb25maWcsXG4gIEJ1aWxkQ29uZmlnLFxuICBCdWlsZFBsdWdpbixcbiAgRmxhdm9yQ29uZmlnLFxuICBGbGF2b3JUeXBlTWFwLFxuICBHZW5lcmF0ZUNvbmZpZyxcbiAgSWNvbixcbiAgSWNvbkNvbmZpZ1xufSBmcm9tICcuLi8uLi9zcmMnO1xuaW1wb3J0IHsgZ2V0TmFtZUZyb21Qcm9wQ29tYm8gfSBmcm9tICcuLi8uLi9zcmMvdXRpbHMvcHJvcC1jb21iaW5hdG9yJztcblxuY29uc3QgRklYVFVSRVMgPSBwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnLi4nLCAnLi4nLCAnLi4nLCAndGVzdCcsICdmaXh0dXJlcycpO1xuXG5jb25zdCBzYW1wbGVFeHQ6IEZsYXZvclR5cGVNYXAgPSB7XG4gIHN2Zzoge1xuICAgIG5hbWU6ICdmaWxsZWQtYS5zdmcnLFxuICAgIHBhdGg6ICcuL2ZpbGxlZC1hLnN2ZydcbiAgfSxcbiAgcG5nOiB7XG4gICAgbmFtZTogJ2ZpbGxlZC1hLnBuZycsXG4gICAgcGF0aDogJy4vZmlsbGVkLWEucG5nJ1xuICB9LFxuICB3ZWJwOiB7XG4gICAgbmFtZTogJ2ZpbGxlZC1hLndlYnAnLFxuICAgIHBhdGg6ICcuL2ZpbGxlZC1hLndlYnAnXG4gIH1cbn07XG5cbmNvbnN0IGJ1aWxkUGx1Z2luczogQnVpbGRQbHVnaW5bXSA9IFtcbiAge1xuICAgIG5hbWU6ICdwMScsXG4gICAgZm46IGFzeW5jIChhc3NldDogQXNzZXQsIGljb246IEljb24sIHBhcmFtcz86IG9iamVjdCk6IFByb21pc2U8QXNzZXQ+ID0+IHtcbiAgICAgIHJldHVybiBuZXcgQXNzZXQoaWNvbi5pY29uUGF0aCwge1xuICAgICAgICBuYW1lOiBnZXROYW1lRnJvbVByb3BDb21ibyhhc3NldC5uYW1lLCBwYXJhbXMpLFxuICAgICAgICBwYXRoOiBhc3NldC5nZXRQYXRoKCksXG4gICAgICAgIGNvbnRlbnRzOiAncDEnXG4gICAgICB9KTtcbiAgICB9LFxuICAgIGl0ZXJhbnRzOiBbJ3Jlc29sdXRpb25zJ10sXG4gICAgd3JpdGVUb091dHB1dDogdHJ1ZVxuICB9LFxuICB7XG4gICAgbmFtZTogJ3AyJyxcbiAgICBmbjogYXN5bmMgKGFzc2V0OiBBc3NldCwgaWNvbjogSWNvbiwgcGFyYW1zPzogb2JqZWN0KTogUHJvbWlzZTxBc3NldD4gPT4ge1xuICAgICAgcmV0dXJuIG5ldyBBc3NldChpY29uLmljb25QYXRoLCB7XG4gICAgICAgIG5hbWU6IGdldE5hbWVGcm9tUHJvcENvbWJvKGFzc2V0Lm5hbWUsIHBhcmFtcyksXG4gICAgICAgIHBhdGg6IGFzc2V0LmdldFBhdGgoKSxcbiAgICAgICAgY29udGVudHM6ICdwMidcbiAgICAgIH0pO1xuICAgIH0sXG4gICAgaXRlcmFudHM6IFsnc2l6ZXMnLCAncmVzb2x1dGlvbnMnXVxuICB9LFxuICB7XG4gICAgbmFtZTogJ3AzJyxcbiAgICBmbjogYXN5bmMgKGFzc2V0OiBBc3NldCwgaWNvbjogSWNvbiwgcGFyYW1zPzogb2JqZWN0KTogUHJvbWlzZTxBc3NldD4gPT4ge1xuICAgICAgcmV0dXJuIG5ldyBBc3NldChpY29uLmljb25QYXRoLCB7XG4gICAgICAgIG5hbWU6IGdldE5hbWVGcm9tUHJvcENvbWJvKGFzc2V0Lm5hbWUsIHBhcmFtcyksXG4gICAgICAgIHBhdGg6IGFzc2V0LmdldFBhdGgoKSxcbiAgICAgICAgY29udGVudHM6ICdwMydcbiAgICAgIH0pO1xuICAgIH0sXG4gICAgaXRlcmFudHM6IFsnc2l6ZXMnXVxuICB9XG5dO1xuXG5leHBvcnQgY29uc3QgZ2VuZXJhdGU6IEdlbmVyYXRlQ29uZmlnID0ge1xuICB0eXBlczogW1xuICAgIHtcbiAgICAgIG5hbWU6ICdzdmcnLFxuICAgICAgcGx1Z2luczogW11cbiAgICB9LFxuICAgIHtcbiAgICAgIG5hbWU6ICdyYXN0ZXInLFxuICAgICAgcGx1Z2luczogW11cbiAgICB9XG4gIF1cbn07XG5cbmV4cG9ydCBjb25zdCBidWlsZDogQnVpbGRDb25maWcgPSB7XG4gIHBsdWdpbnM6IGJ1aWxkUGx1Z2luc1xufTtcblxuZXhwb3J0IGNvbnN0IHZhcmlhbnRzOiBBc3NldENvbmZpZ1tdID0gW1xuICB7XG4gICAgcGF0aDogJy4vZmlsbGVkLnN2ZycsXG4gICAgbmFtZTogJ2ZpbGxlZCdcbiAgfSxcbiAge1xuICAgIHBhdGg6ICcuL291dGxpbmUuc3ZnJyxcbiAgICBuYW1lOiAnc29tZU90aGVyTmFtZSdcbiAgfVxuXTtcblxuZXhwb3J0IGNvbnN0IGZsYXZvcnM6IEZsYXZvckNvbmZpZ1tdID0gW1xuICB7XG4gICAgcGF0aDogJy4vZmlsbGVkLWEuc3ZnJyxcbiAgICBuYW1lOiAnZmlsbGVkLWEnLFxuICAgIGJ1aWxkU291cmNlSGFzaDogdW5kZWZpbmVkLFxuICAgIGdlbmVyYXRlU291cmNlSGFzaDogdW5kZWZpbmVkLFxuICAgIFwiY29sb3JTY2hlbWVcIjogdW5kZWZpbmVkLFxuICAgIFwiaW1hZ2VzZXRcIjogdW5kZWZpbmVkLFxuICAgIHR5cGVzOiBzYW1wbGVFeHRcbiAgfSxcbiAge1xuICAgIHBhdGg6ICcuL2ZpbGxlZC1iLnN2ZycsXG4gICAgbmFtZTogJ2ZpbGxlZC1iJyxcbiAgICBidWlsZFNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICBnZW5lcmF0ZVNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICB0eXBlczogc2FtcGxlRXh0XG4gIH0sXG4gIHtcbiAgICBwYXRoOiAnLi9zb21lT3RoZXJOYW1lLWEuc3ZnJyxcbiAgICBuYW1lOiAnc29tZU90aGVyTmFtZS1hJyxcbiAgICBidWlsZFNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICBnZW5lcmF0ZVNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICB0eXBlczogc2FtcGxlRXh0XG4gIH0sXG4gIHtcbiAgICBwYXRoOiAnLi9zb21lT3RoZXJOYW1lLWIuc3ZnJyxcbiAgICBuYW1lOiAnc29tZU90aGVyTmFtZS1iJyxcbiAgICBidWlsZFNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICBnZW5lcmF0ZVNvdXJjZUhhc2g6IHVuZGVmaW5lZCxcbiAgICB0eXBlczogc2FtcGxlRXh0XG4gIH1cbl07XG5cbmV4cG9ydCBjb25zdCBpZGVhbEljb246IEljb25Db25maWcgPSB7XG4gIGljb25QYXRoOiBgJHtGSVhUVVJFU30vbmF2LWljb25zL2hvbWVgLFxuICBpY29uTmFtZTogJ2hvbWUnLFxuICB2YXJpYW50czogdmFyaWFudHMsXG4gIGZsYXZvcnM6IGZsYXZvcnMsXG4gIG91dHB1dFBhdGg6ICcuL291dCcsXG4gIGJ1aWxkOiBidWlsZCxcbiAgZ2VuZXJhdGU6IGdlbmVyYXRlLFxuICBzaXplczogWzE2LCAyNF0sXG4gIHJlc29sdXRpb25zOiBbMSwgMl0sXG4gIHNvdXJjZUNvbmZpZ0ZpbGU6IGAke0ZJWFRVUkVTfS9uYXYtaWNvbnMvaWNvbnJjLmpzb25gXG59O1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWRlYWwtaWNvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Rlc3QvaGVscGVycy9pZGVhbC1pY29uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDZCQUE2QjtBQUU3QixtQ0FVbUI7QUFDbkIscUVBQXVFO0FBRXZFLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxVQUFVLENBQUMsQ0FBQztBQUUvRSxNQUFNLFNBQVMsR0FBa0I7SUFDL0IsR0FBRyxFQUFFO1FBQ0gsSUFBSSxFQUFFLGNBQWM7UUFDcEIsSUFBSSxFQUFFLGdCQUFnQjtLQUN2QjtJQUNELEdBQUcsRUFBRTtRQUNILElBQUksRUFBRSxjQUFjO1FBQ3BCLElBQUksRUFBRSxnQkFBZ0I7S0FDdkI7SUFDRCxJQUFJLEVBQUU7UUFDSixJQUFJLEVBQUUsZUFBZTtRQUNyQixJQUFJLEVBQUUsaUJBQWlCO0tBQ3hCO0NBQ0YsQ0FBQztBQUVGLE1BQU0sWUFBWSxHQUFrQjtJQUNsQztRQUNFLElBQUksRUFBRSxJQUFJO1FBQ1YsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFZLEVBQUUsSUFBVSxFQUFFLE1BQWUsRUFBa0IsRUFBRTtZQUN0RSxPQUFPLElBQUksV0FBSyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQzlCLElBQUksRUFBRSxzQ0FBb0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxFQUFFLE1BQU0sQ0FBQztnQkFDOUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUU7Z0JBQ3JCLFFBQVEsRUFBRSxJQUFJO2FBQ2YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNELFFBQVEsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUN6QixhQUFhLEVBQUUsSUFBSTtLQUNwQjtJQUNEO1FBQ0UsSUFBSSxFQUFFLElBQUk7UUFDVixFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQVksRUFBRSxJQUFVLEVBQUUsTUFBZSxFQUFrQixFQUFFO1lBQ3RFLE9BQU8sSUFBSSxXQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDOUIsSUFBSSxFQUFFLHNDQUFvQixDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDO2dCQUM5QyxJQUFJLEVBQUUsS0FBSyxDQUFDLE9BQU8sRUFBRTtnQkFDckIsUUFBUSxFQUFFLElBQUk7YUFDZixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsUUFBUSxFQUFFLENBQUMsT0FBTyxFQUFFLGFBQWEsQ0FBQztLQUNuQztJQUNEO1FBQ0UsSUFBSSxFQUFFLElBQUk7UUFDVixFQUFFLEVBQUUsS0FBSyxFQUFFLEtBQVksRUFBRSxJQUFVLEVBQUUsTUFBZSxFQUFrQixFQUFFO1lBQ3RFLE9BQU8sSUFBSSxXQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDOUIsSUFBSSxFQUFFLHNDQUFvQixDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsTUFBTSxDQUFDO2dCQUM5QyxJQUFJLEVBQUUsS0FBSyxDQUFDLE9BQU8sRUFBRTtnQkFDckIsUUFBUSxFQUFFLElBQUk7YUFDZixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDO0tBQ3BCO0NBQ0YsQ0FBQztBQUVXLFFBQUEsUUFBUSxHQUFtQjtJQUN0QyxLQUFLLEVBQUU7UUFDTDtZQUNFLElBQUksRUFBRSxLQUFLO1lBQ1gsT0FBTyxFQUFFLEVBQUU7U0FDWjtRQUNEO1lBQ0UsSUFBSSxFQUFFLFFBQVE7WUFDZCxPQUFPLEVBQUUsRUFBRTtTQUNaO0tBQ0Y7Q0FDRixDQUFDO0FBRVcsUUFBQSxLQUFLLEdBQWdCO0lBQ2hDLE9BQU8sRUFBRSxZQUFZO0NBQ3RCLENBQUM7QUFFVyxRQUFBLFFBQVEsR0FBa0I7SUFDckM7UUFDRSxJQUFJLEVBQUUsY0FBYztRQUNwQixJQUFJLEVBQUUsUUFBUTtLQUNmO0lBQ0Q7UUFDRSxJQUFJLEVBQUUsZUFBZTtRQUNyQixJQUFJLEVBQUUsZUFBZTtLQUN0QjtDQUNGLENBQUM7QUFFVyxRQUFBLE9BQU8sR0FBbUI7SUFDckM7UUFDRSxJQUFJLEVBQUUsZ0JBQWdCO1FBQ3RCLElBQUksRUFBRSxVQUFVO1FBQ2hCLEtBQUssRUFBRSxTQUFTO0tBQ2pCO0lBQ0Q7UUFDRSxJQUFJLEVBQUUsZ0JBQWdCO1FBQ3RCLElBQUksRUFBRSxVQUFVO1FBQ2hCLEtBQUssRUFBRSxTQUFTO0tBQ2pCO0lBQ0Q7UUFDRSxJQUFJLEVBQUUsdUJBQXVCO1FBQzdCLElBQUksRUFBRSxpQkFBaUI7UUFDdkIsS0FBSyxFQUFFLFNBQVM7S0FDakI7SUFDRDtRQUNFLElBQUksRUFBRSx1QkFBdUI7UUFDN0IsSUFBSSxFQUFFLGlCQUFpQjtRQUN2QixLQUFLLEVBQUUsU0FBUztLQUNqQjtDQUNGLENBQUM7QUFFVyxRQUFBLFNBQVMsR0FBZTtJQUNuQyxRQUFRLEVBQUUsR0FBRyxRQUFRLGlCQUFpQjtJQUN0QyxRQUFRLEVBQUUsTUFBTTtJQUNoQixRQUFRLEVBQUUsZ0JBQVE7SUFDbEIsT0FBTyxFQUFFLGVBQU87SUFDaEIsVUFBVSxFQUFFLE9BQU87SUFDbkIsS0FBSyxFQUFFLGFBQUs7SUFDWixRQUFRLEVBQUUsZ0JBQVE7SUFDbEIsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQztJQUNmLFdBQVcsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDbkIsZ0JBQWdCLEVBQUUsR0FBRyxRQUFRLHdCQUF3QjtDQUN0RCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgcGF0aCBmcm9tICdwYXRoJztcblxuaW1wb3J0IHtcbiAgQXNzZXQsXG4gIEFzc2V0Q29uZmlnLFxuICBCdWlsZENvbmZpZyxcbiAgQnVpbGRQbHVnaW4sXG4gIEZsYXZvckNvbmZpZyxcbiAgRmxhdm9yVHlwZU1hcCxcbiAgR2VuZXJhdGVDb25maWcsXG4gIEljb24sXG4gIEljb25Db25maWdcbn0gZnJvbSAnLi4vLi4vc3JjJztcbmltcG9ydCB7IGdldE5hbWVGcm9tUHJvcENvbWJvIH0gZnJvbSAnLi4vLi4vc3JjL3V0aWxzL3Byb3AtY29tYmluYXRvcic7XG5cbmNvbnN0IEZJWFRVUkVTID0gcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJy4uJywgJy4uJywgJy4uJywgJ3Rlc3QnLCAnZml4dHVyZXMnKTtcblxuY29uc3Qgc2FtcGxlRXh0OiBGbGF2b3JUeXBlTWFwID0ge1xuICBzdmc6IHtcbiAgICBuYW1lOiAnZmlsbGVkLWEuc3ZnJyxcbiAgICBwYXRoOiAnLi9maWxsZWQtYS5zdmcnXG4gIH0sXG4gIHBuZzoge1xuICAgIG5hbWU6ICdmaWxsZWQtYS5wbmcnLFxuICAgIHBhdGg6ICcuL2ZpbGxlZC1hLnBuZydcbiAgfSxcbiAgd2VicDoge1xuICAgIG5hbWU6ICdmaWxsZWQtYS53ZWJwJyxcbiAgICBwYXRoOiAnLi9maWxsZWQtYS53ZWJwJ1xuICB9XG59O1xuXG5jb25zdCBidWlsZFBsdWdpbnM6IEJ1aWxkUGx1Z2luW10gPSBbXG4gIHtcbiAgICBuYW1lOiAncDEnLFxuICAgIGZuOiBhc3luYyAoYXNzZXQ6IEFzc2V0LCBpY29uOiBJY29uLCBwYXJhbXM/OiBvYmplY3QpOiBQcm9taXNlPEFzc2V0PiA9PiB7XG4gICAgICByZXR1cm4gbmV3IEFzc2V0KGljb24uaWNvblBhdGgsIHtcbiAgICAgICAgbmFtZTogZ2V0TmFtZUZyb21Qcm9wQ29tYm8oYXNzZXQubmFtZSwgcGFyYW1zKSxcbiAgICAgICAgcGF0aDogYXNzZXQuZ2V0UGF0aCgpLFxuICAgICAgICBjb250ZW50czogJ3AxJ1xuICAgICAgfSk7XG4gICAgfSxcbiAgICBpdGVyYW50czogWydyZXNvbHV0aW9ucyddLFxuICAgIHdyaXRlVG9PdXRwdXQ6IHRydWVcbiAgfSxcbiAge1xuICAgIG5hbWU6ICdwMicsXG4gICAgZm46IGFzeW5jIChhc3NldDogQXNzZXQsIGljb246IEljb24sIHBhcmFtcz86IG9iamVjdCk6IFByb21pc2U8QXNzZXQ+ID0+IHtcbiAgICAgIHJldHVybiBuZXcgQXNzZXQoaWNvbi5pY29uUGF0aCwge1xuICAgICAgICBuYW1lOiBnZXROYW1lRnJvbVByb3BDb21ibyhhc3NldC5uYW1lLCBwYXJhbXMpLFxuICAgICAgICBwYXRoOiBhc3NldC5nZXRQYXRoKCksXG4gICAgICAgIGNvbnRlbnRzOiAncDInXG4gICAgICB9KTtcbiAgICB9LFxuICAgIGl0ZXJhbnRzOiBbJ3NpemVzJywgJ3Jlc29sdXRpb25zJ11cbiAgfSxcbiAge1xuICAgIG5hbWU6ICdwMycsXG4gICAgZm46IGFzeW5jIChhc3NldDogQXNzZXQsIGljb246IEljb24sIHBhcmFtcz86IG9iamVjdCk6IFByb21pc2U8QXNzZXQ+ID0+IHtcbiAgICAgIHJldHVybiBuZXcgQXNzZXQoaWNvbi5pY29uUGF0aCwge1xuICAgICAgICBuYW1lOiBnZXROYW1lRnJvbVByb3BDb21ibyhhc3NldC5uYW1lLCBwYXJhbXMpLFxuICAgICAgICBwYXRoOiBhc3NldC5nZXRQYXRoKCksXG4gICAgICAgIGNvbnRlbnRzOiAncDMnXG4gICAgICB9KTtcbiAgICB9LFxuICAgIGl0ZXJhbnRzOiBbJ3NpemVzJ11cbiAgfVxuXTtcblxuZXhwb3J0IGNvbnN0IGdlbmVyYXRlOiBHZW5lcmF0ZUNvbmZpZyA9IHtcbiAgdHlwZXM6IFtcbiAgICB7XG4gICAgICBuYW1lOiAnc3ZnJyxcbiAgICAgIHBsdWdpbnM6IFtdXG4gICAgfSxcbiAgICB7XG4gICAgICBuYW1lOiAncmFzdGVyJyxcbiAgICAgIHBsdWdpbnM6IFtdXG4gICAgfVxuICBdXG59O1xuXG5leHBvcnQgY29uc3QgYnVpbGQ6IEJ1aWxkQ29uZmlnID0ge1xuICBwbHVnaW5zOiBidWlsZFBsdWdpbnNcbn07XG5cbmV4cG9ydCBjb25zdCB2YXJpYW50czogQXNzZXRDb25maWdbXSA9IFtcbiAge1xuICAgIHBhdGg6ICcuL2ZpbGxlZC5zdmcnLFxuICAgIG5hbWU6ICdmaWxsZWQnXG4gIH0sXG4gIHtcbiAgICBwYXRoOiAnLi9vdXRsaW5lLnN2ZycsXG4gICAgbmFtZTogJ3NvbWVPdGhlck5hbWUnXG4gIH1cbl07XG5cbmV4cG9ydCBjb25zdCBmbGF2b3JzOiBGbGF2b3JDb25maWdbXSA9IFtcbiAge1xuICAgIHBhdGg6ICcuL2ZpbGxlZC1hLnN2ZycsXG4gICAgbmFtZTogJ2ZpbGxlZC1hJyxcbiAgICB0eXBlczogc2FtcGxlRXh0XG4gIH0sXG4gIHtcbiAgICBwYXRoOiAnLi9maWxsZWQtYi5zdmcnLFxuICAgIG5hbWU6ICdmaWxsZWQtYicsXG4gICAgdHlwZXM6IHNhbXBsZUV4dFxuICB9LFxuICB7XG4gICAgcGF0aDogJy4vc29tZU90aGVyTmFtZS1hLnN2ZycsXG4gICAgbmFtZTogJ3NvbWVPdGhlck5hbWUtYScsXG4gICAgdHlwZXM6IHNhbXBsZUV4dFxuICB9LFxuICB7XG4gICAgcGF0aDogJy4vc29tZU90aGVyTmFtZS1iLnN2ZycsXG4gICAgbmFtZTogJ3NvbWVPdGhlck5hbWUtYicsXG4gICAgdHlwZXM6IHNhbXBsZUV4dFxuICB9XG5dO1xuXG5leHBvcnQgY29uc3QgaWRlYWxJY29uOiBJY29uQ29uZmlnID0ge1xuICBpY29uUGF0aDogYCR7RklYVFVSRVN9L25hdi1pY29ucy9ob21lYCxcbiAgaWNvbk5hbWU6ICdob21lJyxcbiAgdmFyaWFudHM6IHZhcmlhbnRzLFxuICBmbGF2b3JzOiBmbGF2b3JzLFxuICBvdXRwdXRQYXRoOiAnLi9vdXQnLFxuICBidWlsZDogYnVpbGQsXG4gIGdlbmVyYXRlOiBnZW5lcmF0ZSxcbiAgc2l6ZXM6IFsxNiwgMjRdLFxuICByZXNvbHV0aW9uczogWzEsIDJdLFxuICBzb3VyY2VDb25maWdGaWxlOiBgJHtGSVhUVVJFU30vbmF2LWljb25zL2ljb25yYy5qc29uYFxufTtcbiJdfQ== |
{ | ||
"name": "@icon-magic/icon-models", | ||
"version": "2.5.0-beta.0", | ||
"version": "2.6.0-beta.0", | ||
"description": "Icon magic provides classes for the icon and iconSet", | ||
@@ -21,4 +21,5 @@ "main": "dist/src/index.js", | ||
"dependencies": { | ||
"@icon-magic/logger": "^2.3.0-beta.0" | ||
"@icon-magic/logger": "^2.3.0-beta.0", | ||
"@icon-magic/config-reader": "^2.3.0-beta.0" | ||
} | ||
} |
@@ -96,4 +96,4 @@ import { Logger } from '@icon-magic/logger'; | ||
} | ||
if (config.generateSourceHash) { | ||
this.generateSourceHash = config.generateSourceHash; | ||
if (this.generateSourceHash) { | ||
config.generateSourceHash = this.generateSourceHash; | ||
} | ||
@@ -100,0 +100,0 @@ if (this.imageset) { |
@@ -50,2 +50,19 @@ import * as path from 'path'; | ||
let flavorTypes; | ||
const config: FlavorConfig = { | ||
name: this.name, | ||
path: `./${path.relative(this.iconPath, this.getPath())}`, | ||
}; | ||
if (this.buildSourceHash) { | ||
config.buildSourceHash = this.buildSourceHash; | ||
} | ||
if (this.generateSourceHash) { | ||
config.generateSourceHash = this.generateSourceHash; | ||
} | ||
if (this.imageset) { | ||
config.imageset = this.imageset; | ||
} | ||
if (this.colorScheme) { | ||
config.colorScheme = this.colorScheme; | ||
} | ||
// return only flavor data | ||
@@ -57,13 +74,6 @@ if (this.types) { | ||
} | ||
config.types = flavorTypes; | ||
} | ||
return { | ||
name: this.name, | ||
path: `./${path.relative(this.iconPath, this.getPath())}`, | ||
buildSourceHash: this.buildSourceHash, | ||
generateSourceHash: this.generateSourceHash, | ||
imageset: this.imageset, | ||
colorScheme: this.colorScheme, | ||
types: flavorTypes | ||
}; | ||
return config; | ||
} | ||
} |
@@ -147,3 +147,3 @@ import { Logger } from '@icon-magic/logger'; | ||
iconPath: '.', // we assume that the config will be written to the icon directory itself | ||
variants: [], // by instantiaing variants to be an empty array | ||
variants: [], // by instantiating variants to be an empty array | ||
sourceConfigFile: path.relative(this.iconPath, this.sourceConfigFile), // again, we resolve this path w.r.t. the icon directory | ||
@@ -150,0 +150,0 @@ sizes: this.sizes, |
@@ -6,3 +6,3 @@ export { Asset } from './asset'; | ||
export { applyPluginsOnAsset } from './plugin-manager'; | ||
export { applyPluginsOnAsset, applyPluginOnAssets } from './plugin-manager'; | ||
export * from './interface'; | ||
@@ -9,0 +9,0 @@ |
@@ -28,2 +28,6 @@ import { Icon } from '.'; | ||
variantsToFilter: string[]; | ||
outputAsHbs: { | ||
imageHrefHelper?: string; | ||
pathToTheImageAsset?: string; | ||
}; | ||
} | ||
@@ -101,3 +105,3 @@ | ||
export interface DistributeConfig { | ||
variantsToFilter: string[]; | ||
variantsToFilter?: string[]; | ||
svg?: SVGOptions; | ||
@@ -104,0 +108,0 @@ webp?: WebpOptions; |
import { Logger } from '@icon-magic/logger'; | ||
import * as path from 'path'; | ||
import { Asset } from './asset'; | ||
import { Flavor } from './flavor'; | ||
import { Icon } from './icon'; | ||
import { Asset, Flavor, FlavorConfig, Icon, hasAssetBeenProcessed } from '.'; | ||
import { BuildPlugin, GeneratePlugin, Iterant } from './interface'; | ||
@@ -57,2 +55,54 @@ import { saveContentToFile } from './utils/files'; | ||
export async function applyPluginOnAssets(icon: Icon, plugin: BuildPlugin | GeneratePlugin, type: RegExp, hashing: boolean) { | ||
// make a deep clone of the flavors so it doesn't change if the plugin alters | ||
//flavors on the icon | ||
const originalFlavors = [...icon.flavors.values()]; | ||
// iterate over all the plugins, applying them one at a time | ||
for (const iconFlavor of originalFlavors) { | ||
if (hashing) { | ||
// Check if generate has been run on this flavor already | ||
const flavorName: string = path.basename(iconFlavor.name); | ||
// Create the output directory | ||
const outputPath = icon.getIconOutputPath(); | ||
// Find the flavors in the config from the initial run that match the flavorName | ||
const savedFlavorConfigs = await hasAssetBeenProcessed( | ||
icon, | ||
outputPath, | ||
flavorName, | ||
iconFlavor, | ||
type | ||
); | ||
if (savedFlavorConfigs && savedFlavorConfigs.length) { | ||
// Make flavors from the already written config | ||
savedFlavorConfigs.forEach( | ||
async (savedFlavorConfig: FlavorConfig) => { | ||
// Create new Flavor from the config we retrieved, so it's copied over | ||
// when the iconrc is written | ||
if (savedFlavorConfig.name) { | ||
icon.flavors.set(savedFlavorConfig.name, new Flavor( | ||
outputPath, | ||
savedFlavorConfig | ||
)); | ||
} | ||
} | ||
); | ||
LOGGER.info( | ||
`${icon.iconName}'s ${flavorName} has been generated. Skipping that step. Turn hashing off if you don't want this.` | ||
); | ||
continue; | ||
} | ||
} | ||
await applySinglePluginOnAsset( | ||
iconFlavor, | ||
icon, | ||
plugin | ||
); | ||
} | ||
} | ||
/** | ||
@@ -125,9 +175,14 @@ * This is the most basic plugin application function It applies one plugin on | ||
if (plugin.writeToOutput) { | ||
// This feature is incorrect when the plugin returns the same flavor with | ||
//appended as it needs to iterate over the types and print the content of | ||
//the type instead of the actual flavor. However, that won't be required if | ||
//we end up addressing this issue https://github.com/linkedin/icon-magic/issues/319 | ||
for (const outputFlavor of output) { | ||
if (outputFlavor.contents) { | ||
const svgTypeFlavor = outputFlavor.types ? outputFlavor.types.get('svg') : null; | ||
if (svgTypeFlavor) { | ||
promises.push( | ||
saveContentToFile( | ||
path.join(icon.iconPath, 'tmp'), | ||
outputFlavor.name, | ||
outputFlavor.contents, | ||
path.join(icon.iconPath, 'tmp', plugin.name), | ||
svgTypeFlavor.name, | ||
await svgTypeFlavor.getContents(), | ||
'svg' | ||
@@ -134,0 +189,0 @@ ) |
@@ -0,3 +1,12 @@ | ||
import { loadConfigFile } from '@icon-magic/config-reader'; | ||
import * as crypto from 'crypto'; | ||
import { readFileSync } from 'fs'; | ||
import * as path from 'path'; | ||
import { | ||
Flavor, | ||
FlavorConfig, | ||
Icon | ||
} from '..'; | ||
/** | ||
@@ -29,1 +38,67 @@ * Creates a hash from a string or Buffer | ||
} | ||
/** | ||
* Checks the config to see if the asset has been generated before i.e if it is | ||
* saved in the config flavors. | ||
* @param outputPath the output path of the icon, where the output of generate would | ||
* be written to. | ||
* @param flavorName the name of the asset currently being processed in generate | ||
* @param flavor the asset currently being processed in generate | ||
* @returns the config of the saved asset, if present | ||
*/ | ||
export async function hasAssetBeenProcessed( | ||
icon: Icon, | ||
outputPath: string, | ||
flavorName: string, | ||
flavor: Flavor, | ||
type: RegExp | ||
): Promise<FlavorConfig[] | null> { | ||
try { | ||
// Try and open the config file in the output path | ||
const iconrc = await loadConfigFile(path.join(outputPath, 'iconrc.json')); | ||
if (iconrc) { | ||
// Look for flavors in the config that matches the current flavor going through | ||
// the generation process | ||
const savedFlavorConfigs: FlavorConfig[] = iconrc['flavors'].filter( | ||
(storedFlavor: Flavor) => { | ||
// does the flavor name match | ||
const doesFlavorNameMatch = RegExp(`^${flavorName}\\b`).test( | ||
storedFlavor.name | ||
); | ||
const doFlavorTypesMatch = Object.keys(storedFlavor.types).every( | ||
flavType => { | ||
return flavType.match(type); | ||
} | ||
); | ||
return doesFlavorNameMatch && doFlavorTypesMatch; | ||
} | ||
); | ||
if (savedFlavorConfigs.length) { | ||
// Check if all the flavors in the config have hashes that match | ||
// the current flavor we are looking at | ||
let allFlavorsMatch = false; | ||
for (const config of savedFlavorConfigs) { | ||
// Check source (build output) | ||
const buildOutputPath = path.resolve(icon.getBuildOutputPath(), `${flavor.name}.svg`); | ||
const flavorContent = readFileSync(buildOutputPath, 'utf8'); | ||
allFlavorsMatch = await compareAssetHashes( | ||
createHash(flavorContent), | ||
config.generateSourceHash | ||
); | ||
if (!allFlavorsMatch) { | ||
break; | ||
} | ||
} | ||
// Flavors (webp, png, minified svg) with the same source svg already exists, no need to run generate again | ||
if (allFlavorsMatch) { | ||
return savedFlavorConfigs; | ||
} | ||
} | ||
} | ||
} catch (e) { | ||
// If we get here then the icon has not been generated before, we don't have to | ||
// do anything, just let it generate | ||
return null; | ||
} | ||
return null; | ||
} |
@@ -102,6 +102,2 @@ import * as path from 'path'; | ||
name: 'filled-a', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
"colorScheme": undefined, | ||
"imageset": undefined, | ||
types: sampleExt | ||
@@ -112,4 +108,2 @@ }, | ||
name: 'filled-b', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -120,4 +114,2 @@ }, | ||
name: 'someOtherName-a', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -128,4 +120,2 @@ }, | ||
name: 'someOtherName-b', | ||
buildSourceHash: undefined, | ||
generateSourceHash: undefined, | ||
types: sampleExt | ||
@@ -132,0 +122,0 @@ } |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Filesystem access
Supply chain riskAccesses the file system, and could potentially read sensitive data.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
2118291
2838
0
2
5
+ Added@icon-magic/config-reader@2.3.0-beta.0(transitive)
+ Added@icon-magic/icon-models@2.3.0-beta.0(transitive)
+ Added@types/glob@7.2.0(transitive)
+ Added@types/minimatch@5.1.2(transitive)
+ Added@types/node@22.10.10(transitive)
+ Addedajv@6.12.6(transitive)
+ Addedbalanced-match@1.0.2(transitive)
+ Addedbrace-expansion@1.1.11(transitive)
+ Addedcallsites@3.1.0(transitive)
+ Addedconcat-map@0.0.1(transitive)
+ Addedfast-deep-equal@3.1.3(transitive)
+ Addedfast-json-stable-stringify@2.1.0(transitive)
+ Addedfs.realpath@1.0.0(transitive)
+ Addedglob@7.2.3(transitive)
+ Addedimport-fresh@3.3.0(transitive)
+ Addedinflight@1.0.6(transitive)
+ Addedjson-schema-traverse@0.4.1(transitive)
+ Addedminimatch@3.1.2(transitive)
+ Addedonce@1.4.0(transitive)
+ Addedparent-module@1.0.1(transitive)
+ Addedpath-is-absolute@1.0.1(transitive)
+ Addedpunycode@2.3.1(transitive)
+ Addedresolve-from@4.0.0(transitive)
+ Addedundici-types@6.20.0(transitive)
+ Addeduri-js@4.4.1(transitive)
+ Addedwrappy@1.0.2(transitive)