/**
* CPAINT - Cross-Platform Asynchronous INterface Toolkit
*
* http://sf.net/projects/cpaint
* 
* released under the terms of the LGPL
* see http://www.fsf.org/licensing/licenses/lgpl.txt for details
*
* @package      CPAINT
* @access       public
* @copyright    Copyright (c) 2005-2006 Paul Sullivan, Dominique Stender - http://sf.net/projects/cpaint
* @author       Paul Sullivan <wiley14@gmail.com>
* @author       Dominique Stender <dstender@st-webdevelopment.de>
* @author        Stephan Tijink <stijink@googlemail.com>
* @version      2.0.3
*/
function cpaint() {
  /**
  * CPAINT version
  * 
  * @access     protected
  * @var        string      version
  */
  this.version = '2.0.3';
  
  /**
  * configuration options both for this class but also for  the cpaint_call() objects.
  *
  * @access     protected
  * @var        array       config
  */
  var config                      = new Array();
  config['debugging']             = -1;
  config['proxy_url']             = '';
  config['transfer_mode']         = 'GET';
  config['async']                 = true;
  config['response_type']         = 'OBJECT';
  config['persistent_connection'] = false;
  config['use_cpaint_api']        = true;
  
  /**
  * maintains the next free index in the stack
  *
  * @access   protected
  * @var      integer   stack_count
  */
  var stack_count = 0;

  /**
  * property returns whether or not the browser is AJAX capable
  * 
  * @access        public
  * @return        boolean
  */
  this.capable = test_ajax_capability();
  
  /**
  * switches debug mode on/off.
  *
  * @access   public
  * @param    boolean    debug    debug flag
  * @return   void
  */
  this.set_debug = function() {
    
    if (typeof arguments[0] == 'boolean') {
      if (arguments[0] === true) {
        config['debugging'] = 1;

      } else {
        config['debugging'] = 0;
      }
      
    } else if (typeof arguments[0] == 'number') {
      config['debugging'] = Math.round(arguments[0]);
    }
  }

  /**
  * defines the URL of the proxy script.
  *
  * @access   public
  * @param    string    proxy_url    URL of the proxyscript to connect
  * @return   void
  */
  this.set_proxy_url = function() {
    
    if (typeof arguments[0] == 'string') {

      config['proxy_url'] = arguments[0];
    }
  }

  /**
  * sets the transfer_mode (GET|POST).
  *
  * @access   public
  * @param    string    transfer_mode    transfer_mode
  * @return   void
  */
  this.set_transfer_mode = function() {
    
    if (arguments[0].toUpperCase() == 'GET'
      || arguments[0].toUpperCase() == 'POST') {

      config['transfer_mode'] = arguments[0].toUpperCase();
    }
  }

  /**
  * sets the flag whether or not to use asynchronous calls.
  *
  * @access   public
  * @param    boolean    async    syncronization flag
  * @return   void
  */
  this.set_async = function() {
    
    if (typeof arguments[0] == 'boolean') {
      config['async'] = arguments[0];
    }
  }

  /**
  * defines the response type.
  *
  * allowed values are:
  *   TEXT    = raw text response
  *   XML     = raw XMLHttpObject
  *   OBJECT  = parsed JavaScript object structure from XMLHttpObject
  *
  * the default is OBJECT.
  *
  * @access   public
  * @param    string    response_type    response type
  * @return   void
  */
  this.set_response_type = function() {
    
    if (arguments[0].toUpperCase() == 'TEXT'
      || arguments[0].toUpperCase() == 'XML'
      || arguments[0].toUpperCase() == 'OBJECT'
      || arguments[0].toUpperCase() == 'E4X'
      || arguments[0].toUpperCase() == 'JSON') {

      config['response_type'] = arguments[0].toUpperCase();
    }
  }

  /**
  * sets the flag whether or not to use a persistent connection.
  *
  * @access   public
  * @param    boolean    persistent_connection    persistance flag
  * @return   void
  */
  this.set_persistent_connection = function() {
    
    if (typeof arguments[0] == 'boolean') {
      config['persistent_connection'] = arguments[0];
    }
  }
  
  
  /**
  * sets the flag whether or not to use the cpaint api on the backend.
  *
  * @access    public
  * @param     boolean    cpaint_api      api_flag
  * @return    void
  */
  this.set_use_cpaint_api = function() {
    if (typeof arguments[0] == 'boolean') {
      config['use_cpaint_api'] = arguments[0];
    }
  }
  
  /**
  * tests whether one of the necessary implementations
  * of the XMLHttpRequest class are available
  *
  * @access     protected
  * @return     boolean
  */
  function test_ajax_capability() {
    var cpc = new cpaint_call(0, config, this.version);
    return cpc.test_ajax_capability();
  }

  /**
  * takes the arguments supplied and triggers a call to the CPAINT backend
  * based on the settings.
  *
  * upon response cpaint_call.callback() will automatically be called
  * to perform post-processing operations.
  *
  * @access   public
  * @param    string    url                 remote URL to call
  * @param    string    remote_method       remote method to call
  * @param    object    client_callback     client side callback method to deliver the remote response to. do NOT supply a string!
  * @param    mixed     argN                remote parameters from now on
  * @return   void
  */
  this.call = function() {
    var use_stack = -1;
    
    if (config['persistent_connection'] == true
      && __cpaint_stack[0] != null) {

      switch (__cpaint_stack[0].get_http_state()) {
        case -1:
          // no XMLHttpObject object has already been instanciated
          // create new object and configure it
          use_stack = 0;
          debug('no XMLHttpObject object to re-use for persistence, creating new one later', 2);
          break;
          
        case 4:
          // object is ready for a new request, no need to do anything
          use_stack = 0
          debug('re-using the persistent connection', 2);
          break;
          
        default:
          // connection is currently in use, don't do anything
          debug('the persistent connection is in use - skipping this request', 2);
      }
      
    } else if (config['persistent_connection'] == true) {
      // persistent connection is active, but no object has been instanciated
      use_stack = 0;
      __cpaint_stack[use_stack] = new cpaint_call(use_stack, config, this.version);
      debug('no cpaint_call object available for re-use, created new one', 2);
    
    } else {
      // no connection persistance
      use_stack = stack_count;
      __cpaint_stack[use_stack] = new cpaint_call(use_stack, config, this.version);
      debug('no cpaint_call object created new one', 2);
    }

    // configure cpaint_call if allowed to
    if (use_stack != -1) {
      __cpaint_stack[use_stack].set_client_callback(arguments[2]);
      
      // distribute according to proxy use
      if (config['proxy_url'] != '') {
        __cpaint_stack[use_stack].call_proxy(arguments);
      
      } else {
        __cpaint_stack[use_stack].call_direct(arguments);
      }

      // increase stack counter
      stack_count++;
      debug('stack size: ' + __cpaint_stack.length, 2);
    }
  }

  /**
  * debug method
  *
  * @access  protected
  * @param   string       message         the message to debug
  * @param   integer      debug_level     debug level at which the message appears
  * @return  void
  */
  var debug  = function(message, debug_level) {
    var prefix = '[CPAINT Debug] ';
    
    if (debug_level < 1) {
      prefix = '[CPAINT Error] ';
    }
    
    if (config['debugging'] >= debug_level) {
      alert(prefix + message);
    }
  }
}

/**
* internal FIFO stack of cpaint_call() objects.
*
* @access   protected
* @var      array    __cpaint_stack
*/
var __cpaint_stack = new Array();

/**
* local instance of cpaint_transformer
* MSIE is unable to handle static classes... sheesh.
*
* @access   public
* @var      object    __cpaint_transformer
*/
var __cpaint_transformer = new cpaint_transformer();

/**
* transport agent class
*
* creates the request object, takes care of the response, handles the 
* client callback. Is configured by the cpaint() object.
*
* @package      CPAINT
* @access       public
* @copyright    Copyright (c) 2005-2006 Paul Sullivan, Dominique Stender - http://sf.net/projects/cpaint
* @author       Dominique Stender <dstender@st-webdevelopment.de>
* @author       Paul Sullivan <wiley14@gmail.com>
* @param        integer     stack_id      stack Id in cpaint
* @param        array       config        configuration array for this call
* @param        string      version       CPAINT API version
*/
function cpaint_call() {
  /**
  * CPAINT version
  * 
  * @access     protected
  * @var        string      version
  */
  var version = arguments[2];
  
  /**
  * configuration options both for this class objects.
  *
  * @access     protected
  * @var        array       config
  */
  var config                      = new Array();
  config['debugging']             = arguments[1]['debugging'];
  config['proxy_url']             = arguments[1]['proxy_url'];
  config['transfer_mode']         = arguments[1]['transfer_mode'];
  config['async']                 = arguments[1]['async'];
  config['response_type']         = arguments[1]['response_type'];
  config['persistent_connection'] = arguments[1]['persistent_connection'];
  config['use_cpaint_api']        = arguments[1]['use_cpaint_api'];

  /**
  * XMLHttpObject used for this request.
  *
  * @access   protected
  * @var      object     httpobj
  */
  var httpobj    = false;

  /**
  * client callback function.
  *
  * @access   public
  * @var      function    client_callback
  */
  var client_callback;

  /**
  * stores the stack Id within the cpaint object
  *
  * @access   protected
  * @var      stack_id
  */
  var stack_id = arguments[0];
  
  /**
  * sets the client callback function.
  *
  * @access   public
  * @param    function    client_callback     the client callback function
  * @return   void
  */
  this.set_client_callback = function() {
    
    if (typeof arguments[0] == 'function') {
      client_callback = arguments[0];
    }
  }

  /**
  * returns the ready state of the internal XMLHttpObject
  *
  * if no such object was set up already, -1 is returned
  * 
  * @access     public
  * @return     integer
  */
  this.get_http_state = function() {
    var return_value = -1;
    
    if (typeof httpobj == 'object') {
      return_value = httpobj.readyState;
    }
    
    return return_value;
  }
  
  /**
  * internal method for remote calls to the local server without use of the proxy script.
  *
  * @access   public
  * @param    array    call_arguments    array of arguments initially passed to cpaint.call()
  * @return   void
  */
  this.call_direct = function(call_arguments) {
    var url             = call_arguments[0];
    var remote_method   = call_arguments[1];
    var querystring     = '';
    var i               = 0;
    
    // correct link to self
    if (url == 'SELF') {
      url = document.location.href;
    }
  
    if (config['use_cpaint_api'] == true) {
      // backend uses cpaint api
      // pass parameters to remote method
      for (i = 3; i < call_arguments.length; i++) {

        if ((typeof call_arguments[i] == 'string'
              && call_arguments[i] != ''
              && call_arguments[i].search(/^\s+$/g) == -1)
          && !isNaN(call_arguments[i])
          && isFinite(call_arguments[i])) {
          // numerical value, convert it first
          querystring += '&cpaint_argument[]=' + encodeURIComponent(JSON.stringify(Number(call_arguments[i])));
        
        } else {
          querystring += '&cpaint_argument[]=' + encodeURIComponent(JSON.stringify(call_arguments[i]));
        }
      }
    
      // add response type to querystring
      querystring += '&cpaint_response_type=' + config['response_type'];
    
      // build header
      if (config['transfer_mode'] == 'GET') {
                
        if(url.indexOf('?') != -1) {
                    url = url + '&cpaint_function=' + remote_method +    querystring;
                
        } else {
                    url = url + '?cpaint_function=' + remote_method +    querystring; 
                }
      
      } else {
        querystring = 'cpaint_function=' + remote_method + querystring;
      }
      
    } else {
      // backend does not use cpaint api
      // pass parameters to remote method
      for (i = 3; i < call_arguments.length; i++) {
        
        if (i == 3) {
          querystring += encodeURIComponent(call_arguments[i]);
        
        } else {
          querystring += '&' + encodeURIComponent(call_arguments[i]);
        }
      }
    
      // build header
      if (config['transfer_mode'] == 'GET') {
        url = url + querystring;
      } 
    }
  
    // open connection 
    get_connection_object();

    // open connection to remote target
    debug('opening connection to "' + url + '"', 1);
    httpobj.open(config['transfer_mode'], url, config['async']);

    // send "urlencoded" header if necessary (if POST)
    if (config['transfer_mode'] == 'POST') {

      try {
        httpobj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');

      } catch (cp_err) {
        debug('POST cannot be completed due to incompatible browser.  Use GET as your request method.', 0);
      }
    }

    // make ourselves known
    httpobj.setRequestHeader('X-Powered-By', 'CPAINT v' + version + ' :: http://sf.net/projects/cpaint');

    // callback handling for asynchronous calls
    httpobj.onreadystatechange = callback;

    // send content
    if (config['transfer_mode'] == 'GET') {
      httpobj.send(null);

    } else {
      debug('sending query: ' + querystring, 1);
      httpobj.send(querystring);
    }

    if (config['async'] == true) {
      // manual callback handling for synchronized calls
      callback();
    }
  }
    
  /**
  * internal method for calls to remote servers through the proxy script.
  *
  * @access   public
  * @param    array    call_arguments    array of arguments passed to cpaint.call()
  * @return   void
  */
  this.call_proxy = function(call_arguments) {
    var proxyscript     = config['proxy_url'];
    var url             = call_arguments[0];
    var remote_method   = call_arguments[1];
    var querystring     = '';
    var i               = 0;
    
    var querystring_argument_prefix = 'cpaint_argument[]=';

    // pass parameters to remote method
    if (config['use_cpaint_api'] == false) {
      // when not talking to a CPAINT backend, don't prefix arguments
      querystring_argument_prefix = '';
    }

    for (i = 3; i < call_arguments.length; i++) {

      if (config['use_cpaint_api'] == true) {
      
        if ((typeof call_arguments[i] == 'string'
              && call_arguments[i] != ''
              && call_arguments[i].search(/^\s+$/g) == -1)
          && !isNaN(call_arguments[i])
          && isFinite(call_arguments[i])) {
          // numerical value, convert it first
          querystring += encodeURIComponent(querystring_argument_prefix + JSON.stringify(Number(call_arguments[i])) + '&');

        } else {
          querystring += encodeURIComponent(querystring_argument_prefix + JSON.stringify(call_arguments[i]) + '&');
        }
        
      } else {
        // no CPAINT in the backend
        querystring += encodeURIComponent(querystring_argument_prefix + call_arguments[i] + '&');
      }
    }

    if (config['use_cpaint_api'] == true) {
      // add remote function name to querystring
      querystring += encodeURIComponent('&cpaint_function=' + remote_method);
  
      // add response type to querystring
      querystring += encodeURIComponent('&cpaint_responsetype=' + config['response_type']);
    }
    
    // build header
    if (config['transfer_mode'] == 'GET') {
      proxyscript += '?cpaint_remote_url=' + encodeURIComponent(url) 
        + '&cpaint_remote_query=' + querystring
        + '&cpaint_remote_method=' + config['transfer_mode'] 
        + '&cpaint_response_type=' + config['response_type'];

    } else {
      querystring = 'cpaint_remote_url=' + encodeURIComponent(url)
        + '&cpaint_remote_query=' + querystring
        + '&cpaint_remote_method=' + config['transfer_mode'] 
        + '&cpaint_response_type=' + config['response_type'];
    }

    // open connection
    get_connection_object();

    // open connection to remote target
    debug('opening connection to proxy "' + proxyscript + '"', 1);
    httpobj.open(config['transfer_mode'], proxyscript, config['async']);

    // send "urlencoded" header if necessary (if POST)
    if (config['transfer_mode'] == 'POST') {

      try {
        httpobj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');

      } catch (cp_err) {
        debug('POST cannot be completed due to incompatible browser.  Use GET as your request method.', 0);
      }
    }

    httpobj.setRequestHeader('X-Powered-By', 'CPAINT v' + version);

    // callback handling for asynchronous calls
    httpobj.onreadystatechange = callback;

    // send content
    if (config['transfer_mode'] == 'GET') {
      httpobj.send(null);

    } else {
      debug('sending query: ' + querystring, 1);
      httpobj.send(querystring);
    }

    if (config['async'] == false) {
      // manual callback handling for synchronized calls
      callback();
    }
  }

  this.test_ajax_capability = function() {
    return get_connection_object();
  }
  
  /**
  * creates a new connection object.
  *
  * @access   protected
  * @return   boolean
  */
  var get_connection_object = function() {
    var return_value    = false;
    var new_connection  = false;

    // open new connection only if necessary
    if (config['persistent_connection'] == false) {
      // no persistance, create a new object every time
      debug('Using new connection object', 1);
      new_connection = true;

    } else {
      // persistent connection object, only open one if no object exists
      debug('Using shared connection object.', 1);

      if (typeof httpobj != 'object') {
        debug('Getting new persistent connection object.', 1);
        new_connection = true;
      }
    }

    if (new_connection == true) {
        
     try {
        httpobj = new XMLHttpRequest();
      } catch (e1) {

          try {
            httpobj = new ActiveXObject('Msxml2.XMLHTTP');
      
          } catch (e) {
            
            try {  
              httpobj = new ActiveXObject('Microsoft.XMLHTTP');
 
            } catch (oc) {
              httpobj = null;
            } 
         }
      }
     
  
      if (!httpobj) {
        debug('Could not create connection object', 0);
      
      } else {
        return_value = true;
      }
    }

    if (httpobj.readyState != 4) {
      httpobj.abort();
    }

    return return_value;
  }

  /**
  * internal callback function.
  *
  * will perform some consistency checks (response code, NULL value testing)
  * and if response_type = 'OBJECT' it will automatically call
  * cpaint_call.parse_ajax_xml() to have a JavaScript object structure generated.
  *
  * after all that is done the client side callback function will be called 
  * with the generated response as single value.
  *
  * @access   protected
  * @return   void
  */
  var callback = function() {
    var response = null;

    if (httpobj.readyState == 4
      && httpobj.status == 200) {
      
      debug(httpobj.responseText, 1);
      debug('using response type ' + config['response_type'], 2);
      
      // fetch correct response
      switch (config['response_type']) {
        case 'XML':
          debug(httpobj.responseXML, 2);
          response = __cpaint_transformer.xml_conversion(httpobj.responseXML);
          break;
          
        case 'OBJECT':
          response = __cpaint_transformer.object_conversion(httpobj.responseXML);
          break;
        
        case 'TEXT':
          response = __cpaint_transformer.text_conversion(httpobj.responseText);
          break;
          
        case 'E4X':
          response = __cpaint_transformer.e4x_conversion(httpobj.responseText);
          break;
          
        case 'JSON':
          response = __cpaint_transformer.json_conversion(httpobj.responseText);
          break;
          
        default:
          debug('invalid response type \'' + response_type + '\'', 0);
      }
      
      // call client side callback
      if (response != null 
        && typeof client_callback == 'function') {
        client_callback(response, httpobj.responseText);
      }
      
      // remove ourselves from the stack
      remove_from_stack();
    
    } else if (httpobj.readyState == 4
      && httpobj.status != 200) {
      // HTTP error of some kind
      debug('invalid HTTP response code \'' + Number(httpobj.status) + '\'', 0);
    }
  }

  /**
  * removes an entry from the stack
  *
  * @access     protected
  * @return     void
  */
  var remove_from_stack = function() {
    // remove only if everything is okay and we're not configured as persistent connection
    if (typeof stack_id == 'number'
      && __cpaint_stack[stack_id]
      && config['persistent_connection'] == false) {
      
      __cpaint_stack[stack_id] = null;
    }
  }

  /**
  * debug method
  *
  * @access  protected
  * @param   string       message         the message to debug
  * @param   integer      debug_level     debug level at which the message appears
  * @return  void
  */
  var debug  = function(message, debug_level) {
    var prefix = '[CPAINT Debug] ';
    
    if (config['debugging'] < 1) {
      prefix = '[CPAINT Error] ';
    }
    
    if (config['debugging'] >= debug_level) {
      alert(prefix + message);
    }
  }
}

/**
* CPAINT transformation object
*
* @package      CPAINT
* @access       public
* @copyright    Copyright (c) 2005-2006 Paul Sullivan, Dominique Stender - http://sf.net/projects/cpaint
* @author       Paul Sullivan <wiley14@gmail.com>
* @author       Dominique Stender <dstender@st-webdevelopment.de>
*/
function cpaint_transformer() {

  /**
  * will take a XMLHttpObject and generate a JavaScript
  * object structure from it.
  *
  * is internally called by cpaint_call.callback() if necessary.
  * will call cpaint_call.create_object_structure() to create nested object structures.
  *
  * @access   public
  * @param    object    xml_document  a XMLHttpObject
  * @return   object
  */
  this.object_conversion = function(xml_document) {
    var return_value  = new cpaint_result_object();
    var i             = 0;
    var firstNodeName = '';
    
    if (typeof xml_document == 'object'
      && xml_document != null) {

      // find the first element node - for MSIE the <?xml?> node is the very first...
      for (i = 0; i < xml_document.childNodes.length; i++) {

        if (xml_document.childNodes[i].nodeType == 1) {
          firstNodeName = xml_document.childNodes[i].nodeName;
          break;
        }
      }
      
      var ajax_response = xml_document.getElementsByTagName(firstNodeName);

      return_value[firstNodeName] = new Array();
    
      for (i = 0; i < ajax_response.length; i++) {
        var tmp_node = create_object_structure(ajax_response[i]);
        tmp_node.id  = ajax_response[i].getAttribute('id')
        return_value[firstNodeName].push(tmp_node);
      }

    } else {
      debug('received invalid XML response', 0);
    }

    return return_value;
  }

  /**
  * performs the necessary conversions for the XML response type
  *
  * @access   public
  * @param    object    xml_document  a XMLHttpObject
  * @return   object
  */
  this.xml_conversion = function(xml_document) {
    return xml_document;
  }
  
  /**
  * performs the necessary conversions for the TEXT response type
  *
  * @access   public
  * @param    string    text  the response text
  * @return   string
  */
  this.text_conversion = function(text) {
    return decode(text);
  }
  
  /**
  * performs the necessary conversions for the E4X response type
  *
  * @access   public
  * @param    string    text  the response text
  * @return   string
  */
  this.e4x_conversion = function(text) {
    // remove <?xml ?>tag
    text = text.replace(/^\<\?xml[^>]+\>/, '');
    return new XML(text);
  }
  
  /**
  * performs the necessary conversions for the JSON response type
  *
  * @access   public
  * @param    string    text  the response text
  * @return   string
  */
  this.json_conversion = function(text) {
    return JSON.parse(text);
  }
  
  /**
  * this method takes a HTML / XML node object and creates a
  * JavaScript object structure from it.
  *
  * @access   public
  * @param    object    stream    a node in the XML structure
  * @return   object
  */
  var create_object_structure = function(stream) {
    var return_value = new cpaint_result_object();
    var node_name = '';
    var i         = 0;
    var attrib    = 0;
    
    if (stream.hasChildNodes() == true) {
      for (i = 0; i < stream.childNodes.length; i++) {
  
        node_name = stream.childNodes[i].nodeName;
        node_name = node_name.replace(/[^a-zA-Z0-9_]*/g, '');
        
        // reset / create subnode
        if (typeof return_value[node_name] != 'object') {
          return_value[node_name] = new Array();
        }
        
        if (stream.childNodes[i].nodeType == 1) {
          var tmp_node  = create_object_structure(stream.childNodes[i]);

          for (attrib = 0; attrib < stream.childNodes[i].attributes.length; attrib++) {
            tmp_node.set_attribute(stream.childNodes[i].attributes[attrib].nodeName, stream.childNodes[i].attributes[attrib].nodeValue);
          }
          
          return_value[node_name].push(tmp_node);
        
        } else if (stream.childNodes[i].nodeType == 3) {
          return_value.data  = decode(String(stream.firstChild.data));
        }
      }
    }
    
    return return_value;
  }

  /**
  * converts an encoded text back to viewable characters.
  *
  * @access     public
  * @param      string      rawtext     raw text as provided by the backend
  * @return     mixed
  */
  var decode = function(rawtext) {
    var plaintext = ''; 
    var i         = 0; 
    var c1        = 0;
    var c2        = 0;
    var c3        = 0;
    var u         = 0;
    var t         = 0;

    // remove special JavaScript encoded non-printable characters
    while (i < rawtext.length) {
      if (rawtext.charAt(i) == '\\'
        && rawtext.charAt(i + 1) == 'u') {
        
        u = 0;
        
        for (j = 2; j < 6; j += 1) {
          t = parseInt(rawtext.charAt(i + j), 16);
          
          if (!isFinite(t)) {
            break;
          }
          u = u * 16 + t;
        }

        plaintext += String.fromCharCode(u);
        i       += 6;
      
      } else {
        plaintext += rawtext.charAt(i);
        i++;
      }
    }

    // convert numeric data to number type
    if (plaintext != ''
      && plaintext.search(/^\s+$/g) == -1
      && !isNaN(plaintext) 
      && isFinite(plaintext)) {
      
      plaintext = Number(plaintext);
    }
  
    return plaintext;
  }
}

/**
* this is the basic prototype for a cpaint node object
* as used in cpaint_call.parse_ajax_xml()
*
* @package      CPAINT
* @access       public
* @copyright    Copyright (c) 2005-2006 Paul Sullivan, Dominique Stender - http://sf.net/projects/cpaint
* @author       Paul Sullivan <wiley14@gmail.com>
* @author       Dominique Stender <dstender@st-webdevelopment.de>
*/
function cpaint_result_object() {
  this.id           = 0;
  this.data         = '';
  var __attributes  = new Array();
  
  /**
  * Returns a subnode with the given type and id.
  *
  * @access     public
  * @param      string    type    The type of the subnode. Equivalent to the XML tag name.
  * @param      string    id      The id of the subnode. Equivalent to the XML tag names id attribute.
  * @return     object
  */
  this.find_item_by_id = function() {
    var return_value  = null;
    var type    = arguments[0];
    var id      = arguments[1];
    var i       = 0;
    
    if (this[type]) {

      for (i = 0; i < this[type].length; i++) {

        if (this[type][i].get_attribute('id') == id) {
          return_value = this[type][i];
          break;
        }
      }
    }

    return return_value;
  }
  
  /**
  * retrieves the value of an attribute.
  *
  * @access   public
  * @param    string    name    name of the attribute
  * @return   mixed
  */
  this.get_attribute = function() {
    var return_value  = null;
    var id            = arguments[0];
    
    if (typeof __attributes[id] != 'undefined') {
      return_value = __attributes[id];
    }
    
    return return_value;
  }
  
  /**
  * assigns a value to an attribute.
  *
  * if that attribute does not exist it will be created.
  *
  * @access     public
  * @param      string    name    name of the attribute
  * @param      string    value   value of the attribute
  * @return     void
  */
  this.set_attribute = function() {
    __attributes[arguments[0]] = arguments[1];
  }
}


/*
Copyright (c) 2005 JSON.org

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The Software shall be used for Good, not Evil.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
*/

Array.prototype.______array = '______array';

var JSON = {
  org: 'http://www.JSON.org',
  copyright: '(c)2005 JSON.org',
  license: 'http://www.crockford.com/JSON/license.html',

  stringify: function (arg) {
    var c, i, l, s = '', v;
    var numeric = true;
    
    switch (typeof arg) {
    case 'object':
      if (arg) {
        if (arg.______array == '______array') {
          // do a test whether all array keys are numeric
          for (i in arg) {
            if (i != '______array'
              && (isNaN(i) 
                || !isFinite(i))) {
              numeric = false;
              break;
            }
          }
          
          if (numeric == true) {
            for (i = 0; i < arg.length; ++i) {
              if (typeof arg[i] != 'undefined') {
                v = this.stringify(arg[i]);
                if (s) {
                  s += ',';
                }
                s += v;
              } else {
                s += ',null';
              }
            }
            return '[' + s + ']';
          } else {
            for (i in arg) {
              if (i != '______array') {
                v = arg[i];
                if (typeof v != 'undefined' && typeof v != 'function') {
                  v = this.stringify(v);
                  if (s) {
                    s += ',';
                  }
                  s += this.stringify(i) + ':' + v;
                }
              }
            }
            // return as object
            return '{' + s + '}';
          }
        } else if (typeof arg.toString != 'undefined') {
          for (i in arg) {
            v = arg[i];
            if (typeof v != 'undefined' && typeof v != 'function') {
              v = this.stringify(v);
              if (s) {
                s += ',';
              }
              s += this.stringify(i) + ':' + v;
            }
          }
          return '{' + s + '}';
        }
      }
      return 'null';
    case 'number':
      return isFinite(arg) ? String(arg) : 'null';
    case 'string':
      l = arg.length;
      s = '"';
      for (i = 0; i < l; i += 1) {
        c = arg.charAt(i);
        if (c >= ' ') {
          if (c == '\\' || c == '"') {
            s += '\\';
          }
          s += c;
        } else {
          switch (c) {
            case '\b':
              s += '\\b';
              break;
            case '\f':
              s += '\\f';
              break;
            case '\n':
              s += '\\n';
              break;
            case '\r':
              s += '\\r';
              break;
            case '\t':
              s += '\\t';
              break;
            default:
              c = c.charCodeAt();
              s += '\\u00' + Math.floor(c / 16).toString(16) +
                (c % 16).toString(16);
          }
        }
      }
      return s + '"';
    case 'boolean':
      return String(arg);
    default:
      return 'null';
    }
  },
  parse: function (text) {
    var at = 0;
    var ch = ' ';

    function error(m) {
      throw {
        name: 'JSONError',
        message: m,
        at: at - 1,
        text: text
      };
    }

    function next() {
      ch = text.charAt(at);
      at += 1;
      return ch;
    }

    function white() {
      while (ch != '' && ch <= ' ') {
        next();
      }
    }

    function str() {
      var i, s = '', t, u;

      if (ch == '"') {
outer:      while (next()) {
          if (ch == '"') {
            next();
            return s;
          } else if (ch == '\\') {
            switch (next()) {
            case 'b':
              s += '\b';
              break;
            case 'f':
              s += '\f';
              break;
            case 'n':
              s += '\n';
              break;
            case 'r':
              s += '\r';
              break;
            case 't':
              s += '\t';
              break;
            case 'u':
              u = 0;
              for (i = 0; i < 4; i += 1) {
                t = parseInt(next(), 16);
                if (!isFinite(t)) {
                  break outer;
                }
                u = u * 16 + t;
              }
              s += String.fromCharCode(u);
              break;
            default:
              s += ch;
            }
          } else {
            s += ch;
          }
        }
      }
      error("Bad string");
    }

    function arr() {
      var a = [];

      if (ch == '[') {
        next();
        white();
        if (ch == ']') {
          next();
          return a;
        }
        while (ch) {
          a.push(val());
          white();
          if (ch == ']') {
            next();
            return a;
          } else if (ch != ',') {
            break;
          }
          next();
          white();
        }
      }
      error("Bad array");
    }

    function obj() {
      var k, o = {};

      if (ch == '{') {
        next();
        white();
        if (ch == '}') {
          next();
          return o;
        }
        while (ch) {
          k = str();
          white();
          if (ch != ':') {
            break;
          }
          next();
          o[k] = val();
          white();
          if (ch == '}') {
            next();
            return o;
          } else if (ch != ',') {
            break;
          }
          next();
          white();
        }
      }
      error("Bad object");
    }

    function assoc() {
      var k, a = [];

      if (ch == '<') {
        next();
        white();
        if (ch == '>') {
          next();
          return a;
        }
        while (ch) {
          k = str();
          white();
          if (ch != ':') {
            break;
          }
          next();
          a[k] = val();
          white();
          if (ch == '>') {
            next();
            return a;
          } else if (ch != ',') {
            break;
          }
          next();
          white();
        }
      }
      error("Bad associative array");
    }

    function num() {
      var n = '', v;
      if (ch == '-') {
        n = '-';
        next();
      }
      while (ch >= '0' && ch <= '9') {
        n += ch;
        next();
      }
      if (ch == '.') {
        n += '.';
        while (next() && ch >= '0' && ch <= '9') {
          n += ch;
        }
      }
      if (ch == 'e' || ch == 'E') {
        n += 'e';
        next();
        if (ch == '-' || ch == '+') {
          n += ch;
          next();
        }
        while (ch >= '0' && ch <= '9') {
          n += ch;
          next();
        }
      }
      v = +n;
      if (!isFinite(v)) {
        error("Bad number");
      } else {
        return v;
      }
    }

    function word() {
      switch (ch) {
        case 't':
          if (next() == 'r' && next() == 'u' && next() == 'e') {
            next();
            return true;
          }
          break;
        case 'f':
          if (next() == 'a' && next() == 'l' && next() == 's' &&
              next() == 'e') {
            next();
            return false;
          }
          break;
        case 'n':
          if (next() == 'u' && next() == 'l' && next() == 'l') {
            next();
            return null;
          }
          break;
      }
      error("Syntax error");
    }

    function val() {
      white();
      switch (ch) {
        case '{':
          return obj();
        case '[':
          return arr();
        case '<':
          return assoc();
        case '"':
          return str();
        case '-':
          return num();
        default:
          return ch >= '0' && ch <= '9' ? num() : word();
      }
    }

    return val();
  }
};



// Flash Player Version Detection - Rev 1.6
// Detect Client Browser type
// Copyright(c) 2005-2006 Adobe Macromedia Software, LLC. All rights reserved.
var isIE  = (navigator.appVersion.indexOf("MSIE") != -1) ? true : false;
var isWin = (navigator.appVersion.toLowerCase().indexOf("win") != -1) ? true : false;
var isOpera = (navigator.userAgent.indexOf("Opera") != -1) ? true : false;

function ControlVersion()
{
    var version;
    var axo;
    var e;

    // NOTE : new ActiveXObject(strFoo) throws an exception if strFoo isn't in the registry

    try {
        // version will be set for 7.X or greater players
        axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");
        version = axo.GetVariable("$version");
    } catch (e) {
    }

    if (!version)
    {
        try {
            // version will be set for 6.X players only
            axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");
            
            // installed player is some revision of 6.0
            // GetVariable("$version") crashes for versions 6.0.22 through 6.0.29,
            // so we have to be careful. 
            
            // default to the first public version
            version = "WIN 6,0,21,0";

            // throws if AllowScripAccess does not exist (introduced in 6.0r47)        
            axo.AllowScriptAccess = "always";

            // safe to call for 6.0r47 or greater
            version = axo.GetVariable("$version");

        } catch (e) {
        }
    }

    if (!version)
    {
        try {
            // version will be set for 4.X or 5.X player
            axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
            version = axo.GetVariable("$version");
        } catch (e) {
        }
    }

    if (!version)
    {
        try {
            // version will be set for 3.X player
            axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash.3");
            version = "WIN 3,0,18,0";
        } catch (e) {
        }
    }

    if (!version)
    {
        try {
            // version will be set for 2.X player
            axo = new ActiveXObject("ShockwaveFlash.ShockwaveFlash");
            version = "WIN 2,0,0,11";
        } catch (e) {
            version = -1;
        }
    }
    
    return version;
}

// JavaScript helper required to detect Flash Player PlugIn version information
function GetSwfVer(){
    // NS/Opera version >= 3 check for Flash plugin in plugin array
    var flashVer = -1;
    
    if (navigator.plugins != null && navigator.plugins.length > 0) {
        if (navigator.plugins["Shockwave Flash 2.0"] || navigator.plugins["Shockwave Flash"]) {
            var swVer2 = navigator.plugins["Shockwave Flash 2.0"] ? " 2.0" : "";
            var flashDescription = navigator.plugins["Shockwave Flash" + swVer2].description;
            var descArray = flashDescription.split(" ");
            var tempArrayMajor = descArray[2].split(".");            
            var versionMajor = tempArrayMajor[0];
            var versionMinor = tempArrayMajor[1];
            var versionRevision = descArray[3];
            if (versionRevision == "") {
                versionRevision = descArray[4];
            }
            if (versionRevision[0] == "d") {
                versionRevision = versionRevision.substring(1);
            } else if (versionRevision[0] == "r") {
                versionRevision = versionRevision.substring(1);
                if (versionRevision.indexOf("d") > 0) {
                    versionRevision = versionRevision.substring(0, versionRevision.indexOf("d"));
                }
            }
            var flashVer = versionMajor + "." + versionMinor + "." + versionRevision;
//            alert("flashVer="+flashVer);
        }
    }
    // MSN/WebTV 2.6 supports Flash 4
    else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.6") != -1) flashVer = 4;
    // WebTV 2.5 supports Flash 3
    else if (navigator.userAgent.toLowerCase().indexOf("webtv/2.5") != -1) flashVer = 3;
    // older WebTV supports Flash 2
    else if (navigator.userAgent.toLowerCase().indexOf("webtv") != -1) flashVer = 2;
    else if ( isIE && isWin && !isOpera ) {
        flashVer = ControlVersion();
    }    
    return flashVer;
}

// When called with reqMajorVer, reqMinorVer, reqRevision returns true if that version or greater is available
function DetectFlashVer(reqMajorVer, reqMinorVer, reqRevision)
{
    versionStr = GetSwfVer();
    if (versionStr == -1 ) {
        return false;
    } else if (versionStr != 0) {
        if(isIE && isWin && !isOpera) {
            // Given "WIN 2,0,0,11"
            tempArray         = versionStr.split(" ");     // ["WIN", "2,0,0,11"]
            tempString        = tempArray[1];            // "2,0,0,11"
            versionArray      = tempString.split(",");    // ['2', '0', '0', '11']
        } else {
            versionArray      = versionStr.split(".");
        }
        var versionMajor      = versionArray[0];
        var versionMinor      = versionArray[1];
        var versionRevision   = versionArray[2];

            // is the major.revision >= requested major.revision AND the minor version >= requested minor
        if (versionMajor > parseFloat(reqMajorVer)) {
            return true;
        } else if (versionMajor == parseFloat(reqMajorVer)) {
            if (versionMinor > parseFloat(reqMinorVer))
                return true;
            else if (versionMinor == parseFloat(reqMinorVer)) {
                if (versionRevision >= parseFloat(reqRevision))
                    return true;
            }
        }
        return false;
    }
}

function AC_AddExtension(src, ext)
{
  if (src.indexOf('?') != -1)
    return src.replace(/\?/, ext+'?'); 
  else
    return src + ext;
}

function AC_Generateobj(objAttrs, params, embedAttrs) 
{ 
    var str = '';
    if (isIE && isWin && !isOpera)
    {
          str += '<object ';
          for (var i in objAttrs)
              str += i + '="' + objAttrs[i] + '" ';
          for (var i in params)
              str += '><param name="' + i + '" value="' + params[i] + '" /> ';
          str += '></object>';
    } else {
          str += '<embed ';
          for (var i in embedAttrs)
              str += i + '="' + embedAttrs[i] + '" ';
          str += '> </embed>';
    }

    document.write(str);
}

function AC_FL_RunContent(){
  var ret = 
    AC_GetArgs
    (  arguments, ".swf", "movie", "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"
     , "application/x-shockwave-flash"
    );
  AC_Generateobj(ret.objAttrs, ret.params, ret.embedAttrs);
}

function AC_GetArgs(args, ext, srcParamName, classid, mimeType){
  var ret = new Object();
  ret.embedAttrs = new Object();
  ret.params = new Object();
  ret.objAttrs = new Object();
  for (var i=0; i < args.length; i=i+2){
    var currArg = args[i].toLowerCase();    

    switch (currArg){    
      case "classid":
        break;
      case "pluginspage":
        ret.embedAttrs[args[i]] = args[i+1];
        break;
      case "src":
      case "movie":    
        args[i+1] = AC_AddExtension(args[i+1], ext);
        ret.embedAttrs["src"] = args[i+1];
        ret.params[srcParamName] = args[i+1];
        break;
      case "onafterupdate":
      case "onbeforeupdate":
      case "onblur":
      case "oncellchange":
      case "onclick":
      case "ondblClick":
      case "ondrag":
      case "ondragend":
      case "ondragenter":
      case "ondragleave":
      case "ondragover":
      case "ondrop":
      case "onfinish":
      case "onfocus":
      case "onhelp":
      case "onmousedown":
      case "onmouseup":
      case "onmouseover":
      case "onmousemove":
      case "onmouseout":
      case "onkeypress":
      case "onkeydown":
      case "onkeyup":
      case "onload":
      case "onlosecapture":
      case "onpropertychange":
      case "onreadystatechange":
      case "onrowsdelete":
      case "onrowenter":
      case "onrowexit":
      case "onrowsinserted":
      case "onstart":
      case "onscroll":
      case "onbeforeeditfocus":
      case "onactivate":
      case "onbeforedeactivate":
      case "ondeactivate":
      case "type":
      case "codebase":
        ret.objAttrs[args[i]] = args[i+1];
        break;
      case "id":
      case "width":
      case "height":
      case "align":
      case "vspace": 
      case "hspace":
      case "class":
      case "title":
      case "accesskey":
      case "name":
      case "tabindex":
        ret.embedAttrs[args[i]] = ret.objAttrs[args[i]] = args[i+1];
        break;
      default:
        ret.embedAttrs[args[i]] = ret.params[args[i]] = args[i+1];
    }
  }
  ret.objAttrs["classid"] = classid;
  if (mimeType) ret.embedAttrs["type"] = mimeType;
  return ret;
}


/*
CSS Browser Selector v0.2.9
Rafael Lima (http://rafael.adm.br)
http://rafael.adm.br/css_browser_selector
License: http://creativecommons.org/licenses/by/2.5/
Contributors: http://rafael.adm.br/css_browser_selector#contributors
*/
var css_browser_selector = function() {var ua=navigator.userAgent.toLowerCase(),is=function(t){return ua.indexOf(t) != -1;},h=document.getElementsByTagName('html')[0],b=(!(/opera|webtv/i.test(ua))&&/msie\s(\d)/.test(ua))?('ie ie'+RegExp.$1):is('firefox/2')?'gecko ff2':is('firefox/3')?'gecko ff3':is('gecko/')?'gecko':is('opera/9')?'opera opera9':/opera\s(\d)/.test(ua)?'opera opera'+RegExp.$1:is('konqueror')?'konqueror':is('chrome')?'chrome webkit safari':is('applewebkit/')?'webkit safari':is('mozilla/')?'gecko':'',os=(is('x11')||is('linux'))?' linux':is('mac')?' mac':is('win')?' win':'';var c=b+os+' js'; h.className += h.className?' '+c:c;}();
 
 

 /****************************************************************
  *                                                              *
  *  curvyCorners                                                *
  *  ------------                                                *
  *                                                              *
  *  This script generates rounded corners for your divs.        *
  *                                                              *
  *  Version 1.2.7                                               *
  *  Copyright (c) 2006 Cameron Cooke                            *
  *  By: Cameron Cooke and Tim Hutchison.                        *
  *                                                              *
  *                                                              *
  *  Website: http://www.curvycorners.net                        *
  *  Email:   info@totalinfinity.com                             *
  *  Forum:   http://www.curvycorners.net/forum/                 *
  *                                                              *
  *                                                              *
  *  This library is free software; you can redistribute         *
  *  it and/or modify it under the terms of the GNU              *
  *  Lesser General Public License as published by the           *
  *  Free Software Foundation; either version 2.1 of the         *
  *  License, or (at your option) any later version.             *
  *                                                              *
  *  This library is distributed in the hope that it will        *
  *  be useful, but WITHOUT ANY WARRANTY; without even the       *
  *  implied warranty of MERCHANTABILITY or FITNESS FOR A        *
  *  PARTICULAR PURPOSE. See the GNU Lesser General Public       *
  *  License for more details.                                   *
  *                                                              *
  *  You should have received a copy of the GNU Lesser           *
  *  General Public License along with this library;             *
  *  Inc., 59 Temple Place, Suite 330, Boston,                   *
  *  MA 02111-1307 USA                                           *
  *                                                              *
  ****************************************************************/

var isIE = navigator.userAgent.toLowerCase().indexOf("msie") > -1; var isMoz = document.implementation && document.implementation.createDocument; var isSafari = ((navigator.userAgent.toLowerCase().indexOf('safari')!=-1)&&(navigator.userAgent.toLowerCase().indexOf('mac')!=-1))?true:false; function curvyCorners()
{ if(typeof(arguments[0]) != "object") throw newCurvyError("First parameter of curvyCorners() must be an object."); if(typeof(arguments[1]) != "object" && typeof(arguments[1]) != "string") throw newCurvyError("Second parameter of curvyCorners() must be an object or a class name."); if(typeof(arguments[1]) == "string")
{ var startIndex = 0; var boxCol = getElementsByClass(arguments[1]);}
else
{ var startIndex = 1; var boxCol = arguments;}
var curvyCornersCol = new Array(); for(var i = startIndex, j = boxCol.length; i < j; i++)
{ if(boxCol[i].tagName.toLowerCase() == "div")
{ curvyCornersCol[curvyCornersCol.length] = new curvyObject(arguments[0], boxCol[i]);}
}
this.objects = curvyCornersCol; this.applyCornersToAll = function()
{ for(var x = 0, k = this.objects.length; x < k; x++)
{ this.objects[x].applyCorners();}
}
}
function curvyObject()
{ this.box = arguments[1]; this.settings = arguments[0]; this.topContainer = null; this.bottomContainer = null; this.masterCorners = new Array(); this.contentDIV = null; var boxHeight = get_style(this.box, "height", "height"); var boxWidth = get_style(this.box, "width", "width"); var borderWidth = get_style(this.box, "borderTopWidth", "border-top-width"); var borderColour = get_style(this.box, "borderTopColor", "border-top-color"); var boxColour = get_style(this.box, "backgroundColor", "background-color"); var backgroundImage = get_style(this.box, "backgroundImage", "background-image"); var boxPosition = get_style(this.box, "position", "position"); var boxPadding = get_style(this.box, "paddingTop", "padding-top"); this.boxHeight = parseInt(((boxHeight != "" && boxHeight != "auto" && boxHeight.indexOf("%") == -1)? boxHeight.substring(0, boxHeight.indexOf("px")) : this.box.scrollHeight)); this.boxWidth = parseInt(((boxWidth != "" && boxWidth != "auto" && boxWidth.indexOf("%") == -1)? boxWidth.substring(0, boxWidth.indexOf("px")) : this.box.scrollWidth)); this.borderWidth = parseInt(((borderWidth != "" && borderWidth.indexOf("px") !== -1)? borderWidth.slice(0, borderWidth.indexOf("px")) : 0)); this.boxColour = format_colour(boxColour); this.boxPadding = parseInt(((boxPadding != "" && boxPadding.indexOf("px") !== -1)? boxPadding.slice(0, boxPadding.indexOf("px")) : 0)); this.borderColour = format_colour(borderColour); this.borderString = this.borderWidth + "px" + " solid " + this.borderColour; this.backgroundImage = ((backgroundImage != "none")? backgroundImage : ""); this.boxContent = this.box.innerHTML; if(boxPosition != "absolute") this.box.style.position = "relative"; this.box.style.padding = "0px"; if(isIE && boxWidth == "auto" && boxHeight == "auto") this.box.style.width = "100%"; if(this.settings.autoPad == true && this.boxPadding > 0)
this.box.innerHTML = ""; this.applyCorners = function()
{ for(var t = 0; t < 2; t++)
{ switch(t)
{ case 0:
if(this.settings.tl || this.settings.tr)
{ var newMainContainer = document.createElement("DIV"); newMainContainer.style.width = "100%"; newMainContainer.style.fontSize = "1px"; newMainContainer.style.overflow = "hidden"; newMainContainer.style.position = "absolute"; newMainContainer.style.paddingLeft = this.borderWidth + "px"; newMainContainer.style.paddingRight = this.borderWidth + "px"; var topMaxRadius = Math.max(this.settings.tl ? this.settings.tl.radius : 0, this.settings.tr ? this.settings.tr.radius : 0); newMainContainer.style.height = topMaxRadius + "px"; newMainContainer.style.top = 0 - topMaxRadius + "px"; newMainContainer.style.left = 0 - this.borderWidth + "px"; this.topContainer = this.box.appendChild(newMainContainer);}
break; case 1:
if(this.settings.bl || this.settings.br)
{ var newMainContainer = document.createElement("DIV"); newMainContainer.style.width = "100%"; newMainContainer.style.fontSize = "1px"; newMainContainer.style.overflow = "hidden"; newMainContainer.style.position = "absolute"; newMainContainer.style.paddingLeft = this.borderWidth + "px"; newMainContainer.style.paddingRight = this.borderWidth + "px"; var botMaxRadius = Math.max(this.settings.bl ? this.settings.bl.radius : 0, this.settings.br ? this.settings.br.radius : 0); newMainContainer.style.height = botMaxRadius + "px"; newMainContainer.style.bottom = 0 - botMaxRadius + "px"; newMainContainer.style.left = 0 - this.borderWidth + "px"; this.bottomContainer = this.box.appendChild(newMainContainer);}
break;}
}
if(this.topContainer) this.box.style.borderTopWidth = "0px"; if(this.bottomContainer) this.box.style.borderBottomWidth = "0px"; var corners = ["tr", "tl", "br", "bl"]; for(var i in corners)
{ var cc = corners[i]; if(!this.settings[cc])
{ if(((cc == "tr" || cc == "tl") && this.topContainer != null) || ((cc == "br" || cc == "bl") && this.bottomContainer != null))
{ var newCorner = document.createElement("DIV"); newCorner.style.position = "relative"; newCorner.style.fontSize = "1px"; newCorner.style.overflow = "hidden"; if(this.backgroundImage == "")
newCorner.style.backgroundColor = this.boxColour; else
newCorner.style.backgroundImage = this.backgroundImage; switch(cc)
{ case "tl":
newCorner.style.height = topMaxRadius - this.borderWidth + "px"; newCorner.style.marginRight = this.settings.tr.radius - (this.borderWidth*2) + "px"; newCorner.style.borderLeft = this.borderString; newCorner.style.borderTop = this.borderString; newCorner.style.left = -this.borderWidth + "px"; break; case "tr":
newCorner.style.height = topMaxRadius - this.borderWidth + "px"; newCorner.style.marginLeft = this.settings.tl.radius - (this.borderWidth*2) + "px"; newCorner.style.borderRight = this.borderString; newCorner.style.borderTop = this.borderString; newCorner.style.backgroundPosition = "-" + (topMaxRadius + this.borderWidth) + "px 0px"; newCorner.style.left = this.borderWidth + "px"; break; case "bl":
newCorner.style.height = botMaxRadius - this.borderWidth + "px"; newCorner.style.marginRight = this.settings.br.radius - (this.borderWidth*2) + "px"; newCorner.style.borderLeft = this.borderString; newCorner.style.borderBottom = this.borderString; newCorner.style.left = -this.borderWidth + "px"; newCorner.style.backgroundPosition = "-" + (this.borderWidth) + "px -" + (this.boxHeight + (botMaxRadius + this.borderWidth)) + "px"; break; case "br":
newCorner.style.height = botMaxRadius - this.borderWidth + "px"; newCorner.style.marginLeft = this.settings.bl.radius - (this.borderWidth*2) + "px"; newCorner.style.borderRight = this.borderString; newCorner.style.borderBottom = this.borderString; newCorner.style.left = this.borderWidth + "px"
newCorner.style.backgroundPosition = "-" + (botMaxRadius + this.borderWidth) + "px -" + (this.boxHeight + (botMaxRadius + this.borderWidth)) + "px"; break;}
}
}
else
{ if(this.masterCorners[this.settings[cc].radius])
{ var newCorner = this.masterCorners[this.settings[cc].radius].cloneNode(true);}
else
{ var newCorner = document.createElement("DIV"); newCorner.style.height = this.settings[cc].radius + "px"; newCorner.style.width = this.settings[cc].radius + "px"; newCorner.style.position = "absolute"; newCorner.style.fontSize = "1px"; newCorner.style.overflow = "hidden"; var borderRadius = parseInt(this.settings[cc].radius - this.borderWidth); for(var intx = 0, j = this.settings[cc].radius; intx < j; intx++)
{ if((intx +1) >= borderRadius)
var y1 = -1; else
var y1 = (Math.floor(Math.sqrt(Math.pow(borderRadius, 2) - Math.pow((intx+1), 2))) - 1); if(borderRadius != j)
{ if((intx) >= borderRadius)
var y2 = -1; else
var y2 = Math.ceil(Math.sqrt(Math.pow(borderRadius,2) - Math.pow(intx, 2))); if((intx+1) >= j)
var y3 = -1; else
var y3 = (Math.floor(Math.sqrt(Math.pow(j ,2) - Math.pow((intx+1), 2))) - 1);}
if((intx) >= j)
var y4 = -1; else
var y4 = Math.ceil(Math.sqrt(Math.pow(j ,2) - Math.pow(intx, 2))); if(y1 > -1) this.drawPixel(intx, 0, this.boxColour, 100, (y1+1), newCorner, -1, this.settings[cc].radius); if(borderRadius != j)
{ for(var inty = (y1 + 1); inty < y2; inty++)
{ if(this.settings.antiAlias)
{ if(this.backgroundImage != "")
{ var borderFract = (pixelFraction(intx, inty, borderRadius) * 100); if(borderFract < 30)
{ this.drawPixel(intx, inty, this.borderColour, 100, 1, newCorner, 0, this.settings[cc].radius);}
else
{ this.drawPixel(intx, inty, this.borderColour, 100, 1, newCorner, -1, this.settings[cc].radius);}
}
else
{ var pixelcolour = BlendColour(this.boxColour, this.borderColour, pixelFraction(intx, inty, borderRadius)); this.drawPixel(intx, inty, pixelcolour, 100, 1, newCorner, 0, this.settings[cc].radius, cc);}
}
}
if(this.settings.antiAlias)
{ if(y3 >= y2)
{ if (y2 == -1) y2 = 0; this.drawPixel(intx, y2, this.borderColour, 100, (y3 - y2 + 1), newCorner, 0, 0);}
}
else
{ if(y3 >= y1)
{ this.drawPixel(intx, (y1 + 1), this.borderColour, 100, (y3 - y1), newCorner, 0, 0);}
}
var outsideColour = this.borderColour;}
else
{ var outsideColour = this.boxColour; var y3 = y1;}
if(this.settings.antiAlias)
{ for(var inty = (y3 + 1); inty < y4; inty++)
{ this.drawPixel(intx, inty, outsideColour, (pixelFraction(intx, inty , j) * 100), 1, newCorner, ((this.borderWidth > 0)? 0 : -1), this.settings[cc].radius);}
}
}
this.masterCorners[this.settings[cc].radius] = newCorner.cloneNode(true);}
if(cc != "br")
{ for(var t = 0, k = newCorner.childNodes.length; t < k; t++)
{ var pixelBar = newCorner.childNodes[t]; var pixelBarTop = parseInt(pixelBar.style.top.substring(0, pixelBar.style.top.indexOf("px"))); var pixelBarLeft = parseInt(pixelBar.style.left.substring(0, pixelBar.style.left.indexOf("px"))); var pixelBarHeight = parseInt(pixelBar.style.height.substring(0, pixelBar.style.height.indexOf("px"))); if(cc == "tl" || cc == "bl"){ pixelBar.style.left = this.settings[cc].radius -pixelBarLeft -1 + "px";}
if(cc == "tr" || cc == "tl"){ pixelBar.style.top = this.settings[cc].radius -pixelBarHeight -pixelBarTop + "px";}
switch(cc)
{ case "tr":
pixelBar.style.backgroundPosition = "-" + Math.abs((this.boxWidth - this.settings[cc].radius + this.borderWidth) + pixelBarLeft) + "px -" + Math.abs(this.settings[cc].radius -pixelBarHeight -pixelBarTop - this.borderWidth) + "px"; break; case "tl":
pixelBar.style.backgroundPosition = "-" + Math.abs((this.settings[cc].radius -pixelBarLeft -1) - this.borderWidth) + "px -" + Math.abs(this.settings[cc].radius -pixelBarHeight -pixelBarTop - this.borderWidth) + "px"; break; case "bl":
pixelBar.style.backgroundPosition = "-" + Math.abs((this.settings[cc].radius -pixelBarLeft -1) - this.borderWidth) + "px -" + Math.abs((this.boxHeight + this.settings[cc].radius + pixelBarTop) -this.borderWidth) + "px"; break;}
}
}
}
if(newCorner)
{ switch(cc)
{ case "tl":
if(newCorner.style.position == "absolute") newCorner.style.top = "0px"; if(newCorner.style.position == "absolute") newCorner.style.left = "0px"; if(this.topContainer) this.topContainer.appendChild(newCorner); break; case "tr":
if(newCorner.style.position == "absolute") newCorner.style.top = "0px"; if(newCorner.style.position == "absolute") newCorner.style.right = "0px"; if(this.topContainer) this.topContainer.appendChild(newCorner); break; case "bl":
if(newCorner.style.position == "absolute") newCorner.style.bottom = "0px"; if(newCorner.style.position == "absolute") newCorner.style.left = "0px"; if(this.bottomContainer) this.bottomContainer.appendChild(newCorner); break; case "br":
if(newCorner.style.position == "absolute") newCorner.style.bottom = "0px"; if(newCorner.style.position == "absolute") newCorner.style.right = "0px"; if(this.bottomContainer) this.bottomContainer.appendChild(newCorner); break;}
}
}
var radiusDiff = new Array(); radiusDiff["t"] = Math.abs(this.settings.tl.radius - this.settings.tr.radius)
radiusDiff["b"] = Math.abs(this.settings.bl.radius - this.settings.br.radius); for(z in radiusDiff)
{ if(radiusDiff[z])
{ var smallerCornerType = ((this.settings[z + "l"].radius < this.settings[z + "r"].radius)? z +"l" : z +"r"); var newFiller = document.createElement("DIV"); newFiller.style.height = radiusDiff[z] + "px"; newFiller.style.width = this.settings[smallerCornerType].radius+ "px"
newFiller.style.position = "absolute"; newFiller.style.fontSize = "1px"; newFiller.style.overflow = "hidden"; newFiller.style.backgroundColor = this.boxColour; switch(smallerCornerType)
{ case "tl":
newFiller.style.bottom = "0px"; newFiller.style.left = "0px"; newFiller.style.borderLeft = this.borderString; this.topContainer.appendChild(newFiller); break; case "tr":
newFiller.style.bottom = "0px"; newFiller.style.right = "0px"; newFiller.style.borderRight = this.borderString; this.topContainer.appendChild(newFiller); break; case "bl":
newFiller.style.top = "0px"; newFiller.style.left = "0px"; newFiller.style.borderLeft = this.borderString; this.bottomContainer.appendChild(newFiller); break; case "br":
newFiller.style.top = "0px"; newFiller.style.right = "0px"; newFiller.style.borderRight = this.borderString; this.bottomContainer.appendChild(newFiller); break;}
}
var newFillerBar = document.createElement("DIV"); newFillerBar.style.position = "relative"; newFillerBar.style.fontSize = "1px"; newFillerBar.style.overflow = "hidden"; newFillerBar.style.backgroundColor = this.boxColour; newFillerBar.style.backgroundImage = this.backgroundImage; switch(z)
{ case "t":
if(this.topContainer)
{ if(this.settings.tl.radius && this.settings.tr.radius)
{ newFillerBar.style.height = topMaxRadius - this.borderWidth + "px"; newFillerBar.style.marginLeft = this.settings.tl.radius - this.borderWidth + "px"; newFillerBar.style.marginRight = this.settings.tr.radius - this.borderWidth + "px"; newFillerBar.style.borderTop = this.borderString; if(this.backgroundImage != "")
newFillerBar.style.backgroundPosition = "-" + (topMaxRadius + this.borderWidth) + "px 0px"; this.topContainer.appendChild(newFillerBar);}
this.box.style.backgroundPosition = "0px -" + (topMaxRadius - this.borderWidth) + "px";}
break; case "b":
if(this.bottomContainer)
{ if(this.settings.bl.radius && this.settings.br.radius)
{ newFillerBar.style.height = botMaxRadius - this.borderWidth + "px"; newFillerBar.style.marginLeft = this.settings.bl.radius - this.borderWidth + "px"; newFillerBar.style.marginRight = this.settings.br.radius - this.borderWidth + "px"; newFillerBar.style.borderBottom = this.borderString; if(this.backgroundImage != "")
newFillerBar.style.backgroundPosition = "-" + (botMaxRadius + this.borderWidth) + "px -" + (this.boxHeight + (topMaxRadius + this.borderWidth)) + "px"; this.bottomContainer.appendChild(newFillerBar);}
}
break;}
}
if(this.settings.autoPad == true && this.boxPadding > 0)
{ var contentContainer = document.createElement("DIV"); contentContainer.style.position = "relative"; contentContainer.innerHTML = this.boxContent; contentContainer.className = "autoPadDiv"; var topPadding = Math.abs(topMaxRadius - this.boxPadding); var botPadding = Math.abs(botMaxRadius - this.boxPadding); if(topMaxRadius < this.boxPadding)
contentContainer.style.paddingTop = topPadding + "px"; if(botMaxRadius < this.boxPadding)
contentContainer.style.paddingBottom = botMaxRadius + "px"; contentContainer.style.paddingLeft = this.boxPadding + "px"; contentContainer.style.paddingRight = this.boxPadding + "px"; this.contentDIV = this.box.appendChild(contentContainer);}
}
this.drawPixel = function(intx, inty, colour, transAmount, height, newCorner, image, cornerRadius)
{ var pixel = document.createElement("DIV"); pixel.style.height = height + "px"; pixel.style.width = "1px"; pixel.style.position = "absolute"; pixel.style.fontSize = "1px"; pixel.style.overflow = "hidden"; var topMaxRadius = Math.max(this.settings["tr"].radius, this.settings["tl"].radius); if(image == -1 && this.backgroundImage != "")
{ pixel.style.backgroundImage = this.backgroundImage; pixel.style.backgroundPosition = "-" + (this.boxWidth - (cornerRadius - intx) + this.borderWidth) + "px -" + ((this.boxHeight + topMaxRadius + inty) -this.borderWidth) + "px";}
else
{ pixel.style.backgroundColor = colour;}
if (transAmount != 100)
setOpacity(pixel, transAmount); pixel.style.top = inty + "px"; pixel.style.left = intx + "px"; newCorner.appendChild(pixel);}
}
function insertAfter(parent, node, referenceNode)
{ parent.insertBefore(node, referenceNode.nextSibling);}
function BlendColour(Col1, Col2, Col1Fraction)
{ var red1 = parseInt(Col1.substr(1,2),16); var green1 = parseInt(Col1.substr(3,2),16); var blue1 = parseInt(Col1.substr(5,2),16); var red2 = parseInt(Col2.substr(1,2),16); var green2 = parseInt(Col2.substr(3,2),16); var blue2 = parseInt(Col2.substr(5,2),16); if(Col1Fraction > 1 || Col1Fraction < 0) Col1Fraction = 1; var endRed = Math.round((red1 * Col1Fraction) + (red2 * (1 - Col1Fraction))); if(endRed > 255) endRed = 255; if(endRed < 0) endRed = 0; var endGreen = Math.round((green1 * Col1Fraction) + (green2 * (1 - Col1Fraction))); if(endGreen > 255) endGreen = 255; if(endGreen < 0) endGreen = 0; var endBlue = Math.round((blue1 * Col1Fraction) + (blue2 * (1 - Col1Fraction))); if(endBlue > 255) endBlue = 255; if(endBlue < 0) endBlue = 0; return "#" + IntToHex(endRed)+ IntToHex(endGreen)+ IntToHex(endBlue);}
function IntToHex(strNum)
{ base = strNum / 16; rem = strNum % 16; base = base - (rem / 16); baseS = MakeHex(base); remS = MakeHex(rem); return baseS + '' + remS;}
function MakeHex(x)
{ if((x >= 0) && (x <= 9))
{ return x;}
else
{ switch(x)
{ case 10: return "A"; case 11: return "B"; case 12: return "C"; case 13: return "D"; case 14: return "E"; case 15: return "F";}
}
}
function pixelFraction(x, y, r)
{ var pixelfraction = 0; var xvalues = new Array(1); var yvalues = new Array(1); var point = 0; var whatsides = ""; var intersect = Math.sqrt((Math.pow(r,2) - Math.pow(x,2))); if ((intersect >= y) && (intersect < (y+1)))
{ whatsides = "Left"; xvalues[point] = 0; yvalues[point] = intersect - y; point = point + 1;}
var intersect = Math.sqrt((Math.pow(r,2) - Math.pow(y+1,2))); if ((intersect >= x) && (intersect < (x+1)))
{ whatsides = whatsides + "Top"; xvalues[point] = intersect - x; yvalues[point] = 1; point = point + 1;}
var intersect = Math.sqrt((Math.pow(r,2) - Math.pow(x+1,2))); if ((intersect >= y) && (intersect < (y+1)))
{ whatsides = whatsides + "Right"; xvalues[point] = 1; yvalues[point] = intersect - y; point = point + 1;}
var intersect = Math.sqrt((Math.pow(r,2) - Math.pow(y,2))); if ((intersect >= x) && (intersect < (x+1)))
{ whatsides = whatsides + "Bottom"; xvalues[point] = intersect - x; yvalues[point] = 0;}
switch (whatsides)
{ case "LeftRight":
pixelfraction = Math.min(yvalues[0],yvalues[1]) + ((Math.max(yvalues[0],yvalues[1]) - Math.min(yvalues[0],yvalues[1]))/2); break; case "TopRight":
pixelfraction = 1-(((1-xvalues[0])*(1-yvalues[1]))/2); break; case "TopBottom":
pixelfraction = Math.min(xvalues[0],xvalues[1]) + ((Math.max(xvalues[0],xvalues[1]) - Math.min(xvalues[0],xvalues[1]))/2); break; case "LeftBottom":
pixelfraction = (yvalues[0]*xvalues[1])/2; break; default:
pixelfraction = 1;}
return pixelfraction;}
function rgb2Hex(rgbColour)
{ try{ var rgbArray = rgb2Array(rgbColour); var red = parseInt(rgbArray[0]); var green = parseInt(rgbArray[1]); var blue = parseInt(rgbArray[2]); var hexColour = "#" + IntToHex(red) + IntToHex(green) + IntToHex(blue);}
catch(e){ alert("There was an error converting the RGB value to Hexadecimal in function rgb2Hex");}
return hexColour;}
function rgb2Array(rgbColour)
{ var rgbValues = rgbColour.substring(4, rgbColour.indexOf(")")); var rgbArray = rgbValues.split(", "); return rgbArray;}
function setOpacity(obj, opacity)
{ opacity = (opacity == 100)?99.999:opacity; if(isSafari && obj.tagName != "IFRAME")
{ var rgbArray = rgb2Array(obj.style.backgroundColor); var red = parseInt(rgbArray[0]); var green = parseInt(rgbArray[1]); var blue = parseInt(rgbArray[2]); obj.style.backgroundColor = "rgba(" + red + ", " + green + ", " + blue + ", " + opacity/100 + ")";}
else if(typeof(obj.style.opacity) != "undefined")
{ obj.style.opacity = opacity/100;}
else if(typeof(obj.style.MozOpacity) != "undefined")
{ obj.style.MozOpacity = opacity/100;}
else if(typeof(obj.style.filter) != "undefined")
{ obj.style.filter = "alpha(opacity:" + opacity + ")";}
else if(typeof(obj.style.KHTMLOpacity) != "undefined")
{ obj.style.KHTMLOpacity = opacity/100;}
}
function inArray(array, value)
{ for(var i = 0; i < array.length; i++){ if (array[i] === value) return i;}
return false;}
function inArrayKey(array, value)
{ for(key in array){ if(key === value) return true;}
return false;}
function addEvent(elm, evType, fn, useCapture) { if (elm.addEventListener) { elm.addEventListener(evType, fn, useCapture); return true;}
else if (elm.attachEvent) { var r = elm.attachEvent('on' + evType, fn); return r;}
else { elm['on' + evType] = fn;}
}
function removeEvent(obj, evType, fn, useCapture){ if (obj.removeEventListener){ obj.removeEventListener(evType, fn, useCapture); return true;} else if (obj.detachEvent){ var r = obj.detachEvent("on"+evType, fn); return r;} else { alert("Handler could not be removed");}
}
function format_colour(colour)
{ var returnColour = "#ffffff"; if(colour != "" && colour != "transparent")
{ if(colour.substr(0, 3) == "rgb")
{ returnColour = rgb2Hex(colour);}
else if(colour.length == 4)
{ returnColour = "#" + colour.substring(1, 2) + colour.substring(1, 2) + colour.substring(2, 3) + colour.substring(2, 3) + colour.substring(3, 4) + colour.substring(3, 4);}
else
{ returnColour = colour;}
}
return returnColour;}
function get_style(obj, property, propertyNS)
{ try
{ if(obj.currentStyle)
{ var returnVal = eval("obj.currentStyle." + property);}
else
{ if(isSafari && obj.style.display == "none")
{ obj.style.display = ""; var wasHidden = true;}
var returnVal = document.defaultView.getComputedStyle(obj, '').getPropertyValue(propertyNS); if(isSafari && wasHidden)
{ obj.style.display = "none";}
}
}
catch(e)
{ }
return returnVal;}
function getElementsByClass(searchClass, node, tag)
{ var classElements = new Array(); if(node == null)
node = document; if(tag == null)
tag = '*'; var els = node.getElementsByTagName(tag); var elsLen = els.length; var pattern = new RegExp("(^|\s)"+searchClass+"(\s|$)"); for (i = 0, j = 0; i < elsLen; i++)
{ if(pattern.test(els[i].className))
{ classElements[j] = els[i]; j++;}
}
return classElements;}
function newCurvyError(errorMessage)
{ return new Error("curvyCorners Error:\n" + errorMessage)
}



// rating

function ajax_rate(rate, idToHide, idToShow, cid)
{
  cp.call(baseurl+'/ajax/myajaxphp.php', 'process_data', return_data, rate, cid);
    hideMe(idToHide);
    showMe(idToShow);
}

function return_data(result)
{
  // collect number of stars
  var cnt = result.getElementsByTagName('trate').item(0).firstChild.data;                

  // die über chain_rating() erzeugten Sterne werden durch innerHTML-Sterne Ajax-maessig ersetzt...
  ///hideMe('idViewVoteResult');
  ///hideMe('idVotePrev');
  // hideMe('viewMessage');
  
  //alert("cnt: " + cnt);
  if (cnt!='exist') // see also function chain_rating() in functions.php
  {
      //alert("A");
    
    // show the vote text
      
    // this is for table-td's (old)!
    ///var x = document.getElementById('idVoteView').rows[0].cells;
    // this will replace the complete idVoteView-string
    ///x[1].innerHTML = '<b>'+result.getElementsByTagName('tvote').item(0).firstChild.data+'</b> Bewertungen';
    
    // this is for a single div (new)!
    var x = document.getElementById('idVotePrev');
    var num = result.getElementsByTagName('tvote').item(0).firstChild.data;
    //alert("num: " + num);
    if (num>1) {x.innerHTML = '<b>'+num+'</b> Bewertungen';}  
    else       {x.innerHTML = '<b>1</b> Bewertung';}  
    // ...if this has been failed, the next steps will be cancled!!  
        
    if (cnt>6) {
            cnt = 6;
        }    
        else if (cnt<0)    {
            cnt = 0;
        }
        
        //var y = document.getElementById('tblViewResult').rows[0].cells;
    // we use one div-element now, not a table
    var y = document.getElementById('idViewVoteResult');
    
    //alert("y.innerHTML: " + y.innerHTML);
    var stars = "";
    // our star versions
    var star = '<img src=\"'+imgurl+'/star.gif\" width=16 alt=\"star\">';
    var half_star = '<img src=\"'+imgurl+'/half_star.gif\" width=16 alt=\"star\">';
    var blank_star = '<img src=\"'+imgurl+'/blank_star.gif\" width=16 alt=\"star\">';
    
    // full stars
    for (i=0; i<cnt; i++) {
      stars = stars.concat(star);
        }
    // get the rate for calculating the half stars (same in insert_show_rate() in functions.php)
    var rate = result.getElementsByTagName('xrate').item(0).firstChild.data;
    rate = Math.ceil(rate);
    
    for (i=0; i<(5-cnt); i++) 
    {
      // check for single half star first
      if (rate-(cnt*2)==1) {
        stars = stars.concat(half_star);
        rate = 0;
      }
      // fill rest with blank stars
      else 
        stars = stars.concat(blank_star);
    }
    // finally display the stars
    y.innerHTML = stars;
  }
  else
  {
      var x=document.getElementById('voteProcessthank').innerHTML="<font color=#ba0a12>Du hast diese Kette bereits bewertet</font>";
  }
    return false;
}



// DB initialization 
var dbArray = new Array();
//var dbreport;
//var recordcount;
//var coloumcount;

// Ajax initialization 
var cp = new cpaint();
cp.set_debug(false);            
cp.set_response_type('XML');    

//function return_value(result)
//{
//    dbreport = result.getElementsByTagName('dbreport').item(0).firstChild.data;
//    
//    if (dbreport=='1') {
        // get how many row fetch
//        recordcount = result.getElementsByTagName('recordcount').item(0).firstChild.data;
//        coloumcount = result.getElementsByTagName('coloumcount').item(0).firstChild.data;

        // population my DB values                            
//        for( i=0; i<recordcount; i++) {
//            dbArray[i] = new Array(recordcount);
//            for (ii=0; ii<coloumcount; ii++){
//                dbArray[i][ii] = result.getElementsByTagName('dbvalue'+i+ii).item(0).firstChild.data;                                                            
//            }
//        }
//    }
//}

function hideMe(myId)
{
    document.getElementById(myId).style.display = "none";
}

function showMe(myId)
{
    document.getElementById(myId).style.display = "block";
}



//Pearlfection.js

sortimentItems = Array();
sortimentCurrentIndex = 0;

function initSortimentTeaser(group_sort,image,textlayer,longdesclayer)
{
  //sortimentCurrentIndex=Math.floor(Math.random()*(group_sort.length-1));
  sortimentCurrentIndex=0;
  
  for (var i = 0; i < group_sort.length; i++) {
    sortimentItems[i] = new Object();
    sortimentItems[i][0] = group_sort[i].image;
    sortimentItems[i][1] = group_sort[i].name;
    sortimentItems[i][2] = group_sort[i].descrip;
  }  

 //document.getElementById(image).innerHTML = sortimentItems[sortimentCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {  
   // document.getElementById(textlayer).innerHTML = sortimentItems[sortimentCurrentIndex][1];
  }
 // document.getElementById(longdesclayer).innerHTML = sortimentItems[sortimentCurrentIndex][2];
}
  
function showNextSortiment(image,textlayer,longdesclayer,elementlink) 
{
  if(sortimentCurrentIndex+1 < sortimentItems.length) {
    sortimentCurrentIndex += 1;
  }
  else {
    sortimentCurrentIndex = 0;
  } 

  //document.getElementById(image).innerHTML = sortimentItems[sortimentCurrentIndex][0];
 // document.getElementById(textlayer).innerHTML = sortimentItems[sortimentCurrentIndex][1];  
  //document.getElementById(longdesclayer).innerHTML = sortimentItems[sortimentCurrentIndex][2];
}

function showPreviousSortiment(image,textlayer,longdesclayer,elementlink) 
{
  if(sortimentCurrentIndex-1 > -1) {
    sortimentCurrentIndex -= 1;
  }
  else {
    sortimentCurrentIndex = sortimentItems.length-1;
  } 
  //document.getElementById(image).innerHTML = sortimentItems[sortimentCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = sortimentItems[sortimentCurrentIndex][1];
  //document.getElementById(longdesclayer).innerHTML = sortimentItems[sortimentCurrentIndex][2];
}

/* designs */
designsItems = Array();
designsCurrentIndex = 0;

function initDesignsTeaser(group_designs,image,textlayer,longdesclayer) 
{
  //designsCurrentIndex=Math.floor(Math.random()*(group_designs.length-1));
  designsCurrentIndex=11;    

  for (var i = 0; i < group_designs.length; i++) {
    designsItems[i] = new Object();
    designsItems[i][0] = group_designs[i].image;
    designsItems[i][1] = group_designs[i].name;
    designsItems[i][2] = group_designs[i].descrip;
  }  

//nabi  document.getElementById(image).innerHTML = designsItems[designsCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    //document.getElementById(textlayer).innerHTML = designsItems[designsCurrentIndex][1];
  }
 // document.getElementById(longdesclayer).innerHTML = designsItems[designsCurrentIndex][2];            
}

function showNextDesigns(image,textlayer,longdesclayer) 
{
  if(designsCurrentIndex+1 < designsItems.length) {
    designsCurrentIndex += 1;
  }
  else {
    designsCurrentIndex = 0;
  } 
  //document.getElementById(image).innerHTML = designsItems[designsCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = designsItems[designsCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = designsItems[designsCurrentIndex][2];
}

function showPreviousDesigns(image,textlayer,longdesclayer) 
{
  if(designsCurrentIndex-1 > -1) {
    designsCurrentIndex -= 1;
  }
  else {
    designsCurrentIndex = designsItems.length-1;
  } 
  //document.getElementById(image).innerHTML = designsItems[designsCurrentIndex][0];
 // document.getElementById(textlayer).innerHTML = designsItems[designsCurrentIndex][1];
//  document.getElementById(longdesclayer).innerHTML = designsItems[designsCurrentIndex][2];
}

armbaenderItems = Array();
armbaenderCurrentIndex = 0;

function initarmbaenderTeaser(group_armbaender,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  armbaenderCurrentIndex=0;

  for (var i = 0; i < group_armbaender.length; i++) {
    armbaenderItems[i] = new Object();
    armbaenderItems[i][0] = group_armbaender[i].image;
    armbaenderItems[i][1] = group_armbaender[i].name;
    armbaenderItems[i][2] = group_armbaender[i].descrip;

  }  
   // alert (image); 
 
  document.getElementById(image).innerHTML = armbaenderItems[armbaenderCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextarmbaender(image,textlayer,longdesclayer) 
{
  if(armbaenderCurrentIndex+1 < armbaenderItems.length) {
    armbaenderCurrentIndex += 1;
  }
  else {
    armbaenderCurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaenderItems[armbaenderCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousarmbaender(image,textlayer,longdesclayer) 
{
  if(armbaenderCurrentIndex-1 > -1) {
    armbaenderCurrentIndex -= 1;
  }
  else {
    armbaenderCurrentIndex = armbaenderItems.length-1;
  } 
  document.getElementById(image).innerHTML = armbaenderItems[armbaenderCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

armbaender1Items = Array();
armbaender1CurrentIndex = 0;

function initarmbaender1Teaser(group_armbaender1,image,textlayer,longdesclayer) 
{
  //armbaender1CurrentIndex=Math.floor(Math.random()*(group_armbaender1.length-1));
  armbaender1CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender1.length; i++) {   
    armbaender1Items[i] = new Object();
    armbaender1Items[i][0] = group_armbaender1[i].image;
    armbaender1Items[i][1] = group_armbaender1[i].name;
    armbaender1Items[i][2] = group_armbaender1[i].descrip;

  }       
    //alert (group_armbaender1.length); 
 
  document.getElementById(image).innerHTML = armbaender1Items[armbaender1CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][2];            
}

function showNextarmbaender1(image,textlayer,longdesclayer) 
{
  if(armbaender1CurrentIndex+1 < armbaender1Items.length) {  
    armbaender1CurrentIndex += 1;
  }
  else {
    armbaender1CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender1Items[armbaender1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][2];
}

function showPreviousarmbaender1(image,textlayer,longdesclayer) 
{
  if(armbaender1CurrentIndex-1 > -1) {
    armbaender1CurrentIndex -= 1;
  }
  else {
    armbaender1CurrentIndex = armbaender1Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender1Items[armbaender1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender1Items[armbaender1CurrentIndex][2];
}


armbaender2Items = Array();
armbaender2CurrentIndex = 0;

function initarmbaender2Teaser(group_armbaender2,image,textlayer,longdesclayer) 
{
  //armbaender2CurrentIndex=Math.floor(Math.random()*(group_armbaender2.length-1));
  armbaender2CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender2.length; i++) {   
    armbaender2Items[i] = new Object();
    armbaender2Items[i][0] = group_armbaender2[i].image;
    armbaender2Items[i][1] = group_armbaender2[i].name;
    armbaender2Items[i][2] = group_armbaender2[i].descrip;

  }       
    //alert (group_armbaender2.length); 
 
  document.getElementById(image).innerHTML = armbaender2Items[armbaender2CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][2];            
}

function showNextarmbaender2(image,textlayer,longdesclayer) 
{
  if(armbaender2CurrentIndex+1 < armbaender2Items.length) {  
    armbaender2CurrentIndex += 1;
  }
  else {
    armbaender2CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender2Items[armbaender2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][2];
}

function showPreviousarmbaender2(image,textlayer,longdesclayer) 
{
  if(armbaender2CurrentIndex-1 > -1) {
    armbaender2CurrentIndex -= 1;
  }
  else {
    armbaender2CurrentIndex = armbaender2Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender2Items[armbaender2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender2Items[armbaender2CurrentIndex][2];
}

armbaender3Items = Array();
armbaender3CurrentIndex = 0;

function initarmbaender3Teaser(group_armbaender3,image,textlayer,longdesclayer) 
{
  //armbaender3CurrentIndex=Math.floor(Math.random()*(group_armbaender3.length-1));
  armbaender3CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender3.length; i++) {   
    armbaender3Items[i] = new Object();
    armbaender3Items[i][0] = group_armbaender3[i].image;
    armbaender3Items[i][1] = group_armbaender3[i].name;
    armbaender3Items[i][2] = group_armbaender3[i].descrip;

  }       
    //alert (group_armbaender3.length); 
 
  document.getElementById(image).innerHTML = armbaender3Items[armbaender3CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][2];            
}

function showNextarmbaender3(image,textlayer,longdesclayer) 
{
  if(armbaender3CurrentIndex+1 < armbaender3Items.length) {  
    armbaender3CurrentIndex += 1;
  }
  else {
    armbaender3CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender3Items[armbaender3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][2];
}

function showPreviousarmbaender3(image,textlayer,longdesclayer) 
{
  if(armbaender3CurrentIndex-1 > -1) {
    armbaender3CurrentIndex -= 1;
  }
  else {
    armbaender3CurrentIndex = armbaender3Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender3Items[armbaender3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender3Items[armbaender3CurrentIndex][2];
}

armbaender4Items = Array();
armbaender4CurrentIndex = 0;

function initarmbaender4Teaser(group_armbaender4,image,textlayer,longdesclayer) 
{
  //armbaender4CurrentIndex=Math.floor(Math.random()*(group_armbaender4.length-1));
  armbaender4CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender4.length; i++) {   
    armbaender4Items[i] = new Object();
    armbaender4Items[i][0] = group_armbaender4[i].image;
    armbaender4Items[i][1] = group_armbaender4[i].name;
    armbaender4Items[i][2] = group_armbaender4[i].descrip;

  }       
    //alert (group_armbaender4.length); 
 
  document.getElementById(image).innerHTML = armbaender4Items[armbaender4CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][2];            
}

function showNextarmbaender4(image,textlayer,longdesclayer) 
{
  if(armbaender4CurrentIndex+1 < armbaender4Items.length) {  
    armbaender4CurrentIndex += 1;
  }
  else {
    armbaender4CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender4Items[armbaender4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][2];
}

function showPreviousarmbaender4(image,textlayer,longdesclayer) 
{
  if(armbaender4CurrentIndex-1 > -1) {
    armbaender4CurrentIndex -= 1;
  }
  else {
    armbaender4CurrentIndex = armbaender4Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender4Items[armbaender4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender4Items[armbaender4CurrentIndex][2];
}

armbaender5Items = Array();
armbaender5CurrentIndex = 0;

function initarmbaender5Teaser(group_armbaender5,image,textlayer,longdesclayer) 
{
  //armbaender5CurrentIndex=Math.floor(Math.random()*(group_armbaender5.length-1));
  armbaender5CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender5.length; i++) {   
    armbaender5Items[i] = new Object();
    armbaender5Items[i][0] = group_armbaender5[i].image;
    armbaender5Items[i][1] = group_armbaender5[i].name;
    armbaender5Items[i][2] = group_armbaender5[i].descrip;

  }       
    //alert (group_armbaender5.length); 
 
  document.getElementById(image).innerHTML = armbaender5Items[armbaender5CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][2];            
}

function showNextarmbaender5(image,textlayer,longdesclayer) 
{
  if(armbaender5CurrentIndex+1 < armbaender5Items.length) {  
    armbaender5CurrentIndex += 1;
  }
  else {
    armbaender5CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender5Items[armbaender5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][2];
}

function showPreviousarmbaender5(image,textlayer,longdesclayer) 
{
  if(armbaender5CurrentIndex-1 > -1) {
    armbaender5CurrentIndex -= 1;
  }
  else {
    armbaender5CurrentIndex = armbaender5Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender5Items[armbaender5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender5Items[armbaender5CurrentIndex][2];
}




armbaender6Items = Array();
armbaender6CurrentIndex = 0;

function initarmbaender6Teaser(group_armbaender6,image,textlayer,longdesclayer) 
{
  //armbaender6CurrentIndex=Math.floor(Math.random()*(group_armbaender6.length-1));
  armbaender6CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender6.length; i++) {   
    armbaender6Items[i] = new Object();
    armbaender6Items[i][0] = group_armbaender6[i].image;
    armbaender6Items[i][1] = group_armbaender6[i].name;
    armbaender6Items[i][2] = group_armbaender6[i].descrip;

  }       
    //alert (group_armbaender6.length); 
 
  document.getElementById(image).innerHTML = armbaender6Items[armbaender6CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][2];            
}

function showNextarmbaender6(image,textlayer,longdesclayer) 
{
  if(armbaender6CurrentIndex+1 < armbaender6Items.length) {  
    armbaender6CurrentIndex += 1;
  }
  else {
    armbaender6CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender6Items[armbaender6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][2];
}

function showPreviousarmbaender6(image,textlayer,longdesclayer) 
{
  if(armbaender6CurrentIndex-1 > -1) {
    armbaender6CurrentIndex -= 1;
  }
  else {
    armbaender6CurrentIndex = armbaender6Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender6Items[armbaender6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender6Items[armbaender6CurrentIndex][2];
}

armbaender7Items = Array();
armbaender7CurrentIndex = 0;

function initarmbaender7Teaser(group_armbaender7,image,textlayer,longdesclayer) 
{
  //armbaender7CurrentIndex=Math.floor(Math.random()*(group_armbaender7.length-1));
  armbaender7CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender7.length; i++) {   
    armbaender7Items[i] = new Object();
    armbaender7Items[i][0] = group_armbaender7[i].image;
    armbaender7Items[i][1] = group_armbaender7[i].name;
    armbaender7Items[i][2] = group_armbaender7[i].descrip;

  }       
    //alert (group_armbaender7.length); 
 
  document.getElementById(image).innerHTML = armbaender7Items[armbaender7CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][2];            
}

function showNextarmbaender7(image,textlayer,longdesclayer) 
{
  if(armbaender7CurrentIndex+1 < armbaender7Items.length) {  
    armbaender7CurrentIndex += 1;
  }
  else {
    armbaender7CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender7Items[armbaender7CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][2];
}

function showPreviousarmbaender7(image,textlayer,longdesclayer) 
{
  if(armbaender7CurrentIndex-1 > -1) {
    armbaender7CurrentIndex -= 1;
  }
  else {
    armbaender7CurrentIndex = armbaender7Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender7Items[armbaender7CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender7Items[armbaender7CurrentIndex][2];
}

armbaender8Items = Array();
armbaender8CurrentIndex = 0;

function initarmbaender8Teaser(group_armbaender8,image,textlayer,longdesclayer) 
{
  //armbaender8CurrentIndex=Math.floor(Math.random()*(group_armbaender8.length-1));
  armbaender8CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender8.length; i++) {   
    armbaender8Items[i] = new Object();
    armbaender8Items[i][0] = group_armbaender8[i].image;
    armbaender8Items[i][1] = group_armbaender8[i].name;
    armbaender8Items[i][2] = group_armbaender8[i].descrip;

  }       
    //alert (group_armbaender8.length); 
 
  document.getElementById(image).innerHTML = armbaender8Items[armbaender8CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][2];            
}

function showNextarmbaender8(image,textlayer,longdesclayer) 
{
  if(armbaender8CurrentIndex+1 < armbaender8Items.length) {  
    armbaender8CurrentIndex += 1;
  }
  else {
    armbaender8CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender8Items[armbaender8CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][2];
}

function showPreviousarmbaender8(image,textlayer,longdesclayer) 
{
  if(armbaender8CurrentIndex-1 > -1) {
    armbaender8CurrentIndex -= 1;
  }
  else {
    armbaender8CurrentIndex = armbaender8Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender8Items[armbaender8CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender8Items[armbaender8CurrentIndex][2];
}

armbaender9Items = Array();
armbaender9CurrentIndex = 0;

function initarmbaender9Teaser(group_armbaender9,image,textlayer,longdesclayer) 
{
  //armbaender9CurrentIndex=Math.floor(Math.random()*(group_armbaender9.length-1));
  armbaender9CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender9.length; i++) {   
    armbaender9Items[i] = new Object();
    armbaender9Items[i][0] = group_armbaender9[i].image;
    armbaender9Items[i][1] = group_armbaender9[i].name;
    armbaender9Items[i][2] = group_armbaender9[i].descrip;

  }       
    //alert (group_armbaender9.length); 
 
  document.getElementById(image).innerHTML = armbaender9Items[armbaender9CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][2];            
}

function showNextarmbaender9(image,textlayer,longdesclayer) 
{
  if(armbaender9CurrentIndex+1 < armbaender9Items.length) {  
    armbaender9CurrentIndex += 1;
  }
  else {
    armbaender9CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender9Items[armbaender9CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][2];
}

function showPreviousarmbaender9(image,textlayer,longdesclayer) 
{
  if(armbaender9CurrentIndex-1 > -1) {
    armbaender9CurrentIndex -= 1;
  }
  else {
    armbaender9CurrentIndex = armbaender9Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender9Items[armbaender9CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender9Items[armbaender9CurrentIndex][2];
}


armbaender10Items = Array();
armbaender10CurrentIndex = 0;

function initarmbaender10Teaser(group_armbaender10,image,textlayer,longdesclayer) 
{
  //armbaender10CurrentIndex=Math.floor(Math.random()*(group_armbaender10.length-1));
  armbaender10CurrentIndex=0;
  
  for (var i = 0; i < group_armbaender10.length; i++) {   
    armbaender10Items[i] = new Object();
    armbaender10Items[i][0] = group_armbaender10[i].image;
    armbaender10Items[i][1] = group_armbaender10[i].name;
    armbaender10Items[i][2] = group_armbaender10[i].descrip;

  }       
    //alert (group_armbaender10.length); 
 
  document.getElementById(image).innerHTML = armbaender10Items[armbaender10CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][1];
  }
//alert(longdesclayer); 
//alert(document.getElementById(longdesclayer));
 //document.getElementById(longdesclayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][2];            
}

function showNextarmbaender10(image,textlayer,longdesclayer) 
{
  if(armbaender10CurrentIndex+1 < armbaender10Items.length) {  
    armbaender10CurrentIndex += 1;
  }
  else {
    armbaender10CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = armbaender10Items[armbaender10CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][2];
}

function showPreviousarmbaender10(image,textlayer,longdesclayer) 
{
  if(armbaender10CurrentIndex-1 > -1) {
    armbaender10CurrentIndex -= 1;
  }
  else {
    armbaender10CurrentIndex = armbaender10Items.length-1;
  } 
  document.getElementById(image).innerHTML = armbaender10Items[armbaender10CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaender10Items[armbaender10CurrentIndex][2];
}





halskettenItems = Array();
halskettenCurrentIndex = 0;

function inithalskettenTeaser(group_halsketten,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halskettenCurrentIndex=11;

  for (var i = 0; i < group_halsketten.length; i++) {
    halskettenItems[i] = new Object();
    halskettenItems[i][0] = group_halsketten[i].image;
    halskettenItems[i][1] = group_halsketten[i].name;
    halskettenItems[i][2] = group_halsketten[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halskettenItems[halskettenCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halskettenItems[halskettenCurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten(image,textlayer,longdesclayer) 
{
  if(halskettenCurrentIndex+1 < halskettenItems.length) {
    halskettenCurrentIndex += 1;
  }
  else {
    halskettenCurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halskettenItems[halskettenCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten(image,textlayer,longdesclayer) 
{
  if(halskettenCurrentIndex-1 > -1) {
    halskettenCurrentIndex -= 1;
  }
  else {
    halskettenCurrentIndex = halskettenItems.length-1;
  } 
  document.getElementById(image).innerHTML = halskettenItems[halskettenCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

halsketten1Items = Array();
halsketten1CurrentIndex = 0;

function inithalsketten1Teaser(group_halsketten1,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten1CurrentIndex=0;

  for (var i = 0; i < group_halsketten1.length; i++) {
    halsketten1Items[i] = new Object();
    halsketten1Items[i][0] = group_halsketten1[i].image;
    halsketten1Items[i][1] = group_halsketten1[i].name;
    halsketten1Items[i][2] = group_halsketten1[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten1Items[halsketten1CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten1Items[halsketten1CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten1(image,textlayer,longdesclayer) 
{
  if(halsketten1CurrentIndex+1 < halsketten1Items.length) {
    halsketten1CurrentIndex += 1;
  }
  else {
    halsketten1CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten1Items[halsketten1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten1(image,textlayer,longdesclayer) 
{
  if(halsketten1CurrentIndex-1 > -1) {
    halsketten1CurrentIndex -= 1;
  }
  else {
    halsketten1CurrentIndex = halsketten1Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten1Items[halsketten1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten2Items = Array();
halsketten2CurrentIndex = 0;

function inithalsketten2Teaser(group_halsketten2,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten2CurrentIndex=0;

  for (var i = 0; i < group_halsketten2.length; i++) {
    halsketten2Items[i] = new Object();
    halsketten2Items[i][0] = group_halsketten2[i].image;
    halsketten2Items[i][1] = group_halsketten2[i].name;
    halsketten2Items[i][2] = group_halsketten2[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten2Items[halsketten2CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten2Items[halsketten2CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten2(image,textlayer,longdesclayer) 
{
  if(halsketten2CurrentIndex+1 < halsketten2Items.length) {
    halsketten2CurrentIndex += 1;
  }
  else {
    halsketten2CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten2Items[halsketten2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten2(image,textlayer,longdesclayer) 
{
  if(halsketten2CurrentIndex-1 > -1) {
    halsketten2CurrentIndex -= 1;
  }
  else {
    halsketten2CurrentIndex = halsketten2Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten2Items[halsketten2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten3Items = Array();
halsketten3CurrentIndex = 0;

function inithalsketten3Teaser(group_halsketten3,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten3CurrentIndex=0;

  for (var i = 0; i < group_halsketten3.length; i++) {
    halsketten3Items[i] = new Object();
    halsketten3Items[i][0] = group_halsketten3[i].image;
    halsketten3Items[i][1] = group_halsketten3[i].name;
    halsketten3Items[i][2] = group_halsketten3[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten3Items[halsketten3CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten3Items[halsketten3CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten3(image,textlayer,longdesclayer) 
{
  if(halsketten3CurrentIndex+1 < halsketten3Items.length) {
    halsketten3CurrentIndex += 1;
  }
  else {
    halsketten3CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten3Items[halsketten3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten3(image,textlayer,longdesclayer) 
{
  if(halsketten3CurrentIndex-1 > -1) {
    halsketten3CurrentIndex -= 1;
  }
  else {
    halsketten3CurrentIndex = halsketten3Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten3Items[halsketten3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten4Items = Array();
halsketten4CurrentIndex = 0;

function inithalsketten4Teaser(group_halsketten4,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten4CurrentIndex=0;

  for (var i = 0; i < group_halsketten4.length; i++) {
    halsketten4Items[i] = new Object();
    halsketten4Items[i][0] = group_halsketten4[i].image;
    halsketten4Items[i][1] = group_halsketten4[i].name;
    halsketten4Items[i][2] = group_halsketten4[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten4Items[halsketten4CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten4Items[halsketten4CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten4(image,textlayer,longdesclayer) 
{
  if(halsketten4CurrentIndex+1 < halsketten4Items.length) {
    halsketten4CurrentIndex += 1;
  }
  else {
    halsketten4CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten4Items[halsketten4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten4(image,textlayer,longdesclayer) 
{
  if(halsketten4CurrentIndex-1 > -1) {
    halsketten4CurrentIndex -= 1;
  }
  else {
    halsketten4CurrentIndex = halsketten4Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten4Items[halsketten4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten5Items = Array();
halsketten5CurrentIndex = 0;

function inithalsketten5Teaser(group_halsketten5,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten5CurrentIndex=0;

  for (var i = 0; i < group_halsketten5.length; i++) {
    halsketten5Items[i] = new Object();
    halsketten5Items[i][0] = group_halsketten5[i].image;
    halsketten5Items[i][1] = group_halsketten5[i].name;
    halsketten5Items[i][2] = group_halsketten5[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten5Items[halsketten5CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten5Items[halsketten5CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten5(image,textlayer,longdesclayer) 
{
  if(halsketten5CurrentIndex+1 < halsketten5Items.length) {
    halsketten5CurrentIndex += 1;
  }
  else {
    halsketten5CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten5Items[halsketten5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten5(image,textlayer,longdesclayer) 
{
  if(halsketten5CurrentIndex-1 > -1) {
    halsketten5CurrentIndex -= 1;
  }
  else {
    halsketten5CurrentIndex = halsketten5Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten5Items[halsketten5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten6Items = Array();
halsketten6CurrentIndex = 0;

function inithalsketten6Teaser(group_halsketten6,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten6CurrentIndex=0;

  for (var i = 0; i < group_halsketten6.length; i++) {
    halsketten6Items[i] = new Object();
    halsketten6Items[i][0] = group_halsketten6[i].image;
    halsketten6Items[i][1] = group_halsketten6[i].name;
    halsketten6Items[i][2] = group_halsketten6[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten6Items[halsketten6CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten6Items[halsketten6CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten6(image,textlayer,longdesclayer) 
{
  if(halsketten6CurrentIndex+1 < halsketten6Items.length) {
    halsketten6CurrentIndex += 1;
  }
  else {
    halsketten6CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten6Items[halsketten6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten6(image,textlayer,longdesclayer) 
{
  if(halsketten6CurrentIndex-1 > -1) {
    halsketten6CurrentIndex -= 1;
  }
  else {
    halsketten6CurrentIndex = halsketten6Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten6Items[halsketten6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten7Items = Array();
halsketten7CurrentIndex = 0;

function inithalsketten7Teaser(group_halsketten7,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten7CurrentIndex=0;

  for (var i = 0; i < group_halsketten7.length; i++) {
    halsketten7Items[i] = new Object();
    halsketten7Items[i][0] = group_halsketten7[i].image;
    halsketten7Items[i][1] = group_halsketten7[i].name;
    halsketten7Items[i][2] = group_halsketten7[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten7Items[halsketten7CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten7Items[halsketten7CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten7(image,textlayer,longdesclayer) 
{
  if(halsketten7CurrentIndex+1 < halsketten7Items.length) {
    halsketten7CurrentIndex += 1;
  }
  else {
    halsketten7CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten7Items[halsketten7CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten7(image,textlayer,longdesclayer) 
{
  if(halsketten7CurrentIndex-1 > -1) {
    halsketten7CurrentIndex -= 1;
  }
  else {
    halsketten7CurrentIndex = halsketten7Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten7Items[halsketten7CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

halsketten8Items = Array();
halsketten8CurrentIndex = 0;

function inithalsketten8Teaser(group_halsketten8,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten8CurrentIndex=0;

  for (var i = 0; i < group_halsketten8.length; i++) {
    halsketten8Items[i] = new Object();
    halsketten8Items[i][0] = group_halsketten8[i].image;
    halsketten8Items[i][1] = group_halsketten8[i].name;
    halsketten8Items[i][2] = group_halsketten8[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten8Items[halsketten8CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten8Items[halsketten8CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten8(image,textlayer,longdesclayer) 
{
  if(halsketten8CurrentIndex+1 < halsketten8Items.length) {
    halsketten8CurrentIndex += 1;
  }
  else {
    halsketten8CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten8Items[halsketten8CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten8(image,textlayer,longdesclayer) 
{
  if(halsketten8CurrentIndex-1 > -1) {
    halsketten8CurrentIndex -= 1;
  }
  else {
    halsketten8CurrentIndex = halsketten8Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten8Items[halsketten8CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten9Items = Array();
halsketten9CurrentIndex = 0;

function inithalsketten9Teaser(group_halsketten9,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten9CurrentIndex=0;

  for (var i = 0; i < group_halsketten9.length; i++) {
    halsketten9Items[i] = new Object();
    halsketten9Items[i][0] = group_halsketten9[i].image;
    halsketten9Items[i][1] = group_halsketten9[i].name;
    halsketten9Items[i][2] = group_halsketten9[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten9Items[halsketten9CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten9Items[halsketten9CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten9(image,textlayer,longdesclayer) 
{
  if(halsketten9CurrentIndex+1 < halsketten9Items.length) {
    halsketten9CurrentIndex += 1;
  }
  else {
    halsketten9CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten9Items[halsketten9CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten9(image,textlayer,longdesclayer) 
{
  if(halsketten9CurrentIndex-1 > -1) {
    halsketten9CurrentIndex -= 1;
  }
  else {
    halsketten9CurrentIndex = halsketten9Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten9Items[halsketten9CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


halsketten10Items = Array();
halsketten10CurrentIndex = 0;

function inithalsketten10Teaser(group_halsketten10,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  halsketten10CurrentIndex=0;

  for (var i = 0; i < group_halsketten10.length; i++) {
    halsketten10Items[i] = new Object();
    halsketten10Items[i][0] = group_halsketten10[i].image;
    halsketten10Items[i][1] = group_halsketten10[i].name;
    halsketten10Items[i][2] = group_halsketten10[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = halsketten10Items[halsketten10CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = halsketten10Items[halsketten10CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNexthalsketten10(image,textlayer,longdesclayer) 
{
  if(halsketten10CurrentIndex+1 < halsketten10Items.length) {
    halsketten10CurrentIndex += 1;
  }
  else {
    halsketten10CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = halsketten10Items[halsketten10CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPrevioushalsketten10(image,textlayer,longdesclayer) 
{
  if(halsketten10CurrentIndex-1 > -1) {
    halsketten10CurrentIndex -= 1;
  }
  else {
    halsketten10CurrentIndex = halsketten10Items.length-1;
  } 
  document.getElementById(image).innerHTML = halsketten10Items[halsketten10CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


ohrringeItems = Array();
ohrringeCurrentIndex = 0;

function initohrringeTeaser(group_ohrringe,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringeCurrentIndex=0;

  for (var i = 0; i < group_ohrringe.length; i++) {
    ohrringeItems[i] = new Object();
    ohrringeItems[i][0] = group_ohrringe[i].image;
    ohrringeItems[i][1] = group_ohrringe[i].name;
    ohrringeItems[i][2] = group_ohrringe[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringeItems[ohrringeCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringeItems[ohrringeCurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe(image,textlayer,longdesclayer) 
{
  if(ohrringeCurrentIndex+1 < ohrringeItems.length) {
    ohrringeCurrentIndex += 1;
  }
  else {
    ohrringeCurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringeItems[ohrringeCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe(image,textlayer,longdesclayer) 
{
  if(ohrringeCurrentIndex-1 > -1) {
    ohrringeCurrentIndex -= 1;
  }
  else {
    ohrringeCurrentIndex = ohrringeItems.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringeItems[ohrringeCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

ohrringe1Items = Array();
ohrringe1CurrentIndex = 0;

function initohrringe1Teaser(group_ohrringe1,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe1CurrentIndex=0;

  for (var i = 0; i < group_ohrringe1.length; i++) {
    ohrringe1Items[i] = new Object();
    ohrringe1Items[i][0] = group_ohrringe1[i].image;
    ohrringe1Items[i][1] = group_ohrringe1[i].name;
    ohrringe1Items[i][2] = group_ohrringe1[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe1Items[ohrringe1CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe1Items[ohrringe1CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe1(image,textlayer,longdesclayer) 
{
  if(ohrringe1CurrentIndex+1 < ohrringe1Items.length) {
    ohrringe1CurrentIndex += 1;
  }
  else {
    ohrringe1CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe1Items[ohrringe1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe1(image,textlayer,longdesclayer) 
{
  if(ohrringe1CurrentIndex-1 > -1) {
    ohrringe1CurrentIndex -= 1;
  }
  else {
    ohrringe1CurrentIndex = ohrringe1Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe1Items[ohrringe1CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

ohrringe2Items = Array();
ohrringe2CurrentIndex = 0;

function initohrringe2Teaser(group_ohrringe2,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe2CurrentIndex=0;

  for (var i = 0; i < group_ohrringe2.length; i++) {
    ohrringe2Items[i] = new Object();
    ohrringe2Items[i][0] = group_ohrringe2[i].image;
    ohrringe2Items[i][1] = group_ohrringe2[i].name;
    ohrringe2Items[i][2] = group_ohrringe2[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe2Items[ohrringe2CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe2Items[ohrringe2CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe2(image,textlayer,longdesclayer) 
{
  if(ohrringe2CurrentIndex+1 < ohrringe2Items.length) {
    ohrringe2CurrentIndex += 1;
  }
  else {
    ohrringe2CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe2Items[ohrringe2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe2(image,textlayer,longdesclayer) 
{
  if(ohrringe2CurrentIndex-1 > -1) {
    ohrringe2CurrentIndex -= 1;
  }
  else {
    ohrringe2CurrentIndex = ohrringe2Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe2Items[ohrringe2CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

ohrringe3Items = Array();
ohrringe3CurrentIndex = 0;

function initohrringe3Teaser(group_ohrringe3,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe3CurrentIndex=0;

  for (var i = 0; i < group_ohrringe3.length; i++) {
    ohrringe3Items[i] = new Object();
    ohrringe3Items[i][0] = group_ohrringe3[i].image;
    ohrringe3Items[i][1] = group_ohrringe3[i].name;
    ohrringe3Items[i][2] = group_ohrringe3[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe3Items[ohrringe3CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe3Items[ohrringe3CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe3(image,textlayer,longdesclayer) 
{
  if(ohrringe3CurrentIndex+1 < ohrringe3Items.length) {
    ohrringe3CurrentIndex += 1;
  }
  else {
    ohrringe3CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe3Items[ohrringe3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe3(image,textlayer,longdesclayer) 
{
  if(ohrringe3CurrentIndex-1 > -1) {
    ohrringe3CurrentIndex -= 1;
  }
  else {
    ohrringe3CurrentIndex = ohrringe3Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe3Items[ohrringe3CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


ohrringe4Items = Array();
ohrringe4CurrentIndex = 0;

function initohrringe4Teaser(group_ohrringe4,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe4CurrentIndex=0;

  for (var i = 0; i < group_ohrringe4.length; i++) {
    ohrringe4Items[i] = new Object();
    ohrringe4Items[i][0] = group_ohrringe4[i].image;
    ohrringe4Items[i][1] = group_ohrringe4[i].name;
    ohrringe4Items[i][2] = group_ohrringe4[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe4Items[ohrringe4CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe4Items[ohrringe4CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe4(image,textlayer,longdesclayer) 
{
  if(ohrringe4CurrentIndex+1 < ohrringe4Items.length) {
    ohrringe4CurrentIndex += 1;
  }
  else {
    ohrringe4CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe4Items[ohrringe4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe4(image,textlayer,longdesclayer) 
{
  if(ohrringe4CurrentIndex-1 > -1) {
    ohrringe4CurrentIndex -= 1;
  }
  else {
    ohrringe4CurrentIndex = ohrringe4Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe4Items[ohrringe4CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

ohrringe5Items = Array();
ohrringe5CurrentIndex = 0;

function initohrringe5Teaser(group_ohrringe5,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe5CurrentIndex=0;

  for (var i = 0; i < group_ohrringe5.length; i++) {
    ohrringe5Items[i] = new Object();
    ohrringe5Items[i][0] = group_ohrringe5[i].image;
    ohrringe5Items[i][1] = group_ohrringe5[i].name;
    ohrringe5Items[i][2] = group_ohrringe5[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe5Items[ohrringe5CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe5Items[ohrringe5CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe5(image,textlayer,longdesclayer) 
{
  if(ohrringe5CurrentIndex+1 < ohrringe5Items.length) {
    ohrringe5CurrentIndex += 1;
  }
  else {
    ohrringe5CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe5Items[ohrringe5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe5(image,textlayer,longdesclayer) 
{
  if(ohrringe5CurrentIndex-1 > -1) {
    ohrringe5CurrentIndex -= 1;
  }
  else {
    ohrringe5CurrentIndex = ohrringe5Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe5Items[ohrringe5CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

ohrringe6Items = Array();
ohrringe6CurrentIndex = 0;

function initohrringe6Teaser(group_ohrringe6,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ohrringe6CurrentIndex=0;

  for (var i = 0; i < group_ohrringe6.length; i++) {
    ohrringe6Items[i] = new Object();
    ohrringe6Items[i][0] = group_ohrringe6[i].image;
    ohrringe6Items[i][1] = group_ohrringe6[i].name;
    ohrringe6Items[i][2] = group_ohrringe6[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ohrringe6Items[ohrringe6CurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ohrringe6Items[ohrringe6CurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextohrringe6(image,textlayer,longdesclayer) 
{
  if(ohrringe6CurrentIndex+1 < ohrringe6Items.length) {
    ohrringe6CurrentIndex += 1;
  }
  else {
    ohrringe6CurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ohrringe6Items[ohrringe6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousohrringe6(image,textlayer,longdesclayer) 
{
  if(ohrringe6CurrentIndex-1 > -1) {
    ohrringe6CurrentIndex -= 1;
  }
  else {
    ohrringe6CurrentIndex = ohrringe6Items.length-1;
  } 
  document.getElementById(image).innerHTML = ohrringe6Items[ohrringe6CurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}













ringeItems = Array();
ringeCurrentIndex = 0;

function initringeTeaser(group_ringe,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  ringeCurrentIndex=0;

  for (var i = 0; i < group_ringe.length; i++) {
    ringeItems[i] = new Object();
    ringeItems[i][0] = group_ringe[i].image;
    ringeItems[i][1] = group_ringe[i].name;
    ringeItems[i][2] = group_ringe[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  // alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = ringeItems[ringeCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = ringeItems[ringeCurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextringe(image,textlayer,longdesclayer) 
{
  if(ringeCurrentIndex+1 < ringeItems.length) {
    ringeCurrentIndex += 1;
  }
  else {
    ringeCurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = ringeItems[ringeCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousringe(image,textlayer,longdesclayer) 
{
  if(ringeCurrentIndex-1 > -1) {
    ringeCurrentIndex -= 1;
  }
  else {
    ringeCurrentIndex = ringeItems.length-1;
  } 
  document.getElementById(image).innerHTML = ringeItems[ringeCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}


charmsundbeadsItems = Array();
charmsundbeadsCurrentIndex = 0;

function initcharmsundbeadsTeaser(group_charmsundbeads,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  charmsundbeadsCurrentIndex=0;

  for (var i = 0; i < group_charmsundbeads.length; i++) {
    charmsundbeadsItems[i] = new Object();
    charmsundbeadsItems[i][0] = group_charmsundbeads[i].image;
    charmsundbeadsItems[i][1] = group_charmsundbeads[i].name;
    charmsundbeadsItems[i][2] = group_charmsundbeads[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  //alert(document.getElementById(image));  
  document.getElementById(image).innerHTML = charmsundbeadsItems[charmsundbeadsCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = charmsundbeadsItems[charmsundbeadsCurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextcharmsundbeads(image,textlayer,longdesclayer) 
{
  if(charmsundbeadsCurrentIndex+1 < charmsundbeadsItems.length) {
    charmsundbeadsCurrentIndex += 1;
  }
  else {
    charmsundbeadsCurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = charmsundbeadsItems[charmsundbeadsCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviouscharmsundbeads(image,textlayer,longdesclayer) 
{
  if(charmsundbeadsCurrentIndex-1 > -1) {
    charmsundbeadsCurrentIndex -= 1;
  }
  else {
    charmsundbeadsCurrentIndex = charmsundbeadsItems.length-1;
  } 
  document.getElementById(image).innerHTML = charmsundbeadsItems[charmsundbeadsCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}




gravurschmuckItems = Array();
gravurschmuckCurrentIndex = 0;

function initgravurschmuckTeaser(group_gravurschmuck,image,textlayer,longdesclayer) 
{
  //armbaenderCurrentIndex=Math.floor(Math.random()*(group_armbaender.length-1));
  gravurschmuckCurrentIndex=11;

  for (var i = 0; i < group_gravurschmuck.length; i++) {
    gravurschmuckItems[i] = new Object();
    gravurschmuckItems[i][0] = group_gravurschmuck[i].image;
    gravurschmuckItems[i][1] = group_gravurschmuck[i].name;
    gravurschmuckItems[i][2] = group_gravurschmuck[i].descrip;

  }  
   // alert (image); 
  // alert(image); 
  //alert(document.getElementById(image));
   
  document.getElementById(image).innerHTML = gravurschmuckItems[gravurschmuckCurrentIndex][0];
  if (document.getElementById(textlayer)!=null) {
    document.getElementById(textlayer).innerHTML = gravurschmuckItems[gravurschmuckCurrentIndex][1];
  }

 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];            
}

function showNextgravurschmuck(image,textlayer,longdesclayer) 
{
  if(gravurschmuckCurrentIndex+1 < gravurschmuckItems.length) {
    gravurschmuckCurrentIndex += 1;
  }
  else {
    gravurschmuckCurrentIndex = 0;
  } 

  document.getElementById(image).innerHTML = gravurschmuckItems[gravurschmuckCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];  
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

function showPreviousgravurschmuck(image,textlayer,longdesclayer) 
{
  if(gravurschmuckCurrentIndex-1 > -1) {
    gravurschmuckCurrentIndex -= 1;
  }
  else {
    gravurschmuckCurrentIndex = gravurschmuckItems.length-1;
  } 
  document.getElementById(image).innerHTML = gravurschmuckItems[gravurschmuckCurrentIndex][0];
  //document.getElementById(textlayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][1];
 // document.getElementById(longdesclayer).innerHTML = armbaenderItems[armbaenderCurrentIndex][2];
}

/* top10 */
top10Items = Array();
top10CurrentIndex = 0;

function initTop10Teaser(chain_top10,image,textlayer,longdesclayer) 
{
  top10CurrentIndex=Math.floor(Math.random()*(chain_top10.length-1));

  for (var i = 0; i < chain_top10.length; i++) {
    top10Items[i] = new Object();
    top10Items[i][0] = chain_top10[i].image;
    top10Items[i][1] = chain_top10[i].name;
    top10Items[i][2] = chain_top10[i].descrip;
  }  

  document.getElementById(image).innerHTML = top10Items[top10CurrentIndex][0];
  document.getElementById(textlayer).innerHTML = top10Items[top10CurrentIndex][1];
  document.getElementById(longdesclayer).innerHTML = top10Items[top10CurrentIndex][2];            
}

function showNextTop10(image,textlayer,longdesclayer) 
{
  if(top10CurrentIndex+1 < top10Items.length) {
    top10CurrentIndex += 1;
  }
  else {
    top10CurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = top10Items[top10CurrentIndex][0];
  document.getElementById(textlayer).innerHTML = top10Items[top10CurrentIndex][1];  
  document.getElementById(longdesclayer).innerHTML = top10Items[top10CurrentIndex][2];
}

function showPreviousTop10(image,textlayer,longdesclayer) 
{
  if(top10CurrentIndex-1 > -1) {
    top10CurrentIndex -= 1;
  }
  else {
    top10CurrentIndex = top10Items.length-1;
  } 
  document.getElementById(image).innerHTML = top10Items[top10CurrentIndex][0];
  document.getElementById(textlayer).innerHTML = top10Items[top10CurrentIndex][1];
  document.getElementById(longdesclayer).innerHTML = top10Items[top10CurrentIndex][2];
}
  

//----------------

function swapNavigation(image) 
{
    if(image.src.indexOf("_hl.jpg")>-1) {
        newsrc = image.src.replace("_hl.jpg",".jpg");
    }
    else {
        newsrc =image.src.replace(".jpg","_hl.jpg");
    }
    image.src = newsrc;
}

function changeReiterNavi(id,image) 
{
    document.getElementById(id).src = image;
}

function selectReiterNavi(image_id,image,content_id) 
{
    currentReiterNavi = image;
    
    for(i in reiterList) {
        if(i/1 == i) {
            document.getElementById(reiterList[i]).style.display = 'none';
        }
    }

    document.getElementById(content_id).style.display = 'block';
}  

function reiterboxBlaettern(context,direction) 
{
    switch(direction) {
        case 'forward':
            document.getElementById(context+"ImageContent"+currentIndex[context]).style.display = 'none';
            document.getElementById(context+"TextContent"+currentIndex[context]).style.display = 'none';
                        
            if(document.getElementById(context+"ImageContent"+(currentIndex[context]+1))) {
                currentIndex[context]++;
            }
            else {
                currentIndex[context] = 0;
            }
            document.getElementById(context+"ImageContent"+currentIndex[context]).style.display = 'block';
            document.getElementById(context+"TextContent"+currentIndex[context]).style.display = 'block';            
            break;
            
        case 'backward':
            document.getElementById(context+"ImageContent"+currentIndex[context]).style.display = 'none';
            document.getElementById(context+"TextContent"+currentIndex[context]).style.display = 'none';
                        
            if(currentIndex[context] == 0) {
                currentIndex[context] = getContentCountForContext(context);
            }
            else {
                currentIndex[context]--;
            }

            document.getElementById(context+"ImageContent"+currentIndex[context]).style.display = 'block';
            document.getElementById(context+"TextContent"+currentIndex[context]).style.display = 'block';
            break;
    }
}

 //  Nabi
   
        function MM_swapImgRestore() { //v3.0
          var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
        }
        function MM_preloadImages() { //v3.0
          var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
            var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
            if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
        }

        function MM_findObj(n, d) { //v4.01
          var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
            d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
          if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
          for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
          if(!x && d.getElementById) x=d.getElementById(n); return x;
        }

        function MM_swapImage() { //v3.0
          var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
           if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
        }
  //end
function initReiter(image) 
{
//  document.getElementById(image).style.display = 'block';
}

function getContentCountForContext(context) 
{
    tmp = 0;
    while(document.getElementById(context+"TextContent"+tmp)) {
        tmp++;
    }
    
    return tmp-1;
    
}

// ------ elements box ----------
function showMoreElementInfo(image,layer) 
{
  if(document.getElementById(image).src.indexOf("_i.") > -1) {
    document.getElementById(image).src = document.getElementById(image).src.replace('_i.',"_a.");
    document.getElementById(layer).style.display = "block";
  }
  else {
    document.getElementById(image).src = document.getElementById(image).src.replace('_a.',"_i.");
    document.getElementById(layer).style.display = "none";
  }            
}

elementItems = Array();
elementCurrentIndex = 0;

function initElementTeaser(group_el,image,textlayer,longdesclayer,elementlink) 
{
  elementCurrentIndex=Math.floor(Math.random()*(group_el.length-1));

  for (var i = 0; i < group_el.length; i++) {
    elementItems[i] = new Object();
    elementItems[i][0] = group_el[i].image;
    elementItems[i][1] = group_el[i].name;
    elementItems[i][2] = group_el[i].descrip;
    elementItems[i][3] = group_el[i].products_link;
  }  

  document.getElementById(image).innerHTML = elementItems[elementCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = elementItems[elementCurrentIndex][1];
  document.getElementById(longdesclayer).innerHTML = elementItems[elementCurrentIndex][2];            
  document.getElementById(elementlink).innerHTML = elementItems[elementCurrentIndex][3];            
}

function showNextElement(image,textlayer,longdesclayer,elementlink) 
{
  if(elementCurrentIndex+1 < elementItems.length) {
    elementCurrentIndex += 1;
  }
  else {
    elementCurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = elementItems[elementCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = elementItems[elementCurrentIndex][1];  
  document.getElementById(longdesclayer).innerHTML = elementItems[elementCurrentIndex][2];
  document.getElementById(elementlink).innerHTML = elementItems[elementCurrentIndex][3];
}

function showPreviousElement(image,textlayer,longdesclayer,elementlink) 
{
  if(elementCurrentIndex-1 > -1) {
    elementCurrentIndex -= 1;
  }
  else {
    elementCurrentIndex = elementItems.length-1;
  } 
  document.getElementById(image).innerHTML = elementItems[elementCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = elementItems[elementCurrentIndex][1];
  document.getElementById(longdesclayer).innerHTML = elementItems[elementCurrentIndex][2];
  document.getElementById(elementlink).innerHTML = elementItems[elementCurrentIndex][3];
}

// ------ designer box ----------
designerItems = Array();
designerCurrentIndex = 0;

function initDesignerTeaser(user_image,image,textlayer,designs,profil) 
{
  designerCurrentIndex=Math.floor(Math.random()*(user_image.length-1));
  
  for (var i = 0; i < user_image.length; i++) {
    designerItems[i] = new Object();
    designerItems[i][0] = user_image[i].image;
    designerItems[i][1] = user_image[i].name;
    designerItems[i][2] = user_image[i].designs_link;
    designerItems[i][3] = user_image[i].profile_link;
  }  

  document.getElementById(image).innerHTML = designerItems[designerCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = designerItems[designerCurrentIndex][1];  
  document.getElementById(designs).innerHTML = designerItems[designerCurrentIndex][2];
  document.getElementById(profil).innerHTML = designerItems[designerCurrentIndex][3];
}

function showNextDesigner(image,textlayer,designs,profil) 
{
  if(designerCurrentIndex+1 < designerItems.length) {
    designerCurrentIndex += 1;
  }
  else {
    designerCurrentIndex = 0;
  } 
  document.getElementById(image).innerHTML = designerItems[designerCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = designerItems[designerCurrentIndex][1];  
  document.getElementById(designs).innerHTML = designerItems[designerCurrentIndex][2];
  document.getElementById(profil).innerHTML = designerItems[designerCurrentIndex][3];
}

function showPreviousDesigner(image,textlayer,designs,profil) 
{
  if(designerCurrentIndex-1 > -1) {
    designerCurrentIndex -= 1;
  }
  else {
    designerCurrentIndex = designerItems.length-1;
  } 
  document.getElementById(image).innerHTML = designerItems[designerCurrentIndex][0];
  document.getElementById(textlayer).innerHTML = designerItems[designerCurrentIndex][1];  
  document.getElementById(designs).innerHTML = designerItems[designerCurrentIndex][2];
  document.getElementById(profil).innerHTML = designerItems[designerCurrentIndex][3];
}  


function setImage(topic) 
{
  // funktion zum wechseln der images/layers unterhalb des Flashmoduls
  // kann innerhalb der beingung beliebig verändert werden
  
  if(topic == "g") {
    //aktion für "Designer-Anleitung" anzeigen, hier beispielhast bildwechsel
    document.getElementById('anleitung').src = 'images/02/3_steps_designtool.jpg';
  }
  else if (topic == "s") {
    //aktion fuer "Marktplatz-Anleitung" anzeigen
    document.getElementById('anleitung').src = 'images/02/3_steps_marktplatz.jpg';
  }
}

function jumpToAssistent(ref) {
       
            //ajax objekt aufbauen
            try {
                req = new XMLHttpRequest();
            } 
            catch (e) {
                try {
                    req = new ActiveXObject("Msxml2.XMLHTTP");
                } 
                catch (e) {
                    try {
                        req = new ActiveXObject("Microsoft.XMLHTTP");
                    } 
                    catch (failed) {
                        req = null;
                    }
                }
            }
            
            //von hier soll nachgeladen werden
            req.open("GET", 'http://www.pearlfection.de/tool/display_session_chain.php', true);
            
            //absenden bzw. laden
            req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            req.send(null);

            //lade-methode
            req.onreadystatechange = function(){
                switch (req.readyState) {
                    case 4:
                        if (req.status != 200) {
                            //!!! etwaige fehlerbehandlung!!!
                            //alert("Fehler:"+req.status);
                        } else {
                            //hier ist LASTCHAIN zugï¿½nglich
                            //alert(req.responseText);
                            var drop = "";
                            if (req.responseText!="") {
                                var answer = confirm("Es befindet sich eine Kette in der Zwischenablage. Diese wird nun verworfen.");
                                if (answer==true) {
                                    drop = "/drop";    
                                } else {
                                    //return;
                                }
                            }
                            document.location.href=ref+drop;
                        }
                        break;
                    default:
                        return false;
                        //alert("default");
                        break;
                }
            };
        }
   
this.LupePreview = function(){    
    
        
        xOffset = 230;
        yOffset = 20;
        
    jQuery("a.lupe").hover(function(e){
        this.t = this.title;
        this.title = "";    
        var c = (this.t != "") ? "<br/>" + this.t : "";
        jQuery("body").append("<p id='lupe'><img src='"+ this.rel +"' alt='Zoom' />"+ c +"</p>");                                 
        jQuery("#lupe")
            .css("position","absolute")
            .css("border","1px solid #666666")    
            .css("background","#FFF")    
            .css("padding","0px")    
            .css("text-align","center")  
            .css("color","#6D0B3C")  
            .css("font-family","Verdana,Arial,Helvetica")  
            .css("font-size","11px")  
            .css("top",(e.pageY - xOffset) + "px")
            .css("left",(e.pageX + yOffset) + "px")
            .fadeIn("fast");                        
    },
    function(){
        this.title = this.t;    
        jQuery("#lupe").remove();
    });    
    jQuery("a.lupe").mousemove(function(e){
        jQuery("#lupe")
            .css("top",(e.pageY - xOffset) + "px")
            .css("left",(e.pageX + yOffset) + "px");
    });            
};


jQuery(document).ready(function(){
    LupePreview();
});