UNPKG

2.96 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3// Bindig `requestAnimationFrame` like this fixes a bug in IE/Edge. See #360 and #409.
4var raf = (typeof window !== 'undefined' && (window.requestAnimationFrame).bind(window)) || setTimeout;
5var nextFrame = function (fn) { raf(function () { raf(fn); }); };
6var reflowForced = false;
7function setNextFrame(obj, prop, val) {
8 nextFrame(function () { obj[prop] = val; });
9}
10function updateStyle(oldVnode, vnode) {
11 var cur, name, elm = vnode.elm, oldStyle = oldVnode.data.style, style = vnode.data.style;
12 if (!oldStyle && !style)
13 return;
14 if (oldStyle === style)
15 return;
16 oldStyle = oldStyle || {};
17 style = style || {};
18 var oldHasDel = 'delayed' in oldStyle;
19 for (name in oldStyle) {
20 if (!style[name]) {
21 if (name[0] === '-' && name[1] === '-') {
22 elm.style.removeProperty(name);
23 }
24 else {
25 elm.style[name] = '';
26 }
27 }
28 }
29 for (name in style) {
30 cur = style[name];
31 if (name === 'delayed' && style.delayed) {
32 for (var name2 in style.delayed) {
33 cur = style.delayed[name2];
34 if (!oldHasDel || cur !== oldStyle.delayed[name2]) {
35 setNextFrame(elm.style, name2, cur);
36 }
37 }
38 }
39 else if (name !== 'remove' && cur !== oldStyle[name]) {
40 if (name[0] === '-' && name[1] === '-') {
41 elm.style.setProperty(name, cur);
42 }
43 else {
44 elm.style[name] = cur;
45 }
46 }
47 }
48}
49function applyDestroyStyle(vnode) {
50 var style, name, elm = vnode.elm, s = vnode.data.style;
51 if (!s || !(style = s.destroy))
52 return;
53 for (name in style) {
54 elm.style[name] = style[name];
55 }
56}
57function applyRemoveStyle(vnode, rm) {
58 var s = vnode.data.style;
59 if (!s || !s.remove) {
60 rm();
61 return;
62 }
63 if (!reflowForced) {
64 vnode.elm.offsetLeft;
65 reflowForced = true;
66 }
67 var name, elm = vnode.elm, i = 0, compStyle, style = s.remove, amount = 0, applied = [];
68 for (name in style) {
69 applied.push(name);
70 elm.style[name] = style[name];
71 }
72 compStyle = getComputedStyle(elm);
73 var props = compStyle['transition-property'].split(', ');
74 for (; i < props.length; ++i) {
75 if (applied.indexOf(props[i]) !== -1)
76 amount++;
77 }
78 elm.addEventListener('transitionend', function (ev) {
79 if (ev.target === elm)
80 --amount;
81 if (amount === 0)
82 rm();
83 });
84}
85function forceReflow() {
86 reflowForced = false;
87}
88exports.styleModule = {
89 pre: forceReflow,
90 create: updateStyle,
91 update: updateStyle,
92 destroy: applyDestroyStyle,
93 remove: applyRemoveStyle
94};
95exports.default = exports.styleModule;
96//# sourceMappingURL=style.js.map
\No newline at end of file