datalist: set loading class and add (optional) loading gif (CSS) - jscancer - Javascript crap (relatively small)
(HTM) git clone git://git.codemadness.org/jscancer
(DIR) Log
(DIR) Files
(DIR) Refs
(DIR) README
(DIR) LICENSE
---
(DIR) commit aa6690aad0a7b64010561df965d589b8f1a59a75
(DIR) parent e0c81bf5b28e8e3ae06401063522752d7c4de854
(HTM) Author: Hiltjo Posthuma <hiltjo@codemadness.org>
Date: Mon, 25 Mar 2024 20:47:31 +0100
datalist: set loading class and add (optional) loading gif (CSS)
Diffstat:
M datalist/datalist.js | 7 +++++++
A datalist/loading.css | 8 ++++++++
2 files changed, 15 insertions(+), 0 deletions(-)
---
(DIR) diff --git a/datalist/datalist.js b/datalist/datalist.js
@@ -72,8 +72,15 @@ function datalist_init(input) {
}
timer = setTimeout(function() {
+ // set class for loading indicator styling.
+ input.classList.add("loading");
+
var x = new(XMLHttpRequest);
x.onreadystatechange = function() {
+ // remove loading indicator when "DONE".
+ if (x.readyState == 4)
+ input.classList.remove("loading");
+
if (x.readyState != 4 || [ 0, 200 ].indexOf(x.status) == -1)
return;
(DIR) diff --git a/datalist/loading.css b/datalist/loading.css
@@ -0,0 +1,7 @@
+/* loader gif animation */
+input.datalist.loading {
+ cursor: wait;
+ background-image: url("");
+ background-repeat: no-repeat;
+ background-position: center right;
+}
+\ No newline at end of file