web-apps/build/sprites/Gruntfile.js
2022-10-18 19:20:32 +03:00

320 lines
12 KiB
JavaScript

module.exports = function (grunt, rootpathprefix) {
const sprite_name = 'iconssmall';
const sprite_name_big = 'iconsbig';
const sprite_name_huge = 'iconshuge';
const helpers = {
parselang: (name, options) => {
if (/\((\S+)\)$/.test(name)) {
let _match = /(.+)\((\S+)\)$/.exec(name);
return '[applang=' + _match[2] + '] ' + options.fn({name:_match[1]});
}
return options.fn({name:name});
},
half: num => {return num/2;},
scaled: (num, factor) => {return num / factor;}
};
const _prefix = rootpathprefix || '../../';
const configTemplate = opts => {
let _editor_res_root = `${_prefix}apps/${opts.editor}/main/resources`,
_common_res_root = `${_prefix}apps/common/main/resources`,
_scaled_path = `${opts.scale}/${opts.extpath ? opts.extpath : '.'}`;
return {
src: [`${_editor_res_root}/img/toolbar/${_scaled_path}/*.png`, `${_common_res_root}/img/toolbar/${_scaled_path}/*.png`],
dest: `${_editor_res_root}/img/${opts.scale != '1x' ? opts.spritename + '@' + opts.scale : opts.spritename}.png`,
destCss: `${_editor_res_root}/less/sprites/${opts.spritename}@${opts.scale}.less`,
cssTemplate: `${_common_res_root}/img/toolbar/${_scaled_path}/.css.handlebars`,
algorithm: 'top-down',
cssHandlebarsHelpers: helpers
};
};
grunt.initConfig({
sprite: {
'word-1x': configTemplate({
editor:'documenteditor',
spritename: sprite_name,
scale: '1x'
}),
'word-big-1x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_big,
scale: '1x',
extpath: 'big'
}),
'word-huge-1x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_huge,
scale: '1x',
extpath: 'huge'
}),
'word-2x': configTemplate({
editor:'documenteditor',
spritename: sprite_name,
scale: '2x'
}),
'word-big-2x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_big,
scale: '2x',
extpath: 'big'
}),
'word-huge-2x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_huge,
scale: '2x',
extpath: 'huge'
}),
'word1.25x': configTemplate({
editor:'documenteditor',
spritename: sprite_name,
scale: '1.25x'
}),
'word-big-1.25x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_big,
scale: '1.25x',
extpath: 'big'
}),
'word-huge-1.25x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_huge,
scale: '1.25x',
extpath: 'huge'
}),
'word1.5x': configTemplate({
editor:'documenteditor',
spritename: sprite_name,
scale: '1.5x'
}),
'word-big-1.5x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_big,
scale: '1.5x',
extpath: 'big'
}),
'word-huge-1.5x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_huge,
scale: '1.5x',
extpath: 'huge'
}),
'word1.75x': configTemplate({
editor:'documenteditor',
spritename: sprite_name,
scale: '1.75x'
}),
'word-big-1.75x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_big,
scale: '1.75x',
extpath: 'big'
}),
'word-huge-1.75x': configTemplate({
editor:'documenteditor',
spritename: sprite_name_huge,
scale: '1.75x',
extpath: 'huge'
}),
'slide-1x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name,
scale: '1x'
}),
'slide-big-1x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name_big,
scale: '1x',
extpath: 'big'
}),
'slide-2x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name,
scale: '2x'
}),
'slide-big-2x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name_big,
scale: '2x',
extpath: 'big'
}),
'slide-1.5x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name,
scale: '1.5x'
}),
'slide-big-1.5x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name_big,
scale: '1.5x',
extpath: 'big'
}),
'slide-1.25x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name,
scale: '1.25x'
}),
'slide-big-1.25x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name_big,
scale: '1.25x',
extpath: 'big'
}),
'slide-1.75x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name,
scale: '1.75x'
}),
'slide-big-1.75x': configTemplate({
editor:'presentationeditor',
spritename: sprite_name_big,
scale: '1.75x',
extpath: 'big'
}),
'cell-1x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name,
scale: '1x'
}),
'cell-big-1x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name_big,
scale: '1x',
extpath: 'big'
}),
'cell-2x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name,
scale: '2x'
}),
'cell-big-2x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name_big,
scale: '2x',
extpath: 'big'
}),
'cell-1.5x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name,
scale: '1.5x'
}),
'cell-big-1.5x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name_big,
scale: '1.5x',
extpath: 'big'
}),
'cell-1.25x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name,
scale: '1.25x'
}),
'cell-big-1.25x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name_big,
scale: '1.25x',
extpath: 'big'
}),
'cell-1.75x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name,
scale: '1.75x'
}),
'cell-big-1.75x': configTemplate({
editor:'spreadsheeteditor',
spritename: sprite_name_big,
scale: '1.75x',
extpath: 'big'
}),
},
svg_sprite: {
options: {
svg: {
rootAttributes: {
//xmlns:'http://www.w3.org/2000/svg',
},
},
shape: {
transform: [{
svgo: {
plugins: [
'removeXMLNS',
{
name: "removeAttrs",
params: {
attrs: "(fill|stroke)"
}
},
]
},
}]
},
mode: {
symbol: {
},
},
},
deiconssmall: {
src: [`${_prefix}apps/common/main/resources/img/toolbar/2.5x/*.svg`],
dest: `${_prefix}apps/documenteditor/main/resources/img/`,
options: {
mode: {
symbol: {
inline: true,
dest: './',
sprite: `iconssmall@2.5x.svg`,
},
},
}
},
deiconsbig: {
src: [`${_prefix}apps/common/main/resources/img/toolbar/2.5x/big/*.svg`],
dest: `${_prefix}apps/documenteditor/main/resources/img/`,
options: {
mode: {
symbol: {
inline: true,
dest: './',
sprite: `iconsbig@2.5x.svg`,
},
},
}
},
},
});
// Load in `grunt-spritesmith`
grunt.loadNpmTasks('grunt-spritesmith');
grunt.loadNpmTasks('grunt-svg-sprite');
grunt.registerTask('word-icons', ['sprite:word-1x', 'sprite:word-big-1x', 'sprite:word-huge-1x', 'sprite:word-2x', 'sprite:word-big-2x', 'sprite:word-huge-2x',
'sprite:word1.25x', 'sprite:word-big-1.25x', 'sprite:word-huge-1.25x',
'sprite:word1.5x', 'sprite:word-big-1.5x', 'sprite:word-huge-1.5x',
'sprite:word1.75x', 'sprite:word-big-1.75x', 'sprite:word-huge-1.75x']);
grunt.registerTask('slide-icons', ['sprite:slide-1x', 'sprite:slide-big-1x','sprite:slide-2x', 'sprite:slide-big-2x',
'sprite:slide-1.5x', 'sprite:slide-big-1.5x',
'sprite:slide-1.25x', 'sprite:slide-big-1.25x',
'sprite:slide-1.75x', 'sprite:slide-big-1.75x']);
grunt.registerTask('cell-icons', ['sprite:cell-1x', 'sprite:cell-big-1x','sprite:cell-2x', 'sprite:cell-big-2x',
'sprite:cell-1.5x', 'sprite:cell-big-1.5x',
'sprite:cell-1.25x', 'sprite:cell-big-1.25x',
'sprite:cell-1.75x', 'sprite:cell-big-1.75x']);
grunt.registerTask('all-icons-sprite', ['word-icons','slide-icons','cell-icons','svg_sprite']);
grunt.registerTask('default', ['all-icons-sprite']);
};