Dotclear

source: admin/js/_post.js @ 2531:2daf216ff255

Revision 2531:2daf216ff255, 8.9 KB checked in by Nicolas <nikrou77@…>, 12 years ago (diff)

Refactoring of expandContent for list (entries, comments, trackback).
Addresses #1848

Line 
1dotclear.viewCommentContent = function(line,action) {
2     var commentId = $(line).attr('id').substr(1);
3     var tr = document.getElementById('ce'+commentId);
4
5     if (!tr) {
6          tr = document.createElement('tr');
7          tr.id = 'ce'+commentId;
8          var td = document.createElement('td');
9          td.colSpan = 6;
10          td.className = 'expand';
11          tr.appendChild(td);
12
13          // Get comment content
14          $.get('services.php',{f:'getCommentById',id: commentId},function(data) {
15               var rsp = $(data).children('rsp')[0];
16
17               if (rsp.attributes[0].value == 'ok') {
18                    var comment = $(rsp).find('comment_display_content').text();
19
20                    if (comment) {
21                         $(td).append(comment);
22                         var comment_email = $(rsp).find('comment_email').text();
23                         var comment_site = $(rsp).find('comment_site').text();
24                         var comment_ip = $(rsp).find('comment_ip').text();
25                         var comment_spam_disp = $(rsp).find('comment_spam_disp').text();
26
27                         $(td).append('<p><strong>' + dotclear.msg.website +
28                         '</strong> ' + comment_site + '<br />' +
29                         '<strong>' + dotclear.msg.email + '</strong> ' +
30                         comment_email + '<br />' + comment_spam_disp + '</p>');
31                    }
32               } else {
33                    alert($(rsp).find('message').text());
34               }
35          });
36
37          $(line).toggleClass('expand');
38          line.parentNode.insertBefore(tr,line.nextSibling);
39     }
40     else if (tr.style.display == 'none')
41     {
42          $(tr).toggle();
43          $(line).toggleClass('expand');
44     }
45     else
46     {
47          $(tr).toggle();
48          $(line).toggleClass('expand');
49     }
50};
51
52$(function() {
53     if (!document.getElementById) { return; }
54
55     if (document.getElementById('edit-entry'))
56     {
57          // Get document format and prepare toolbars
58          var formatField = $('#post_format').get(0);
59          var last_post_format = $(formatField).val();
60          $(formatField).change(function() {
61               // Confirm post format change
62               if(window.confirm(dotclear.msg.confirm_change_post_format_noconvert)){
63                    excerptTb.switchMode(this.value);
64                    contentTb.switchMode(this.value);
65                    last_post_format = $(this).val();
66               }else{
67                    // Restore last format if change cancelled
68                    $(this).val(last_post_format);
69               }
70               
71               $('.format_control > *').addClass('hide');
72               $('.format_control:not(.control_no_'+$(this).val()+') > *').removeClass('hide');
73          });
74
75          var excerptTb = new jsToolBar(document.getElementById('post_excerpt'));
76          var contentTb = new jsToolBar(document.getElementById('post_content'));
77          excerptTb.context = contentTb.context = 'post';
78     }
79
80     if (document.getElementById('comment_content')) {
81          var commentTb = new jsToolBar(document.getElementById('comment_content'));
82     }
83
84     // Post preview
85     $('#post-preview').modalWeb($(window).width()-40,$(window).height()-40);
86
87     // Tabs events
88     $('#edit-entry').onetabload(function() {
89          dotclear.hideLockable();
90
91          // Add date picker
92          var post_dtPick = new datePicker($('#post_dt').get(0));
93          post_dtPick.img_top = '1.5em';
94          post_dtPick.draw();
95
96          // Confirm post deletion
97          $('input[name="delete"]').click(function() {
98               return window.confirm(dotclear.msg.confirm_delete_post);
99          });
100
101          // Markup validator
102          var v = $('<div class="format_control"><p><a id="a-validator"></a></p><div/>').get(0);
103          $('.format_control').before(v);
104          var a = $('#a-validator').get(0);
105          a.href = '#';
106          a.className = 'button ';
107          $(a).click(function() {
108               
109               excerpt_content = $('#post_excerpt').css('display') != 'none' ? $('#post_excerpt').val() : $('#excerpt-area iframe').contents().find('body').html();
110               post_content   = $('#post_content').css('display') != 'none' ? $('#post_content').val() : $('#content-area iframe').contents().find('body').html();
111               
112               var params = {
113                    xd_check: dotclear.nonce,
114                    f: 'validatePostMarkup',
115                    excerpt: excerpt_content,
116                    content: post_content,
117                    format: $('#post_format').get(0).value,
118                    lang: $('#post_lang').get(0).value
119               };
120
121               $.post('services.php',params,function(data) {
122                    if ($(data).find('rsp').attr('status') != 'ok') {
123                         alert($(data).find('rsp message').text());
124                         return false;
125                    }
126                         
127                    $('.message, .success, .error, .warning-msg').remove();
128
129                    if ($(data).find('valid').text() == 1) {
130                         var p = document.createElement('p');
131                         p.id = 'markup-validator';
132                         
133                         $(p).addClass('success');
134                         $(p).text(dotclear.msg.xhtml_valid);
135                         $('#entry-content h3').after(p);
136                         $(p).backgroundFade({sColor: dotclear.fadeColor.beginValidatorMsg, eColor: dotclear.fadeColor.endValidatorMsg, steps: 50},function() {
137                                   $(this).backgroundFade({sColor: dotclear.fadeColor.endValidatorMsg, eColor: dotclear.fadeColor.beginValidatorMsg});
138                         });
139                    } else {
140                         var div = document.createElement('div');
141                         div.id = 'markup-validator';
142                         
143                         $(div).addClass('error');
144                         $(div).html('<p><strong>' + dotclear.msg.xhtml_not_valid + '</strong></p>' + $(data).find('errors').text());
145                         $('#entry-content h3').after(div);
146                         $(div).backgroundFade({sColor: dotclear.fadeColor.beginValidatorErr,eColor: dotclear.fadeColor.endValidatorErr, steps: 50},function() {
147                                   $(this).backgroundFade({sColor: dotclear.fadeColor.endValidatorErr, eColor: dotclear.fadeColor.beginValidatorErr});
148                         });
149                    }
150
151                    if ( $('#post_excerpt').text() != excerpt_content || $('#post_content').text() != post_content ) {
152                         var pn = document.createElement('p');
153                         $(pn).addClass('warning-msg');
154                         $(pn).text(dotclear.msg.warning_validate_no_save_content);
155                         $('#entry-content h3').after(pn);
156                    }
157
158                    return false;
159               });
160
161               return false;
162          });
163
164          a.appendChild(document.createTextNode(dotclear.msg.xhtml_validator));
165         
166          $('.format_control > *').addClass('hide');
167          $('.format_control:not(.control_no_'+last_post_format+') > *').removeClass('hide');
168
169          // Hide some fields
170          $('#notes-area label').toggleWithLegend($('#notes-area').children().not('label'),{
171               user_pref: 'dcx_post_notes',
172               legend_click:true,
173               hide: $('#post_notes').val() == ''
174          });
175          $('#post_lang').parent().children('label').toggleWithLegend($('#post_lang'),{
176               user_pref: 'dcx_post_lang',
177               legend_click: true
178          });
179          $('#post_password').parent().children('label').toggleWithLegend($('#post_password'),{
180               user_pref: 'dcx_post_password',
181               legend_click: true,
182               hide: $('#post_password').val() == ''
183          });
184          $('#post_status').parent().children('label').toggleWithLegend($('#post_status'),{
185               user_pref: 'dcx_post_status',
186               legend_click: true
187          });
188          $('#post_dt').parent().children('label').toggleWithLegend($('#post_dt').parent().children().not('label'),{
189               user_pref: 'dcx_post_dt',
190               legend_click: true
191          });
192          $('#label_format').toggleWithLegend($('#label_format').parent().children().not('#label_format'),{
193               user_pref: 'dcx_post_format',
194               legend_click: true
195          });
196          $('#label_cat_id').toggleWithLegend($('#label_cat_id').parent().children().not('#label_cat_id'),{
197               user_pref: 'dcx_cat_id',
198               legend_click: true
199          });
200          $('#create_cat').toggleWithLegend($('#create_cat').parent().children().not('#create_cat'),{
201               // no cookie on new category as we don't use this every day
202               legend_click: true
203          });
204          $('#label_comment_tb').toggleWithLegend($('#label_comment_tb').parent().children().not('#label_comment_tb'),{
205               user_pref: 'dcx_comment_tb',
206               legend_click: true
207          });
208          $('#post_url').parent().children('label').toggleWithLegend($('#post_url').parent().children().not('label'),{
209               user_pref: 'post_url',
210               legend_click: true
211          });
212          // We load toolbar on excerpt only when it's ready
213          $('#excerpt-area label').toggleWithLegend($('#excerpt-area').children().not('label'),{
214               user_pref: 'dcx_post_excerpt',
215               legend_click: true,
216               hide: $('#post_excerpt').val() == ''
217          });
218
219          // Load toolbars
220          contentTb.switchMode(formatField.value);
221          excerptTb.switchMode(formatField.value);
222
223          // Replace attachment remove links by a POST form submit
224          $('a.attachment-remove').click(function() {
225               this.href = '';
226               var m_name = $(this).parents('ul').find('li:first>a').attr('title');
227               if (window.confirm(dotclear.msg.confirm_remove_attachment.replace('%s',m_name))) {
228                    var f = $('#attachment-remove-hide').get(0);
229                    f.elements['media_id'].value = this.id.substring(11);
230                    f.submit();
231               }
232               return false;
233          });
234
235          // Check unsaved changes before XHTML conversion
236          var excerpt = $('#post_excerpt').val();
237          var content = $('#post_content').val();
238          $('#convert-xhtml').click(function() {
239               if (excerpt != $('#post_excerpt').val() || content != $('#post_content').val()) {
240                    return window.confirm(dotclear.msg.confirm_change_post_format);
241               }
242          });
243     });
244
245     $('#comments').onetabload(function() {
246          $.expandContent({
247               lines:$('#form-comments .comments-list tr.line'),
248               callback:dotclear.viewCommentContent
249          });
250          $('#form-comments .checkboxes-helpers').each(function() {
251               dotclear.checkboxesHelpers(this);
252          });
253
254          dotclear.commentsActionsHelper();
255     });
256
257     $('#trackbacks').onetabload(function() {
258          $.expandContent({
259               lines:$('#form-trackbacks .comments-list tr.line'),
260               callback:dotclear.viewCommentContent
261          });
262          $('#form-trackbacks .checkboxes-helpers').each(function() {
263               dotclear.checkboxesHelpers(this);
264          });
265
266          dotclear.commentsActionsHelper();
267     });
268
269     $('#add-comment').onetabload(function() {
270          commentTb.draw('xhtml');
271     });
272});
Note: See TracBrowser for help on using the repository browser.

Sites map