1 | "use strict";
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 |
|
4 | var raf = (typeof window !== 'undefined' && (window.requestAnimationFrame).bind(window)) || setTimeout;
|
5 | var nextFrame = function (fn) { raf(function () { raf(fn); }); };
|
6 | var reflowForced = false;
|
7 | function setNextFrame(obj, prop, val) {
|
8 | nextFrame(function () { obj[prop] = val; });
|
9 | }
|
10 | function 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 | }
|
49 | function 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 | }
|
57 | function 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 | }
|
85 | function forceReflow() {
|
86 | reflowForced = false;
|
87 | }
|
88 | exports.styleModule = {
|
89 | pre: forceReflow,
|
90 | create: updateStyle,
|
91 | update: updateStyle,
|
92 | destroy: applyDestroyStyle,
|
93 | remove: applyRemoveStyle
|
94 | };
|
95 | exports.default = exports.styleModule;
|
96 |
|
\ | No newline at end of file |