X-Git-Url: http://git.scottworley.com/voter/blobdiff_plain/3a49148b2736feb552620b329abd0729a9192bfb..2487fe70473abf0434311c78e99c1e1adeda9f48:/src/main.rs?ds=inline diff --git a/src/main.rs b/src/main.rs index 9f536ed..d15194f 100644 --- a/src/main.rs +++ b/src/main.rs @@ -130,6 +130,9 @@ const HTML_HEADER: &str = " cb.parentElement.removeChild(cb.previousElementSibling) if (req.status == 200) { cb.style.display = '' + const delta = cb.checked ? 1 : -1 + const count_td = cb.parentElement.previousElementSibling + count_td.textContent = parseInt(count_td.textContent) + delta } else { cb.parentElement.insertBefore(document.createTextNode('❗'), cb) } @@ -141,13 +144,37 @@ const HTML_HEADER: &str = " cb.disabled = false } } + function num_cmp(a, b) { + return parseInt(b.textContent) - parseInt(a.textContent) + } + function str_cmp(a, b) { + if (a.textContent < b.textContent) return -1 + if (a.textContent > b.textContent) return 1 + return 0 + } + function checked_cmp(a, b) { + vs = [a, b].map(x => { + const v = x.children[0].checked + 0 + return isNaN(v) ? -1 : v + }) + return vs[1] - vs[0] + } + function sort_table(col, cmp) { + const rows = Array.from(document.getElementsByTagName('tr')) + rows.shift() + rows.sort((a, b) => cmp(a.children[col], b.children[col])) + for (row of rows) { + row.parentElement.appendChild(row) + } + } - - + + + "; const HTML_FOOTER: &str = "
VoteCandidateCountVoteCandidate
@@ -177,6 +204,10 @@ fn prompt_for_vote(dir: PathBuf, request: cgi::Request) -> Result Result + {count} {c} "