$.ajax({
url: STATIC_URL + 'xsl/wl2html_client.xsl',
dataType: 'xml',
+ timeout: 10000,
success: function(data) {
xml2htmlStylesheet = createXSLT(data);
$.unblockUI();
}
+// Wykonuje block z załadowanymi kanonicznymi motywami
+function withThemes(code_block, onError)
+{
+ if (typeof withThemes.canon == 'undefined') {
+ $.ajax({
+ url: '/themes',
+ dataType: 'text',
+ success: function(data) {
+ withThemes.canon = data.split('\n');
+ code_block(withThemes.canon);
+ },
+ error: function() {
+ withThemes.canon = null;
+ code_block(withThemes.canon);
+ }
+ })
+ }
+ else {
+ code_block(withThemes.canon);
+ }
+}
+
+
+
function xml2html(options) {
withStylesheets(function() {
- var xml = options.xml.replace(/\/\s+/g, '<br />');
+ var xml = options.xml.replace(/\/(\s+)/g, '<br />$1');
var parser = new DOMParser();
var serializer = new XMLSerializer();
var doc = parser.parseFromString(xml, 'text/xml');
if (error.length == 0) {
doc = xml2htmlStylesheet.transformToFragment(doc, document);
- console.log(doc.firstChild);
+ console.log(doc.firstChild);
- if(doc.firstChild === null) {
- options.error("Błąd w przetwarzaniu XML.");
- return;
- }
+ if(doc.firstChild === null) {
+ options.error("Błąd w przetwarzaniu XML.");
+ return;
+ }
error = $('parsererror', doc);
}
options.error(error.text());
} else {
options.success(doc.firstChild);
+
+ withThemes(function(canonThemes) {
+ if (canonThemes != null) {
+ $('.theme-text-list').addClass('canon').each(function(){
+ var themes = $(this).html().split(',');
+ for (i in themes) {
+ themes[i] = $.trim(themes[i]);
+ if (canonThemes.indexOf(themes[i]) == -1)
+ themes[i] = '<span x-pass-thru="true" class="noncanon">' + themes[i] + "</span>"
+ }
+ $(this).html(themes.join(', '));
+ });
+ }
+ });
}
}, function() { options.error && options.error('Nie udało się załadować XSLT'); });
}
switch(token.node.nodeType) {
case ELEMENT_NODE:
- if(token.node.hasAttribute('x-pass-thru')) {
+ if(token.node.hasAttribute('x-pass-thru')
+ || token.node.hasAttribute('data-pass-thru')) {
self._pushChildren(token.node);
break;
}
if(xnode === 'wers') {
/* push children */
if(self._verseBefore(token.node))
- self.result += '/\n';
+ self.result += '/';
self._pushChildren(token.node);
break;
};
self._serializeElement(token.node);
break;
case TEXT_NODE:
- self.result += token.node.nodeValue;
+ // collapse previous element's padding
+ var i = 0;
+ while (token.node.nodeValue[i] == '\n' && self.result[self.result.length - 1] == '\n')
+ i ++;
+ self.result += token.node.nodeValue.substr(i);
break;
};
};
};
/* print out */
- if (getPadding(tagName))
+
+ // at least one newline before padded elements
+ if (getPadding(tagName) && self.result[self.result.length - 1] != '\n')
self.result += '\n';
self.result += '<' + tagName;