From 4fc02fbe2076bc606f0cc561ed205c79e190e9c0 Mon Sep 17 00:00:00 2001 From: nathangray Date: Wed, 8 Jul 2020 14:34:40 -0600 Subject: [PATCH] Etemplate: Fix searchbox did not properly manage child DOM nodes --- api/js/etemplate/et2_widget_textbox.js | 34 ++++++++++------ api/js/etemplate/et2_widget_textbox.ts | 55 ++++++++++++++++---------- 2 files changed, 55 insertions(+), 34 deletions(-) diff --git a/api/js/etemplate/et2_widget_textbox.js b/api/js/etemplate/et2_widget_textbox.js index 5c91485c27..9f5ddb93be 100644 --- a/api/js/etemplate/et2_widget_textbox.js +++ b/api/js/etemplate/et2_widget_textbox.js @@ -367,19 +367,16 @@ var et2_searchbox = /** @class */ (function (_super) { // Call the inherited constructor _super.call(this, _parent, _attrs, et2_core_inheritance_1.ClassWithAttributes.extendAttributes(et2_searchbox._attributes, _child || {})) || this; _this.value = ""; - _this.value = ""; - _this.div = jQuery(document.createElement('div')) - .addClass('et2_searchbox'); - _this.flex = jQuery(document.createElement('div')) - .addClass('flex') - .appendTo(_this.div); - //this._super.apply(this, arguments); - _this.setDOMNode(_this.div[0]); - _this._createWidget(); return _this; } - et2_searchbox.prototype._createWidget = function () { + et2_searchbox.prototype.createInputWidget = function () { var self = this; + this.div = jQuery(document.createElement('div')) + .addClass('et2_searchbox'); + this.flex = jQuery(document.createElement('div')) + .addClass('flex') + .appendTo(this.div); + this.setDOMNode(this.div[0]); if (this.options.overlay) this.flex.addClass('overlay'); // search button indicator @@ -433,7 +430,6 @@ var et2_searchbox = /** @class */ (function (_super) { event.stopImmediatePropagation(); } }); - this.flex.append(this.search.getDOMNode()); // clear button implementation this.clear = jQuery(document.createElement('span')) .addClass('ui-icon clear') @@ -466,7 +462,7 @@ var et2_searchbox = /** @class */ (function (_super) { if (this.options.fix) return; jQuery(this.flex).toggleClass('hide', !_stat); - jQuery(this.getDOMNode()).toggleClass('expanded', _stat); + jQuery(this.getDOMNode(this)).toggleClass('expanded', _stat); }; /** * toggle search button status based on value @@ -498,6 +494,12 @@ var et2_searchbox = /** @class */ (function (_super) { if (this.search) this.search.input.val(_value); }; + et2_searchbox.prototype.set_readonly = function (_readonly) { + this.search.set_readonly(_readonly); + }; + et2_searchbox.prototype.set_blur = function (_value) { + this.search.set_blur(_value); + }; /** * override doLoadingFinished in order to set initial state */ @@ -512,6 +514,12 @@ var et2_searchbox = /** @class */ (function (_super) { } return true; }; + et2_searchbox.prototype.getDOMNode = function (asker) { + if (asker.getParent() == this) { + return this.flex[0]; + } + return _super.prototype.getDOMNode.call(this, asker); + }; /** * Overrride attachToDOM in order to unbind change handler */ @@ -537,7 +545,7 @@ var et2_searchbox = /** @class */ (function (_super) { name: "Fix searchbox", type: "boolean", default: true, - description: "Define wheter the searchbox should be a fix input field or flexible search button. Default is true (fix)." + description: "Define whether the searchbox should be a fix input field or flexible search button. Default is true (fix)." } }; return et2_searchbox; diff --git a/api/js/etemplate/et2_widget_textbox.ts b/api/js/etemplate/et2_widget_textbox.ts index 854e7d520a..5b8051ef71 100644 --- a/api/js/etemplate/et2_widget_textbox.ts +++ b/api/js/etemplate/et2_widget_textbox.ts @@ -421,7 +421,7 @@ class et2_searchbox extends et2_textbox name:"Fix searchbox", type:"boolean", default:true, - description:"Define wheter the searchbox should be a fix input field or flexible search button. Default is true (fix)." + description:"Define whether the searchbox should be a fix input field or flexible search button. Default is true (fix)." } } value: string = ""; @@ -439,24 +439,20 @@ class et2_searchbox extends et2_textbox { // Call the inherited constructor super(_parent, _attrs, ClassWithAttributes.extendAttributes(et2_searchbox._attributes, _child || {})); - - this.value = ""; - this.div = jQuery(document.createElement('div')) - .addClass('et2_searchbox'); - this.flex = jQuery(document.createElement('div')) - .addClass('flex') - .appendTo(this.div); - - //this._super.apply(this, arguments); - - this.setDOMNode(this.div[0]); - this._createWidget(); } - _createWidget() + createInputWidget() { var self = this; + + this.div = jQuery(document.createElement('div')) + .addClass('et2_searchbox'); + this.flex = jQuery(document.createElement('div')) + .addClass('flex') + .appendTo(this.div); + this.setDOMNode(this.div[0]); if (this.options.overlay) this.flex.addClass('overlay'); + // search button indicator // no need to create search button if it's a fix search field if (!this.options.fix) @@ -511,7 +507,6 @@ class et2_searchbox extends et2_textbox if (event.target.tagName == 'span') event.stopImmediatePropagation(); } }); - this.flex.append(this.search.getDOMNode()); // clear button implementation this.clear = jQuery(document.createElement('span')) @@ -542,11 +537,11 @@ class et2_searchbox extends et2_textbox */ _show_hide(_stat) { - // Not applied for fix option - if (this.options.fix) return; + // Not applied for fix option + if (this.options.fix) return; - jQuery(this.flex).toggleClass('hide',!_stat); - jQuery(this.getDOMNode()).toggleClass('expanded', _stat); + jQuery(this.flex).toggleClass('hide',!_stat); + jQuery(this.getDOMNode(this)).toggleClass('expanded', _stat); } /** @@ -590,6 +585,14 @@ class et2_searchbox extends et2_textbox if (this.search) this.search.input.val(_value); } + set_readonly(_readonly) + { + this.search.set_readonly(_readonly); + } + set_blur(_value) + { + this.search.set_blur(_value); + } /** * override doLoadingFinished in order to set initial state */ @@ -597,16 +600,26 @@ class et2_searchbox extends et2_textbox { super.doLoadingFinished(); - if (!this.get_value()) { + if (!this.get_value()) + { this._show_hide(false); } - else { + else + { this._show_hide(!this.options.overlay); this._searchToggleState(); } return true; } + getDOMNode(asker) + { + if(asker.getParent() == this) + { + return this.flex[0]; + } + return super.getDOMNode(asker); + } /** * Overrride attachToDOM in order to unbind change handler */