blockless
Rich Harris 11 months ago
parent 3963ff9ec9
commit e474ffe79c

@ -266,6 +266,7 @@ export function derived_safe_equal(fn) {
* @param {() => void} done * @param {() => void} done
*/ */
export function pause_effect(effect, done) { export function pause_effect(effect, done) {
/** @type {import('../types.js').TransitionObject[]} */
const transitions = []; const transitions = [];
pause_children(effect, transitions); pause_children(effect, transitions);
@ -291,7 +292,7 @@ export function pause_effect(effect, done) {
/** /**
* @param {import('../types.js').ComputationSignal} effect * @param {import('../types.js').ComputationSignal} effect
* @param {TODO[]} transitions * @param {import('../types.js').TransitionObject[]} transitions
*/ */
function pause_children(effect, transitions) { function pause_children(effect, transitions) {
effect.f |= INERT; effect.f |= INERT;

@ -516,16 +516,19 @@ export function bind_transition(element, get_fn, get_params, direction, global)
/** @type {Animation | null} */ /** @type {Animation | null} */
let current_animation; let current_animation;
/** @type {TODO} */ /** @type {import('./types.js').TransitionPayload | null} */
let current_options; let current_options;
let current_delta = 0; let current_delta = 0;
/** @type {import('./types.js').TransitionObject} */
const transition = { const transition = {
global, global,
to(target, callback) { to(target, callback) {
if (current_animation && current_options) { if (current_animation && current_options) {
p = current_delta * (current_animation.currentTime / current_options.duration); const time = /** @type {number} */ (current_animation.currentTime);
const duration = /** @type {number} */ (current_options.duration);
p = (current_delta * time) / duration;
current_animation.cancel(); current_animation.cancel();
} }
@ -545,7 +548,7 @@ export function bind_transition(element, get_fn, get_params, direction, global)
current_delta = target - p; current_delta = target - p;
for (let i = 0; i <= n; i += 1) { for (let i = 0; i <= n; i += 1) {
const t = current_options.easing(p + (current_delta * i) / n); const t = (current_options.easing ?? linear)(p + (current_delta * i) / n);
const css = current_options.css(t, 1 - t); const css = current_options.css(t, 1 - t);
keyframes.push(css_to_keyframe(css)); keyframes.push(css_to_keyframe(css));
} }

@ -421,3 +421,10 @@ export interface ProxyMetadata<T = Record<string | symbol, any>> {
export type ProxyStateObject<T = Record<string | symbol, any>> = T & { export type ProxyStateObject<T = Record<string | symbol, any>> = T & {
[STATE_SYMBOL]: ProxyMetadata; [STATE_SYMBOL]: ProxyMetadata;
}; };
// TODO remove the other transition types once we're
// happy we don't need them, and rename this
export interface TransitionObject {
global: boolean;
to(target: number, callback?: () => void): void;
}

Loading…
Cancel
Save