]> matita.cs.unibo.it Git - helm.git/blobdiff - matitaB/matita/matitaweb.js
Matitaweb: first attempt at "Save as".
[helm.git] / matitaB / matita / matitaweb.js
index 86481a1ed15417a77dc3cdbc732cc02d17ceb7ee..221ef90b56f3c6361d5338d48c71d5a89548498e 100644 (file)
@@ -179,7 +179,7 @@ function debug(txt)
        // but google chrome's innerText is, in a sense, "write only"
        // what should we do?
         // logarea.innerText = txt + "\n" + logarea.innerText;
-        logarea.innerHTML = txt + "\n" + logarea.innerHTML;
+        logarea.innerHTML = txt; // + "\n" + logarea.innerText;
 }
 
 function listhd(l)
@@ -508,7 +508,9 @@ function gotoBottom()
                        if (len > 0) {
                          // len0 = unlocked.innerHTML.length;
                          unescaped = unlocked.innerHTML.html_to_matita();
-                         parsedtxt = parsed.childNodes[0].nodeValue;
+                          // not working in mozilla
+                         // parsedtxt = parsed.childNodes[0].nodeValue;
+                         parsedtxt = parsed.childNodes[0].wholeText;
                          //parsedtxt = unescaped.substr(0,len); 
                          unparsedtxt = unescaped.substr(len);
                          lockedbackup += parsedtxt;
@@ -612,7 +614,7 @@ function openFile()
                if (is_defined(xml)) {  
                        lockedbackup = "";
                        locked.innerHTML = lockedbackup;
-                       unlocked.innerHTML = xml.documentElement.textContent;
+                       unlocked.innerHTML = xml.documentElement.wholeText;
                } else {
                        debug("file open failed");
                }
@@ -642,7 +644,7 @@ function retrieveFile(thefile)
        callServer("open",processor,"file=" + escape(thefile)); 
 }
 
-function showLibrary()
+function showLibrary(title,callback)
 { 
        var req = null; 
         // pause();
@@ -673,7 +675,7 @@ function showLibrary()
                        if(stat == 200)
                        {
                          debug(req.responseText);
-                         showDialog("<H2>Library</H2>",req.responseText);
+                         showDialog("<H2>" + title + "</H2>",req.responseText, callback);
                        } 
                } 
        };
@@ -683,21 +685,44 @@ function showLibrary()
   
 }
 
-function saveFile()
+function openDialog()
+{  
+       callback = function (fname) { retrieveFile(fname); };
+       showLibrary("Open file", callback);
+}
+
+function saveDialog()
+{  
+       callback = function (fname) { saveFile(fname,false); };
+       showLibrary("Save file as", callback);
+}
+
+function saveFile(fname,force)
 {
+        if (!is_defined(fname) {
+            fname = current_fname;
+        }
        processor = function(xml) {
                if (is_defined(xml)) {
+                 if (xml.childNodes[0].textContent != "ok") {
+                    if (confirm("File already exists. Do you want to proceed anyway?")) {
+                       saveFile(fname,true);
+                   } else {
+                      saveDialog();
+                   }
+                 } else
                        debug("file saved!");
                } else {
                        debug("save file failed");
                }
                resume();
        };
-       if (is_defined(current_fname)) {
+       if (is_defined(fname)) {
           pause();
-          callServer("save",processor,"file=" + escape(current_fname) + 
+          callServer("save",processor,"file=" + escape(fname) + 
                                    "&locked=" + (locked.innerHTML.html_to_matita()).sescape() +
-                                   "&unlocked=" + (unlocked.innerHTML.html_to_matita()).sescape());
+                                   "&unlocked=" + (unlocked.innerHTML.html_to_matita()).sescape() +
+                                   "&force=" + force);
        }
        else { debug("no file selected"); }
 }
@@ -728,10 +753,11 @@ function showSequent() {
   workarea.appendChild(goalcell);
 }
 
-function showDialog(title,content) {
+function showDialog(title,content,callback) {
   dialogTitle.innerHTML = title;
   dialogContent.innerHTML = content;
   dialogBox.style.display = "block";
+  dialogBox.callback = callback;
 }
 
 function removeElement(id) {