var Behaviour = {
  list : new Array,
  
  register : function(sheet){
    Behaviour.list.push(sheet);
  },
  
  start : function(){
    Event.observe(window, 'load', function(){
      Behaviour.apply();
    });
  },
  
  apply : function(){
  for (h=0;sheet=Behaviour.list[h];h++){
      for (selector in sheet){
    list = document.getElementsBySelector(selector);
    if (!list) continue;
    
    for (i=0;el=list[i];i++){
        sheet[selector](el);
    }
      }
  }
    }
}

Behaviour.start();

/*
   The following code is Copyright (C) Simon Willison 2004.

   document.getElementsBySelector(selector)
   - returns an array of element objects from the current document
     matching the CSS selector. Selectors can contain element names, 
     class names and ids and can be nested. For example:
     
       elements = document.getElementsBySelect('div#main p a.external')
     
     Will return an array of all 'a' elements with 'external' in their 
     class attribute that are contained inside 'p' elements that are 
     contained inside the 'div' element which has id="main"

   New in version 0.4: Support for CSS2 and CSS3 attribute selectors:
   See http://www.w3.org/TR/css3-selectors/#attribute-selectors

   Version 0.4 - Simon Willison, March 25th 2003
   -- Works in Phoenix 0.5, Mozilla 1.3, Opera 7, Internet Explorer 6, Internet Explorer 5 on Windows
   -- Opera 7 fails 
*/

function getAllChildren(e) {
  // Returns all children of element. Workaround required for IE5/Windows. Ugh.
  return e.all ? e.all : e.getElementsByTagName('*');
}

document.getElementsBySelector = function(selector) {
  // Attempt to fail gracefully in lesser browsers
  if (!document.getElementsByTagName) {
    return new Array();
  }
  // Split selector in to tokens
  var tokens = selector.split(' ');
  var currentContext = new Array(document);
  for (var i = 0; i < tokens.length; i++) {
    token = tokens[i].replace(/^\s+/,'').replace(/\s+$/,'');;
    if (token.indexOf('#') > -1) {
      // Token is an ID selector
      var bits = token.split('#');
      var tagName = bits[0];
      var id = bits[1];
      var element = $(id);
      if (tagName && element.nodeName.toLowerCase() != tagName) {
        // tag with that ID not found, return false
        return new Array();
      }
      // Set currentContext to contain just this element
      currentContext = new Array(element);
      continue; // Skip to next token
    }
    if (token.indexOf('.') > -1) {
     // Token contains a class selector
      var bits = token.split('.');
      var tagName = bits[0];
      var className = bits[1];
      if (!tagName) {
        tagName = '*';
      }
      // Get elements matching tag, filter them for class selector
      var found = new Array;
      var foundCount = 0;
      for (var h = 0; h < currentContext.length; h++) {
        var elements;
        if (tagName == '*') {
            elements = getAllChildren(currentContext[h]);
        } else {
            elements = currentContext[h].getElementsByTagName(tagName);
        }
        for (var j = 0; j < elements.length; j++) {
          found[foundCount++] = elements[j];
        }
      }
      currentContext = new Array;
      var currentContextIndex = 0;
      for (var k = 0; k < found.length; k++) {
        if (found[k].className && found[k].className.match(new RegExp('\\b'+className+'\\b'))) {
          currentContext[currentContextIndex++] = found[k];
        }
      }
      continue; // Skip to next token
    }
    // Code to deal with attribute selectors
    if (token.match(/^(\w*)\[(\w+)([=~\|\^\$\*]?)=?"?([^\]"]*)"?\]$/)) {
      var tagName = RegExp.$1;
      var attrName = RegExp.$2;
      var attrOperator = RegExp.$3;
      var attrValue = RegExp.$4;
      if (!tagName) {
        tagName = '*';
      }
      // Grab all of the tagName elements within current context
      var found = new Array;
      var foundCount = 0;
      for (var h = 0; h < currentContext.length; h++) {
        var elements;
        if (tagName == '*') {
            elements = getAllChildren(currentContext[h]);
        } else {
            elements = currentContext[h].getElementsByTagName(tagName);
        }
        for (var j = 0; j < elements.length; j++) {
          found[foundCount++] = elements[j];
        }
      }
      currentContext = new Array;
      var currentContextIndex = 0;
      var checkFunction; // This function will be used to filter the elements
      switch (attrOperator) {
        case '=': // Equality
          checkFunction = function(e) { return (e.getAttribute(attrName) == attrValue); };
          break;
        case '~': // Match one of space seperated words 
          checkFunction = function(e) { return (e.getAttribute(attrName).match(new RegExp('\\b'+attrValue+'\\b'))); };
          break;
        case '|': // Match start with value followed by optional hyphen
          checkFunction = function(e) { return (e.getAttribute(attrName).match(new RegExp('^'+attrValue+'-?'))); };
          break;
        case '^': // Match starts with value
          checkFunction = function(e) { return (e.getAttribute(attrName).indexOf(attrValue) == 0); };
          break;
        case '$': // Match ends with value - fails with "Warning" in Opera 7
          checkFunction = function(e) { return (e.getAttribute(attrName).lastIndexOf(attrValue) == e.getAttribute(attrName).length - attrValue.length); };
          break;
        case '*': // Match ends with value
          checkFunction = function(e) { return (e.getAttribute(attrName).indexOf(attrValue) > -1); };
          break;
        default :
          // Just test for existence of attribute
          checkFunction = function(e) { return e.getAttribute(attrName); };
      }
      currentContext = new Array;
      var currentContextIndex = 0;
      for (var k = 0; k < found.length; k++) {
        if (checkFunction(found[k])) {
          currentContext[currentContextIndex++] = found[k];
        }
      }
      // alert('Attribute Selector: '+tagName+' '+attrName+' '+attrOperator+' '+attrValue);
      continue; // Skip to next token
    }
    
    if (!currentContext[0]){
      return;
    }
    
    // If we get here, token is JUST an element (not a class or ID selector)
    tagName = token;
    var found = new Array;
    var foundCount = 0;
    for (var h = 0; h < currentContext.length; h++) {
      var elements = currentContext[h].getElementsByTagName(tagName);
      for (var j = 0; j < elements.length; j++) {
        found[foundCount++] = elements[j];
      }
    }
    currentContext = found;
  }
  return currentContext;
}

/* That revolting regular expression explained 
/^(\w+)\[(\w+)([=~\|\^\$\*]?)=?"?([^\]"]*)"?\]$/
  \---/  \---/\-------------/    \-------/
    |      |         |               |
    |      |         |           The value
    |      |    ~,|,^,$,* or =
    |   Attribute 
   Tag
*/





/*
 * Append by MASUIDRIVE
 * Edited by Kousho Shimada
 */
 
var Validator = {

  register : function(validates){
    sheet = {};
    for (selector in validates){
      sheet[selector] = function(el) {
        if(el.masuidrive_validates==undefined) {
          el.masuidrive_validates = new Array();
          
          el.validate = function(event) {
            
            el = event.srcElement;
            
            if( el==null || el==undefined ) el = event.target;
            if( el==null || el==undefined ) el = event;

            for(i=0; func=el.masuidrive_validates[i]; ++i) {

              msg = undefined;
              
              if(typeof(func)=='function') {
                msg = func(el);
              }
              else {
                for(key in func) {
                  if(el.value.match(eval(key))) {
                    if(typeof(func[key])=='function')
                      msg = (func[key])(el);
                    else
                      msg = func[key];
                    break;
                  }
                }
              }
              
              
              if( msg!=undefined ) {
                Validator.message(el.id, msg);
              }
              
            }

          };
          
          
          if(el.type=='text' || el.type=='password' || el.type == 'textarea') {
              Event.observe(el, 'keyup', el.validate);
          }
          else {
              Event.observe(el, 'change', el.validate);
          }
          
          Event.observe(el, 'blur', el.validate);
          
        }
        el.masuidrive_validates.push(validates[selector]);
        
        el.validate(el);
        
      }
    }
    Behaviour.register(sheet);
  },

  message : function(eid, message) {
    if($(eid + '_msg')!=undefined){
      Validator.changeBGColor(eid, message);
      Validator.checkAll();
      if(message == 'EMPTY') message = '';
      $(eid + '_msg').innerHTML = message;
    }
  },
  
  checkAll : function() {
    if(/*$('inquiry_year').flag && $('inquiry_month1').flag && $('inquiry_day1').flag && $('inquiry_time1').flag && $('inquiry_time2').flag && $('inquiry_num').flag && $('inquiry_fa_no').flag && $('inquiry_usage').flag && */$('inquiry_company').flag && $('inquiry_kana1').flag && $('inquiry_kana2').flag && $('inquiry_name1').flag && $('inquiry_name2').flag && $('inquiry_post1').flag && $('inquiry_address').flag && $('inquiry_tel1').flag && $('inquiry_tel2').flag && $('inquiry_tel3').flag && $('inquiry_email').flag){
      $('checkBtn').src = "check/btn_check.jpg";
	  $('checkBtn').alt = "確認画面";
      return true;
    }else{
      $('checkBtn').src = "check/btn_error.jpg";
      $('checkBtn').alt = "必要項目を全てご入力ください";
      return false;
    }
  },
  
  resetAll : function() {
	$('inquiry_year').validate($('inquiry_year'));
	$('inquiry_month1').validate($('inquiry_month1'));
	$('inquiry_day1').validate($('inquiry_day1'));
	$('inquiry_time1').validate($('inquiry_time1'));
	$('inquiry_time2').validate($('inquiry_time2'));
	$('inquiry_num').validate($('inquiry_num'));
	$('inquiry_fa_no').validate($('inquiry_fa_no'));
	$('inquiry_usage').validate($('inquiry_usage'));
	$('inquiry_company').validate($('inquiry_company'));
	$('inquiry_kana1').validate($('inquiry_kana1'));
	$('inquiry_kana2').validate($('inquiry_kana2'));
	$('inquiry_name1').validate($('inquiry_name1'));
    $('inquiry_name2').validate($('inquiry_name2'));
	$('inquiry_post1').validate($('inquiry_post1'));
//	$('inquiry_post2').validate($('inquiry_post2'));
	$('inquiry_address').validate($('inquiry_address'));
	$('inquiry_tel1').validate($('inquiry_tel1'));
	$('inquiry_tel2').validate($('inquiry_tel2'));
	$('inquiry_tel3').validate($('inquiry_tel3'));
	$('inquiry_email').validate($('inquiry_email'));
  },
  
  changeBGColor : function(eid, message) {
    if(message == ''){
      $(eid).style.backgroundColor = '#FFFFFF';
	  $(eid).style.border = '1px solid #7F9DB9';
      $(eid).flag = true;
    }else{
      $(eid).style.backgroundColor = '#FFFF99';
	  $(eid).style.border = '1px solid #7F9DB9';
      $(eid).flag = false;
    }
  }

};

