Skip to content

Commit

Permalink
Form: DropDownBox loses its value after the Form is resized (T1196835) (
Browse files Browse the repository at this point in the history
EugeniyKiyashko authored Jan 15, 2025

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature.
1 parent 5db85c9 commit 4a12798
Showing 5 changed files with 162 additions and 42 deletions.
Original file line number Diff line number Diff line change
@@ -29,7 +29,7 @@ import Widget from '@js/ui/widget/ui.widget';
import DropDownButton from './m_drop_down_button';
import { getElementWidth, getSizeValue } from './m_utils';

const DROP_DOWN_EDITOR_CLASS = 'dx-dropdowneditor';
export const DROP_DOWN_EDITOR_CLASS = 'dx-dropdowneditor';
const DROP_DOWN_EDITOR_INPUT_WRAPPER = 'dx-dropdowneditor-input-wrapper';
const DROP_DOWN_EDITOR_BUTTON_ICON = 'dx-dropdowneditor-icon';
const DROP_DOWN_EDITOR_OVERLAY = 'dx-dropdowneditor-overlay';
7 changes: 3 additions & 4 deletions packages/devextreme/js/__internal/ui/form/m_form.ts
Original file line number Diff line number Diff line change
@@ -26,8 +26,10 @@ import TabPanel from '@js/ui/tab_panel';
import { isMaterial, isMaterialBased } from '@js/ui/themes';
import ValidationEngine from '@js/ui/validation_engine';
import Widget from '@js/ui/widget/ui.widget';
import { DROP_DOWN_EDITOR_CLASS } from '@ts/ui/drop_down_editor/m_drop_down_editor';
import { TOOLBAR_CLASS } from '@ts/ui/toolbar/m_constants';

import { TEXTEDITOR_CLASS, TEXTEDITOR_INPUT_CLASS } from '../text_box/m_text_editor.base';
import {
setLabelWidthByMaxLabelWidth,
} from './components/m_label';
@@ -67,7 +69,6 @@ import {
} from './m_form.utils';

const FOCUSED_STATE_CLASS = 'dx-state-focused';

const ITEM_OPTIONS_FOR_VALIDATION_UPDATING = ['items', 'isRequired', 'validationRules', 'visible'];

// @ts-expect-error
@@ -1152,9 +1153,7 @@ const Form = Widget.inherit({
},

_refresh() {
const editorSelector = `.${FOCUSED_STATE_CLASS} > :not(.dx-dropdowneditor-input-wrapper) input,`
+ ` .${FOCUSED_STATE_CLASS} textarea`;

const editorSelector = `.${TEXTEDITOR_CLASS}.${FOCUSED_STATE_CLASS}:not(.${DROP_DOWN_EDITOR_CLASS}) .${TEXTEDITOR_INPUT_CLASS}`;
// @ts-expect-error
eventsEngine.trigger(this.$element().find(editorSelector), 'change');

Original file line number Diff line number Diff line change
@@ -15,7 +15,7 @@ import { current as currentTheme, isFluent, isMaterialBased } from '@js/ui/theme
// eslint-disable-next-line import/no-named-default
import { default as TabPanelItem } from './m_item';

const TABPANEL_CLASS = 'dx-tabpanel';
export const TABPANEL_CLASS = 'dx-tabpanel';
const TABPANEL_TABS_CLASS = 'dx-tabpanel-tabs';
const TABPANEL_TABS_ITEM_CLASS = 'dx-tabpanel-tab';
const TABPANEL_CONTAINER_CLASS = 'dx-tabpanel-container';
Original file line number Diff line number Diff line change
@@ -22,9 +22,9 @@ import ClearButton from './m_text_editor.clear';
import { TextEditorLabel } from './m_text_editor.label';
import TextEditorButtonCollection from './texteditor_button_collection/m_index';

const TEXTEDITOR_CLASS = 'dx-texteditor';
export const TEXTEDITOR_CLASS = 'dx-texteditor';
const TEXTEDITOR_INPUT_CONTAINER_CLASS = 'dx-texteditor-input-container';
const TEXTEDITOR_INPUT_CLASS = 'dx-texteditor-input';
export const TEXTEDITOR_INPUT_CLASS = 'dx-texteditor-input';
const TEXTEDITOR_INPUT_SELECTOR = `.${TEXTEDITOR_INPUT_CLASS}`;
const TEXTEDITOR_CONTAINER_CLASS = 'dx-texteditor-container';
const TEXTEDITOR_BUTTONS_CONTAINER_CLASS = 'dx-texteditor-buttons-container';
Original file line number Diff line number Diff line change
@@ -20,6 +20,10 @@ import 'ui/range_slider';
import windowModule from 'core/utils/window';
import Form from 'ui/form';
import TextEditorBase from 'ui/text_box/ui.text_editor.base.js';
import {
TEXTEDITOR_INPUT_CLASS
} from '__internal/ui/text_box/m_text_editor.base';


import {
FIELD_ITEM_CLASS,
@@ -57,6 +61,7 @@ import themes from 'ui/themes';
import registerKeyHandlerTestHelper from '../../helpers/registerKeyHandlerTestHelper.js';
import responsiveBoxScreenMock from '../../helpers/responsiveBoxScreenMock.js';
import { isDefined } from 'core/utils/type.js';
import { TABPANEL_CLASS } from '__internal/ui/tab_panel/m_tab_panel';

const INVALID_CLASS = 'dx-invalid';
const FORM_GROUP_CONTENT_CLASS = 'dx-form-group-content';
@@ -95,9 +100,9 @@ if(device.current().deviceType === 'desktop') {
});
}

QUnit.testInActiveWindow('Form\'s inputs saves value on refresh', function(assert) {
QUnit.testInActiveWindow('Form\'s textbox input saves value on refresh (T404958)', function(assert) {
let screen = 'md';
const $formContainer = $('#form').dxForm({
const $form = $('#form').dxForm({
screenByWidth: function() {
return screen;
},
@@ -113,17 +118,48 @@ QUnit.testInActiveWindow('Form\'s inputs saves value on refresh', function(asser
]
});

$('#form input')
$form.find(`.${TEXTEDITOR_INPUT_CLASS}`)
.first()
.focus()
.val('test');

screen = 'sm';
resizeCallbacks.fire();

const formData = $formContainer.dxForm('instance').option('formData');
const formData = $form.dxForm('instance').option('formData');

assert.deepEqual(formData, { name: 'test' }, 'value updates');
assert.deepEqual(formData, { name: 'test' }, 'textbox value updates');
});

QUnit.testInActiveWindow('Form\'s textarea input saves value on refresh (T404958)', function(assert) {
let screen = 'md';
const $form = $('#form').dxForm({
screenByWidth: function() {
return screen;
},
colCountByScreen: {
sm: 1,
md: 2
},
items: [
{
dataField: 'name',
editorType: 'dxTextArea'
}
]
});

$form.find(`.${TEXTEDITOR_INPUT_CLASS}`)
.first()
.focus()
.val('test');

screen = 'sm';
resizeCallbacks.fire();

const formData = $form.dxForm('instance').option('formData');

assert.deepEqual(formData, { name: 'test' }, 'textarea value updates');
});

QUnit.test('Check field width on render form with colspan', function(assert) {
@@ -4917,39 +4953,124 @@ QUnit.module('reset', () => {
assert.strictEqual(summaryItemsAfterValidate.length, 2, 'form has validation summary after validation');
});

QUnit.test('DropDownBox should not lose its value if form resized (T1196835)', function(assert) {
let screen = 'lg';

const value = 'VINET';
const text = 'Vins et alcools Chevalier (France)';
const $form = $('#form').dxForm({
formData: { CustomerID: value },
screenByWidth: function() { return screen; },
colCountByScreen: {
sm: 1,
lg: 2
},
items: [
{
itemType: 'simple',
cssClass: 'test-ddbox',
dataField: 'CustomerID',
editorOptions: {
displayExpr: 'Text',
valueExpr: 'Value',
showClearButton: true,
dataSource: [{ Value: value, Text: text }],
[
'dxSelectBox',
'dxDropDownBox'
].forEach((editorType) => {
QUnit.test(`Focused ${editorType} should not lose its value when the form is resized (T1196835)`, function(assert) {
let screen = 'lg';

const name = 'VINET';
const value = 'Vins et alcools Chevalier (France)';
const form = $('#form').dxForm({
formData: { name: name },
screenByWidth: function() { return screen; },
colCountByScreen: {
sm: 1,
lg: 2
},
items: [
{
itemType: 'simple',
dataField: 'name',
editorOptions: {
displayExpr: 'Text',
valueExpr: 'Value',
showClearButton: true,
dataSource: [{ Value: name, Text: value }],
},
editorType,
},
editorType: 'dxDropDownBox',
]
}).dxForm('instance');

const dropDownEditor = form.getEditor('name');

screen = 'sm';
dropDownEditor.focus();
resizeCallbacks.fire();

assert.strictEqual($(form.getEditor('name').field()).val(), value, `${editorType} contains expected value`);
});

QUnit.test(`Focused ${editorType} inside a tabbed item should not lose its value when the form is resized (T1196835)`, function(assert) {
let screen = 'lg';

const name = 'VINET';
const value = 'Vins et alcools Chevalier (France)';
const form = $('#form').dxForm({
formData: { name: name },
screenByWidth: function() { return screen; },
colCountByScreen: {
sm: 1,
lg: 2
},
]
items: [{
itemType: 'tabbed',
tabs: [{
title: 'Phone',
colCount: 1,
items: [{
itemType: 'simple',
dataField: 'name',
editorOptions: {
displayExpr: 'Text',
valueExpr: 'Value',
showClearButton: true,
dataSource: [{ Value: name, Text: value }],
},
editorType,
}],
}],
}],
}).dxForm('instance');

const dropDownEditor = form.getEditor('name');

screen = 'sm';
dropDownEditor.focus();
resizeCallbacks.fire();

assert.strictEqual($(form.getEditor('name').field()).val(), value, `${editorType} contains expected value`);
});
const $input = $form.find(`.test-ddbox .${EDITOR_INPUT_CLASS}`);

screen = 'sm';
$input.focus();
resizeCallbacks.fire();
QUnit.test(`${editorType} inside a tabbed item and focused tab should not lose its value when the form is resized (T1196835)`, function(assert) {
let screen = 'lg';

assert.strictEqual($input.val(), text, 'ddBox contain correct value');
const name = 'VINET';
const value = 'Vins et alcools Chevalier (France)';
const form = $('#form').dxForm({
formData: { name: name },
screenByWidth: function() { return screen; },
colCountByScreen: {
sm: 1,
lg: 2
},
items: [{
itemType: 'tabbed',
tabs: [{
title: 'Phone',
colCount: 1,
items: [{
itemType: 'simple',
dataField: 'name',
editorOptions: {
displayExpr: 'Text',
valueExpr: 'Value',
showClearButton: true,
dataSource: [{ Value: name, Text: value }],
},
editorType,
}],
}],
}],
}).dxForm('instance');

screen = 'sm';
$(form.element()).find(`.${TABPANEL_CLASS}`).focus();
resizeCallbacks.fire();

assert.strictEqual($(form.getEditor('name').field()).val(), value, `${editorType} contains expected value`);
});
});
});

0 comments on commit 4a12798

Please sign in to comment.