@interactjs/inertia
Advanced tools
Comparing version 1.6.3 to 1.7.0
@@ -0,1 +1,2 @@ | ||
import { EventPhase } from '../core/InteractEvent'; | ||
declare module '@interactjs/core/InteractEvent' { | ||
@@ -49,3 +50,16 @@ enum EventPhase { | ||
} | ||
declare module '@interactjs/core/scope' { | ||
interface SignalArgs { | ||
'interactions:action-resume': { | ||
interaction: Interact.Interaction; | ||
phase: EventPhase.Resume; | ||
}; | ||
} | ||
} | ||
declare function install(scope: Interact.Scope): void; | ||
declare function resume({ interaction, event, pointer, eventTarget }: Interact.SignalArgs['interactions:down'], scope: Interact.Scope): void; | ||
declare function release<T extends Interact.ActionName>({ interaction, event, noPreEnd }: Interact.DoPhaseArg & { | ||
noPreEnd?: boolean; | ||
}, scope: Interact.Scope): boolean; | ||
declare function stop({ interaction }: Interact.DoPhaseArg): void; | ||
declare function calcInertia(interaction: Interact.Interaction, state: any): void; | ||
@@ -58,2 +72,11 @@ declare function inertiaTick(interaction: Interact.Interaction): void; | ||
install: typeof install; | ||
listeners: { | ||
'interactions:new': ({ interaction }: { | ||
interaction: any; | ||
}) => void; | ||
'interactions:before-action-end': typeof release; | ||
'interactions:down': typeof resume; | ||
'interactions:stop': typeof stop; | ||
}; | ||
before: string; | ||
calcInertia: typeof calcInertia; | ||
@@ -60,0 +83,0 @@ inertiaTick: typeof inertiaTick; |
494
index.js
@@ -1,246 +0,290 @@ | ||
import { EventPhase } from '@interactjs/core/InteractEvent'; | ||
import modifiers, { restoreCoords, setCoords } from '@interactjs/modifiers/base'; | ||
import * as utils from '@interactjs/utils'; | ||
import raf from '@interactjs/utils/raf'; | ||
import { EventPhase } from "../core/InteractEvent.js"; | ||
import modifiers, { restoreCoords, setCoords } from "../modifiers/base.js"; | ||
import * as utils from "../utils/index.js"; | ||
import raf from "../utils/raf.js"; | ||
EventPhase.Resume = 'resume'; | ||
EventPhase.InertiaStart = 'inertiastart'; | ||
function install(scope) { | ||
const { interactions, defaults, } = scope; | ||
interactions.signals.on('new', ({ interaction }) => { | ||
interaction.inertia = { | ||
active: false, | ||
smoothEnd: false, | ||
allowResume: false, | ||
upCoords: {}, | ||
timeout: null, | ||
const { | ||
defaults | ||
} = scope; | ||
scope.usePlugin(modifiers); | ||
defaults.perAction.inertia = { | ||
enabled: false, | ||
resistance: 10, | ||
// the lambda in exponential decay | ||
minSpeed: 100, | ||
// target speed must be above this for inertia to start | ||
endSpeed: 10, | ||
// the speed at which inertia is slow enough to stop | ||
allowResume: true, | ||
// allow resuming an action in inertia phase | ||
smoothEndDuration: 300 // animate to snap/restrict endOnly if there's no inertia | ||
}; | ||
} | ||
function resume({ | ||
interaction, | ||
event, | ||
pointer, | ||
eventTarget | ||
}, scope) { | ||
const state = interaction.inertia; // Check if the down event hits the current inertia target | ||
if (state.active) { | ||
let element = eventTarget; // climb up the DOM tree from the event target | ||
while (utils.is.element(element)) { | ||
// if interaction element is the current inertia target element | ||
if (element === interaction.element) { | ||
// stop inertia | ||
raf.cancel(state.timeout); | ||
state.active = false; | ||
interaction.simulation = null; // update pointers to the down event's coordinates | ||
interaction.updatePointer(pointer, event, eventTarget, true); | ||
utils.pointer.setCoords(interaction.coords.cur, interaction.pointers.map(p => p.pointer), interaction._now()); // fire appropriate signals | ||
const signalArg = { | ||
interaction, | ||
phase: EventPhase.Resume | ||
}; | ||
}); | ||
interactions.signals.on('before-action-end', (arg) => release(arg, scope)); | ||
interactions.signals.on('down', (arg) => resume(arg, scope)); | ||
interactions.signals.on('stop', stop); | ||
defaults.perAction.inertia = { | ||
enabled: false, | ||
resistance: 10, | ||
minSpeed: 100, | ||
endSpeed: 10, | ||
allowResume: true, | ||
smoothEndDuration: 300, | ||
}; | ||
scope.usePlugin(modifiers); | ||
} | ||
function resume({ interaction, event, pointer, eventTarget }, scope) { | ||
const state = interaction.inertia; | ||
// Check if the down event hits the current inertia target | ||
if (state.active) { | ||
let element = eventTarget; | ||
// climb up the DOM tree from the event target | ||
while (utils.is.element(element)) { | ||
// if interaction element is the current inertia target element | ||
if (element === interaction.element) { | ||
// stop inertia | ||
raf.cancel(state.timeout); | ||
state.active = false; | ||
interaction.simulation = null; | ||
// update pointers to the down event's coordinates | ||
interaction.updatePointer(pointer, event, eventTarget, true); | ||
utils.pointer.setCoords(interaction.coords.cur, interaction.pointers.map(p => p.pointer), interaction._now()); | ||
// fire appropriate signals | ||
const signalArg = { | ||
interaction, | ||
phase: EventPhase.Resume, | ||
}; | ||
scope.interactions.signals.fire('action-resume', signalArg); | ||
// fire a reume event | ||
const resumeEvent = new scope.InteractEvent(interaction, event, interaction.prepared.name, EventPhase.Resume, interaction.element); | ||
interaction._fireEvent(resumeEvent); | ||
utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur); | ||
break; | ||
} | ||
element = utils.dom.parentNode(element); | ||
} | ||
scope.fire('interactions:action-resume', signalArg); // fire a reume event | ||
const resumeEvent = new scope.InteractEvent(interaction, event, interaction.prepared.name, EventPhase.Resume, interaction.element); | ||
interaction._fireEvent(resumeEvent); | ||
utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur); | ||
break; | ||
} | ||
element = utils.dom.parentNode(element); | ||
} | ||
} | ||
} | ||
function release({ interaction, event, noPreEnd }, scope) { | ||
const state = interaction.inertia; | ||
if (!interaction.interacting() || | ||
(interaction.simulation && interaction.simulation.active) || | ||
noPreEnd) { | ||
return null; | ||
function release({ | ||
interaction, | ||
event, | ||
noPreEnd | ||
}, scope) { | ||
const state = interaction.inertia; | ||
if (!interaction.interacting() || interaction.simulation && interaction.simulation.active || noPreEnd) { | ||
return null; | ||
} | ||
const options = getOptions(interaction); | ||
const now = interaction._now(); | ||
const { | ||
client: velocityClient | ||
} = interaction.coords.velocity; | ||
const pointerSpeed = utils.hypot(velocityClient.x, velocityClient.y); | ||
let smoothEnd = false; | ||
let modifierResult; // check if inertia should be started | ||
const inertiaPossible = options && options.enabled && interaction.prepared.name !== 'gesture' && event !== state.startEvent; | ||
const inertia = inertiaPossible && now - interaction.coords.cur.timeStamp < 50 && pointerSpeed > options.minSpeed && pointerSpeed > options.endSpeed; | ||
const modifierArg = { | ||
interaction, | ||
interactable: interaction.interactable, | ||
element: interaction.element, | ||
rect: interaction.rect, | ||
pageCoords: interaction.coords.cur.page, | ||
states: inertiaPossible && interaction.modifiers.states.map(modifierStatus => utils.extend({}, modifierStatus)), | ||
preEnd: true, | ||
prevCoords: null, | ||
requireEndOnly: null, | ||
phase: EventPhase.InertiaStart | ||
}; // smoothEnd | ||
if (inertiaPossible && !inertia) { | ||
modifierArg.prevCoords = interaction.modifiers.result ? interaction.modifiers.result.coords : interaction.prevEvent.page; | ||
modifierArg.requireEndOnly = false; | ||
modifierResult = modifiers.setAll(modifierArg); | ||
if (modifierResult.changed) { | ||
smoothEnd = true; | ||
} | ||
const options = getOptions(interaction); | ||
const now = interaction._now(); | ||
const { client: velocityClient } = interaction.coords.velocity; | ||
const pointerSpeed = utils.hypot(velocityClient.x, velocityClient.y); | ||
let smoothEnd = false; | ||
let modifierResult; | ||
// check if inertia should be started | ||
const inertiaPossible = (options && options.enabled && | ||
interaction.prepared.name !== 'gesture' && | ||
event !== state.startEvent); | ||
const inertia = (inertiaPossible && | ||
(now - interaction.coords.cur.timeStamp) < 50 && | ||
pointerSpeed > options.minSpeed && | ||
pointerSpeed > options.endSpeed); | ||
const modifierArg = { | ||
interaction, | ||
pageCoords: interaction.coords.cur.page, | ||
states: inertiaPossible && interaction.modifiers.states.map(modifierStatus => utils.extend({}, modifierStatus)), | ||
preEnd: true, | ||
prevCoords: null, | ||
requireEndOnly: null, | ||
phase: EventPhase.InertiaStart, | ||
}; | ||
// smoothEnd | ||
if (inertiaPossible && !inertia) { | ||
modifierArg.prevCoords = interaction.modifiers.result | ||
? interaction.modifiers.result.coords | ||
: interaction.prevEvent.page; | ||
modifierArg.requireEndOnly = false; | ||
modifierResult = modifiers.setAll(modifierArg); | ||
if (modifierResult.changed) { | ||
smoothEnd = true; | ||
} | ||
} | ||
if (!(inertia || smoothEnd)) { | ||
return null; | ||
} | ||
utils.pointer.copyCoords(state.upCoords, interaction.coords.cur); | ||
setCoords(modifierArg); | ||
interaction.pointers[0].pointer = state.startEvent = new scope.InteractEvent(interaction, event, | ||
// FIXME add proper typing Action.name | ||
interaction.prepared.name, EventPhase.InertiaStart, interaction.element); | ||
restoreCoords(modifierArg); | ||
state.t0 = now; | ||
state.active = true; | ||
state.allowResume = options.allowResume; | ||
interaction.simulation = state; | ||
interaction.interactable.fire(state.startEvent); | ||
if (inertia) { | ||
state.vx0 = interaction.coords.velocity.client.x; | ||
state.vy0 = interaction.coords.velocity.client.y; | ||
state.v0 = pointerSpeed; | ||
calcInertia(interaction, state); | ||
utils.extend(modifierArg.pageCoords, interaction.coords.cur.page); | ||
modifierArg.pageCoords.x += state.xe; | ||
modifierArg.pageCoords.y += state.ye; | ||
modifierArg.prevCoords = null; | ||
modifierArg.requireEndOnly = true; | ||
modifierResult = modifiers.setAll(modifierArg); | ||
state.modifiedXe += modifierResult.delta.x; | ||
state.modifiedYe += modifierResult.delta.y; | ||
state.timeout = raf.request(() => inertiaTick(interaction)); | ||
} | ||
else { | ||
state.smoothEnd = true; | ||
state.xe = modifierResult.delta.x; | ||
state.ye = modifierResult.delta.y; | ||
state.sx = state.sy = 0; | ||
state.timeout = raf.request(() => smothEndTick(interaction)); | ||
} | ||
return false; | ||
} | ||
if (!(inertia || smoothEnd)) { | ||
return null; | ||
} | ||
utils.pointer.copyCoords(state.upCoords, interaction.coords.cur); | ||
setCoords(modifierArg); | ||
interaction.pointers[0].pointer = state.startEvent = new scope.InteractEvent(interaction, event, // FIXME add proper typing Action.name | ||
interaction.prepared.name, EventPhase.InertiaStart, interaction.element); | ||
restoreCoords(modifierArg); | ||
state.t0 = now; | ||
state.active = true; | ||
state.allowResume = options.allowResume; | ||
interaction.simulation = state; | ||
interaction.interactable.fire(state.startEvent); | ||
if (inertia) { | ||
state.vx0 = interaction.coords.velocity.client.x; | ||
state.vy0 = interaction.coords.velocity.client.y; | ||
state.v0 = pointerSpeed; | ||
calcInertia(interaction, state); | ||
utils.extend(modifierArg.pageCoords, interaction.coords.cur.page); | ||
modifierArg.pageCoords.x += state.xe; | ||
modifierArg.pageCoords.y += state.ye; | ||
modifierArg.prevCoords = null; | ||
modifierArg.requireEndOnly = true; | ||
modifierResult = modifiers.setAll(modifierArg); | ||
state.modifiedXe += modifierResult.delta.x; | ||
state.modifiedYe += modifierResult.delta.y; | ||
state.timeout = raf.request(() => inertiaTick(interaction)); | ||
} else { | ||
state.smoothEnd = true; | ||
state.xe = modifierResult.delta.x; | ||
state.ye = modifierResult.delta.y; | ||
state.sx = state.sy = 0; | ||
state.timeout = raf.request(() => smothEndTick(interaction)); | ||
} | ||
return false; | ||
} | ||
function stop({ interaction }) { | ||
const state = interaction.inertia; | ||
if (state.active) { | ||
raf.cancel(state.timeout); | ||
state.active = false; | ||
interaction.simulation = null; | ||
} | ||
function stop({ | ||
interaction | ||
}) { | ||
const state = interaction.inertia; | ||
if (state.active) { | ||
raf.cancel(state.timeout); | ||
state.active = false; | ||
interaction.simulation = null; | ||
} | ||
} | ||
function calcInertia(interaction, state) { | ||
const options = getOptions(interaction); | ||
const lambda = options.resistance; | ||
const inertiaDur = -Math.log(options.endSpeed / state.v0) / lambda; | ||
state.x0 = interaction.prevEvent.page.x; | ||
state.y0 = interaction.prevEvent.page.y; | ||
state.t0 = state.startEvent.timeStamp / 1000; | ||
state.sx = state.sy = 0; | ||
state.modifiedXe = state.xe = (state.vx0 - inertiaDur) / lambda; | ||
state.modifiedYe = state.ye = (state.vy0 - inertiaDur) / lambda; | ||
state.te = inertiaDur; | ||
state.lambda_v0 = lambda / state.v0; | ||
state.one_ve_v0 = 1 - options.endSpeed / state.v0; | ||
const options = getOptions(interaction); | ||
const lambda = options.resistance; | ||
const inertiaDur = -Math.log(options.endSpeed / state.v0) / lambda; | ||
state.x0 = interaction.prevEvent.page.x; | ||
state.y0 = interaction.prevEvent.page.y; | ||
state.t0 = state.startEvent.timeStamp / 1000; | ||
state.sx = state.sy = 0; | ||
state.modifiedXe = state.xe = (state.vx0 - inertiaDur) / lambda; | ||
state.modifiedYe = state.ye = (state.vy0 - inertiaDur) / lambda; | ||
state.te = inertiaDur; | ||
state.lambda_v0 = lambda / state.v0; | ||
state.one_ve_v0 = 1 - options.endSpeed / state.v0; | ||
} | ||
function inertiaTick(interaction) { | ||
updateInertiaCoords(interaction); | ||
utils.pointer.setCoordDeltas(interaction.coords.delta, interaction.coords.prev, interaction.coords.cur); | ||
utils.pointer.setCoordVelocity(interaction.coords.velocity, interaction.coords.delta); | ||
const state = interaction.inertia; | ||
const options = getOptions(interaction); | ||
const lambda = options.resistance; | ||
const t = interaction._now() / 1000 - state.t0; | ||
if (t < state.te) { | ||
const progress = 1 - (Math.exp(-lambda * t) - state.lambda_v0) / state.one_ve_v0; | ||
if (state.modifiedXe === state.xe && state.modifiedYe === state.ye) { | ||
state.sx = state.xe * progress; | ||
state.sy = state.ye * progress; | ||
} | ||
else { | ||
const quadPoint = utils.getQuadraticCurvePoint(0, 0, state.xe, state.ye, state.modifiedXe, state.modifiedYe, progress); | ||
state.sx = quadPoint.x; | ||
state.sy = quadPoint.y; | ||
} | ||
interaction.move(); | ||
state.timeout = raf.request(() => inertiaTick(interaction)); | ||
updateInertiaCoords(interaction); | ||
utils.pointer.setCoordDeltas(interaction.coords.delta, interaction.coords.prev, interaction.coords.cur); | ||
utils.pointer.setCoordVelocity(interaction.coords.velocity, interaction.coords.delta); | ||
const state = interaction.inertia; | ||
const options = getOptions(interaction); | ||
const lambda = options.resistance; | ||
const t = interaction._now() / 1000 - state.t0; | ||
if (t < state.te) { | ||
const progress = 1 - (Math.exp(-lambda * t) - state.lambda_v0) / state.one_ve_v0; | ||
if (state.modifiedXe === state.xe && state.modifiedYe === state.ye) { | ||
state.sx = state.xe * progress; | ||
state.sy = state.ye * progress; | ||
} else { | ||
const quadPoint = utils.getQuadraticCurvePoint(0, 0, state.xe, state.ye, state.modifiedXe, state.modifiedYe, progress); | ||
state.sx = quadPoint.x; | ||
state.sy = quadPoint.y; | ||
} | ||
else { | ||
state.sx = state.modifiedXe; | ||
state.sy = state.modifiedYe; | ||
interaction.move(); | ||
interaction.end(state.startEvent); | ||
state.active = false; | ||
interaction.simulation = null; | ||
} | ||
utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur); | ||
interaction.move(); | ||
state.timeout = raf.request(() => inertiaTick(interaction)); | ||
} else { | ||
state.sx = state.modifiedXe; | ||
state.sy = state.modifiedYe; | ||
interaction.move(); | ||
interaction.end(state.startEvent); | ||
state.active = false; | ||
interaction.simulation = null; | ||
} | ||
utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur); | ||
} | ||
function smothEndTick(interaction) { | ||
updateInertiaCoords(interaction); | ||
const state = interaction.inertia; | ||
const t = interaction._now() - state.t0; | ||
const { smoothEndDuration: duration } = getOptions(interaction); | ||
if (t < duration) { | ||
state.sx = utils.easeOutQuad(t, 0, state.xe, duration); | ||
state.sy = utils.easeOutQuad(t, 0, state.ye, duration); | ||
interaction.move(); | ||
state.timeout = raf.request(() => smothEndTick(interaction)); | ||
} | ||
else { | ||
state.sx = state.xe; | ||
state.sy = state.ye; | ||
interaction.move(); | ||
interaction.end(state.startEvent); | ||
state.smoothEnd = | ||
state.active = false; | ||
interaction.simulation = null; | ||
} | ||
updateInertiaCoords(interaction); | ||
const state = interaction.inertia; | ||
const t = interaction._now() - state.t0; | ||
const { | ||
smoothEndDuration: duration | ||
} = getOptions(interaction); | ||
if (t < duration) { | ||
state.sx = utils.easeOutQuad(t, 0, state.xe, duration); | ||
state.sy = utils.easeOutQuad(t, 0, state.ye, duration); | ||
interaction.move(); | ||
state.timeout = raf.request(() => smothEndTick(interaction)); | ||
} else { | ||
state.sx = state.xe; | ||
state.sy = state.ye; | ||
interaction.move(); | ||
interaction.end(state.startEvent); | ||
state.smoothEnd = state.active = false; | ||
interaction.simulation = null; | ||
} | ||
} | ||
function updateInertiaCoords(interaction) { | ||
const state = interaction.inertia; | ||
// return if inertia isn't running | ||
if (!state.active) { | ||
return; | ||
} | ||
const pageUp = state.upCoords.page; | ||
const clientUp = state.upCoords.client; | ||
utils.pointer.setCoords(interaction.coords.cur, [{ | ||
pageX: pageUp.x + state.sx, | ||
pageY: pageUp.y + state.sy, | ||
clientX: clientUp.x + state.sx, | ||
clientY: clientUp.y + state.sy, | ||
}], interaction._now()); | ||
const state = interaction.inertia; // return if inertia isn't running | ||
if (!state.active) { | ||
return; | ||
} | ||
const pageUp = state.upCoords.page; | ||
const clientUp = state.upCoords.client; | ||
utils.pointer.setCoords(interaction.coords.cur, [{ | ||
pageX: pageUp.x + state.sx, | ||
pageY: pageUp.y + state.sy, | ||
clientX: clientUp.x + state.sx, | ||
clientY: clientUp.y + state.sy | ||
}], interaction._now()); | ||
} | ||
function getOptions({ interactable, prepared }) { | ||
return interactable && | ||
interactable.options && | ||
prepared.name && | ||
interactable.options[prepared.name].inertia; | ||
function getOptions({ | ||
interactable, | ||
prepared | ||
}) { | ||
return interactable && interactable.options && prepared.name && interactable.options[prepared.name].inertia; | ||
} | ||
export default { | ||
id: 'inertia', | ||
install, | ||
calcInertia, | ||
inertiaTick, | ||
smothEndTick, | ||
updateInertiaCoords, | ||
id: 'inertia', | ||
install, | ||
listeners: { | ||
'interactions:new': ({ | ||
interaction | ||
}) => { | ||
interaction.inertia = { | ||
active: false, | ||
smoothEnd: false, | ||
allowResume: false, | ||
upCoords: {}, | ||
timeout: null | ||
}; | ||
}, | ||
'interactions:before-action-end': release, | ||
'interactions:down': resume, | ||
'interactions:stop': stop | ||
}, | ||
before: 'modifiers/base', | ||
calcInertia, | ||
inertiaTick, | ||
smothEndTick, | ||
updateInertiaCoords | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventPhase } from '@interactjs/core/InteractEvent'\nimport modifiers, { restoreCoords, setCoords } from '@interactjs/modifiers/base'\nimport * as utils from '@interactjs/utils'\nimport raf from '@interactjs/utils/raf'\n\ndeclare module '@interactjs/core/InteractEvent' {\n  // eslint-disable-next-line no-shadow\n  enum EventPhase {\n    Resume = 'resume',\n    InertiaStart = 'inertiastart',\n  }\n}\n\ndeclare module '@interactjs/core/Interaction' {\n  interface Interaction {\n    inertia?: {\n      active: boolean\n      smoothEnd: boolean\n      allowResume: boolean\n\n      startEvent?: Interact.InteractEvent\n      upCoords: {\n        page: Interact.Point\n        client: Interact.Point\n        timeStamp: number\n      }\n\n      xe?: number\n      ye?: number\n      sx?: number\n      sy?: number\n\n      t0?: number\n      te?: number\n      v0?: number\n      vx0?: number\n      vy0?: number\n      duration?: number\n      modifiedXe?: number\n      modifiedYe?: number\n\n      lambda_v0?: number // eslint-disable-line camelcase\n      one_ve_v0?: number // eslint-disable-line camelcase\n      timeout: any\n    }\n  }\n}\n\ndeclare module '@interactjs/core/defaultOptions' {\n  interface PerActionDefaults {\n    inertia?: {\n      enabled?: boolean\n      resistance?: number        // the lambda in exponential decay\n      minSpeed?: number          // target speed must be above this for inertia to start\n      endSpeed?: number          // the speed at which inertia is slow enough to stop\n      allowResume?: true         // allow resuming an action in inertia phase\n      smoothEndDuration?: number // animate to snap/restrict endOnly if there's no inertia\n    } | boolean // FIXME\n  }\n}\n\n(EventPhase as any).Resume = 'resume'\n;(EventPhase as any).InertiaStart = 'inertiastart'\n\nfunction install (scope: Interact.Scope) {\n  const {\n    interactions,\n    defaults,\n  } = scope\n\n  interactions.signals.on('new', ({ interaction }) => {\n    interaction.inertia = {\n      active     : false,\n      smoothEnd  : false,\n      allowResume: false,\n      upCoords   : {} as any,\n      timeout    : null,\n    }\n  })\n\n  interactions.signals.on('before-action-end', (arg: Interact.SignalArg) => release(arg, scope))\n  interactions.signals.on('down', (arg: Interact.SignalArg) => resume(arg, scope))\n  interactions.signals.on('stop', stop)\n\n  defaults.perAction.inertia = {\n    enabled          : false,\n    resistance       : 10,    // the lambda in exponential decay\n    minSpeed         : 100,   // target speed must be above this for inertia to start\n    endSpeed         : 10,    // the speed at which inertia is slow enough to stop\n    allowResume      : true,  // allow resuming an action in inertia phase\n    smoothEndDuration: 300,   // animate to snap/restrict endOnly if there's no inertia\n  }\n\n  scope.usePlugin(modifiers)\n}\n\nfunction resume (\n  { interaction, event, pointer, eventTarget }: Interact.SignalArg,\n  scope: Interact.Scope\n) {\n  const state = interaction.inertia\n\n  // Check if the down event hits the current inertia target\n  if (state.active) {\n    let element = eventTarget\n\n    // climb up the DOM tree from the event target\n    while (utils.is.element(element)) {\n      // if interaction element is the current inertia target element\n      if (element === interaction.element) {\n        // stop inertia\n        raf.cancel(state.timeout)\n        state.active = false\n        interaction.simulation = null\n\n        // update pointers to the down event's coordinates\n        interaction.updatePointer(pointer, event, eventTarget, true)\n        utils.pointer.setCoords(\n          interaction.coords.cur,\n          interaction.pointers.map(p => p.pointer),\n          interaction._now()\n        )\n\n        // fire appropriate signals\n        const signalArg = {\n          interaction,\n          phase: EventPhase.Resume,\n        }\n\n        scope.interactions.signals.fire('action-resume', signalArg)\n\n        // fire a reume event\n        const resumeEvent = new scope.InteractEvent(\n          interaction, event, interaction.prepared.name, EventPhase.Resume, interaction.element)\n\n        interaction._fireEvent(resumeEvent)\n\n        utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur)\n        break\n      }\n\n      element = utils.dom.parentNode(element)\n    }\n  }\n}\n\nfunction release<T extends Interact.ActionName> (\n  { interaction, event, noPreEnd }: Interact.SignalArg,\n  scope: Interact.Scope\n) {\n  const state = interaction.inertia\n\n  if (!interaction.interacting() ||\n    (interaction.simulation && interaction.simulation.active) ||\n  noPreEnd) {\n    return null\n  }\n\n  const options = getOptions(interaction)\n\n  const now = interaction._now()\n  const { client: velocityClient } = interaction.coords.velocity\n  const pointerSpeed = utils.hypot(velocityClient.x, velocityClient.y)\n\n  let smoothEnd = false\n  let modifierResult: ReturnType<typeof modifiers.setAll>\n\n  // check if inertia should be started\n  const inertiaPossible = (options && options.enabled &&\n                     interaction.prepared.name !== 'gesture' &&\n                     event !== state.startEvent)\n\n  const inertia = (inertiaPossible &&\n    (now - interaction.coords.cur.timeStamp) < 50 &&\n    pointerSpeed > options.minSpeed &&\n    pointerSpeed > options.endSpeed)\n\n  const modifierArg = {\n    interaction,\n    pageCoords: interaction.coords.cur.page,\n    states: inertiaPossible && interaction.modifiers.states.map(\n      modifierStatus => utils.extend({}, modifierStatus)\n    ),\n    preEnd: true,\n    prevCoords: null,\n    requireEndOnly: null,\n    phase: EventPhase.InertiaStart,\n  }\n\n  // smoothEnd\n  if (inertiaPossible && !inertia) {\n    modifierArg.prevCoords = interaction.modifiers.result\n      ? interaction.modifiers.result.coords\n      : interaction.prevEvent.page\n    modifierArg.requireEndOnly = false\n    modifierResult = modifiers.setAll(modifierArg)\n\n    if (modifierResult.changed) {\n      smoothEnd = true\n    }\n  }\n\n  if (!(inertia || smoothEnd)) { return null }\n\n  utils.pointer.copyCoords(state.upCoords, interaction.coords.cur)\n\n  setCoords(modifierArg)\n  interaction.pointers[0].pointer = state.startEvent = new scope.InteractEvent(\n    interaction,\n    event,\n    // FIXME add proper typing Action.name\n    interaction.prepared.name as T,\n    EventPhase.InertiaStart,\n    interaction.element,\n  )\n  restoreCoords(modifierArg)\n\n  state.t0 = now\n\n  state.active = true\n  state.allowResume = options.allowResume\n  interaction.simulation = state\n\n  interaction.interactable.fire(state.startEvent)\n\n  if (inertia) {\n    state.vx0 = interaction.coords.velocity.client.x\n    state.vy0 = interaction.coords.velocity.client.y\n    state.v0 = pointerSpeed\n\n    calcInertia(interaction, state)\n\n    utils.extend(modifierArg.pageCoords, interaction.coords.cur.page)\n\n    modifierArg.pageCoords.x += state.xe\n    modifierArg.pageCoords.y += state.ye\n    modifierArg.prevCoords = null\n    modifierArg.requireEndOnly = true\n\n    modifierResult = modifiers.setAll(modifierArg)\n\n    state.modifiedXe += modifierResult.delta.x\n    state.modifiedYe += modifierResult.delta.y\n\n    state.timeout = raf.request(() => inertiaTick(interaction))\n  }\n  else {\n    state.smoothEnd = true\n    state.xe = modifierResult.delta.x\n    state.ye = modifierResult.delta.y\n\n    state.sx = state.sy = 0\n\n    state.timeout = raf.request(() => smothEndTick(interaction))\n  }\n\n  return false\n}\n\nfunction stop ({ interaction }: Interact.SignalArg) {\n  const state = interaction.inertia\n  if (state.active) {\n    raf.cancel(state.timeout)\n    state.active = false\n    interaction.simulation = null\n  }\n}\n\nfunction calcInertia (interaction: Interact.Interaction, state) {\n  const options = getOptions(interaction)\n  const lambda = options.resistance\n  const inertiaDur = -Math.log(options.endSpeed / state.v0) / lambda\n\n  state.x0 = interaction.prevEvent.page.x\n  state.y0 = interaction.prevEvent.page.y\n  state.t0 = state.startEvent.timeStamp / 1000\n  state.sx = state.sy = 0\n\n  state.modifiedXe = state.xe = (state.vx0 - inertiaDur) / lambda\n  state.modifiedYe = state.ye = (state.vy0 - inertiaDur) / lambda\n  state.te = inertiaDur\n\n  state.lambda_v0 = lambda / state.v0\n  state.one_ve_v0 = 1 - options.endSpeed / state.v0\n}\n\nfunction inertiaTick (interaction: Interact.Interaction) {\n  updateInertiaCoords(interaction)\n  utils.pointer.setCoordDeltas(interaction.coords.delta, interaction.coords.prev, interaction.coords.cur)\n  utils.pointer.setCoordVelocity(interaction.coords.velocity, interaction.coords.delta)\n\n  const state = interaction.inertia\n  const options = getOptions(interaction)\n  const lambda = options.resistance\n  const t = interaction._now() / 1000 - state.t0\n\n  if (t < state.te) {\n    const progress =  1 - (Math.exp(-lambda * t) - state.lambda_v0) / state.one_ve_v0\n\n    if (state.modifiedXe === state.xe && state.modifiedYe === state.ye) {\n      state.sx = state.xe * progress\n      state.sy = state.ye * progress\n    }\n    else {\n      const quadPoint = utils.getQuadraticCurvePoint(\n        0, 0,\n        state.xe, state.ye,\n        state.modifiedXe, state.modifiedYe,\n        progress)\n\n      state.sx = quadPoint.x\n      state.sy = quadPoint.y\n    }\n\n    interaction.move()\n\n    state.timeout = raf.request(() => inertiaTick(interaction))\n  }\n  else {\n    state.sx = state.modifiedXe\n    state.sy = state.modifiedYe\n\n    interaction.move()\n    interaction.end(state.startEvent)\n    state.active = false\n    interaction.simulation = null\n  }\n\n  utils.pointer.copyCoords(interaction.coords.prev, interaction.coords.cur)\n}\n\nfunction smothEndTick (interaction: Interact.Interaction) {\n  updateInertiaCoords(interaction)\n\n  const state = interaction.inertia\n  const t = interaction._now() - state.t0\n  const { smoothEndDuration: duration } = getOptions(interaction)\n\n  if (t < duration) {\n    state.sx = utils.easeOutQuad(t, 0, state.xe, duration)\n    state.sy = utils.easeOutQuad(t, 0, state.ye, duration)\n\n    interaction.move()\n\n    state.timeout = raf.request(() => smothEndTick(interaction))\n  }\n  else {\n    state.sx = state.xe\n    state.sy = state.ye\n\n    interaction.move()\n    interaction.end(state.startEvent)\n\n    state.smoothEnd =\n      state.active = false\n    interaction.simulation = null\n  }\n}\n\nfunction updateInertiaCoords (interaction: Interact.Interaction) {\n  const state = interaction.inertia\n\n  // return if inertia isn't running\n  if (!state.active) { return }\n\n  const pageUp   = state.upCoords.page\n  const clientUp = state.upCoords.client\n\n  utils.pointer.setCoords(interaction.coords.cur, [{\n    pageX  : pageUp.x   + state.sx,\n    pageY  : pageUp.y   + state.sy,\n    clientX: clientUp.x + state.sx,\n    clientY: clientUp.y + state.sy,\n  }], interaction._now())\n}\n\nfunction getOptions ({ interactable, prepared }: Interact.Interaction) {\n  return interactable &&\n    interactable.options &&\n    prepared.name &&\n    interactable.options[prepared.name].inertia\n}\n\nexport default {\n  id: 'inertia',\n  install,\n  calcInertia,\n  inertiaTick,\n  smothEndTick,\n  updateInertiaCoords,\n}\n"]} | ||
//# sourceMappingURL=index.js.map |
{ | ||
"name": "@interactjs/inertia", | ||
"version": "1.6.3", | ||
"version": "1.7.0", | ||
"license": "MIT", | ||
"peerDependencies": { | ||
"@interactjs/core": "1.6.3", | ||
"@interactjs/modifiers": "1.6.3", | ||
"@interactjs/utils": "1.6.3" | ||
"@interactjs/core": "1.7.0", | ||
"@interactjs/modifiers": "1.7.0", | ||
"@interactjs/utils": "1.7.0" | ||
}, | ||
"devDependencies": { | ||
"@interactjs/actions": "1.6.3" | ||
"@interactjs/actions": "1.7.0" | ||
}, | ||
@@ -13,0 +13,0 @@ "publishConfig": { |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
7
337
38316