UNPKG

quasar

Version:

Build high-performance VueJS user interfaces (SPA, PWA, SSR, Mobile and Desktop) in record time

62 lines (52 loc) 1.41 kB
import { isSSR, client, iosEmulated } from '../plugins/Platform.js' const directions = [ 'left', 'right', 'up', 'down', 'horizontal', 'vertical' ] const modifiersAll = { left: true, right: true, up: true, down: true, horizontal: true, vertical: true, all: true } export function getModifierDirections (mod) { const dir = {} directions.forEach(direction => { if (mod[direction]) { dir[direction] = true } }) if (Object.keys(dir).length === 0) { return modifiersAll } if (dir.horizontal === true) { dir.left = dir.right = true } if (dir.vertical === true) { dir.up = dir.down = true } if (dir.left === true && dir.right === true) { dir.horizontal = true } if (dir.up === true && dir.down === true) { dir.vertical = true } if (dir.horizontal === true && dir.vertical === true) { dir.all = true } return dir } export const getTouchTarget = isSSR === false && iosEmulated !== true && ( client.is.ios === true || window.navigator.vendor.toLowerCase().indexOf('apple') > -1 ) ? () => document : target => target export function shouldStart (evt, ctx) { return ctx.event === void 0 && evt.target !== void 0 && evt.target.draggable !== true && typeof ctx.handler === 'function' && evt.target.nodeName.toUpperCase() !== 'INPUT' && (evt.qClonedBy === void 0 || evt.qClonedBy.indexOf(ctx.uid) === -1) }