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
@@ -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);
      });
    }
  };
@@ -790,12 +793,98 @@
    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;
@@ -810,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");
@@ -849,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;