From a7585943e71034e5e6cb95e42f94d756488b677d Mon Sep 17 00:00:00 2001
From: ulrich <undisclosed>
Date: Sun, 12 Mar 2017 16:50:59 +0000
Subject: [PATCH] Dialog 'vor dem Schliessen speichern' wenn Aenderungen gemacht wurden

---
 web/ui/ui.js |  134 ++++++++++++++++++++++++++++++++++++++------
 1 files changed, 116 insertions(+), 18 deletions(-)

diff --git a/web/ui/ui.js b/web/ui/ui.js
index a05b1bb..5b30784 100644
--- a/web/ui/ui.js
+++ b/web/ui/ui.js
@@ -28,6 +28,9 @@
 var cutCopySrcDir;
 var cutCopyFiles;
 var cutCopyOperation;
+var loc;
+var PERS_DIR = "Persoenlich";
+var PUB_DIR = "Oeffentlich";
 
 function fm_init() {
   $("#mce-editor").hide();
@@ -52,6 +55,7 @@
   $('#m-cut').on('click', fm_menu_cut);
   $('#m-copy').on('click', fm_menu_copy);
   $('#m-paste').on('click', fm_menu_paste);
+  $('#m-shrink').on('click', fm_menu_shrink);
   $('#m-test').on('click', fm_menu_test);
   $('#saveModal').on('hidden.bs.modal', function (e) {
     $('#modal_ok').attr('onclick','').unbind('click');
@@ -60,6 +64,14 @@
   fm_get_login();
   fm_get_list('');
   fm_init_uploader();
+  /*
+  console.log('href: ' + window.location.href);
+  console.log('host: ' + window.location.host);
+  console.log('hostname: ' + window.location.hostname);
+  console.log('port: ' + window.location.port);
+  console.log('protocol: ' + window.location.protocol);
+  */
+  loc = window.location.protocol + '//' + window.location.host;
 }
 
 function fm_resize_editor() {
@@ -76,10 +88,10 @@
 function fm_get_path(uid) {
   //console.log('pfad: ' + pfad);
   var restdir;
-  if(pfad.indexOf('Oeffentlich') > -1) {
-    restdir = pfad.substr('Oeffentlich'.length);
-  } else if(pfad.indexOf('Persoenlicher Ordner') > -1) {
-    restdir = pfad.substr('Persoenlicher Ordner'.length);
+  if(pfad.indexOf(PUB_DIR) > -1) {
+    restdir = pfad.substr(PUB_DIR.length);
+  } else if(pfad.indexOf(PERS_DIR) > -1) {
+    restdir = pfad.substr(PERS_DIR.length);
   }
   if(restdir !== undefined && restdir.startsWith('/')) {
     restdir = restdir.substr(1);
@@ -96,9 +108,9 @@
 function fm_get_base(uid) {
   //console.log('pfad: ' + pfad);
   var pdir;
-  if(pfad.indexOf('Oeffentlich') > -1) {
+  if(pfad.indexOf(PUB_DIR) > -1) {
     pdir = '/data/';
-  } else if(pfad.indexOf('Persoenlicher Ordner') > -1) {
+  } else if(pfad.indexOf(PERS_DIR) > -1) {
     pdir = '/home/';
   }
   //console.log('base: ' + pdir + uid);
@@ -107,6 +119,7 @@
 
 function fm_dok_editor_init(uid) {
   var base = fm_get_path(uid);
+  edCount = 0;
   //console.log("calling tinymce.init with base: " + base + "/");
   
   /*
@@ -210,8 +223,13 @@
 }
 function fm_menu_delete() {
   $('#confirmOk').click(function() {
+    $('#confirmOk').attr('onclick','').unbind('click');
     fm_del_files();
   });
+  $('#confirmOk').text("Loeschen");
+  $('#confirmOk').removeClass('btn-primary');
+  $('#confirmOk').addClass('btn-danger');
+  $('#confirmClose').hide();
   $('#confirmModalTitle').text("Löschen");
   $('#confirmModalBody').text("Wirklich löschen?");
   $('#confirmModal').modal({
@@ -289,6 +307,37 @@
 }
 
 function fm_menu_datei_schliessen() {
+  if(tinymce.activeEditor.undoManager.hasUndo()) {
+    // hier Abfrage ob gespeichert werden soll    
+    $('#confirmOk').click(function() {
+      $('#confirmOk').attr('onclick','').unbind('click');
+      fm_menu_datei_speichern(function() {
+        fm_do_close();
+      });
+    });
+    $('#confirmCancel').click(function() {
+      $('#confirmCancel').attr('onclick','').unbind('click');
+    });
+    $('#confirmClose').show();
+    $('#confirmClose').click(function() {
+      $('#confirmClose').attr('onclick','').unbind('click');
+      fm_do_close();
+    });
+    $('#confirmOk').text("Speichern");
+    $('#confirmOk').addClass('btn-primary');
+    $('#confirmOk').removeClass('btn-danger');
+    $('#confirmModalTitle').text("Schliessen");
+    $('#confirmModalBody').text("Speichern vor dem Schliessen?");
+    $('#confirmModal').modal({
+      keyboard: false,
+      show: true
+    });
+  } else {
+    fm_do_close();
+  }
+}
+
+function fm_do_close() {
   $('.codeeditor-space').hide();
   $('.code-editor-container').hide();
   $("#mce-editor").hide();
@@ -318,7 +367,7 @@
         }
         fm_get_list(pfad);
       }
-    } else if($(elem).children(0).hasClass('fa-file')) {
+    } else if($(elem).children(0).hasClass('datei')) {
       if(/*ev.shiftKey || */ ev.ctrlKey) {
         // mehrere Dateien sollen gewaehlt werden
       } else {
@@ -411,7 +460,6 @@
   fm_get(u, "text", function(resp) {
     userid = resp;
     $('#userMenu').text(resp);
-    //fm_dok_editor_init(resp);
   });  
 }
 
@@ -499,6 +547,18 @@
   m = m + '&p=' + p; 
   m = m + '&p=' + fn; 
   m = m + '&p=' + neuerName; 
+  var u = '../svc' + m;
+  fm_get(u, "text", function(resp) {
+    fm_get_list(pfad);
+  });  
+}
+
+function fm_menu_shrink() {
+  var gewaehlte = $('.datei-gewaehlt');
+  var fname = $(gewaehlte[0]).text();
+  var m = '?c=de.uhilger.filecms.api.FileMgr&m=bildVerkleinern';
+  m = m + '&p=' + pfad; 
+  m = m + '&p=' + fname; 
   var u = '../svc' + m;
   fm_get(u, "text", function(resp) {
     fm_get_list(pfad);
@@ -685,17 +745,17 @@
   });
 }
 
-function fm_menu_datei_speichern() {
+function fm_menu_datei_speichern(callback) {
   //var fname = $('.datei-gewaehlt').text();
   var fname = openFileName;
   if(fname !== undefined && fname !== '') {
-    fm_save_file(fname, 'saveTextFile');
+    fm_save_file(fname, 'saveTextFile', callback);
   } else {
-    fm_menu_datei_speichern_unter();
+    fm_menu_datei_speichern_unter(callback);
   }
 }
 
-function fm_save_file(saveFileName, method) {
+function fm_save_file(saveFileName, method, callback) {
   var content;
   if(openEditor === 'text') {
     content = cm.getValue();
@@ -705,14 +765,20 @@
   var m = '?c=de.uhilger.filecms.api.FileMgr&m=' + method;
   var u = '../svc' + m;
   fm_post(u, {p1: pfad, p2: saveFileName, p3: content}, function(resp) {
-    openFileName = saveFileName;
+    // hier scheint nichts zurueckzukommen..
   });
+  tinymce.activeEditor.undoManager.clear();
+  openFileName = saveFileName;
+  if(callback !== undefined) {
+    callback();
+  }
 }
 
-function fm_menu_datei_speichern_unter() {  
+function fm_menu_datei_speichern_unter(callback) {  
   $('#modal_ok').click(function() {
+    $('#modal_ok').attr('onclick','').unbind('click');
     // hier speichern
-    fm_save_file($('#dateiname').val(), 'saveTextFileAs');
+    fm_save_file($('#dateiname').val(), 'saveTextFileAs', callback);
   });
   $('#saveModalTitle').text('Datei speichern');
   $('#dialogfrage').text("Dateiname?");
@@ -840,6 +906,7 @@
 function FileRef(obj) {
   var self = this;
   this.fr = obj;
+  this.fnx;
   
   this.typeClass = function() {
     if(modus == 'kacheln') {
@@ -857,13 +924,44 @@
     }
   };
   
-  this.fileName = function() {
+  this.mini = function() {
+    var miniatur = false;
     var namen = self.fr.absolutePath.split('/');
     if(namen.length > 0) {
-      return namen[namen.length - 1];
+      self.fnx = decodeURIComponent(namen[namen.length - 1]);
     } else {
-      return self.fr.absolutePath;
+      self.fnx = decodeURIComponent(self.fr.absolutePath);
     }
+    if(self.fnx.indexOf('.jpg') > -1 || self.fnx.indexOf('.png') > -1 || self.fnx.indexOf('.gif') > -1 || self.fnx.indexOf('.jpeg') > -1) {
+      miniatur = true;
+    }
+    return miniatur;
+  };
+  
+  this.miniurl = function() {
+      var userid = $('#userMenu').text();
+      var ext = '';
+      var dotpos = self.fnx.indexOf('.');
+      if(dotpos > -1) {
+        var fny = self.fnx;
+        self.fnx = self.fnx.substring(0, dotpos);
+        ext = fny.substr(dotpos);
+      }
+      var path = fm_get_path(userid);
+      var imgurl = loc + path + '/' + self.fnx + '_tn' + ext;
+      return imgurl;
+    
+  };
+  
+  this.fileName = function() {
+    
+    var namen = self.fr.absolutePath.split('/');
+    if(namen.length > 0) {
+      return decodeURIComponent(namen[namen.length - 1]);
+    } else {
+      return decodeURIComponent(self.fr.absolutePath);
+    }
+    
   };
 }
 

--
Gitblit v1.9.3