mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
MINOR: reverted r93693 due to the field being required for the CMS
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/branches/2.4@93701 467b73ca-7a2a-4603-9d3b-597d59a354a9
This commit is contained in:
parent
e46a8b8a13
commit
a188d2439b
30
forms/RestrictedTextField.php
Executable file
30
forms/RestrictedTextField.php
Executable file
@ -0,0 +1,30 @@
|
||||
<?php
|
||||
/**
|
||||
* A Text field that cannot contain certain characters
|
||||
* @deprecated 2.3
|
||||
* @package forms
|
||||
* @subpackage fields-formatted
|
||||
*/
|
||||
class RestrictedTextField extends TextField {
|
||||
|
||||
protected $restrictedChars;
|
||||
|
||||
function __construct($name, $title = null, $value = "", $restrictedChars = "", $maxLength = null){
|
||||
$this->restrictedChars = $restrictedChars;
|
||||
parent::__construct($name, $title, $value);
|
||||
}
|
||||
|
||||
function Field() {
|
||||
Requirements::add_i18n_javascript(SAPPHIRE_DIR . '/javascript/lang');
|
||||
Requirements::javascript( SAPPHIRE_DIR . '/javascript/UniqueFields.js' );
|
||||
|
||||
if($this->maxLength){
|
||||
$field = "<input class=\"text restricted\" type=\"text\" id=\"" . $this->id() . "\" name=\"{$this->name}\" value=\"" . $this->attrValue() . "\" maxlength=\"$this->maxLength\" />";
|
||||
}else{
|
||||
$field = "<input class=\"text restricted\" type=\"text\" id=\"" . $this->id() . "\" name=\"{$this->name}\" value=\"" . $this->attrValue() . "\" />";
|
||||
}
|
||||
|
||||
return $field."<input type=\"hidden\" name=\"restricted-chars[".$this->id()."]\" id=\"".$this->id()."-restricted-chars\" value=\"".$this->restrictedChars."\" />";
|
||||
}
|
||||
}
|
||||
?>
|
27
forms/UniqueRestrictedTextField.php
Executable file
27
forms/UniqueRestrictedTextField.php
Executable file
@ -0,0 +1,27 @@
|
||||
<?php
|
||||
/**
|
||||
* Text field that automatically checks that the value entered is unique for the given
|
||||
* set of fields in a given set of tables
|
||||
* @deprecated 2.3
|
||||
* @package forms
|
||||
* @subpackage fields-formattedinput
|
||||
*/
|
||||
class UniqueRestrictedTextField extends UniqueTextField {
|
||||
|
||||
protected $charRegex;
|
||||
protected $charReplacement;
|
||||
protected $charMessage;
|
||||
|
||||
function __construct($name, $restrictedField, $restrictedTable, $restrictedMessage, $charRegex, $charReplacement, $charMessage, $title = null, $value = "", $maxLength = null ){
|
||||
$this->charRegex = $charRegex;
|
||||
$this->charReplacement = $charReplacement;
|
||||
$this->charMessage = $charMessage;
|
||||
|
||||
parent::__construct($name, $restrictedField, $restrictedTable, $restrictedMessage, $title, $value, $maxLength);
|
||||
}
|
||||
|
||||
function Field() {
|
||||
return parent::Field()."<input type=\"hidden\" name=\"restricted-chars[".$this->id()."]\" id=\"".$this->id()."-restricted-chars\" value=\"".$this->charRegex."\" /><input type=\"hidden\" name=\"restricted-chars[".$this->id()."]\" id=\"".$this->id()."-restricted-chars-replace\" value=\"".$this->charReplacement."\" /><input type=\"hidden\" name=\"restricted-chars[".$this->id()."]\" id=\"".$this->id()."-restricted-chars-message\" value=\"".$this->charMessage."\" />";
|
||||
}
|
||||
}
|
||||
?>
|
@ -36,3 +36,114 @@ UniqueFormField.prototype = {
|
||||
return suggested;
|
||||
}
|
||||
}
|
||||
|
||||
UniqueRestrictedTextField = Class.extend('UniqueFormField');
|
||||
UniqueRestrictedTextField.applyTo('input.UniqueRestrictedTextField');
|
||||
UniqueRestrictedTextField.prototype = {
|
||||
initialize: function() {
|
||||
this.loadMessages();
|
||||
if(this.loadRestrictedValues){ this.loadRestrictedValues()};
|
||||
this.loadRestrictedChars();
|
||||
this.onblur = this.validate.bind(this);
|
||||
},
|
||||
loadRestrictedChars: function() {
|
||||
this.charRegex = new RegExp( $(this.id + '-restricted-chars').value, 'g' );
|
||||
this.charReplacement = $(this.id + '-restricted-chars-replace').value;
|
||||
this.trimRegex = new RegExp( '^[' + this.charReplacement + ']+|[' + this.charReplacement + ']+$', 'g' );
|
||||
},
|
||||
suggestNewValue: function( fromString ) {
|
||||
var prefix = '';
|
||||
var count = 1;
|
||||
var suggested = fromString || this.value;
|
||||
|
||||
if( suggested.length == 0 ) {
|
||||
suggested = $('Form_EditForm_Title').value.toLowerCase();
|
||||
}
|
||||
|
||||
var escaped = suggested.replace(this.charRegex, this.charReplacement);
|
||||
escaped = escaped.replace( this.trimRegex, '' );
|
||||
|
||||
// this.loadRestrictedValues is never called, i think someone missed a function..
|
||||
if(this.restrictedValues){
|
||||
if( !this.restrictedValues[escaped] )
|
||||
return escaped;
|
||||
}
|
||||
|
||||
var prefix = escaped;
|
||||
|
||||
if( prefix.charAt(prefix.length-1) != this.charReplacement )
|
||||
prefix = prefix + this.charReplacement;
|
||||
|
||||
suggested = prefix;
|
||||
suggested = suggested.replace( this.charRegex, this.charReplacement );
|
||||
suggested = suggested.replace( this.trimRegex, '' );
|
||||
|
||||
if(this.restrictedValues){
|
||||
while( this.restrictedValues[suggested] ) {
|
||||
suggested = prefix + (++count);
|
||||
suggested = suggested.replace( this.charRegex, this.charReplacement );
|
||||
suggested = suggested.replace( this.trimRegex, '' );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return suggested;
|
||||
},
|
||||
validate: function() {
|
||||
// check that the value is not in use, and matches the pattern
|
||||
var suggested = this.value;
|
||||
if(this.restrictedValues){
|
||||
var suggestedValue = this.restrictedValues[suggested];
|
||||
}
|
||||
|
||||
if( suggested == null || suggested.length == 0 || suggestedValue || suggested.match( this.charRegex ) ) {
|
||||
var message;
|
||||
if( suggested == null )
|
||||
message = ss.i18n._t('UNIQUEFIELD.ENTERNEWVALUE', 'You will need to enter a new value for this field');
|
||||
else if( suggested.length == 0 )
|
||||
message = ss.i18n._t('UNIQUEFIELD.CANNOTLEAVEEMPTY', 'This field cannot be left empty');
|
||||
else if( suggestedValue )
|
||||
message = this.restrictedMessage;
|
||||
else
|
||||
message = this.charMessage;
|
||||
|
||||
suggested = this.suggestNewValue();
|
||||
statusMessage(ss.i18n.sprintf(
|
||||
ss.i18n._t('UNIQUEFIELD.SUGGESTED', "Changed value to '%s' : %s"),
|
||||
suggested,
|
||||
message
|
||||
));
|
||||
}
|
||||
|
||||
this.value = suggested;
|
||||
},
|
||||
loadMessages: function() {
|
||||
this.restrictedMessage = $(this.id + '-restricted-message').value;
|
||||
this.charMessage = $(this.id + '-restricted-chars-message').value;
|
||||
}
|
||||
}
|
||||
|
||||
RestrictedTextField = Class.create();
|
||||
RestrictedTextField.applyTo('input.text.restricted');
|
||||
RestrictedTextField.prototype = {
|
||||
|
||||
initialize: function() {
|
||||
this.restrictedChars = $(this.id + '-restricted-chars').value;
|
||||
// this.restrictedRegex = new RegExp( $(this.id.'-restricted-chars').value, 'g' );
|
||||
},
|
||||
|
||||
onkeyup: function() {
|
||||
|
||||
var lastChar = this.value.charAt(this.value.length - 1);
|
||||
|
||||
for( var index = 0; index < this.restrictedChars.length; index++ ) {
|
||||
if( lastChar == this.restrictedChars.charAt(index) ) {
|
||||
alert(ss.i18n.sprintf(
|
||||
ss.i18n._t('RESTRICTEDTEXTFIELD.CHARCANTBEUSED', "The character '%s' cannot be used in this field"),
|
||||
lastChar
|
||||
));
|
||||
this.value = this.value.substring( 0, this.value.length - 1 );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user