material-motion
Version:
Makes it easy to add rich, interactive motion to your application.
52 lines (48 loc) • 1.91 kB
text/typescript
/** @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 {
Dict,
ObservableWithMotionOperators,
PartialPointerEvent,
} from '../types';
// TouchEvent types from https://developer.apple.com/reference/webkitjs/touchevent/
// PointerEvent types from https://w3c.github.io/pointerevents/
const TOUCH_TYPE_TO_POINTER_TYPE: Dict<string> = {
'touchstart': 'pointerdown',
'touchmove': 'pointermove',
'touchend': 'pointerup',
'touchcancel': 'pointercancel',
};
export function convertTouchEventsToPointerEvents(touchEvent$: ObservableWithMotionOperators<TouchEvent>): ObservableWithMotionOperators<PartialPointerEvent> {
return touchEvent$._map({
transform: ({ type, targetTouches, changedTouches }: TouchEvent) => Array.from(
['touchend', 'touchcancel'].includes(type)
? changedTouches
: targetTouches,
({ clientX, clientY, identifier }: Touch) => (
{
// `PointerEvent` defines `x` and `y` as aliases for `clientX` and
// `clientY`, but `TouchEvent` doesn't have the same sugar.
x: clientX,
y: clientY,
pointerId: identifier,
type: TOUCH_TYPE_TO_POINTER_TYPE[type]
}
)
)
})._flattenIterables<PartialPointerEvent>();
}
export default convertTouchEventsToPointerEvents;