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 +21 -0
- package/README.md +27 -0
- package/_build/script.js +160 -0
- package/lanimate.min.js +201 -0
- package/package.json +47 -0
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
|
+
```
|
package/_build/script.js
ADDED
|
@@ -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(' ');
|
|
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;
|
package/lanimate.min.js
ADDED
|
@@ -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(' ');
|
|
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":"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","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
|
+
}
|