X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/b23f2eb2dba1c6e2c49f45362197b51eee60ac7c..ba6fd3dfb0d3241d4ce85fa43cd6e760d17db948:/platforma/static/js/main.js?ds=sidebyside diff --git a/platforma/static/js/main.js b/platforma/static/js/main.js index 2c20b9ca..cdcc21a8 100644 --- a/platforma/static/js/main.js +++ b/platforma/static/js/main.js @@ -94,7 +94,7 @@ function gallery(element, url) { element.data('images', []); function changePage(pageNumber) { - $('img', element).attr('src', element.data('images')[pageNumber - 1]); + $('.gallery-image img', element).attr('src', element.data('images')[pageNumber - 1]); } function normalizeNumber(pageNumber) { @@ -130,7 +130,7 @@ function gallery(element, url) { }); - var image = $('img', element).attr('unselectable', 'on'); + var image = $('.gallery-image img', element).attr('unselectable', 'on'); var origin = {}; var imageOrigin = {}; var zoomFactor = 1; @@ -145,7 +145,7 @@ function gallery(element, url) { }); $('.change-gallery', element).click(function() { $('.chosen-gallery').val($('#document-meta .gallery').html() || '/platforma/gallery/'); - $('.gallery-image').animate({top: 53}, 200); + $('.gallery-image').animate({top: 60}, 200); $('.chosen-gallery').focus(); }); $('.change-gallery-ok', element).click(function() { @@ -154,13 +154,13 @@ function gallery(element, url) { } $('#document-meta .gallery').html($('.chosen-gallery').val()); updateGallery($('.chosen-gallery').val()); - $('.gallery-image').animate({top: 27}, 200); + $('.gallery-image').animate({top: 30}, 200); }); $('.change-gallery-cancel', element).click(function() { - $('.gallery-image').animate({top: 27}, 200); + $('.gallery-image').animate({top: 30}, 200); }); - $('img', element).load(function() { + $('.gallery-image img', element).load(function() { image.css({width: null, height: null}); imageDimensions = { width: $(this).width() * zoomFactor, @@ -172,7 +172,7 @@ function gallery(element, url) { }; if (!(imageDimensions.width && imageDimensions.height)) { - setTimeout(function() { $('img', element).load(); }, 100); + setTimeout(function() { $('.gallery-image img', element).load(); }, 100); } var position = normalizePosition( image.position().left, @@ -269,14 +269,14 @@ function gallery(element, url) { element.data('images', data); pn.val(1); pn.change(); - $('img', element).show(); + $('.gallery-image img', element).show(); }, error: function(data) { element.data('images', []); pn.val(1); pn.change(); - $('img', element).hide(); + $('.gallery-image img', element).hide(); } }); } @@ -287,41 +287,65 @@ function gallery(element, url) { } -function transform(editor) { - $.blockUI({message: 'Ładowanie...'}); +function transform(editor, callback) { + if (!callback) { + $.blockUI({message: 'Ładowanie...'}); + } setTimeout(function() { xml2html({ xml: editor.getCode(), success: function(element) { $('#html-view').html(element); $.unblockUI(); + if (callback) { + callback(); + } }, error: function(text) { - $('#html-view').html('

Wystąpił błąd:

' + text + '
'); + var message = $('
');
+				message.text(text);
+                $('#html-view').html('

Wystąpił błąd:

' + 
+				    message.html() + '
'); + $.unblockUI(); + if (callback) { + callback(); + } } }); }, 200); }; -function reverseTransform(editor, cont) { +function reverseTransform(editor, cont, errorCont, dontBlock) { var serializer = new XMLSerializer(); if ($('#html-view .error').length > 0) { + if (errorCont) { + errorCont(); + } return; } - $.blockUI({message: 'Ładowanie...'}); + if (!dontBlock) { + $.blockUI({message: 'Ładowanie...'}); + } setTimeout(function() { - html2xml({ - xml: serializer.serializeToString($('#html-view div').get(0)), + html2text({ + element: $('#html-view div').get(0), success: function(text) { editor.setCode(text); - $.unblockUI(); + if (!dontBlock) { + $.unblockUI(); + } if (cont) { cont(); } }, error: function(text) { $('#source-editor').html('

Wystąpił błąd:

' + text + '
'); - $.unblockUI(); + if (!dontBlock) { + $.unblockUI(); + } + if (errorCont) { + errorCont(); + } } }); }, 200); @@ -373,6 +397,23 @@ function html(element) { return true; } + + var ANNOT_ALLOWED = ['wyroznienie']; + + function html2plainText(fragment) { + var text = ""; + + $(fragment.childNodes).each(function() { + if(this.nodeType == 3) // textNode + text += this.nodeValue; + else if (this.nodeType == 1 + && $.inArray($(this).attr('x-node'), ANNOT_ALLOWED) != -1 ){ + text += html2plainText(this); + } + }); + + return text; + } function addAnnotation() { @@ -398,7 +439,10 @@ function html(element) { return false; } - var text = range.toString(); + // BUG #273 - selected text can contain themes, which should be omited from + // defining term + var text = html2plainText( range.cloneContents() ); + var tag = $(''); range.collapse(false); range.insertNode(tag[0]); @@ -429,12 +473,20 @@ function html(element) { // for now allow only 1 range if(n > 1) { - window.alert("Zaznacz jeden obszar"); + window.alert("Zaznacz jeden obszar."); return false; } + // remember the selected range var range = selection.getRangeAt(0); + + + if( $(range.startContainer).is('.html-editarea') + || $(range.endContainer).is('.html-editarea') ) { + window.alert("Motywy można oznaczać tylko na tekście nie otwartym do edycji. \n Zamknij edytowany fragment i spróbuj ponownie."); + return false; + } // verify if the start/end points make even sense - // they must be inside a x-node (otherwise they will be discarded) @@ -471,7 +523,7 @@ function html(element) { etag.replaceWith(text); xml2html({ xml: '', - success: function(text) { + success: function(text) { mtag = $(''); spoint.insertNode(mtag[0]); mtag.replaceWith(text); @@ -543,9 +595,9 @@ function html(element) { var serializer = new XMLSerializer(); - html2xml({ - xml: serializer.serializeToString($box[0]), - inner: true, + html2text({ + element: $box[0], + stripOuter: true, success: function(text) { $('textarea', $overlay).val($.trim(text)); @@ -555,10 +607,16 @@ function html(element) { function save(argument) { var nodeName = $box.attr('x-node') || 'pe'; + var insertedText = $('textarea', $overlay).val(); + + if ($origin.is('.motyw')) { + insertedText = insertedText.replace(/,\s*$/, ''); + } + xml2html({ - xml: '<' + nodeName + '>' + $('textarea', $overlay).val() + '', + xml: '<' + nodeName + '>' + insertedText + '', success: function(element) { - $box.html($(element).html()); + $origin.html($(element).html()); $overlay.remove(); }, error: function(text) { @@ -601,6 +659,13 @@ function html(element) { if (!editable.hasClass('active')) { editable.addClass('active').append(button); } + if (editable.is('.annotation-inline-box')) { + $('*[x-annotation-box]', editable) + .css({position: 'absolute', left: event.clientX - editable.offset().left + 5, top: event.clientY - editable.offset().top + 5}) + .show(); + } else { + $('*[x-annotation-box]').hide(); + } }); $('.motyw').live('click', function() { @@ -618,6 +683,78 @@ function html(element) { }); } +/* + * History + */ + +function refreshHistory(callback){ + $.blockUI({ + message: 'Odświeżanie historii...' + }); + + $.ajax({ + url: document.location.href + '/history', + dataType: 'json', + error: function() { + $('#history-view .message-box').html('Nie udało się odświeżyć historii').show(); + $.unblockUI(); + }, + success: function(data) { + $('#history-view .message-box').hide(); + var changes_list = $('#changes-list'); + changes_list.html(''); + + $.each(data, function() { + var val = this[0]; + changes_list.append('' + +'' + + '' + +''+ this[0]+'' + +''+ this[3]+'' + +''+ this[2]+'' + +''+ this[1]+'') + }); + $.unblockUI(); + if(callback) callback(); + } + }); +}; + +function historyDiff(callback) { + var changelist = $('#changes-list'); + var rev_a = $("input[name='rev_from']:checked", changelist); + var rev_b = $("input[name='rev_to']:checked", changelist); + + if (rev_a.length != 1 || rev_b.length != 1) { + window.alert("Musisz zaznaczyć dwie wersje do porównania."); + return false; + } + + if (rev_a.val() == rev_b.val()) { + window.alert("Musisz zaznaczyć dwie różne wersje do porównania."); + return false; + } + + $.blockUI({ + message: 'Wczytywanie porównania...' + }); + + $.ajax({ + url: document.location.href + '/diff/'+rev_a.val() + '/'+ rev_b.val(), + dataType: 'html', + error: function() { + $.unblockUI(); + window.alert('Nie udało się wykonać porównania :(.') + }, + success: function(data) { + $.unblockUI(); + var diffview = $('#diff-view'); + diffview.html(data); + diffview.show(); + } + }); +} + $(function() { gallery('#sidebar', $('#document-meta .gallery').html()); @@ -630,8 +767,10 @@ $(function() { parserConfig: { useHTMLKludges: false }, - iframeClass: 'xml-iframe', + iframeClass: 'xml-iframe', textWrapping: true, + lineNumbers: true, + width: "100%", tabMode: 'spaces', indentUnit: 0, initCallback: function(editor) { @@ -654,7 +793,7 @@ $(function() { name: $('#document-name').html(), text: metaComment + editor.getCode(), revision: $('#document-revision').html(), - author: 'annonymous', + author: $('#username').html() || 'annonymous', comment: $('#komentarz').val() }; @@ -678,7 +817,7 @@ $(function() { }) } - if ('#simple-view-tab.active') { + if ($('#simple-view-tab').hasClass('active')) { reverseTransform(editor, doSave); } else { doSave(); @@ -688,36 +827,39 @@ $(function() { $('#save-cancel').click(function() { $.unblockUI(); }); - - $('#simple-view-tab').click(function() { - if ($(this).hasClass('active')) { - return; - } - $(this).addClass('active'); - $('#source-view-tab').removeClass('active'); - $('#source-editor').hide(); - $('#simple-editor').show(); - transform(editor); - }); - - $('#source-view-tab').click(function() { - if ($(this).hasClass('active')) { - return; - } - $(this).addClass('active'); - $('#simple-view-tab').removeClass('active'); - $('#simple-editor').hide(); - $('#source-editor').show(); - reverseTransform(editor); + + var tabs = $('ol#tabs li'); + + tabs.click(function(event, callback) { + tabs.removeClass('active'); + $('.editor').hide(); + $(this).addClass('active'); + $('#' + $(this).attr('ui:related')).show(); + $(this).trigger('wl:tabload', callback); + }); + + + $('#simple-view-tab').bind('wl:tabload', function(event, callback) { + transform(editor, callback); }); + + $('#source-view-tab').bind('wl:tabload', function(event, callback) { + reverseTransform(editor, callback); + }); + + $('#history-view-tab').bind('wl:tabload', function(event, callback) { + refreshHistory(callback); + }); + + $('#make-diff-button').click(historyDiff); $('#source-editor .toolbar button').click(function(event) { event.preventDefault(); var params = eval("(" + $(this).attr('ui:action-params') + ")"); scriptletCenter.scriptlets[$(this).attr('ui:action')](editor, params); - }); + }); - $('.toolbar select').change(function() { + $('.toolbar select').change(function(event) { var slug = $(this).val(); $('.toolbar-buttons-container').hide().filter('[data-group=' + slug + ']').show(); @@ -727,7 +869,12 @@ $(function() { $('.toolbar-buttons-container').hide(); $('.toolbar select').change(); - $('#simple-view-tab').click(); + + $('#simple-view-tab').trigger('click', + function() { + $('#loading-overlay').fadeOut(); + return false; + }); } }); @@ -740,15 +887,18 @@ $(function() { $('.vsplitbar').click(function() { if ($('#sidebar').width() == 0) { $('#sidebar').width(480).css({right: 0}).show(); - $('#source-editor, #simple-editor').css({right: 495}); + $('#editor .editor').css({right: 495}); $('.vsplitbar').css({right: 480}).addClass('active'); } else { $('#sidebar').width(0).hide(); - $('#source-editor, #simple-editor').css({right: 15}); + $('#editor .editor').css({right: 15}); $('.vsplitbar').css({right: 0}).removeClass('active'); } $(window).resize(); }); - + + $(window).bind('beforeunload', function(event) { + return "Na stronie mogą być niezapisane zmiany."; + }); });