<?php /* SVN FILE: $Id$ */ /** * Javascript Helper class file. * * PHP versions 4 and 5 * * CakePHP : Rapid Development Framework <http://www.cakephp.org/> * Copyright (c) 2006, Cake Software Foundation, Inc. * 1785 E. Sahara Avenue, Suite 490-204 * Las Vegas, Nevada 89104 * * Licensed under The MIT License * Redistributions of files must retain the above copyright notice. * * @filesource * @copyright Copyright (c) 2006, Cake Software Foundation, Inc. * @link http://www.cakefoundation.org/projects/info/cakephp CakePHP Project * @package cake * @subpackage cake.cake.libs.view.helpers * @since CakePHP v 0.10.0.1076 * @version $Revision$ * @modifiedby $LastChangedBy$ * @lastmodified $Date$ * @license http://www.opensource.org/licenses/mit-license.php The MIT License */ /** * Javascript Helper class for easy use of JavaScript. * * JavascriptHelper encloses all methods needed while working with JavaScript. * * @package cake * @subpackage cake.cake.libs.view.helpers * @since CakePHP v 0.10.0.1076 */ class JavascriptHelper extends Helper { var $_cachedEvents = array(); var $_cacheEvents = false; /** * Returns a JavaScript script tag. * * @param string $script The JavaScript to be wrapped in SCRIPT tags. * @return string The full SCRIPT element, with the JavaScript inside it. */ function codeBlock($script) { return sprintf($this->tags['javascriptblock'], $script); } /** * Returns a JavaScript include tag (SCRIPT element) * * @param string $url URL to JavaScript file. * @return string */ function link($url) { if(strpos($url, ".") === false) $url .= ".js"; return sprintf($this->tags['javascriptlink'], $this->webroot.JS_URL.$this->themeWeb.$url); } /** * Returns a JavaScript include tag for an externally-hosted script * * @param string $url URL to JavaScript file. * @return string */ function linkOut($url) { if(strpos($url, ".") === false) $url .= ".js"; return sprintf($this->tags['javascriptlink'], $url); } /** * Escape carriage returns and single and double quotes for JavaScript segments. * * @param string $script string that might have javascript elements * @return string escaped string */ function escapeScript ($script) { $script = str_replace(array("\r\n","\n","\r"),'\n', $script); $script = str_replace(array('"', "'"), array('\"', "\\'"), $script); return $script; } /** * Escape a string to be JavaScript friendly. * * List of escaped ellements: * + "\r\n" => '\n' * + "\r" => '\n' * + "\n" => '\n' * + '"' => '\"' * + "'" => "\\'" * * @param string $script String that needs to get escaped. * @return string Escaped string. */ function escapeString($string) { $escape = array( "\r\n" => '\n', "\r" => '\n', "\n" => '\n', '"' => '\"', "'" => "\\'" ); return str_replace(array_keys($escape), array_values($escape), $string); } /** * Attach an event to an element. Used with the Prototype library. * * @param string $object Object to be observed * @param string $event event to observe * @param string $observer function to call * @param boolean $useCapture default true * @return boolean true on success */ function event ($object, $event, $observer, $useCapture = false) { if($useCapture == true) { $useCapture = "true"; } else { $useCapture = "false"; } $b = "Event.observe($object, '$event', function(event){ $observer }, $useCapture);"; if($this->_cacheEvents === true) { $this->_cachedEvents[] = $b; return true; } else { return $this->codeBlock($b); } } /** * Cache JavaScript events created with event() * * @return null */ function cacheEvents () { $this->_cacheEvents = true; } /** * Write cached JavaScript events * * @return string A single code block of all cached JavaScript events created with event() */ function writeEvents () { $this->_cacheEvents = false; return $this->codeBlock("\n" . implode("\n", $this->_cachedEvents) . "\n"); } /** * Includes the Prototype Javascript library (and anything else) inside a single script tag. * * Note: The recommended approach is to copy the contents of * javascripts into your application's * public/javascripts/ directory, and use @see javascriptIncludeTag() to * create remote script links. * @return string script with all javascript in/javascripts folder */ function includeScript ($script = "") { if($script == "") { $files = scandir(JS); $javascript = ''; foreach($files as $file) { if (substr($file, -3) == '.js') { $javascript .= file_get_contents(JS."{$file}") . "\n\n"; } } } else { $javascript = file_get_contents(JS."$script.js") . "\n\n"; } return $this->codeBlock("\n\n" . $javascript); } /** * Generates a JavaScript object in JavaScript Object Notation (JSON) * from an array * * @param array $data Data to be converted * @param boolean $block Wraps return value in a <script/> block if true * @param string $prefix Prepends the string to the returned data * @param string $postfix Appends the string to the returned data * @param array $stringKeys A list of array keys to be treated as a string * @param boolean $quoteKeys If false, treats $stringKey as a list of keys *not* to be quoted * @param string $q The type of quote to use * @return string A JSON code block */ function object ($data = array(), $block = false, $prefix = '', $postfix = '', $stringKeys = array(), $quoteKeys = true, $q = "\"") { if (is_object($data)) { $data = get_object_vars($data); } $out = array(); $key = array(); if (is_array($data)) { $keys = array_keys($data); } $numeric = true; if (!empty($keys)) { foreach ($keys as $key) { if (!is_numeric($key)) { $numeric = false; break; } } } foreach($data as $key => $val) { if (is_array($val) || is_object($val)) { $val = $this->object($val, false, '', '', $stringKeys, $quoteKeys, $q); $out[] = $val; } else { if ((!count($stringKeys) && !is_numeric($val) && !is_bool($val)) || ($quoteKeys && in_array($key, $stringKeys)) || (!$quoteKeys && !in_array($key, $stringKeys))) { $val = $q.$val.$q; } if (trim($val) == '') { $val = 'null'; } } if (!$numeric) { $val = $key.':'.$val; } $out[] = $val; } if (!$numeric) { $rt = '{'.join(', ', $out).'}'; } else { $rt = 'new Array('.join(', ', $out).')'; } $rt = $prefix.$rt.$postfix; if ($block) { $rt = $this->codeBlock($rt); } return $rt; } } ?>