UNPKG

material-motion

Version:

Makes it easy to add rich, interactive motion to your application.

61 lines (53 loc) 2.19 kB
/** @license * Copyright 2016 - present The Material Motion Authors. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); you may not * use this file except in compliance with the License. You may obtain a copy * of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the * License for the specific language governing permissions and limitations * under the License. */ import { MotionObservable, } from '../observables/MotionObservable'; import { ObservableWithMotionOperators, Observer, } from '../types'; // Passive event feature detection from // https://github.com/WICG/EventListenerOptions/blob/gh-pages/explainer.md let supportsPassiveListeners = false; try { const eventOptions: any = Object.defineProperty({}, 'passive', { get() { supportsPassiveListeners = true; } }); window.addEventListener("test", () => {}, eventOptions); } catch (e) {} export function getEventStreamFromElement<U extends Event = Event>(type: string, element: Element, eventListenerOptions: AddEventListenerOptions = { passive: true }): ObservableWithMotionOperators<U> { return new MotionObservable<U>( (observer: Observer<U>) => { if (!supportsPassiveListeners) { eventListenerOptions = (eventListenerOptions.capture || false) as any as AddEventListenerOptions; } const next = observer.next.bind(observer); // For some reason, TypeScript has an interface for // AddEventListenerOptions, but its addEventListener signature hasn't been // updated to use it, so for now, we manually cast to boolean. // // https://github.com/Microsoft/TypeScript/issues/18136 element.addEventListener(type, next, eventListenerOptions as any as boolean); return () => { element.removeEventListener(type, next, eventListenerOptions as any as boolean); }; } ); } export default getEventStreamFromElement;