// Funkcja sprawdza czy element jest różny od null i czy nie posiada już ustawionej klasy
function CanHaveClass__CssFriendlyAdapters(element)
{
    return ((element != null) && (element.className != null));
}

function HasAnyClass__CssFriendlyAdapters(element)
{
    return (CanHaveClass__CssFriendlyAdapters(element) && (element.className.length > 0));
}
// funkcja sprawdza czy dany element posiada klasę o nazwie zadanej w parametrze
function HasClass__CssFriendlyAdapters(element, specificClass)
{
    return (HasAnyClass__CssFriendlyAdapters(element) && (element.className.indexOf(specificClass) > -1));
}
// Funkcja dodaje klasę do określonego elementu
function AddClass__CssFriendlyAdapters(element, classToAdd)
{
    if (HasAnyClass__CssFriendlyAdapters(element)) // jeśli element posiada już ustawioną jakąkolwiek klase
    {
        if (!HasClass__CssFriendlyAdapters(element, classToAdd)) // jeśli element nie posiadał wcześniej ustawionej określonej klasy zostaje mu dodana
        {
            element.className = element.className + " " + classToAdd;
        }
    }
    else if (CanHaveClass__CssFriendlyAdapters(element)) // jesli nie ma klasy i może posiadać klasa zostaje mu ustawiona
    {
        element.className = classToAdd;
    }
}
// 
function AddClassUpward__CssFriendlyAdapters(startElement, stopParentClass, classToAdd)
{
    var elementOrParent = startElement; // element startowy
    // Popuki elementOrParent nie jest pusty i nie posiada ustawionej klasy topmostClass
    while ((elementOrParent != null) && (!HasClass__CssFriendlyAdapters(elementOrParent, topmostClass)))
    {
        AddClass__CssFriendlyAdapters(elementOrParent, classToAdd); // klasa podana w parametrze zostaje mu dodana
        elementOrParent = elementOrParent.parentNode; // elementem który jest tez testowany staje się element nadrzędny
    }    
}
// Zamienia kalsy dla elementu
function SwapClass__CssFriendlyAdapters(element, oldClass, newClass)
{
    if (HasAnyClass__CssFriendlyAdapters(element)) // jeśli element miał jaką kolwiek klasę 
    {
        element.className = element.className.replace(new RegExp(oldClass, "gi"), newClass); // zamiana
    }
}
// zmienia albo dodaje klasę do elementu
function SwapOrAddClass__CssFriendlyAdapters(element, oldClass, newClass)
{
    if (HasClass__CssFriendlyAdapters(element, oldClass)) // jeśli element posiadał klasę old zostaje ona zamieniona na new
    {
        SwapClass__CssFriendlyAdapters(element, oldClass, newClass);
    }
    else
    {
        AddClass__CssFriendlyAdapters(element, newClass);
    }
}
// usuwa klasę dla elementu
function RemoveClass__CssFriendlyAdapters(element, classToRemove)
{
    SwapClass__CssFriendlyAdapters(element, classToRemove, "");
}
// ta funkcja jak i ta pozywżej jest dość dziwna nie znana definicja topmostClass
function RemoveClassUpward__CssFriendlyAdapters(startElement, stopParentClass, classToRemove)
{
    var elementOrParent = startElement;
    while ((elementOrParent != null) && (!HasClass__CssFriendlyAdapters(elementOrParent, topmostClass)))
    {
        RemoveClass__CssFriendlyAdapters(elementOrParent, classToRemove);
        elementOrParent = elementOrParent.parentNode;
    }    
}
// zwraca true jeśli kliknięto klawisz enter
function IsEnterKey()
{
    var retVal = false;
    var keycode = 0;
    if ((typeof(window.event) != "undefined") && (window.event != null))
    {
        keycode = window.event.keyCode;
    }
    else if ((typeof(e) != "undefined") && (e != null))
    {
        keycode = e.which;
    }
    if (keycode == 13)
    {
        retVal = true;
    }
    return retVal;
}
