Edit in JSFiddle

define("func", function() {
  return {
    data: {
      form: function($, res, src, reaction) { // "jquery", 'data/result', 'data/source', 'helpers/reactions'
        return function(id, otherObjs) {
          var ret = {
            form: $('#' + id),
            source: src(id),
            result: res(id),
            'reactions': new reaction('#' + id)
          };
          if (otherObjs) {
            for (var x in otherObjs) {
              ret[x] = otherObjs[x];
            }
          }
          return ret;
        }
      },
      result: function($) {
        return function(id) {
          return $('#' + id + ' [name=result]');
        }
      },
      source: function($) {
        return function(id) {
          return $('#' + id + ' [name=source], #' + id + ' [name="source[]"]');
        }
      }
    },
    helpers: {
      init_canvas: function($) {
        $('[data-role="canvas"]').each(function() {
          var canvas = $('<canvas></canvas>'),
            obj = $(this);
          canvas.attr(obj.data());
          obj.replaceWith(canvas);
        });
      },
      loading: function($) {
        return function(parent_id) {
          var parent = $('#' + parent_id);
          var progress = $('<div><div><span class="glyphicon glyphicon-refresh refresh-animate" data-role="animation"></span> <span data-role="msg">Apdorojama...</span></div></div>');
          progress.hide();
          progress.msg = function(msg) {
            $('[data-role="msg"]', progress).html(msg);
          };
          progress.start = function(msg) {
            if (msg) {
              progress.msg(msg);
            }
            progress.show();
            parent.hide();
          };
          progress.stop = function() {
            parent.show();
            progress.hide();
          };
          parent.after(progress);
          return progress;
        };
      },
      reactions: function($) {
        return function(owner) {
          var obj = $(owner);
          this.error = function(error) {
            if (!error.split) {
              return;
            }
            var prefix = 'error' + error.split('-').map(function(txt) {
              return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();
            }).join('');
            switch (obj.data(prefix + 'Action')) {
              case 'alert':
                alert(obj.data(prefix + 'Msg'));
                break;
              case 'show':
                $(obj.data(prefix + 'Target')).show();
                break;
            }
          };
        };
      },
      readImageFromField: function($, when) { // 'jquery', 'when'
        return function(field, minWidth, minHeight) {
          field = $(field);
          return when.promise(function(resolve, reject, notify) {
            if (typeof(field.get(0).files) == 'undefined') {
              reject('old-browser');
              $(field).val('');
            } else {
              var file = field.get(0).files[0];
              var fr = new FileReader();
              fr.onload = function() {
                image = new Image();
                image.onerror = function() {
                  reject('cant-read-image');
                  $(field).val('');
                };
                image.onload = function() {
                  if (image.width < minWidth) {
                    reject('image-width-too-small');
                    $(field).val('');
                  } else if (image.height < minHeight) {
                    reject('image-height-too-small');
                    $(field).val('');
                  } else {
                    resolve(image);
                  }
                };
                image.src = fr.result;
              };
              try {
                fr.readAsDataURL(file);
              } catch (ex) {
                reject(ex);
                $(field).val('');
              }
            }
          });
          /*.catch(function (e) {
          					$(field).val('');
          				});*/
        }
      }
    },
    draw: {
      drawGradientBar: function() {
        return function(context, x1, y1, x2, y2, color1, color2) {
          var grd = context.createLinearGradient(0, y1, 0, y2);
          grd.addColorStop(0, color1);
          grd.addColorStop(1, color2);

          context.fillStyle = grd;
          context.fillRect(x1, y1, x2 - x1, y2 - y1);
        };
      },
      drawTransparentBackground: function() {
        return function(context, width, height, stepSize) {
          var grey = false;
          for (var x = 0; x < width; x += stepSize) {
            for (var y = 0; y < height; y += stepSize) {
              if (!(grey = !grey))
                continue;
              context.fillRect(x, y, stepSize, stepSize);
            }
            grey = !grey;
          }
        };
      },
      outlineText: function(strokeText, rgba) { // 'draw/strokeText', 'draw/rgba'
        return function(context, text, x, y, lineWidth, red, green, blue) {
          for (var i = lineWidth; i > 0; i--)
            strokeText(context, text, x, y, i, rgba(red, green, blue, 1.1 - (1 / lineWidth) * i));
        };
      },
      rgba: function() {
        return function(red, green, blue, alpha) {
          return "rgba(" + red + "," + green + "," + blue + "," + alpha + ")";
        }
      },
      setImageSmoothingEnabled: function() {
        return function(enabled) {
          this.imageSmoothingEnabled = enabled;
          this.mozImageSmoothingEnabled = enabled;
        };
      },
      strokeText: function() {
        return function(context, text, x, y, lineWidth, color) {
          context.strokeStyle = color;
          context.lineWidth = lineWidth;
          context.strokeText(text, x, y);
        };
      }
    },
    images: {
      gamersgate: function() {
        var img = new Image();
        img.src = '';
        return img;
      },
      made_in_lithuania: function() {
        var img = new Image();
        img.src = '';
        return img;
      }
    },
    behaviors: {
      move: function() {
        return function(obj) {
          obj = $(obj);
          obj.data({
            x: 0,
            y: 0
          });
          var bg_pos = {
            sx: 0,
            sy: 0
          };
          var dragmode = false;
          obj.bind({
            mousedown: function(event) {
              obj.css('cursor', 'move');
              bg_pos.sx = event.clientX;
              bg_pos.sy = event.clientY;
              dragmode = true;
              obj.trigger('movedStarted');
            },
            mouseup: function(event) {
              obj.css('cursor', 'default');
              dragmode = false;
              obj.trigger('moveFinished');
            },
            mousemove: function(event) {
              if (!dragmode)
                return;
              obj.data('x', obj.data('x') - (bg_pos.sx - event.clientX));
              obj.data('y', obj.data('y') - (bg_pos.sy - event.clientY));
              bg_pos.sx = event.clientX;
              bg_pos.sy = event.clientY;
              obj.trigger('moved');
            }
          });
        };
      },
      zoom: function($, mouseWheel) { // 'jquery', 'jquery.mousewheel'
        return function(obj, zoomLvl) {
          obj = $(obj);
          obj.data('zoom', zoomLvl);
          obj.mousewheel(function(event) {
            obj.data('zoom', obj.data('zoom') + event.deltaY);
            if (obj.data('zoom') < 1) {
              obj.data('zoom', 1);
            }
            event.preventDefault();
            obj.trigger('zoom');
          });
        }
      }
    }
  };
});

define("main", function() {

  // main

  return function(
    $,
    jForm,
    loading,
    init_canvas,
    download,
    img_gamersgate,
    img_made_in_lithuania,
    draw_gradient_bar,
    strokeText,
    outlineText,
    transparentBackgroundDraw,
    readImageFromField,
    imageSmoothingEnabled,
    behaviorMove,
    behaviorZoom
  ) {

    var form = jForm('tool', {
        banner_type: $('#banner_type'),
        game_name: $('#game_name'),
        game_platform: $('#game_platform'),
        banner: $('#banner'),
        game_flag: $('#game_flag'),
        game_image_size: $('#game_image_size')
      }),
      context = form.banner.get(0).getContext("2d"),
      image = {
        box: null,
        background: null,
        gamersgate: img_gamersgate,
        made_in_lithuania: img_made_in_lithuania
      },
      getCaption = function() {
        var caption = form.banner_type.val().toUpperCase(),
          gn = form.game_name.val();
        if (gn) {
          caption += ' | ' + gn;
        }
        var platform = form.game_platform.val()
        if (platform != 'PC')
          caption += ' (' + platform + ')';
        return caption;
      }

    imageSmoothingEnabled(context);

    var redraw = function(options) {
      if (!options) {
        options = {};
      }

      var caption = getCaption();

      context.clearRect(0, 0, 625, 190);
      context.fillStyle = "#BFBFBF";

      if (!options.noTransparent) {
        transparentBackgroundDraw(context, 625, 190, 7);
      }

      if (image.background)
        context.drawImage(
          image.background,
          form.banner.data('x'),
          form.banner.data('y'),
          image.background.width * form.banner.data('zoom') / 100,
          image.background.height * form.banner.data('zoom') / 100
        );

      if (image[form.game_flag.val()]) {
        context.drawImage(
          image[form.game_flag.val()],
          0,
          0
        );
      }

      draw_gradient_bar(context, 0, 190 - 32, 625, 190 - (32 - 12), "#D9DAD5", "#D7D9D4");
      draw_gradient_bar(context, 0, 190 - (32 - 12), 625, 190, "#D7D9D4", "#B1B6B0");

      var active_width = 625;
      if (image.box) {
        switch (form.game_platform.val()) {
          case 'Android':
          case 'iOS':
            active_width -= 190 / 1.79 - (190 / 2.21 - 190 / 1.89);
            break;
          default:
            var ih = (image.box.height > 190) ? 190 : image.box.height;
            var iw = image.box.width / (image.box.height / 190);
            active_width -= iw;
            break;
        }
      }

      context.font = "19px Verdana";

      var textX = (active_width - context.measureText(caption).width) / 2;
      var textY = 190 - (32 - 19) / 1.6;

      outlineText(context, caption, textX, textY, 5, 255, 255, 255);

      context.fillStyle = 'black';
      context.fillText(caption, textX, textY);

      context.fill();
      context.stroke();

      if (image.box) {
        context.shadowColor = 'black';
        context.shadowBlur = 10;
        context.shadowOffsetX = 0;
        context.shadowOffsetY = 0;
        switch (form.game_platform.val()) {
          case 'Android':
          case 'iOS':
            context.drawImage(
              image.box,
              625 - 190 / 1.79,
              190 - 190 / 1.89,
              190 / 2.21,
              190 / 2.21
            );
            break;
          default:
            context.drawImage(
              image.box,
              625 - iw,
              0,
              iw,
              ih
            );
            break;
        }
        context.shadowBlur = 0;
      }

    };
    form.game_image_size.change(function() {
      var val = parseInt($(this).val());
      if (val < 1) {
        val = 1;
        $(this).val(1);
      }
      form.banner.data('zoom', val);
    });
    $('select, input', form.form).bind({
      change: redraw,
      keyup: redraw
    });

    behaviorZoom(form.banner, parseInt(form.game_image_size.val()));
    behaviorMove(form.banner);
    form.banner.bind({
      'moved': redraw,
      'zoom': function() {
        form.game_image_size.val(form.banner.data('zoom'));
        redraw();
      }
    });

    $('[data-role="changeImage"]', form.form).change(function() {
      var obj = $(this);
      readImageFromField(obj, obj.data('width'), obj.data('height')).catch(
        function(error) {
          form.reactions.error(error);
          image[obj.data('key')] = null;
          redraw();
        }).then(function(result) {
        if (typeof result == 'undefined') {
          return;
        }
        image[obj.data('key')] = result;
        redraw();
      });
    });

    form.form.bind({
      submit: function(e) {
        e.preventDefault();

        var filename = form.banner_type.val().toUpperCase(),
          gn = form.game_name.val();
        if (gn) {
          filename += ' - ' + gn;
        }
        filename += ' (' + form.game_platform.val() + ').png';

        redraw({
          noTransparent: true
        });
        var data = form.banner.get(0).toDataURL("image/png");
        redraw();

        download(data, filename, "image/png");
      },
      reset: function() {
        image.box = null;
        image.background = null;
        form.banner.data({
          x: 0,
          y: 0,
          zoom: 100
        });
        redraw();
      }
    });

    $('[data-role="changeImage"]', form.form).change();

  };

});

require.config({
    baseUrl: 'https://cdn.rawgit.com/cujojs/when/3.7.7/',
    paths: {
        
    }
});
require(["main", "func", 'when', 'https://cdn.rawgit.com/rndme/download/v1.4.6/download.js'], function(main, func, when, download) {

  main(
    $, // jquery
    func.data.form($, func.data.result($), func.data.source($), func.helpers.reactions($)), // data/form
    func.helpers.loading($), // helpers/loading
    func.helpers.init_canvas($), // helpers/init_canvas
    download, // download
    func.images.gamersgate(), // images/gamersgate
    func.images.made_in_lithuania(), // images/made_in_lithuania
    func.draw.drawGradientBar(), //'draw/drawGradientBar',
    func.draw.strokeText(), //'draw/strokeText',
    func.draw.outlineText(func.draw.strokeText(), func.draw.rgba()), //'draw/outlineText',
    func.draw.drawTransparentBackground(), //'draw/drawTransparentBackground',
    func.helpers.readImageFromField($, when), //'helpers/readImageFromField',
    func.draw.setImageSmoothingEnabled(), //'draw/setImageSmoothingEnabled',
    func.behaviors.move(), //'behaviors/move',
    func.behaviors.zoom($) //'behaviors/zoom'
  );
});
<div class="container">
  <h3><a href="#" rel="bookmark" title="Permanent Link to Didelių banerių kūrėjas (Games.lt 2008 metų dizaino stiliumi)">Didelių banerių kūrėjas (Games.lt 2008 metų dizaino stiliumi)</a></h3>

  <div class="full-post-content">
    <p>Šis banerių kūrėjas skirtas, sukurti tokio pačio stiliaus didelius banerius, kokie buvo naudojami 2008-ais metais pradėtame naudoti Games.lt dizaine.</p>
    <p>Fono paveikslėlio dydį bei poziciją galima keisti pelės pagalba. Paspaudus kairė pelės klavišą ir tempiant, keičiamos koordinatės. Sukant ratuką, keičiamas mastelis.</p>
    <form data-error-image-height-too-small-msg="Klaida: pasirinktas per mažo aukščio paveikslėlis!" data-error-image-width-too-small-msg="Klaida: pasirinktas per mažo pločio paveikslėlis!" data-error-image-height-too-small-action="alert" data-error-image-width-too-small-action="alert"
    data-error-old-browser-action="show" data-error-old-browser-target=".browserupgrade" id="tool" class="form-horizontal big_banner_editor_gameslt_style" action="javascript://">
      <fieldset>
        <legend>Duomenys</legend>
        <div class="form-group">
          <label class="control-label col-sm-4" for="banner_type">Tipas</label>
          <div class="col-sm-8 input-el">
            <input class="form-control" id="banner_type" maxlength="255" name="banner_type" required="required" type="text" value="Apžvalga">
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_name">Rodomas žaidimo pavadinimas</label>
          <div class="col-sm-8 input-el">
            <input class="form-control" id="game_name" maxlength="255" name="game_name" type="text" value="">
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_platform">Platforma</label>
          <div class="col-sm-8 input-el">
            <select class="form-control" name="game_platform" id="game_platform">
              <option value="PC">PC</option>
              <option value="PS2">PlayStation 2</option>
              <option value="XBOX">XBOX</option>
              <option value="GCUBE">GameCube</option>
              <option value="GBOY">GameBoy</option>
              <option value="PS3">PlayStation 3</option>
              <option value="PSP">PlayStation Portable</option>
              <option value="DS">Nintendo DS</option>
              <option value="X360">Xbox 360</option>
              <option value="REV">Nintendo Wii</option>
              <option value="MOBILE">Mobile</option>
              <option value="3DS">Nintendo 3DS</option>
              <option value="PSVITA">PlayStation Vita</option>
              <option value="ANDROID">Android</option>
              <option value="PS4">PlayStation 4</option>
              <option value="XO">Xbox One</option>
              <option value="WIIU">WII U</option>
              <option value="Naršyklinis">Web</option>
              <option value="iOS">iOS</option>
              <option value="Android">Android</option>
              <option value="WP7">Windows Phone 7</option>
              <option value="WP8">Windows Phone 8</option>a </select>
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_box">Dėžutės paveiksliukas <span class="label label-info" title="Minimalūs matmenys - 190x190 "><i class="fa fa-info "></i></span></label>
          <div class="col-sm-8 input-el">
            <input class="form-control" id="game_box" data-role="changeImage" data-width="100" data-height="190" data-key="box" accept="image/*" name="game_box" type="file">
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_image">Fono paveiksliukas <span class="label label-info" title="Minimalūs matmenys - 625x190"><i class="fa fa-info "></i></span></label>
          <div class="col-sm-8 input-el">
            <input class="form-control" data-role="changeImage" data-key="background" data-width="625" data-height="158" id="game_image" accept="image/*" name="game_image" required="true" type="file">
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_image_size">Fono paveiksliuko dydis</label>
          <div class="col-sm-8 input-el">
            <input class="form-control" id="game_image_size" max="100" min="1" name="game_image_size" required="true" type="number" value="100">
          </div>
          <p></p>
        </div>
        <div class="form-group">
          <label class="control-label col-sm-4" for="game_flag">Ženkliukas</label>
          <div class="col-sm-8 input-el">
            <select class="form-control" id="game_flag" name="game_flag" required="true">
              <option>Joks</option>
              <option value="gamersgate">GamersGate</option>
              <option value="made_in_lithuania">Pagaminta Lietuvoje!</option>
            </select>
          </div>
          <p></p>
        </div>
      </fieldset>
      <fieldset>
        <legend>Redagavimas</legend>
        <canvas height="190" width="625" id="banner" role="canvas"></canvas>
      </fieldset>
      <fieldset>
        <legend>Rezultatas</legend>
        <p>
          <button type="reset" class="btn btn-danger">Išvalyti formą</button>
          <button type="submit" class="btn btn-primary">Atsisiųsti rezultatą</button>
        </p>
      </fieldset>
    </form>
    <div id="page_error">
      <noscript>Norint pasinaudoti šiuo įrankiu būtina, kad naudojama naršyklė palaikytų JavaScript.</noscript>
    </div>
    <p>Šis banerių kūrėjas skirtas, sukurti tokio pačio stiliaus didelius banerius, kokie buvo naudojami 2008-ais metais pradėtame naudoti Games.lt dizaine.</p>
    <p>Fono paveikslėlio dydį bei poziciją galima keisti pelės pagalba. Paspaudus kairė pelės klavišą ir tempiant, keičiamos koordinatės. Sukant ratuką, keičiamas mastelis.</p>
  </div>

</div>