forked from educoin/notarypoc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBLKCC_Notary_View.js
114 lines (97 loc) · 3.99 KB
/
BLKCC_Notary_View.js
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
export default class BLKCC_Notary_View {
constructor(argObj = {}) {return this instanceof BLKCC_Notary_View
? this.init(argObj)
: new BLKCC_Notary_View(argObj)
}
init(argObj = {}) {
this.navTabs = {};
this.appViews = {};
Object.assign(this, argObj);
this.container = document.querySelector(this.querySelector);
for(let section of this.container.children) {this[section.tagName.toLowerCase()] = section;}
this.nav = this.nav.querySelector('nav');
this.initAppViews(this.form.children);
for(let navTab of this.nav.children) {
let navName = navTab.getAttribute('for');
this.navTabs[navName] = navTab;
navTab.addEventListener('click', ev => this.render(this.appViews[navName]));
}
for(let field of this.details.querySelectorAll('div')) {this[field.classList[0]] = field.lastChild;}
this.form.addEventListener('submit', ev => {
ev.preventDefault();
this.formSubmit(this.form.querySelector(':focus').parentNode.name);
});
this.appViews.regFile.input.addEventListener('change', this.fileInputChange);
this.appViews.regText.input.addEventListener('keyup', this.inputChange);
this.stats = this.form.querySelector('.statistics');
return this.render(this.appViews.regFile);
}
initAppViews(appViews) {for(let viewOffset = 0, f = appViews.length; viewOffset < f; viewOffset++) {
let view = appViews[viewOffset],
viewName = view.name;
this.appViews[viewName] = view;
view.offset = viewOffset;
view.setAttribute('disabled', 'true');
let inp = view.input = view.querySelector('input, textarea');
if(viewName.slice(0, 3) !== 'reg') {continue;}
inp.addEventListener('change', ev => notary[viewName](inp));
if(inp.preview = view.querySelector('input[placeholder=hash]')) {inp.preview.addEventListener('click', this.copyHash);}
}}
formSubmit(viewName) {
const reg = viewName.slice(0, 3) === 'reg',
inp = this.appViews[viewName].input;
console.log(viewName, this.appViews);
this.notary[reg ? 'submitHash' : viewName]((inp.preview || inp).value);
}
inputChange(ev) {notary[ev.target.name](ev.target);}
copyHash(ev) {
const tar = ev.target;
tar.select();
document.execCommand('copy');
tar.title = 'Copied to clipboard';
setTimeout(() => tar.title = '', 5000);
}
fileInputChange(ev) {
let tar = ev.target;
tar.previousElementSibling.textContent = tar.value.slice(tar.value.lastIndexOf('\\') + 1);
}
verHashUpd() {
if(this.notary.errorLocks.login) {return this.stats.innerHTML = 'Not logged into <a href="https://metamask.io/" target="_blank">Metamask</a>';}
this.notary.web3js.eth.getTransactionCount(this.notary.account, (err, res) => {
if(err) {throw err;}
this.stats.textContent = "";
// this.stats.textContent = `Total account transactions: ${res}`;
});
}
render(view) {
if('curr' in this) {this.showView(this.curr, false);}
this.showView(this.curr = view);
this.form.style.left = `-${view.offset}00%`;
if((view = `${view.name}Upd`) in this) {this[view]();}
return this;
}
showView(view, show = true) {
if(view.name in this.navTabs) {this.navTabs[view.name].classList[show ? 'add' : 'remove']('selected');}
view[`${show ? 'remove' : 'set'}Attribute`]('disabled', 'true');
}
showResult(res = 'Results') {
this.appViews.results.innerHTML = res;
return this.render(this.appViews.results);
}
error(err) {
const el = document.createElement('figure'),
btn = el.appendChild(document.createElement('button'));
el.appendChild(document.createElement('span'))
.innerHTML = err.lineno
? `<pre>${err.message}\n@ ${err.filename}:${err.lineno}:${err.colno}</pre>`
: err;
btn.innerText = 'dismiss';
btn.addEventListener('click', this.dismissErr);
return this.aside.appendChild(el);
}
dismissErr(ev) {
const tar = ev.target.parentNode;
tar.parentNode.removeChild(tar);
}
setInfo(prop, val) {return this[prop].innerHTML = val;}
};