You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							1076 lines
						
					
					
						
							25 KiB
						
					
					
				
			
		
		
	
	
							1076 lines
						
					
					
						
							25 KiB
						
					
					
				<?php | 
						|
/** | 
						|
 * CodeIgniter | 
						|
 * | 
						|
 * An open source application development framework for PHP | 
						|
 * | 
						|
 * This content is released under the MIT License (MIT) | 
						|
 * | 
						|
 * Copyright (c) 2014 - 2016, British Columbia Institute of Technology | 
						|
 * | 
						|
 * Permission is hereby granted, free of charge, to any person obtaining a copy | 
						|
 * of this software and associated documentation files (the "Software"), to deal | 
						|
 * in the Software without restriction, including without limitation the rights | 
						|
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | 
						|
 * copies of the Software, and to permit persons to whom the Software is | 
						|
 * furnished to do so, subject to the following conditions: | 
						|
 * | 
						|
 * The above copyright notice and this permission notice shall be included in | 
						|
 * all copies or substantial portions of the Software. | 
						|
 * | 
						|
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | 
						|
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
						|
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | 
						|
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
						|
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | 
						|
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | 
						|
 * THE SOFTWARE. | 
						|
 * | 
						|
 * @package	CodeIgniter | 
						|
 * @author	EllisLab Dev Team | 
						|
 * @copyright	Copyright (c) 2008 - 2014, EllisLab, Inc. (https://ellislab.com/) | 
						|
 * @copyright	Copyright (c) 2014 - 2016, British Columbia Institute of Technology (http://bcit.ca/) | 
						|
 * @license	http://opensource.org/licenses/MIT	MIT License | 
						|
 * @link	https://codeigniter.com | 
						|
 * @since	Version 1.0.0 | 
						|
 * @filesource | 
						|
 */ | 
						|
defined('BASEPATH') OR exit('No direct script access allowed'); | 
						|
 | 
						|
/** | 
						|
 * Jquery Class | 
						|
 * | 
						|
 * @package		CodeIgniter | 
						|
 * @subpackage	Libraries | 
						|
 * @category	Loader | 
						|
 * @author		EllisLab Dev Team | 
						|
 * @link		https://codeigniter.com/user_guide/libraries/javascript.html | 
						|
 */ | 
						|
class CI_Jquery extends CI_Javascript { | 
						|
 | 
						|
	/** | 
						|
	 * JavaScript directory location | 
						|
	 * | 
						|
	 * @var	string | 
						|
	 */ | 
						|
	protected $_javascript_folder = 'js'; | 
						|
 | 
						|
	/** | 
						|
	 * JQuery code for load | 
						|
	 * | 
						|
	 * @var	array | 
						|
	 */ | 
						|
	public $jquery_code_for_load = array(); | 
						|
 | 
						|
	/** | 
						|
	 * JQuery code for compile | 
						|
	 * | 
						|
	 * @var	array | 
						|
	 */ | 
						|
	public $jquery_code_for_compile = array(); | 
						|
 | 
						|
	/** | 
						|
	 * JQuery corner active flag | 
						|
	 * | 
						|
	 * @var	bool | 
						|
	 */ | 
						|
	public $jquery_corner_active = FALSE; | 
						|
 | 
						|
	/** | 
						|
	 * JQuery table sorter active flag | 
						|
	 * | 
						|
	 * @var	bool | 
						|
	 */ | 
						|
	public $jquery_table_sorter_active = FALSE; | 
						|
 | 
						|
	/** | 
						|
	 * JQuery table sorter pager active | 
						|
	 * | 
						|
	 * @var	bool | 
						|
	 */ | 
						|
	public $jquery_table_sorter_pager_active = FALSE; | 
						|
 | 
						|
	/** | 
						|
	 * JQuery AJAX image | 
						|
	 * | 
						|
	 * @var	string | 
						|
	 */ | 
						|
	public $jquery_ajax_img = ''; | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Constructor | 
						|
	 * | 
						|
	 * @param	array	$params | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	public function __construct($params) | 
						|
	{ | 
						|
		$this->CI =& get_instance(); | 
						|
		extract($params); | 
						|
 | 
						|
		if ($autoload === TRUE) | 
						|
		{ | 
						|
			$this->script(); | 
						|
		} | 
						|
 | 
						|
		log_message('info', 'Jquery Class Initialized'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
	// Event Code | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Blur | 
						|
	 * | 
						|
	 * Outputs a jQuery blur event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _blur($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'blur'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Change | 
						|
	 * | 
						|
	 * Outputs a jQuery change event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _change($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'change'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Click | 
						|
	 * | 
						|
	 * Outputs a jQuery click event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @param	bool	whether or not to return false | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _click($element = 'this', $js = '', $ret_false = TRUE) | 
						|
	{ | 
						|
		is_array($js) OR $js = array($js); | 
						|
 | 
						|
		if ($ret_false) | 
						|
		{ | 
						|
			$js[] = 'return false;'; | 
						|
		} | 
						|
 | 
						|
		return $this->_add_event($element, $js, 'click'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Double Click | 
						|
	 * | 
						|
	 * Outputs a jQuery dblclick event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _dblclick($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'dblclick'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Error | 
						|
	 * | 
						|
	 * Outputs a jQuery error event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _error($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'error'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Focus | 
						|
	 * | 
						|
	 * Outputs a jQuery focus event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _focus($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'focus'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Hover | 
						|
	 * | 
						|
	 * Outputs a jQuery hover event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- Javascript code for mouse over | 
						|
	 * @param	string	- Javascript code for mouse out | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _hover($element = 'this', $over = '', $out = '') | 
						|
	{ | 
						|
		$event = "\n\t$(".$this->_prep_element($element).").hover(\n\t\tfunction()\n\t\t{\n\t\t\t{$over}\n\t\t}, \n\t\tfunction()\n\t\t{\n\t\t\t{$out}\n\t\t});\n"; | 
						|
 | 
						|
		$this->jquery_code_for_compile[] = $event; | 
						|
 | 
						|
		return $event; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Keydown | 
						|
	 * | 
						|
	 * Outputs a jQuery keydown event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _keydown($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'keydown'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Keyup | 
						|
	 * | 
						|
	 * Outputs a jQuery keydown event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _keyup($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'keyup'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Load | 
						|
	 * | 
						|
	 * Outputs a jQuery load event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _load($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'load'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Mousedown | 
						|
	 * | 
						|
	 * Outputs a jQuery mousedown event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _mousedown($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'mousedown'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Mouse Out | 
						|
	 * | 
						|
	 * Outputs a jQuery mouseout event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _mouseout($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'mouseout'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Mouse Over | 
						|
	 * | 
						|
	 * Outputs a jQuery mouseover event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _mouseover($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'mouseover'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Mouseup | 
						|
	 * | 
						|
	 * Outputs a jQuery mouseup event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _mouseup($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'mouseup'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Output | 
						|
	 * | 
						|
	 * Outputs script directly | 
						|
	 * | 
						|
	 * @param	array	$array_js = array() | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	protected function _output($array_js = array()) | 
						|
	{ | 
						|
		if ( ! is_array($array_js)) | 
						|
		{ | 
						|
			$array_js = array($array_js); | 
						|
		} | 
						|
 | 
						|
		foreach ($array_js as $js) | 
						|
		{ | 
						|
			$this->jquery_code_for_compile[] = "\t".$js."\n"; | 
						|
		} | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Resize | 
						|
	 * | 
						|
	 * Outputs a jQuery resize event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _resize($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'resize'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Scroll | 
						|
	 * | 
						|
	 * Outputs a jQuery scroll event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _scroll($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'scroll'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Unload | 
						|
	 * | 
						|
	 * Outputs a jQuery unload event | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _unload($element = 'this', $js = '') | 
						|
	{ | 
						|
		return $this->_add_event($element, $js, 'unload'); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
	// Effects | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Add Class | 
						|
	 * | 
						|
	 * Outputs a jQuery addClass event | 
						|
	 * | 
						|
	 * @param	string	$element | 
						|
	 * @param	string	$class | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _addClass($element = 'this', $class = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		return '$('.$element.').addClass("'.$class.'");'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Animate | 
						|
	 * | 
						|
	 * Outputs a jQuery animate event | 
						|
	 * | 
						|
	 * @param	string	$element | 
						|
	 * @param	array	$params | 
						|
	 * @param	string	$speed	'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	$extra | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _animate($element = 'this', $params = array(), $speed = '', $extra = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		$animations = "\t\t\t"; | 
						|
 | 
						|
		foreach ($params as $param => $value) | 
						|
		{ | 
						|
			$animations .= $param.": '".$value."', "; | 
						|
		} | 
						|
 | 
						|
		$animations = substr($animations, 0, -2); // remove the last ", " | 
						|
 | 
						|
		if ($speed !== '') | 
						|
		{ | 
						|
			$speed = ', '.$speed; | 
						|
		} | 
						|
 | 
						|
		if ($extra !== '') | 
						|
		{ | 
						|
			$extra = ', '.$extra; | 
						|
		} | 
						|
 | 
						|
		return "$({$element}).animate({\n$animations\n\t\t}".$speed.$extra.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Fade In | 
						|
	 * | 
						|
	 * Outputs a jQuery hide event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _fadeIn($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return "$({$element}).fadeIn({$speed}{$callback});"; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Fade Out | 
						|
	 * | 
						|
	 * Outputs a jQuery hide event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _fadeOut($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return '$('.$element.').fadeOut('.$speed.$callback.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Hide | 
						|
	 * | 
						|
	 * Outputs a jQuery hide action | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _hide($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return "$({$element}).hide({$speed}{$callback});"; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Remove Class | 
						|
	 * | 
						|
	 * Outputs a jQuery remove class event | 
						|
	 * | 
						|
	 * @param	string	$element | 
						|
	 * @param	string	$class | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _removeClass($element = 'this', $class = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		return '$('.$element.').removeClass("'.$class.'");'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Slide Up | 
						|
	 * | 
						|
	 * Outputs a jQuery slideUp event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _slideUp($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return '$('.$element.').slideUp('.$speed.$callback.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Slide Down | 
						|
	 * | 
						|
	 * Outputs a jQuery slideDown event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _slideDown($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return '$('.$element.').slideDown('.$speed.$callback.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Slide Toggle | 
						|
	 * | 
						|
	 * Outputs a jQuery slideToggle event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _slideToggle($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return '$('.$element.').slideToggle('.$speed.$callback.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Toggle | 
						|
	 * | 
						|
	 * Outputs a jQuery toggle event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _toggle($element = 'this') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		return '$('.$element.').toggle();'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Toggle Class | 
						|
	 * | 
						|
	 * Outputs a jQuery toggle class event | 
						|
	 * | 
						|
	 * @param	string	$element | 
						|
	 * @param	string	$class | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _toggleClass($element = 'this', $class = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		return '$('.$element.').toggleClass("'.$class.'");'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Show | 
						|
	 * | 
						|
	 * Outputs a jQuery show event | 
						|
	 * | 
						|
	 * @param	string	- element | 
						|
	 * @param	string	- One of 'slow', 'normal', 'fast', or time in milliseconds | 
						|
	 * @param	string	- Javascript callback function | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _show($element = 'this', $speed = '', $callback = '') | 
						|
	{ | 
						|
		$element = $this->_prep_element($element); | 
						|
		$speed = $this->_validate_speed($speed); | 
						|
 | 
						|
		if ($callback !== '') | 
						|
		{ | 
						|
			$callback = ", function(){\n{$callback}\n}"; | 
						|
		} | 
						|
 | 
						|
		return '$('.$element.').show('.$speed.$callback.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Updater | 
						|
	 * | 
						|
	 * An Ajax call that populates the designated DOM node with | 
						|
	 * returned content | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	the controller to run the call against | 
						|
	 * @param	string	optional parameters | 
						|
	 * @return	string | 
						|
	 */ | 
						|
 | 
						|
	protected function _updater($container = 'this', $controller = '', $options = '') | 
						|
	{ | 
						|
		$container = $this->_prep_element($container); | 
						|
		$controller = (strpos('://', $controller) === FALSE) ? $controller : $this->CI->config->site_url($controller); | 
						|
 | 
						|
		// ajaxStart and ajaxStop are better choices here... but this is a stop gap | 
						|
		if ($this->CI->config->item('javascript_ajax_img') === '') | 
						|
		{ | 
						|
			$loading_notifier = 'Loading...'; | 
						|
		} | 
						|
		else | 
						|
		{ | 
						|
			$loading_notifier = '<img src="'.$this->CI->config->slash_item('base_url').$this->CI->config->item('javascript_ajax_img').'" alt="Loading" />'; | 
						|
		} | 
						|
 | 
						|
		$updater = '$('.$container.").empty();\n" // anything that was in... get it out | 
						|
			."\t\t$(".$container.').prepend("'.$loading_notifier."\");\n"; // to replace with an image | 
						|
 | 
						|
		$request_options = ''; | 
						|
		if ($options !== '') | 
						|
		{ | 
						|
			$request_options .= ', {' | 
						|
					.(is_array($options) ? "'".implode("', '", $options)."'" : "'".str_replace(':', "':'", $options)."'") | 
						|
					.'}'; | 
						|
		} | 
						|
 | 
						|
		return $updater."\t\t$($container).load('$controller'$request_options);"; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
	// Pre-written handy stuff | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Zebra tables | 
						|
	 * | 
						|
	 * @param	string	$class | 
						|
	 * @param	string	$odd | 
						|
	 * @param	string	$hover | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _zebraTables($class = '', $odd = 'odd', $hover = '') | 
						|
	{ | 
						|
		$class = ($class !== '') ? '.'.$class : ''; | 
						|
		$zebra = "\t\$(\"table{$class} tbody tr:nth-child(even)\").addClass(\"{$odd}\");"; | 
						|
 | 
						|
		$this->jquery_code_for_compile[] = $zebra; | 
						|
 | 
						|
		if ($hover !== '') | 
						|
		{ | 
						|
			$hover = $this->hover("table{$class} tbody tr", "$(this).addClass('hover');", "$(this).removeClass('hover');"); | 
						|
		} | 
						|
 | 
						|
		return $zebra; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
	// Plugins | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Corner Plugin | 
						|
	 * | 
						|
	 * @link	http://www.malsup.com/jquery/corner/ | 
						|
	 * @param	string	$element | 
						|
	 * @param	string	$corner_style | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	public function corner($element = '', $corner_style = '') | 
						|
	{ | 
						|
		// may want to make this configurable down the road | 
						|
		$corner_location = '/plugins/jquery.corner.js'; | 
						|
 | 
						|
		if ($corner_style !== '') | 
						|
		{ | 
						|
			$corner_style = '"'.$corner_style.'"'; | 
						|
		} | 
						|
 | 
						|
		return '$('.$this->_prep_element($element).').corner('.$corner_style.');'; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Modal window | 
						|
	 * | 
						|
	 * Load a thickbox modal window | 
						|
	 * | 
						|
	 * @param	string	$src | 
						|
	 * @param	bool	$relative | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	public function modal($src, $relative = FALSE) | 
						|
	{ | 
						|
		$this->jquery_code_for_load[] = $this->external($src, $relative); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Effect | 
						|
	 * | 
						|
	 * Load an Effect library | 
						|
	 * | 
						|
	 * @param	string	$src | 
						|
	 * @param	bool	$relative | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	public function effect($src, $relative = FALSE) | 
						|
	{ | 
						|
		$this->jquery_code_for_load[] = $this->external($src, $relative); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Plugin | 
						|
	 * | 
						|
	 * Load a plugin library | 
						|
	 * | 
						|
	 * @param	string	$src | 
						|
	 * @param	bool	$relative | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	public function plugin($src, $relative = FALSE) | 
						|
	{ | 
						|
		$this->jquery_code_for_load[] = $this->external($src, $relative); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * UI | 
						|
	 * | 
						|
	 * Load a user interface library | 
						|
	 * | 
						|
	 * @param	string	$src | 
						|
	 * @param	bool	$relative | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	public function ui($src, $relative = FALSE) | 
						|
	{ | 
						|
		$this->jquery_code_for_load[] = $this->external($src, $relative); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Sortable | 
						|
	 * | 
						|
	 * Creates a jQuery sortable | 
						|
	 * | 
						|
	 * @param	string	$element | 
						|
	 * @param	array	$options | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	public function sortable($element, $options = array()) | 
						|
	{ | 
						|
		if (count($options) > 0) | 
						|
		{ | 
						|
			$sort_options = array(); | 
						|
			foreach ($options as $k=>$v) | 
						|
			{ | 
						|
				$sort_options[] = "\n\t\t".$k.': '.$v; | 
						|
			} | 
						|
			$sort_options = implode(',', $sort_options); | 
						|
		} | 
						|
		else | 
						|
		{ | 
						|
			$sort_options = ''; | 
						|
		} | 
						|
 | 
						|
		return '$('.$this->_prep_element($element).').sortable({'.$sort_options."\n\t});"; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Table Sorter Plugin | 
						|
	 * | 
						|
	 * @param	string	table name | 
						|
	 * @param	string	plugin location | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	public function tablesorter($table = '', $options = '') | 
						|
	{ | 
						|
		$this->jquery_code_for_compile[] = "\t$(".$this->_prep_element($table).').tablesorter('.$options.");\n"; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
	// Class functions | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Add Event | 
						|
	 * | 
						|
	 * Constructs the syntax for an event, and adds to into the array for compilation | 
						|
	 * | 
						|
	 * @param	string	The element to attach the event to | 
						|
	 * @param	string	The code to execute | 
						|
	 * @param	string	The event to pass | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _add_event($element, $js, $event) | 
						|
	{ | 
						|
		if (is_array($js)) | 
						|
		{ | 
						|
			$js = implode("\n\t\t", $js); | 
						|
		} | 
						|
 | 
						|
		$event = "\n\t$(".$this->_prep_element($element).').'.$event."(function(){\n\t\t{$js}\n\t});\n"; | 
						|
		$this->jquery_code_for_compile[] = $event; | 
						|
		return $event; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Compile | 
						|
	 * | 
						|
	 * As events are specified, they are stored in an array | 
						|
	 * This function compiles them all for output on a page | 
						|
	 * | 
						|
	 * @param	string	$view_var | 
						|
	 * @param	bool	$script_tags | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	protected function _compile($view_var = 'script_foot', $script_tags = TRUE) | 
						|
	{ | 
						|
		// External references | 
						|
		$external_scripts = implode('', $this->jquery_code_for_load); | 
						|
		$this->CI->load->vars(array('library_src' => $external_scripts)); | 
						|
 | 
						|
		if (count($this->jquery_code_for_compile) === 0) | 
						|
		{ | 
						|
			// no inline references, let's just return | 
						|
			return; | 
						|
		} | 
						|
 | 
						|
		// Inline references | 
						|
		$script = '$(document).ready(function() {'."\n" | 
						|
			.implode('', $this->jquery_code_for_compile) | 
						|
			.'});'; | 
						|
 | 
						|
		$output = ($script_tags === FALSE) ? $script : $this->inline($script); | 
						|
 | 
						|
		$this->CI->load->vars(array($view_var => $output)); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Clear Compile | 
						|
	 * | 
						|
	 * Clears the array of script events collected for output | 
						|
	 * | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	protected function _clear_compile() | 
						|
	{ | 
						|
		$this->jquery_code_for_compile = array(); | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Document Ready | 
						|
	 * | 
						|
	 * A wrapper for writing document.ready() | 
						|
	 * | 
						|
	 * @param	array	$js | 
						|
	 * @return	void | 
						|
	 */ | 
						|
	protected function _document_ready($js) | 
						|
	{ | 
						|
		is_array($js) OR $js = array($js); | 
						|
 | 
						|
		foreach ($js as $script) | 
						|
		{ | 
						|
			$this->jquery_code_for_compile[] = $script; | 
						|
		} | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Script Tag | 
						|
	 * | 
						|
	 * Outputs the script tag that loads the jquery.js file into an HTML document | 
						|
	 * | 
						|
	 * @param	string	$library_src | 
						|
	 * @param	bool	$relative | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	public function script($library_src = '', $relative = FALSE) | 
						|
	{ | 
						|
		$library_src = $this->external($library_src, $relative); | 
						|
		$this->jquery_code_for_load[] = $library_src; | 
						|
		return $library_src; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Prep Element | 
						|
	 * | 
						|
	 * Puts HTML element in quotes for use in jQuery code | 
						|
	 * unless the supplied element is the Javascript 'this' | 
						|
	 * object, in which case no quotes are added | 
						|
	 * | 
						|
	 * @param	string | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _prep_element($element) | 
						|
	{ | 
						|
		if ($element !== 'this') | 
						|
		{ | 
						|
			$element = '"'.$element.'"'; | 
						|
		} | 
						|
 | 
						|
		return $element; | 
						|
	} | 
						|
 | 
						|
	// -------------------------------------------------------------------- | 
						|
 | 
						|
	/** | 
						|
	 * Validate Speed | 
						|
	 * | 
						|
	 * Ensures the speed parameter is valid for jQuery | 
						|
	 * | 
						|
	 * @param	string | 
						|
	 * @return	string | 
						|
	 */ | 
						|
	protected function _validate_speed($speed) | 
						|
	{ | 
						|
		if (in_array($speed, array('slow', 'normal', 'fast'))) | 
						|
		{ | 
						|
			return '"'.$speed.'"'; | 
						|
		} | 
						|
		elseif (preg_match('/[^0-9]/', $speed)) | 
						|
		{ | 
						|
			return ''; | 
						|
		} | 
						|
 | 
						|
		return $speed; | 
						|
	} | 
						|
 | 
						|
}
 | 
						|
 |