summaryrefslogtreecommitdiffhomepage
path: root/docs/docs.js
blob: 4c5a69b139aa24fa86ad3713e9f76e9c2538d8d0 (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
function all_paragraphs() {
  return Array.from(document.querySelectorAll("p"));
}

function all_pres() {
  return Array.from(document.querySelectorAll("pre"));
}

function all_lists() {
  return Array.from(document.querySelectorAll("li"));
}

function all_anchors() {
  return Array.from(document.querySelectorAll("a"));
}

function all_headers() {
  return Array.from([
    Array.from(document.querySelectorAll("h1")),
    Array.from(document.querySelectorAll("h2")),
    Array.from(document.querySelectorAll("h3"))
  ].flat());
}

function all_searchable_elements() {
  return Array.from([
    all_paragraphs(),
    all_pres(),
    all_lists(),
    all_headers(),
    all_anchors()
  ].flat());
}

function hide_element(element) {
  element.style.color = "rgb(0, 0, 0, 0.2)";
}

function show_element(element) {
  element.style.color = "";
}

function show_all_searchable_elements() {
  all_searchable_elements().forEach(show_element);
}

function does_element_has_word(element, word) {
  return element.innerText
                .toLowerCase()
                .includes(word.toLowerCase());
}

function perform_search(search_text) {
  search_text = search_text || "";
  show_all_searchable_elements();
  var result_count = 0;
  document.getElementById('search-count').innerHTML = " ";
  if (search_text.length < 3) return;

  var tokens = search_text.split(" ");

  all_searchable_elements().forEach(function (element) {
    tokens.forEach(function(word) {
      if (does_element_has_word(element, word)) {
        result_count += 1;
        show_element(element);
      } else {
        hide_element(element);
      }
    });
  });

  document.getElementById('search-count').innerHTML = result_count.toString() + " result(s) found.";
}

function add_search() {
  var search_html = `
    <div style='padding: 10px; border: solid 1px silver; background-color: white;'>
      <input placeholder='search' type='text' id='search-term' style='width: 100%; padding: 5px; margin-bottom: 3px;' />
      <div id='search-count'>&nbsp;</div>
    </div>
`;

  // create search div
  var search_div = document.createElement("div");
  search_div.innerHTML = search_html;
  document.body.insertBefore(search_div, document.body.firstChild);
  search_div.style.position = 'fixed';
  search_div.style.right = '10px';
  search_div.style.width = '200px';

  // wire up incremental search
  var search_textbox = document.getElementById("search-term");
  search_textbox.onkeydown = function() { perform_search(search_textbox.value); };
}

document.addEventListener('DOMContentLoaded', function() {
  add_search();
}, false);