-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdemo.js
More file actions
73 lines (63 loc) · 1.7 KB
/
demo.js
File metadata and controls
73 lines (63 loc) · 1.7 KB
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
import * as glasses_id from './main.js';
console.log(glasses_id);
function info(str) {
document.getElementById('info').innerText = str;
}
let inputs = Array.from(document.querySelectorAll('#layers input'));
let codeinput = document.querySelector('#code input');
let ignoreHashChange = false;
function encode() {
let inputs = Array.from( document.querySelectorAll('#layers input') );
let incomplete = inputs.some(i => isNaN(parseInt(i.value)) );
if (incomplete) {
info('layers incomplete');
return;
}
let arr = inputs.map( i => parseInt(i.value) );
let id = glasses_id.encode(arr);
if (id === false) {
info("Encode Error");
} else {
codeinput.value = id;
ignoreHashChange = true; // next line triggers onhashchange, set a flag so we can ignore it
location.hash = id;
info("Encode OK");
}
}
function decode() {
let layers = glasses_id.decode(codeinput.value);
if (layers === false) {
info("Decode Error");
} else {
for (let [i, input] of inputs.entries()) {
input.value = layers[i];
}
info('Decode OK');
}
}
for (let i of inputs) {
i.addEventListener('change', encode);
}
code.addEventListener('change', decode);
// Check for #fragment in url
function loadFromHash(e) {
if (ignoreHashChange) {
ignoreHashChange = false;
return;
}
let code = location.hash.slice(1);
if (code) {
let layers = glasses_id.decode(code);
if (layers === false) {
info("Decode (from URL) Error");
} else {
for (let [i, input] of inputs.entries()) {
input.value = layers[i];
}
codeinput.value = code;
info('Decode (from URL) OK');
}
}
}
document.addEventListener('DOMContentLoaded', loadFromHash);
window.addEventListener('hashchange', loadFromHash);