Warn on fill/blank down when a sorting criterion is applied (#4284)
* Fixes #3256, with Cypress tests Co-authored-by: Nabeel Sait <>
This commit is contained in:
parent
debc4e65c8
commit
282b5a7956
@ -0,0 +1,56 @@
|
|||||||
|
describe(__filename, function () {
|
||||||
|
it('Ensure cells are blanked down', function () {
|
||||||
|
const fixture = [
|
||||||
|
['a', 'b', 'c'],
|
||||||
|
|
||||||
|
['0a', 'identical', '0c'],
|
||||||
|
['1a', 'identical', '1c'],
|
||||||
|
['2a', '2b', '2c'],
|
||||||
|
['3a', 'also identical', '3c'],
|
||||||
|
['4a', 'also identical', '4c'],
|
||||||
|
['5a', 'also identical', '5c'],
|
||||||
|
];
|
||||||
|
|
||||||
|
cy.loadAndVisitProject(fixture);
|
||||||
|
|
||||||
|
//Create Pending Sort
|
||||||
|
cy.columnActionClick('b', ['Sort']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.confirmDialogPanel();
|
||||||
|
|
||||||
|
//Verify Sort occurred
|
||||||
|
cy.assertCellEquals(0, 'b', '2b');
|
||||||
|
cy.assertCellEquals(1, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(2, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(3, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(4, 'b', 'identical');
|
||||||
|
cy.assertCellEquals(5, 'b', 'identical');
|
||||||
|
|
||||||
|
// click, then cancel dialog window
|
||||||
|
cy.columnActionClick('b', ['Edit cells', 'Blank down']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.cancelDialogPanel();
|
||||||
|
|
||||||
|
//Verify blank down did not occur
|
||||||
|
cy.assertCellEquals(0, 'b', '2b');
|
||||||
|
cy.assertCellEquals(1, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(2, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(3, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(4, 'b', 'identical');
|
||||||
|
cy.assertCellEquals(5, 'b', 'identical');
|
||||||
|
|
||||||
|
// click, then confirm dialog window
|
||||||
|
cy.columnActionClick('b', ['Edit cells', 'Blank down']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.confirmDialogPanel();
|
||||||
|
|
||||||
|
// ensure notification and cell content
|
||||||
|
cy.assertNotificationContainingText('Blank down 3 cells');
|
||||||
|
cy.assertCellEquals(0, 'b', '2b');
|
||||||
|
cy.assertCellEquals(1, 'b', 'also identical');
|
||||||
|
cy.assertCellEquals(2, 'b', 'identical');
|
||||||
|
cy.assertCellEquals(3, 'b', null);
|
||||||
|
cy.assertCellEquals(4, 'b', null);
|
||||||
|
cy.assertCellEquals(5, 'b', null);
|
||||||
|
});
|
||||||
|
});
|
@ -0,0 +1,56 @@
|
|||||||
|
describe(__filename, function () {
|
||||||
|
it('Ensure cells are filled down', function () {
|
||||||
|
const fixture = [
|
||||||
|
['a', 'b', 'c'],
|
||||||
|
|
||||||
|
['0a', '0b', '0c'],
|
||||||
|
['1a', null, '1c'],
|
||||||
|
['2a', '2b', '2c'],
|
||||||
|
['3a', null, '3c'],
|
||||||
|
['4a', null, '4c'],
|
||||||
|
['5a', '5b', '5c'],
|
||||||
|
];
|
||||||
|
|
||||||
|
cy.loadAndVisitProject(fixture);
|
||||||
|
|
||||||
|
//Create Pending Sort
|
||||||
|
cy.columnActionClick('b', ['Sort']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.confirmDialogPanel();
|
||||||
|
|
||||||
|
//Verify Sort occurred
|
||||||
|
cy.assertCellEquals(0, 'b', '0b');
|
||||||
|
cy.assertCellEquals(1, 'b', '2b');
|
||||||
|
cy.assertCellEquals(2, 'b', '5b');
|
||||||
|
cy.assertCellEquals(3, 'b', null);
|
||||||
|
cy.assertCellEquals(4, 'b', null);
|
||||||
|
cy.assertCellEquals(5, 'b', null);
|
||||||
|
|
||||||
|
// click, then cancel dialog
|
||||||
|
cy.columnActionClick('b', ['Edit cells', 'Fill down']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.cancelDialogPanel();
|
||||||
|
|
||||||
|
//Verify fill down did not occur
|
||||||
|
cy.assertCellEquals(0, 'b', '0b');
|
||||||
|
cy.assertCellEquals(1, 'b', '2b');
|
||||||
|
cy.assertCellEquals(2, 'b', '5b');
|
||||||
|
cy.assertCellEquals(3, 'b', null);
|
||||||
|
cy.assertCellEquals(4, 'b', null);
|
||||||
|
cy.assertCellEquals(5, 'b', null);
|
||||||
|
|
||||||
|
// click, then confirm dialog
|
||||||
|
cy.columnActionClick('b', ['Edit cells', 'Fill down']);
|
||||||
|
cy.waitForDialogPanel();
|
||||||
|
cy.confirmDialogPanel();
|
||||||
|
|
||||||
|
// ensure notification and cell content
|
||||||
|
cy.assertNotificationContainingText('Fill down 3 cells in column b');
|
||||||
|
cy.assertCellEquals(0, 'b', '0b'); // untouched
|
||||||
|
cy.assertCellEquals(1, 'b', '0b'); // filled
|
||||||
|
cy.assertCellEquals(2, 'b', '2b'); // untouched
|
||||||
|
cy.assertCellEquals(3, 'b', '2b'); // filled
|
||||||
|
cy.assertCellEquals(4, 'b', '2b'); // filled
|
||||||
|
cy.assertCellEquals(5, 'b', '5b'); // untouched
|
||||||
|
});
|
||||||
|
});
|
@ -307,6 +307,16 @@ Cypress.Commands.add('confirmDialogPanel', () => {
|
|||||||
cy.get('body > .dialog-container > .dialog-frame').should('not.exist');
|
cy.get('body > .dialog-container > .dialog-frame').should('not.exist');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Click on the Cancel button of a dialog panel
|
||||||
|
*/
|
||||||
|
Cypress.Commands.add('cancelDialogPanel', () => {
|
||||||
|
cy.get(
|
||||||
|
'body > .dialog-container > .dialog-frame .dialog-footer button[bind="cancelButton"]'
|
||||||
|
).click();
|
||||||
|
cy.get('body > .dialog-container > .dialog-frame').should('not.exist');
|
||||||
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Will click on a menu entry for a given column name
|
* Will click on a menu entry for a given column name
|
||||||
*/
|
*/
|
||||||
|
@ -453,6 +453,8 @@
|
|||||||
"core-views/remove-sort": "Remove sort",
|
"core-views/remove-sort": "Remove sort",
|
||||||
"core-views/sort-by": "Sort by",
|
"core-views/sort-by": "Sort by",
|
||||||
"core-views/sort-cell": "Sort cell values as",
|
"core-views/sort-cell": "Sort cell values as",
|
||||||
|
"core-views/warn-of-pending-sort": "There is a sort pending. The data visible on screen may not reflect the data this operation will act on.",
|
||||||
|
"core-views/warning": "Warning",
|
||||||
"core-views/pos-blank": "Position blanks and errors",
|
"core-views/pos-blank": "Position blanks and errors",
|
||||||
"core-views/text": "text",
|
"core-views/text": "text",
|
||||||
"core-views/case-sensitive": "case-sensitive",
|
"core-views/case-sensitive": "case-sensitive",
|
||||||
|
@ -910,12 +910,26 @@ DataTableView.prototype._createMenuForAllColumns = function(elmt) {
|
|||||||
{
|
{
|
||||||
label: $.i18n('core-views/fill-down'),
|
label: $.i18n('core-views/fill-down'),
|
||||||
id: "core/fill-down",
|
id: "core/fill-down",
|
||||||
click: doAllFillDown
|
click: function () {
|
||||||
|
if (self._getSortingCriteriaCount() > 0) {
|
||||||
|
self._createPendingSortWarningDialog(doAllFillDown);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
doAllFillDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: $.i18n('core-views/blank-down'),
|
label: $.i18n('core-views/blank-down'),
|
||||||
id: "core/blank-down",
|
id: "core/blank-down",
|
||||||
click: doAllBlankDown
|
click: function () {
|
||||||
|
if (self._getSortingCriteriaCount() > 0) {
|
||||||
|
self._createPendingSortWarningDialog(doAllBlankDown);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
doAllBlankDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
@ -1117,3 +1131,29 @@ DataTableView.promptExpressionOnVisibleRows = function(column, title, expression
|
|||||||
onDone
|
onDone
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//This function takes a function as a parameter and creates a dialog window
|
||||||
|
//If the ok button is pressed, the function is executed
|
||||||
|
//If the cancel button is pressed instead, the window is dismissed and the function is not executed
|
||||||
|
DataTableView.prototype._createPendingSortWarningDialog = function(func) {
|
||||||
|
var frame = $(DOM.loadHTML("core", "scripts/views/data-table/warn-of-pending-sort.html"));
|
||||||
|
var elmts = DOM.bind(frame);
|
||||||
|
|
||||||
|
elmts.or_views_warning.text($.i18n('core-views/warn-of-pending-sort'));
|
||||||
|
elmts.dialogHeader.text($.i18n('core-views/warning'));
|
||||||
|
elmts.okButton.html($.i18n('core-buttons/ok'));
|
||||||
|
elmts.cancelButton.text($.i18n('core-buttons/cancel'));
|
||||||
|
|
||||||
|
var level = DialogSystem.showDialog(frame);
|
||||||
|
var dismiss = function() { DialogSystem.dismissLevel(level - 1); };
|
||||||
|
|
||||||
|
elmts.cancelButton.click( function () {
|
||||||
|
dismiss();
|
||||||
|
});
|
||||||
|
|
||||||
|
elmts.okButton.click( function () {
|
||||||
|
func();
|
||||||
|
dismiss();
|
||||||
|
});
|
||||||
|
|
||||||
|
};
|
||||||
|
@ -468,12 +468,26 @@ DataTableColumnHeaderUI.extendMenu(function(column, columnHeaderUI, menu) {
|
|||||||
{
|
{
|
||||||
id: "core/fill-down",
|
id: "core/fill-down",
|
||||||
label: $.i18n('core-views/fill-down'),
|
label: $.i18n('core-views/fill-down'),
|
||||||
click: doFillDown
|
click: function () {
|
||||||
|
if (columnHeaderUI._dataTableView._getSortingCriteriaCount() > 0) {
|
||||||
|
columnHeaderUI._dataTableView._createPendingSortWarningDialog(doFillDown);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
doFillDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "core/blank-down",
|
id: "core/blank-down",
|
||||||
label: $.i18n('core-views/blank-down'),
|
label: $.i18n('core-views/blank-down'),
|
||||||
click: doBlankDown
|
click: function () {
|
||||||
|
if (columnHeaderUI._dataTableView._getSortingCriteriaCount() > 0) {
|
||||||
|
columnHeaderUI._dataTableView._createPendingSortWarningDialog(doBlankDown);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
doBlankDown();
|
||||||
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
{},
|
{},
|
||||||
{
|
{
|
||||||
|
@ -0,0 +1,17 @@
|
|||||||
|
<div class="dialog-frame" style="min-width: 600px;">
|
||||||
|
<div class="dialog-border">
|
||||||
|
<div class="dialog-header" bind="dialogHeader"></div>
|
||||||
|
<div class="dialog-body" bind="dialogBody">
|
||||||
|
<div class="grid-layout layout-tight layout-full"><table>
|
||||||
|
<tr>
|
||||||
|
<td><span bind="or_views_warning"></span></td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="dialog-footer" bind="dialogFooter">
|
||||||
|
<button class="button" bind="okButton"></button>
|
||||||
|
<button class="button" bind="cancelButton"></button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
Loading…
Reference in New Issue
Block a user