X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/3d61fc117d9e5274189d16be83d4489cd4b36d7f..312d803612945fabb774fc959bc36e654c872e1a:/platforma/static/js/xslt.js?ds=sidebyside diff --git a/platforma/static/js/xslt.js b/platforma/static/js/xslt.js index f164c5bd..e098a7d9 100644 --- a/platforma/static/js/xslt.js +++ b/platforma/static/js/xslt.js @@ -132,12 +132,12 @@ function withStylesheets(block, onError) { } $.blockUI({message: 'Ładowanie arkuszy stylów...'}); $.ajax({ - url: '/static/xsl/wl2html_client.xsl', + url: STATIC_URL + 'xsl/wl2html_client.xsl', dataType: 'xml', success: function(data) { xml2htmlStylesheet = createXSLT(data); $.ajax({ - url: '/static/xsl/html2wl_client.xsl', + url: STATIC_URL + 'xsl/html2wl_client.xsl', dataType: 'xml', success: function(data) { html2xmlStylesheet = createXSLT(data); @@ -151,72 +151,49 @@ function withStylesheets(block, onError) { }) } -function transform(editor) { - $.blockUI({message: 'Ładowanie...'}); + +function xml2html(options) { withStylesheets(function() { - setTimeout(function() { - var doc = null; - var parser = new DOMParser(); - var serializer = new XMLSerializer(); - - doc = editor.getCode().replace(/\/\s+/g, '
'); - doc = parser.parseFromString(doc, 'text/xml'); - var error = $('parsererror', doc); - console.log(error); - if (error.length == 0) { - doc = xml2htmlStylesheet.transformToFragment(doc, document); - error = $('parsererror', doc); - } - console.log('xml', doc); - if (error.length > 0) { - console.log(error); - $('#html-view').html('

Wystąpił błąd:

' + error.text() + '
'); - } else { - console.log('after transform', doc); - $('#html-view').html(doc.firstChild); - } - - $.unblockUI(); - }, 200); - }, function() { alert('Nie udało się załadować XSLT!'); }); -}; + var xml = options.xml.replace(/\/\s+/g, '
'); + var parser = new DOMParser(); + var serializer = new XMLSerializer(); + var doc = parser.parseFromString(xml, 'text/xml'); + var error = $('parsererror', doc); + + if (error.length == 0) { + doc = xml2htmlStylesheet.transformToFragment(doc, document); + error = $('parsererror', doc); + } + + if (error.length > 0 && options.error) { + options.error(error.text()); + } else { + options.success(doc.firstChild); + } + }, function() { options.error && options.success('Nie udało się załadować XSLT'); }); +} -function reverseTransform(editor) { - $.blockUI({message: 'Ładowanie...'}); +function html2xml(options) { withStylesheets(function() { - setTimeout(function() { - var doc = null; - var parser = new DOMParser(); - var serializer = new XMLSerializer(); - - if ($('#html-view .error').length > 0) { - $('#source-editor').unblock(); - return; - } - - doc = serializer.serializeToString($('#html-view div').get(0)) - doc = parser.parseFromString(doc, 'text/xml'); - console.log('xml',doc, doc.documentElement); - // TODO: Sprawdzenie błędów - var error = $('parsererror', doc.documentElement); + var xml = options.xml; + var parser = new DOMParser(); + var serializer = new XMLSerializer(); + var doc = parser.parseFromString(xml, 'text/xml'); + var error = $('parsererror', doc.documentElement); + + if (error.length == 0) { + doc = html2xmlStylesheet.transformToDocument(doc, document); + error = $('parsererror', doc.documentElement); + } + + if (error.length > 0 && options.error) { + options.error(error.text()); console.log(error); - if (error.length == 0) { - doc = html2xmlStylesheet.transformToDocument(doc, document); - error = $('parsererror', doc.documentElement); - } - - if (error.length > 0) { - console.log(error); - $('#source-editor').html('

Wystąpił błąd:

' + error.text()); - } else { - doc = serialize(doc.documentElement).join(''); - editor.setCode(doc); - } - - console.log('after transform', doc, doc.documentElement); - $.unblockUI(); - }, 200) - }, function() { alert('Nie udało się załadować XSLT!')}); + $('#source-editor').html('

Wystąpił błąd:

' + error.text()); + } else { + options.success(serialize(doc.documentElement).join('')); + } + }, function() { options.error && options.success('Nie udało się załadować XSLT'); }); };