//Callbacks from applet implemented here so you don't /have/ to implement them
//in every js file unless you need them.
function loaded(){
}

function registered(status){
}

function hostreachable(status, roundtrip){
}

function newCall(inbound, far, near, answered, callingname){
}

function hungUp(causecode){
}

function ringing(inbound, far, near, answered, callingname){
}

function answered(inbound, far, near, answered, callingname){
}

// called early on in applet startup - before loaded
function setup(){
    var indev = getCookie("inputDevice");
    var outdev = getCookie("outputDevice");
    var faceless = getFaceless();
    if (indev != null){
      faceless.setAudioIn(indev);
    }
    if (outdev != null){
      faceless.setAudioOut(outdev);
    }
}


//Helper methods
function getFaceless(){
  var faceless = document.getElementById('faceless');
  if (!faceless){
    faceless = document.getElementById('IEfaceless');
  }
  return faceless;
}

function setAudioCookie(name,val){
  var nextyear = new Date();
  nextyear.setFullYear(nextyear.getFullYear() +1);
  setCookie(name,val,nextyear.toGMTString(),"/");
}

function setAudioInCookie(val){
  setAudioCookie("inputDevice",val);
}
function setAudioOutCookie(val){
  setAudioCookie("outputDevice",val);
}
/******************************************************************************
***                           Cookie support                                ***
******************************************************************************/

/**
 * Read the JavaScript cookies tutorial at:
 *   http://www.netspade.com/articles/javascript/cookies.xml
 */

/**
 * Sets a Cookie with the given name and value.
 *
 * name       Name of the cookie
 * value      Value of the cookie
 * [expires]  Expiration date of the cookie (default: end of current session)
 * [path]     Path where the cookie is valid (default: path of calling document)
 * [domain]   Domain where the cookie is valid
 *              (default: domain of calling document)
 * [secure]   Boolean value indicating if the cookie transmission requires a
 *              secure transmission
 */
function setCookie(name, value, expires, path, domain, secure)
{
    var cook = name + "=" + escape(value) +
        ((expires) ? "; expires=" + expires : "") +
        ((path) ? "; path=" + path : "") +
        ((domain) ? "; domain=" + domain : "") +
        ((secure) ? "; secure" : "");
    document.cookie = cook;
}

/**
 * Gets the value of the specified cookie.
 *
 * name  Name of the desired cookie.
 *
 * Returns a string containing value of specified cookie,
 *   or null if cookie does not exist.
 */
function getCookie(name)
{
    var dc = document.cookie;
    var prefix = name + "=";
    var begin = dc.indexOf("; " + prefix);
    if (begin == -1)
    {
        begin = dc.indexOf(prefix);
        if (begin != 0) return null;
    }
    else
    {
        begin += 2;
    }
    var end = document.cookie.indexOf(";", begin);
    if (end == -1)
    {
        end = dc.length;
    }
    return unescape(dc.substring(begin + prefix.length, end));
}

/**
 * Deletes the specified cookie.
 *
 * name      name of the cookie
 * [path]    path of the cookie (must be same as path used to create cookie)
 * [domain]  domain of the cookie (must be same as domain used to create cookie)
 */
function deleteCookie(name, path, domain)
{
    if (getCookie(name))
    {
        document.cookie = name + "=" +
            ((path) ? "; path=" + path : "") +
            ((domain) ? "; domain=" + domain : "") +
            "; expires=Thu, 01-Jan-70 00:00:01 GMT";
    }
}
