UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

1,183 lines (1,179 loc) • 54.8 kB
/** * DevExtreme (cjs/ui/overlay/ui.overlay.js) * Version: 21.2.4 * Build date: Mon Dec 06 2021 * * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; exports.default = void 0; var _size = require("../../core/utils/size"); var _fx = _interopRequireDefault(require("../../animation/fx")); var _component_registrator = _interopRequireDefault(require("../../core/component_registrator")); var _devices = _interopRequireDefault(require("../../core/devices")); var _dom_adapter = _interopRequireDefault(require("../../core/dom_adapter")); var _element = require("../../core/element"); var _renderer = _interopRequireDefault(require("../../core/renderer")); var _empty_template = require("../../core/templates/empty_template"); var _array = require("../../core/utils/array"); var _common = require("../../core/utils/common"); var _deferred = require("../../core/utils/deferred"); var _dom = require("../../core/utils/dom"); var _extend = require("../../core/utils/extend"); var _iterator = require("../../core/utils/iterator"); var _ready_callbacks = _interopRequireDefault(require("../../core/utils/ready_callbacks")); var _type = require("../../core/utils/type"); var _view_port = require("../../core/utils/view_port"); var _window = require("../../core/utils/window"); var _errors = _interopRequireDefault(require("../../core/errors")); var _events_engine = _interopRequireDefault(require("../../events/core/events_engine")); var _drag = require("../../events/drag"); var _pointer = _interopRequireDefault(require("../../events/pointer")); var _short = require("../../events/short"); var _index = require("../../events/utils/index"); var _visibility_change = require("../../events/visibility_change"); var _hide_callback = require("../../mobile/hide_callback"); var _resizable = _interopRequireDefault(require("../resizable")); var _overlay_drag = _interopRequireDefault(require("./overlay_drag")); var _selectors = require("../widget/selectors"); var _swatch_container = _interopRequireDefault(require("../widget/swatch_container")); var _ui = _interopRequireDefault(require("../widget/ui.widget")); var _browser = _interopRequireDefault(require("../../core/utils/browser")); var zIndexPool = _interopRequireWildcard(require("./z_index")); var _resize_observer = _interopRequireDefault(require("../../core/resize_observer")); var _overlay_position_controller = require("./overlay_position_controller"); function _getRequireWildcardCache(nodeInterop) { if ("function" !== typeof WeakMap) { return null } var cacheBabelInterop = new WeakMap; var cacheNodeInterop = new WeakMap; return (_getRequireWildcardCache = function(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop })(nodeInterop) } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj } if (null === obj || "object" !== _typeof(obj) && "function" !== typeof obj) { return { default: obj } } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj) } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if ("default" !== key && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc) } else { newObj[key] = obj[key] } } } newObj.default = obj; if (cache) { cache.set(obj, newObj) } return newObj } function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj } } function _typeof(obj) { if ("function" === typeof Symbol && "symbol" === typeof Symbol.iterator) { _typeof = function(obj) { return typeof obj } } else { _typeof = function(obj) { return obj && "function" === typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj } } return _typeof(obj) } var ready = _ready_callbacks.default.add; var window = (0, _window.getWindow)(); var viewPortChanged = _view_port.changeCallback; var OVERLAY_CLASS = "dx-overlay"; var OVERLAY_WRAPPER_CLASS = "dx-overlay-wrapper"; var OVERLAY_CONTENT_CLASS = "dx-overlay-content"; var OVERLAY_SHADER_CLASS = "dx-overlay-shader"; var OVERLAY_MODAL_CLASS = "dx-overlay-modal"; var INNER_OVERLAY_CLASS = "dx-inner-overlay"; var INVISIBLE_STATE_CLASS = "dx-state-invisible"; var ANONYMOUS_TEMPLATE_NAME = "content"; var RTL_DIRECTION_CLASS = "dx-rtl"; var ACTIONS = ["onShowing", "onShown", "onHiding", "onHidden", "onPositioned", "onResizeStart", "onResize", "onResizeEnd", "onVisualPositionChanged"]; var OVERLAY_STACK = []; var DISABLED_STATE_CLASS = "dx-state-disabled"; var PREVENT_SAFARI_SCROLLING_CLASS = "dx-prevent-safari-scrolling"; var TAB_KEY = "tab"; ready((function() { _events_engine.default.subscribeGlobal(_dom_adapter.default.getDocument(), _pointer.default.down, (function(e) { for (var i = OVERLAY_STACK.length - 1; i >= 0; i--) { if (!OVERLAY_STACK[i]._proxiedDocumentDownHandler(e)) { return } } })) })); var Overlay = _ui.default.inherit({ _supportedKeys: function() { var _this = this; return (0, _extend.extend)(this.callBase(), { escape: function() { this.hide() }, upArrow: function(e) { _this._drag.moveUp(e) }, downArrow: function(e) { _this._drag.moveDown(e) }, leftArrow: function(e) { _this._drag.moveLeft(e) }, rightArrow: function(e) { _this._drag.moveRight(e) } }) }, _getDefaultOptions: function() { var _this2 = this; return (0, _extend.extend)(this.callBase(), { activeStateEnabled: false, visible: false, deferRendering: true, shading: true, shadingColor: "", wrapperAttr: {}, position: (0, _extend.extend)({}, _overlay_position_controller.OVERLAY_POSITION_ALIASES.center), width: "80vw", minWidth: null, maxWidth: null, height: "80vh", minHeight: null, maxHeight: null, animation: { show: { type: "pop", duration: 300, from: { scale: .55 } }, hide: { type: "pop", duration: 300, to: { opacity: 0, scale: .55 }, from: { opacity: 1, scale: 1 } } }, dragOutsideBoundary: false, closeOnOutsideClick: false, copyRootClassesToWrapper: false, _ignoreCopyRootClassesToWrapperDeprecation: false, onShowing: null, onShown: null, onHiding: null, onHidden: null, contentTemplate: "content", dragEnabled: false, dragAndResizeArea: void 0, outsideDragFactor: 0, resizeEnabled: false, onResizeStart: null, onResize: null, onResizeEnd: null, innerOverlay: false, restorePosition: true, target: void 0, container: void 0, hideTopOverlayHandler: function() { _this2.hide() }, hideOnParentScroll: false, onPositioned: null, propagateOutsideClick: false, ignoreChildEvents: true, _checkParentVisibility: true, _fixWrapperPosition: false }) }, _defaultOptionsRules: function() { return this.callBase().concat([{ device: function() { return !(0, _window.hasWindow)() }, options: { width: null, height: null, animation: null, _checkParentVisibility: false } }]) }, _setOptionsByReference: function() { this.callBase(); (0, _extend.extend)(this._optionsByReference, { animation: true }) }, $wrapper: function() { return this._$wrapper }, _eventBindingTarget: function() { return this._$content }, _setDeprecatedOptions: function() { this.callBase(); (0, _extend.extend)(this._deprecatedOptions, { elementAttr: { since: "21.2", message: 'Use the "wrapperAttr" option instead' } }) }, ctor: function(element, options) { this.callBase(element, options); if (options && options.copyRootClassesToWrapper && !options._ignoreCopyRootClassesToWrapperDeprecation) { _errors.default.log("W0001", this.NAME, "copyRootClassesToWrapper", "21.2", 'Use the "wrapperAttr" option instead') } }, _init: function() { var _this3 = this; this.callBase(); this._initActions(); this._initCloseOnOutsideClickHandler(); this._initTabTerminatorHandler(); this._customWrapperClass = null; this._$wrapper = (0, _renderer.default)("<div>").addClass(OVERLAY_WRAPPER_CLASS); this._$content = (0, _renderer.default)("<div>").addClass(OVERLAY_CONTENT_CLASS); this._initInnerOverlayClass(); var $element = this.$element(); if (this.option("copyRootClassesToWrapper")) { this._$wrapper.addClass($element.attr("class")) } $element.addClass(OVERLAY_CLASS); this._$wrapper.attr("data-bind", "dxControlsDescendantBindings: true"); this._toggleViewPortSubscription(true); this._initHideTopOverlayHandler(this.option("hideTopOverlayHandler")); this._parentsScrollSubscriptionInfo = { handler: function(e) { _this3._targetParentsScrollHandler(e) } }; this._updateResizeCallbackSkipCondition(); this.warnPositionAsFunction() }, warnPositionAsFunction: function() { if ((0, _type.isFunction)(this.option("position"))) { _errors.default.log("W0018") } }, _initOptions: function(options) { this._setAnimationTarget(options.target); this.callBase(options) }, _initInnerOverlayClass: function() { this._$content.toggleClass(INNER_OVERLAY_CLASS, this.option("innerOverlay")) }, _setAnimationTarget: function(target) { if (!(0, _type.isDefined)(target)) { return } var options = this.option(); ["animation.show.from.position.of", "animation.show.to.position.of", "animation.hide.from.position.of", "animation.hide.to.position.of"].forEach((function(path) { var pathParts = path.split("."); var option = options; while (option) { if (1 === pathParts.length) { if ((0, _type.isPlainObject)(option)) { option[pathParts.shift()] = target } break } else { option = option[pathParts.shift()] } } })) }, _initHideTopOverlayHandler: function(handler) { this._hideTopOverlayHandler = handler }, _initActions: function() { var _this4 = this; this._actions = {}; (0, _iterator.each)(ACTIONS, (function(_, action) { _this4._actions[action] = _this4._createActionByOption(action, { excludeValidators: ["disabled", "readOnly"] }) || _common.noop })) }, _initCloseOnOutsideClickHandler: function() { var _this5 = this; this._proxiedDocumentDownHandler = function() { return _this5._documentDownHandler.apply(_this5, arguments) } }, _areContentDimensionsRendered: function(entry) { var _entry$contentBoxSize, _this$_renderedDimens3, _this$_renderedDimens4; var contentBox = null === (_entry$contentBoxSize = entry.contentBoxSize) || void 0 === _entry$contentBoxSize ? void 0 : _entry$contentBoxSize[0]; if (contentBox) { var _this$_renderedDimens, _this$_renderedDimens2; return parseInt(contentBox.inlineSize, 10) === (null === (_this$_renderedDimens = this._renderedDimensions) || void 0 === _this$_renderedDimens ? void 0 : _this$_renderedDimens.width) && parseInt(contentBox.blockSize, 10) === (null === (_this$_renderedDimens2 = this._renderedDimensions) || void 0 === _this$_renderedDimens2 ? void 0 : _this$_renderedDimens2.height) } var contentRect = entry.contentRect; return parseInt(contentRect.width, 10) === (null === (_this$_renderedDimens3 = this._renderedDimensions) || void 0 === _this$_renderedDimens3 ? void 0 : _this$_renderedDimens3.width) && parseInt(contentRect.height, 10) === (null === (_this$_renderedDimens4 = this._renderedDimensions) || void 0 === _this$_renderedDimens4 ? void 0 : _this$_renderedDimens4.height) }, _contentResizeHandler: function(entry) { if (!this._shouldSkipContentResize(entry)) { this._renderGeometry({ shouldOnlyReposition: true }) } }, _updateResizeCallbackSkipCondition: function() { var _this6 = this; var doesShowAnimationChangeDimensions = this._doesShowAnimationChangeDimensions(); this._shouldSkipContentResize = function(entry) { return doesShowAnimationChangeDimensions && _this6._showAnimationProcessing || _this6._areContentDimensionsRendered(entry) } }, _doesShowAnimationChangeDimensions: function() { var animation = this.option("animation"); return ["to", "from"].some((function(prop) { var _animation$show; var config = null === animation || void 0 === animation ? void 0 : null === (_animation$show = animation.show) || void 0 === _animation$show ? void 0 : _animation$show[prop]; return (0, _type.isObject)(config) && ("width" in config || "height" in config) })) }, _observeContentResize: function(shouldObserve) { var _this7 = this; if (!this.option("useResizeObserver")) { return } var contentElement = this._$content.get(0); if (shouldObserve) { _resize_observer.default.observe(contentElement, (function(entry) { _this7._contentResizeHandler(entry) })) } else { _resize_observer.default.unobserve(contentElement) } }, _initMarkup: function() { this.callBase(); this._renderWrapperAttributes(); this._initPositionController() }, _documentDownHandler: function(e) { if (this._showAnimationProcessing) { this._stopAnimation() } var closeOnOutsideClick = this.option("closeOnOutsideClick"); if ((0, _type.isFunction)(closeOnOutsideClick)) { closeOnOutsideClick = closeOnOutsideClick(e) } var isAttachedTarget = (0, _renderer.default)(window.document).is(e.target) || (0, _dom.contains)(window.document, e.target); var isInnerOverlay = (0, _renderer.default)(e.target).closest(".".concat(INNER_OVERLAY_CLASS)).length; var outsideClick = isAttachedTarget && !isInnerOverlay && !(this._$content.is(e.target) || (0, _dom.contains)(this._$content.get(0), e.target)); if (outsideClick && closeOnOutsideClick) { this._outsideClickHandler(e) } return this.option("propagateOutsideClick") }, _outsideClickHandler: function(e) { if (this.option("shading")) { e.preventDefault() } this.hide() }, _getAnonymousTemplateName: function() { return ANONYMOUS_TEMPLATE_NAME }, _initTemplates: function() { this._templateManager.addDefaultTemplates({ content: new _empty_template.EmptyTemplate }); this.callBase() }, _isTopOverlay: function() { var overlayStack = this._overlayStack(); for (var i = overlayStack.length - 1; i >= 0; i--) { var tabbableElements = overlayStack[i]._findTabbableBounds(); if (tabbableElements.first || tabbableElements.last) { return overlayStack[i] === this } } return false }, _overlayStack: function() { return OVERLAY_STACK }, _zIndexInitValue: function() { return Overlay.baseZIndex() }, _toggleViewPortSubscription: function(toggle) { var _this8 = this; viewPortChanged.remove(this._viewPortChangeHandle); if (toggle) { this._viewPortChangeHandle = function() { _this8._viewPortChangeHandler.apply(_this8, arguments) }; viewPortChanged.add(this._viewPortChangeHandle) } }, _viewPortChangeHandler: function() { this._positionController.updateContainer(this.option("container")); this._refresh() }, _renderWrapperAttributes: function() { var _this$option = this.option(), wrapperAttr = _this$option.wrapperAttr; var attributes = (0, _extend.extend)({}, wrapperAttr); var classNames = attributes.class; delete attributes.class; this.$wrapper().attr(attributes).removeClass(this._customWrapperClass).addClass(classNames); this._customWrapperClass = classNames }, _renderVisibilityAnimate: function(visible) { this._observeContentResize(visible); this._stopAnimation(); return visible ? this._show() : this._hide() }, _getAnimationConfig: function() { return this._getOptionValue("animation", this) }, _animateShowing: function() { var _this$_getAnimationCo, _showAnimation$start, _showAnimation$comple, _this9 = this; var animation = null !== (_this$_getAnimationCo = this._getAnimationConfig()) && void 0 !== _this$_getAnimationCo ? _this$_getAnimationCo : {}; var showAnimation = this._normalizeAnimation(animation.show, "to"); var startShowAnimation = null !== (_showAnimation$start = null === showAnimation || void 0 === showAnimation ? void 0 : showAnimation.start) && void 0 !== _showAnimation$start ? _showAnimation$start : _common.noop; var completeShowAnimation = null !== (_showAnimation$comple = null === showAnimation || void 0 === showAnimation ? void 0 : showAnimation.complete) && void 0 !== _showAnimation$comple ? _showAnimation$comple : _common.noop; this._animate(showAnimation, (function() { if (_this9._isAnimationPaused) { return } if (_this9.option("focusStateEnabled")) { _events_engine.default.trigger(_this9._focusTarget(), "focus") } for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key] } completeShowAnimation.call.apply(completeShowAnimation, [_this9].concat(args)); _this9._showAnimationProcessing = false; _this9._isHidden = false; _this9._actions.onShown(); _this9._toggleSafariScrolling(); _this9._showingDeferred.resolve() }), (function() { if (_this9._isAnimationPaused) { return } for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { args[_key2] = arguments[_key2] } startShowAnimation.call.apply(startShowAnimation, [_this9].concat(args)); _this9._showAnimationProcessing = true })) }, _show: function() { var _this10 = this; this._showingDeferred = new _deferred.Deferred; this._parentHidden = this._isParentHidden(); this._showingDeferred.done((function() { delete _this10._parentHidden })); if (this._parentHidden) { this._isHidden = true; return this._showingDeferred.resolve() } if (this._currentVisible) { return (new _deferred.Deferred).resolve().promise() } this._currentVisible = true; if (this._isHidingActionCanceled) { delete this._isHidingActionCanceled; this._showingDeferred.resolve() } else { var show = function() { _this10._renderVisibility(true); if (_this10._isShowingActionCanceled) { delete _this10._isShowingActionCanceled; _this10._showingDeferred.resolve(); return } _this10._animateShowing() }; if (this.option("templatesRenderAsynchronously")) { this._stopShowTimer(); this._asyncShowTimeout = setTimeout(show) } else { show() } } return this._showingDeferred.promise() }, _normalizeAnimation: function(animation, prop) { if (animation) { animation = (0, _extend.extend)({ type: "slide", skipElementInitialStyles: true }, animation); if (animation[prop] && "object" === _typeof(animation[prop])) { (0, _extend.extend)(animation[prop], { position: this._positionController._position }) } } return animation }, _animateHiding: function() { var _this$_getAnimationCo2, _hideAnimation$start, _hideAnimation$comple, _this11 = this; var animation = null !== (_this$_getAnimationCo2 = this._getAnimationConfig()) && void 0 !== _this$_getAnimationCo2 ? _this$_getAnimationCo2 : {}; var hideAnimation = this._normalizeAnimation(animation.hide, "from"); var startHideAnimation = null !== (_hideAnimation$start = null === hideAnimation || void 0 === hideAnimation ? void 0 : hideAnimation.start) && void 0 !== _hideAnimation$start ? _hideAnimation$start : _common.noop; var completeHideAnimation = null !== (_hideAnimation$comple = null === hideAnimation || void 0 === hideAnimation ? void 0 : hideAnimation.complete) && void 0 !== _hideAnimation$comple ? _hideAnimation$comple : _common.noop; this._animate(hideAnimation, (function() { var _this11$_actions; _this11._$content.css("pointerEvents", ""); _this11._renderVisibility(false); for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) { args[_key3] = arguments[_key3] } completeHideAnimation.call.apply(completeHideAnimation, [_this11].concat(args)); _this11._hideAnimationProcessing = false; null === (_this11$_actions = _this11._actions) || void 0 === _this11$_actions ? void 0 : _this11$_actions.onHidden(); _this11._hidingDeferred.resolve() }), (function() { _this11._$content.css("pointerEvents", "none"); for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) { args[_key4] = arguments[_key4] } startHideAnimation.call.apply(startHideAnimation, [_this11].concat(args)); _this11._hideAnimationProcessing = true })) }, _hide: function() { if (!this._currentVisible) { return (new _deferred.Deferred).resolve().promise() } this._currentVisible = false; this._hidingDeferred = new _deferred.Deferred; var hidingArgs = { cancel: false }; if (this._isShowingActionCanceled) { this._hidingDeferred.resolve() } else { this._actions.onHiding(hidingArgs); this._toggleSafariScrolling(); if (hidingArgs.cancel) { this._isHidingActionCanceled = true; this.option("visible", true); this._hidingDeferred.resolve() } else { this._forceFocusLost(); this._toggleShading(false); this._toggleSubscriptions(false); this._stopShowTimer(); this._animateHiding() } } return this._hidingDeferred.promise() }, _forceFocusLost: function() { var activeElement = _dom_adapter.default.getActiveElement(); var shouldResetActiveElement = !!this._$content.find(activeElement).length; if (shouldResetActiveElement) { (0, _dom.resetActiveElement)() } }, _animate: function(animation, completeCallback, startCallback) { if (animation) { startCallback = startCallback || animation.start || _common.noop; _fx.default.animate(this._$content, (0, _extend.extend)({}, animation, { start: startCallback, complete: completeCallback })) } else { completeCallback() } }, _stopAnimation: function() { _fx.default.stop(this._$content, true) }, _renderVisibility: function(visible) { if (visible && this._isParentHidden()) { return } this._currentVisible = visible; this._stopAnimation(); if (!visible) { (0, _visibility_change.triggerHidingEvent)(this._$content) } this._toggleVisibility(visible); this._$content.toggleClass(INVISIBLE_STATE_CLASS, !visible); this._updateZIndexStackPosition(visible); if (visible) { this._positionController.openingHandled(); this._renderContent(); var showingArgs = { cancel: false }; this._actions.onShowing(showingArgs); if (showingArgs.cancel) { this._toggleVisibility(false); this._$content.toggleClass(INVISIBLE_STATE_CLASS, true); this._updateZIndexStackPosition(false); this._moveFromContainer(); this._isShowingActionCanceled = true; this.option("visible", false); return } this._moveToContainer(); this._renderGeometry(); (0, _visibility_change.triggerShownEvent)(this._$content); (0, _visibility_change.triggerResizeEvent)(this._$content) } else { this._moveFromContainer() } this._toggleShading(visible); this._toggleSubscriptions(visible) }, _updateZIndexStackPosition: function(pushToStack) { var overlayStack = this._overlayStack(); var index = (0, _array.inArray)(this, overlayStack); if (pushToStack) { if (-1 === index) { this._zIndex = zIndexPool.create(this._zIndexInitValue()); overlayStack.push(this) } this._$wrapper.css("zIndex", this._zIndex); this._$content.css("zIndex", this._zIndex) } else if (-1 !== index) { overlayStack.splice(index, 1); zIndexPool.remove(this._zIndex) } }, _toggleShading: function(visible) { this._$wrapper.toggleClass(OVERLAY_MODAL_CLASS, this.option("shading") && !this.option("container")); this._$wrapper.toggleClass(OVERLAY_SHADER_CLASS, visible && this.option("shading")); this._$wrapper.css("backgroundColor", this.option("shading") ? this.option("shadingColor") : ""); this._toggleTabTerminator(visible && this.option("shading")) }, _initTabTerminatorHandler: function() { var _this12 = this; this._proxiedTabTerminatorHandler = function() { _this12._tabKeyHandler.apply(_this12, arguments) } }, _toggleTabTerminator: function(enabled) { var eventName = (0, _index.addNamespace)("keydown", this.NAME); if (enabled) { _events_engine.default.on(_dom_adapter.default.getDocument(), eventName, this._proxiedTabTerminatorHandler) } else { _events_engine.default.off(_dom_adapter.default.getDocument(), eventName, this._proxiedTabTerminatorHandler) } }, _findTabbableBounds: function() { var $elements = this._$wrapper.find("*"); var elementsCount = $elements.length - 1; var result = { first: null, last: null }; for (var i = 0; i <= elementsCount; i++) { if (!result.first && $elements.eq(i).is(_selectors.tabbable)) { result.first = $elements.eq(i) } if (!result.last && $elements.eq(elementsCount - i).is(_selectors.tabbable)) { result.last = $elements.eq(elementsCount - i) } if (result.first && result.last) { break } } return result }, _tabKeyHandler: function(e) { if ((0, _index.normalizeKeyName)(e) !== TAB_KEY || !this._isTopOverlay()) { return } var tabbableElements = this._findTabbableBounds(); var $firstTabbable = tabbableElements.first; var $lastTabbable = tabbableElements.last; var isTabOnLast = !e.shiftKey && e.target === $lastTabbable.get(0); var isShiftTabOnFirst = e.shiftKey && e.target === $firstTabbable.get(0); var isEmptyTabList = 0 === tabbableElements.length; var isOutsideTarget = !(0, _dom.contains)(this._$wrapper.get(0), e.target); if (isTabOnLast || isShiftTabOnFirst || isEmptyTabList || isOutsideTarget) { e.preventDefault(); var $focusElement = e.shiftKey ? $lastTabbable : $firstTabbable; _events_engine.default.trigger($focusElement, "focusin"); _events_engine.default.trigger($focusElement, "focus") } }, _toggleSubscriptions: function(enabled) { if ((0, _window.hasWindow)()) { this._toggleHideTopOverlayCallback(enabled); this._toggleParentsScrollSubscription(enabled) } }, _toggleHideTopOverlayCallback: function(subscribe) { if (!this._hideTopOverlayHandler) { return } if (subscribe) { _hide_callback.hideCallback.add(this._hideTopOverlayHandler) } else { _hide_callback.hideCallback.remove(this._hideTopOverlayHandler) } }, _toggleParentsScrollSubscription: function(needSubscribe) { var _this$_parentsScrollS; var scrollEvent = (0, _index.addNamespace)("scroll", this.NAME); var _ref = null !== (_this$_parentsScrollS = this._parentsScrollSubscriptionInfo) && void 0 !== _this$_parentsScrollS ? _this$_parentsScrollS : {}, prevTargets = _ref.prevTargets, handler = _ref.handler; _events_engine.default.off(prevTargets, scrollEvent, handler); var closeOnScroll = this.option("hideOnParentScroll"); if (needSubscribe && closeOnScroll) { var $parents = this._$wrapper.parents(); if ("desktop" === _devices.default.real().deviceType) { $parents = $parents.add(window) } _events_engine.default.on($parents, scrollEvent, handler); this._parentsScrollSubscriptionInfo.prevTargets = $parents } }, _targetParentsScrollHandler: function(e) { var closeHandled = false; var closeOnScroll = this.option("hideOnParentScroll"); if ((0, _type.isFunction)(closeOnScroll)) { closeHandled = closeOnScroll(e) } if (!closeHandled && !this._showAnimationProcessing) { this.hide() } }, _render: function() { this.callBase(); this._appendContentToElement(); this._renderVisibilityAnimate(this.option("visible")) }, _appendContentToElement: function() { if (!this._$content.parent().is(this.$element())) { this._$content.appendTo(this.$element()) } }, _renderContent: function() { var shouldDeferRendering = !this._currentVisible && this.option("deferRendering"); var isParentHidden = this.option("visible") && this._isParentHidden(); if (isParentHidden) { this._isHidden = true; return } if (this._contentAlreadyRendered || shouldDeferRendering) { return } this._contentAlreadyRendered = true; this._appendContentToElement(); this.callBase() }, _isParentHidden: function() { if (!this.option("_checkParentVisibility")) { return false } if (void 0 !== this._parentHidden) { return this._parentHidden } var $parent = this.$element().parent(); if ($parent.is(":visible")) { return false } var isHidden = false; $parent.add($parent.parents()).each((function() { var $element = (0, _renderer.default)(this); if ("none" === $element.css("display")) { isHidden = true; return false } })); return isHidden || !_dom_adapter.default.getBody().contains($parent.get(0)) }, _renderContentImpl: function() { var _this13 = this; var whenContentRendered = new _deferred.Deferred; var contentTemplateOption = this.option("contentTemplate"); var contentTemplate = this._getTemplate(contentTemplateOption); var transclude = this._templateManager.anonymousTemplateName === contentTemplateOption; contentTemplate && contentTemplate.render({ container: (0, _element.getPublicElement)(this.$content()), noModel: true, transclude: transclude, onRendered: function() { whenContentRendered.resolve() } }); this._renderDrag(); this._renderResize(); this._renderScrollTerminator(); whenContentRendered.done((function() { if (_this13.option("visible")) { _this13._moveToContainer() } })); return whenContentRendered.promise() }, _getPositionControllerConfig: function() { var _this$option2 = this.option(), target = _this$option2.target, container = _this$option2.container, dragAndResizeArea = _this$option2.dragAndResizeArea, dragOutsideBoundary = _this$option2.dragOutsideBoundary, outsideDragFactor = _this$option2.outsideDragFactor, _fixWrapperPosition = _this$option2._fixWrapperPosition, restorePosition = _this$option2.restorePosition; return { target: target, container: container, $root: this.$element(), $content: this._$content, $wrapper: this._$wrapper, onPositioned: this._actions.onPositioned, onVisualPositionChanged: this._actions.onVisualPositionChanged, restorePosition: restorePosition, dragAndResizeArea: dragAndResizeArea, dragOutsideBoundary: dragOutsideBoundary, outsideDragFactor: outsideDragFactor, _fixWrapperPosition: _fixWrapperPosition } }, _initPositionController: function() { this._positionController = new _overlay_position_controller.OverlayPositionController(this._getPositionControllerConfig()) }, _renderDrag: function() { var $dragTarget = this._getDragTarget(); if (!$dragTarget) { return } var config = { dragEnabled: this.option("dragEnabled"), handle: $dragTarget.get(0), draggableElement: this._$content.get(0), positionController: this._positionController }; if (this._drag) { this._drag.init(config) } else { this._drag = new _overlay_drag.default(config) } }, _renderResize: function() { var _this14 = this; this._resizable = this._createComponent(this._$content, _resizable.default, { handles: this.option("resizeEnabled") ? "all" : "none", onResizeEnd: function(e) { _this14._resizeEndHandler(e); _this14._observeContentResize(true) }, onResize: function(e) { _this14._actions.onResize(e) }, onResizeStart: function(e) { _this14._observeContentResize(false); _this14._actions.onResizeStart(e) }, minHeight: 100, minWidth: 100, area: this._positionController.$dragResizeContainer }) }, _resizeEndHandler: function(e) { var width = this._resizable.option("width"); var height = this._resizable.option("height"); width && this._setOptionWithoutOptionChange("width", width); height && this._setOptionWithoutOptionChange("height", height); this._cacheDimensions(); this._positionController.resizeHandled(); this._positionController.detectVisualPositionChange(e.event); this._actions.onResizeEnd(e) }, _renderScrollTerminator: function() { var $scrollTerminator = this._$wrapper; var terminatorEventName = (0, _index.addNamespace)(_drag.move, this.NAME); _events_engine.default.off($scrollTerminator, terminatorEventName); _events_engine.default.on($scrollTerminator, terminatorEventName, { validate: function() { return true }, getDirection: function() { return "both" }, _toggleGestureCover: function(toggle) { if (!toggle) { this._toggleGestureCoverImpl(toggle) } }, _clearSelection: _common.noop, isNative: true }, (function(e) { var originalEvent = e.originalEvent.originalEvent; var _ref2 = originalEvent || {}, type = _ref2.type; var isWheel = "wheel" === type; var isMouseMove = "mousemove" === type; var isScrollByWheel = isWheel && !(0, _index.isCommandKeyPressed)(e); e._cancelPreventDefault = true; if (originalEvent && false !== e.cancelable && (!isMouseMove && !isWheel || isScrollByWheel)) { e.preventDefault() } })) }, _getDragTarget: function() { return this.$content() }, _moveFromContainer: function() { this._$content.appendTo(this.$element()); this._detachWrapperToContainer() }, _detachWrapperToContainer: function() { this._$wrapper.detach() }, _moveToContainer: function() { this._attachWrapperToContainer(); this._$content.appendTo(this._$wrapper) }, _attachWrapperToContainer: function() { var $element = this.$element(); var containerDefined = void 0 !== this.option("container"); var renderContainer = containerDefined ? this._positionController.$container : _swatch_container.default.getSwatchContainer($element); if (renderContainer && renderContainer[0] === $element.parent()[0]) { renderContainer = $element } this._$wrapper.appendTo(renderContainer) }, _renderGeometry: function(options) { var _this$option3 = this.option(), visible = _this$option3.visible, useResizeObserver = _this$option3.useResizeObserver; if (visible && (0, _window.hasWindow)()) { var isAnimated = this._showAnimationProcessing; var shouldRepeatAnimation = isAnimated && !(null !== options && void 0 !== options && options.forceStopAnimation) && useResizeObserver; this._isAnimationPaused = shouldRepeatAnimation || void 0; this._stopAnimation(); if (null !== options && void 0 !== options && options.shouldOnlyReposition) { this._positionController.positionContent() } else { this._renderGeometryImpl() } if (shouldRepeatAnimation) { this._animateShowing(); this._isAnimationPaused = void 0 } } }, _cacheDimensions: function() { if (!this.option("useResizeObserver")) { return } this._renderedDimensions = { width: parseInt((0, _size.getWidth)(this._$content), 10), height: parseInt((0, _size.getHeight)(this._$content), 10) } }, _renderGeometryImpl: function() { this._positionController.updatePosition(this._getOptionValue("position")); this._renderWrapper(); this._renderDimensions(); this._cacheDimensions(); this._renderPosition() }, _renderPosition: function() { this._positionController.positionContent() }, _isAllWindowCovered: function() { return this._positionController.isAllWindowCoveredByWrapper() && this.option("shading") }, _toggleSafariScrolling: function() { var visible = this.option("visible"); var $body = (0, _renderer.default)(_dom_adapter.default.getBody()); var isIosSafari = "ios" === _devices.default.real().platform && _browser.default.safari; var isAllWindowCovered = this._isAllWindowCovered(); var isScrollingPrevented = $body.hasClass(PREVENT_SAFARI_SCROLLING_CLASS); var shouldPreventScrolling = !isScrollingPrevented && visible && isAllWindowCovered; var shouldEnableScrolling = isScrollingPrevented && (!visible || !isAllWindowCovered || this._disposed); if (isIosSafari) { if (shouldEnableScrolling) { $body.removeClass(PREVENT_SAFARI_SCROLLING_CLASS); window.scrollTo(0, this._cachedBodyScrollTop); this._cachedBodyScrollTop = void 0 } else if (shouldPreventScrolling) { this._cachedBodyScrollTop = window.pageYOffset; $body.addClass(PREVENT_SAFARI_SCROLLING_CLASS) } } }, _renderWrapper: function() { this._positionController.styleWrapperPosition(); this._renderWrapperDimensions(); this._positionController.positionWrapper() }, _renderWrapperDimensions: function() { var wrapperWidth; var wrapperHeight; var $container = this._positionController._$wrapperCoveredElement; if (!$container) { return } var isWindow = this._positionController.isAllWindowCoveredByWrapper(); var documentElement = _dom_adapter.default.getDocumentElement(); wrapperWidth = isWindow ? documentElement.clientWidth : (0, _size.getOuterWidth)($container), wrapperHeight = isWindow ? window.innerHeight : (0, _size.getOuterHeight)($container); this._$wrapper.css({ width: wrapperWidth, height: wrapperHeight }) }, _renderDimensions: function() { var content = this._$content.get(0); this._$content.css({ minWidth: this._getOptionValue("minWidth", content), maxWidth: this._getOptionValue("maxWidth", content), minHeight: this._getOptionValue("minHeight", content), maxHeight: this._getOptionValue("maxHeight", content), width: this._getOptionValue("width", content), height: this._getOptionValue("height", content) }) }, _focusTarget: function() { return this._$content }, _attachKeyboardEvents: function() { var _this15 = this; this._keyboardListenerId = _short.keyboard.on(this._$content, null, (function(opts) { return _this15._keyboardHandler(opts) })) }, _keyboardHandler: function(options) { var e = options.originalEvent; var $target = (0, _renderer.default)(e.target); if ($target.is(this._$content) || !this.option("ignoreChildEvents")) { this.callBase.apply(this, arguments) } }, _isVisible: function() { return this.option("visible") }, _visibilityChanged: function(visible) { if (visible) { if (this.option("visible")) { this._renderVisibilityAnimate(visible) } } else { this._renderVisibilityAnimate(visible) } }, _dimensionChanged: function() { this._renderGeometry() }, _clean: function() { if (!this._contentAlreadyRendered) { this.$content().empty() } this._renderVisibility(false); this._stopShowTimer(); this._observeContentResize(false); this._cleanFocusState() }, _stopShowTimer: function() { if (this._asyncShowTimeout) { clearTimeout(this._asyncShowTimeout) } this._asyncShowTimeout = null }, _dispose: function() { _fx.default.stop(this._$content, false); clearTimeout(this._deferShowTimer); this._toggleViewPortSubscription(false); this._toggleSubscriptions(false); this._updateZIndexStackPosition(false); this._toggleTabTerminator(false); this._actions = null; this._parentsScrollSubscriptionInfo = null; this.callBase(); this._toggleSafariScrolling(); zIndexPool.remove(this._zIndex); this._$wrapper.remove(); this._$content.remove() }, _toggleDisabledState: function(value) { this.callBase.apply(this, arguments); this._$content.toggleClass(DISABLED_STATE_CLASS, Boolean(value)) }, _toggleRTLDirection: function(rtl) { this._$content.toggleClass(RTL_DIRECTION_CLASS, rtl) }, _optionChanged: function(args) { var _this$_resizable, _this16 = this; var value = args.value; if ((0, _array.inArray)(args.name, ACTIONS) > -1) { this._initActions(); return } switch (args.name) { case "dragEnabled": this._renderDrag(); this._renderGeometry(); break; case "resizeEnabled": this._renderResize(); this._renderGeometry(); break; case "shading": this._toggleShading(this.option("visible")); this._toggleSafariScrolling(); break; case "shadingColor": this._toggleShading(this.option("visible")); break; case "width": case "height": this._renderGeometry(); null === (_this$_resizable = this._resizable) || void 0 === _this$_resizable ? void 0 : _this$_resizable.option(args.name, args.value); break; case "minWidth": case "maxWidth": case "minHeight": case "maxHeight": this._renderGeometry(); break; case "position": this._positionController.updatePosition(this.option("position")); this._positionController.restorePositionOnNextRender(true); this._renderGeometry(); this._toggleSafariScrolling(); break; case "visible": this._renderVisibilityAnimate(value).done((function() { if (!_this16._animateDeferred) { return } _this16._animateDeferred.resolveWith(_thi