// Copyright (c) 2004-2005 koikikukan All Rights Reserved.
// http://yujiro.dyndns.com/blog/koikikukan/
// License is granted if and only if this entire
// copyright notice is included. By Yujiro ARAKI.

// Ver1.00 initial version.
// Ver2.00 add the state maintenance function by cookie.
// Ver3.00 improve cookie processing.
// Ver3.01 corresponds to Mac+IE.
// Ver4.00 2005.03.31 add link display by block.
// Ver5.00 2005.08.22 add Ajax library.
// Ver5.01 2005.08.27 add flag of Ajax selection for subcategory.
// Ver6.00 2006.07.10 add archives.
// Ver6.01 2006.08.22 corresponds to image.
// Ver6.02 2006.11.26 fix bug(corresponds to image).

function deleteValue(name, nameEQ) {
    var ca = document.cookie.split(';');
    var newData = new Array();

    // Repeat by cookie
    for(var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') {
            c = c.substring(1,c.length);
        }
        if (c.indexOf(nameEQ) == 0) {

            // Delete the corresponding name.
            var data = c.substring(nameEQ.length,c.length);
            var list = data.split('|');
            for(var x = 0; x < list.length; x++) {
                if (list[x] != name) {

                    // corresponds to Mac+IE
                    newData[newData.length] = list[x];
                }
            }
            return newData.join('|');
        }
    }

    // Return empty when cookie does not exist.
    return '';
}

function hasName(name, nameEQ) {
    var ca = document.cookie.split(';');
    for(var i = 0; i < ca.length; i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') {
            c = c.substring(1,c.length);
        }
        if (c.indexOf(nameEQ) == 0) {
            var data = c.substring(nameEQ.length,c.length);
            var list = data.split('|');
            for(var x = 0; x < list.length; x++) {
                if (list[x] == name) {
                    return true;
                }
            }
            return false;
        }
    }
}

function createCookieByValue(name, onoff, days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires="+date.toGMTString();
    } else {
        expires = "";
    }

    // Once delete a name from cookie.
    var newOnData = deleteValue(name, 'sidebarMenuOn=');
    var newOffData = deleteValue(name, 'sidebarMenuOff=');

    // Set up a name as new data.
    if (onoff == 'on') {
        if (newOnData != '') {
            newOnData += '|' + name;
        } else {
            newOnData = name;
        }
    } else {
        if (newOffData != '') {
            newOffData += '|' + name;
        } else {
            newOffData = name;
        }
    }

    // Save cookie.
    document.cookie = "sidebarMenuOn=" + newOnData + expires + "; path=/";
    document.cookie = "sidebarMenuOff=" + newOffData + expires + "; path=/";
}

function readCookieByValue(name) {

    // Search a menu.
    // Return empty if there is nothing to both.
    if (hasName(name, 'sidebarMenuOn=')) {
        return 'on';
    }
    if (hasName(name, 'sidebarMenuOff=')) {
        return 'off';
    }
    return null;
}

// リスト数取征E
function getListCount(objLists, viewNum, idName, linkNumber, trackbackNumber, rightMarkForListNumber, subCategoryCount, leftMarkForListNumber, countTag, offsetValue) {

    var objItems;
    var href;
    var commentCounter = 0;

    // サブカチEリーリスチE
    if (subCategoryCount && (idName.indexOf('subcategories') == 0)) {
        objItems = objLists.getElementsByTagName('li');

    // 持Eされたタグを使用
    } else if (countTag == 'li') {
        objItems = objLists.getElementsByTagName(countTag);

    // そE仁Eaタグ)
    } else {
        objItems = objLists.getElementsByTagName('a');
    }

    // Recent Comments
    if (idName == 'comment') {
        for (i = 0; i < objItems.length; i++) { // Repeat a tag.
            href = objItems[i].getAttribute("href");
            if(href.indexOf('#') == -1){ // Count if '#' exists in a href attribute.
                commentCounter++;
            }
        }
    }

    // Trackback
    var counter;
    if (idName == 'trackback') {
        commentCounter = objItems.length / trackbackNumber;
    }

    // Subtract the unnecessary number of links.
    if (idName.indexOf('link') == 0) {
        var linkName;
        for (j = 0; j < linkNumber; j++) {
            linkName = 'link' + (j + 1);
            if (idName == linkName) {
                counter = objItems.length - offsetValue[j];
            }
        }
    } else {

        // Subtract the value of a counter from 'Recent Comments'
        counter = objItems.length - commentCounter;
    }

    // decoration counter
    if (leftMarkForListNumber) {
        counter = leftMarkForListNumber + counter;
    }
    if (rightMarkForListNumber) {
        counter = counter + rightMarkForListNumber;
    }

    return counter;
}

// リスト数設宁E
function setListNumber(buffer, listCount, menuTitle, listNumberPosition, tlspace) {

    // リスト数を前に表示
    if (listNumberPosition) {
        buffer[buffer.length] = listCount;
        if (tlspace) {
            buffer[buffer.length] = tlspace;
        }
        buffer[buffer.length] = menuTitle;

    // リスト数を後に表示
    } else {
        buffer[buffer.length] = menuTitle;
        if (tlspace) {
            buffer[buffer.length] = tlspace;
        }
        buffer[buffer.length] = listCount;
    }
}

// メニュータイトル+リスト数設宁Eblock用)
function setMenuTitleForBlock(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace) {

    // リスト数表示
    if (viewNum) {
        setListNumber(buffer, listCount, menuTitle, listNumberPosition, tlspace);

    // リスト数非表示
    } else {
        buffer[buffer.length] = menuTitle;
    }
}

// メニュータイトル+リスト数設宁E
function setMenuTitle(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace) {

    // リスト数表示
    if (viewNum) {

        // リスト数を前に表示
        if (listNumberPosition) {
            buffer[buffer.length] = listCount;
            if (tlspace) {
                buffer[buffer.length] = tlspace;
            }
        }

        buffer[buffer.length] = menuTitle;

        // リスト数を後に表示
        if (!listNumberPosition) {
            if (tlspace) {
                buffer[buffer.length] = tlspace;
            }
            buffer[buffer.length] = listCount;
        }

    // リスト数非表示
    } else {
        buffer[buffer.length] = menuTitle;
    }
}

// 折りたたみ実衁Eタグ持EE
function FoldNavigationByTagName(idName, initMode, viewNum, countTag, sp) {

//--------------------------------------------------------
// Configuration
//--------------------------------------------------------

//--------------------------------------------------------
// メニュータイトル用設定データ
//--------------------------------------------------------

// リンク方弁E
// 折りたたみマEクにリンク付与！Eunblock'
// メニュータイトル枠全体にリンク付丁E'block'
var linkType = 'block';

//-----------------------
// 折りたたみスピEチE
//-----------------------

// 全てのメニューのスピEチE
// 通常EEnormal'
// 遁EEEslow'
var speed = 'normal';

// サブカチEリーのスピEチEspeed ぁEslow の場合Eみ有効)
// 通常EEnormal'
// 遁EEEslow'
var subcategorySpeed = 'normal';

//-----------------------
// 折りたたみマEク関連
//-----------------------

// 折りたたみマEク表示(メニュータイトル枠全体をリンクにする場合Eみ有効)
// 表示するEtrue
// 表示しなぁEfalse
var displayMark = true;

// 折りたたみマEク
// 上：閉じてぁE状態で表示されるEーク
// 下：開ぁEぁE状態で表示されるEーク
// 画像を設定する場合E右辺めE'<img src="[画像EURL]" />'; と書ぁEください
var openMarkForSideBarMenu  = '<img src="http://file.midnightsirius.blog.shinobi.jp/open1.gif" border="0" />';
var closeMarkForSideBarMenu = '<img src="http://file.midnightsirius.blog.shinobi.jp/close1.gif" border="0" />';

// 折りたたみマEク位置(折りたたみマEクを表示する場合Eみ有効)
// タイトル前に折りたたみマEクをE置Etrue
// タイトル後に折りたたみマEクをE置Efalse
// 左端またE右端に折りたたみマEクをE置Etrue
var preMarkForSideBarMenu = true;

// 折りたたみマEク画僁Eリンク方式が 'block' の場合Eみ使われまぁE
// 画像を使用するEtrue
// 画像を使用しなぁEfalse
// var image = false;

//---------------
// リスト数関連
//---------------

// リスト数表示位置
// タイトル前にリスト数を表示Etrue
// タイトル後にリスト数を表示Efalse
var listNumberPosition = true;

// リスト数表示を括るEーク
var leftMarkForListNumber = '';
var rightMarkForListNumber = '';

// リンク数減算が忁Eなメニュー数
// リンク数を減算する忁Eがあるメニューはここに含めてください
// 注:対象となるid属性名が「linkx(xは数孁E」であること
// 減算するメニューがなぁE吁E0
var linkNumber = 2;

// 減算する各メニューのオフセチE値
// 注:対象となるid属性名が「linkx(xは数孁E」であること
var offsetValue = new Array(linkNumber);
offsetValue[0] = 3;
offsetValue[1] = 2;

// トラチEバック数の除数
// 注1:対象となるid属性名が「trackback」であること
// 注2:除算が不要な場合E'1'を設定すること
var trackbackNumber = 2;

// サブカチEリーリスト数計数方況E
// liタグで計数Etrue
// aタグで計数Efalse
// 注:他Eタグを指定する場合Efalseを設定してください
var subCategoryCount = true;

//-------------------
// 表示位置補正関連
//-------------------

// タイトル表示位置補正フラグ(折りたたみマEクを左端またE右端に配置する場吁E
// 補正するEtrue
// 補正しなぁEfalse
var modificationFlag = true;

// タイトル表示位置補正方吁E折りたたみマEクを左端またE右端に配置する場吁E
// ・タイトルを右方向に補正Etrue
// ・タイトルを左方向に補正Efalse
var centeringPosition = false;

// タイトル表示位置補正オフセチE(折りたたみマEクを左端またE右端に配置した場吁E
var offsetForCentering = 0;

// タイトルと折りたたみマEクのスペEス(上記以外で折りたたみマEクを表示をする場合に有効)
// 折りたたみマEクを左端またE右端に配置する場吁E0'を設宁E
var offsetForTitleAndMark = 0;

// タイトルとリスト数のスペEス(リスト数を表示するメニューに有効)
var offsetForTitleAndLinkNumber = 1;

//--------------------------------------------------------
// サブカチEリーリスト用設定データ
//--------------------------------------------------------

// サブカチEリーフラグ
// サブカチEリーの折りたたみを有効にする(別途テンプレート設定が忁EE
// 有効にするEtrue
// 無効にするEfalse
var subCategory = true;

// サブカチEリー用折りたたみマEク
// 上：閉じてぁE状態で表示されるEーク
// 下：開ぁEぁE状態で表示されるEーク
var openMarkForSubCategories  = '▼';
var closeMarkForSubCategories = '▲';

// サブカチEリー用折りたたみマEク挿入位置
// カチEリー前に折りたたみマEクをE置Etrue
// カチEリー後に折りたたみマEクをE置Efalse
var preMarkForSubCategory = false;

// サブカチEリーのタイトルとマEクのスペEス
var offsetForTitleAndMarkOfSubcategory = 0;

//--------------------------------------------------------
// アーカイブリスト用設定データ
//--------------------------------------------------------

// アーカイブリストフラグ
// サブカチEリーの折りたたみを有効にする(別途テンプレート設定が忁EE
// 有効にするEtrue
// 無効にするEfalse
var archives = true;

// アーカイブリスト用折りたたみマEク
// 上：閉じてぁE状態で表示されるEーク
// 下：開ぁEぁE状態で表示されるEーク
var openMarkForArchives  = '▼';
var closeMarkForArchives = '▲';

// アーカイブリスト用折りたたみマEク挿入位置
// カチEリー前に折りたたみマEクをE置Etrue
// カチEリー後に折りたたみマEクをE置Efalse
var preMarkForArchives = false;

// アーカイブリストEタイトルとマEクのスペEス
var offsetForTitleAndMarkOfArchives = 1;

//--------------------------------------------------------
// 状態保持用設定データ
//--------------------------------------------------------

// 状態保持フラグ
// 有効にするEtrue
// 無効にするEfalse
var holdState = true;

//--------------------------------------------------------

    var openMark;  // The mark for opening, when having closed
    var closeMark; // The mark for closing, when open

    var idTitle = Array(idName,'name').join('');
    var idList = Array(idName,'list').join('');
    var objTitle = this.document.getElementById(idTitle);
    var objLists = this.document.getElementById(idList);

    if (!objTitle || !objLists) return;

    // 折りたたみマEク
    openMark = openMarkForSideBarMenu;
    closeMark = closeMarkForSideBarMenu;
    if (subCategory) {
        if (idName.indexOf('subcategories') == 0) {
            openMark = openMarkForSubCategories;
            closeMark = closeMarkForSubCategories;
        }
    }
    if (archives) {
        if (idName.indexOf('archive') == 0) {
            openMark = openMarkForArchives;
            closeMark = closeMarkForArchives;
        }
    }

    var dispMode = objLists.style.display;
    if (!dispMode) {

        // Hold a fold-up state to cookie.
        if (holdState) {
            var cookie_initMode = readCookieByValue(idName);
            if(cookie_initMode){
                initMode = cookie_initMode;
            }
            createCookieByValue(idName, initMode, 365);
        }

        // 開始タグ
        var buffer = new Array();
        var tmpText;

        // 折りたたみスピEドによって起動関数を変更
        if(sp != 'dummy'){
            speed = sp;
        }
        if(speed == 'slow') {
            tmpText = Array('FoldNavigationSlowly(',"'",idName,"','chng','');return(false);").join('');
        } else {
            tmpText = Array('FoldNavigation(',"'",idName,"','chng','');return(false);").join('');
        }
        var startTag = Array('<a class="foldmark" href="#" onclick="',tmpText,'" onkeypress="',tmpText,'">').join('');

        // 終亁Eグ
        var endTag = '</a>';

        // 表示する折りたたみマEク
        var foldMark = (initMode == 'off') ? openMark : closeMark;

        // メニュータイトル
        var menuTitle = objTitle.innerHTML;

        // パディング
        var padding = '';
        for (k = 0; k < offsetForCentering; k++) {
            padding += '&nbsp;';
        }

        // タイトルとリンク数のスペEス
        var tlspace = '';
        for (l = 0; l < offsetForTitleAndLinkNumber; l++) {
            tlspace += '&nbsp;';
        }

        // タイトルとマEクのスペEス
        var tmspace = '';
        for (l = 0; l < offsetForTitleAndMark; l++) {
            tmspace += '&nbsp;';
        }

        // サブカチEリー用タイトルとマEクのスペEス
        var scspace = '';
        for (l = 0; l < offsetForTitleAndMarkOfSubcategory; l++) {
            scspace += '&nbsp;';
        }

        // アーカイブリスト用タイトルとマEクのスペEス
        var alspace = '';
        for (l = 0; l < offsetForTitleAndMarkOfArchives; l++) {
            alspace += '&nbsp;';
        }

        // リスト数
        var listCount;
        if (viewNum) {
            listCount = getListCount(objLists, viewNum, idName, linkNumber, trackbackNumber, rightMarkForListNumber, subCategoryCount, leftMarkForListNumber, countTag, offsetValue);
        }

        // 折りたたみ表示つきタイトル生E

        // サブカチEリーリスチE
        if (subCategory && (idName.indexOf('subcategories') == 0)) {
            if (preMarkForSubCategory) {
                buffer[buffer.length] = startTag;
                buffer[buffer.length] = foldMark;
                buffer[buffer.length] = endTag;
                if (scspace) {
                    buffer[buffer.length] = scspace;
                }
                buffer[buffer.length] = menuTitle;
            } else {
                buffer[buffer.length] = menuTitle;
                if (scspace) {
                    buffer[buffer.length] = scspace;
                }
                buffer[buffer.length] = startTag;
                buffer[buffer.length] = foldMark;
                buffer[buffer.length] = endTag;
            }

        // アーカイブリスチE
        } else if (archives && (idName.indexOf('archive') == 0)) {
            if (preMarkForArchives) {
                buffer[buffer.length] = startTag;
                buffer[buffer.length] = foldMark;
                buffer[buffer.length] = endTag;
                if (alspace) {
                    buffer[buffer.length] = alspace;
                }
                buffer[buffer.length] = menuTitle;
            } else {
                buffer[buffer.length] = menuTitle;
                if (alspace) {
                    buffer[buffer.length] = alspace;
                }
                buffer[buffer.length] = startTag;
                buffer[buffer.length] = foldMark;
                buffer[buffer.length] = endTag;
            }

        // メニュータイトル
        } else {

            // 生Eパターン決宁Ebuffer生E)
            if (linkType == 'unblock') {

                // マEク剁E
                if (preMarkForSideBarMenu) {

                    // 折りたたみマEク設宁E
                    buffer[buffer.length] = startTag;
                    buffer[buffer.length] = foldMark;
                    buffer[buffer.length] = endTag;

                    // 表示位置補正
                    if(modificationFlag && centeringPosition) {
                        buffer[buffer.length] = padding;
                    }

                    // タイトルとマEクのスペEス
                    if(offsetForTitleAndMark) {
                        buffer[buffer.length] = tmspace;
                    }

                    // タイトル設宁E
                    setMenuTitle(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace);

                    // 表示位置補正
                    if(modificationFlag && !centeringPosition) {
                        buffer[buffer.length] = padding;
                    }

                // マEク征E
                } else {

                    // 表示位置補正
                    if(modificationFlag && centeringPosition) {
                        buffer[buffer.length] = padding;
                    }

                    // タイトル設宁E
                    setMenuTitle(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace);

                    // タイトルとマEクのスペEス
                    if(offsetForTitleAndMark) {
                        buffer[buffer.length] = tmspace;
                    }

                    // 折りたたみマEク設宁E
                    buffer[buffer.length] = startTag;
                    buffer[buffer.length] = foldMark;
                    buffer[buffer.length] = endTag;

                    // 表示位置補正
                    if(modificationFlag && !centeringPosition) {
                        buffer[buffer.length] = padding;
                    }
                }

            // ブロチE表示
            } else {
                buffer[buffer.length] = startTag;

                // マEク表示
                if (displayMark) {

                    // マEク剁E
                    if (preMarkForSideBarMenu) {
                        buffer[buffer.length] = foldMark;

                        // タイトルとマEクのスペEス
                        if(offsetForTitleAndMark) {
                            buffer[buffer.length] = tmspace;
                        }

                        setMenuTitleForBlock(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace);

                    // マEク征E
                    } else {
                        setMenuTitleForBlock(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace);

                        // タイトルとマEクのスペEス
                        if(offsetForTitleAndMark) {
                            buffer[buffer.length] = tmspace;
                        }
                        buffer[buffer.length] = foldMark;
                    }

                // マEク非表示
                } else {
                    setMenuTitleForBlock(viewNum, buffer, listCount, menuTitle, listNumberPosition, tlspace);
                }
                buffer[buffer.length] = endTag;
            }
        }

        // 生EチEEタをオブジェクトに設宁E
        objTitle.innerHTML = buffer.join('');

        // スタイル設宁E
        objLists.style.display = (initMode == 'off') ? 'none' : 'block';

    } else if (initMode == 'chng') {

        // 折りたたみマEク置揁E
        var objMarks = objTitle.getElementsByTagName('a');
        for (i = 0; i < objMarks.length; i++) {
            if (objMarks[i].className == 'foldmark') {

                if(linkType == 'block' && displayMark) {
                    var title = objMarks[i].innerHTML;

                    // 折りたたみマEクの画像判宁E
                    var image = openMarkForSideBarMenu.search(/^</) != -1 ? true : false;
                    if (subCategory) {
                        if (idName.indexOf('subcategories') == 0) {
                            image = openMarkForSubCategories.search(/^</) != -1 ? true : false;
                        }
                    }
                    if (archives) {
                        if (idName.indexOf('archive') == 0) {
                            image = openMarkForArchives.search(/^</) != -1 ? true : false;
                        }
                    }
                    if(image){
                        if(dispMode == 'none'){
                            title = title.replace(/<.*>/, closeMark);
                        } else {
                            title = title.replace(/<.*>/, openMark);
                        }
                    } else {
                        if(dispMode == 'none'){
                           title = title.replace(openMark, closeMark);
                        } else {
                           title = title.replace(closeMark, openMark);
                        }
                    }
                    objMarks[i].innerHTML = title;
                } else if((linkType == 'unblock') || (subCategory && (idName.indexOf('subcategories') == 0)) || (archives && (idName.indexOf('archive') == 0))) {
                    objMarks[i].innerHTML = (dispMode == 'none') ? closeMark : openMark;
                }
            }
        }

        // 折りたたみスピEチE
        if(sp != 'dummy'){
            speed = sp;
        }
        if(speed == 'slow' || (idName.indexOf('subcategories') == 0 && subcategorySpeed == 'slow')) {
            if(dispMode == 'none') {
                element = $(idList);
                options = {
                    afterFinish: function(effect) {
                        Element.undoClipping(effect.element);
                        Element.show(effect.element); // prototype.js 修正要E
//                        element.style.display = 'block';
                    }
                };
                Effect.BlindDown(element, options);
            } else {
                element = $(idList);
                options = {
                    afterFinish: function(effect) {
                        Element.hide(effect.element);
                    }
                };
                Effect.BlindUp(element, options);
            }
        } else {

            // スタイル設宁E
            objLists.style.display = (dispMode == 'none') ? 'block' : 'none';
        }

        // Hold a fold-up state to cookie, when a change occurs.
        if (holdState) {
            if (dispMode == 'none') {
                createCookieByValue(idName, 'on', 365);
            } else {
                createCookieByValue(idName, 'off', 365);
            }
        }
    }
}

// 折りたたみ実衁E
function FoldNavigation(idName, initMode, viewNum) {
    FoldNavigationByTagName(idName, initMode, viewNum, 'dummy', 'dummy');
}

function FoldNavigationSlowly(idName, initMode, viewNum) {
    FoldNavigationByTagName(idName, initMode, viewNum, 'dummy', 'slow');
}

