maxLength = $maxLength; $this->restrictedField = $restrictedField; $this->restrictedTable = $restrictedTable; $this->validateURL = $validationURL; $this->restrictedRegex = $restrictedRegex; parent::__construct($name, $title, $value); } function Field() { Requirements::add_i18n_javascript(SAPPHIRE_DIR . '/javascript/lang'); Requirements::javascript(SAPPHIRE_DIR . "/javascript/UniqueFields.js"); $this->jsValidation(); $url = Convert::raw2att( $this->validateURL ); if($this->restrictedRegex) $restrict = "name}Restricted\" id=\"" . $this->id() . "RestrictedRegex\" value=\"{$this->restrictedRegex}\" />"; $attributes = array( 'type' => 'text', 'class' => 'text' . ($this->extraClass() ? $this->extraClass() : ''), 'id' => $this->id(), 'name' => $this->Name(), 'value' => $this->Value(), 'tabindex' => $this->getTabIndex(), 'maxlength' => ($this->maxLength) ? $this->maxLength : null ); return $this->createTag('input', $attributes); } function jsValidation() { $formID = $this->form->FormName(); $id = $this->id(); $url = Director::absoluteBaseURL() . $this->validateURL; if($this->restrictedRegex) { $jsCheckFunc = <<restrictedRegex}/); if(match) { Element.addClassName(this, 'invalid'); return false; } return true; JS; } else { $jsCheckFunc = "return true;"; } $jsFunc = <<name}=' + encodeURIComponent(this.value), { method: 'get', onSuccess: function(response) { if(response.responseText == 'ok') Element.removeClassName(this, 'inuse'); else { Element.addClassName(this, 'inuse'); } }.bind(this), onFailure: function(response) { } }); } }, checkValid: function() { $jsCheckFunc } } }); JS; Requirements::customScript($jsFunc, 'func_validateAjaxUniqueTextField'); //return "\$('$formID').validateCurrency('$this->name');"; } function validate( $validator ) { $result = DB::query(sprintf( "SELECT COUNT(*) FROM `%s` WHERE `%s` = '%s'", $this->restrictedTable, $this->restrictedField, Convert::raw2sql($this->value) ))->value(); if( $result && ( $result > 0 ) ) { $validator->validationError( $this->name, _t('Form.VALIDATIONNOTUNIQUE', "The value entered is not unique") ); return false; } return true; } } ?>