summaryrefslogtreecommitdiffstats
path: root/admin/survey/minify/vendor/tubalmartin/cssmin/gui/scripts.js
blob: e4d06ff274d6b7fb2ff3f94f4038a71c3e56daae (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
$(function(){

    var inputCss = $('#input-css')
      ,	outputCss = $('#output-css')
      ,	outputContainer = $('#output-container')
      , originalSize = $('#original-size')
      , compressedSize = $('#compressed-size')
      , bytesSaved = $('#bytes-saved')
      , compressionRatio = $('#compression-ratio')
      ,	compressBtn = $('#compress-btn')
      ,	lessConsole = $('#less-error-message')

        /**
         * Prints LESS compilation errors
         */
      ,	lessError = function(e) {
            var content, errorline
              ,	template = '<li><label>{line}</label><pre class="{class}">{content}</pre></li>'
              , error = [];

            content = '<h3>'  + (e.type || "Syntax") + "Error: " + (e.message || 'There is an error in your .less file') +
                      '</h3>' + '<p>';

            errorline = function (e, i, classname) {
                if (e.extract[i] != undefined) {
                    error.push(template.replace(/\{line\}/, (parseInt(e.line) || 0) + (i - 1))
                                       .replace(/\{class\}/, classname)
                                       .replace(/\{content\}/, e.extract[i]));
                }
            };

            if (e.stack) {
                content += '<br/>' + e.stack.split('\n').slice(1).join('<br/>');
            } else if (e.extract) {
                errorline(e, 0, '');
                errorline(e, 1, 'line');
                errorline(e, 2, '');
                content += 'on line ' + e.line + ', column ' + (e.column + 1) + ':</p>' +
                            '<ul>' + error.join('') + '</ul>';
            }

            lessConsole.html(content).slideDown('fast');
      }

        /**
         * Compresses user's CSS with the PHP port of the YUI compressor
         */
      , compress = function(formData) {
            $.post(window.location.href, formData, function(data, textStatus, jqXHR){
                // Hide LESS error console
                lessConsole.slideUp('fast');

                // Fill output & show
                outputCss.val(data.css);
                originalSize.html(data.originalSize);
                compressedSize.html(data.compressedSize);
                bytesSaved.html(data.bytesSaved);
                compressionRatio.html(data.compressionRatio);

                outputContainer.slideDown('fast');

                // Restore button state
                compressBtn.button('reset');
            }, 'json');
      };



    /**
     * Controller
     */
    $('#options-form').on('submit', function(e){
        e && e.preventDefault();

        var data = {
            css: inputCss.val(),
            options: $(this).serialize()
        };

        // Change button state
        compressBtn.button('loading');

        // If LESS enabled, precompile CSS with LESS and then compress
        if (!!$('#enable-less:checked').val()) {
            try {
              new(less.Parser)().parse(data.css, function (err, tree) {
                  if (err) {
                      lessError(err);
                      compressBtn.button('reset');
                  } else {
                      data.css = tree.toCSS();
                      compress(data);
                  }
              });
            } catch (err) {
              lessError(err);
              compressBtn.button('reset');
            }
        } else {
            compress(data);
        }
    });

});