all repos — litestore @ 98c53976f76ab618c018bb05800a89a9e3970b82

A minimalist nosql document store.

admin/js/components/uploader.js

 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
(function(){
  'use strict';  
  var app = window.LS || (window.LS = {});
  var u = app.utils;

  app.uploader = {};

  app.uploader.config = function(obj){
    return function(element, isInitialized, context){
      $(element).change(function(event){
        obj.file(element.files[0]);
        if (obj.reader.readyState != 1) {
          obj.reader.readAsDataURL(obj.file()); 
        }
      });
    };
  };

  app.uploader.controller = function(args) {
    var vm = this;

    vm.docid = m.prop(args.docid);
    vm.file = m.prop();
    vm.id = args.id; 
    vm.btnId = "#upload-"+vm.id+"-btn";
    vm.modalId = "#upload-"+vm.id+"-modal";
    vm.reader = new FileReader();
    vm.contents = m.prop();
    vm.isText = m.prop(false);

    vm.reader.onloadstart = function() {
      vm.contents("");
      $(vm.modalId).find(".btn-primary").attr("disabled", true);
    };

    vm.reader.onloadend = function() {
      vm.contents(vm.reader.result);
      $(vm.modalId).find(".btn-primary").removeAttr("disabled");
    };

    vm.save = function() {
      var doc = {id: vm.docid()};
      doc.data = vm.contents().split(',')[1];
      if (vm.isText()) {
        doc.data = window.atob(doc.data);
      }
      return Doc.put(doc, vm.file().type).then(args.onSuccess, args.onFailure);
    };
    
    vm.cancel = function(){
      $("input:file").val('');
    };
    
    return vm;
  };
    
  app.uploader.view = function(ctrl, args){
    var config = {
      title: "Upload Document",
      id: "upload-"+ctrl.id+"-modal",
      action: ctrl.save,
      dismiss: ctrl.cancel,
      actionText: "Upload",
      content: m("div.upload-form", [
        m(".form-group", [
        m("label", "Document ID"),
          m("input.form-control", {
            placeholder: "Enter document ID",
            onchange: m.withAttr("value", ctrl.docid),
            size: 35,
            value: ctrl.docid()
          })
        ]),
        m(".form-group", [
        m("label", "File"),
          m("input.form-control#upload-"+ctrl.id+"-btn", {type:"file", config: app.uploader.config(ctrl)}),
          m("p.help-block", "Select a file to upload as document.")
        ]),
        m(".checkbox", [
          m("label", [
            m("input", {type: "checkbox", value: ctrl.isText(), onchange: m.withAttr("value", ctrl.isText)}), 
            "Text File"
          ]),
          m("p.help-block", "Select if the file to upload contains textual content.")
        ])
      ])
    };
    return u.modal(config);
  };
  
}());