UNPKG

5.09 kBJavaScriptView Raw
1"use strict";
2
3exports.__esModule = true;
4exports.default = void 0;
5
6var _ssrWindow = require("ssr-window");
7
8var _dom = _interopRequireDefault(require("../../utils/dom"));
9
10var _utils = require("../../utils/utils");
11
12function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
14function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
15
16var Keyboard = {
17 handle: function handle(event) {
18 var swiper = this;
19 var window = (0, _ssrWindow.getWindow)();
20 var document = (0, _ssrWindow.getDocument)();
21 var rtl = swiper.rtlTranslate;
22 var e = event;
23 if (e.originalEvent) e = e.originalEvent; // jquery fix
24
25 var kc = e.keyCode || e.charCode;
26 var pageUpDown = swiper.params.keyboard.pageUpDown;
27 var isPageUp = pageUpDown && kc === 33;
28 var isPageDown = pageUpDown && kc === 34;
29 var isArrowLeft = kc === 37;
30 var isArrowRight = kc === 39;
31 var isArrowUp = kc === 38;
32 var isArrowDown = kc === 40; // Directions locks
33
34 if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {
35 return false;
36 }
37
38 if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {
39 return false;
40 }
41
42 if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {
43 return undefined;
44 }
45
46 if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {
47 return undefined;
48 }
49
50 if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {
51 var inView = false; // Check that swiper should be inside of visible area of window
52
53 if (swiper.$el.parents("." + swiper.params.slideClass).length > 0 && swiper.$el.parents("." + swiper.params.slideActiveClass).length === 0) {
54 return undefined;
55 }
56
57 var $el = swiper.$el;
58 var swiperWidth = $el[0].clientWidth;
59 var swiperHeight = $el[0].clientHeight;
60 var windowWidth = window.innerWidth;
61 var windowHeight = window.innerHeight;
62 var swiperOffset = swiper.$el.offset();
63 if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;
64 var swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];
65
66 for (var i = 0; i < swiperCoord.length; i += 1) {
67 var point = swiperCoord[i];
68
69 if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {
70 if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line
71
72 inView = true;
73 }
74 }
75
76 if (!inView) return undefined;
77 }
78
79 if (swiper.isHorizontal()) {
80 if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {
81 if (e.preventDefault) e.preventDefault();else e.returnValue = false;
82 }
83
84 if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();
85 if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();
86 } else {
87 if (isPageUp || isPageDown || isArrowUp || isArrowDown) {
88 if (e.preventDefault) e.preventDefault();else e.returnValue = false;
89 }
90
91 if (isPageDown || isArrowDown) swiper.slideNext();
92 if (isPageUp || isArrowUp) swiper.slidePrev();
93 }
94
95 swiper.emit('keyPress', kc);
96 return undefined;
97 },
98 enable: function enable() {
99 var swiper = this;
100 var document = (0, _ssrWindow.getDocument)();
101 if (swiper.keyboard.enabled) return;
102 (0, _dom.default)(document).on('keydown', swiper.keyboard.handle);
103 swiper.keyboard.enabled = true;
104 },
105 disable: function disable() {
106 var swiper = this;
107 var document = (0, _ssrWindow.getDocument)();
108 if (!swiper.keyboard.enabled) return;
109 (0, _dom.default)(document).off('keydown', swiper.keyboard.handle);
110 swiper.keyboard.enabled = false;
111 }
112};
113var _default = {
114 name: 'keyboard',
115 params: {
116 keyboard: {
117 enabled: false,
118 onlyInViewport: true,
119 pageUpDown: true
120 }
121 },
122 create: function create() {
123 var swiper = this;
124 (0, _utils.bindModuleMethods)(swiper, {
125 keyboard: _extends({
126 enabled: false
127 }, Keyboard)
128 });
129 },
130 on: {
131 init: function init(swiper) {
132 if (swiper.params.keyboard.enabled) {
133 swiper.keyboard.enable();
134 }
135 },
136 destroy: function destroy(swiper) {
137 if (swiper.keyboard.enabled) {
138 swiper.keyboard.disable();
139 }
140 }
141 }
142};
143exports.default = _default;
\No newline at end of file