Complete serialization with pretty printing. Works both in FF and Webkit. This fixes...
authorŁukasz Rekucki <lrekucki@gmail.com>
Fri, 12 Mar 2010 10:07:24 +0000 (11:07 +0100)
committerŁukasz Rekucki <lrekucki@gmail.com>
Fri, 12 Mar 2010 10:07:24 +0000 (11:07 +0100)
platforma/static/js/main.js
platforma/static/js/xslt.js

index 0baf04a..b98e1c2 100644 (file)
@@ -616,7 +616,7 @@ function html(element) {
                     xml2html({
                         xml: '<' + nodeName + '>' + insertedText + '</' + nodeName + '>',
                         success: function(element) {
                     xml2html({
                         xml: '<' + nodeName + '>' + insertedText + '</' + nodeName + '>',
                         success: function(element) {
-                            $box.html($(element).html());
+                            $origin.html($(element).html());
                             $overlay.remove();
                         },
                         error: function(text) {
                             $overlay.remove();
                         },
                         error: function(text) {
index 750acb2..6cc545a 100644 (file)
@@ -43,15 +43,21 @@ function xml2html(options) {
         var error = $('parsererror', doc);
         
         if (error.length == 0) {
         var error = $('parsererror', doc);
         
         if (error.length == 0) {
-            doc = xml2htmlStylesheet.transformToDocument(doc);
-                       console.log(doc);
+            doc = xml2htmlStylesheet.transformToFragment(doc, document);
+                       console.log(doc.firstChild);
+                       
+                       if(doc.firstChild === null) {
+                               options.error("Błąd w przetwarzaniu XML.");
+                               return;
+                       }
+                               
             error = $('parsererror', doc);
         }
         
         if (error.length > 0 && options.error) {
             options.error(error.text());
         } else {                       
             error = $('parsererror', doc);
         }
         
         if (error.length > 0 && options.error) {
             options.error(error.text());
         } else {                       
-            options.success(document.importNode(doc.documentElement, true));
+            options.success(doc.firstChild);
         }
     }, function() { options.error && options.error('Nie udało się załadować XSLT'); });
 }
         }
     }, function() { options.error && options.error('Nie udało się załadować XSLT'); });
 }
@@ -123,13 +129,27 @@ const PADDING = {
        "wers_akap": 1,
        "wers_wciety": 1,       
        
        "wers_akap": 1,
        "wers_wciety": 1,       
        
-       "rdf:RDF": 3,   
+       "rdf:RDF": 3,
+       "rdf:Description": 1,   
+};
+
+function getPadding(name) {
+       
+       if(name.match(/^dc:.*$/))
+               return -1;
+       
+       if(PADDING[name])
+               return PADDING[name];
+               
+       return 0;
 }
 
 function HTMLSerializer() {    
        // empty constructor
 }
 
 }
 
 function HTMLSerializer() {    
        // empty constructor
 }
 
+
+
 HTMLSerializer.prototype._prepare = function() {
        this.stack = [];
        
 HTMLSerializer.prototype._prepare = function() {
        this.stack = [];
        
@@ -170,20 +190,23 @@ HTMLSerializer.prototype._verseBefore = function(node) {
        return false;
 }
 
        return false;
 }
 
-HTMLSerializer.prototype.serialize = function(rootElement) 
+HTMLSerializer.prototype.serialize = function(rootElement, stripOuter
 {
        var self = this;
        self._prepare();
 {
        var self = this;
        self._prepare();
-       self._pushElement(rootElement); 
+       
+       if(!stripOuter)
+               self._pushElement(rootElement);
+       else    
+               self._pushChildren(rootElement);
        
        while(self.stack.length > 0) {
                var token = self.stack.pop();
                                                
                if(token.type === ELEM_END) {
        
        while(self.stack.length > 0) {
                var token = self.stack.pop();
                                                
                if(token.type === ELEM_END) {
-                       self.result += "</" + token.tagName + ">";
-                       if (PADDING[token.tagName]) {
-                               for(var n=0; n < PADDING[token.tagName]; n++)                   
-                                       self.result += "\n";
+                       self.result += "</" + token.tagName + ">";                                      
+                       for(var padding = getPadding(token.tagName); padding > 0; padding--) {                  
+                               self.result += "\n";                    
                        }
                        continue;
                };
                        }
                        continue;
                };
@@ -305,6 +328,9 @@ HTMLSerializer.prototype._serializeElement = function(node) {
        };
                                
        /* print out */
        };
                                
        /* print out */
+       if (getPadding(tagName))
+               self.result += '\n';
+               
        self.result += '<' + tagName;   
                                        
        $.each(attributeIDs, function() {
        self.result += '<' + tagName;   
                                        
        $.each(attributeIDs, function() {
@@ -338,14 +364,10 @@ HTMLSerializer.prototype._serializeElement = function(node) {
        };
 };
 
        };
 };
 
-function html2text(params) {
-       if (params.stripOuter) {
-               // ...
-       };
-       
+function html2text(params) {   
        try {
                var s = new HTMLSerializer();
        try {
                var s = new HTMLSerializer();
-               params.success( s.serialize(params.element) );
+               params.success( s.serialize(params.element, params.stripOuter) );
        } catch(e) {
                params.error("Nie udało się zserializować tekstu:" + e)
        }       
        } catch(e) {
                params.error("Nie udało się zserializować tekstu:" + e)
        }