| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- // Binding `requestAnimationFrame` like this fixes a bug in IE/Edge. See #360 and #409.
- const raf = typeof (window === null || window === void 0 ? void 0 : window.requestAnimationFrame) === "function"
- ? window.requestAnimationFrame.bind(window)
- : setTimeout;
- const nextFrame = function (fn) {
- raf(function () {
- raf(fn);
- });
- };
- let reflowForced = false;
- function setNextFrame(obj, prop, val) {
- nextFrame(function () {
- obj[prop] = val;
- });
- }
- function updateStyle(oldVnode, vnode) {
- let cur;
- let name;
- const elm = vnode.elm;
- let oldStyle = oldVnode.data.style;
- let style = vnode.data.style;
- if (!oldStyle && !style)
- return;
- if (oldStyle === style)
- return;
- oldStyle = oldStyle || {};
- style = style || {};
- const oldHasDel = "delayed" in oldStyle;
- for (name in oldStyle) {
- if (!(name in style)) {
- if (name[0] === "-" && name[1] === "-") {
- elm.style.removeProperty(name);
- }
- else {
- elm.style[name] = "";
- }
- }
- }
- for (name in style) {
- cur = style[name];
- if (name === "delayed" && style.delayed) {
- for (const name2 in style.delayed) {
- cur = style.delayed[name2];
- if (!oldHasDel || cur !== oldStyle.delayed[name2]) {
- setNextFrame(elm.style, name2, cur);
- }
- }
- }
- else if (name !== "remove" && cur !== oldStyle[name]) {
- if (name[0] === "-" && name[1] === "-") {
- elm.style.setProperty(name, cur);
- }
- else {
- elm.style[name] = cur;
- }
- }
- }
- }
- function applyDestroyStyle(vnode) {
- let style;
- let name;
- const elm = vnode.elm;
- const s = vnode.data.style;
- if (!s || !(style = s.destroy))
- return;
- for (name in style) {
- elm.style[name] = style[name];
- }
- }
- function applyRemoveStyle(vnode, rm) {
- const s = vnode.data.style;
- if (!s || !s.remove) {
- rm();
- return;
- }
- if (!reflowForced) {
- // eslint-disable-next-line @typescript-eslint/no-unused-expressions
- vnode.elm.offsetLeft;
- reflowForced = true;
- }
- let name;
- const elm = vnode.elm;
- let i = 0;
- const style = s.remove;
- let amount = 0;
- const applied = [];
- for (name in style) {
- applied.push(name);
- elm.style[name] = style[name];
- }
- const compStyle = getComputedStyle(elm);
- const props = compStyle["transition-property"].split(", ");
- for (; i < props.length; ++i) {
- if (applied.indexOf(props[i]) !== -1)
- amount++;
- }
- elm.addEventListener("transitionend", function (ev) {
- if (ev.target === elm)
- --amount;
- if (amount === 0)
- rm();
- });
- }
- function forceReflow() {
- reflowForced = false;
- }
- export const styleModule = {
- pre: forceReflow,
- create: updateStyle,
- update: updateStyle,
- destroy: applyDestroyStyle,
- remove: applyRemoveStyle
- };
- //# sourceMappingURL=style.js.map
|