Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
ef02c5c7
Commit
ef02c5c7
authored
Nov 03, 2020
by
Dave Pisek
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Feedback: Make validity reporting clearer
* Renaming of parameter * Add more comments to explain the behavior
parent
ed884e74
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
14 deletions
+27
-14
app/assets/javascripts/vue_shared/directives/validation.js
app/assets/javascripts/vue_shared/directives/validation.js
+27
-14
No files found.
app/assets/javascripts/vue_shared/directives/validation.js
View file @
ef02c5c7
...
@@ -3,6 +3,7 @@ import { s__ } from '~/locale';
...
@@ -3,6 +3,7 @@ import { s__ } from '~/locale';
/**
/**
* Validation messages will take priority based on the property order.
* Validation messages will take priority based on the property order.
*
* For example:
* For example:
* { valueMissing: {...}, urlTypeMismatch: {...} }
* { valueMissing: {...}, urlTypeMismatch: {...} }
*
*
...
@@ -34,7 +35,7 @@ const focusFirstInvalidInput = e => {
...
@@ -34,7 +35,7 @@ const focusFirstInvalidInput = e => {
const
isEveryFieldValid
=
form
=>
Object
.
values
(
form
.
fields
).
every
(({
state
})
=>
state
===
true
);
const
isEveryFieldValid
=
form
=>
Object
.
values
(
form
.
fields
).
every
(({
state
})
=>
state
===
true
);
const
createValidator
=
(
context
,
feedbackMap
)
=>
({
el
,
report
Validity
=
false
})
=>
{
const
createValidator
=
(
context
,
feedbackMap
)
=>
({
el
,
report
InvalidInput
=
false
})
=>
{
const
{
form
}
=
context
;
const
{
form
}
=
context
;
const
{
name
}
=
el
;
const
{
name
}
=
el
;
...
@@ -51,26 +52,38 @@ const createValidator = (context, feedbackMap) => ({ el, reportValidity = false
...
@@ -51,26 +52,38 @@ const createValidator = (context, feedbackMap) => ({ el, reportValidity = false
const
formField
=
form
.
fields
[
name
];
const
formField
=
form
.
fields
[
name
];
const
isValid
=
el
.
checkValidity
();
const
isValid
=
el
.
checkValidity
();
// valid fields can be flagged as such, without triggering any validation feedback (messages, input-styles)
// This makes sure we always report valid fields - this can be useful for cases where the consuming
formField
.
state
=
!
reportValidity
&&
!
isValid
?
null
:
isValid
;
// component's logic depends on certain fields being in a valid state.
formField
.
feedback
=
reportValidity
?
getFeedbackForElement
(
feedbackMap
,
el
)
:
''
;
// Invalid input, on the other hand, should only be reported once we want to display feedback to the user.
// (eg.: After a field has been touched and moved away from, a submit-button has been clicked, ...)
formField
.
state
=
reportInvalidInput
?
isValid
:
isValid
||
null
;
formField
.
feedback
=
reportInvalidInput
?
getFeedbackForElement
(
feedbackMap
,
el
)
:
''
;
form
.
state
=
isEveryFieldValid
(
form
);
form
.
state
=
isEveryFieldValid
(
form
);
};
};
/**
/**
* Takes an object that allows to add or change custom feedback messages:
* Takes an object that allows to add or change custom feedback messages.
*
* The passed in object will be merged with the built-in feedback
* so it is possible to override a built-in message.
*
*
* @example
* validate({
* validate({
* tooLong: {
* tooLong: {
* check: el => el.validity.tooLong === true,
* check: el => el.validity.tooLong === true,
*
message: 'The value you have entered is too long
'
*
message: 'Your custom feedback
'
* }
* }
* })
* })
*
*
* Note: The passed in object will be merged with the built-in feedback.
* @example
* validate({
* valueMissing: {
* message: 'Your custom feedback'
* }
* })
*
*
* @param {Object<string, {
isValid: function, message: string
}>} customFeedbackMap
* @param {Object<string, {
message: string, isValid: ?function
}>} customFeedbackMap
* @returns {{ inserted: function, update: function }} validateDirective
* @returns {{ inserted: function, update: function }} validateDirective
*/
*/
export
default
function
(
customFeedbackMap
=
{})
{
export
default
function
(
customFeedbackMap
=
{})
{
...
@@ -96,7 +109,7 @@ export default function(customFeedbackMap = {}) {
...
@@ -96,7 +109,7 @@ export default function(customFeedbackMap = {}) {
el
.
addEventListener
(
'
blur
'
,
function
markAsBlurred
({
target
})
{
el
.
addEventListener
(
'
blur
'
,
function
markAsBlurred
({
target
})
{
if
(
elData
.
isTouched
)
{
if
(
elData
.
isTouched
)
{
elData
.
isBlurred
=
true
;
elData
.
isBlurred
=
true
;
validate
({
el
:
target
,
report
Validity
:
true
});
validate
({
el
:
target
,
report
InvalidInput
:
true
});
// this event handler can be removed, since the live-feedback in `update` takes over
// this event handler can be removed, since the live-feedback in `update` takes over
el
.
removeEventListener
(
'
blur
'
,
markAsBlurred
);
el
.
removeEventListener
(
'
blur
'
,
markAsBlurred
);
}
}
...
@@ -106,14 +119,14 @@ export default function(customFeedbackMap = {}) {
...
@@ -106,14 +119,14 @@ export default function(customFeedbackMap = {}) {
formEl
.
addEventListener
(
'
submit
'
,
focusFirstInvalidInput
);
formEl
.
addEventListener
(
'
submit
'
,
focusFirstInvalidInput
);
}
}
validate
({
el
,
report
Validity
:
showGlobalValidation
});
validate
({
el
,
report
InvalidInput
:
showGlobalValidation
});
},
},
update
(
el
,
binding
)
{
update
(
el
,
binding
)
{
const
{
arg
:
showGlobalValidation
}
=
binding
;
const
{
arg
:
showGlobalValidation
}
=
binding
;
const
{
validate
,
isTouched
,
isBlurred
}
=
elDataMap
.
get
(
el
);
const
{
validate
,
isTouched
,
isBlurred
}
=
elDataMap
.
get
(
el
);
const
showValidationFeedback
=
showGlobalValidation
||
(
isTouched
&&
isBlurred
);
const
showValidationFeedback
=
showGlobalValidation
||
(
isTouched
&&
isBlurred
);
validate
({
el
,
report
Validity
:
showValidationFeedback
});
validate
({
el
,
report
InvalidInput
:
showValidationFeedback
});
},
},
};
};
}
}
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