all repos — litestore @ e465690e6e082935801e5c6a10a37663def8bb05

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
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
/*
 * Dependencies:
 * - models.js
 * - utils.js
 */
(function(){
  'use strict';  
  var app = window.LS || (window.LS = {});
  var u = LS.utils;
  
  app.uploader = function(docid){
    
    var uploader = {vm: {}};
    var vm = uploader.vm;
    
    vm.docid = m.prop(docid);
    vm.file = m.prop();
    vm.id = u.guid();
    vm.modalId = "#upload-"+vm.id+"-modal";
    vm.btnId = "#upload-"+vm.id+"-btn";
    vm.reader = new FileReader();
    vm.contents = m.prop();
    vm.isText = m.prop(false);
    
    vm.reader.onloadstart = function() {
      vm.contents("");
      $(uploader.vm.modalId).find(".btn-primary").attr("disabled", true);
    };
    
    vm.reader.onloadend = function() {
      vm.contents(vm.reader.result);
      $(uploader.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(uploader.onSuccess, uploader.onFailure);
    };
    
    uploader.config = function(obj){
      return function(element, isInitialized, context){
        $(element).change(function(event){
          vm.file(element.files[0]);
          if (vm.reader.readyState != 1) {
            vm.reader.readAsDataURL(vm.file()); 
          }
        });
      };
    };
    
    uploader.showModal = function() {
      return u.showModal(uploader.vm.modalId);
    };
    
    uploader.onSuccess = function(data){
      // Callback
    };
    uploader.onFailure = function(data){
      // Callback
    };
    
    uploader.view = function(){
      var config = {
        title: "Upload Document",
        id: "upload-"+vm.id+"-modal",
        action: vm.save,
        actionText: "Upload",
        content: m("div", [
          m(".form-group", [
          m("label", "Document ID"),
            m("input.form-control", {
              placeholder: "Enter document ID",
              onchange: m.withAttr("value", vm.docid),
              size: 35,
              disabled: (docid === "") ? false : true,
              value: vm.docid()
            })
          ]),
          m(".form-group", [
            m("label", "File"),
            m("input.form-control#upload-"+vm.id+"-btn", {type:"file", config: uploader.config(vm)}),
            m("p.help-block", "Select a file to upload as document.")
          ]),
          m(".checkbox", [
            m("label", [
              m("input", {type: "checkbox", value: vm.isText(), onchange: m.withAttr("value", vm.isText)}), 
              "Text File"
            ]),
            m("p.help-block", "Select if the file to upload contains textual content.")
          ])
        ])
      };
      return u.modal(config);
    };
    return uploader;
  };
}());