UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

233 lines (232 loc) 6.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.PickerModeMap = void 0; exports.addGlobalMousedownEvent = addGlobalMousedownEvent; exports.createKeydownHandler = createKeydownHandler; exports.elementsContains = elementsContains; exports.getDefaultFormat = getDefaultFormat; exports.getInputSize = getInputSize; exports.getTargetFromEvent = getTargetFromEvent; exports.scrollTo = scrollTo; exports.waitElementReady = waitElementReady; var _isVisible = _interopRequireDefault(require("../../vc-util/Dom/isVisible")); var _KeyCode = _interopRequireDefault(require("../../_util/KeyCode")); var _raf = _interopRequireDefault(require("../../_util/raf")); const scrollIds = new Map(); /** Trigger when element is visible in view */ function waitElementReady(element, callback) { let id; function tryOrNextFrame() { if ((0, _isVisible.default)(element)) { callback(); } else { id = (0, _raf.default)(() => { tryOrNextFrame(); }); } } tryOrNextFrame(); return () => { _raf.default.cancel(id); }; } /* eslint-disable no-param-reassign */ function scrollTo(element, to, duration) { if (scrollIds.get(element)) { _raf.default.cancel(scrollIds.get(element)); } // jump to target if duration zero if (duration <= 0) { scrollIds.set(element, (0, _raf.default)(() => { element.scrollTop = to; })); return; } const difference = to - element.scrollTop; const perTick = difference / duration * 10; scrollIds.set(element, (0, _raf.default)(() => { element.scrollTop += perTick; if (element.scrollTop !== to) { scrollTo(element, to, duration - 10); } })); } function createKeydownHandler(event, _ref) { let { onLeftRight, onCtrlLeftRight, onUpDown, onPageUpDown, onEnter } = _ref; const { which, ctrlKey, metaKey } = event; switch (which) { case _KeyCode.default.LEFT: if (ctrlKey || metaKey) { if (onCtrlLeftRight) { onCtrlLeftRight(-1); return true; } } else if (onLeftRight) { onLeftRight(-1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.RIGHT: if (ctrlKey || metaKey) { if (onCtrlLeftRight) { onCtrlLeftRight(1); return true; } } else if (onLeftRight) { onLeftRight(1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.UP: if (onUpDown) { onUpDown(-1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.DOWN: if (onUpDown) { onUpDown(1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.PAGE_UP: if (onPageUpDown) { onPageUpDown(-1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.PAGE_DOWN: if (onPageUpDown) { onPageUpDown(1); return true; } /* istanbul ignore next */ break; case _KeyCode.default.ENTER: if (onEnter) { onEnter(); return true; } /* istanbul ignore next */ break; } return false; } // ===================== Format ===================== function getDefaultFormat(format, picker, showTime, use12Hours) { let mergedFormat = format; if (!mergedFormat) { switch (picker) { case 'time': mergedFormat = use12Hours ? 'hh:mm:ss a' : 'HH:mm:ss'; break; case 'week': mergedFormat = 'gggg-wo'; break; case 'month': mergedFormat = 'YYYY-MM'; break; case 'quarter': mergedFormat = 'YYYY-[Q]Q'; break; case 'year': mergedFormat = 'YYYY'; break; default: mergedFormat = showTime ? 'YYYY-MM-DD HH:mm:ss' : 'YYYY-MM-DD'; } } return mergedFormat; } function getInputSize(picker, format, generateConfig) { const defaultSize = picker === 'time' ? 8 : 10; const length = typeof format === 'function' ? format(generateConfig.getNow()).length : format.length; return Math.max(defaultSize, length) + 2; } let globalClickFunc = null; const clickCallbacks = new Set(); function addGlobalMousedownEvent(callback) { if (!globalClickFunc && typeof window !== 'undefined' && window.addEventListener) { globalClickFunc = e => { // Clone a new list to avoid repeat trigger events [...clickCallbacks].forEach(queueFunc => { queueFunc(e); }); }; window.addEventListener('mousedown', globalClickFunc); } clickCallbacks.add(callback); return () => { clickCallbacks.delete(callback); if (clickCallbacks.size === 0) { window.removeEventListener('mousedown', globalClickFunc); globalClickFunc = null; } }; } function getTargetFromEvent(e) { var _a; const target = e.target; // get target if in shadow dom if (e.composed && target.shadowRoot) { return ((_a = e.composedPath) === null || _a === void 0 ? void 0 : _a.call(e)[0]) || target; } return target; } // ====================== Mode ====================== const getYearNextMode = next => { if (next === 'month' || next === 'date') { return 'year'; } return next; }; const getMonthNextMode = next => { if (next === 'date') { return 'month'; } return next; }; const getQuarterNextMode = next => { if (next === 'month' || next === 'date') { return 'quarter'; } return next; }; const getWeekNextMode = next => { if (next === 'date') { return 'week'; } return next; }; const PickerModeMap = exports.PickerModeMap = { year: getYearNextMode, month: getMonthNextMode, quarter: getQuarterNextMode, week: getWeekNextMode, time: null, date: null }; function elementsContains(elements, target) { if (process.env.NODE_ENV === 'test') { return false; } return elements.some(ele => ele && ele.contains(target)); }