summaryrefslogtreecommitdiff
path: root/lib/scripts/ajax.js
blob: 44dcee999113202f2dffcf2dc47fe086bbc7ac98 (plain)
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
/**
 * AJAX functions for the pagename quicksearch
 *
 * @license  GPL2 (http://www.gnu.org/licenses/gpl.html)
 * @author   Andreas Gohr <andi@splitbrain.org>
 * @author   Adrian Lang <lang@cosmocode.de>
 */
var ajax_quicksearch = {

    inObj:   null,
    outObj:  null,
    sackObj: null,
    delay:   null,

    init: function(inID, outID) {

        this.inObj  = $(inID);
        this.outObj = $(outID);

        // objects found?
        if (this.inObj  === null) return;
        if (this.outObj === null) return;

        // prepare AJAX
        this.sackObj = new sack(DOKU_BASE + 'lib/exe/ajax.php');
        this.sackObj.AjaxFailedAlert = '';
        this.sackObj.encodeURIString = false;
        this.sackObj.onCompletion = ajax_quicksearch.onCompletion;

        // attach eventhandler to search field
        this.delay = new Delay(function () {
            ajax_quicksearch.clear_results();
            var value = ajax_quicksearch.inObj.value;
            if(value === ''){ return; }
            ajax_quicksearch.sackObj.runAJAX('call=qsearch&q=' + encodeURI(value));
        });

        addEvent(this.inObj, 'keyup', function () {
            ajax_quicksearch.clear_results();
            ajax_quicksearch.delay.start();
        });

        // attach eventhandler to output field
        addEvent(this.outObj, 'click', function () {
            ajax_quicksearch.outObj.style.display = 'none';
        });
    },

    clear_results: function(){
        ajax_quicksearch.outObj.style.display = 'none';
        ajax_quicksearch.outObj.innerHTML = '';
    },

    onCompletion: function() {
        var data = this.response; // 'this' is sack context
        if (data === '') { return; }

        var outObj = ajax_quicksearch.outObj;

        outObj.innerHTML = data;
        outObj.style.display = 'block';
        outObj.style['white-space'] = 'nowrap';

        // shorten namespaces if too long
        var width = outObj.clientWidth;
        var links = outObj.getElementsByTagName('a');
        for(var i=0; i<links.length; i++){
            // maximum allowed width:
            var max = width - links[i].offsetLeft;
            var isRTL = (document.documentElement.dir == 'rtl');

            if(!isRTL && links[i].offsetWidth < max) continue;
            if(isRTL && links[i].offsetLeft > 0) continue;

            var nsL = links[i].innerText.indexOf('(');
            var nsR = links[i].innerText.indexOf(')');
            var eli = 0;
            var runaway = 0;

            while( (nsR - nsL > 3) &&
                    (
                       (!isRTL && links[i].offsetWidth > max) ||
                       (isRTL && links[i].offsetLeft < 0)
                    )
                 ){
                if(runaway++ > 500) return; // just in case something went wrong

                if(eli){
                    // elipsis already inserted
                    if( (eli - nsL) > (nsR - eli) ){
                        // cut left
                        links[i].innerText = links[i].innerText.substring(0,eli-2)+
                                             links[i].innerText.substring(eli);
                    }else{
                        // cut right
                        links[i].innerText = links[i].innerText.substring(0,eli+1)+
                                             links[i].innerText.substring(eli+2);
                    }
                }else{
                    // replace middle with ellipsis
                    var mid = Math.floor( nsL + ((nsR-nsL)/2) );
                    links[i].innerText = links[i].innerText.substring(0,mid)+'…'+
                                         links[i].innerText.substring(mid+1);
                }
                eli = links[i].innerText.indexOf('…');
                nsL = links[i].innerText.indexOf('(');
                nsR = links[i].innerText.indexOf(')');
            }
        }
    }

};


addInitEvent(function(){
    ajax_quicksearch.init('qsearch__in','qsearch__out');
});