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,6 +793,85 @@
    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 ---------- */
@@ -817,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");