MINOR Merged from trunk

git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.3@72384 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
Ingo Schommer 2009-03-03 02:42:35 +00:00 committed by Sam Minnee
parent 3222a080a4
commit dd6ff797e2
2 changed files with 63 additions and 22 deletions

View File

@ -546,7 +546,7 @@ class Requirements_Backend {
function includeInHTML($templateFile, $content) { function includeInHTML($templateFile, $content) {
if(isset($_GET['debug_profile'])) Profiler::mark("Requirements::includeInHTML"); if(isset($_GET['debug_profile'])) Profiler::mark("Requirements::includeInHTML");
if(strpos($content, '</head') !== false && ($this->javascript || $this->css || $this->customScript || $this->customHeadTags)) { if(strpos($content, '</head') !== false && ($this->css || $this->javascript || $this->customCSS || $this->customScript || $this->customHeadTags)) {
$requirements = ''; $requirements = '';
$jsRequirements = ''; $jsRequirements = '';

View File

@ -14,56 +14,93 @@
* @subpackage validators * @subpackage validators
*/ */
abstract class Validator extends Object { abstract class Validator extends Object {
/**
* @var Form $form
*/
protected $form; protected $form;
/**
* @var array $errors
*/
protected $errors; protected $errors;
/** /**
* Static for default value of $this->javascriptValidationHandler. * Static for default value of $this->javascriptValidationHandler.
* Set with Validator::set_javascript_validation_handler(); * Set with Validator::set_javascript_validation_handler();
* @var string
*/ */
protected static $javascript_validation_handler = null; protected static $javascript_validation_handler = "prototype";
/** /**
* Handler for javascript validation. Can be "prototype" or "none" * Handler for javascript validation. Can be "prototype" or "none".
* @var string
*/ */
protected $javascriptValidationHandler = "prototype"; protected $javascriptValidationHandler = null;
/** /**
* Call this function to set the javascript validation handler for all valdiation on your site. * Call this function to set the javascript validation handler for all valdiation on your site.
* This could be called from _config.php to set site-wide javascript validation, or from ContentController::init() * This could be called from _config.php to set site-wide javascript validation, or from ContentController::init()
* to affect only the front-end site. * to affect only the front-end site.
* Use instance method {@link setJavascriptValidationHandler()} to
* only set handler for a specific form instance.
* *
* @param $handler A string representing the handler to use: 'prototype' or 'none'. * @param $handler A string representing the handler to use: 'prototype' or 'none'.
* @todo Add 'jquery' as a handler option. * @todo Add 'jquery' as a handler option.
*/ */
public function set_javascript_validation_handler($handler = 'prototype') { public static function set_javascript_validation_handler($handler) {
self::$javascript_validation_handler = $handler;
}
/**
* Disable JavaScript validation for this validator
*/
public function setJavascriptValidationHandler($handler) {
if($handler == 'prototype' || $handler == 'none') { if($handler == 'prototype' || $handler == 'none') {
$this->javascriptValidationHandler = $handler; self::$javascript_validation_handler = $handler;
} else { } else {
user_error("Validator::setJavascriptValidationHandler() passed bad handler '$handler'", E_USER_WARNING); user_error("Validator::setJavascriptValidationHandler() passed bad handler '$handler'", E_USER_WARNING);
} }
} }
public function __construct() { /**
if(self::$javascript_validation_handler) $this->setJavascriptValidationHandler(self::$javascript_validation_handler); * Returns global validation handler used for all forms by default,
* unless overwritten by {@link setJavascriptValidationHandler()}.
if($this->javascriptValidationHandler && $this->javascriptValidationHandler != 'none') { *
Requirements::javascript(SAPPHIRE_DIR . '/javascript/Validator.js'); * @return string
*/
public static function get_javascript_validator_handler() {
return self::$javascript_validation_handler;
}
/**
* Set JavaScript validation for this validator.
* Use static method {@link set_javascript_validation_handler()}
* to set handlers globally.
*
* @param string $handler
*/
public function setJavascriptValidationHandler($handler) {
if($handler == 'prototype' || $handler == 'none') {
$this->javascriptValidationHandler = $handler;
} else {
user_error("Validator::setJavascriptValidationHandler() passed bad handler '$handler'", E_USER_WARNING);
} }
parent::__construct(); }
/**
* Gets the current javascript validation handler for this form.
* If not set, falls back to the global static {@link self::$javascript_validation_handler}.
*
* @return string
*/
public function getJavascriptValidationHandler() {
return ($this->javascriptValidationHandler) ? $this->javascriptValidationHandler : self::$javascript_validation_handler;
} }
/**
* @param Form $form
*/
function setForm($form) { function setForm($form) {
$this->form = $form; $this->form = $form;
} }
/**
* @return array Errors (if any)
*/
function validate(){ function validate(){
$this->errors = null; $this->errors = null;
$this->php($this->form->getData()); $this->php($this->form->getData());
@ -86,8 +123,11 @@ abstract class Validator extends Object {
); );
} }
function showError(){ /**
debug::show($this->errors); * @deprecated 2.4 Use Validator->getCombinedError() and custom code
*/
function showError() {
Debug::show($this->errors);
} }
function getCombinedError(){ function getCombinedError(){
@ -109,10 +149,11 @@ abstract class Validator extends Object {
} }
function includeJavascriptValidation() { function includeJavascriptValidation() {
if($this->javascriptValidationHandler == 'prototype') { if($this->getJavascriptValidationHandler() == 'prototype') {
Requirements::javascript(THIRDPARTY_DIR . "/prototype.js"); Requirements::javascript(THIRDPARTY_DIR . "/prototype.js");
Requirements::javascript(THIRDPARTY_DIR . "/behaviour.js"); Requirements::javascript(THIRDPARTY_DIR . "/behaviour.js");
Requirements::javascript(THIRDPARTY_DIR . "/prototype_improvements.js"); Requirements::javascript(THIRDPARTY_DIR . "/prototype_improvements.js");
//Requirements::add_i18n_javascript(SAPPHIRE_DIR);
Requirements::javascript(SAPPHIRE_DIR . "/javascript/i18n.js"); Requirements::javascript(SAPPHIRE_DIR . "/javascript/i18n.js");
Requirements::javascript(SAPPHIRE_DIR . "/javascript/Validator.js"); Requirements::javascript(SAPPHIRE_DIR . "/javascript/Validator.js");