Persoenliche Mediazentrale
ulrich
2021-04-06 5b73568c001c245ea630c1b97bf8086a738ea8b7
Ablageort bearbeiten und leoschen in Arbeit
1 files added
3 files modified
82 ■■■■ changed files
www/ui/app.css 9 ●●●●● patch | view | raw | blame | history
www/ui/data/tpl/dlg-loeschen.tpl 13 ●●●●● patch | view | raw | blame | history
www/ui/data/tpl/form_ablageort.tpl 1 ●●●● patch | view | raw | blame | history
www/ui/js/app.js 59 ●●●● patch | view | raw | blame | history
www/ui/app.css
@@ -140,6 +140,15 @@
  margin-bottom: 0;
}
.form-button-footer {
  display: flex;
  flex-flow: row;
}
.dlg-btn {
  margin-left: 0.4rem;
}
/*
@media (min-width: 800px) {
  .zentrum-behaelter {
www/ui/data/tpl/dlg-loeschen.tpl
New file
@@ -0,0 +1,13 @@
<div class="dlg-info">
  <span class="close-btn pointer-cursor">&#10006;</span>
  <div class="dlg-behaelter">
    <div class="dlg-info-app-titel">L&ouml;schen</div>
    <div class="dlg-info-app-info">{{del-elem}} wirklich l&ouml;schen?</div>
    <div class="dlg-info-app-info"></div>
    <div class="form-button-footer">
      <button class="button dlg-btn" type="button" id="nein-btn">Abbrechen</button>
      <button class="button-primary dlg-btn" type="button" id="ja-btn">L&ouml;schen</button>
    </div>
  </div>
</div>
www/ui/data/tpl/form_ablageort.tpl
@@ -7,6 +7,7 @@
      <div class="entity-buttons">
        <button class="button-primary" id="ok-btn">Speichern</button>
        <button class="button" id="cancel-btn">Abbrechen</button>
        <button class="button" id="loeschen-btn">L&ouml;schen</button>
      </div>
      
    </div>
www/ui/js/app.js
@@ -28,21 +28,28 @@
    self.vorlage_laden_und_fuellen("data/tpl/form_ablageort.tpl", "", function (html) {
      document.querySelector(".zentraler-inhalt").innerHTML = html;
      self.addEvtListener('#ok-btn', 'click', function () {
        // hier neuen Ablageort speichern
        var a = new Ablageort(
          document.querySelector('#ablageort-name').value,
          document.querySelector('#ablageort-ort').value,
          document.querySelector('#ablageort-url').value
        );
        // {"name":"Katalog","ort":"/home/ulrich/Videos","url":"/media/test"}
        var daten = JSON.stringify(a);
        self.http_post('../api/store/Ablageort', daten, function (responseText) {
          // hier die Antwort verarbeiten
        });
      });
      self.addEvtListener('#cancel-btn', 'click', function () {
        // hier die Aktion abbrechen
        document.querySelector(".zentraler-inhalt").innerHTML = '';
      });
      self.addEvtListener('#loeschen-btn', 'click', function() {
        var aoname = document.querySelector('#ablageort-name').value;
        var dlgdata = {"del-elem": aoname};
        self.dialog_laden_und_zeigen('data/tpl/dlg-loeschen.tpl', dlgdata, function() {
          self.addEvtListener('#nein-btn', 'click', self.dialog_schliessen);
          self.addEvtListener('#ja-btn', 'click', function() {
            // hier loeschen
          });
        });
      });
    });
  };
@@ -61,6 +68,10 @@
  this.http_post = function (u, data, cb) {
    self.http_call('POST', u, data, cb);
  };
  this.http_delete = function (u, data, cb) {
    self.http_call('DELETE', u, data, cb);
  };
  this.http_call = function (method, u, data, scallback) {
@@ -192,20 +203,42 @@
   vurl - URL zur Dialogvorlage
   msgTpl - URL mit einer Vorlage eines Mitteilungstextes (optional)
   */
  this.dialog_laden_und_zeigen = function (vurl, msgTpl) {
    if (msgTpl !== '') {
      fetch(msgTpl)
              .then(data => {
                // Handle data
                self.dialog_zeigen(vurl, data);
              }).catch(error => {
        // Handle error
  this.dialog_laden_und_zeigen = function (vurl, msgTpl, cb) {
    var vorlage = self.cache[vurl];
    if(vorlage === undefined) {
      self.http_get(vurl, function(antwort) {
        self.cache[vurl] = antwort;
        self.dialog_zeigen(vurl, msgTpl, cb);
        //self.dialog_zeigen(vurl, antwort, cb);
        //self.vorlage_fuellen(vurl, inhalt, cb);
      });
    } else {
      self.dialog_zeigen(vurl, '');
      self.dialog_zeigen(vurl, msgTpl, cb);
      //self.dialog_zeigen(vurl, vorlage, cb);
    }
  };
  this.dialog_zeigen = function (vurl, inhalt, cb) {
    var dlg = document.querySelector(".dialog");
    self.html_erzeugen(
            vurl,
            inhalt,
            function (html) {
              //dlg.html(html);
              dlg.style.height = '7em';
              dlg.innerHTML = html;
              document.querySelector('.close-btn').addEventListener('click', self.dialog_schliessen);
              //dlg.slideDown(300);
              if(typeof(cb) !== 'function') {
                // ..
              } else {
                cb();
              }
            });
  };
/*
  this.dialog_zeigen = function (vurl, inhalt) {
    var dlg = document.querySelector(".dialog");
    self.html_erzeugen(
@@ -219,7 +252,7 @@
              //dlg.slideDown(300);
            });
  };
*/
  self.dialog_schliessen = function () {
    document.querySelector('.close-btn').removeEventListener('click', self.dialog_schliessen);
    //$('.dialog').slideUp(300);