src/cm/media/js/lib/flexible-js-formatting/html-form-input-mask/html-form-input-mask.js
author raph
Mon, 23 Nov 2009 15:14:29 +0100
changeset 0 40c8f766c9b8
permissions -rw-r--r--
import from internal svn r 4007
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
 * Copyright (C) 2006 Baron Schwartz <baron at xaprb dot com>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
 * This program is free software; you can redistribute it and/or modify it
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
 * under the terms of the GNU Lesser General Public License as published by the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
 * Free Software Foundation, version 2.1.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     7
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     8
 * This program is distributed in the hope that it will be useful, but WITHOUT
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
 * FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
 * details.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
 * $Id: html-form-input-mask.js,v 1.6 2006-11-03 04:04:29 baron Exp $
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
/* Set up a global Xaprb object to act as the Xaprb namespace, without colliding
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
 * with other Xaprb scripts.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
if ( typeof(Xaprb) === 'undefined' ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
   Xaprb = new Object();
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
}
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
/* The Xaprb.InputMask object acts as the namespace for input masking
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
 * functionality.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
Xaprb.InputMask = {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
   /* Each mask has a format and regex property.  The format consists
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
    * of spaces and non-spaces.  A space is a placeholder for a value the user
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
    * enters.  A non-space is a literal character that gets copied to that
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
    * position in the value.  The regex is used to validate each character, one
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
    * at a time (it is not applied against the entire value in the form field,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
    * just the characters the user enters).
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
    * The way you name your masks is significant.  If you create a mask called
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
    * date_us, you cause it to be applied to a form field by a) adding the
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    * input_mask class to that form field, which triggers this script to treat
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
    * it specially, and b) adding the class mask_date_us to the form field,
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
    * which causes this script to apply the date_us mask to it.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
   masks: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
      date_iso: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
         format: '    -  -  ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
      },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
      date_us: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
         format: '  /  /    ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
      },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
      time: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
         format: '  :  :  ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
      },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
      phone: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
         format: '(   )   -    ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
      },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
      ssn: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
         format: '   -  -    ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
      },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
      visa: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
         format: '    -    -    -    ',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
         regex:  /\d/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
      }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
   },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
   /* Finds every element with class input_mask and applies masks to them.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
   setupElementMasks: function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
      if ( document.getElementsByClassName ) { // Requires the Prototype library
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
         document.getElementsByClassName('input_mask').each(function(item) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
            Event.observe(item, 'keypress',
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
               Xaprb.InputMask.applyMask.bindAsEventListener(item), true);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
         });
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
      }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
   },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
   
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
   /* This is triggered when the key is pressed in the form input.  It is
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
    * bound to the element, so 'this' is the input element.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
   applyMask: function(event) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
      var match = /mask_(\w+)/.exec(this.className);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
      if ( match.length == 2 && Xaprb.InputMask.masks[match[1]] ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
         var mask = Xaprb.InputMask.masks[match[1]];
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
         var key  = Xaprb.InputMask.getKey(event);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
         if ( Xaprb.InputMask.isPrintable(key) ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
            var ch      = String.fromCharCode(key);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
            var str     = this.value + ch;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
            var pos     = str.length;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
            if ( mask.regex.test(ch) && pos <= mask.format.length ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
               if ( mask.format.charAt(pos - 1) != ' ' ) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
                  str = this.value + mask.format.charAt(pos - 1) + ch;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
               }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
               this.value = str;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
            }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
            Event.stop(event);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
         }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
      }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
   },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
   /* Returns true if the key is a printable character.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
   isPrintable: function(key) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
      return ( key >= 32 && key < 127 );
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
   },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
   /* Returns the key code associated with the event.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
   getKey: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
      return window.event ? window.event.keyCode
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
           : e            ? e.which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
           :                0;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
   }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
};