Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
e7c1777a
Commit
e7c1777a
authored
May 01, 2013
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
form wip
parent
53a7b826
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
90 additions
and
46 deletions
+90
-46
yii.activeForm.js
framework/assets/yii.activeForm.js
+25
-10
yii.validation.js
framework/assets/yii.validation.js
+28
-2
BooleanValidator.php
framework/validators/BooleanValidator.php
+19
-11
RequiredValidator.php
framework/validators/RequiredValidator.php
+18
-23
No files found.
framework/assets/yii.activeForm.js
View file @
e7c1777a
...
@@ -23,6 +23,16 @@
...
@@ -23,6 +23,16 @@
};
};
var
defaults
=
{
var
defaults
=
{
enableAjaxValidation
:
false
,
enableClientValidation
:
true
,
// the URL for performing AJAX validation. If not set, it will use the the form's action
validationUrl
:
undefined
,
// number of milliseconds of validation delay. This is used when validateOnType is true.
validationDelay
:
200
,
// whether to perform validation when a change is detected on the input.
validateOnChange
:
true
,
// whether to perform validation when the user is typing.
validateOnType
:
false
,
// the container CSS class representing the corresponding attribute has validation error
// the container CSS class representing the corresponding attribute has validation error
errorCssClass
:
'error'
,
errorCssClass
:
'error'
,
// the container CSS class representing the corresponding attribute passes validation
// the container CSS class representing the corresponding attribute passes validation
...
@@ -43,17 +53,22 @@
...
@@ -43,17 +53,22 @@
* - input: string, the jQuery selector of the input field
* - input: string, the jQuery selector of the input field
* - error: string, the jQuery selector of the error tag
* - error: string, the jQuery selector of the error tag
* - value: string|array, the value of the input
* - value: string|array, the value of the input
* - validationDelay: integer, number of milliseconds of validation delay.
* This is used when validateOnType is true. If not set, it will take the value
* of the corresponding global setting.
* - validateOnChange: boolean, whether to perform validation when a change is detected on the input.
* If not set, it will take the value of the corresponding global setting.
* - validateOnType: boolean, defaults to false, whether to perform validation when the user is typing.
* If not set, it will take the value of the corresponding global setting.
* - enableAjaxValidation: boolean, whether to enable AJAX-based validation.
* If not set, it will take the value of the corresponding global setting.
* - enableClientValidation: boolean, whether to enable client-side validation.
* If not set, it will take the value of the corresponding global setting.
* - validate: function (attribute, value, messages), the client-side validation function.
* - beforeValidate: function ($form, attribute), callback called before validating an attribute. If it
* returns false, the validation will be cancelled.
* - afterValidate: function ($form, attribute, data, hasError), callback called after validating an attribute.
* - status: integer, 0: empty, not entered before, 1: validated, 2: pending validation, 3: validating
* - status: integer, 0: empty, not entered before, 1: validated, 2: pending validation, 3: validating
* - validationDelay: 200,
* - validateOnChange: true,
* - validateOnType: false,
* - hideErrorMessage: false,
* - inputContainer: undefined,
* - enableAjaxValidation: true,
* - enableClientValidation: true,
* - clientValidation: undefined, // function (value, messages, attribute) | client-side validation
* - beforeValidateAttribute: undefined, // function (form, attribute) | boolean
* - afterValidateAttribute: undefined, // function (form, attribute, data, hasError)
*
*
* @param options object the configuration for the plugin. The following options can be set:
* @param options object the configuration for the plugin. The following options can be set:
*/
*/
...
...
framework/assets/yii.validation.js
View file @
e7c1777a
...
@@ -11,7 +11,33 @@
...
@@ -11,7 +11,33 @@
*/
*/
yii
.
validation
=
(
function
(
$
)
{
yii
.
validation
=
(
function
(
$
)
{
var
pub
=
{
var
isEmpty
=
function
(
value
,
trim
)
{
return
value
===
null
||
value
===
undefined
||
value
==
[]
||
value
===
''
||
trim
&&
$
.
trim
(
value
)
===
''
;
};
return
{
required
:
function
(
value
,
messages
,
options
)
{
var
valid
=
false
;
if
(
options
.
requiredValue
===
undefined
)
{
if
(
options
.
strict
&&
value
!==
undefined
||
!
options
.
strict
&&
!
isEmpty
(
value
,
true
))
{
valid
=
true
;
}
}
else
if
(
!
options
.
strict
&&
value
==
options
.
requiredValue
||
options
.
strict
&&
value
===
options
.
requiredValue
)
{
valid
=
true
;
}
valid
||
messages
.
push
(
options
.
message
);
},
boolean
:
function
(
value
,
messages
,
options
)
{
if
(
options
.
skipOnEmpty
&&
isEmpty
(
value
))
{
return
;
}
var
valid
=
!
options
.
strict
&&
(
value
==
options
.
trueValue
||
value
==
options
.
falseValue
)
||
options
.
strict
&&
(
value
===
options
.
trueValue
||
value
===
options
.
falseValue
);
valid
||
messages
.
push
(
options
.
message
);
}
};
};
return
pub
;
})(
jQuery
);
})(
jQuery
);
framework/validators/BooleanValidator.php
View file @
e7c1777a
...
@@ -8,6 +8,7 @@
...
@@ -8,6 +8,7 @@
namespace
yii\validators
;
namespace
yii\validators
;
use
Yii
;
use
Yii
;
use
yii\helpers\Html
;
/**
/**
* BooleanValidator checks if the attribute value is a boolean value.
* BooleanValidator checks if the attribute value is a boolean value.
...
@@ -82,16 +83,23 @@ class BooleanValidator extends Validator
...
@@ -82,16 +83,23 @@ class BooleanValidator extends Validator
*/
*/
public
function
clientValidateAttribute
(
$object
,
$attribute
)
public
function
clientValidateAttribute
(
$object
,
$attribute
)
{
{
$message
=
strtr
(
$this
->
message
,
array
(
$options
[
'message'
]
=
array
(
'{attribute}'
=>
$object
->
getAttributeLabel
(
$attribute
),
'trueValue'
=>
$this
->
trueValue
,
'{value}'
=>
$object
->
$attribute
,
'falseValue'
=>
$this
->
falseValue
,
'{true}'
=>
$this
->
trueValue
,
'message'
=>
Html
::
encode
(
strtr
(
$this
->
message
,
array
(
'{false}'
=>
$this
->
falseValue
,
'{attribute}'
=>
$object
->
getAttributeLabel
(
$attribute
),
));
'{value}'
=>
$object
->
$attribute
,
return
"
'{true}'
=>
$this
->
trueValue
,
if("
.
(
$this
->
skipOnEmpty
?
"$.trim(value)!='' && "
:
''
)
.
"value!="
.
json_encode
(
$this
->
trueValue
)
.
" && value!="
.
json_encode
(
$this
->
falseValue
)
.
") {
'{false}'
=>
$this
->
falseValue
,
messages.push("
.
json_encode
(
$message
)
.
");
))),
}
);
"
;
if
(
$this
->
skipOnEmpty
)
{
$options
[
'skipOnEmpty'
]
=
1
;
}
if
(
$this
->
strict
)
{
$options
[
'strict'
]
=
1
;
}
return
'yii.validation.boolean(value, messages, '
.
json_encode
(
$options
)
.
');'
;
}
}
}
}
framework/validators/RequiredValidator.php
View file @
e7c1777a
...
@@ -8,6 +8,7 @@
...
@@ -8,6 +8,7 @@
namespace
yii\validators
;
namespace
yii\validators
;
use
Yii
;
use
Yii
;
use
yii\helpers\Html
;
/**
/**
* RequiredValidator validates that the specified attribute does not have null or empty value.
* RequiredValidator validates that the specified attribute does not have null or empty value.
...
@@ -60,13 +61,10 @@ class RequiredValidator extends Validator
...
@@ -60,13 +61,10 @@ class RequiredValidator extends Validator
*/
*/
public
function
validateAttribute
(
$object
,
$attribute
)
public
function
validateAttribute
(
$object
,
$attribute
)
{
{
$value
=
$object
->
$attribute
;
if
(
!
$this
->
validateValue
(
$object
->
$attribute
))
{
if
(
$this
->
requiredValue
===
null
)
{
if
(
$this
->
requiredValue
===
null
)
{
if
(
$this
->
strict
&&
$value
===
null
||
!
$this
->
strict
&&
$this
->
isEmpty
(
$value
,
true
))
{
$this
->
addError
(
$object
,
$attribute
,
$this
->
message
);
$this
->
addError
(
$object
,
$attribute
,
$this
->
message
);
}
}
else
{
}
else
{
if
(
!
$this
->
strict
&&
$value
!=
$this
->
requiredValue
||
$this
->
strict
&&
$value
!==
$this
->
requiredValue
)
{
$this
->
addError
(
$object
,
$attribute
,
$this
->
message
,
array
(
$this
->
addError
(
$object
,
$attribute
,
$this
->
message
,
array
(
'{requiredValue}'
=>
$this
->
requiredValue
,
'{requiredValue}'
=>
$this
->
requiredValue
,
));
));
...
@@ -99,27 +97,24 @@ class RequiredValidator extends Validator
...
@@ -99,27 +97,24 @@ class RequiredValidator extends Validator
*/
*/
public
function
clientValidateAttribute
(
$object
,
$attribute
)
public
function
clientValidateAttribute
(
$object
,
$attribute
)
{
{
$options
=
array
();
if
(
$this
->
requiredValue
!==
null
)
{
if
(
$this
->
requiredValue
!==
null
)
{
$message
=
strtr
(
$this
->
message
,
array
(
$options
[
'message'
]
=
strtr
(
$this
->
message
,
array
(
'{attribute}'
=>
$object
->
getAttributeLabel
(
$attribute
),
'{value}'
=>
$object
->
$attribute
,
'{requiredValue}'
=>
$this
->
requiredValue
,
'{requiredValue}'
=>
$this
->
requiredValue
,
));
));
return
"
$options
[
'requiredValue'
]
=
$this
->
requiredValue
;
if (value != "
.
json_encode
(
$this
->
requiredValue
)
.
") {
messages.push("
.
json_encode
(
$message
)
.
");
}
"
;
}
else
{
}
else
{
$message
=
strtr
(
$this
->
message
,
array
(
$options
[
'message'
]
=
$this
->
message
;
'{attribute}'
=>
$object
->
getAttributeLabel
(
$attribute
),
}
'{value}'
=>
$object
->
$attribute
,
if
(
$this
->
strict
)
{
));
$options
[
'strict'
]
=
1
;
return
"
if($.trim(value) == '') {
messages.push("
.
json_encode
(
$message
)
.
");
}
"
;
}
}
$options
[
'message'
]
=
Html
::
encode
(
strtr
(
$options
[
'message'
],
array
(
'{attribute}'
=>
$object
->
getAttributeLabel
(
$attribute
),
'{value}'
=>
$object
->
$attribute
,
)));
return
'yii.validation.required(value, messages, '
.
json_encode
(
$options
)
.
');'
;
}
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment