init 3
This commit is contained in:
90
node_modules/dom-helpers/esm/animate.js
generated
vendored
Normal file
90
node_modules/dom-helpers/esm/animate.js
generated
vendored
Normal file
@@ -0,0 +1,90 @@
|
||||
import css from './css';
|
||||
import hyphenate from './hyphenate';
|
||||
import isTransform from './isTransform';
|
||||
import transitionEnd from './transitionEnd';
|
||||
var reset = {
|
||||
transition: '',
|
||||
'transition-duration': '',
|
||||
'transition-delay': '',
|
||||
'transition-timing-function': ''
|
||||
};
|
||||
|
||||
// super lean animate function for transitions
|
||||
// doesn't support all translations to keep it matching the jquery API
|
||||
|
||||
/**
|
||||
* code in part from: Zepto 1.1.4 | zeptojs.com/license
|
||||
*/
|
||||
function _animate(_ref) {
|
||||
var node = _ref.node,
|
||||
properties = _ref.properties,
|
||||
_ref$duration = _ref.duration,
|
||||
duration = _ref$duration === void 0 ? 200 : _ref$duration,
|
||||
easing = _ref.easing,
|
||||
callback = _ref.callback;
|
||||
var cssProperties = [];
|
||||
var cssValues = {};
|
||||
var transforms = '';
|
||||
Object.keys(properties).forEach(function (key) {
|
||||
var value = properties[key];
|
||||
if (isTransform(key)) transforms += key + "(" + value + ") ";else {
|
||||
cssValues[key] = value;
|
||||
cssProperties.push(hyphenate(key));
|
||||
}
|
||||
});
|
||||
|
||||
if (transforms) {
|
||||
cssValues.transform = transforms;
|
||||
cssProperties.push('transform');
|
||||
}
|
||||
|
||||
function done(event) {
|
||||
if (event.target !== event.currentTarget) return;
|
||||
css(node, reset);
|
||||
if (callback) callback.call(this, event);
|
||||
}
|
||||
|
||||
if (duration > 0) {
|
||||
cssValues.transition = cssProperties.join(', ');
|
||||
cssValues['transition-duration'] = duration / 1000 + "s";
|
||||
cssValues['transition-delay'] = '0s';
|
||||
cssValues['transition-timing-function'] = easing || 'linear';
|
||||
}
|
||||
|
||||
var removeListener = transitionEnd(node, done, duration); // eslint-disable-next-line no-unused-expressions
|
||||
|
||||
node.clientLeft; // trigger page reflow
|
||||
|
||||
css(node, cssValues);
|
||||
return {
|
||||
cancel: function cancel() {
|
||||
removeListener();
|
||||
css(node, reset);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
function animate(nodeOrOptions, properties, duration, easing, callback) {
|
||||
if (!('nodeType' in nodeOrOptions)) {
|
||||
return _animate(nodeOrOptions);
|
||||
}
|
||||
|
||||
if (!properties) {
|
||||
throw new Error('must include properties to animate');
|
||||
}
|
||||
|
||||
if (typeof easing === 'function') {
|
||||
callback = easing;
|
||||
easing = '';
|
||||
}
|
||||
|
||||
return _animate({
|
||||
node: nodeOrOptions,
|
||||
properties: properties,
|
||||
duration: duration,
|
||||
easing: easing,
|
||||
callback: callback
|
||||
});
|
||||
}
|
||||
|
||||
export default animate;
|
||||
10
node_modules/dom-helpers/esm/childNodes.js
generated
vendored
Normal file
10
node_modules/dom-helpers/esm/childNodes.js
generated
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
var toArray = Function.prototype.bind.call(Function.prototype.call, [].slice);
|
||||
/**
|
||||
* Collects all child nodes of an element.
|
||||
*
|
||||
* @param node the node
|
||||
*/
|
||||
|
||||
export default function childNodes(node) {
|
||||
return node ? toArray(node.childNodes) : [];
|
||||
}
|
||||
30
node_modules/dom-helpers/esm/offset.js
generated
vendored
Normal file
30
node_modules/dom-helpers/esm/offset.js
generated
vendored
Normal file
@@ -0,0 +1,30 @@
|
||||
import contains from './contains';
|
||||
import ownerDocument from './ownerDocument';
|
||||
import scrollLeft from './scrollLeft';
|
||||
import scrollTop from './scrollTop';
|
||||
/**
|
||||
* Returns the offset of a given element, including top and left positions, width and height.
|
||||
*
|
||||
* @param node the element
|
||||
*/
|
||||
|
||||
export default function offset(node) {
|
||||
var doc = ownerDocument(node);
|
||||
var box = {
|
||||
top: 0,
|
||||
left: 0,
|
||||
height: 0,
|
||||
width: 0
|
||||
};
|
||||
var docElem = doc && doc.documentElement; // Make sure it's not a disconnected DOM node
|
||||
|
||||
if (!docElem || !contains(docElem, node)) return box;
|
||||
if (node.getBoundingClientRect !== undefined) box = node.getBoundingClientRect();
|
||||
box = {
|
||||
top: box.top + scrollTop(docElem) - (docElem.clientTop || 0),
|
||||
left: box.left + scrollLeft(docElem) - (docElem.clientLeft || 0),
|
||||
width: box.width,
|
||||
height: box.height
|
||||
};
|
||||
return box;
|
||||
}
|
||||
8
node_modules/dom-helpers/esm/types.d.ts
generated
vendored
Normal file
8
node_modules/dom-helpers/esm/types.d.ts
generated
vendored
Normal file
@@ -0,0 +1,8 @@
|
||||
import * as CSS from 'csstype'
|
||||
|
||||
type Styles = keyof CSSStyleDeclaration
|
||||
|
||||
export type HyphenProperty = keyof CSS.PropertiesHyphen
|
||||
export type CamelProperty = keyof CSS.Properties
|
||||
|
||||
export type Property = HyphenProperty | CamelProperty
|
||||
Reference in New Issue
Block a user