Dateiverwaltung für die WebBox
ulrich
2021-01-28 81abd5a101a52f7ca9c803af879815dacae028b1
web/ui2/js/app.js
@@ -24,6 +24,8 @@
  this.cutCopySrcDir;
  this.cutCopyFiles;
  this.fm_slideshow = false;
  this.listOrder = 'asc';
  this.listCol = 'name';
  this.dateien;
  this.cache = {}; // mustache template cache
@@ -102,7 +104,7 @@
  };
  
  this.fm_hilfe = function() {
    window.open('/data/dok/wbx-doku.html#wbx-bedienung', '_blank');
    window.open('/data/dok/wbx/bedienung.html#wbx-bedienung', '_blank');
  };
  
  this.fm_toggle_show_slideshow = function() {
@@ -500,6 +502,7 @@
        var elem = document.querySelector('#dateien');
        elem.innerHTML = html;
        self.addEvtListener('.datei-zeile', 'click', self.fm_dateiwahl);
        self.addEvtListener('.col-hdr', 'click', self.fm_set_sort);
      });
    }
  };
@@ -783,12 +786,105 @@
  this.fm_menu_html_export = function() {
    self.fm_export_html();
  };
  this.sued_schliessen = function() {
    var suedDiv = document.querySelector('.sued');
    document.querySelector('.close-btn-fuss').removeEventListener('click', this);
    suedDiv.classList.remove('sued-open');
    suedDiv.style.height = '0';
  };
  // FileRef Vergleicher
  this.fm_vergleichen_asc = function(av, bv) {
    if (av > bv) { return 1;  }
    if (av < bv) { return -1; }
    return 0;
  };
  this.name_vergleicher_asc = function(a, b) {
    return self.fm_vergleichen_asc(a.fileName().small(), b.fileName().small());
  };
  this.name_vergleicher_desc = function(a, b) {
    return self.fm_vergleichen_asc(b.fileName().small(), a.fileName().small());
  };
  this.type_vergleicher_asc = function(a, b) {
    return self.fm_vergleichen_asc(a.fr.mimetype.small(), b.fr.mimetype.small());
  };
  this.type_vergleicher_desc = function(a, b) {
    return self.fm_vergleichen_asc(b.fr.mimetype.small(), a.fr.mimetype.small());
  };
  this.size_vergleicher_asc = function(a, b) {
    return self.fm_vergleichen_asc(a.fileSize(), b.fileSize());
  };
  this.size_vergleicher_desc = function(a, b) {
    return self.fm_vergleichen_asc(b.fileSize(), a.fileSize());
  };
  this.date_vergleicher_asc = function(a, b) {
    return self.fm_vergleichen_asc(a.fileDate(), b.fileDate());
  };
  this.date_vergleicher_desc = function(a, b) {
    return self.fm_vergleichen_asc(b.fileDate(), a.fileDate());
  };
  this.fm_toggle_order = function () {
    if(self.listOrder === 'asc') {
      self.listOrder = 'desc';
    } else {
      self.listOrder = 'asc';
    }
  };
  this.fm_set_sort = function(event) {
    var t = event.target;
    if(t.classList.contains('col-f-name')) {
      if(self.listCol === 'name') {
        self.fm_toggle_order();
      } else {
        self.listCol = 'name';
      }
    } else if(t.classList.contains('col-f-size')) {
      if(self.listCol === 'size') {
        self.fm_toggle_order();
      } else {
        self.listCol = 'size';
      }
    } else if(t.classList.contains('col-f-type')) {
      if(self.listCol === 'type') {
        self.fm_toggle_order();
      } else {
        self.listCol = 'type';
      }
    } else if(t.classList.contains('col-f-date')) {
      if(self.listCol === 'date') {
        self.fm_toggle_order();
      } else {
        self.listCol = 'date';
      }
    }
    //console.log('fm_set_sort col ' + self.listCol + ', order ' + self.listOrder);
    self.fm_get_list(self.pfad);
  };
  /* --------- Dateifunktionen Ende ---------- */
  /* API functions */
  // http://localhost:8079/file-cms/svc?c=de.uhilger.filecms.api.FileMgr&f=JSONNICE&m=list&p=
  /*
    https://[host]:[port]/file-cms/svc
      ?c=de.uhilger.filecms.api.FileMgr
      &m=list
      &p=Persoenlich/prj/jsp
      erster Ordner in Pfad ist stets 'Persoenlich' oder 'Oeffentlich'
   */
  this.fm_get_list = function (relPfad) {
    var m = '?c=de.uhilger.filecms.api.FileMgr&m=list&p=' + relPfad;
    var u = '../svc' + m;
@@ -803,8 +899,32 @@
        } else {
          files.push(new FileRef(resp.List[0].FileRef));
        }
        //console.log('fm_get_list col ' + self.listCol + ', order ' + self.listOrder);
        if(self.listOrder === 'asc') {
          //console.log('fm_get_list order asc');
          if(self.listCol === 'name') {
            files.sort(self.name_vergleicher_asc);
          } else if(self.listCol === 'type') {
            files.sort(self.type_vergleicher_asc);
          } else if(self.listCol === 'date') {
            files.sort(self.date_vergleicher_asc);
          } else if(self.listCol === 'size') {
            files.sort(self.size_vergleicher_asc);
          }
        } else {
          //console.log('fm_get_list order desc');
          if(self.listCol === 'name') {
            files.sort(self.name_vergleicher_desc);
          } else if(self.listCol === 'type') {
            files.sort(self.type_vergleicher_desc);
          } else if(self.listCol === 'date') {
            files.sort(self.date_vergleicher_desc);
          } else if(self.listCol === 'size') {
            files.sort(self.size_vergleicher_desc);
          }
        }
        var fl = new FileList(files);
        self.fm_render_list(fl);
        self.fm_render_list(fl);
      } else {
        // #dateien leeren
        var elem = document.querySelector("#dateien");
@@ -842,6 +962,17 @@
    self.datei_ansehen_oder_bearbeiten(fname);
  };
  /*
  https://[host]:[port]/file-cms/svc
    ?c=de.uhilger.filecms.api.FileMgr
    &m=getCode
    &p=Persoenlich/prj/jsp
    &p=styleTest.jsp
    erster Ordner in Pfad ist stets 'Persoenlich' oder 'Oeffentlich'
  */
  this.fm_get_file_content = function(typ, fname) {
    self.openFileName = fname;
    var m = '?c=de.uhilger.filecms.api.FileMgr&m=getCode&p=' + self.pfad + '&p=' + fname;
@@ -943,17 +1074,54 @@
        //console.log(html);
        var elem = document.querySelector('.sued');
        elem.innerHTML = html;
        document.querySelector('.close-btn-fuss').addEventListener('click', self.sued_schliessen);
        /*
        document.querySelector('.close-btn-fuss').addEventListener('click', function(){
          var suedDiv = document.querySelector('.sued');
          document.querySelector('.close-btn-fuss').removeEventListener('click', this);
          suedDiv.classList.remove('sued-open');
          suedDiv.style.height = '0';
        });
        */
        self.fm_fusszeile_zeigen();
        self.fm_get_list(self.pfad);
      });
    });  
  };
  this.fm_pack_folder = function() {
    //var liste = fm_gewaehlte_dateien();
    var m = '?c=de.uhilger.filecms.api.FileMgr&m=packFolder&p=' + self.pfad;
    var u = '../svc' + m;
    self.fm_get(u, "text", function(resp) {
      // console.log('deleteFiles gab folgendes zurueck: ' + resp);
      self.fm_get_list(self.pfad);
    });
  };
  this.fm_export_html = function() {
    var m = '?c=de.uhilger.filecms.api.HtmlExportService&m=exportHtml';
    m = m + '&p=' + self.pfad;
    var u = '../svc' + m;
    self.fm_get(u, "text", function(resp) {
      var mtx = new Meldung('Rueckmeldung vom HTML-Export: ' + resp);
      //console.log(mtx);
      self.html_erzeugen("data/tpl/fuss.tpl", mtx, function(html) {
        var elem = document.querySelector('.sued');
        elem.innerHTML = html;
        document.querySelector('.close-btn-fuss').addEventListener('click', self.sued_schliessen);
        self.fm_fusszeile_zeigen();
        //self.fm_get_list(self.pfad);
        /*
        $('.system-out').empty();
        $('.system-out').append('Rueckmeldung vom HTML-Export: ' + resp);
        fm_fusszeile_zeigen();
        */
      });
    });
  };
  /* -------- upload ----------- */