mirror of
https://github.com/sveltejs/svelte.git
synced 2024-12-01 17:30:59 +01:00
shuffle things around a bit
This commit is contained in:
parent
f746031f96
commit
8d1afbb3d4
@ -1,5 +1,7 @@
|
|||||||
import { transitionManager, linear, generateRule, hash } from './transitions.js';
|
import { identity as linear } from './utils.js';
|
||||||
|
import { hash } from './transitions.js';
|
||||||
import { loop } from './loop.js';
|
import { loop } from './loop.js';
|
||||||
|
import { add_rule, delete_rule, generate_rule } from './style_manager.js';
|
||||||
|
|
||||||
export function wrapAnimation(node, from, fn, params) {
|
export function wrapAnimation(node, from, fn, params) {
|
||||||
if (!from) return;
|
if (!from) return;
|
||||||
@ -36,10 +38,10 @@ export function wrapAnimation(node, from, fn, params) {
|
|||||||
if (info.css) {
|
if (info.css) {
|
||||||
if (delay) node.style.cssText = cssText;
|
if (delay) node.style.cssText = cssText;
|
||||||
|
|
||||||
const rule = generateRule(program, ease, info.css);
|
const rule = generate_rule(program, ease, info.css);
|
||||||
program.name = `__svelte_${hash(rule)}`;
|
program.name = `__svelte_${hash(rule)}`;
|
||||||
|
|
||||||
transitionManager.addRule(rule, program.name);
|
add_rule(rule, program.name);
|
||||||
|
|
||||||
node.style.animation = (node.style.animation || '')
|
node.style.animation = (node.style.animation || '')
|
||||||
.split(', ')
|
.split(', ')
|
||||||
@ -64,15 +66,11 @@ export function wrapAnimation(node, from, fn, params) {
|
|||||||
},
|
},
|
||||||
|
|
||||||
stop() {
|
stop() {
|
||||||
if (info.css) transitionManager.deleteRule(node, program.name);
|
if (info.css) delete_rule(node, program.name);
|
||||||
animation.running = false;
|
animation.running = false;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// transitionManager.add(animation);
|
|
||||||
|
|
||||||
transitionManager.active += 1;
|
|
||||||
|
|
||||||
const { abort, promise } = loop(() => {
|
const { abort, promise } = loop(() => {
|
||||||
const now = window.performance.now();
|
const now = window.performance.now();
|
||||||
|
|
||||||
@ -90,15 +88,6 @@ export function wrapAnimation(node, from, fn, params) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
promise.then(() => {
|
|
||||||
transitionManager.active -= 1;
|
|
||||||
if (!transitionManager.active) {
|
|
||||||
let i = transitionManager.stylesheet.cssRules.length;
|
|
||||||
while (i--) transitionManager.stylesheet.deleteRule(i);
|
|
||||||
transitionManager.activeRules = {};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (info.tick) info.tick(0, 1);
|
if (info.tick) info.tick(0, 1);
|
||||||
|
|
||||||
if (delay) {
|
if (delay) {
|
||||||
|
50
src/internal/style_manager.js
Normal file
50
src/internal/style_manager.js
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
import { createElement } from './dom.js';
|
||||||
|
|
||||||
|
let stylesheet;
|
||||||
|
let active = 0;
|
||||||
|
let current_rules = {};
|
||||||
|
|
||||||
|
export function add_rule(rule, name) {
|
||||||
|
if (!stylesheet) {
|
||||||
|
const style = createElement('style');
|
||||||
|
document.head.appendChild(style);
|
||||||
|
stylesheet = style.sheet;
|
||||||
|
}
|
||||||
|
|
||||||
|
active += 1;
|
||||||
|
console.log(`adding rule`, active);
|
||||||
|
|
||||||
|
if (!current_rules[name]) {
|
||||||
|
current_rules[name] = true;
|
||||||
|
stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function delete_rule(node, name) {
|
||||||
|
node.style.animation = node.style.animation
|
||||||
|
.split(', ')
|
||||||
|
.filter(anim => anim && anim.indexOf(name) === -1)
|
||||||
|
.join(', ');
|
||||||
|
|
||||||
|
console.trace(`removing rule`, active - 1);
|
||||||
|
if (--active <= 0) clear_rules();
|
||||||
|
}
|
||||||
|
|
||||||
|
export function generate_rule({ a, b, delta, duration }, ease, fn) {
|
||||||
|
const step = 16.666 / duration;
|
||||||
|
let keyframes = '{\n';
|
||||||
|
|
||||||
|
for (let p = 0; p <= 1; p += step) {
|
||||||
|
const t = a + delta * ease(p);
|
||||||
|
keyframes += p * 100 + `%{${fn(t, 1 - t)}}\n`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return keyframes + `100% {${fn(b, 1 - b)}}\n}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
export function clear_rules() {
|
||||||
|
let i = stylesheet.cssRules.length;
|
||||||
|
console.log(`clearing ${i} rules`);
|
||||||
|
while (i--) stylesheet.deleteRule(i);
|
||||||
|
current_rules = {};
|
||||||
|
}
|
@ -1,22 +1,6 @@
|
|||||||
import { createElement } from './dom.js';
|
import { identity as linear, noop, run } from './utils.js';
|
||||||
import { noop, run } from './utils.js';
|
|
||||||
import { loop } from './loop.js';
|
import { loop } from './loop.js';
|
||||||
|
import { add_rule, delete_rule, generate_rule } from './style_manager.js';
|
||||||
export function linear(t) {
|
|
||||||
return t;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function generateRule({ a, b, delta, duration }, ease, fn) {
|
|
||||||
const step = 16.666 / duration;
|
|
||||||
let keyframes = '{\n';
|
|
||||||
|
|
||||||
for (let p = 0; p <= 1; p += step) {
|
|
||||||
const t = a + delta * ease(p);
|
|
||||||
keyframes += p * 100 + `%{${fn(t, 1 - t)}}\n`;
|
|
||||||
}
|
|
||||||
|
|
||||||
return keyframes + `100% {${fn(b, 1 - b)}}\n}`;
|
|
||||||
}
|
|
||||||
|
|
||||||
// https://github.com/darkskyapp/string-hash/blob/master/index.js
|
// https://github.com/darkskyapp/string-hash/blob/master/index.js
|
||||||
export function hash(str) {
|
export function hash(str) {
|
||||||
@ -84,10 +68,8 @@ export function wrapTransition(component, node, fn, params, intro) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!this.running) {
|
if (!this.running) {
|
||||||
transitionManager.active += 1;
|
|
||||||
|
|
||||||
this.running = true;
|
this.running = true;
|
||||||
// transitionManager.add(this);
|
|
||||||
const { abort, promise } = loop(() => {
|
const { abort, promise } = loop(() => {
|
||||||
const now = window.performance.now();
|
const now = window.performance.now();
|
||||||
|
|
||||||
@ -104,15 +86,6 @@ export function wrapTransition(component, node, fn, params, intro) {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
promise.then(() => {
|
|
||||||
transitionManager.active -= 1;
|
|
||||||
if (!transitionManager.active) {
|
|
||||||
let i = transitionManager.stylesheet.cssRules.length;
|
|
||||||
while (i--) transitionManager.stylesheet.deleteRule(i);
|
|
||||||
transitionManager.activeRules = {};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -127,8 +100,8 @@ export function wrapTransition(component, node, fn, params, intro) {
|
|||||||
if (obj.css) {
|
if (obj.css) {
|
||||||
if (obj.delay) node.style.cssText = cssText;
|
if (obj.delay) node.style.cssText = cssText;
|
||||||
|
|
||||||
const rule = generateRule(program, ease, obj.css);
|
const rule = generate_rule(program, ease, obj.css);
|
||||||
transitionManager.addRule(rule, program.name = '__svelte_' + hash(rule));
|
add_rule(rule, program.name = '__svelte_' + hash(rule));
|
||||||
|
|
||||||
node.style.animation = (node.style.animation || '')
|
node.style.animation = (node.style.animation || '')
|
||||||
.split(', ')
|
.split(', ')
|
||||||
@ -152,6 +125,8 @@ export function wrapTransition(component, node, fn, params, intro) {
|
|||||||
|
|
||||||
done() {
|
done() {
|
||||||
const program = this.program;
|
const program = this.program;
|
||||||
|
this.program = null;
|
||||||
|
|
||||||
this.t = program.b;
|
this.t = program.b;
|
||||||
|
|
||||||
if (obj.tick) obj.tick(this.t, 1 - this.t);
|
if (obj.tick) obj.tick(this.t, 1 - this.t);
|
||||||
@ -161,23 +136,24 @@ export function wrapTransition(component, node, fn, params, intro) {
|
|||||||
if (!program.b && !program.invalidated) {
|
if (!program.b && !program.invalidated) {
|
||||||
program.group.callbacks.push(() => {
|
program.group.callbacks.push(() => {
|
||||||
program.callback();
|
program.callback();
|
||||||
if (obj.css) transitionManager.deleteRule(node, program.name);
|
if (obj.css) delete_rule(node, program.name);
|
||||||
});
|
});
|
||||||
|
|
||||||
if (--program.group.remaining === 0) {
|
if (--program.group.remaining === 0) {
|
||||||
program.group.callbacks.forEach(run);
|
program.group.callbacks.forEach(run);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (obj.css) transitionManager.deleteRule(node, program.name);
|
if (obj.css) delete_rule(node, program.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.running = !!this.pending;
|
this.running = !!this.pending;
|
||||||
},
|
},
|
||||||
|
|
||||||
abort(reset) {
|
abort(reset) {
|
||||||
|
if (reset && obj.tick) obj.tick(1, 0);
|
||||||
|
|
||||||
if (this.program) {
|
if (this.program) {
|
||||||
if (reset && obj.tick) obj.tick(1, 0);
|
if (obj.css) delete_rule(node, this.program.name);
|
||||||
if (obj.css) transitionManager.deleteRule(node, this.program.name);
|
|
||||||
this.program = this.pending = null;
|
this.program = this.pending = null;
|
||||||
this.running = false;
|
this.running = false;
|
||||||
}
|
}
|
||||||
@ -201,34 +177,8 @@ export function groupOutros() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export var transitionManager = {
|
export var transitionManager = {
|
||||||
active: 0,
|
|
||||||
running: false,
|
|
||||||
transitions: [],
|
|
||||||
bound: null,
|
|
||||||
stylesheet: null,
|
|
||||||
activeRules: {},
|
|
||||||
promise: null,
|
promise: null,
|
||||||
|
|
||||||
addRule(rule, name) {
|
|
||||||
if (!this.stylesheet) {
|
|
||||||
const style = createElement('style');
|
|
||||||
document.head.appendChild(style);
|
|
||||||
transitionManager.stylesheet = style.sheet;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!this.activeRules[name]) {
|
|
||||||
this.activeRules[name] = true;
|
|
||||||
this.stylesheet.insertRule(`@keyframes ${name} ${rule}`, this.stylesheet.cssRules.length);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
deleteRule(node, name) {
|
|
||||||
node.style.animation = node.style.animation
|
|
||||||
.split(', ')
|
|
||||||
.filter(anim => anim && anim.indexOf(name) === -1)
|
|
||||||
.join(', ');
|
|
||||||
},
|
|
||||||
|
|
||||||
wait() {
|
wait() {
|
||||||
if (!transitionManager.promise) {
|
if (!transitionManager.promise) {
|
||||||
transitionManager.promise = Promise.resolve();
|
transitionManager.promise = Promise.resolve();
|
||||||
|
Loading…
Reference in New Issue
Block a user