| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076 | <?php/** * CodeIgniter * * An open source application development framework for PHP * * This content is released under the MIT License (MIT) * * Copyright (c) 2014 - 2017, 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 - 2017, 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;	}}
 |