search.js 6.84 KB
Newer Older
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
1
2
3
4
5
// search options
// --- needs to be adapted to the form of our content
const options = {
    includeScore: true,
    // Search in `author` and in `tags` array
Joe TS Dell's avatar
update    
Joe TS Dell committed
6
7
8
    keys: ["item.title", "item.keywords",
        "item.author.firstName", "item.author.lastName"
    ]
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
9
}
Patrick's avatar
Patrick committed
10
11
12
const options_paper = {
    includeScore: true,
    // Search in `author` and in `tags` array
Patrick's avatar
Patrick committed
13
    keys: ["item.title", "item.keywords", "item.authors.lastName", "item.authors.firstName"
Joe TS Dell's avatar
update    
Joe TS Dell committed
14
    ]
Patrick's avatar
Patrick committed
15
}
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
16
17
18

// start search
var searchanswer
Patrick's avatar
Patrick committed
19
var searchanswer_paper
Joe TS Dell's avatar
update    
Joe TS Dell committed
20
21
22
23

function search() {
    const fuse = new Fuse(stuff, options);
    searchanswer = fuse.search(document.getElementById("search-input").value)
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
24
25
26
27
28
29
30
31
32
33
34

    var new_row = document.getElementById("row_main")
    new_row.innerHTML = "";
    var searchLength = searchanswer.length;
    for (var i = 0; i < searchLength; i++) {
        addcontent(searchanswer[i].item);
        //Do something
    }
    // alert(searchanswer);
    console.log(searchanswer);
}
Joe TS Dell's avatar
update    
Joe TS Dell committed
35
36

function search_paper() {
Patrick's avatar
Patrick committed
37
     const fuse = new Fuse(jsonContent, options_paper); //stuff_paper
Joe TS Dell's avatar
update    
Joe TS Dell committed
38
    searchanswer_paper = fuse.search(document.getElementById("search-input_paper").value)
Patrick's avatar
Patrick committed
39
    document.getElementById("nextblock").style.display = "none";
Patrick's avatar
Patrick committed
40
41
42
43
    var new_row = document.getElementById("cont_paper")
    new_row.innerHTML = "";
    var searchLength = searchanswer_paper.length;
    for (var i = 0; i < searchLength; i++) {
Patrick's avatar
Patrick committed
44
45
46
47
48
        console.log(searchanswer_paper[i])
        if (searchanswer_paper[i].score < 0.5){
            addpaper(searchanswer_paper[i].item);
        }
        
Patrick's avatar
Patrick committed
49
50
51
52
53
        //Do something
    }
    // alert(searchanswer);
    console.log(searchanswer_paper);
}
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
54
55
56
//get json
// --- can be adapted if we load the content from the json
var stuff = []
Patrick's avatar
Patrick committed
57
var stuff_paper = []
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
58
59
60
61
62
63
64
65
66
67
68
// $.getJSON("./content/content.json", function(result){
//     stuff = result;
//     var new_row = document.getElementById("row_main")
//     new_row.innerHTML = "";
//     var arrayLength = stuff.length;
//     for (var i = 0; i < arrayLength; i++) {
//         addcontent(stuff[i]);
//         //Do something
//     }
//     // stuff.forEach(addcontent());
//     });
Sini's avatar
Sini committed
69
70
71
72




Joe TS Dell's avatar
update    
Joe TS Dell committed
73
74
$(document).ready(function () {
    $.getJSON("./content/content.json", function (result) {
Joe TS Dell's avatar
update    
Joe TS Dell committed
75
        console.log("content.json ==> HTML")
Joe TS Dell's avatar
update    
Joe TS Dell committed
76
77
78
79
80
81
82
83
        stuff = result;
        var new_row = document.getElementById("row_main")
        new_row.innerHTML = "";
        var arrayLength = stuff.length;
        for (var i = 0; i < arrayLength; i++) {
            addcontent(stuff[i]);
            //Do something
        }
Patrick's avatar
Patrick committed
84

Joe TS Dell's avatar
update    
Joe TS Dell committed
85
86
87
88
89
90
91
92
93
94
95
        $.getJSON("./content/team.json", function(result){ 
            console.log("team.json ==> HTML")
            team = result;
            var new_row = document.getElementById("team-section")
            new_row.innerHTML = "";
            var arrayLength = team.length;
            for (var i = 0; i < arrayLength; i++) {
                addTeam(team[i]);
                //Do something
            }
        });
Patrick's avatar
Patrick committed
96
        changeLang();
Joe TS Dell's avatar
update    
Joe TS Dell committed
97
    });
Joe TS Dell's avatar
up    
Joe TS Dell committed
98
99
    var currentYear = new Date().getFullYear();
    document.getElementById('current-year').innerHTML = currentYear;   
Joe TS Dell's avatar
update    
Joe TS Dell committed
100

Joe TS Dell's avatar
update    
Joe TS Dell committed
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
    // get paper content is commented out for back up
    // $.getJSON("./content/paper2.json", function (result) {
    //     stuff_paper = result;
    //     var new_row = document.getElementById("cont_paper")
    //     new_row.innerHTML = "";
    //     var arrayLength = stuff_paper.length;
    //     for (var i = 0; i < arrayLength; i++) {

    //         if (Math.abs(arrayLength - i) <= max_paper_list) {
    //             console.log("close to " + i)
    //             addpaper(stuff_paper[i]);
    //         }
    //         //Do something
    //     }
    // });

117
118
    
    
Joe TS Dell's avatar
update    
Joe TS Dell committed
119

Joe TS Dell's avatar
up    
Joe TS Dell committed
120
    
Patrick's avatar
Patrick committed
121
122
123

});
function changeLang () {
Joe TS Dell's avatar
update    
Joe TS Dell committed
124
    var userLang = navigator.language || navigator.userLanguage;
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
125
    console.log("The language is: " + userLang);
Joe TS Dell's avatar
update    
Joe TS Dell committed
126
    if (userLang.includes("de")) {
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
127
128
129
130
131
        console.log(true)
        var select1 = document.getElementById('selectpicker1');
        console.log(select1)
        select1.value = "2";
        select1.dispatchEvent(new Event('change'));
Patrick's avatar
Patrick committed
132
133
134
135
136
    } else {
        var select1 = document.getElementById('selectpicker1');
        console.log(select1)
        select1.value = "1";
        select1.dispatchEvent(new Event('change'));
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
137
    }
Patrick's avatar
Patrick committed
138
}
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
139
140
141
142
143
144
145
146
147

// window.onload = function () {
//     var e = document.getElementById("selectpicker1");
//     e.value = 2;
//     e.dispatchEvent(new Event('change'));
// };


// searchbar and start search
Joe TS Dell's avatar
update    
Joe TS Dell committed
148
function searchToggle(obj, evt) {
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
149
150
    console.log("arrive")
    var container = $(obj).closest('.search-wrapper');
Joe TS Dell's avatar
update    
Joe TS Dell committed
151
152
153
154
155
156
157
158
159
160
161
162
163
164
    if (!container.hasClass('active')) {
        container.addClass('active');
        evt.preventDefault();
        console.log("first")
    } else if (container.hasClass('active') && $(obj).closest('.input-holder').length == 0) {
        container.removeClass('active');
        // clear input
        console.log("second")
        var new_row = document.getElementById("row_main")
        new_row.innerHTML = "";
        var arrayLength = stuff.length;
        for (var i = 0; i < arrayLength; i++) {
            addcontent(stuff[i]);
            //Do something
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
165
        }
Joe TS Dell's avatar
update    
Joe TS Dell committed
166
167
168
169
170
171
        container.find('.search-input').val('');
    } else {
        console.log("search")
        search();
        // addcontent();
    }
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
172
}
Joe TS Dell's avatar
update    
Joe TS Dell committed
173
174

function searchToggle_paper(obj, evt) {
Patrick's avatar
Patrick committed
175
176
    console.log("arrive")
    var container = $(obj).closest('.search-wrapper');
Joe TS Dell's avatar
update    
Joe TS Dell committed
177
178
179
180
    if (!container.hasClass('active')) {
        container.addClass('active');
        evt.preventDefault();
        console.log("first")
Patrick's avatar
Patrick committed
181
        
Joe TS Dell's avatar
update    
Joe TS Dell committed
182
183
184
185
186
187
188
189
    } else if (container.hasClass('active') && $(obj).closest('.input-holder').length == 0) {
        container.removeClass('active');
        // clear input
        console.log("second")
        var new_row = document.getElementById("cont_paper")
        new_row.innerHTML = "";
        var arrayLength = stuff_paper.length;
        for (var i = 0; i < arrayLength; i++) {
Patrick's avatar
Patrick committed
190
191
            document.getElementById("nextblock").style.display = "block";
            if (i <= max_paper_list) {
Joe TS Dell's avatar
update    
Joe TS Dell committed
192
                addpaper(stuff_paper[i]);
Patrick's avatar
Patrick committed
193
            }
Joe TS Dell's avatar
update    
Joe TS Dell committed
194
195

            //Do something
Patrick's avatar
Patrick committed
196
        }
Patrick's avatar
Patrick committed
197
198
199
200
201
        for (var j = 0; j < 6; j++) {
            addpaper(jsonContent[j]);
            //Do something
        }
        document.getElementById("nextblock").style.display = "block";
Joe TS Dell's avatar
update    
Joe TS Dell committed
202
203
204
205
206
207
        container.find('#search-input_paper').val('');
    } else {
        console.log("search")
        search_paper();
        // addcontent();
    }
Patrick's avatar
Patrick committed
208
}
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
209
210
211

// search on enter
var input = document.getElementById("search-input");
Joe TS Dell's avatar
update    
Joe TS Dell committed
212
213
214
input.addEventListener("keyup", function (event) {
    if (event.keyCode === 13) {
        event.preventDefault();
JOE Thunyathep S's avatar
up  
JOE Thunyathep S committed
215

Joe TS Dell's avatar
update    
Joe TS Dell committed
216
217
        document.getElementById("search-button").click();
    }
Patrick's avatar
Patrick committed
218
219
});

Patrick's avatar
Patrick committed
220
221
var input2 = document.getElementById("search-input_paper");
input2.addEventListener("keyup", function (event) {
Joe TS Dell's avatar
update    
Joe TS Dell committed
222
223
    if (event.keyCode === 13) {
        event.preventDefault();
Patrick's avatar
Patrick committed
224

Joe TS Dell's avatar
update    
Joe TS Dell committed
225
226
227
        document.getElementById("search-button_paper").click();
    }
});