Skip to content

Commit

Permalink
elyra-ai#2213 Table toolbar should not be shown for single select ta…
Browse files Browse the repository at this point in the history
…bles (elyra-ai#2214)
  • Loading branch information
mikieyx authored Nov 13, 2024
1 parent 32f2a74 commit 3bebb81
Show file tree
Hide file tree
Showing 13 changed files with 133 additions and 34 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -498,7 +498,7 @@ describe("StructureListEditor render from paramdef", () => {
expect(tableUtilsRTL.getTableRows(container)).to.have.length(2);

// select the first row in the table
tableUtilsRTL.clickTableRows(container, [0]);
tableUtilsRTL.selectCheckboxes(container, [0]);

// ensure table toolbar has Delete button and select it
const tableToolbar = container.querySelector("div.properties-table-toolbar");
Expand All @@ -525,7 +525,7 @@ describe("StructureListEditor render from paramdef", () => {
expect(tableData).to.have.length(3);

// set the error in the last row
const checkboxCell = summaryPanel.querySelectorAll("input[type='checkbox']")[3];
const checkboxCell = summaryPanel.querySelectorAll("input[type='checkbox']")[7];
checkboxCell.setAttribute("checked", false);
fireEvent.click(checkboxCell);

Expand All @@ -544,10 +544,10 @@ describe("StructureListEditor render from paramdef", () => {
expect(errorMessage).to.eql(actual);

// remove the first row and ensure the error message is associated with the correct row.
tableUtilsRTL.clickTableRows(summaryPanel, [0]);
tableUtilsRTL.selectCheckboxes(container, [0]);
const tableToolbar = container.querySelector("div.properties-table-toolbar");
let deleteButton = tableToolbar.querySelector("button.properties-action-delete");
fireEvent.click(deleteButton);
let deleteButton = tableToolbar.querySelectorAll("button.properties-action-delete");
fireEvent.click(deleteButton[0]);

const messages = renderedController.getAllErrorMessages();
const rowErrorMsg = { "1": { "3": { propertyId: {
Expand All @@ -561,9 +561,9 @@ describe("StructureListEditor render from paramdef", () => {
summaryPanel = container.querySelector("div.properties-wf-content.show");
tableData = tableUtilsRTL.getTableRows(summaryPanel);
expect(tableData).to.have.length(2);
tableUtilsRTL.clickTableRows(summaryPanel, [1]);
deleteButton = container.querySelector("div.properties-table-toolbar").querySelector("button.properties-action-delete");
fireEvent.click(deleteButton);
tableUtilsRTL.selectCheckboxes(container, [1]);
deleteButton = container.querySelectorAll("button.properties-action-delete");
fireEvent.click(deleteButton[0]);
actual = renderedController.getErrorMessage({ name: "inlineEditingTableError" });
expect(actual).to.equal(null);
});
Expand Down Expand Up @@ -630,7 +630,7 @@ describe("StructureListEditor render from paramdef", () => {
expect(errorMessage).to.eql(actual);

// select the first row and move it to the bottom and make sure the error messages stay aligned.
tableUtilsRTL.clickTableRows(summaryPanel, [0]);
tableUtilsRTL.selectCheckboxes(summaryPanel, [0]);
summaryPanel = container.querySelector("div.properties-wf-content.show");
const moveRowBottom = container.querySelector("div.properties-table-toolbar").querySelector("button.table-row-move-bottom-button");
fireEvent.click(moveRowBottom);
Expand All @@ -656,7 +656,7 @@ describe("StructureListEditor render from paramdef", () => {
// select the second from the last row and move it to the top and make sure the error messages stay aligned.
tableData = tableUtilsRTL.getTableRows(summaryPanel);
expect(tableData).to.have.length(5);
tableUtilsRTL.clickTableRows(summaryPanel, [3]);
tableUtilsRTL.selectCheckboxes(summaryPanel, [3]);
summaryPanel = container.querySelector("div.properties-wf-content.show");
const moveRowTop = container.querySelector("div.properties-table-toolbar").querySelector("button.table-row-move-top-button");
fireEvent.click(moveRowTop);
Expand Down Expand Up @@ -780,6 +780,49 @@ describe("StructureListEditor render from paramdef", () => {
});
});

describe("StructureListEditor single select table renders and functions correctly", () => {
let wrapper;

beforeEach(() => {
const renderedObject = propertyUtilsRTL.flyoutEditorForm(structureListEditorParamDef);
wrapper = renderedObject.wrapper;
});

afterEach(() => {
wrapper.unmount();
});

// Removed table toolbar from single select tables.
it("Should not render table toolbar", () => {
const { container } = wrapper;
propertyUtilsRTL.openSummaryPanel(wrapper, "inlineEditingTableWarning-summary-panel");
tableUtilsRTL.clickTableRows(container, [0]);
const tableToolbar = container.querySelectorAll("div.properties-table-toolbar");
expect(tableToolbar).to.have.length(0);
});

// Testing delete icons for single select table
it("should delete rows correctly", async() => {
const { container } = wrapper;
const summaryPanel = propertyUtilsRTL.openSummaryPanel(wrapper, "inlineEditingTableWarning-summary-panel");

// Adding a row
const addColumnButton = summaryPanel.querySelectorAll("button.properties-add-fields-button");
expect(addColumnButton).to.have.length(1);
fireEvent.click(addColumnButton[0]);

expect(tableUtilsRTL.getTableRows(container)).to.have.length(2);

// Testing delete row icon
const deleteButtons = container.querySelectorAll(".delete-button");
expect(deleteButtons).to.have.length(2);
tableUtilsRTL.clickTableRows(container, [0]); // need to click on the table that we want to delete
fireEvent.click(deleteButtons[0]);

expect(tableUtilsRTL.getTableRows(container)).to.have.length(1);
});
});

describe("StructureListEditor renders correctly with nested controls", () => {
let wrapper;
let renderedController;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -106,19 +106,18 @@ describe("summary panel renders error/warning status correctly", () => {
// ensure table toolbar has Delete button and click it
wideflyout = wrapper.find("div.properties-wf-content.show");
let tableWrapper = wideflyout.find("div[data-id='properties-expressionCellTable']");
let tableToolbar = tableWrapper.find("div.properties-table-toolbar");
let deleteButton = tableToolbar.find("button.properties-action-delete");
expect(deleteButton).to.have.length(1);
deleteButton.simulate("click");
let deleteButtons = tableWrapper.find("button.delete-button");
expect(deleteButtons).to.have.length(2);
deleteButtons.at(0).simulate("click");

// remove second row
tableUtils.clickTableRows(wideflyout, [0]);
wideflyout = wrapper.find("div.properties-wf-content.show");
tableWrapper = wideflyout.find("div[data-id='properties-expressionCellTable']");
tableToolbar = tableWrapper.find("div.properties-table-toolbar");
deleteButton = tableToolbar.find("button.properties-action-delete");
expect(deleteButton).to.have.length(1);
deleteButton.simulate("click");
deleteButtons = tableWrapper.find("button.delete-button");
expect(deleteButtons).to.have.length(1);
deleteButtons.at(0).simulate("click");


// close fly-out
wideflyout.find("button.properties-apply-button").simulate("click");
Expand Down Expand Up @@ -162,18 +161,16 @@ describe("summary panel renders error/warning status correctly", () => {
wideflyout = wrapper.find("div.properties-wf-content.show");
// ensure table toolbar has Delete button and click it
let tableWrapper = wideflyout.find("div[data-id='properties-expressionCellTable']");
const tableToolbar = tableWrapper.find("div.properties-table-toolbar");
let deleteButton = tableToolbar.find("button.properties-action-delete");
expect(deleteButton).to.have.length(1);
deleteButton.simulate("click");
let deleteButtons = tableWrapper.find("button.delete-button");
deleteButtons.at(0).simulate("click");

// remove second row
tableUtils.clickTableRows(wideflyout, [0]);
wideflyout = wrapper.find("div.properties-wf-content.show");
tableWrapper = wideflyout.find("div[data-id='properties-expressionCellTable']");
deleteButton = tableWrapper.find("div.properties-table-toolbar").find("button.properties-action-delete");
expect(deleteButton).to.have.length(1);
deleteButton.simulate("click");
deleteButtons = tableWrapper.find("button.delete-button");
deleteButtons.at(0).simulate("click");


// check that all rows were removed
wideflyout = wrapper.find("div.properties-wf-content.show");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1216,7 +1216,7 @@
},
{
"complex_type_ref": "inlineEditingTableError",
"row_selection": "single",
"row_selection": "multiple-edit",
"moveable_rows": true,
"parameters": [
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -114,5 +114,6 @@
"label.indicator.optional": "(optional)",
"slider.numberInput.label": "Slider number input",
"editorForm.tabList.label": "Primary Tabs",
"subTabs.tabList.label": "Tab List"
"subTabs.tabList.label": "Tab List",
"table.deleteIcon.tooltip": "Delete"
}
Original file line number Diff line number Diff line change
Expand Up @@ -112,5 +112,6 @@
"label.indicator.optional": "[Esperanto~(optional)~~~~~~eo]",
"slider.numberInput.label": "[Esperanto~Slider number input~~~~~eo]",
"editorForm.tabList.label": "[Esperanto~Primary Tabs~~~~eo]",
"subTabs.tabList.label": "[Esperanto~Tab List~~~~eo]"
"subTabs.tabList.label": "[Esperanto~Tab List~~~~eo]",
"table.deleteIcon.tooltip": "[Esperanto~Delete~~~~eo]"
}
Original file line number Diff line number Diff line change
Expand Up @@ -523,7 +523,8 @@ class FlexibleTable extends React.Component {

const containerClass = this.props.showHeader ? "properties-ft-container-absolute " : "properties-ft-container-absolute-noheader ";
const messageClass = (!this.props.messageInfo) ? containerClass + STATES.INFO : containerClass;
const ftHeaderClassname = "properties-ft-table-header";
const ftHeaderClassname = classNames("properties-ft-table-header",
{ "single-row-selection-table": this.props.rowSelection === ROW_SELECTION.SINGLE });
// When topRightPanel has Add button, it has this.props.topRightPanel.props.className = "properties-at-buttons-container"
const topRightPanelHasTableToolbar = (typeof this.props.topRightPanel !== "undefined" && this.props.topRightPanel !== null &&
typeof this.props.topRightPanel.props.className === "undefined");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,11 @@ $row-left-padding: $spacing-02;
height: $spacing-07;
}

.single-row-selection-table {
display: flex;
justify-content: right;
}

.properties-ft-container-panel {
height: calc(100% - #{$spacing-07}); // adjust height for table header
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -378,7 +378,6 @@ class VirtualizedTable extends React.Component {
let selectOption = "";
let selectedRow = false;
const rowDisabled = typeof rowData.disabled === "boolean" ? rowData.disabled : false;

if (typeof this.props.rowHeight === "function" && this.props.rowHeight({ index }) === 0) {
return null;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ export const MESSAGE_KEYS = {
TABLE_TOOLBAR_BUTTON_DELETE: "table.toolbar.button.delete",
TABLE_TOOLBAR_BUTTON_EDIT: "table.toolbar.button.edit",
TABLE_TOOLBAR_BUTTON_CANCEL: "table.toolbar.button.cancel",
TABLE_DELETEICON_TOOLTIP: "table.deleteIcon.tooltip"

};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,11 @@
import React from "react";
import PropTypes from "prop-types";
import { Button, Checkbox } from "@carbon/react";
import { TrashCan } from "@carbon/react/icons";
import FlexibleTable from "./../components/flexible-table";
import TableButtons from "./../components/table-buttons";
import SubPanelCell from "./../panels/sub-panel/cell.jsx";
import Tooltip from "../../tooltip/tooltip.jsx";
import ReadonlyControl from "./readonly";
import * as PropertyUtils from "./../util/property-utils";
import classNames from "classnames";
Expand Down Expand Up @@ -429,7 +431,9 @@ export default class AbstractTable extends React.Component {
}

makeTableToolbar(selectedRows) {
if ((this.props.addRemoveRows || this.props.control?.moveableRows || this.isSelectSummaryEdit(selectedRows)) && selectedRows?.length > 0) {
if ((this.props.addRemoveRows || this.props.control?.moveableRows || this.isSelectSummaryEdit(selectedRows)) &&
selectedRows?.length > 0 &&
this.props.control.rowSelection !== ROW_SELECTION.SINGLE) {
const multiSelectEditRowPropertyId = {
name: this.selectSummaryPropertyName,
row: 0
Expand Down Expand Up @@ -704,6 +708,9 @@ export default class AbstractTable extends React.Component {
// set to specific size. Exclude this column from resizing.
headers.push({ "key": "subpanel", "label": "", "width": TABLE_SUBPANEL_BUTTON_WIDTH, "staticWidth": true });
}
if (this.props.control.rowSelection === ROW_SELECTION.SINGLE) {
headers.push({ "key": "deleteRow", "label": "", "width": TABLE_SUBPANEL_BUTTON_WIDTH, "staticWidth": true });
}
return headers;
}

Expand Down Expand Up @@ -733,6 +740,34 @@ export default class AbstractTable extends React.Component {
const cell = this.buildChildItem(propertyName, rowIndex, tableState);
columns.push(cell);
}
if (this.props.control.rowSelection === ROW_SELECTION.SINGLE) {
const toolTip = PropertyUtils.formatMessage(this.reactIntl, MESSAGE_KEYS.TABLE_DELETEICON_TOOLTIP);
const tooltipId = "tooltip-delete-row";
const deleteOption = (
<Tooltip
id={tooltipId}
tip={toolTip}
direction="left"
className="properties-tooltips icon-tooltip"
>
<Button
kind="ghost"
size="sm"
className="delete-button"
hasIconOnly
onClick={this.removeSelected}
renderIcon={TrashCan}
iconDescription={toolTip}
/>
</Tooltip>
);
const deleteRow = {
column: "deleteRow",
width: TABLE_SUBPANEL_BUTTON_WIDTH,
content: deleteOption
};
columns.push(deleteRow);
}
rows.push({
columns: columns
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,9 +47,9 @@ describe("Test if tips show up for summary validation icon when there is an erro
// Select an existing row in the table and delete it's value.
cy.openSubPanel("Configure Derive Node");
cy.selectRowInTable(1, "expressionCellTable");
cy.clickButtonInTable("Delete", "expressionCellTable");
cy.clickButtonInSingleSelectTable("Delete", "expressionCellTable");
cy.selectRowInTable(1, "expressionCellTable");
cy.clickButtonInTable("Delete", "expressionCellTable");
cy.clickButtonInSingleSelectTable("Delete", "expressionCellTable");

// Select all rows in a table and delete its value
cy.selectAllRowsInTable("structurelisteditorTableInput");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -239,6 +239,22 @@ Cypress.Commands.add("clickButtonInTable", (buttonName, propertyId) => {
});
});

Cypress.Commands.add("clickButtonInSingleSelectTable", (buttonName, propertyId) => {
cy.get(`div[data-id='properties-ctrl-${propertyId}']`)
.then((tableDiv) => {
cy.wrap(tableDiv).should("exist");
if (buttonName === "Add") {
cy.wrap(tableDiv)
.find(".properties-add-fields-button")
.click();
} else {
cy.wrap(tableDiv).find("button.delete-button")
.first()
.click();
}
});
});

// StructureListEditorControl commands
Cypress.Commands.add("selectFieldInFieldPickerPanel", (fieldName, dataType, panelName) => {
// Following logic works based on assumption - fieldName in each row is unique
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1216,7 +1216,7 @@
},
{
"complex_type_ref": "inlineEditingTableError",
"row_selection": "single",
"row_selection": "multiple-edit",
"moveable_rows": true,
"parameters": [
{
Expand Down

0 comments on commit 3bebb81

Please sign in to comment.