X-Git-Url: http://git.ieval.ro/?a=blobdiff_plain;f=make_static.PL;h=100b6c2ca31c40f3c5fba2784859ac43c8f6e4a1;hb=c9dee86562251301d7ef25a3a1689a2d07723128;hp=a47df2d8511d289c6ca62eee73a9bd5fe06ccd69;hpb=8798626b0e96a4d1eb423f7f70ece78a2fcb4ae7;p=plack-app-gruntmaster.git diff --git a/make_static.PL b/make_static.PL index a47df2d..100b6c2 100644 --- a/make_static.PL +++ b/make_static.PL @@ -3,6 +3,7 @@ use v5.14; use warnings; use CSS::Minifier::XS qw//; +use CSS::SpriteMaker; use JavaScript::Minifier::XS qw//; use File::Slurp qw/read_file write_file/; @@ -10,6 +11,27 @@ use File::Slurp qw/read_file write_file/; mkdir 'static'; mkdir 'static/css'; +my $maker = Local::CSS::SpriteMaker->new( + css_class_prefix => 'logo-', + rc_override_classname => sub { + my ($name) = @_; + $name =~ s/-light/.logo-light/r; + } +); + +$maker->make_sprite( + source_images => ['logos/'], + target_file => 'static/logos.png', + add_extra_padding => 10, +); + +$maker->print_css( + filename => 'css/logos.css', + sprite_filename => 'https://static.mindcoding.ro/static/logos.png', +); + +system 'optipng', '-o7', '-zm1-9', 'static/logos.png'; + my $common_css; $common_css .= read_file $_ for ; for () { @@ -19,6 +41,34 @@ for () { write_file "static/css/$theme.css", CSS::Minifier::XS::minify $css; } -my $js; -$js .= read_file $_ for ; -write_file 'static/js.js', JavaScript::Minifier::XS::minify $js; +if (-f 'compiler.jar') { + system java => -jar => 'compiler.jar', qw,-O SIMPLE --create_source_map static/js.map --js_output_file static/js.js --language_in ECMASCRIPT5_STRICT --source_map_location_mapping js/|/static/js/,, ; + my $js = read_file 'static/js.js'; + write_file 'static/js.js', '//# sourceMappingURL=/static/js.map', "\n", $js; + system 'cp', '-rp', 'js', 'static/'; +} else { + my $js; + $js .= read_file $_ for ; + write_file 'static/js.js', JavaScript::Minifier::XS::minify $js; +} + +package + Local::CSS::SpriteMaker; + +use parent qw/CSS::SpriteMaker/; + +sub _get_stylesheet_string { + my $self = shift; + my @ret = split "\n", $self->SUPER::_get_stylesheet_string(@_); + shift @ret; + @ret = sort @ret; + unshift @ret, <