mirror of https://github.com/helloxz/imgurl.git
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 - 2018, 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 - 2018, 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; |
|
} |
|
|
|
}
|
|
|