Files
openlayers/examples/index.js
Maximilian Krög 687795ba24 Skip listing all examples if query param is set.
Also use the `input` event instead of `keyup` and addEventlistener instead
of setting the onload / onchange properties.
And handle space character encoded as `+` in query string correctly.
2020-07-17 21:52:34 +02:00

134 lines
3.4 KiB
JavaScript

(function () {
'use strict';
/* global info, jugl */
let template, target;
function listExamples(examples) {
target.innerHTML = '';
template.process({
context: {examples: examples},
clone: true,
parent: target,
});
document.getElementById('count').innerHTML = '(' + examples.length + ')';
}
let timerId;
function inputChange() {
if (timerId) {
window.clearTimeout(timerId);
}
const text = this.value;
timerId = window.setTimeout(function () {
filterList(text);
}, 500);
}
function getMatchingExamples(text) {
if (text.length < 2) {
return info.examples;
}
const words = text.split(/\W+/);
const scores = {};
for (let i = 0; i < words.length; ++i) {
const word = words[i].toLowerCase();
let dict = info.index[word];
const updateScores = function () {
// eslint-disable-next-line prefer-const
for (let exIndex in dict) {
const count = dict[exIndex];
if (scores[exIndex]) {
if (scores[exIndex][word]) {
scores[exIndex][word] += count;
} else {
scores[exIndex][word] = count;
}
} else {
scores[exIndex] = {};
scores[exIndex][word] = count;
}
}
};
if (dict) {
updateScores();
} else {
const r = new RegExp(word);
// eslint-disable-next-line prefer-const
for (let idx in info.index) {
if (r.test(idx)) {
dict = info.index[idx];
updateScores();
}
}
}
}
const examples = [];
// eslint-disable-next-line prefer-const
for (let j in scores) {
const ex = info.examples[j];
ex.score = scores[j];
examples.push(ex);
}
// sort examples by first by number of words matched, then
// by word frequency
examples.sort(function (a, b) {
let cmp;
let aWords = 0,
bWords = 0;
let aScore = 0,
bScore = 0;
// eslint-disable-next-line prefer-const
for (let i in a.score) {
aScore += a.score[i];
aWords += 1;
}
// eslint-disable-next-line prefer-const
for (let j in b.score) {
bScore += b.score[j];
bWords += 1;
}
if (aWords == bWords) {
cmp = bScore - aScore;
} else {
cmp = bWords - aWords;
}
return cmp;
});
return examples;
}
function filterList(text) {
const examples = getMatchingExamples(text);
listExamples(examples);
}
function parseParams() {
const params = {};
const list = window.location.search
.substring(1)
.replace(/\+/g, '%20')
.split('&');
for (let i = 0; i < list.length; ++i) {
const pair = list[i].split('=');
if (pair.length === 2) {
params[decodeURIComponent(pair[0])] = decodeURIComponent(pair[1]);
}
}
return params;
}
window.addEventListener('load', function () {
for (let i = 0; i < info.examples.length; ++i) {
info.examples[i].link += window.location.search;
}
template = new jugl.Template('template');
target = document.getElementById('examples');
const params = parseParams();
const text = params['q'] || '';
const input = document.getElementById('keywords');
input.addEventListener('input', inputChange);
input.value = text;
filterList(text);
});
})();