From 20dd6ea03755c1a44134105b66792e261707166a Mon Sep 17 00:00:00 2001 From: Jonas Leder <jonas@jonasled.de> Date: Sun, 15 Mar 2020 11:53:11 +0100 Subject: [PATCH] rebuild cookieinfo (+darkmode, -size) --- static/cookie.js | 23 +++++ static/cookieinfo.js | 237 ------------------------------------------- static/style.css | 55 ++++++++++ templates/home.html | 24 +++-- 4 files changed, 96 insertions(+), 243 deletions(-) create mode 100644 static/cookie.js delete mode 100644 static/cookieinfo.js diff --git a/static/cookie.js b/static/cookie.js new file mode 100644 index 0000000..68a84f3 --- /dev/null +++ b/static/cookie.js @@ -0,0 +1,23 @@ +function acceptCookie(){ + document.cookie = "cookieMessageHide=1"; + checkHide(); +} + +function getCookie(name){ + var nameEQ = name + "="; + var ca = document.cookie.split(";"); + for (var i=0; i < ca.length; i++) { + var c = ca[i]; + while(c.charAt(0) == " ") c = c.substr(1, c.length); + if(c.indexOf(nameEQ) == 0) return c.substr(nameEQ.length, c.length) + } + return null +} + +function checkHide(){ + if (getCookie("cookieMessageHide") == "1"){ + $(".cookieinfo").hide(); + } else { + $(".cookieinfo").show(); + } + } \ No newline at end of file diff --git a/static/cookieinfo.js b/static/cookieinfo.js deleted file mode 100644 index bad9f1f..0000000 --- a/static/cookieinfo.js +++ /dev/null @@ -1,237 +0,0 @@ -! function(e) { - "use strict"; - var t = e, - i = t.document, - o = "cbinstance"; - var n = { - get: function(e) { - return decodeURIComponent(i.cookie.replace(new RegExp("(?:(?:^|.*;)\\s*" + encodeURIComponent(e).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=\\s*([^;]*).*$)|^.*$"), "$1")) || null - }, - set: function(e, t, o, n, s, r) { - if (!e || /^(?:expires|max\-age|path|domain|secure)$/i.test(e)) return !1; - var a = ""; - if (o) switch (o.constructor) { - case Number: - a = o === 1 / 0 ? "; expires=Fri, 31 Dec 9999 23:59:59 GMT" : "; max-age=" + o; - break; - case String: - a = "; expires=" + o; - break; - case Date: - a = "; expires=" + o.toUTCString() - } - return i.cookie = encodeURIComponent(e) + "=" + encodeURIComponent(t) + a + (s ? "; domain=" + s : "") + (n ? "; path=" + n : "") + (r ? "; secure" : ""), !0 - }, - has: function(e) { - return new RegExp("(?:^|;\\s*)" + encodeURIComponent(e).replace(/[\-\.\+\*]/g, "\\$&") + "\\s*\\=").test(i.cookie) - }, - remove: function(e, t, o) { - return !(!e || !this.has(e)) && (i.cookie = encodeURIComponent(e) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + (o ? "; domain=" + o : "") + (t ? "; path=" + t : ""), !0) - } - }, - s = { - merge: function() { - var e, t = {}, - i = 0, - o = arguments.length; - if (0 === o) return t; - for (; i < o; i++) - for (e in arguments[i]) Object.prototype.hasOwnProperty.call(arguments[i], e) && (t[e] = arguments[i][e]); - return t - }, - str2bool: function(e) { - switch ((e = "" + e).toLowerCase()) { - case "false": - case "no": - case "0": - case "": - return !1; - default: - return !0 - } - }, - fade_in: function(e) { - e.style.opacity < 1 && (e.style.opacity = (parseFloat(e.style.opacity) + .05).toFixed(2), t.setTimeout(function() { - s.fade_in(e) - }, 50)) - }, - get_data_attribs: function(e) { - var t = {}; - if (Object.prototype.hasOwnProperty.call(e, "dataset")) t = e.dataset; - else { - var i, o = e.attributes; - for (i in o) - if (Object.prototype.hasOwnProperty.call(o, i)) { - var n = o[i]; - if (/^data-/.test(n.name)) t[s.camelize(n.name.substr(5))] = n.value - } - } - return t - }, - normalize_keys: function(e) { - var t = {}; - for (var i in e) - if (Object.prototype.hasOwnProperty.call(e, i)) { - var o = s.camelize(i); - t[o] = e[o] ? e[o] : e[i] - } return t - }, - camelize: function(e) { - for (var t = "-", i = e.indexOf(t); - 1 != i;) { - var o = i === e.length - 1, - n = o ? "" : e[i + 1], - s = n.toUpperCase(), - r = o ? t : t + n; - i = (e = e.replace(r, s)).indexOf(t) - } - return e - }, - find_script_by_id: function(e) { - for (var t = i.getElementsByTagName("script"), o = 0, n = t.length; o < n; o++) - if (e === t[o].id) return t[o]; - return null - } - }, - r = s.find_script_by_id("cookieinfo"), - a = e.cookieinfo = function(e) { - this.init(e) - }; - a.prototype = { - cookiejar: n, - init: function(t) { - this.inserted = !1, this.closed = !1, this.test_mode = !1; - if (this.default_options = { - cookie: "we-love-cookies", - closeText: "✖", - cookiePath: "/", - debug: !1, - expires: 1 / 0, - zindex: 1e20, - mask: !1, - maskOpacity: .5, - maskBackground: "#999", - height: "auto", - minHeight: "21px", - bg: "#eee", - fg: "#333", - link: "#31A8F0", - divlink: "#000", - divlinkbg: "#F1D600", - position: "bottom", - message: "We use cookies to enhance your experience. By continuing to visit this site you agree to our use of cookies.", - linkmsg: "More info", - scriptmsg: "Cookie Info Script", - moreinfo: "http://wikipedia.org/wiki/HTTP_cookie", - scriptinfo: "https://cookieinfoscript.com", - tracking: "", - effect: null, - fontSize: "14px", - fontFamily: "verdana, arial, sans-serif", - instance: o, - textAlign: "center", - acceptOnScroll: !1 - }, this.options = this.default_options, this.script_el = r, this.script_el) { - var i = s.get_data_attribs(this.script_el); - this.options = s.merge(this.options, i) - } - t && (t = s.normalize_keys(t), this.options = s.merge(this.options, t)), o = this.options.instance, this.options.zindex = parseInt(this.options.zindex, 10), this.options.mask = s.str2bool(this.options.mask), "string" == typeof this.options.expires && "function" == typeof e[this.options.expires] && (this.options.expires = e[this.options.expires]), "function" == typeof this.options.expires && (this.options.expires = this.options.expires()), this.script_el && this.run() - }, - log: function() { - "undefined" != typeof console && console.log.apply(console, arguments) - }, - run: function() { - if (!this.agreed()) { - var e = this; - ! function(e, t) { - var i = !1, - o = !0, - n = e.document, - s = n.documentElement, - r = n.addEventListener ? "addEventListener" : "attachEvent", - a = n.addEventListener ? "removeEventListener" : "detachEvent", - c = n.addEventListener ? "" : "on", - l = function(o) { - "readystatechange" == o.type && "complete" != n.readyState || (("load" == o.type ? e : n)[a](c + o.type, l, !1), !i && (i = !0) && t.call(e, o.type || o)) - }, - p = function() { - try { - s.doScroll("left") - } catch (e) { - return void setTimeout(p, 50) - } - l("poll") - }; - if ("complete" == n.readyState) t.call(e, "lazy"); - else { - if (n.createEventObject && s.doScroll) { - try { - o = !e.frameElement - } catch (e) {} - o && p() - } - n[r](c + "DOMContentLoaded", l, !1), n[r](c + "readystatechange", l, !1), e[r](c + "load", l, !1) - } - }(t, function() { - e.insert() - }) - } - }, - build_viewport_mask: function() { - var e = null; - if (!0 === this.options.mask) { - var t = this.options.maskOpacity, - o = '<div id="cookieinfo-mask" style="position:fixed;top:0;left:0;width:100%;height:100%;background:' + this.options.maskBackground + ";zoom:1;filter:alpha(opacity=" + 100 * t + ");opacity:" + t + ";z-index:" + this.options.zindex + ';"></div>', - n = i.createElement("div"); - n.innerHTML = o, e = n.firstChild - } - return e - }, - agree: function() { - return this.cookiejar.set(this.options.cookie, 1, this.options.expires, this.options.cookiePath), !0 - }, - agreed: function() { - return this.cookiejar.has(this.options.cookie) - }, - close: function() { - return this.inserted && (this.closed || (this.element && this.element.parentNode.removeChild(this.element), this.element_mask && this.element_mask.parentNode.removeChild(this.element_mask), this.closed = !0)), this.closed - }, - agree_and_close: function() { - return this.agree(), this.close() - }, - cleanup: function() { - return this.close(), this.unload() - }, - unload: function() { - return this.script_el && this.script_el.parentNode.removeChild(this.script_el), e[o] = void 0, !0 - }, - insert: function() { - this.element_mask = this.build_viewport_mask(); - var e = this.options.zindex; - this.element_mask && (e += 1); - var t = i.createElement("div"); - t.className = "cookieinfo", t.style.position = "fixed", t.style.left = 0, t.style.right = 0, t.style.height = this.options.height, t.style.minHeight = this.options.minHeight, t.style.zIndex = e, t.style.background = this.options.bg, t.style.color = this.options.fg, t.style.lineHeight = t.style.minHeight, t.style.padding = "8px 18px", t.style.fontFamily = this.options.fontFamily, t.style.fontSize = this.options.fontSize, t.style.textAlign = this.options.textAlign, "top" === this.options.position ? t.style.top = 0 : t.style.bottom = 0, t.innerHTML = '<div class="cookieinfo-close" style="float:right;display:block;padding:5px 8px 5px 8px;min-width:100px;margin-left:5px;border-top-left-radius:5px;border-top-right-radius:5px;border-bottom-right-radius:5px;border-bottom-left-radius:5px;">' + this.options.closeText + '</div><span style="display:block;padding:5px 0 5px 0;">' + this.options.message + " <a>" + this.options.linkmsg + "</a><img> <a>" + this.options.scriptmsg + "</a></span>", this.element = t; - var o = t.getElementsByTagName("a")[0]; - o.href = this.options.moreinfo, o.style.textDecoration = "none", o.style.color = this.options.link; - var n = t.getElementsByTagName("a")[1]; - n.href = this.options.scriptinfo, n.style.textDecoration = "none", n.style.display = "none", n.style.color = this.options.link; - var r = t.getElementsByTagName("div")[0]; - r.style.cursor = "pointer", r.style.color = this.options.divlink, r.style.background = this.options.divlinkbg, r.style.textAlign = "center"; - var a = t.getElementsByTagName("img")[0]; - - function c(e, t, i) { - var o = e.addEventListener ? "addEventListener" : "attachEvent", - n = e.addEventListener ? "" : "on"; - e[o](n + t, i, !1) - } - a.src = this.options.tracking, a.style.display = "none"; - var l = this; - c(r, "click", function() { - l.agree_and_close() - }), this.element_mask && (c(this.element_mask, "click", function() { - l.agree_and_close() - }), i.body.appendChild(this.element_mask)), this.options.acceptOnScroll && c(window, "scroll", function() { - l.agree_and_close() - }), i.body.appendChild(this.element), this.inserted = !0, "fade" === this.options.effect ? (this.element.style.opacity = 0, s.fade_in(this.element)) : this.element.style.opacity = 1 - } - }, r && (e[o] || (e[o] = new a)) -}(window); \ No newline at end of file diff --git a/static/style.css b/static/style.css index b9567ac..15316ec 100644 --- a/static/style.css +++ b/static/style.css @@ -156,6 +156,48 @@ a#red { button#small { width: 30%; } + +.cookieinfo{ + position: fixed; + left: 0px; + right: 0px; + height: auto; + min-height: 21px; + z-index: 2147483647; + background: rgb(238, 238, 238); + color: rgb(51, 51, 51); + line-height: 21px; + padding: 8px 18px; + font-family: verdana, arial, sans-serif; + font-size: 14px; + text-align: center; + bottom: 0px; + opacity: 1; +} + +.cookieinfo-close{ + float: right; + display: block; + padding: 5px 8px; + min-width: 100px; + margin-left: 5px; + border-radius: 5px; + cursor: pointer; + color: rgb(0, 0, 0); + background: rgb(241, 214, 0); + text-align: center; +} + +.cookieinfo-text { + display:block; + padding:5px 0 5px 0; +} + +.cookieinfo-link{ + text-decoration: none; + color: rgb(49, 168, 240); +} + @-webkit-keyframes fadein { from {bottom: 0; opacity: 0;} to {bottom: 30px; opacity: 1;} @@ -291,4 +333,17 @@ unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+ background-color: #10151f; color: #b3b3b3; } + + .cookieinfo{ + background: #1a2332; + color: #b3b3b3; + } + + .cookieinfo-link{ + color: #1cb09a; + } + + .cookieinfo-close{ + background: #1cb09a; + } } \ No newline at end of file diff --git a/templates/home.html b/templates/home.html index 61b030b..40280eb 100644 --- a/templates/home.html +++ b/templates/home.html @@ -5,9 +5,9 @@ <link href="/static/style.css" rel="stylesheet"> <link href="/static/socialSignin/css/buttons-si.css" rel="stylesheet"> <title>URL shorter</title> - {% if cookieNotice %} - <script type="text/javascript" id="cookieinfo" src="/static/cookieinfo.js" ></script> - {% endif %} + <script src="/static/external/jquery/jquery.js"></script> + <script src="/static/jquery-ui.js"></script> + <script src="/static/cookie.js"></script> {% if recaptchaPublicKey %} <script src="https://www.google.com/recaptcha/api.js" async defer></script> <script> @@ -70,6 +70,21 @@ </ul> </div> </div> + {% if cookieNotice %} + <div class="cookieinfo"> + <div class="cookieinfo-close" onclick="acceptCookie()"> + ✖ + </div> + <span class="cookieinfo-text"> + We use cookies to enhance your experience. By continuing to visit this site you agree to our use of cookies. <a class="cookieinfo-link" href="http://wikipedia.org/wiki/HTTP_cookie">More info</a> + </span> + </div> + <script> + checkHide(); + </script> + {% endif %} + + {% if snackbar %} <script> @@ -84,9 +99,6 @@ x.selectedIndex = {{domain_prefilled}}; </script> {% endif %} - - <script src="/static/external/jquery/jquery.js"></script> - <script src="/static/jquery-ui.js"></script> <script> $( "#dialog" ).dialog({ autoOpen: false, -- GitLab