@qubit-ltd/json 1.2.1 → 1.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/dist/json.cjs +188 -20
  2. package/dist/json.cjs.map +1 -1
  3. package/dist/json.min.cjs +1 -1
  4. package/dist/json.min.cjs.map +1 -1
  5. package/dist/json.min.mjs +1 -1
  6. package/dist/json.min.mjs.map +1 -1
  7. package/dist/json.mjs +188 -20
  8. package/dist/json.mjs.map +1 -1
  9. package/doc/api/Json.html +42 -0
  10. package/doc/api/LosslessNumber.html +3 -610
  11. package/doc/api/data/search.json +1 -0
  12. package/doc/api/fonts/Inconsolata-Regular.ttf +0 -0
  13. package/doc/api/fonts/OpenSans-Regular.ttf +0 -0
  14. package/doc/api/fonts/WorkSans-Bold.ttf +0 -0
  15. package/doc/api/global.html +3 -1274
  16. package/doc/api/index.html +63 -264
  17. package/doc/api/scripts/core.js +719 -0
  18. package/doc/api/scripts/core.min.js +23 -0
  19. package/doc/api/scripts/resize.js +90 -0
  20. package/doc/api/scripts/search.js +267 -0
  21. package/doc/api/scripts/search.min.js +6 -0
  22. package/doc/api/scripts/third-party/fuse.js +1749 -0
  23. package/doc/api/scripts/third-party/hljs-line-num-original.js +367 -0
  24. package/doc/api/scripts/third-party/hljs-line-num.js +1 -0
  25. package/doc/api/scripts/third-party/hljs-original.js +5260 -0
  26. package/doc/api/scripts/third-party/hljs.js +1 -0
  27. package/doc/api/scripts/third-party/popper.js +1287 -0
  28. package/doc/api/scripts/third-party/tippy.js +1499 -0
  29. package/doc/api/scripts/third-party/tocbot.js +757 -0
  30. package/doc/api/scripts/third-party/tocbot.min.js +1 -0
  31. package/doc/api/styles/clean-jsdoc-theme-base.css +1257 -0
  32. package/doc/api/styles/clean-jsdoc-theme-dark.css +412 -0
  33. package/doc/api/styles/clean-jsdoc-theme-light.css +482 -0
  34. package/doc/api/styles/clean-jsdoc-theme-scrollbar.css +30 -0
  35. package/doc/api/styles/clean-jsdoc-theme-without-scrollbar.min.css +1 -0
  36. package/doc/api/styles/clean-jsdoc-theme.min.css +1 -0
  37. package/doc/json.min.visualization.html +15 -15
  38. package/doc/json.visualization.html +15 -15
  39. package/package.json +20 -19
  40. package/doc/api/fonts/OpenSans-Bold-webfont.eot +0 -0
  41. package/doc/api/fonts/OpenSans-Bold-webfont.svg +0 -1838
  42. package/doc/api/fonts/OpenSans-Bold-webfont.woff +0 -0
  43. package/doc/api/fonts/OpenSans-BoldItalic-webfont.eot +0 -0
  44. package/doc/api/fonts/OpenSans-BoldItalic-webfont.svg +0 -1838
  45. package/doc/api/fonts/OpenSans-BoldItalic-webfont.woff +0 -0
  46. package/doc/api/fonts/OpenSans-Italic-webfont.eot +0 -0
  47. package/doc/api/fonts/OpenSans-Italic-webfont.svg +0 -1838
  48. package/doc/api/fonts/OpenSans-Italic-webfont.woff +0 -0
  49. package/doc/api/fonts/OpenSans-Light-webfont.eot +0 -0
  50. package/doc/api/fonts/OpenSans-Light-webfont.svg +0 -1839
  51. package/doc/api/fonts/OpenSans-Light-webfont.woff +0 -0
  52. package/doc/api/fonts/OpenSans-LightItalic-webfont.eot +0 -0
  53. package/doc/api/fonts/OpenSans-LightItalic-webfont.svg +0 -1843
  54. package/doc/api/fonts/OpenSans-LightItalic-webfont.woff +0 -0
  55. package/doc/api/fonts/OpenSans-Regular-webfont.eot +0 -0
  56. package/doc/api/fonts/OpenSans-Regular-webfont.svg +0 -1839
  57. package/doc/api/fonts/OpenSans-Regular-webfont.woff +0 -0
  58. package/doc/api/fonts/OpenSans-Semibold-webfont.eot +0 -0
  59. package/doc/api/fonts/OpenSans-Semibold-webfont.svg +0 -1838
  60. package/doc/api/fonts/OpenSans-Semibold-webfont.ttf +0 -0
  61. package/doc/api/fonts/OpenSans-Semibold-webfont.woff +0 -0
  62. package/doc/api/fonts/OpenSans-SemiboldItalic-webfont.eot +0 -0
  63. package/doc/api/fonts/OpenSans-SemiboldItalic-webfont.svg +0 -1838
  64. package/doc/api/fonts/OpenSans-SemiboldItalic-webfont.ttf +0 -0
  65. package/doc/api/fonts/OpenSans-SemiboldItalic-webfont.woff +0 -0
  66. package/doc/api/scripts/linenumber.js +0 -34
  67. package/doc/api/scripts/prettify/lang-css.js +0 -2
  68. package/doc/api/scripts/prettify/prettify.js +0 -28
  69. package/doc/api/styles/jsdoc-default.css +0 -699
  70. package/doc/api/styles/prettify-jsdoc.css +0 -120
  71. package/doc/api/styles/prettify-tomorrow.css +0 -141
  72. /package/doc/api/scripts/{prettify → third-party}/Apache-License-2.0.txt +0 -0
@@ -0,0 +1,719 @@
1
+ /* global document */
2
+ var accordionLocalStorageKey = "accordion-id";
3
+ var themeLocalStorageKey = "theme";
4
+ var fontSizeLocalStorageKey = "font-size";
5
+ var html = document.querySelector("html");
6
+
7
+ var MAX_FONT_SIZE = 30;
8
+ var MIN_FONT_SIZE = 10;
9
+
10
+ // eslint-disable-next-line no-undef
11
+ var localStorage = window.localStorage;
12
+
13
+ function getTheme() {
14
+ var theme = localStorage.getItem(themeLocalStorageKey);
15
+
16
+ if (theme) return theme;
17
+
18
+ theme = document.body.getAttribute("data-theme");
19
+
20
+ switch (theme) {
21
+ case "dark":
22
+ case "light":
23
+ return theme;
24
+ case "fallback-dark":
25
+ if (
26
+ // eslint-disable-next-line no-undef
27
+ window.matchMedia("(prefers-color-scheme)").matches &&
28
+ // eslint-disable-next-line no-undef
29
+ window.matchMedia("(prefers-color-scheme: light)").matches
30
+ ) {
31
+ return "light";
32
+ }
33
+
34
+ return "dark";
35
+
36
+ case "fallback-light":
37
+ if (
38
+ // eslint-disable-next-line no-undef
39
+ window.matchMedia("(prefers-color-scheme)").matches &&
40
+ // eslint-disable-next-line no-undef
41
+ window.matchMedia("(prefers-color-scheme: dark)").matches
42
+ ) {
43
+ return "dark";
44
+ }
45
+
46
+ return "light";
47
+
48
+ default:
49
+ return "dark";
50
+ }
51
+ }
52
+
53
+ function localUpdateTheme(theme) {
54
+ var body = document.body;
55
+ var svgUse = document.querySelectorAll(".theme-svg-use");
56
+ var iconID = theme === "dark" ? "#light-theme-icon" : "#dark-theme-icon";
57
+
58
+ body.setAttribute("data-theme", theme);
59
+ body.classList.remove("dark", "light");
60
+ body.classList.add(theme);
61
+
62
+ svgUse.forEach(function (svg) {
63
+ svg.setAttribute("xlink:href", iconID);
64
+ });
65
+ }
66
+
67
+ function updateTheme(theme) {
68
+ localUpdateTheme(theme);
69
+ localStorage.setItem(themeLocalStorageKey, theme);
70
+ }
71
+
72
+ function toggleTheme() {
73
+ var body = document.body;
74
+ var theme = body.getAttribute("data-theme");
75
+
76
+ var newTheme = theme === "dark" ? "light" : "dark";
77
+
78
+ updateTheme(newTheme);
79
+ }
80
+
81
+ (function () {
82
+ var theme = getTheme();
83
+
84
+ updateTheme(theme);
85
+ })();
86
+
87
+ /**
88
+ * Function to set accordion id to localStorage.
89
+ * @param {string} id Accordion id
90
+ */
91
+ function setAccordionIdToLocalStorage(id) {
92
+ /**
93
+ * @type {object}
94
+ */
95
+ var ids = JSON.parse(localStorage.getItem(accordionLocalStorageKey));
96
+
97
+ ids[id] = id;
98
+ localStorage.setItem(accordionLocalStorageKey, JSON.stringify(ids));
99
+ }
100
+
101
+ /**
102
+ * Function to remove accordion id from localStorage.
103
+ * @param {string} id Accordion id
104
+ */
105
+ function removeAccordionIdFromLocalStorage(id) {
106
+ /**
107
+ * @type {object}
108
+ */
109
+ var ids = JSON.parse(localStorage.getItem(accordionLocalStorageKey));
110
+
111
+ delete ids[id];
112
+ localStorage.setItem(accordionLocalStorageKey, JSON.stringify(ids));
113
+ }
114
+
115
+ /**
116
+ * Function to get all accordion ids from localStorage.
117
+ *
118
+ * @returns {object}
119
+ */
120
+ function getAccordionIdsFromLocalStorage() {
121
+ /**
122
+ * @type {object}
123
+ */
124
+ var ids = JSON.parse(localStorage.getItem(accordionLocalStorageKey));
125
+
126
+ return ids || {};
127
+ }
128
+
129
+ function toggleAccordion(element) {
130
+ var currentNode = element;
131
+ var isCollapsed = currentNode.getAttribute("data-isopen") === "false";
132
+
133
+ if (isCollapsed) {
134
+ currentNode.setAttribute("data-isopen", "true");
135
+ setAccordionIdToLocalStorage(currentNode.id);
136
+ } else {
137
+ currentNode.setAttribute("data-isopen", "false");
138
+ removeAccordionIdFromLocalStorage(currentNode.id);
139
+ }
140
+ }
141
+
142
+ function initAccordion() {
143
+ if (
144
+ localStorage.getItem(accordionLocalStorageKey) === undefined ||
145
+ localStorage.getItem(accordionLocalStorageKey) === null
146
+ ) {
147
+ localStorage.setItem(accordionLocalStorageKey, "{}");
148
+ }
149
+ var allAccordion = document.querySelectorAll(".sidebar-section-title");
150
+ var ids = getAccordionIdsFromLocalStorage();
151
+
152
+ allAccordion.forEach(function (item) {
153
+ item.addEventListener("click", function () {
154
+ toggleAccordion(item);
155
+ });
156
+ if (item.id in ids) {
157
+ toggleAccordion(item);
158
+ }
159
+ });
160
+ }
161
+
162
+ function isSourcePage() {
163
+ return Boolean(document.querySelector("#source-page"));
164
+ }
165
+
166
+ function bringElementIntoView(element, updateHistory = true) {
167
+ // If element is null then we are not going further
168
+ if (!element) {
169
+ return;
170
+ }
171
+
172
+ /**
173
+ * tocbotInstance is defined in layout.tmpl
174
+ * It is defined when we are initializing tocbot.
175
+ *
176
+ */
177
+ // eslint-disable-next-line no-undef
178
+ if (tocbotInstance) {
179
+ setTimeout(
180
+ // eslint-disable-next-line no-undef
181
+ () => tocbotInstance.updateTocListActiveElement(element),
182
+ 60
183
+ );
184
+ }
185
+ var navbar = document.querySelector(".navbar-container");
186
+ var body = document.querySelector(".main-content");
187
+ var elementTop = element.getBoundingClientRect().top;
188
+
189
+ var offset = 16;
190
+
191
+ if (navbar) {
192
+ offset += navbar.scrollHeight;
193
+ }
194
+
195
+ if (body) {
196
+ body.scrollBy(0, elementTop - offset);
197
+ }
198
+
199
+ if (updateHistory) {
200
+ // eslint-disable-next-line no-undef
201
+ history.pushState(null, null, "#" + element.id);
202
+ }
203
+ }
204
+
205
+ // eslint-disable-next-line no-unused-vars
206
+ function bringLinkToView(event) {
207
+ event.preventDefault();
208
+ event.stopPropagation();
209
+ var id = event.currentTarget.getAttribute("href");
210
+
211
+ if (!id) {
212
+ return;
213
+ }
214
+
215
+ var element = document.getElementById(id.slice(1));
216
+
217
+ if (element) {
218
+ bringElementIntoView(element);
219
+ }
220
+ }
221
+
222
+ function bringIdToViewOnMount() {
223
+ if (isSourcePage()) {
224
+ return;
225
+ }
226
+
227
+ // eslint-disable-next-line no-undef
228
+ var id = window.location.hash;
229
+
230
+ if (id === "") {
231
+ return;
232
+ }
233
+
234
+ var element = document.getElementById(id.slice(1));
235
+
236
+ if (!element) {
237
+ id = decodeURI(id);
238
+ element = document.getElementById(id.slice(1));
239
+ }
240
+
241
+ if (element) {
242
+ bringElementIntoView(element, false);
243
+ }
244
+ }
245
+
246
+ function createAnchorElement(id) {
247
+ var anchor = document.createElement("a");
248
+
249
+ anchor.textContent = "#";
250
+ anchor.href = "#" + id;
251
+ anchor.classList.add("link-anchor");
252
+ anchor.onclick = bringLinkToView;
253
+
254
+ return anchor;
255
+ }
256
+
257
+ function addAnchor() {
258
+ var main = document.querySelector(".main-content").querySelector("section");
259
+
260
+ var h1 = main.querySelectorAll("h1");
261
+ var h2 = main.querySelectorAll("h2");
262
+ var h3 = main.querySelectorAll("h3");
263
+ var h4 = main.querySelectorAll("h4");
264
+
265
+ var targets = [h1, h2, h3, h4];
266
+
267
+ targets.forEach(function (target) {
268
+ target.forEach(function (heading) {
269
+ var anchor = createAnchorElement(heading.id);
270
+
271
+ heading.classList.add("has-anchor");
272
+ heading.append(anchor);
273
+ });
274
+ });
275
+ }
276
+
277
+ /**
278
+ *
279
+ * @param {string} value
280
+ */
281
+ function copy(value) {
282
+ const el = document.createElement("textarea");
283
+
284
+ el.value = value;
285
+ document.body.appendChild(el);
286
+ el.select();
287
+ document.execCommand("copy");
288
+ document.body.removeChild(el);
289
+ }
290
+
291
+ function showTooltip(id) {
292
+ var tooltip = document.getElementById(id);
293
+
294
+ tooltip.classList.add("show-tooltip");
295
+ setTimeout(function () {
296
+ tooltip.classList.remove("show-tooltip");
297
+ }, 3000);
298
+ }
299
+
300
+ /* eslint-disable-next-line */
301
+ function copyFunction(id) {
302
+ // selecting the pre element
303
+ var code = document.getElementById(id);
304
+
305
+ // selecting the ol.linenums
306
+ var element = code.querySelector(".linenums");
307
+
308
+ if (!element) {
309
+ // selecting the code block
310
+ element = code.querySelector("code");
311
+ }
312
+
313
+ // copy
314
+ copy(element.innerText.trim().replace(/(^\t)/gm, ""));
315
+
316
+ // show tooltip
317
+ showTooltip("tooltip-" + id);
318
+ }
319
+
320
+ function hideTocOnSourcePage() {
321
+ if (isSourcePage()) {
322
+ document.querySelector(".toc-container").style.display = "none";
323
+ }
324
+ }
325
+
326
+ function getPreTopBar(id, lang = "") {
327
+ // tooltip
328
+ var tooltip = '<div class="tooltip" id="tooltip-' + id + '">Copied!</div>';
329
+
330
+ // template of copy to clipboard icon container
331
+ var copyToClipboard =
332
+ '<button aria-label="copy code" class="icon-button copy-code" onclick="copyFunction(\'' +
333
+ id +
334
+ '\')"><svg class="sm-icon" alt="click to copy"><use xlink:href="#copy-icon"></use></svg>' +
335
+ tooltip +
336
+ "</button>";
337
+
338
+ var langNameDiv =
339
+ '<div class="code-lang-name-container"><div class="code-lang-name">' +
340
+ lang.toLocaleUpperCase() +
341
+ "</div></div>";
342
+
343
+ var topBar =
344
+ '<div class="pre-top-bar-container">' +
345
+ langNameDiv +
346
+ copyToClipboard +
347
+ "</div>";
348
+
349
+ return topBar;
350
+ }
351
+
352
+ function getPreDiv() {
353
+ var divElement = document.createElement("div");
354
+
355
+ divElement.classList.add("pre-div");
356
+
357
+ return divElement;
358
+ }
359
+
360
+ function processAllPre() {
361
+ var targets = document.querySelectorAll("pre");
362
+ var footer = document.querySelector("#PeOAagUepe");
363
+ var navbar = document.querySelector("#VuAckcnZhf");
364
+
365
+ var navbarHeight = 0;
366
+ var footerHeight = 0;
367
+
368
+ if (footer) {
369
+ footerHeight = footer.getBoundingClientRect().height;
370
+ }
371
+
372
+ if (navbar) {
373
+ navbarHeight = navbar.getBoundingClientRect().height;
374
+ }
375
+
376
+ // eslint-disable-next-line no-undef
377
+ var preMaxHeight = window.innerHeight - navbarHeight - footerHeight - 250;
378
+
379
+ targets.forEach(function (pre, idx) {
380
+ var parent = pre.parentNode;
381
+
382
+ if (parent && parent.getAttribute("data-skip-pre-process") === "true") {
383
+ return;
384
+ }
385
+
386
+ var div = getPreDiv();
387
+ var id = "ScDloZOMdL" + idx;
388
+
389
+ var lang = pre.getAttribute("data-lang") || "code";
390
+ var topBar = getPreTopBar(id, lang);
391
+
392
+ div.innerHTML = topBar;
393
+
394
+ pre.style.maxHeight = preMaxHeight + "px";
395
+ pre.id = id;
396
+ pre.classList.add("prettyprint");
397
+ pre.parentNode.insertBefore(div, pre);
398
+ div.appendChild(pre);
399
+ });
400
+ }
401
+
402
+ function highlightAndBringLineIntoView() {
403
+ // eslint-disable-next-line no-undef
404
+ var lineNumber = window.location.hash.replace("#line", "");
405
+
406
+ try {
407
+ var selector = '[data-line-number="' + lineNumber + '"';
408
+
409
+ var element = document.querySelector(selector);
410
+
411
+ element.scrollIntoView();
412
+ element.parentNode.classList.add("selected");
413
+ } catch (error) {
414
+ console.error(error);
415
+ }
416
+ }
417
+
418
+ function getFontSize() {
419
+ var currentFontSize = 16;
420
+
421
+ try {
422
+ currentFontSize = Number.parseInt(html.style.fontSize.split("px")[0], 10);
423
+ } catch (error) {
424
+ console.log(error);
425
+ }
426
+
427
+ return currentFontSize;
428
+ }
429
+
430
+ function localUpdateFontSize(fontSize) {
431
+ html.style.fontSize = fontSize + "px";
432
+
433
+ var fontSizeText = document.querySelector(
434
+ "#b77a68a492f343baabea06fad81f651e"
435
+ );
436
+
437
+ if (fontSizeText) {
438
+ fontSizeText.innerHTML = fontSize;
439
+ }
440
+ }
441
+
442
+ function updateFontSize(fontSize) {
443
+ localUpdateFontSize(fontSize);
444
+ localStorage.setItem(fontSizeLocalStorageKey, fontSize);
445
+ }
446
+
447
+ (function () {
448
+ var fontSize = getFontSize();
449
+ var fontSizeInLocalStorage = localStorage.getItem(fontSizeLocalStorageKey);
450
+
451
+ if (fontSizeInLocalStorage) {
452
+ var n = Number.parseInt(fontSizeInLocalStorage, 10);
453
+
454
+ if (n === fontSize) {
455
+ return;
456
+ }
457
+ updateFontSize(n);
458
+ } else {
459
+ updateFontSize(fontSize);
460
+ }
461
+ })();
462
+
463
+ // eslint-disable-next-line no-unused-vars
464
+ function incrementFont(event) {
465
+ var n = getFontSize();
466
+
467
+ if (n < MAX_FONT_SIZE) {
468
+ updateFontSize(n + 1);
469
+ }
470
+ }
471
+
472
+ // eslint-disable-next-line no-unused-vars
473
+ function decrementFont(event) {
474
+ var n = getFontSize();
475
+
476
+ if (n > MIN_FONT_SIZE) {
477
+ updateFontSize(n - 1);
478
+ }
479
+ }
480
+
481
+ function fontSizeTooltip() {
482
+ var fontSize = getFontSize();
483
+
484
+ return `
485
+ <div class="font-size-tooltip">
486
+ <button aria-label="decrease-font-size" class="icon-button ${
487
+ fontSize >= MAX_FONT_SIZE ? "disabled" : ""
488
+ }" onclick="decrementFont(event)">
489
+ <svg>
490
+ <use xlink:href="#minus-icon"></use>
491
+ </svg>
492
+ </button>
493
+ <div class="font-size-text" id="b77a68a492f343baabea06fad81f651e">
494
+ ${fontSize}
495
+ </div>
496
+ <button aria-label="increase-font-size" class="icon-button ${
497
+ fontSize <= MIN_FONT_SIZE ? "disabled" : ""
498
+ }" onclick="incrementFont(event)">
499
+ <svg>
500
+ <use xlink:href="#add-icon"></use>
501
+ </svg>
502
+ </button>
503
+ <button class="icon-button" onclick="updateFontSize(16)">
504
+ <svg>
505
+ <use xlink:href="#reset-icon"></use>
506
+ </svg>
507
+ </button>
508
+ </div>
509
+
510
+ `;
511
+ }
512
+
513
+ function initTooltip() {
514
+ // add tooltip to navbar item
515
+ // Tooltips are now initialized via i18n-tooltips.tmpl template
516
+
517
+ // eslint-disable-next-line no-undef
518
+ tippy(".codepen-button", {
519
+ content: "Open code in CodePen",
520
+ placement: "left",
521
+ });
522
+
523
+ // eslint-disable-next-line no-undef
524
+ tippy(".copy-code", {
525
+ content: "Copy this code",
526
+ placement: "left",
527
+ });
528
+
529
+ // eslint-disable-next-line no-undef
530
+ tippy(".font-size", {
531
+ content: fontSizeTooltip(),
532
+ trigger: "click",
533
+ interactive: true,
534
+ allowHTML: true,
535
+ placement: "left",
536
+ });
537
+ }
538
+
539
+ function fixTable() {
540
+ const tables = document.querySelectorAll("table");
541
+
542
+ for (const table of tables) {
543
+ if (table.classList.contains("hljs-ln")) {
544
+ // don't want to wrap code blocks.
545
+ return;
546
+ }
547
+
548
+ var div = document.createElement("div");
549
+
550
+ div.classList.add("table-div");
551
+ table.parentNode.insertBefore(div, table);
552
+ div.appendChild(table);
553
+ }
554
+ }
555
+
556
+ function hideMobileMenu() {
557
+ var mobileMenuContainer = document.querySelector("#mobile-sidebar");
558
+ var target = document.querySelector("#mobile-menu");
559
+ var svgUse = target.querySelector("use");
560
+
561
+ if (mobileMenuContainer) {
562
+ mobileMenuContainer.classList.remove("show");
563
+ }
564
+ if (target) {
565
+ target.setAttribute("data-isopen", "false");
566
+ }
567
+ if (svgUse) {
568
+ svgUse.setAttribute("xlink:href", "#menu-icon");
569
+ }
570
+ }
571
+
572
+ function showMobileMenu() {
573
+ var mobileMenuContainer = document.querySelector("#mobile-sidebar");
574
+ var target = document.querySelector("#mobile-menu");
575
+ var svgUse = target.querySelector("use");
576
+
577
+ if (mobileMenuContainer) {
578
+ mobileMenuContainer.classList.add("show");
579
+ }
580
+ if (target) {
581
+ target.setAttribute("data-isopen", "true");
582
+ }
583
+ if (svgUse) {
584
+ svgUse.setAttribute("xlink:href", "#close-icon");
585
+ }
586
+ }
587
+
588
+ function onMobileMenuClick() {
589
+ var target = document.querySelector("#mobile-menu");
590
+ var isOpen = target.getAttribute("data-isopen") === "true";
591
+
592
+ if (isOpen) {
593
+ hideMobileMenu();
594
+ } else {
595
+ showMobileMenu();
596
+ }
597
+ }
598
+
599
+ function initMobileMenu() {
600
+ var menu = document.querySelector("#mobile-menu");
601
+
602
+ if (menu) {
603
+ menu.addEventListener("click", onMobileMenuClick);
604
+ }
605
+ }
606
+
607
+ function addHrefToSidebarTitle() {
608
+ var titles = document.querySelectorAll(".sidebar-title-anchor");
609
+
610
+ titles.forEach(function (title) {
611
+ // eslint-disable-next-line no-undef
612
+ title.setAttribute("href", baseURL);
613
+ });
614
+ }
615
+
616
+ function highlightActiveLinkInSidebar() {
617
+ const list = document.location.href.split("/");
618
+ const targetURL = decodeURI(list[list.length - 1]);
619
+ let element = document.querySelector(`.sidebar a[href*='${targetURL}']`);
620
+
621
+ if (!element) {
622
+ try {
623
+ element = document.querySelector(
624
+ `.sidebar a[href*='${targetURL.split("#")[0]}']`
625
+ );
626
+ } catch (e) {
627
+ console.error(e);
628
+ return;
629
+ }
630
+ }
631
+
632
+ if (!element) return;
633
+
634
+ element.parentElement.classList.add("active");
635
+ element.scrollIntoView();
636
+ }
637
+
638
+ function goToHomepage() {
639
+ // Navigate to the base URL (homepage)
640
+ // eslint-disable-next-line no-undef
641
+ window.location.href = baseURL + "index.html";
642
+ }
643
+
644
+ function onDomContentLoaded() {
645
+ var themeButton = document.querySelectorAll(".theme-toggle");
646
+ var homeButton = document.querySelectorAll(".home-button");
647
+
648
+ initMobileMenu();
649
+
650
+ if (themeButton) {
651
+ themeButton.forEach(function (button) {
652
+ button.addEventListener("click", toggleTheme);
653
+ });
654
+ }
655
+
656
+ if (homeButton) {
657
+ homeButton.forEach(function (button) {
658
+ button.addEventListener("click", goToHomepage);
659
+ });
660
+ }
661
+
662
+ // Highlighting code
663
+
664
+ // eslint-disable-next-line no-undef
665
+ hljs.addPlugin({
666
+ "after:highlightElement": function (obj) {
667
+ // Replace 'code' with result.language when
668
+ // we are able to cross-check the correctness of
669
+ // result.
670
+ obj.el.parentNode.setAttribute("data-lang", "code");
671
+ },
672
+ });
673
+ // eslint-disable-next-line no-undef
674
+ hljs.highlightAll();
675
+ // eslint-disable-next-line no-undef
676
+ hljs.initLineNumbersOnLoad({
677
+ singleLine: true,
678
+ });
679
+
680
+ // Highlight complete
681
+
682
+ initAccordion();
683
+ addAnchor();
684
+ processAllPre();
685
+ hideTocOnSourcePage();
686
+ setTimeout(function () {
687
+ bringIdToViewOnMount();
688
+ if (isSourcePage()) {
689
+ highlightAndBringLineIntoView();
690
+ }
691
+ }, 1000);
692
+ initTooltip();
693
+ fixTable();
694
+ addHrefToSidebarTitle();
695
+ highlightActiveLinkInSidebar();
696
+ }
697
+
698
+ // eslint-disable-next-line no-undef
699
+ window.addEventListener("DOMContentLoaded", onDomContentLoaded);
700
+
701
+ // eslint-disable-next-line no-undef
702
+ window.addEventListener("hashchange", (event) => {
703
+ const url = new URL(event.newURL);
704
+
705
+ if (url.hash !== "") {
706
+ bringIdToViewOnMount(url.hash);
707
+ }
708
+ });
709
+
710
+ // eslint-disable-next-line no-undef
711
+ window.addEventListener("storage", (event) => {
712
+ if (event.newValue === "undefined") return;
713
+
714
+ initTooltip();
715
+
716
+ if (event.key === themeLocalStorageKey) localUpdateTheme(event.newValue);
717
+ if (event.key === fontSizeLocalStorageKey)
718
+ localUpdateFontSize(event.newValue);
719
+ });