mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-26 05:06:12 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			382 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			382 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| var phpbb = {};
 | |
| phpbb.alert_time = 100;
 | |
| 
 | |
| (function($) {  // Avoid conflicts with other libraries
 | |
| 
 | |
| // define a couple constants for keydown functions.
 | |
| var ENTER = 13,
 | |
| 	ESC = 27;
 | |
| 
 | |
| 
 | |
| var dark = $('#darkenwrapper'),
 | |
| 	loading_alert = $('#loadingalert');
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Display a loading screen.
 | |
|  *
 | |
|  * @returns object Returns loading_alert.
 | |
|  */
 | |
| phpbb.loading_alert = function() {
 | |
| 	if (dark.is(':visible'))
 | |
| 	{
 | |
| 		loading_alert.fadeIn(phpbb.alert_time);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		loading_alert.show();
 | |
| 		dark.fadeIn(phpbb.alert_time, function() {
 | |
| 			// Wait five seconds and display an error if nothing has been returned by then.
 | |
| 			setTimeout(function() {
 | |
| 				if (loading_alert.is(':visible'))
 | |
| 				{
 | |
| 					phpbb.alert($('body').data('l-err'), $('body').data('l-timeout-processing-req'));
 | |
| 				}
 | |
| 			}, 5000);
 | |
| 		});
 | |
| 	}
 | |
| 
 | |
| 	return loading_alert;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Display a simple alert similar to JSs native alert().
 | |
|  *
 | |
|  * You can only call one alert or confirm box at any one time.
 | |
|  *
 | |
|  * @param string title Title of the message, eg "Information" (HTML).
 | |
|  * @param string msg Message to display (HTML).
 | |
|  * @param bool fadedark Remove the dark background when done? Defaults
 | |
|  * 	to yes.
 | |
|  *
 | |
|  * @returns object Returns the div created.
 | |
|  */
 | |
| phpbb.alert = function(title, msg, fadedark) {
 | |
| 	var div = $('#phpbb_alert');
 | |
| 	div.find('.alert_title').html(title);
 | |
| 	div.find('.alert_text').html(msg);
 | |
| 
 | |
| 	div.bind('click', function(e) {
 | |
| 		e.stopPropagation();
 | |
| 		return true;
 | |
| 	});
 | |
| 	dark.one('click', function(e) {
 | |
| 		div.find('.alert_close').unbind('click');
 | |
| 		var fade = (typeof fadedark !== 'undefined' && !fadedark) ? div : dark;
 | |
| 		fade.fadeOut(phpbb.alert_time, function() {
 | |
| 			div.hide();
 | |
| 		});
 | |
| 		return false;
 | |
| 	});
 | |
| 
 | |
| 	$(document).bind('keydown', function(e) {
 | |
| 		if (e.keyCode === ENTER || e.keyCode === ESC) {
 | |
| 			dark.trigger('click');
 | |
| 			return false;
 | |
| 		}
 | |
| 		return true;
 | |
| 	});
 | |
| 
 | |
| 	div.find('.alert_close').one('click', function() {
 | |
| 		dark.trigger('click');
 | |
| 	});
 | |
| 
 | |
| 	if (loading_alert.is(':visible'))
 | |
| 	{
 | |
| 		loading_alert.fadeOut(phpbb.alert_time, function() {
 | |
| 			dark.append(div);
 | |
| 			div.fadeIn(phpbb.alert_time);
 | |
| 		});
 | |
| 	}
 | |
| 	else if (dark.is(':visible'))
 | |
| 	{
 | |
| 		dark.append(div);
 | |
| 		div.fadeIn(phpbb.alert_time);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		dark.append(div);
 | |
| 		div.show();
 | |
| 		dark.fadeIn(phpbb.alert_time);
 | |
| 	}
 | |
| 
 | |
| 	return div;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Display a simple yes / no box to the user.
 | |
|  *
 | |
|  * You can only call one alert or confirm box at any one time.
 | |
|  *
 | |
|  * @param string msg Message to display (HTML).
 | |
|  * @param function callback Callback. Bool param, whether the user pressed
 | |
|  * 	yes or no (or whatever their language is).
 | |
|  * @param bool fadedark Remove the dark background when done? Defaults
 | |
|  * 	to yes.
 | |
|  *
 | |
|  * @returns object Returns the div created.
 | |
|  */
 | |
| phpbb.confirm = function(msg, callback, fadedark) {
 | |
| 	var div = $('#phpbb_confirm');
 | |
| 	div.find('.alert_text').html(msg);
 | |
| 
 | |
| 	div.bind('click', function(e) {
 | |
| 		e.stopPropagation();
 | |
| 		return true;
 | |
| 	});
 | |
| 	
 | |
| 	var click_handler = function() {
 | |
| 		var res = this.className === 'button1';
 | |
| 		var fade = (typeof fadedark !== 'undefined' && !fadedark && res) ? div : dark;
 | |
| 		fade.fadeOut(phpbb.alert_time, function() {
 | |
| 			div.hide();
 | |
| 		});
 | |
| 		div.find('input[type="button"]').unbind('click', click_handler);
 | |
| 		callback(res);
 | |
| 		return false;
 | |
| 	};
 | |
| 	div.find('input[type="button"]').one('click', click_handler);
 | |
| 
 | |
| 	dark.one('click', function(e) {
 | |
| 		div.find('.alert_close').unbind('click');
 | |
| 		dark.fadeOut(phpbb.alert_time, function() {
 | |
| 			div.hide();
 | |
| 		});
 | |
| 		callback(false);
 | |
| 		return false;
 | |
| 	});
 | |
| 
 | |
| 	$(document).bind('keydown', function(e) {
 | |
| 		if (e.keyCode === ENTER) {
 | |
| 			$('input[type="button"].button1').trigger('click');
 | |
| 			return false;
 | |
| 		} else if (e.keyCode === ESC) {
 | |
| 			$('input[type="button"].button2').trigger('click');
 | |
| 			return false;
 | |
| 		}
 | |
| 		return true;
 | |
| 	});
 | |
| 
 | |
| 	div.find('.alert_close').one('click', function() {
 | |
| 		var fade = (typeof fadedark !== 'undefined' && fadedark) ? div : dark;
 | |
| 		fade.fadeOut(phpbb.alert_time, function() {
 | |
| 			div.hide();
 | |
| 		});
 | |
| 		callback(false);
 | |
| 	});
 | |
| 
 | |
| 	if (loading_alert.is(':visible'))
 | |
| 	{
 | |
| 		loading_alert.fadeOut(phpbb.alert_time, function() {
 | |
| 			dark.append(div);
 | |
| 			div.fadeIn(phpbb.alert_time);
 | |
| 		});
 | |
| 	}
 | |
| 	else if (dark.is(':visible'))
 | |
| 	{
 | |
| 		dark.append(div);
 | |
| 		div.fadeIn(phpbb.alert_time);
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		dark.append(div);
 | |
| 		div.show();
 | |
| 		dark.fadeIn(phpbb.alert_time);
 | |
| 	}
 | |
| 
 | |
| 	return div;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Turn a querystring into an array.
 | |
|  *
 | |
|  * @argument string string The querystring to parse.
 | |
|  * @returns object The object created.
 | |
|  */
 | |
| phpbb.parse_querystring = function(string) {
 | |
| 	var params = {}, i, split;
 | |
| 
 | |
| 	string = string.split('&');
 | |
| 	for (i = 0; i < string.length; i++)
 | |
| 	{
 | |
| 		split = string[i].split('=');
 | |
| 		params[split[0]] = decodeURIComponent(split[1]);
 | |
| 	}
 | |
| 	return params;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Makes a link use AJAX instead of loading an entire page.
 | |
|  *
 | |
|  * This function will work for links (both standard links and links which
 | |
|  * invoke confirm_box) and forms. It will be called automatically for links
 | |
|  * and forms with the data-ajax attribute set, and will call the necessary
 | |
|  * callback.
 | |
|  *
 | |
|  * For more info, view the following page on the phpBB wiki:
 | |
|  * http://wiki.phpbb.com/JavaScript_Function.phpbb.ajaxify
 | |
|  *
 | |
|  * @param object options Options, if a string will be the selector.
 | |
|  * @param bool/function refresh If we are sent back a refresh, should it be
 | |
|  * 	acted upon? This can either be true / false / a function.
 | |
|  * @param function callback Callback to call on completion of event. Has
 | |
|  * 	three parameters: the element that the event was evoked from, the JSON
 | |
|  * 	that was returned and (if it is a form) the form action.
 | |
|  */
 | |
| phpbb.ajaxify = function(options, refresh, callback) {
 | |
| 	var selector = $((typeof options === 'string') ? options : options.selector);
 | |
| 	var is_form = selector.is('form');
 | |
| 	if (is_form)
 | |
| 	{
 | |
| 		selector = selector.find('input:submit');
 | |
| 	}
 | |
| 
 | |
| 	selector.click(function() {
 | |
| 		var action, data, path, that = this, $this = $(this);
 | |
| 
 | |
| 		if ($this.data('ajax') == false)
 | |
| 		{
 | |
| 			return true;
 | |
| 		}
 | |
| 
 | |
| 		/**
 | |
| 		 * This is a private function used to handle the callbacks, refreshes
 | |
| 		 * and alert. It calls the callback, refreshes the page if necessary, and
 | |
| 		 * displays an alert to the user and removes it after an amount of time.
 | |
| 		 *
 | |
| 		 * It cannot be called from outside this function, and is purely here to
 | |
| 		 * avoid repetition of code.
 | |
| 		 *
 | |
| 		 * @param object res The object sent back by the server.
 | |
| 		 */
 | |
| 		function return_handler(res)
 | |
| 		{
 | |
| 			if (typeof res.S_CONFIRM_ACTION === 'undefined')
 | |
| 			{
 | |
| 				// It is a standard link, no confirm_box required.
 | |
| 				if (typeof res.MESSAGE_TITLE !== 'undefined')
 | |
| 				{
 | |
| 					var alert = phpbb.alert(res.MESSAGE_TITLE, res.MESSAGE_TEXT);
 | |
| 				}
 | |
| 				else
 | |
| 				{
 | |
| 					dark.fadeOut(phpbb.alert_time);
 | |
| 				}
 | |
| 
 | |
| 				if (typeof phpbb.ajax_callbacks[callback] === 'function')
 | |
| 				{
 | |
| 					phpbb.ajax_callbacks[callback].call(that, res, (is_form) ? act : null);
 | |
| 				}
 | |
| 
 | |
| 				if (res.REFRESH_DATA)
 | |
| 				{
 | |
| 					if (typeof refresh === 'function')
 | |
| 					{
 | |
| 						refresh = refresh(res.REFRESH_DATA.url);
 | |
| 					}
 | |
| 					else if (typeof refresh !== 'boolean')
 | |
| 					{
 | |
| 						refresh = false;
 | |
| 					}
 | |
| 
 | |
| 					setTimeout(function() {
 | |
| 						if (refresh)
 | |
| 						{
 | |
| 							window.location = res.REFRESH_DATA.url;
 | |
| 						}
 | |
| 
 | |
| 						dark.fadeOut(phpbb.alert_time, function() {
 | |
| 							alert.hide();
 | |
| 						});
 | |
| 					}, res.REFRESH_DATA.time * 1000);
 | |
| 				}
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				// confirm_box - confirm with the user and send back
 | |
| 				phpbb.confirm(res.MESSAGE_TEXT, function(del) {
 | |
| 					if (del)
 | |
| 					{
 | |
| 						phpbb.loading_alert();
 | |
| 						data =  $('<form>' + res.S_HIDDEN_FIELDS + '</form>').serialize();
 | |
| 						$.post(res.S_CONFIRM_ACTION, data + '&confirm=' + res.YES_VALUE, return_handler);
 | |
| 					}
 | |
| 				}, false);
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		var run_exception = (typeof options.exception === 'function');
 | |
| 		if (is_form)
 | |
| 		{
 | |
| 			action = /action\[([a-z]+)\]/.exec(this.name);
 | |
| 			data = decodeURI($this.closest('form').serialize());
 | |
| 			path = $this.closest('form').attr('action').replace('&', '&');
 | |
| 
 | |
| 			if (action)
 | |
| 			{
 | |
| 				action = action[1]
 | |
| 				data += '&action=' + action;
 | |
| 			}
 | |
| 			else
 | |
| 			{
 | |
| 				data += '&' + this.name + '=' + this.value;
 | |
| 			}
 | |
| 
 | |
| 			if (run_exception && options.exception.call($this.parents('form')[0], action, data))
 | |
| 			{
 | |
| 				return true;
 | |
| 			}
 | |
| 			phpbb.loading_alert();
 | |
| 			$.post(path, data, return_handler);
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			if (run_exception && options.exception.call(this))
 | |
| 			{
 | |
| 				return true;
 | |
| 			}
 | |
| 			phpbb.loading_alert();
 | |
| 			$.get(this.href, return_handler);
 | |
| 		}
 | |
| 
 | |
| 		return false;
 | |
| 	});
 | |
| 	return this;
 | |
| }
 | |
| 
 | |
| phpbb.ajax_callbacks = {};
 | |
| 
 | |
| /**
 | |
|  * Adds an AJAX callback to be used by phpbb.ajaxify.
 | |
|  *
 | |
|  * See the phpbb.ajaxify comments for information on stuff like parameters.
 | |
|  *
 | |
|  * @param string id The name of the callback.
 | |
|  * @param function callback The callback to be called.
 | |
|  */
 | |
| phpbb.add_ajax_callback = function(id, callback)
 | |
| {
 | |
| 	if (typeof callback === 'function')
 | |
| 	{
 | |
| 		phpbb.ajax_callbacks[id] = callback;
 | |
| 	}
 | |
| 	return this;
 | |
| }
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * This callback alternates text - it replaces the current text with the text in
 | |
|  * the alt-text data attribute, and replaces the text in the attribute with the
 | |
|  * current text so that the process can be repeated.
 | |
|  */
 | |
| phpbb.add_ajax_callback('alt_text', function(el) {
 | |
| 	el = $(el);
 | |
| 	var alt_text = el.data('alt-text');
 | |
| 	el.data('alt-text', el.text());
 | |
| 	el.text(el[0].title = alt_text);
 | |
| });
 | |
| 
 | |
| 
 | |
| })(jQuery); // Avoid conflicts with other libraries
 |