UNPKG

devextreme

Version:

HTML5 JavaScript Component Suite for Responsive Web Development

171 lines (166 loc) 6.11 kB
/** * DevExtreme (cjs/ui/diagram/ui.diagram.context_toolbox.js) * Version: 22.1.9 * Build date: Tue Apr 18 2023 * * Copyright (c) 2012 - 2023 Developer Express Inc. ALL RIGHTS RESERVED * Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/ */ "use strict"; exports.default = void 0; var _renderer = _interopRequireDefault(require("../../core/renderer")); var _ui = _interopRequireDefault(require("../widget/ui.widget")); var _popover = _interopRequireDefault(require("../popover")); var _diagram = require("./diagram.importer"); var _window = require("../../core/utils/window"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj } } function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass) } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function(o, p) { o.__proto__ = p; return o }; return _setPrototypeOf(o, p) } var DIAGRAM_CONTEXT_TOOLBOX_TARGET_CLASS = "dx-diagram-context-toolbox-target"; var DIAGRAM_CONTEXT_TOOLBOX_CLASS = "dx-diagram-context-toolbox"; var DIAGRAM_TOUCH_CONTEXT_TOOLBOX_CLASS = "dx-diagram-touch-context-toolbox"; var DIAGRAM_CONTEXT_TOOLBOX_CONTENT_CLASS = "dx-diagram-context-toolbox-content"; var DiagramContextToolbox = function(_Widget) { _inheritsLoose(DiagramContextToolbox, _Widget); function DiagramContextToolbox() { return _Widget.apply(this, arguments) || this } var _proto = DiagramContextToolbox.prototype; _proto._init = function() { _Widget.prototype._init.call(this); this._onShownAction = this._createActionByOption("onShown"); this._popoverPositionData = [{ my: { x: "center", y: "top" }, at: { x: "center", y: "bottom" }, offset: { x: 0, y: 5 } }, { my: { x: "right", y: "center" }, at: { x: "left", y: "center" }, offset: { x: -5, y: 0 } }, { my: { x: "center", y: "bottom" }, at: { x: "center", y: "top" }, offset: { x: 0, y: -5 } }, { my: { x: "left", y: "center" }, at: { x: "right", y: "center" }, offset: { x: 5, y: 0 } }] }; _proto._initMarkup = function() { _Widget.prototype._initMarkup.call(this); this._$popoverTargetElement = (0, _renderer.default)("<div>").addClass(DIAGRAM_CONTEXT_TOOLBOX_TARGET_CLASS).appendTo(this.$element()); var $popoverElement = (0, _renderer.default)("<div>").appendTo(this.$element()); var popoverClass = DIAGRAM_CONTEXT_TOOLBOX_CLASS; if (this._isTouchMode()) { popoverClass += " " + DIAGRAM_TOUCH_CONTEXT_TOOLBOX_CLASS } this._popoverInstance = this._createComponent($popoverElement, _popover.default, { hideOnOutsideClick: false, container: this.$element() }); this._popoverInstance.$element().addClass(popoverClass) }; _proto._isTouchMode = function() { var _getDiagram = (0, _diagram.getDiagram)(), Browser = _getDiagram.Browser; return Browser.TouchUI }; _proto._show = function(x, y, side, category, callback) { this._popoverInstance.hide(); var $content = (0, _renderer.default)("<div>").addClass(DIAGRAM_CONTEXT_TOOLBOX_CONTENT_CLASS); if (void 0 !== this.option("toolboxWidth")) { $content.css("width", this.option("toolboxWidth")) } this._$popoverTargetElement.css({ left: x + this._popoverPositionData[side].offset.x, top: y + this._popoverPositionData[side].offset.y }).show(); var window = (0, _window.getWindow)(); var targetDiv = this._$popoverTargetElement.get(0); this._$popoverTargetElement.css({ left: targetDiv.offsetLeft - (targetDiv.getBoundingClientRect().left + window.scrollX - targetDiv.offsetLeft), top: targetDiv.offsetTop - (targetDiv.getBoundingClientRect().top + window.scrollY - targetDiv.offsetTop) }); this._popoverInstance.option({ position: { my: this._popoverPositionData[side].my, at: this._popoverPositionData[side].at, of: this._$popoverTargetElement }, contentTemplate: $content, onContentReady: function() { var _this = this; var $element = this.$element().find("." + DIAGRAM_CONTEXT_TOOLBOX_CONTENT_CLASS); this._onShownAction({ category: category, callback: callback, $element: $element, hide: function() { return _this._popoverInstance.hide() } }) }.bind(this) }); this._popoverInstance.show() }; _proto._hide = function() { this._$popoverTargetElement.hide(); this._popoverInstance.hide() }; return DiagramContextToolbox }(_ui.default); var _default = DiagramContextToolbox; exports.default = _default; module.exports = exports.default; module.exports.default = exports.default;