summaryrefslogtreecommitdiff
path: root/server/app/static/js/util.js
diff options
context:
space:
mode:
authoradamhrv <adam@ahprojects.com>2018-12-15 19:57:49 +0100
committeradamhrv <adam@ahprojects.com>2018-12-15 19:57:49 +0100
commit82b2c0b5d6d7baccbe4d574d96e18fe2078047d7 (patch)
treea8784b7ec2bc5a0451c252f66a6b786f3a2504f5 /server/app/static/js/util.js
parent8e978af21c2b29f678a09701afb3ec7d65d0a6ab (diff)
parentc5b02ffab8d388e8a2925e51736b902a48a95e71 (diff)
Merge branch 'master' of github.com:adamhrv/megapixels_dev
Diffstat (limited to 'server/app/static/js/util.js')
-rw-r--r--server/app/static/js/util.js32
1 files changed, 32 insertions, 0 deletions
diff --git a/server/app/static/js/util.js b/server/app/static/js/util.js
new file mode 100644
index 00000000..851f634a
--- /dev/null
+++ b/server/app/static/js/util.js
@@ -0,0 +1,32 @@
+var is_iphone = (navigator.userAgent.match(/iPhone/i)) || (navigator.userAgent.match(/iPod/i))
+var is_ipad = (navigator.userAgent.match(/iPad/i))
+var is_android = (navigator.userAgent.match(/Android/i))
+var is_mobile = is_iphone || is_ipad || is_android
+var is_desktop = ! is_mobile;
+
+document.body.parentNode.classList.add(is_desktop ? 'desktop' : 'mobile')
+
+function preventDefault(e){
+ e.preventDefault()
+ e.stopPropagation()
+}
+
+var decodeEntities = (function() {
+ // this prevents any overhead from creating the object each time
+ var element = document.createElement('div');
+
+ function decodeHTMLEntities (str) {
+ if(str && typeof str === 'string') {
+ // strip script/html tags
+ str = str.replace(/<script[^>]*>([\S\s]*?)<\/script>/gmi, '');
+ str = str.replace(/<\/?\w(?:[^"'>]|"[^"]*"|'[^']*')*>/gmi, '');
+ element.innerHTML = str;
+ str = element.textContent;
+ element.textContent = '';
+ }
+
+ return str;
+ }
+
+ return decodeHTMLEntities;
+})(); \ No newline at end of file