devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
94 lines (89 loc) • 3.72 kB
JavaScript
/**
* DevExtreme (cjs/ui/text_box/ui.text_editor.clear.js)
* Version: 21.1.4
* Build date: Mon Jun 21 2021
*
* Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
;
exports.default = void 0;
var _renderer = _interopRequireDefault(require("../../core/renderer"));
var _events_engine = _interopRequireDefault(require("../../events/core/events_engine"));
var _button = _interopRequireDefault(require("./texteditor_button_collection/button"));
var _index = require("../../events/utils/index");
var _pointer = _interopRequireDefault(require("../../events/pointer"));
var _click = require("../../events/click");
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 || function(o, p) {
o.__proto__ = p;
return o
};
return _setPrototypeOf(o, p)
}
var pointerDown = _pointer.default.down;
var STATE_INVISIBLE_CLASS = "dx-state-invisible";
var TEXTEDITOR_CLEAR_BUTTON_CLASS = "dx-clear-button-area";
var TEXTEDITOR_CLEAR_ICON_CLASS = "dx-icon-clear";
var TEXTEDITOR_ICON_CLASS = "dx-icon";
var TEXTEDITOR_SHOW_CLEAR_BUTTON_CLASS = "dx-show-clear-button";
var ClearButton = function(_TextEditorButton) {
_inheritsLoose(ClearButton, _TextEditorButton);
function ClearButton() {
return _TextEditorButton.apply(this, arguments) || this
}
var _proto = ClearButton.prototype;
_proto._create = function() {
var $element = (0, _renderer.default)("<span>").addClass(TEXTEDITOR_CLEAR_BUTTON_CLASS).append((0, _renderer.default)("<span>").addClass(TEXTEDITOR_ICON_CLASS).addClass(TEXTEDITOR_CLEAR_ICON_CLASS));
this._addToContainer($element);
this.update(true);
return {
instance: $element,
$element: $element
}
};
_proto._isVisible = function() {
var editor = this.editor;
return editor._isClearButtonVisible()
};
_proto._attachEvents = function(instance, $button) {
var editor = this.editor;
var editorName = editor.NAME;
_events_engine.default.on($button, (0, _index.addNamespace)(pointerDown, editorName), (function(e) {
e.preventDefault();
if ("mouse" !== e.pointerType) {
editor._clearValueHandler(e)
}
}));
_events_engine.default.on($button, (0, _index.addNamespace)(_click.name, editorName), (function(e) {
return editor._clearValueHandler(e)
}))
};
_proto._legacyRender = function($editor, isVisible) {
$editor.toggleClass(TEXTEDITOR_SHOW_CLEAR_BUTTON_CLASS, isVisible)
};
_proto.update = function() {
var rendered = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : false;
!rendered && _TextEditorButton.prototype.update.call(this);
var editor = this.editor,
instance = this.instance;
var $editor = editor.$element();
var isVisible = this._isVisible();
instance && instance.toggleClass(STATE_INVISIBLE_CLASS, !isVisible);
this._legacyRender($editor, isVisible)
};
return ClearButton
}(_button.default);
exports.default = ClearButton;
module.exports = exports.default;
module.exports.default = exports.default;