jekyll-swift-theme 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +22 -0
  3. data/README.md +114 -0
  4. data/_config.yml +22 -0
  5. data/_includes/author.html +28 -0
  6. data/_includes/footer.html +11 -0
  7. data/_includes/head.html +16 -0
  8. data/_includes/header.html +8 -0
  9. data/_includes/intro.html +16 -0
  10. data/_includes/nav.html +10 -0
  11. data/_includes/related.html +26 -0
  12. data/_layouts/default.html +13 -0
  13. data/_layouts/home.html +64 -0
  14. data/_layouts/page.html +22 -0
  15. data/_layouts/post.html +27 -0
  16. data/_sass/swift/_audio.sass +11 -0
  17. data/_sass/swift/_base.sass +185 -0
  18. data/_sass/swift/_comments.sass +77 -0
  19. data/_sass/swift/_components.sass +302 -0
  20. data/_sass/swift/_fonts.sass +36 -0
  21. data/_sass/swift/_footer.sass +24 -0
  22. data/_sass/swift/_nav.sass +131 -0
  23. data/_sass/swift/_posts.sass +209 -0
  24. data/_sass/swift/_social.sass +6 -0
  25. data/_sass/swift/_syntax.sass +15 -0
  26. data/_sass/swift/_utils.sass +145 -0
  27. data/_sass/swift/_variables.sass +44 -0
  28. data/_sass/swift.sass +12 -0
  29. data/assets/fonts/Metropolis-Light.woff +0 -0
  30. data/assets/fonts/Metropolis-Light.woff2 +0 -0
  31. data/assets/fonts/Metropolis-Medium.woff +0 -0
  32. data/assets/fonts/Metropolis-Medium.woff2 +0 -0
  33. data/assets/fonts/Metropolis-Regular.woff +0 -0
  34. data/assets/fonts/Metropolis-Regular.woff2 +0 -0
  35. data/assets/fonts/Metropolis-Thin.woff +0 -0
  36. data/assets/fonts/Metropolis-Thin.woff2 +0 -0
  37. data/assets/fonts/cookie-v10-latin-regular.woff +0 -0
  38. data/assets/fonts/cookie-v10-latin-regular.woff2 +0 -0
  39. data/assets/fonts/volkhov-v11-latin-700italic.woff +0 -0
  40. data/assets/fonts/volkhov-v11-latin-700italic.woff2 +0 -0
  41. data/assets/fonts/volkhov-v11-latin-italic.woff +0 -0
  42. data/assets/fonts/volkhov-v11-latin-italic.woff2 +0 -0
  43. data/assets/images/artist.jpg +0 -0
  44. data/assets/images/avatar.png +0 -0
  45. data/assets/images/fast-lane.jpg +0 -0
  46. data/assets/images/frustrated.jpg +0 -0
  47. data/assets/images/icons/android-chrome-512x512.png +0 -0
  48. data/assets/images/icons/apple-touch-icon.png +0 -0
  49. data/assets/images/icons/browserconfig.xml +9 -0
  50. data/assets/images/icons/close.svg +1 -0
  51. data/assets/images/icons/copy.svg +1 -0
  52. data/assets/images/icons/favicon-16x16.png +0 -0
  53. data/assets/images/icons/favicon-32x32.png +0 -0
  54. data/assets/images/icons/favicon.ico +0 -0
  55. data/assets/images/icons/link.svg +1 -0
  56. data/assets/images/icons/next.svg +6 -0
  57. data/assets/images/icons/reply.svg +1 -0
  58. data/assets/images/icons/site.webmanifest +1 -0
  59. data/assets/images/icons/sitting.svg +1 -0
  60. data/assets/images/read.jpg +0 -0
  61. data/assets/images/speakers.jpg +0 -0
  62. data/assets/images/stuck.jpg +0 -0
  63. data/assets/images/thumbnail.svg +49 -0
  64. data/assets/js/audio.js +59 -0
  65. data/assets/js/autosize.min.js +140 -0
  66. data/assets/js/functions.js +164 -0
  67. data/assets/js/index.js +240 -0
  68. data/assets/js/qrcode.js +4 -0
  69. data/assets/js/sine-waves.min.js +10 -0
  70. data/assets/js/timeago.js +54 -0
  71. data/assets/js/variables.js +9 -0
  72. data/assets/main.scss +5 -0
  73. metadata +200 -0
@@ -0,0 +1,140 @@
1
+ ! function(e, t) {
2
+ if ("function" == typeof define && define.amd) define(["exports", "module"], t);
3
+ else if ("undefined" != typeof exports && "undefined" != typeof module) t(exports, module);
4
+ else {
5
+ var n = {
6
+ exports: {}
7
+ };
8
+ t(n.exports, n), e.autosize = n.exports
9
+ }
10
+ }(this, function(e, t) {
11
+ "use strict";
12
+
13
+ function n(e) {
14
+ function t() {
15
+ var t = window.getComputedStyle(e, null);
16
+ "vertical" === t.resize ? e.style.resize = "none" : "both" === t.resize && (e.style.resize = "horizontal"), s = "content-box" === t.boxSizing ? -(parseFloat(t.paddingTop) + parseFloat(t.paddingBottom)) : parseFloat(t.borderTopWidth) + parseFloat(t.borderBottomWidth), isNaN(s) && (s = 0), l()
17
+ }
18
+
19
+ function n(t) {
20
+ var n = e.style.width;
21
+ e.style.width = "0px", e.offsetWidth, e.style.width = n, e.style.overflowY = t
22
+ }
23
+
24
+ function o(e) {
25
+ for (var t = []; e && e.parentNode && e.parentNode instanceof Element;) e.parentNode.scrollTop && t.push({
26
+ node: e.parentNode,
27
+ scrollTop: e.parentNode.scrollTop
28
+ }), e = e.parentNode;
29
+ return t
30
+ }
31
+
32
+ function r() {
33
+ var t = e.style.height,
34
+ n = o(e),
35
+ r = document.documentElement && document.documentElement.scrollTop;
36
+ e.style.height = "";
37
+ var i = e.scrollHeight + s;
38
+ return 0 === e.scrollHeight ? void(e.style.height = t) : (e.style.height = i + "px", u = e.clientWidth, n.forEach(function(e) {
39
+ e.node.scrollTop = e.scrollTop
40
+ }), void(r && (document.documentElement.scrollTop = r)))
41
+ }
42
+
43
+ function l() {
44
+ r();
45
+ var t = Math.round(parseFloat(e.style.height)),
46
+ o = window.getComputedStyle(e, null),
47
+ i = "content-box" === o.boxSizing ? Math.round(parseFloat(o.height)) : e.offsetHeight;
48
+ if (i !== t ? "hidden" === o.overflowY && (n("scroll"), r(), i = "content-box" === o.boxSizing ? Math.round(parseFloat(window.getComputedStyle(e, null).height)) : e.offsetHeight) : "hidden" !== o.overflowY && (n("hidden"), r(), i = "content-box" === o.boxSizing ? Math.round(parseFloat(window.getComputedStyle(e, null).height)) : e.offsetHeight), a !== i) {
49
+ a = i;
50
+ var l = d("autosize:resized");
51
+ try {
52
+ e.dispatchEvent(l)
53
+ } catch (e) {}
54
+ }
55
+ }
56
+ if (e && e.nodeName && "TEXTAREA" === e.nodeName && !i.has(e)) {
57
+ var s = null,
58
+ u = e.clientWidth,
59
+ a = null,
60
+ c = function() {
61
+ e.clientWidth !== u && l()
62
+ },
63
+ p = function(t) {
64
+ window.removeEventListener("resize", c, !1), e.removeEventListener("input", l, !1), e.removeEventListener("keyup", l, !1), e.removeEventListener("autosize:destroy", p, !1), e.removeEventListener("autosize:update", l, !1), Object.keys(t).forEach(function(n) {
65
+ e.style[n] = t[n]
66
+ }), i.delete(e)
67
+ }.bind(e, {
68
+ height: e.style.height,
69
+ resize: e.style.resize,
70
+ overflowY: e.style.overflowY,
71
+ overflowX: e.style.overflowX,
72
+ wordWrap: e.style.wordWrap
73
+ });
74
+ e.addEventListener("autosize:destroy", p, !1), "onpropertychange" in e && "oninput" in e && e.addEventListener("keyup", l, !1), window.addEventListener("resize", c, !1), e.addEventListener("input", l, !1), e.addEventListener("autosize:update", l, !1), e.style.overflowX = "hidden", e.style.wordWrap = "break-word", i.set(e, {
75
+ destroy: p,
76
+ update: l
77
+ }), t()
78
+ }
79
+ }
80
+
81
+ function o(e) {
82
+ var t = i.get(e);
83
+ t && t.destroy()
84
+ }
85
+
86
+ function r(e) {
87
+ var t = i.get(e);
88
+ t && t.update()
89
+ }
90
+ var i = "function" == typeof Map ? new Map : function() {
91
+ var e = [],
92
+ t = [];
93
+ return {
94
+ has: function(t) {
95
+ return e.indexOf(t) > -1
96
+ },
97
+ get: function(n) {
98
+ return t[e.indexOf(n)]
99
+ },
100
+ set: function(n, o) {
101
+ e.indexOf(n) === -1 && (e.push(n), t.push(o))
102
+ },
103
+ delete: function(n) {
104
+ var o = e.indexOf(n);
105
+ o > -1 && (e.splice(o, 1), t.splice(o, 1))
106
+ }
107
+ }
108
+ }(),
109
+ d = function(e) {
110
+ return new Event(e, {
111
+ bubbles: !0
112
+ })
113
+ };
114
+ try {
115
+ new Event("test")
116
+ } catch (e) {
117
+ d = function(e) {
118
+ var t = document.createEvent("Event");
119
+ return t.initEvent(e, !0, !1), t
120
+ }
121
+ }
122
+ var l = null;
123
+ "undefined" == typeof window || "function" != typeof window.getComputedStyle ? (l = function(e) {
124
+ return e
125
+ }, l.destroy = function(e) {
126
+ return e
127
+ }, l.update = function(e) {
128
+ return e
129
+ }) : (l = function(e, t) {
130
+ return e && Array.prototype.forEach.call(e.length ? e : [e], function(e) {
131
+ return n(e, t)
132
+ }), e
133
+ }, l.destroy = function(e) {
134
+ return e && Array.prototype.forEach.call(e.length ? e : [e], o), e
135
+ }, l.update = function(e) {
136
+ return e && Array.prototype.forEach.call(e.length ? e : [e], r), e
137
+ }), t.exports = l
138
+ });
139
+
140
+ autosize(document.querySelector('textarea'));
@@ -0,0 +1,164 @@
1
+ function isObj(obj) {
2
+ return (obj && typeof obj === 'object' && obj !== null) ? true : false;
3
+ }
4
+
5
+ function createEl(element = 'div') {
6
+ return document.createElement(element);
7
+ }
8
+
9
+ function elem(selector, parent = document){
10
+ let elem = parent.querySelector(selector);
11
+ return elem != false ? elem : false;
12
+ }
13
+
14
+ function elems(selector, parent = document) {
15
+ let elems = parent.querySelectorAll(selector);
16
+ return elems.length ? elems : false;
17
+ }
18
+
19
+ function pushClass(el, targetClass) {
20
+ if (isObj(el) && targetClass) {
21
+ elClass = el.classList;
22
+ elClass.contains(targetClass) ? false : elClass.add(targetClass);
23
+ }
24
+ }
25
+
26
+ function deleteClass(el, targetClass) {
27
+ if (isObj(el) && targetClass) {
28
+ elClass = el.classList;
29
+ elClass.contains(targetClass) ? elClass.remove(targetClass) : false;
30
+ }
31
+ }
32
+
33
+ function modifyClass(el, targetClass) {
34
+ if (isObj(el) && targetClass) {
35
+ elClass = el.classList;
36
+ elClass.contains(targetClass) ? elClass.remove(targetClass) : elClass.add(targetClass);
37
+ }
38
+ }
39
+
40
+ function containsClass(el, targetClass) {
41
+ if (isObj(el) && targetClass && el !== document ) {
42
+ return el.classList.contains(targetClass) ? true : false;
43
+ }
44
+ }
45
+
46
+ function isChild(node, parentClass) {
47
+ let objectsAreValid = isObj(node) && parentClass && typeof parentClass == 'string';
48
+ return (objectsAreValid && node.closest(parentClass)) ? true : false;
49
+ }
50
+
51
+ function getSiblings(el) {
52
+ return Array.prototype.filter.call(el.parentNode.children, function(child){
53
+ return child !== el;
54
+ });
55
+ }
56
+
57
+ function markActive(el, activeClass = active) {
58
+ const siblings = getSiblings(el);
59
+ pushClass(el, activeClass);
60
+ if(siblings.length) {
61
+ siblings.forEach(element => deleteClass(element, activeClass));
62
+ }
63
+ }
64
+
65
+ function elemAttribute(elem, attr, value = null) {
66
+ if (value) {
67
+ elem.setAttribute(attr, value);
68
+ } else {
69
+ value = elem.getAttribute(attr);
70
+ return value ? value : false;
71
+ }
72
+ }
73
+
74
+ function deleteChars(str, subs) {
75
+ let newStr = str;
76
+ if (Array.isArray(subs)) {
77
+ for (let i = 0; i < subs.length; i++) {
78
+ newStr = newStr.replace(subs[i], '');
79
+ }
80
+ } else {
81
+ newStr = newStr.replace(subs, '');
82
+ }
83
+ return newStr;
84
+ }
85
+
86
+ function isBlank(str) {
87
+ return (!str || str.trim().length === 0);
88
+ }
89
+
90
+ function isMatch(element, selectors) {
91
+ if(isObj(element)) {
92
+ if(selectors.isArray) {
93
+ let matching = selectors.map(function(selector){
94
+ return element.matches(selector)
95
+ })
96
+ return matching.includes(true);
97
+ }
98
+ return element.matches(selectors)
99
+ }
100
+ }
101
+
102
+ function exactMatch(target, criteria) {
103
+ const isTarget = target.matches(criteria);
104
+ const isWithinTarget = target.closest(criteria);
105
+ return isTarget ? isTarget : isWithinTarget;;
106
+ }
107
+
108
+ const copyToClipboard = str => {
109
+ let copy, selection, selected;
110
+ copy = createEl('textarea');
111
+ copy.value = str;
112
+ copy.setAttribute('readonly', '');
113
+ copy.style.position = 'absolute';
114
+ copy.style.left = '-9999px';
115
+ selection = document.getSelection();
116
+ doc.appendChild(copy);
117
+ // check if there is any selected content
118
+ selected = selection.rangeCount > 0 ? selection.getRangeAt(0) : false;
119
+ copy.select();
120
+ document.execCommand('copy');
121
+ doc.removeChild(copy);
122
+ if (selected) { // if a selection existed before copying
123
+ selection.removeAllRanges(); // unselect existing selection
124
+ selection.addRange(selected); // restore the original selection
125
+ }
126
+ }
127
+
128
+ function convertToUnderScoreCase(str) {
129
+ let char, newChar, newStr;
130
+ newStr = '';
131
+ if (typeof str == 'string') {
132
+ for (let x = 0; x < str.length; x++) {
133
+ char = str.charAt(x);
134
+ if (char.match(/^[A-Z]*$/)) {
135
+ char = char.toLowerCase();
136
+ newChar = `_${char}`
137
+ newStr += newChar;
138
+ } else {
139
+ newStr += char;
140
+ }
141
+ }
142
+ return newStr;
143
+ }
144
+ }
145
+
146
+ function elementInViewport(el) {
147
+ var top = el.offsetTop;
148
+ var left = el.offsetLeft;
149
+ var width = el.offsetWidth;
150
+ var height = el.offsetHeight;
151
+
152
+ while(el.offsetParent) {
153
+ el = el.offsetParent;
154
+ top += el.offsetTop;
155
+ left += el.offsetLeft;
156
+ }
157
+
158
+ return (
159
+ top < (window.pageYOffset + window.innerHeight) &&
160
+ left < (window.pageXOffset + window.innerWidth) &&
161
+ (top + height) > window.pageYOffset &&
162
+ (left + width) > window.pageXOffset
163
+ );
164
+ }
@@ -0,0 +1,240 @@
1
+ function fileClosure(){
2
+ // everything in this file should be declared within this closure (function).
3
+
4
+ (function updateDate() {
5
+ var date = new Date();
6
+ var year = date.getFullYear();
7
+ elem('.year').innerHTML = year;
8
+ })();
9
+
10
+ (function() {
11
+ let bar = 'nav_bar-wrap';
12
+ let navBar = elem(`.${bar}`);
13
+ let nav = elem('.nav-body');
14
+ let open = 'nav-open';
15
+ let exit = 'nav-exit';
16
+ let drop = 'nav-drop';
17
+ let pop = 'nav-pop';
18
+ let navDrop = elem(`.${drop}`);
19
+
20
+ function toggleMenu(){
21
+ let menuOpen, menuPulled, status;
22
+ modifyClass(navDrop, pop);
23
+ modifyClass(navBar, hidden);
24
+ menuOpen = containsClass(nav, open);
25
+ menuPulled = containsClass(nav, exit);
26
+
27
+ status = menuOpen || menuPulled ? true : false;
28
+
29
+ status ? modifyClass(nav, exit) : modifyClass(nav, open);
30
+ status ? modifyClass(nav, open) : modifyClass(nav, exit);
31
+ }
32
+
33
+ navBar.addEventListener('click', function() {
34
+ toggleMenu();
35
+ });
36
+ elem('.nav-close').addEventListener('click', function() {
37
+ toggleMenu();
38
+ });
39
+
40
+ elem('.nav-drop').addEventListener('click', function(e) {
41
+ e.target === this ? toggleMenu() : false;
42
+ });
43
+
44
+ })();
45
+
46
+ (function makeExternalLinks(){
47
+ let links = elems('a');
48
+ if(links) {
49
+ Array.from(links).forEach(function(link){
50
+ let target, rel, blank, noopener, attr1, attr2, url, isExternal;
51
+ url = elemAttribute(link, 'href');
52
+ isExternal = (url && typeof url == 'string' && url.startsWith('http')) && !url.startsWith(parentURL) ? true : false;
53
+ if(isExternal) {
54
+ target = 'target';
55
+ rel = 'rel';
56
+ blank = '_blank';
57
+ noopener = 'noopener';
58
+ attr1 = elemAttribute(link, target);
59
+ attr2 = elemAttribute(link, noopener);
60
+
61
+ attr1 ? false : elemAttribute(link, target, blank);
62
+ attr2 ? false : elemAttribute(link, rel, noopener);
63
+ }
64
+ });
65
+ }
66
+ })();
67
+
68
+ let headingNodes = [], results, link, icon, current, id,
69
+ tags = ['h2', 'h3', 'h4', 'h5', 'h6'];
70
+
71
+ current = document.URL;
72
+
73
+ tags.forEach(function(tag){
74
+ results = document.getElementsByTagName(tag);
75
+ Array.prototype.push.apply(headingNodes, results);
76
+ });
77
+
78
+ headingNodes.forEach(function(node){
79
+ link = createEl('a');
80
+ icon = createEl('img');
81
+ icon.src = '/assets/images/icons/link.svg';
82
+ link.className = 'link';
83
+ link.appendChild(icon);
84
+ id = node.getAttribute('id');
85
+ if(id) {
86
+ link.href = `${current}#${id}`;
87
+ node.appendChild(link);
88
+ pushClass(node, 'link_owner');
89
+ }
90
+ });
91
+
92
+ let inlineListItems = elems('ol li');
93
+ if(inlineListItems) {
94
+ inlineListItems.forEach(function(listItem){
95
+ let firstChild = listItem.children[0]
96
+ let containsHeading = isMatch(firstChild, tags);
97
+ containsHeading ? pushClass(listItem, 'align') : false;
98
+ })
99
+ }
100
+
101
+ (function copyHeadingLink() {
102
+ let deeplink, deeplinks, newLink, parent, target;
103
+ deeplink = 'link';
104
+ deeplinks = elems(`.${deeplink}`);
105
+ if(deeplinks) {
106
+ document.addEventListener('click', function(event)
107
+ {
108
+ target = event.target;
109
+ parent = target.parentNode;
110
+ if (target && containsClass(target, deeplink) || containsClass(parent, deeplink)) {
111
+ event.preventDefault();
112
+ newLink = target.href != undefined ? target.href : target.parentNode.href;
113
+ copyToClipboard(newLink);
114
+ }
115
+ });
116
+ }
117
+ })();
118
+
119
+ (function hideAside(){
120
+ let aside, title, posts;
121
+ aside = elem('.aside');
122
+ title = aside ? aside.previousElementSibling : null;
123
+ if(aside && title.nodeName.toLowerCase() === 'h3') {
124
+ posts = Array.from(aside.children);
125
+ posts.length < 1 ? title.remove() : false;
126
+ }
127
+ })();
128
+
129
+ (function goBack() {
130
+ let backBtn = elem('.btn_back');
131
+ let history = window.history;
132
+ if (backBtn) {
133
+ backBtn.addEventListener('click', function(){
134
+ history.back();
135
+ });
136
+ }
137
+ })();
138
+
139
+ /*(function postsPager(){
140
+ const pager = elem('.pagination');
141
+ if (pager) {
142
+ pushClass(pager, 'pager');
143
+ const pagerItems = elems('li', pager);
144
+ const pagerLinks = Array.from(pagerItems).map(function(item){
145
+ return item.firstElementChild;
146
+ });
147
+
148
+ pagerLinks.forEach(function(link){
149
+ pushClass(link, 'pager_link')
150
+ });
151
+
152
+ pagerItems.forEach(function(item){
153
+ pushClass(item, 'pager_item')
154
+ });
155
+ }
156
+ })();*/
157
+
158
+ (function lazy() {
159
+ function lazyLoadMedia(element) {
160
+ let mediaItems = elems(element);
161
+ if(mediaItems) {
162
+ Array.from(mediaItems).forEach(function(item) {
163
+ item.loading = "lazy";
164
+ });
165
+ }
166
+ }
167
+ lazyLoadMedia('iframe');
168
+ lazyLoadMedia('img');
169
+ })();
170
+
171
+ const qr = elem(".crypto_qr");
172
+
173
+ function cryptoAddressQR(address, el = qr) {
174
+ const qrCode = new QRious({ element: el, size: 225, value: address});
175
+ qrCode.set({
176
+ foreground: "#ef7f1a",
177
+ size: 225,
178
+ });
179
+ }
180
+
181
+ function activeCryptoTitle(el) {
182
+ const cryptoTitle = `${el.dataset.title} ${tAddress}`;
183
+ const cryptoTitleEl = elem(".crypto_title");
184
+ cryptoTitleEl.textContent = cryptoTitle;
185
+ }
186
+
187
+ const cryptoRow = ".crypto_row";
188
+
189
+ doc.addEventListener('click', function(event){
190
+ const target = event.target;
191
+ const cryptoCopy = ".crypto_copy";
192
+ const cryptoScan = ".crypto_scan";
193
+ const isCrypto = exactMatch(target, cryptoRow);
194
+ if(qr) {
195
+ const cryptoPad = qr.parentNode;
196
+ if(isCrypto) {
197
+ const isCopyCrypto = exactMatch(target, cryptoCopy);
198
+ const isScanCrypto = exactMatch(target, cryptoScan);
199
+ if(isCrypto.dataset) {
200
+ const address = isCrypto.dataset.address;
201
+ isCopyCrypto ? copyToClipboard(address) : false;
202
+ isScanCrypto ? pushClass(cryptoPad, active) : false;
203
+ markActive(isCrypto);
204
+ cryptoAddressQR(address);
205
+ activeCryptoTitle(isCrypto);
206
+ }
207
+ } else {
208
+ containsClass(cryptoPad, active) ? modifyClass(cryptoPad, active) : false;
209
+ }
210
+ }
211
+ });
212
+
213
+ let applied = false;
214
+ // let fadedUp = false;
215
+ // let fadedSideways = false;
216
+ const toFade = elems(".fp");
217
+ const toFadeSideways = elems(".fs");
218
+ window.addEventListener("scroll", () => {
219
+ if(toFade.length) {
220
+ toFade.forEach((el) => {
221
+ let blockInPosition = elementInViewport(el);
222
+ if(blockInPosition) {
223
+ pushClass(el, "fade_up");
224
+ }
225
+ })
226
+ }
227
+
228
+ if(toFadeSideways.length) {
229
+ toFadeSideways.forEach((el) => {
230
+ let blockInPosition = elementInViewport(el);
231
+ if(blockInPosition) {
232
+ pushClass(el, "fade_left");
233
+ }
234
+ })
235
+ }
236
+ });
237
+
238
+ // add new code above this line
239
+ }
240
+ window.addEventListener('load', fileClosure());
@@ -0,0 +1,4 @@
1
+ /*! QRious v4.0.2 | (C) 2017 Alasdair Mercer | GPL v3 License
2
+ Based on jsqrencode | (C) 2010 tz@execpc.com | GPL v3 License
3
+ */
4
+ !function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):t.QRious=e()}(this,function(){"use strict";function t(t,e){var n;return"function"==typeof Object.create?n=Object.create(t):(s.prototype=t,n=new s,s.prototype=null),e&&i(!0,n,e),n}function e(e,n,s,r){var o=this;return"string"!=typeof e&&(r=s,s=n,n=e,e=null),"function"!=typeof n&&(r=s,s=n,n=function(){return o.apply(this,arguments)}),i(!1,n,o,r),n.prototype=t(o.prototype,s),n.prototype.constructor=n,n.class_=e||o.class_,n.super_=o,n}function i(t,e,i){for(var n,s,a=0,h=(i=o.call(arguments,2)).length;a<h;a++){s=i[a];for(n in s)t&&!r.call(s,n)||(e[n]=s[n])}}function n(){}var s=function(){},r=Object.prototype.hasOwnProperty,o=Array.prototype.slice,a=e;n.class_="Nevis",n.super_=Object,n.extend=a;var h=n,f=h.extend(function(t,e,i){this.qrious=t,this.element=e,this.element.qrious=t,this.enabled=Boolean(i)},{draw:function(t){},getElement:function(){return this.enabled||(this.enabled=!0,this.render()),this.element},getModuleSize:function(t){var e=this.qrious,i=e.padding||0,n=Math.floor((e.size-2*i)/t.width);return Math.max(1,n)},getOffset:function(t){var e=this.qrious,i=e.padding;if(null!=i)return i;var n=this.getModuleSize(t),s=Math.floor((e.size-n*t.width)/2);return Math.max(0,s)},render:function(t){this.enabled&&(this.resize(),this.reset(),this.draw(t))},reset:function(){},resize:function(){}}),c=f.extend({draw:function(t){var e,i,n=this.qrious,s=this.getModuleSize(t),r=this.getOffset(t),o=this.element.getContext("2d");for(o.fillStyle=n.foreground,o.globalAlpha=n.foregroundAlpha,e=0;e<t.width;e++)for(i=0;i<t.width;i++)t.buffer[i*t.width+e]&&o.fillRect(s*e+r,s*i+r,s,s)},reset:function(){var t=this.qrious,e=this.element.getContext("2d"),i=t.size;e.lineWidth=1,e.clearRect(0,0,i,i),e.fillStyle=t.background,e.globalAlpha=t.backgroundAlpha,e.fillRect(0,0,i,i)},resize:function(){var t=this.element;t.width=t.height=this.qrious.size}}),u=h.extend(null,{BLOCK:[0,11,15,19,23,27,31,16,18,20,22,24,26,28,20,22,24,24,26,28,28,22,24,24,26,26,28,28,24,24,26,26,26,28,28,24,26,26,26,28,28]}),l=h.extend(null,{BLOCKS:[1,0,19,7,1,0,16,10,1,0,13,13,1,0,9,17,1,0,34,10,1,0,28,16,1,0,22,22,1,0,16,28,1,0,55,15,1,0,44,26,2,0,17,18,2,0,13,22,1,0,80,20,2,0,32,18,2,0,24,26,4,0,9,16,1,0,108,26,2,0,43,24,2,2,15,18,2,2,11,22,2,0,68,18,4,0,27,16,4,0,19,24,4,0,15,28,2,0,78,20,4,0,31,18,2,4,14,18,4,1,13,26,2,0,97,24,2,2,38,22,4,2,18,22,4,2,14,26,2,0,116,30,3,2,36,22,4,4,16,20,4,4,12,24,2,2,68,18,4,1,43,26,6,2,19,24,6,2,15,28,4,0,81,20,1,4,50,30,4,4,22,28,3,8,12,24,2,2,92,24,6,2,36,22,4,6,20,26,7,4,14,28,4,0,107,26,8,1,37,22,8,4,20,24,12,4,11,22,3,1,115,30,4,5,40,24,11,5,16,20,11,5,12,24,5,1,87,22,5,5,41,24,5,7,24,30,11,7,12,24,5,1,98,24,7,3,45,28,15,2,19,24,3,13,15,30,1,5,107,28,10,1,46,28,1,15,22,28,2,17,14,28,5,1,120,30,9,4,43,26,17,1,22,28,2,19,14,28,3,4,113,28,3,11,44,26,17,4,21,26,9,16,13,26,3,5,107,28,3,13,41,26,15,5,24,30,15,10,15,28,4,4,116,28,17,0,42,26,17,6,22,28,19,6,16,30,2,7,111,28,17,0,46,28,7,16,24,30,34,0,13,24,4,5,121,30,4,14,47,28,11,14,24,30,16,14,15,30,6,4,117,30,6,14,45,28,11,16,24,30,30,2,16,30,8,4,106,26,8,13,47,28,7,22,24,30,22,13,15,30,10,2,114,28,19,4,46,28,28,6,22,28,33,4,16,30,8,4,122,30,22,3,45,28,8,26,23,30,12,28,15,30,3,10,117,30,3,23,45,28,4,31,24,30,11,31,15,30,7,7,116,30,21,7,45,28,1,37,23,30,19,26,15,30,5,10,115,30,19,10,47,28,15,25,24,30,23,25,15,30,13,3,115,30,2,29,46,28,42,1,24,30,23,28,15,30,17,0,115,30,10,23,46,28,10,35,24,30,19,35,15,30,17,1,115,30,14,21,46,28,29,19,24,30,11,46,15,30,13,6,115,30,14,23,46,28,44,7,24,30,59,1,16,30,12,7,121,30,12,26,47,28,39,14,24,30,22,41,15,30,6,14,121,30,6,34,47,28,46,10,24,30,2,64,15,30,17,4,122,30,29,14,46,28,49,10,24,30,24,46,15,30,4,18,122,30,13,32,46,28,48,14,24,30,42,32,15,30,20,4,117,30,40,7,47,28,43,22,24,30,10,67,15,30,19,6,118,30,18,31,47,28,34,34,24,30,20,61,15,30],FINAL_FORMAT:[30660,29427,32170,30877,26159,25368,27713,26998,21522,20773,24188,23371,17913,16590,20375,19104,13663,12392,16177,14854,9396,8579,11994,11245,5769,5054,7399,6608,1890,597,3340,2107],LEVELS:{L:1,M:2,Q:3,H:4}}),_=h.extend(null,{EXPONENT:[1,2,4,8,16,32,64,128,29,58,116,232,205,135,19,38,76,152,45,90,180,117,234,201,143,3,6,12,24,48,96,192,157,39,78,156,37,74,148,53,106,212,181,119,238,193,159,35,70,140,5,10,20,40,80,160,93,186,105,210,185,111,222,161,95,190,97,194,153,47,94,188,101,202,137,15,30,60,120,240,253,231,211,187,107,214,177,127,254,225,223,163,91,182,113,226,217,175,67,134,17,34,68,136,13,26,52,104,208,189,103,206,129,31,62,124,248,237,199,147,59,118,236,197,151,51,102,204,133,23,46,92,184,109,218,169,79,158,33,66,132,21,42,84,168,77,154,41,82,164,85,170,73,146,57,114,228,213,183,115,230,209,191,99,198,145,63,126,252,229,215,179,123,246,241,255,227,219,171,75,150,49,98,196,149,55,110,220,165,87,174,65,130,25,50,100,200,141,7,14,28,56,112,224,221,167,83,166,81,162,89,178,121,242,249,239,195,155,43,86,172,69,138,9,18,36,72,144,61,122,244,245,247,243,251,235,203,139,11,22,44,88,176,125,250,233,207,131,27,54,108,216,173,71,142,0],LOG:[255,0,1,25,2,50,26,198,3,223,51,238,27,104,199,75,4,100,224,14,52,141,239,129,28,193,105,248,200,8,76,113,5,138,101,47,225,36,15,33,53,147,142,218,240,18,130,69,29,181,194,125,106,39,249,185,201,154,9,120,77,228,114,166,6,191,139,98,102,221,48,253,226,152,37,179,16,145,34,136,54,208,148,206,143,150,219,189,241,210,19,92,131,56,70,64,30,66,182,163,195,72,126,110,107,58,40,84,250,133,186,61,202,94,155,159,10,21,121,43,78,212,229,172,115,243,167,87,7,112,192,247,140,128,99,13,103,74,222,237,49,197,254,24,227,165,153,119,38,184,180,124,17,68,146,217,35,32,137,46,55,63,209,91,149,188,207,205,144,135,151,178,220,252,190,97,242,86,211,171,20,42,93,158,132,60,57,83,71,109,65,162,31,45,67,216,183,123,164,118,196,23,73,236,127,12,111,246,108,161,59,82,41,157,85,170,251,96,134,177,187,204,62,90,203,89,95,176,156,169,160,81,11,245,22,235,122,117,44,215,79,174,213,233,230,231,173,232,116,214,244,234,168,80,88,175]}),d=h.extend(null,{BLOCK:[3220,1468,2713,1235,3062,1890,2119,1549,2344,2936,1117,2583,1330,2470,1667,2249,2028,3780,481,4011,142,3098,831,3445,592,2517,1776,2234,1951,2827,1070,2660,1345,3177]}),v=h.extend(function(t){var e,i,n,s,r,o=t.value.length;for(this._badness=[],this._level=l.LEVELS[t.level],this._polynomial=[],this._value=t.value,this._version=0,this._stringBuffer=[];this._version<40&&(this._version++,n=4*(this._level-1)+16*(this._version-1),s=l.BLOCKS[n++],r=l.BLOCKS[n++],e=l.BLOCKS[n++],i=l.BLOCKS[n],n=e*(s+r)+r-3+(this._version<=9),!(o<=n)););this._dataBlock=e,this._eccBlock=i,this._neccBlock1=s,this._neccBlock2=r;var a=this.width=17+4*this._version;this.buffer=v._createArray(a*a),this._ecc=v._createArray(e+(e+i)*(s+r)+r),this._mask=v._createArray((a*(a+1)+1)/2),this._insertFinders(),this._insertAlignments(),this.buffer[8+a*(a-8)]=1,this._insertTimingGap(),this._reverseMask(),this._insertTimingRowAndColumn(),this._insertVersion(),this._syncMask(),this._convertBitStream(o),this._calculatePolynomial(),this._appendEccToData(),this._interleaveBlocks(),this._pack(),this._finish()},{_addAlignment:function(t,e){var i,n=this.buffer,s=this.width;for(n[t+s*e]=1,i=-2;i<2;i++)n[t+i+s*(e-2)]=1,n[t-2+s*(e+i+1)]=1,n[t+2+s*(e+i)]=1,n[t+i+1+s*(e+2)]=1;for(i=0;i<2;i++)this._setMask(t-1,e+i),this._setMask(t+1,e-i),this._setMask(t-i,e-1),this._setMask(t+i,e+1)},_appendData:function(t,e,i,n){var s,r,o,a=this._polynomial,h=this._stringBuffer;for(r=0;r<n;r++)h[i+r]=0;for(r=0;r<e;r++){if(255!==(s=_.LOG[h[t+r]^h[i]]))for(o=1;o<n;o++)h[i+o-1]=h[i+o]^_.EXPONENT[v._modN(s+a[n-o])];else for(o=i;o<i+n;o++)h[o]=h[o+1];h[i+n-1]=255===s?0:_.EXPONENT[v._modN(s+a[0])]}},_appendEccToData:function(){var t,e=0,i=this._dataBlock,n=this._calculateMaxLength(),s=this._eccBlock;for(t=0;t<this._neccBlock1;t++)this._appendData(e,i,n,s),e+=i,n+=s;for(t=0;t<this._neccBlock2;t++)this._appendData(e,i+1,n,s),e+=i+1,n+=s},_applyMask:function(t){var e,i,n,s,r=this.buffer,o=this.width;switch(t){case 0:for(s=0;s<o;s++)for(n=0;n<o;n++)n+s&1||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 1:for(s=0;s<o;s++)for(n=0;n<o;n++)1&s||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 2:for(s=0;s<o;s++)for(e=0,n=0;n<o;n++,e++)3===e&&(e=0),e||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 3:for(i=0,s=0;s<o;s++,i++)for(3===i&&(i=0),e=i,n=0;n<o;n++,e++)3===e&&(e=0),e||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 4:for(s=0;s<o;s++)for(e=0,i=s>>1&1,n=0;n<o;n++,e++)3===e&&(e=0,i=!i),i||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 5:for(i=0,s=0;s<o;s++,i++)for(3===i&&(i=0),e=0,n=0;n<o;n++,e++)3===e&&(e=0),(n&s&1)+!(!e|!i)||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 6:for(i=0,s=0;s<o;s++,i++)for(3===i&&(i=0),e=0,n=0;n<o;n++,e++)3===e&&(e=0),(n&s&1)+(e&&e===i)&1||this._isMasked(n,s)||(r[n+s*o]^=1);break;case 7:for(i=0,s=0;s<o;s++,i++)for(3===i&&(i=0),e=0,n=0;n<o;n++,e++)3===e&&(e=0),(e&&e===i)+(n+s&1)&1||this._isMasked(n,s)||(r[n+s*o]^=1)}},_calculateMaxLength:function(){return this._dataBlock*(this._neccBlock1+this._neccBlock2)+this._neccBlock2},_calculatePolynomial:function(){var t,e,i=this._eccBlock,n=this._polynomial;for(n[0]=1,t=0;t<i;t++){for(n[t+1]=1,e=t;e>0;e--)n[e]=n[e]?n[e-1]^_.EXPONENT[v._modN(_.LOG[n[e]]+t)]:n[e-1];n[0]=_.EXPONENT[v._modN(_.LOG[n[0]]+t)]}for(t=0;t<=i;t++)n[t]=_.LOG[n[t]]},_checkBadness:function(){var t,e,i,n,s,r=0,o=this._badness,a=this.buffer,h=this.width;for(s=0;s<h-1;s++)for(n=0;n<h-1;n++)(a[n+h*s]&&a[n+1+h*s]&&a[n+h*(s+1)]&&a[n+1+h*(s+1)]||!(a[n+h*s]||a[n+1+h*s]||a[n+h*(s+1)]||a[n+1+h*(s+1)]))&&(r+=v.N2);var f=0;for(s=0;s<h;s++){for(i=0,o[0]=0,t=0,n=0;n<h;n++)t===(e=a[n+h*s])?o[i]++:o[++i]=1,f+=(t=e)?1:-1;r+=this._getBadness(i)}f<0&&(f=-f);var c=0,u=f;for(u+=u<<2,u<<=1;u>h*h;)u-=h*h,c++;for(r+=c*v.N4,n=0;n<h;n++){for(i=0,o[0]=0,t=0,s=0;s<h;s++)t===(e=a[n+h*s])?o[i]++:o[++i]=1,t=e;r+=this._getBadness(i)}return r},_convertBitStream:function(t){var e,i,n=this._ecc,s=this._version;for(i=0;i<t;i++)n[i]=this._value.charCodeAt(i);var r=this._stringBuffer=n.slice(),o=this._calculateMaxLength();t>=o-2&&(t=o-2,s>9&&t--);var a=t;if(s>9){for(r[a+2]=0,r[a+3]=0;a--;)e=r[a],r[a+3]|=255&e<<4,r[a+2]=e>>4;r[2]|=255&t<<4,r[1]=t>>4,r[0]=64|t>>12}else{for(r[a+1]=0,r[a+2]=0;a--;)e=r[a],r[a+2]|=255&e<<4,r[a+1]=e>>4;r[1]|=255&t<<4,r[0]=64|t>>4}for(a=t+3-(s<10);a<o;)r[a++]=236,r[a++]=17},_getBadness:function(t){var e,i=0,n=this._badness;for(e=0;e<=t;e++)n[e]>=5&&(i+=v.N1+n[e]-5);for(e=3;e<t-1;e+=2)n[e-2]===n[e+2]&&n[e+2]===n[e-1]&&n[e-1]===n[e+1]&&3*n[e-1]===n[e]&&(0===n[e-3]||e+3>t||3*n[e-3]>=4*n[e]||3*n[e+3]>=4*n[e])&&(i+=v.N3);return i},_finish:function(){this._stringBuffer=this.buffer.slice();var t,e,i=0,n=3e4;for(e=0;e<8&&(this._applyMask(e),(t=this._checkBadness())<n&&(n=t,i=e),7!==i);e++)this.buffer=this._stringBuffer.slice();i!==e&&this._applyMask(i),n=l.FINAL_FORMAT[i+(this._level-1<<3)];var s=this.buffer,r=this.width;for(e=0;e<8;e++,n>>=1)1&n&&(s[r-1-e+8*r]=1,e<6?s[8+r*e]=1:s[8+r*(e+1)]=1);for(e=0;e<7;e++,n>>=1)1&n&&(s[8+r*(r-7+e)]=1,e?s[6-e+8*r]=1:s[7+8*r]=1)},_interleaveBlocks:function(){var t,e,i=this._dataBlock,n=this._ecc,s=this._eccBlock,r=0,o=this._calculateMaxLength(),a=this._neccBlock1,h=this._neccBlock2,f=this._stringBuffer;for(t=0;t<i;t++){for(e=0;e<a;e++)n[r++]=f[t+e*i];for(e=0;e<h;e++)n[r++]=f[a*i+t+e*(i+1)]}for(e=0;e<h;e++)n[r++]=f[a*i+t+e*(i+1)];for(t=0;t<s;t++)for(e=0;e<a+h;e++)n[r++]=f[o+t+e*s];this._stringBuffer=n},_insertAlignments:function(){var t,e,i,n=this._version,s=this.width;if(n>1)for(t=u.BLOCK[n],i=s-7;;){for(e=s-7;e>t-3&&(this._addAlignment(e,i),!(e<t));)e-=t;if(i<=t+9)break;i-=t,this._addAlignment(6,i),this._addAlignment(i,6)}},_insertFinders:function(){var t,e,i,n,s=this.buffer,r=this.width;for(t=0;t<3;t++){for(e=0,n=0,1===t&&(e=r-7),2===t&&(n=r-7),s[n+3+r*(e+3)]=1,i=0;i<6;i++)s[n+i+r*e]=1,s[n+r*(e+i+1)]=1,s[n+6+r*(e+i)]=1,s[n+i+1+r*(e+6)]=1;for(i=1;i<5;i++)this._setMask(n+i,e+1),this._setMask(n+1,e+i+1),this._setMask(n+5,e+i),this._setMask(n+i+1,e+5);for(i=2;i<4;i++)s[n+i+r*(e+2)]=1,s[n+2+r*(e+i+1)]=1,s[n+4+r*(e+i)]=1,s[n+i+1+r*(e+4)]=1}},_insertTimingGap:function(){var t,e,i=this.width;for(e=0;e<7;e++)this._setMask(7,e),this._setMask(i-8,e),this._setMask(7,e+i-7);for(t=0;t<8;t++)this._setMask(t,7),this._setMask(t+i-8,7),this._setMask(t,i-8)},_insertTimingRowAndColumn:function(){var t,e=this.buffer,i=this.width;for(t=0;t<i-14;t++)1&t?(this._setMask(8+t,6),this._setMask(6,8+t)):(e[8+t+6*i]=1,e[6+i*(8+t)]=1)},_insertVersion:function(){var t,e,i,n,s=this.buffer,r=this._version,o=this.width;if(r>6)for(t=d.BLOCK[r-7],e=17,i=0;i<6;i++)for(n=0;n<3;n++,e--)1&(e>11?r>>e-12:t>>e)?(s[5-i+o*(2-n+o-11)]=1,s[2-n+o-11+o*(5-i)]=1):(this._setMask(5-i,2-n+o-11),this._setMask(2-n+o-11,5-i))},_isMasked:function(t,e){var i=v._getMaskBit(t,e);return 1===this._mask[i]},_pack:function(){var t,e,i,n=1,s=1,r=this.width,o=r-1,a=r-1,h=(this._dataBlock+this._eccBlock)*(this._neccBlock1+this._neccBlock2)+this._neccBlock2;for(e=0;e<h;e++)for(t=this._stringBuffer[e],i=0;i<8;i++,t<<=1){128&t&&(this.buffer[o+r*a]=1);do{s?o--:(o++,n?0!==a?a--:(n=!n,6===(o-=2)&&(o--,a=9)):a!==r-1?a++:(n=!n,6===(o-=2)&&(o--,a-=8))),s=!s}while(this._isMasked(o,a))}},_reverseMask:function(){var t,e,i=this.width;for(t=0;t<9;t++)this._setMask(t,8);for(t=0;t<8;t++)this._setMask(t+i-8,8),this._setMask(8,t);for(e=0;e<7;e++)this._setMask(8,e+i-7)},_setMask:function(t,e){var i=v._getMaskBit(t,e);this._mask[i]=1},_syncMask:function(){var t,e,i=this.width;for(e=0;e<i;e++)for(t=0;t<=e;t++)this.buffer[t+i*e]&&this._setMask(t,e)}},{_createArray:function(t){var e,i=[];for(e=0;e<t;e++)i[e]=0;return i},_getMaskBit:function(t,e){var i;return t>e&&(i=t,t=e,e=i),i=e,i+=e*e,i>>=1,i+=t},_modN:function(t){for(;t>=255;)t=((t-=255)>>8)+(255&t);return t},N1:3,N2:3,N3:40,N4:10}),p=v,m=f.extend({draw:function(){this.element.src=this.qrious.toDataURL()},reset:function(){this.element.src=""},resize:function(){var t=this.element;t.width=t.height=this.qrious.size}}),g=h.extend(function(t,e,i,n){this.name=t,this.modifiable=Boolean(e),this.defaultValue=i,this._valueTransformer=n},{transform:function(t){var e=this._valueTransformer;return"function"==typeof e?e(t,this):t}}),k=h.extend(null,{abs:function(t){return null!=t?Math.abs(t):null},hasOwn:function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},noop:function(){},toUpperCase:function(t){return null!=t?t.toUpperCase():null}}),w=h.extend(function(t){this.options={},t.forEach(function(t){this.options[t.name]=t},this)},{exists:function(t){return null!=this.options[t]},get:function(t,e){return w._get(this.options[t],e)},getAll:function(t){var e,i=this.options,n={};for(e in i)k.hasOwn(i,e)&&(n[e]=w._get(i[e],t));return n},init:function(t,e,i){"function"!=typeof i&&(i=k.noop);var n,s;for(n in this.options)k.hasOwn(this.options,n)&&(s=this.options[n],w._set(s,s.defaultValue,e),w._createAccessor(s,e,i));this._setAll(t,e,!0)},set:function(t,e,i){return this._set(t,e,i)},setAll:function(t,e){return this._setAll(t,e)},_set:function(t,e,i,n){var s=this.options[t];if(!s)throw new Error("Invalid option: "+t);if(!s.modifiable&&!n)throw new Error("Option cannot be modified: "+t);return w._set(s,e,i)},_setAll:function(t,e,i){if(!t)return!1;var n,s=!1;for(n in t)k.hasOwn(t,n)&&this._set(n,t[n],e,i)&&(s=!0);return s}},{_createAccessor:function(t,e,i){var n={get:function(){return w._get(t,e)}};t.modifiable&&(n.set=function(n){w._set(t,n,e)&&i(n,t)}),Object.defineProperty(e,t.name,n)},_get:function(t,e){return e["_"+t.name]},_set:function(t,e,i){var n="_"+t.name,s=i[n],r=t.transform(null!=e?e:t.defaultValue);return i[n]=r,r!==s}}),M=w,b=h.extend(function(){this._services={}},{getService:function(t){var e=this._services[t];if(!e)throw new Error("Service is not being managed with name: "+t);return e},setService:function(t,e){if(this._services[t])throw new Error("Service is already managed with name: "+t);e&&(this._services[t]=e)}}),B=new M([new g("background",!0,"white"),new g("backgroundAlpha",!0,1,k.abs),new g("element"),new g("foreground",!0,"black"),new g("foregroundAlpha",!0,1,k.abs),new g("level",!0,"L",k.toUpperCase),new g("mime",!0,"image/png"),new g("padding",!0,null,k.abs),new g("size",!0,100,k.abs),new g("value",!0,"")]),y=new b,O=h.extend(function(t){B.init(t,this,this.update.bind(this));var e=B.get("element",this),i=y.getService("element"),n=e&&i.isCanvas(e)?e:i.createCanvas(),s=e&&i.isImage(e)?e:i.createImage();this._canvasRenderer=new c(this,n,!0),this._imageRenderer=new m(this,s,s===e),this.update()},{get:function(){return B.getAll(this)},set:function(t){B.setAll(t,this)&&this.update()},toDataURL:function(t){return this.canvas.toDataURL(t||this.mime)},update:function(){var t=new p({level:this.level,value:this.value});this._canvasRenderer.render(t),this._imageRenderer.render(t)}},{use:function(t){y.setService(t.getName(),t)}});Object.defineProperties(O.prototype,{canvas:{get:function(){return this._canvasRenderer.getElement()}},image:{get:function(){return this._imageRenderer.getElement()}}});var A=O,L=h.extend({getName:function(){}}).extend({createCanvas:function(){},createImage:function(){},getName:function(){return"element"},isCanvas:function(t){},isImage:function(t){}}).extend({createCanvas:function(){return document.createElement("canvas")},createImage:function(){return document.createElement("img")},isCanvas:function(t){return t instanceof HTMLCanvasElement},isImage:function(t){return t instanceof HTMLImageElement}});return A.use(new L),A});
@@ -0,0 +1,10 @@
1
+ /*!
2
+ _______ _____ __ _ _______ _ _ _ _______ _ _ _______ _______
3
+ |______ | | \ | |______ | | | |_____| \ / |______ |______
4
+ ______| __|__ | \_| |______ |__|__| | | \/ |______ ______|
5
+
6
+ sine-waves v0.3.0 <https://github.com/isuttell/sine-waves>
7
+ Contributor(s): Isaac Suttell <isaac@isaacsuttell.com>
8
+ Last Build: 2014-12-03
9
+ */
10
+ !function(a,b){"use strict";"function"==typeof define&&"object"==typeof define.amd?define([],function(){return b(a)}):a.SineWaves=b(a)}(this,function(){"use strict";function a(a){if(this.options=i.defaults(this.options,a),this.el=this.options.el,delete this.options.el,!this.el)throw"No Canvas Selected";if(this.ctx=this.el.getContext("2d"),this.waves=this.options.waves,delete this.options.waves,!this.waves||!this.waves.length)throw"No waves specified";this.dpr=window.devicePixelRatio||1,this.updateDimensions(),window.addEventListener("resize",this.updateDimensions.bind(this)),this.setupUserFunctions(),this.easeFn=i.getFn(n,this.options.ease,"linear"),this.rotation=i.degreesToRadians(this.options.rotate),i.isType(this.options.running,"boolean")&&(this.running=this.options.running),this.setupWaveFns(),this.loop()}function b(a,b){return i.isType(a,"number")?a:(a=a.toString(),a.indexOf("%")>-1?(a=parseFloat(a),a>1&&(a/=100),b*a):a.indexOf("px")>-1?parseInt(a,10):void 0)}Function.prototype.bind||(Function.prototype.bind=function(a){if("function"!=typeof this)throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var b=Array.prototype.slice.call(arguments,1),c=this,d=function(){},e=function(){return c.apply(this instanceof d&&a?this:a,b.concat(Array.prototype.slice.call(arguments)))};return d.prototype=this.prototype,e.prototype=new d,e});for(var c=["ms","moz","webkit","o"],d=0;d<c.length&&!window.requestAnimationFrame;++d)window.requestAnimationFrame=window[c[d]+"RequestAnimationFrame"],window.cancelAnimationFrame=window[c[d]+"CancelAnimationFrame"]||window[c[d]+"CancelRequestAnimationFrame"];if(!window.requestAnimationFrame){var e=0;window.requestAnimationFrame=function(a){var b=(new Date).getTime(),c=Math.max(0,16-(b-e)),d=window.setTimeout(function(){a(b+c)},c);return e=b+c,d}}window.cancelAnimationFrame||(window.cancelAnimationFrame=function(a){clearTimeout(a)});var f=Math.PI/180,g=2*Math.PI,h=Math.PI/2,i={},j=i.isType=function(a,b){var c={}.toString.call(a).toLowerCase();return c==="[object "+b.toLowerCase()+"]"},k=i.isFunction=function(a){return j(a,"function")},l=i.isString=function(a){return j(a,"string")},m=(i.isNumber=function(a){return j(a,"number")},i.shallowClone=function(a){var b={};for(var c in a)a.hasOwnProperty(c)&&(b[c]=a[c]);return b}),n=(i.defaults=function(a,b){j(b,"object")||(b={});var c=m(a);for(var d in b)b.hasOwnProperty(d)&&(c[d]=b[d]);return c},i.degreesToRadians=function(a){if(!j(a,"number"))throw new TypeError("Degrees is not a number");return a*f},i.getFn=function(a,b,c){return k(b)?b:l(b)&&k(a[b.toLowerCase()])?a[b.toLowerCase()]:a[c]},{});n.linear=function(a,b){return b},n.sinein=function(a,b){return b*(Math.sin(a*Math.PI-h)+1)*.5},n.sineout=function(a,b){return b*(Math.sin(a*Math.PI+h)+1)*.5},n.sineinout=function(a,b){return b*(Math.sin(a*g-h)+1)*.5};var o={};o.sine=function(a){return Math.sin(a)},o.sin=o.sine,o.sign=function(a){return a=+a,0===a||isNaN(a)?a:a>0?1:-1},o.square=function(a){return o.sign(Math.sin(a*g))},o.sawtooth=function(a){return 2*(a-Math.floor(a+.5))},o.triangle=function(a){return Math.abs(o.sawtooth(a))},a.prototype.options={speed:10,rotate:0,ease:"Linear",wavesWidth:"95%"},a.prototype.setupWaveFns=function(){for(var a=-1,b=this.waves.length;++a<b;)this.waves[a].waveFn=i.getFn(o,this.waves[a].type,"sine")},a.prototype.setupUserFunctions=function(){i.isFunction(this.options.resizeEvent)&&(this.options.resizeEvent.call(this),window.addEventListener("resize",this.options.resizeEvent.bind(this))),i.isFunction(this.options.initialize)&&this.options.initialize.call(this)};var p={timeModifier:1,amplitude:50,wavelength:50,segmentLength:10,lineWidth:1,strokeStyle:"rgba(255, 255, 255, 0.2)",type:"Sine"};return a.prototype.getDimension=function(a){return i.isNumber(this.options[a])?this.options[a]:i.isFunction(this.options[a])?this.options[a].call(this,this.el):"width"===a?this.el.clientWidth:"height"===a?this.el.clientHeight:void 0},a.prototype.updateDimensions=function(){var a=this.getDimension("width"),c=this.getDimension("height");this.width=this.el.width=a*this.dpr,this.height=this.el.height=c*this.dpr,this.el.style.width=a+"px",this.el.style.height=c+"px",this.waveWidth=b(this.options.wavesWidth,this.width),this.waveLeft=(this.width-this.waveWidth)/2,this.yAxis=this.height/2},a.prototype.clear=function(){this.ctx.clearRect(0,0,this.width,this.height)},a.prototype.time=0,a.prototype.update=function(a){this.time=this.time-.007,"undefined"==typeof a&&(a=this.time);var b=-1,c=this.waves.length;for(this.clear(),this.ctx.save(),this.rotation>0&&(this.ctx.translate(this.width/2,this.height/2),this.ctx.rotate(this.rotation),this.ctx.translate(-this.width/2,-this.height/2));++b<c;){var d=this.waves[b].timeModifier||1;this.drawWave(a*d,this.waves[b])}this.ctx.restore(),b=void 0,c=void 0},a.prototype.getPoint=function(a,b,c){var d=a*this.options.speed+(-this.yAxis+b)/c.wavelength,e=c.waveFn.call(this,d,o),f=this.easeFn.call(this,b/this.waveWidth,c.amplitude);return d=b+this.waveLeft,e=f*e+this.yAxis,{x:d,y:e}},a.prototype.drawWave=function(a,b){b=i.defaults(p,b),this.ctx.lineWidth=b.lineWidth*this.dpr,this.ctx.strokeStyle=b.strokeStyle,this.ctx.lineCap="butt",this.ctx.lineJoin="round",this.ctx.beginPath(),this.ctx.moveTo(0,this.yAxis),this.ctx.lineTo(this.waveLeft,this.yAxis);var c,d;for(c=0;c<this.waveWidth;c+=b.segmentLength)d=this.getPoint(a,c,b),this.ctx.lineTo(d.x,d.y),d=void 0;c=void 0,b=void 0,this.ctx.lineTo(this.width,this.yAxis),this.ctx.stroke()},a.prototype.running=!0,a.prototype.loop=function(){this.running===!0&&this.update(),window.requestAnimationFrame(this.loop.bind(this))},a.prototype.Waves=o,a.prototype.Ease=n,a});
@@ -0,0 +1,54 @@
1
+ function calculateTimeSince(num){
2
+ const currentTime = Math.floor(Date.now()/1000);
3
+ const timestamp = parseInt(num);
4
+ const timeSince = currentTime - timestamp;
5
+
6
+ var timeAgo;
7
+ var timeTag;
8
+ var minute = 60;
9
+ var hour = 3600;
10
+ var day = 86400;
11
+ var week = 604800;
12
+ var month = 2.628e+6;
13
+ var year = 3.154e+7;
14
+
15
+ if (timeSince < minute ) {
16
+ timeAgo = 1;
17
+ timeTag = timeAgo < 2 ? 'MIN' : 'MINS';
18
+ } else if (timeSince > minute && timeSince < hour ) {
19
+ timeAgo = Math.ceil(timeSince / minute);
20
+ timeTag = timeAgo < 2 ? 'MIN' : 'MINS';
21
+ } else if (timeSince > hour && timeSince < day ) {
22
+ timeAgo = Math.floor(timeSince / hour);
23
+ timeTag = timeAgo < 2 ? 'HR' : 'HRS';
24
+ } else if (timeSince > day && timeSince < week) {
25
+ timeAgo = Math.floor(timeSince / day);
26
+ timeTag = timeAgo < 2 ? 'DAY' : 'DAYS';
27
+ } else if (timeSince > week && timeSince < month) {
28
+ timeAgo = Math.floor(timeSince / week);
29
+ timeTag = timeAgo < 2 ? 'WK' : 'WKS';
30
+ } else if (timeSince > month && timeSince < year) {
31
+ timeAgo = Math.floor(timeSince / month);
32
+ timeTag = timeAgo < 2 ? 'MONTH' : 'MONTHS';
33
+ } else if (timeSince > year) {
34
+ timeAgo = Math.floor(timeSince / year);
35
+ timeTag = timeAgo < 2 ? 'YR' : 'YRS';
36
+ }
37
+
38
+ return `${timeAgo}&nbsp;${timeTag} AGO`;
39
+ }
40
+
41
+ function populateCommentsTime(nodes) {
42
+ if (nodes) {
43
+ nodes.forEach(function(node) {
44
+ let durationTime = node.dataset.time;
45
+ let durationSeconds = Math.ceil(Date.parse(durationTime) / 1000) ;
46
+ let durationSince = calculateTimeSince(durationSeconds);
47
+ node.innerHTML = `${durationSince}`;
48
+ });
49
+ }
50
+ }
51
+
52
+ const durations = document.querySelectorAll('.comment_heading');
53
+
54
+ populateCommentsTime(durations);
@@ -0,0 +1,9 @@
1
+ // global variables
2
+ const hidden = "hidden";
3
+ const active = "active";
4
+
5
+ const doc = document.documentElement;
6
+ const parentURL = window.location.protocol + "//" + window.location.host + "/";
7
+ const staticman = Object.create(null);
8
+
9
+ const tAddress = 'Adresse';
data/assets/main.scss ADDED
@@ -0,0 +1,5 @@
1
+ ---
2
+ # Only the main Sass file needs front matter (the dashes are enough)
3
+ ---
4
+
5
+ @import "swift";