mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-24 21:26:24 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			116 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| (function($) {  // Avoid conflicts with other libraries
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| // This callback finds the post from the delete link, and removes it.
 | |
| phpbb.add_ajax_callback('post_delete', function() {
 | |
| 	var el = $(this),
 | |
| 		post_id;
 | |
| 
 | |
| 	if (el.attr('data-refresh') === undefined)
 | |
| 	{
 | |
| 		post_id = el[0].href.split('&p=')[1];
 | |
| 		var post = el.parents('#p' + post_id).css('pointer-events', 'none');
 | |
| 		if (post.hasClass('bg1') || post.hasClass('bg2'))
 | |
| 		{
 | |
| 			var posts1 = post.nextAll('.bg1');
 | |
| 			post.nextAll('.bg2').removeClass('bg2').addClass('bg1');
 | |
| 			posts1.removeClass('bg1').addClass('bg2');
 | |
| 		}
 | |
| 		post.fadeOut(function() {
 | |
| 			$(this).remove();
 | |
| 		});
 | |
| 	}
 | |
| });
 | |
| 
 | |
| // This callback removes the approve / disapprove div or link.
 | |
| phpbb.add_ajax_callback('post_approve', function(res) {
 | |
| 	var remove = (res.approved) ? $(this) : $(this).parents('.post');
 | |
| 	$(remove).css('pointer-events', 'none').fadeOut(function() {
 | |
| 		$(this).remove();
 | |
| 	});
 | |
| });
 | |
| 
 | |
| // This removes the parent row of the link or form that fired the callback.
 | |
| phpbb.add_ajax_callback('row_delete', function() {
 | |
| 	$(this).parents('tr').remove();
 | |
| });
 | |
| 
 | |
| // This handles friend / foe additions removals.
 | |
| phpbb.add_ajax_callback('zebra', function(res) {
 | |
| 	var zebra;
 | |
| 
 | |
| 	if (res.success) {
 | |
| 		zebra = $('.zebra');
 | |
| 		zebra.first().html(res.MESSAGE_TEXT);
 | |
| 		zebra.not(':first').html(' ').prev().html(' ');
 | |
| 	}
 | |
| });
 | |
| 
 | |
| 
 | |
| 
 | |
| $('[data-ajax]').each(function() {
 | |
| 	var $this = $(this),
 | |
| 		ajax = $this.attr('data-ajax'),
 | |
| 		fn;
 | |
| 
 | |
| 	if (ajax !== 'false')
 | |
| 	{
 | |
| 		fn = (ajax !== 'true') ? ajax : null;
 | |
| 		phpbb.ajaxify({
 | |
| 			selector: this,
 | |
| 			refresh: $this.attr('data-refresh') !== undefined,
 | |
| 			callback: fn
 | |
| 		});
 | |
| 	}
 | |
| });
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * This simply appends #preview to the action of the
 | |
|  * QR action when you click the Full Editor & Preview button
 | |
|  */
 | |
| $('#qr_full_editor').click(function() {
 | |
| 	$('#qr_postform').attr('action', function(i, val) {
 | |
| 		return val + '#preview';
 | |
| 	});
 | |
| });
 | |
| 
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * This AJAXifies the quick-mod tools. The reason it cannot be a standard
 | |
|  * callback / data attribute is that it requires filtering - some of the options
 | |
|  * can be ajaxified, while others cannot.
 | |
|  */
 | |
| phpbb.ajaxify({
 | |
| 	selector: '#quickmodform',
 | |
| 	refresh: true,
 | |
| 	filter: function (data) {
 | |
| 		var action = $('#quick-mod-select').val();
 | |
| 
 | |
| 		if (action === 'make_normal')
 | |
| 		{
 | |
| 			return $(this).find('select option[value="make_global"]').length > 0;
 | |
| 		}
 | |
| 		else if (action === 'lock' || action === 'unlock')
 | |
| 		{
 | |
| 			return true;
 | |
| 		}
 | |
| 
 | |
| 		if (action === 'delete_topic' || action === 'make_sticky' || action === 'make_announce' || action === 'make_global') {
 | |
| 			return true;
 | |
| 		}
 | |
| 
 | |
| 		return false;
 | |
| 	}
 | |
| });
 | |
| 
 | |
| $('#quick-mod-select').change(function () {
 | |
| 	$('#quickmodform').submit();
 | |
| });
 | |
| 
 | |
| 
 | |
| 
 | |
| })(jQuery); // Avoid conflicts with other libraries
 |