/**
 * Validates that the value is a valid email.
 */
Ext.define('Ext.data.validator.Email', {
    extend: 'Ext.data.validator.Format',
    alias: 'data.validator.email',
 
    type: 'email',
 
    /**
     * @cfg {String} message
     * The error message to return when the value is not a valid email
     * @locale
     */
    message: 'Is not a valid email address',
 
    // http://en.wikipedia.org/wiki/Email_address#Local_part
    // http://stackoverflow.com/a/2049510
    // http://isemail.info/
    // http://blog.stevenlevithan.com/archives/capturing-vs-non-capturing-groups
    //
    // 1. Can begin with a double-quote ONLY IF the local part also ends in a double-quote.
    // 2. Can NOT BEGIN with a period.
    // 3. Can NOT END with a period.
    // 4. Can not have MORE THAN ONE period in a row.
    //
    // Let's break this down:
    //
    // ^(")?
    // The local part may begin with double-quotes, but only if it also ends with it.
    // See the back-reference.  Capturing.
    //
    // (?:[^\."])
    // Here we've defined that the local part cannot begin with a period or a double-quote.  Non-capturing.
    //
    // (?:(?:[\.])?(?:[\w\-!#$%&'*+/=?^_`{|}~]))*
    // After the first character is matched, the regex ensures that there is not more than one period
    // in a row.  Then, this nested grouping allows for zero or more of the accepted characters.
    // NOTE that this also ensures that any character not defined in the character class
    // is invalid as an ending character for the local part (such as the period).
    //
    // \1@
    // The local part of the address is a backreference to the first (and only) capturing group that allows
    // for a double-quote to wrap the local part of an email address.
    /**
     * @cfg {RegExp} matcher
     * A matcher to check for simple emails. This may be overridden.
     */
    matcher: /^(")?(?:[^\."])(?:(?:[\.])?(?:[\w\-!#$%&'*+\/=?\^_`{|}~]))*\1@(\w[\-\w]*\.){1,5}([A-Za-z]){2,6}$/
});