From 11536c42a172f2f63b6c7f2ee2b83667f2fbb5ee Mon Sep 17 00:00:00 2001
From: ulrich <not disclosed>
Date: Sun, 19 Mar 2017 09:04:55 +0000
Subject: [PATCH] Pfadeinstellungen fuer TinyMCE berichtigt

---
 web/ui/ui.js |  259 ++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 192 insertions(+), 67 deletions(-)

diff --git a/web/ui/ui.js b/web/ui/ui.js
index fbceedc..345603d 100644
--- a/web/ui/ui.js
+++ b/web/ui/ui.js
@@ -28,6 +28,13 @@
 var cutCopySrcDir;
 var cutCopyFiles;
 var cutCopyOperation;
+var loc;
+var PERS_DIR = "Persoenlich";
+var PUB_DIR = "Oeffentlich";
+var BASE_DIR = "$basis";
+var DATA_DIR = "$daten";
+var WWW_DIR = "www";
+var compilerIssues;
 
 function fm_init() {
   $("#mce-editor").hide();
@@ -54,6 +61,7 @@
   $('#m-paste').on('click', fm_menu_paste);
   $('#m-shrink').on('click', fm_menu_shrink);
   $('#m-test').on('click', fm_menu_test);
+  $('#m-test-2').on('click', fm_menu_test_2);
   $('#saveModal').on('hidden.bs.modal', function (e) {
     $('#modal_ok').attr('onclick','').unbind('click');
   });
@@ -61,6 +69,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() {
@@ -77,16 +93,23 @@
 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);
+  } else if(pfad.indexOf(BASE_DIR) > -1) {
+    restdir = pfad.substr(BASE_DIR.length);
+  } else if(pfad.indexOf(DATA_DIR) > -1) {
+    restdir = pfad.substr(DATA_DIR.length);
   }
   if(restdir !== undefined && restdir.startsWith('/')) {
     restdir = restdir.substr(1);
+    if(restdir.indexOf(WWW_DIR) > -1) {
+      restdir = restdir.replace(WWW_DIR, 'data');
+    }
   }
   var pdir = fm_get_base(uid);
-  //console.log('path: ' + pdir + "/" + restdir);
+  // console.log('fm_get_path path: ' + pdir + "/" + restdir);
   if(restdir.length > 1) {
     return pdir + "/" + restdir;
   } else {
@@ -97,18 +120,23 @@
 function fm_get_base(uid) {
   //console.log('pfad: ' + pfad);
   var pdir;
-  if(pfad.indexOf('Oeffentlich') > -1) {
-    pdir = '/data/';
-  } else if(pfad.indexOf('Persoenlicher Ordner') > -1) {
-    pdir = '/home/';
+  if(pfad.indexOf(PUB_DIR) > -1) {
+    pdir = '/data/' + uid;
+  } else if(pfad.indexOf(PERS_DIR) > -1) {
+    pdir = '/home/' + uid;
+  } else if(pfad.indexOf(BASE_DIR) > -1) {
+    pdir = '';
+  } else if(pfad.indexOf(DATA_DIR) > -1) {
+    pdir = '';
   }
-  //console.log('base: ' + pdir + uid);
-  return pdir + uid;
+  //console.log('fm_get_base base: ' + pdir + uid);
+  return pdir;
 }
 
 function fm_dok_editor_init(uid) {
   var base = fm_get_path(uid);
-  //console.log("calling tinymce.init with base: " + base + "/");
+  edCount = 0;
+  //console.log("fm_dok_editor_init calling tinymce.init with base: " + base + "/");
   
   /*
    * vgl.
@@ -127,6 +155,7 @@
    */
   tinymce.init({
     content_css : "/file-cms/ui/mce.css",
+    //content_css: "/jslib/bootstrap/css/bootstrap.min.css",
     selector: "textarea.text-editor",
     statusbar: false,
     menubar: false,
@@ -143,6 +172,8 @@
     importcss_append: true,
     width: "100%",
     height: '100%',
+    relative_urls : true, 
+    convert_urls : false, 
     document_base_url : base + "/",
     setup: function (editor) {
       ed = editor;
@@ -211,8 +242,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({
@@ -258,6 +294,46 @@
   }
 }
 
+function fm_menu_test_2() {
+  fm_compile('0', fm_mark_compile_results_in_editor);
+}
+
+function fm_mark_compile_results_in_editor(resp) {
+  cm.clearGutter("breakpoints");
+
+  if(resp.List[0].CompilerIssue !== undefined) {
+    var lno;
+    var eMsg;
+    if(resp.List[0].CompilerIssue instanceof Array) {
+      var issueNo = 0;
+      while(issueNo < resp.List[0].CompilerIssue.length) {
+        // console.log(resp.List[0].CompilerIssue[issueNo].kind);
+        // console.log(resp.List[0].CompilerIssue[issueNo].lineNumber);
+        // console.log(resp.List[0].CompilerIssue[issueNo].sourceName);
+        // console.log(resp.List[0].CompilerIssue[issueNo].message);
+        lno = resp.List[0].CompilerIssue[issueNo].lineNumber;
+        eMsg = resp.List[0].CompilerIssue[issueNo].kind + ' ' + resp.List[0].CompilerIssue[issueNo].message;
+        cm.setGutterMarker(lno-1, "breakpoints", makeMarker(eMsg));
+        issueNo++;
+      }
+    } else {
+      lno = resp.List[0].CompilerIssue.lineNumber;
+      eMsg = resp.List[0].CompilerIssue.kind + ' ' + resp.List[0].CompilerIssue.message;
+      cm.setGutterMarker(lno-1, "breakpoints", makeMarker(eMsg));
+    }
+  }
+}
+
+function fm_compile(modeStr, callback) {
+  var liste = fm_gewaehlte_dateien();
+  var m = '?c=de.uhilger.filecms.api.CompileService&m=compile&p=' + pfad + '&p=' + encodeURIComponent(liste) + 
+          '&p=' + modeStr;
+  var u = '../svc' + m;
+  fm_get(u, "json", function(resp) {
+    callback(resp);
+  });
+}
+
 function fm_ansicht_umschalten() {
   if($('#ansicht').children(0).hasClass('fa-th-list')) {
     $('#ansicht').children(0).addClass('fa-th-large');
@@ -290,6 +366,49 @@
 }
 
 function fm_menu_datei_schliessen() {
+  if(openEditor === 'text') {
+    if(!cm.getDoc().isClean()) {
+      fm_ask_for_save();
+    } else {
+      fm_do_close();
+    }
+  } else {
+    if(tinymce.activeEditor.undoManager.hasUndo()) {
+      fm_ask_for_save();
+    } else {
+      fm_do_close();
+    }
+  }
+}
+
+function fm_ask_for_save() {
+  // 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
+  });
+}
+
+function fm_do_close() {
   $('.codeeditor-space').hide();
   $('.code-editor-container').hide();
   $("#mce-editor").hide();
@@ -412,7 +531,6 @@
   fm_get(u, "text", function(resp) {
     userid = resp;
     $('#userMenu').text(resp);
-    //fm_dok_editor_init(resp);
   });  
 }
 
@@ -480,7 +598,7 @@
 
   $('#modal_ok').click(function() {
     // hier umbenennen
-    fm_rename_file(fname, pfad, $('#dateiname').val())
+    fm_rename_file(fname, pfad, $('#dateiname').val());
   });
   $('#saveModalTitle').text('Datei umbenennen');
   $('#dialogfrage').text("Neuer Dateiname?");  
@@ -698,34 +816,43 @@
   });
 }
 
-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();
+    cm.getDoc().markClean();
   } else {
     content = ed.getContent();
+    tinymce.activeEditor.undoManager.clear();
   }
   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..
   });
+  openFileName = saveFileName;
+  if(typeof (callback) !== 'function') {
+    
+  } else {
+    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?");
@@ -756,30 +883,72 @@
 
 /* ---- codemirror editor handling -------- */
 
+/*
 function htmlDecode(value){ 
   return $('<div/>').html(value).text(); 
 }
+*/
 
 function fm_code_edit(content, m) {
   cm = CodeMirror.fromTextArea(document.getElementById("editspace"), {
     lineNumbers: true,
+    gutters: ["CodeMirror-linenumbers", "breakpoints"],
     mode: m,
     viewportMargin : Infinity,
+    tabSize: 2,
     extraKeys: {
         "F9": function(cm) {
         cm.setOption("fullScreen", !cm.getOption("fullScreen"));
       },
         "Esc": function(cm) {
         if (cm.getOption("fullScreen")) cm.setOption("fullScreen", false);
+      },
+        ".": function(cm) {
+        console.log('dot pressed: perhaps look up class or method name');
+        /*
+         * Hier kann man eine Funktion ausloesen, die fuer das 
+         * Wort vor dem Punkt (Name der Klasse) eine Liste mit 
+         * Vorschlaegen fuer Methodennamen einblendet.
+         */
+        
+        /*
+         * CodeMirror.Pass laesst das Zeichen zum Editorinhalt durch, 
+         * verhindert aber das Ausloesen von 'keyHandled'
+         */
+        return CodeMirror.Pass; 
       }
     }
   });
   //cm.setValue(htmlDecode(content));
   //cm.setValue(content);
   cm.setValue(unescapeHtml(content));
+  cm.getDoc().markClean();
+  cm.on("gutterClick", function(theEditor, lineNumber) {
+    var info = theEditor.lineInfo(lineNumber);
+    //--lineNumber;
+    //console.log(info.gutterMarkers.breakpoints.message);
+    //var marker = info.gutterMarkers.breakpoints;
+    //$(marker).tooltip('toggle');
+  });
+  /*
+  cm.on("keyHandled", function(theEditor, keyName, event){
+    console.log('cm.keyHandled keyName: ' + keyName + ', event.type: ' + event.type);    
+  });
+  */
 }
 
-
+function makeMarker(msg) {
+  var marker = document.createElement("div");
+  marker.style.color = "#822";
+  marker.innerHTML = "●";
+  //marker.message = msg;
+  $(marker).tooltip({
+    placement: 'right',
+    title: msg,
+    offset: '0 -30'
+  });
+  return marker;
+}
 
 /* -------- helper functions ----------- */
 
@@ -895,54 +1064,10 @@
         ext = fny.substr(dotpos);
       }
       var path = fm_get_path(userid);
-      var imgurl = 'http://localhost:8079' + path + '/' + self.fnx + '_tn' + ext;
+      var imgurl = loc + path + '/' + self.fnx + '_tn' + ext;
       return imgurl;
     
   };
-  
-  /*
-  this.kachel = function() {
-    var htm;
-    var fnx; // = self.fileName;
-    var namen = self.fr.absolutePath.split('/');
-    if(namen.length > 0) {
-      fnx = decodeURIComponent(namen[namen.length - 1]);
-    } else {
-      fnx = decodeURIComponent(self.fr.absolutePath);
-    }
-    
-    
-    if(fnx.indexOf('.jpg') > -1 || fnx.indexOf('.png') > -1 || fnx.indexOf('.gif') > -1 || fnx.indexOf('.jpeg') > -1) {
-      var userid = $('#userMenu').text();
-      var ext = '';
-      var dotpos = fnx.indexOf('.');
-      if(dotpos > -1) {
-        fnx = fnx.substring(0, dotpos);
-        ext = fnx.substr(dotpos);
-      }
-      var path = fm_get_path(userid);
-      var imgurl = path + '/' + fnx + '_tn' + ext;
-      htm = "img src='" + imgurl + "'";
-    } else {
-      var cl;
-      if(modus == 'kacheln') {
-        if(self.fr.isDirectory) {
-          cl = 'fa-folder ordner';
-        } else {
-          cl = 'fa-file datei';
-        }
-      } else {
-        if(self.fr.isDirectory) {
-          cl = 'fa-folder ordner';
-        } else {
-          cl = 'fa-file-o datei';
-        }
-      }
-      htm = "i class='fa " + cl + " fa-3x'></i";
-    }
-    return htm;
-  };
-  */
   
   this.fileName = function() {
     

--
Gitblit v1.9.3