blob: cab0bbd3eeb8b7e3c87157ef4564df76740eff48 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
|
/*
* JavaScript for Special:ChangeEmail
*/
( function ( mw, $ ) {
/**
* Given an email validity status (true, false, null) update the label CSS class
*/
function updateMailValidityLabel( mail ) {
var isValid = mw.util.validateEmail( mail ),
$label = $( '#mw-emailaddress-validity' );
// We allow empty address
if( isValid === null ) {
$label.text( '' ).removeClass( 'valid invalid' );
// Valid
} else if ( isValid ) {
$label.text( mw.msg( 'email-address-validity-valid' ) ).addClass( 'valid' ).removeClass( 'invalid' );
// Not valid
} else {
$label.text( mw.msg( 'email-address-validity-invalid' ) ).addClass( 'invalid' ).removeClass( 'valid' );
}
}
$( document ).ready( function () {
// Lame tip to let user know if its email is valid. See bug 22449
// Only bind once for 'blur' so that the user can fill it in without errors
// After that look at every keypress for direct feedback if it was invalid onblur
$( '#wpNewEmail' ).one( 'blur', function () {
if ( $( '#mw-emailaddress-validity' ).length === 0 ) {
$(this).after( '<label for="wpNewEmail" id="mw-emailaddress-validity"></label>' );
}
updateMailValidityLabel( $(this).val() );
$(this).keyup( function () {
updateMailValidityLabel( $(this).val() );
} );
} );
} );
}( mediaWiki, jQuery ) );
|