lanimate 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2022 David Vielhuber
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,27 @@
1
+ # 🥤 lanimate 🥤
2
+
3
+ lanimate is a small library that animates appearing dom elements.
4
+
5
+ ## installation
6
+
7
+ use it as a module:
8
+
9
+ ```
10
+ npm install lanimate
11
+ ```
12
+
13
+ ```js
14
+ import lanimate from 'lanimate';
15
+ ```
16
+
17
+ or include it the traditional way:
18
+
19
+ ```html
20
+ <script src="lanimate.min.js"></script>
21
+ ```
22
+
23
+ ## usage
24
+
25
+ ```js
26
+ new lanimate();
27
+ ```
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+
10
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
+
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
+
14
+ var lanimate = /*#__PURE__*/function () {
15
+ function lanimate() {
16
+ var _this = this;
17
+
18
+ (0, _classCallCheck2.default)(this, lanimate);
19
+ document.addEventListener('DOMContentLoaded', function () {
20
+ _this.ready();
21
+ });
22
+ window.addEventListener('load', function () {
23
+ _this.load();
24
+ });
25
+ }
26
+
27
+ (0, _createClass2.default)(lanimate, [{
28
+ key: "ready",
29
+ value: function ready() {
30
+ document.head.insertAdjacentHTML('beforeend', "\n <style>\n [data-lanimate] {\n opacity: 0;\n }\n /* disable on mobile */\n @media screen and (max-width: 1100px) {\n [data-lanimate] {\n transition: all 0s ease 0s;\n opacity: 1;\n }\n [data-lanimate='scrollX'] {\n transform: translateX(0px);\n }\n [data-lanimate='scrollY'] {\n transform: translateX(0px);\n }\n [data-lanimate='scale'] {\n transform: scale(1) translateY(0px);\n }\n [data-lanimate='rotate'] {\n transform: rotate(0deg);\n }\n }\n </style>\n ");
31
+ }
32
+ }, {
33
+ key: "traverseAllTextNodes",
34
+ value: function traverseAllTextNodes($el, $fn) {
35
+ var _this2 = this;
36
+
37
+ if ($el.childNodes.length > 0) {
38
+ $el.childNodes.forEach(function ($el2) {
39
+ if ($el2.nodeType === 3) {
40
+ $el2.textContent = $fn($el2.textContent);
41
+ } else {
42
+ _this2.traverseAllTextNodes($el2, $fn);
43
+ }
44
+ });
45
+ }
46
+ }
47
+ }, {
48
+ key: "load",
49
+ value: function load() {
50
+ var _this3 = this;
51
+
52
+ if (document.querySelectorAll('[data-lanimate-split]').length > 0) {
53
+ document.querySelectorAll('[data-lanimate-split]').forEach(function ($el) {
54
+ $el.setAttribute('data-aria-label', $el.innerText.replace(/(?:\r\n|\r|\n)/g, ' '));
55
+ $el.innerHTML = $el.innerHTML.split(' ').join('&nbsp;');
56
+ var shift = 0;
57
+
58
+ if ($el.getAttribute('data-lanimate-split') === 'char') {
59
+ _this3.traverseAllTextNodes($el, function ($text) {
60
+ return '%span%' + $text.split('').join('%/span%%span%') + '%/span%';
61
+ });
62
+
63
+ $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');
64
+ shift = 100;
65
+ }
66
+
67
+ if ($el.getAttribute('data-lanimate-split') === 'word') {
68
+ _this3.traverseAllTextNodes($el, function ($text) {
69
+ return '%span%' + $text.split(' ').join('%/span% %span%') + '%/span%';
70
+ });
71
+
72
+ $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');
73
+ shift = 250;
74
+ }
75
+
76
+ if ($el.getAttribute('data-lanimate-split') === 'line') {
77
+ $el.innerHTML = '<span>' + $el.innerHTML.split('<br>').join('</span><br/><span>') + '</span>';
78
+ shift = 500;
79
+ }
80
+
81
+ var index = 0;
82
+ $el.querySelectorAll('span').forEach(function ($el2, i) {
83
+ if ($el2.innerText.trim() == '') {
84
+ return;
85
+ }
86
+
87
+ $el2.setAttribute('data-lanimate', $el.getAttribute('data-lanimate'));
88
+ var delay = 0;
89
+
90
+ if ($el.hasAttribute('data-lanimate-delay')) {
91
+ delay = parseInt($el.getAttribute('data-lanimate-delay'));
92
+ }
93
+
94
+ if ($el.hasAttribute('data-lanimate-speed')) {
95
+ $el2.setAttribute('data-lanimate-speed', $el.getAttribute('data-lanimate-speed'));
96
+ delay *= 1 / parseInt($el.getAttribute('data-lanimate-speed'));
97
+ }
98
+
99
+ $el2.setAttribute('data-lanimate-delay', delay + shift * index);
100
+ index++;
101
+ });
102
+ $el.removeAttribute('data-lanimate');
103
+ $el.removeAttribute('data-lanimate-delay');
104
+ $el.removeAttribute('data-lanimate-speed');
105
+ });
106
+ }
107
+
108
+ if (document.querySelectorAll('[data-lanimate-speed]').length > 0) {
109
+ document.querySelectorAll('[data-lanimate-speed]').forEach(function ($el) {
110
+ var speed = parseInt($el.getAttribute('data-lanimate-speed')) / 1000;
111
+ setTimeout(function () {
112
+ $el.style.transitionDuration = speed + 's, ' + speed + 's';
113
+ }, 10);
114
+ });
115
+ }
116
+
117
+ if (document.querySelectorAll('[data-lanimate]').length > 0) {
118
+ document.querySelectorAll('[data-lanimate]').forEach(function ($el) {
119
+ _this3.start($el);
120
+
121
+ window.addEventListener('scroll', function () {
122
+ _this3.start($el);
123
+ });
124
+ });
125
+ }
126
+
127
+ document.head.insertAdjacentHTML('beforeend', "\n <style>\n [data-lanimate='fade'] {\n }\n [data-lanimate='scrollX'] {\n transform: translateX(30px);\n }\n [data-lanimate='scrollY'] {\n transform: translateY(30px);\n }\n [data-lanimate='scale'] {\n transform: scale(1.1) translateY(30px);\n }\n [data-lanimate='rotate'] {\n transform: rotate(15deg);\n transform-origin: 0 0;\n }\n [data-lanimate-started] {\n transition: opacity 1s ease-in-out, transform 1s ease-in-out;\n opacity: 1;\n }\n [data-lanimate-split] span {\n display:inline-block;\n }\n [data-lanimate='fade'][data-lanimate-started] {\n }\n [data-lanimate='scrollX'][data-lanimate-started] {\n transform: translateX(0px);\n }\n [data-lanimate='scrollY'][data-lanimate-started] {\n transform: translateX(0px);\n }\n [data-lanimate='scale'][data-lanimate-started] {\n transform: scale(1) translateY(0px);\n }\n [data-lanimate='rotate'][data-lanimate-started] {\n transform: rotate(0deg);\n }\n </style>\n ");
128
+ }
129
+ }, {
130
+ key: "start",
131
+ value: function start($el) {
132
+ if (!$el.hasAttribute('data-lanimate-started') && this.scrollTop() + window.innerHeight >= this.offsetTop($el)) {
133
+ var delay = 0;
134
+
135
+ if ($el.hasAttribute('data-lanimate-delay')) {
136
+ delay = parseInt($el.getAttribute('data-lanimate-delay'));
137
+ }
138
+
139
+ setTimeout(function () {
140
+ $el.setAttribute('data-lanimate-started', 'true');
141
+ }, delay);
142
+ }
143
+ }
144
+ }, {
145
+ key: "scrollTop",
146
+ value: function scrollTop() {
147
+ var doc = document.documentElement;
148
+ return (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0);
149
+ }
150
+ }, {
151
+ key: "offsetTop",
152
+ value: function offsetTop($el) {
153
+ return $el.getBoundingClientRect().top + window.pageYOffset - document.documentElement.clientTop;
154
+ }
155
+ }]);
156
+ return lanimate;
157
+ }();
158
+
159
+ exports.default = lanimate;
160
+ window.lanimate = lanimate;
@@ -0,0 +1,201 @@
1
+ (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){
2
+ "use strict";
3
+
4
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
5
+
6
+ Object.defineProperty(exports, "__esModule", {
7
+ value: true
8
+ });
9
+ exports.default = void 0;
10
+
11
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
12
+
13
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
14
+
15
+ var lanimate = /*#__PURE__*/function () {
16
+ function lanimate() {
17
+ var _this = this;
18
+
19
+ (0, _classCallCheck2.default)(this, lanimate);
20
+ document.addEventListener('DOMContentLoaded', function () {
21
+ _this.ready();
22
+ });
23
+ window.addEventListener('load', function () {
24
+ _this.load();
25
+ });
26
+ }
27
+
28
+ (0, _createClass2.default)(lanimate, [{
29
+ key: "ready",
30
+ value: function ready() {
31
+ document.head.insertAdjacentHTML('beforeend', "\n <style>\n [data-lanimate] {\n opacity: 0;\n }\n /* disable on mobile */\n @media screen and (max-width: 1100px) {\n [data-lanimate] {\n transition: all 0s ease 0s;\n opacity: 1;\n }\n [data-lanimate='scrollX'] {\n transform: translateX(0px);\n }\n [data-lanimate='scrollY'] {\n transform: translateX(0px);\n }\n [data-lanimate='scale'] {\n transform: scale(1) translateY(0px);\n }\n [data-lanimate='rotate'] {\n transform: rotate(0deg);\n }\n }\n </style>\n ");
32
+ }
33
+ }, {
34
+ key: "traverseAllTextNodes",
35
+ value: function traverseAllTextNodes($el, $fn) {
36
+ var _this2 = this;
37
+
38
+ if ($el.childNodes.length > 0) {
39
+ $el.childNodes.forEach(function ($el2) {
40
+ if ($el2.nodeType === 3) {
41
+ $el2.textContent = $fn($el2.textContent);
42
+ } else {
43
+ _this2.traverseAllTextNodes($el2, $fn);
44
+ }
45
+ });
46
+ }
47
+ }
48
+ }, {
49
+ key: "load",
50
+ value: function load() {
51
+ var _this3 = this;
52
+
53
+ if (document.querySelectorAll('[data-lanimate-split]').length > 0) {
54
+ document.querySelectorAll('[data-lanimate-split]').forEach(function ($el) {
55
+ $el.setAttribute('data-aria-label', $el.innerText.replace(/(?:\r\n|\r|\n)/g, ' '));
56
+ $el.innerHTML = $el.innerHTML.split(' ').join('&nbsp;');
57
+ var shift = 0;
58
+
59
+ if ($el.getAttribute('data-lanimate-split') === 'char') {
60
+ _this3.traverseAllTextNodes($el, function ($text) {
61
+ return '%span%' + $text.split('').join('%/span%%span%') + '%/span%';
62
+ });
63
+
64
+ $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');
65
+ shift = 100;
66
+ }
67
+
68
+ if ($el.getAttribute('data-lanimate-split') === 'word') {
69
+ _this3.traverseAllTextNodes($el, function ($text) {
70
+ return '%span%' + $text.split(' ').join('%/span% %span%') + '%/span%';
71
+ });
72
+
73
+ $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');
74
+ shift = 250;
75
+ }
76
+
77
+ if ($el.getAttribute('data-lanimate-split') === 'line') {
78
+ $el.innerHTML = '<span>' + $el.innerHTML.split('<br>').join('</span><br/><span>') + '</span>';
79
+ shift = 500;
80
+ }
81
+
82
+ var index = 0;
83
+ $el.querySelectorAll('span').forEach(function ($el2, i) {
84
+ if ($el2.innerText.trim() == '') {
85
+ return;
86
+ }
87
+
88
+ $el2.setAttribute('data-lanimate', $el.getAttribute('data-lanimate'));
89
+ var delay = 0;
90
+
91
+ if ($el.hasAttribute('data-lanimate-delay')) {
92
+ delay = parseInt($el.getAttribute('data-lanimate-delay'));
93
+ }
94
+
95
+ if ($el.hasAttribute('data-lanimate-speed')) {
96
+ $el2.setAttribute('data-lanimate-speed', $el.getAttribute('data-lanimate-speed'));
97
+ delay *= 1 / parseInt($el.getAttribute('data-lanimate-speed'));
98
+ }
99
+
100
+ $el2.setAttribute('data-lanimate-delay', delay + shift * index);
101
+ index++;
102
+ });
103
+ $el.removeAttribute('data-lanimate');
104
+ $el.removeAttribute('data-lanimate-delay');
105
+ $el.removeAttribute('data-lanimate-speed');
106
+ });
107
+ }
108
+
109
+ if (document.querySelectorAll('[data-lanimate-speed]').length > 0) {
110
+ document.querySelectorAll('[data-lanimate-speed]').forEach(function ($el) {
111
+ var speed = parseInt($el.getAttribute('data-lanimate-speed')) / 1000;
112
+ setTimeout(function () {
113
+ $el.style.transitionDuration = speed + 's, ' + speed + 's';
114
+ }, 10);
115
+ });
116
+ }
117
+
118
+ if (document.querySelectorAll('[data-lanimate]').length > 0) {
119
+ document.querySelectorAll('[data-lanimate]').forEach(function ($el) {
120
+ _this3.start($el);
121
+
122
+ window.addEventListener('scroll', function () {
123
+ _this3.start($el);
124
+ });
125
+ });
126
+ }
127
+
128
+ document.head.insertAdjacentHTML('beforeend', "\n <style>\n [data-lanimate='fade'] {\n }\n [data-lanimate='scrollX'] {\n transform: translateX(30px);\n }\n [data-lanimate='scrollY'] {\n transform: translateY(30px);\n }\n [data-lanimate='scale'] {\n transform: scale(1.1) translateY(30px);\n }\n [data-lanimate='rotate'] {\n transform: rotate(15deg);\n transform-origin: 0 0;\n }\n [data-lanimate-started] {\n transition: opacity 1s ease-in-out, transform 1s ease-in-out;\n opacity: 1;\n }\n [data-lanimate-split] span {\n display:inline-block;\n }\n [data-lanimate='fade'][data-lanimate-started] {\n }\n [data-lanimate='scrollX'][data-lanimate-started] {\n transform: translateX(0px);\n }\n [data-lanimate='scrollY'][data-lanimate-started] {\n transform: translateX(0px);\n }\n [data-lanimate='scale'][data-lanimate-started] {\n transform: scale(1) translateY(0px);\n }\n [data-lanimate='rotate'][data-lanimate-started] {\n transform: rotate(0deg);\n }\n </style>\n ");
129
+ }
130
+ }, {
131
+ key: "start",
132
+ value: function start($el) {
133
+ if (!$el.hasAttribute('data-lanimate-started') && this.scrollTop() + window.innerHeight >= this.offsetTop($el)) {
134
+ var delay = 0;
135
+
136
+ if ($el.hasAttribute('data-lanimate-delay')) {
137
+ delay = parseInt($el.getAttribute('data-lanimate-delay'));
138
+ }
139
+
140
+ setTimeout(function () {
141
+ $el.setAttribute('data-lanimate-started', 'true');
142
+ }, delay);
143
+ }
144
+ }
145
+ }, {
146
+ key: "scrollTop",
147
+ value: function scrollTop() {
148
+ var doc = document.documentElement;
149
+ return (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0);
150
+ }
151
+ }, {
152
+ key: "offsetTop",
153
+ value: function offsetTop($el) {
154
+ return $el.getBoundingClientRect().top + window.pageYOffset - document.documentElement.clientTop;
155
+ }
156
+ }]);
157
+ return lanimate;
158
+ }();
159
+
160
+ exports.default = lanimate;
161
+ window.lanimate = lanimate;
162
+
163
+ },{"@babel/runtime/helpers/classCallCheck":2,"@babel/runtime/helpers/createClass":3,"@babel/runtime/helpers/interopRequireDefault":4}],2:[function(require,module,exports){
164
+ function _classCallCheck(instance, Constructor) {
165
+ if (!(instance instanceof Constructor)) {
166
+ throw new TypeError("Cannot call a class as a function");
167
+ }
168
+ }
169
+
170
+ module.exports = _classCallCheck, module.exports.__esModule = true, module.exports["default"] = module.exports;
171
+ },{}],3:[function(require,module,exports){
172
+ function _defineProperties(target, props) {
173
+ for (var i = 0; i < props.length; i++) {
174
+ var descriptor = props[i];
175
+ descriptor.enumerable = descriptor.enumerable || false;
176
+ descriptor.configurable = true;
177
+ if ("value" in descriptor) descriptor.writable = true;
178
+ Object.defineProperty(target, descriptor.key, descriptor);
179
+ }
180
+ }
181
+
182
+ function _createClass(Constructor, protoProps, staticProps) {
183
+ if (protoProps) _defineProperties(Constructor.prototype, protoProps);
184
+ if (staticProps) _defineProperties(Constructor, staticProps);
185
+ Object.defineProperty(Constructor, "prototype", {
186
+ writable: false
187
+ });
188
+ return Constructor;
189
+ }
190
+
191
+ module.exports = _createClass, module.exports.__esModule = true, module.exports["default"] = module.exports;
192
+ },{}],4:[function(require,module,exports){
193
+ function _interopRequireDefault(obj) {
194
+ return obj && obj.__esModule ? obj : {
195
+ "default": obj
196
+ };
197
+ }
198
+
199
+ module.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports["default"] = module.exports;
200
+ },{}]},{},[1])
201
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","_js/script.js","node_modules/@babel/runtime/helpers/classCallCheck.js","node_modules/@babel/runtime/helpers/createClass.js","node_modules/@babel/runtime/helpers/interopRequireDefault.js"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;ICAqB,Q;AACjB,sBAAc;AAAA;;AAAA;AACV,IAAA,QAAQ,CAAC,gBAAT,CAA0B,kBAA1B,EAA8C,YAAM;AAChD,MAAA,KAAI,CAAC,KAAL;AACH,KAFD;AAGA,IAAA,MAAM,CAAC,gBAAP,CAAwB,MAAxB,EAAgC,YAAM;AAClC,MAAA,KAAI,CAAC,IAAL;AACH,KAFD;AAGH;;;;WACD,iBAAQ;AACJ,MAAA,QAAQ,CAAC,IAAT,CAAc,kBAAd,CACI,WADJ;AA6BH;;;WACD,8BAAqB,GAArB,EAA0B,GAA1B,EAA+B;AAAA;;AAC3B,UAAI,GAAG,CAAC,UAAJ,CAAe,MAAf,GAAwB,CAA5B,EAA+B;AAC3B,QAAA,GAAG,CAAC,UAAJ,CAAe,OAAf,CAAuB,UAAA,IAAI,EAAI;AAC3B,cAAI,IAAI,CAAC,QAAL,KAAkB,CAAtB,EAAyB;AACrB,YAAA,IAAI,CAAC,WAAL,GAAmB,GAAG,CAAC,IAAI,CAAC,WAAN,CAAtB;AACH,WAFD,MAEO;AACH,YAAA,MAAI,CAAC,oBAAL,CAA0B,IAA1B,EAAgC,GAAhC;AACH;AACJ,SAND;AAOH;AACJ;;;WACD,gBAAO;AAAA;;AACH,UAAI,QAAQ,CAAC,gBAAT,CAA0B,uBAA1B,EAAmD,MAAnD,GAA4D,CAAhE,EAAmE;AAC/D,QAAA,QAAQ,CAAC,gBAAT,CAA0B,uBAA1B,EAAmD,OAAnD,CAA2D,UAAA,GAAG,EAAI;AAC9D,UAAA,GAAG,CAAC,YAAJ,CAAiB,iBAAjB,EAAoC,GAAG,CAAC,SAAJ,CAAc,OAAd,CAAsB,iBAAtB,EAAyC,GAAzC,CAApC;AACA,UAAA,GAAG,CAAC,SAAJ,GAAgB,GAAG,CAAC,SAAJ,CAAc,KAAd,CAAoB,GAApB,EAAyB,IAAzB,CAA8B,QAA9B,CAAhB;AACA,cAAI,KAAK,GAAG,CAAZ;;AACA,cAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,MAA4C,MAAhD,EAAwD;AACpD,YAAA,MAAI,CAAC,oBAAL,CAA0B,GAA1B,EAA+B,UAAA,KAAK,EAAI;AACpC,qBAAO,WAAW,KAAK,CAAC,KAAN,CAAY,EAAZ,EAAgB,IAAhB,CAAqB,eAArB,CAAX,GAAmD,SAA1D;AACH,aAFD;;AAGA,YAAA,GAAG,CAAC,SAAJ,GAAgB,GAAG,CAAC,SAAJ,CAAc,KAAd,CAAoB,QAApB,EAA8B,IAA9B,CAAmC,QAAnC,EAA6C,KAA7C,CAAmD,SAAnD,EAA8D,IAA9D,CAAmE,SAAnE,CAAhB;AACA,YAAA,KAAK,GAAG,GAAR;AACH;;AACD,cAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,MAA4C,MAAhD,EAAwD;AACpD,YAAA,MAAI,CAAC,oBAAL,CAA0B,GAA1B,EAA+B,UAAA,KAAK,EAAI;AACpC,qBAAO,WAAW,KAAK,CAAC,KAAN,CAAY,GAAZ,EAAiB,IAAjB,CAAsB,gBAAtB,CAAX,GAAqD,SAA5D;AACH,aAFD;;AAGA,YAAA,GAAG,CAAC,SAAJ,GAAgB,GAAG,CAAC,SAAJ,CAAc,KAAd,CAAoB,QAApB,EAA8B,IAA9B,CAAmC,QAAnC,EAA6C,KAA7C,CAAmD,SAAnD,EAA8D,IAA9D,CAAmE,SAAnE,CAAhB;AACA,YAAA,KAAK,GAAG,GAAR;AACH;;AACD,cAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,MAA4C,MAAhD,EAAwD;AACpD,YAAA,GAAG,CAAC,SAAJ,GAAgB,WAAW,GAAG,CAAC,SAAJ,CAAc,KAAd,CAAoB,MAApB,EAA4B,IAA5B,CAAiC,oBAAjC,CAAX,GAAoE,SAApF;AACA,YAAA,KAAK,GAAG,GAAR;AACH;;AACD,cAAI,KAAK,GAAG,CAAZ;AACA,UAAA,GAAG,CAAC,gBAAJ,CAAqB,MAArB,EAA6B,OAA7B,CAAqC,UAAC,IAAD,EAAO,CAAP,EAAa;AAC9C,gBAAI,IAAI,CAAC,SAAL,CAAe,IAAf,MAAyB,EAA7B,EAAiC;AAC7B;AACH;;AACD,YAAA,IAAI,CAAC,YAAL,CAAkB,eAAlB,EAAmC,GAAG,CAAC,YAAJ,CAAiB,eAAjB,CAAnC;AACA,gBAAI,KAAK,GAAG,CAAZ;;AACA,gBAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAJ,EAA6C;AACzC,cAAA,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAD,CAAhB;AACH;;AACD,gBAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAJ,EAA6C;AACzC,cAAA,IAAI,CAAC,YAAL,CAAkB,qBAAlB,EAAyC,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAzC;AACA,cAAA,KAAK,IAAI,IAAI,QAAQ,CAAC,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAD,CAArB;AACH;;AACD,YAAA,IAAI,CAAC,YAAL,CAAkB,qBAAlB,EAAyC,KAAK,GAAG,KAAK,GAAG,KAAzD;AACA,YAAA,KAAK;AACR,WAfD;AAgBA,UAAA,GAAG,CAAC,eAAJ,CAAoB,eAApB;AACA,UAAA,GAAG,CAAC,eAAJ,CAAoB,qBAApB;AACA,UAAA,GAAG,CAAC,eAAJ,CAAoB,qBAApB;AACH,SA1CD;AA2CH;;AACD,UAAI,QAAQ,CAAC,gBAAT,CAA0B,uBAA1B,EAAmD,MAAnD,GAA4D,CAAhE,EAAmE;AAC/D,QAAA,QAAQ,CAAC,gBAAT,CAA0B,uBAA1B,EAAmD,OAAnD,CAA2D,UAAA,GAAG,EAAI;AAC9D,cAAI,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAD,CAAR,GAAoD,IAAhE;AACA,UAAA,UAAU,CAAC,YAAM;AACb,YAAA,GAAG,CAAC,KAAJ,CAAU,kBAAV,GAA+B,KAAK,GAAG,KAAR,GAAgB,KAAhB,GAAwB,GAAvD;AACH,WAFS,EAEP,EAFO,CAAV;AAGH,SALD;AAMH;;AACD,UAAI,QAAQ,CAAC,gBAAT,CAA0B,iBAA1B,EAA6C,MAA7C,GAAsD,CAA1D,EAA6D;AACzD,QAAA,QAAQ,CAAC,gBAAT,CAA0B,iBAA1B,EAA6C,OAA7C,CAAqD,UAAA,GAAG,EAAI;AACxD,UAAA,MAAI,CAAC,KAAL,CAAW,GAAX;;AACA,UAAA,MAAM,CAAC,gBAAP,CAAwB,QAAxB,EAAkC,YAAM;AACpC,YAAA,MAAI,CAAC,KAAL,CAAW,GAAX;AACH,WAFD;AAGH,SALD;AAMH;;AACD,MAAA,QAAQ,CAAC,IAAT,CAAc,kBAAd,CACI,WADJ;AA2CH;;;WACD,eAAM,GAAN,EAAW;AACP,UACI,CAAC,GAAG,CAAC,YAAJ,CAAiB,uBAAjB,CAAD,IACA,KAAK,SAAL,KAAmB,MAAM,CAAC,WAA1B,IAAyC,KAAK,SAAL,CAAe,GAAf,CAF7C,EAGE;AACE,YAAI,KAAK,GAAG,CAAZ;;AACA,YAAI,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAJ,EAA6C;AACzC,UAAA,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,YAAJ,CAAiB,qBAAjB,CAAD,CAAhB;AACH;;AACD,QAAA,UAAU,CAAC,YAAM;AACb,UAAA,GAAG,CAAC,YAAJ,CAAiB,uBAAjB,EAA0C,MAA1C;AACH,SAFS,EAEP,KAFO,CAAV;AAGH;AACJ;;;WACD,qBAAY;AACR,UAAI,GAAG,GAAG,QAAQ,CAAC,eAAnB;AACA,aAAO,CAAC,MAAM,CAAC,WAAP,IAAsB,GAAG,CAAC,SAA3B,KAAyC,GAAG,CAAC,SAAJ,IAAiB,CAA1D,CAAP;AACH;;;WACD,mBAAU,GAAV,EAAe;AACX,aAAO,GAAG,CAAC,qBAAJ,GAA4B,GAA5B,GAAkC,MAAM,CAAC,WAAzC,GAAuD,QAAQ,CAAC,eAAT,CAAyB,SAAvF;AACH;;;;;;AAGL,MAAM,CAAC,QAAP,GAAkB,QAAlB;;;ACpLA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c=\"function\"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error(\"Cannot find module '\"+i+\"'\");throw a.code=\"MODULE_NOT_FOUND\",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u=\"function\"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()","export default class lanimate {\n    constructor() {\n        document.addEventListener('DOMContentLoaded', () => {\n            this.ready();\n        });\n        window.addEventListener('load', () => {\n            this.load();\n        });\n    }\n    ready() {\n        document.head.insertAdjacentHTML(\n            'beforeend',\n            `\n            <style>\n                [data-lanimate] {\n                    opacity: 0;\n                }\n                /* disable on mobile */\n                @media screen and (max-width: 1100px) {\n                    [data-lanimate] {\n                        transition: all 0s ease 0s;\n                        opacity: 1;\n                    }\n                    [data-lanimate='scrollX'] {\n                        transform: translateX(0px);\n                    }\n                    [data-lanimate='scrollY'] {\n                        transform: translateX(0px);\n                    }\n                    [data-lanimate='scale'] {\n                        transform: scale(1) translateY(0px);\n                    }\n                    [data-lanimate='rotate'] {\n                        transform: rotate(0deg);\n                    }\n                }\n            </style>\n            `\n        );\n    }\n    traverseAllTextNodes($el, $fn) {\n        if ($el.childNodes.length > 0) {\n            $el.childNodes.forEach($el2 => {\n                if ($el2.nodeType === 3) {\n                    $el2.textContent = $fn($el2.textContent);\n                } else {\n                    this.traverseAllTextNodes($el2, $fn);\n                }\n            });\n        }\n    }\n    load() {\n        if (document.querySelectorAll('[data-lanimate-split]').length > 0) {\n            document.querySelectorAll('[data-lanimate-split]').forEach($el => {\n                $el.setAttribute('data-aria-label', $el.innerText.replace(/(?:\\r\\n|\\r|\\n)/g, ' '));\n                $el.innerHTML = $el.innerHTML.split(' ').join('&nbsp;');\n                let shift = 0;\n                if ($el.getAttribute('data-lanimate-split') === 'char') {\n                    this.traverseAllTextNodes($el, $text => {\n                        return '%span%' + $text.split('').join('%/span%%span%') + '%/span%';\n                    });\n                    $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');\n                    shift = 100;\n                }\n                if ($el.getAttribute('data-lanimate-split') === 'word') {\n                    this.traverseAllTextNodes($el, $text => {\n                        return '%span%' + $text.split(' ').join('%/span% %span%') + '%/span%';\n                    });\n                    $el.innerHTML = $el.innerHTML.split('%span%').join('<span>').split('%/span%').join('</span>');\n                    shift = 250;\n                }\n                if ($el.getAttribute('data-lanimate-split') === 'line') {\n                    $el.innerHTML = '<span>' + $el.innerHTML.split('<br>').join('</span><br/><span>') + '</span>';\n                    shift = 500;\n                }\n                let index = 0;\n                $el.querySelectorAll('span').forEach(($el2, i) => {\n                    if ($el2.innerText.trim() == '') {\n                        return;\n                    }\n                    $el2.setAttribute('data-lanimate', $el.getAttribute('data-lanimate'));\n                    let delay = 0;\n                    if ($el.hasAttribute('data-lanimate-delay')) {\n                        delay = parseInt($el.getAttribute('data-lanimate-delay'));\n                    }\n                    if ($el.hasAttribute('data-lanimate-speed')) {\n                        $el2.setAttribute('data-lanimate-speed', $el.getAttribute('data-lanimate-speed'));\n                        delay *= 1 / parseInt($el.getAttribute('data-lanimate-speed'));\n                    }\n                    $el2.setAttribute('data-lanimate-delay', delay + shift * index);\n                    index++;\n                });\n                $el.removeAttribute('data-lanimate');\n                $el.removeAttribute('data-lanimate-delay');\n                $el.removeAttribute('data-lanimate-speed');\n            });\n        }\n        if (document.querySelectorAll('[data-lanimate-speed]').length > 0) {\n            document.querySelectorAll('[data-lanimate-speed]').forEach($el => {\n                let speed = parseInt($el.getAttribute('data-lanimate-speed')) / 1000;\n                setTimeout(() => {\n                    $el.style.transitionDuration = speed + 's, ' + speed + 's';\n                }, 10);\n            });\n        }\n        if (document.querySelectorAll('[data-lanimate]').length > 0) {\n            document.querySelectorAll('[data-lanimate]').forEach($el => {\n                this.start($el);\n                window.addEventListener('scroll', () => {\n                    this.start($el);\n                });\n            });\n        }\n        document.head.insertAdjacentHTML(\n            'beforeend',\n            `\n            <style>\n                [data-lanimate='fade'] {\n                }\n                [data-lanimate='scrollX'] {\n                    transform: translateX(30px);\n                }\n                [data-lanimate='scrollY'] {\n                    transform: translateY(30px);\n                }\n                [data-lanimate='scale'] {\n                    transform: scale(1.1) translateY(30px);\n                }\n                [data-lanimate='rotate'] {\n                    transform: rotate(15deg);\n                    transform-origin: 0 0;\n                }\n                [data-lanimate-started] {\n                    transition: opacity 1s ease-in-out, transform 1s ease-in-out;\n                    opacity: 1;\n                }\n                [data-lanimate-split] span {\n                    display:inline-block;\n                }\n                [data-lanimate='fade'][data-lanimate-started] {\n                }\n                [data-lanimate='scrollX'][data-lanimate-started] {\n                    transform: translateX(0px);\n                }\n                [data-lanimate='scrollY'][data-lanimate-started] {\n                    transform: translateX(0px);\n                }\n                [data-lanimate='scale'][data-lanimate-started] {\n                    transform: scale(1) translateY(0px);\n                }\n                [data-lanimate='rotate'][data-lanimate-started] {\n                    transform: rotate(0deg);\n                }\n            </style>\n            `\n        );\n    }\n    start($el) {\n        if (\n            !$el.hasAttribute('data-lanimate-started') &&\n            this.scrollTop() + window.innerHeight >= this.offsetTop($el)\n        ) {\n            let delay = 0;\n            if ($el.hasAttribute('data-lanimate-delay')) {\n                delay = parseInt($el.getAttribute('data-lanimate-delay'));\n            }\n            setTimeout(() => {\n                $el.setAttribute('data-lanimate-started', 'true');\n            }, delay);\n        }\n    }\n    scrollTop() {\n        let doc = document.documentElement;\n        return (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0);\n    }\n    offsetTop($el) {\n        return $el.getBoundingClientRect().top + window.pageYOffset - document.documentElement.clientTop;\n    }\n}\n\nwindow.lanimate = lanimate;\n","function _classCallCheck(instance, Constructor) {\n  if (!(instance instanceof Constructor)) {\n    throw new TypeError(\"Cannot call a class as a function\");\n  }\n}\n\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _defineProperties(target, props) {\n  for (var i = 0; i < props.length; i++) {\n    var descriptor = props[i];\n    descriptor.enumerable = descriptor.enumerable || false;\n    descriptor.configurable = true;\n    if (\"value\" in descriptor) descriptor.writable = true;\n    Object.defineProperty(target, descriptor.key, descriptor);\n  }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n  if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n  if (staticProps) _defineProperties(Constructor, staticProps);\n  Object.defineProperty(Constructor, \"prototype\", {\n    writable: false\n  });\n  return Constructor;\n}\n\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n}\n\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;"]}
package/package.json ADDED
@@ -0,0 +1,47 @@
1
+ {
2
+ "name": "lanimate",
3
+ "version": "1.0.1",
4
+ "main": "_build/script.js",
5
+ "files": [
6
+ "_build/*.js",
7
+ "lanimate.min.js"
8
+ ],
9
+ "repository": "git@github.com:vielhuber/lanimate.git",
10
+ "author": "David Vielhuber <david@vielhuber.de>",
11
+ "license": "MIT",
12
+ "description": "",
13
+ "scripts": {
14
+ "js:browserify": "browserify ./_js/script.js --outfile ./lanimate.min.js --debug --transform babelify",
15
+ "js:minify": "terser --compress --mangle --output ./lanimate.min.js ./lanimate.min.js",
16
+ "js:babel": "npx babel ./_js/ --out-dir ./_build/",
17
+ "js": "npm-run-all --sequential js:browserify js:minify js:babel",
18
+ "js:dev": "npm-run-all --sequential js:browserify js:babel",
19
+ "watch:js": "onchange ./_js/*.js --initial --poll 50 --delay 0 --await-write-finish 50 -- npm run js:dev",
20
+ "dev": "npm-run-all --parallel watch:*",
21
+ "prod": "npm-run-all --parallel js"
22
+ },
23
+ "dependencies": {
24
+ "@babel/runtime": "^7.16.7",
25
+ "mdn-polyfills": "^5.20.0",
26
+ "onchange": "^7.1.0"
27
+ },
28
+ "devDependencies": {
29
+ "auto-changelog": "^2.3.0",
30
+ "@babel/cli": "^7.16.8",
31
+ "@babel/core": "^7.16.12",
32
+ "@babel/plugin-proposal-class-properties": "^7.16.7",
33
+ "@babel/plugin-proposal-optional-chaining": "^7.16.7",
34
+ "@babel/plugin-transform-runtime": "^7.16.10",
35
+ "@babel/polyfill": "^7.11.5",
36
+ "@babel/preset-env": "^7.16.11",
37
+ "babelify": "^10.0.0",
38
+ "browserify": "^17.0.0",
39
+ "npm-run-all": "^4.1.5",
40
+ "terser": "^5.10.0"
41
+ },
42
+ "browserslist": [
43
+ "ie >= 11",
44
+ "> 0.25%",
45
+ "not dead"
46
+ ]
47
+ }