File: toggle_visibility.js

package info (click to toggle)
wxpython4.0 4.2.0%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 232,540 kB
  • sloc: cpp: 958,937; python: 233,059; ansic: 150,441; makefile: 51,662; sh: 8,687; perl: 1,563; javascript: 584; php: 326; xml: 200
file content (60 lines) | stat: -rw-r--r-- 1,906 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*
 * toggle_visibility.js
 * --------------------
 *
 * These functions enable the user to toggle the visibility of a block of
 * the document, which is delimited by a <div> tag with an expected id
 * attribute.  The magic happens via using the id of the object passed to
 * toggle visibility to make the id's used to find the other elements that
 * will be operated upon.
 */

function hasClass(ele,cls) {
    return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)'));
}

function addClass(ele,cls) {
    if (!this.hasClass(ele,cls)) ele.className += " "+cls;
}

function removeClass(ele,cls) {
    if (hasClass(ele,cls)) {
        var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)');
        ele.className=ele.className.replace(reg,' ');
    }
}

function toggleVisibility(linkObj) {
    var base = linkObj.getAttribute('id');
    var summary = document.getElementById(base + '-summary');
    var content = document.getElementById(base + '-content');
    var trigger = document.getElementById(base + '-trigger');
    var cookieName = base + '-savedState'
    if ( hasClass(linkObj,'closed') ) {
        summary.style.display = 'none';
        content.style.display = 'block';
        trigger.src = '_static/images/open.png';
        removeClass(linkObj,'closed');
        addClass(linkObj,'opened');
        $.cookie(cookieName, 'opened');
    } else if ( hasClass(linkObj,'opened') ) {
        summary.style.display = 'block';
        content.style.display = 'none';
        trigger.src = '_static/images/closed.png';
        removeClass(linkObj,'opened');
        addClass(linkObj,'closed');
        $.cookie(cookieName, 'closed');
    }
    return false;
}


function toggleVisibilityOnLoad(linkObj) {
    var base = linkObj.getAttribute('id');
    var cookieName = base + '-savedState'
    var state = $.cookie(cookieName);
    if ( state == 'opened' ) {
        toggleVisibility(linkObj);
    }
}