Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: isRequired validation property for table select column #36375

Merged
Merged
Show file tree
Hide file tree
Changes from 16 commits
Commits
Show all changes
20 commits
Select commit Hold shift + click to select a range
b0963bb
fix: add regex check on phone number change
SaiCharanChetpelly31 Jul 4, 2024
ed41946
feat: add comment for regex in phone input widget
SaiCharanChetpelly31 Jul 17, 2024
beea37b
Merge branch 'release' of https://github.com/SaiCharanChetpelly31/app…
SaiCharanChetpelly31 Jul 17, 2024
6c823bf
add validation in derived.js and SelectCell with isEditableCellValid
jacquesikot Sep 10, 2024
440ec7f
Merge branch 'release' of https://github.com/appsmithorg/appsmith int…
jacquesikot Sep 10, 2024
0ff1bac
allow validation in select column property + pass hasError prop in Se…
jacquesikot Sep 13, 2024
eceeb49
remove overriding css
Sep 13, 2024
886c248
add cypress test cases
jacquesikot Sep 17, 2024
9ef6228
set only isRequired validation for table select column
jacquesikot Sep 17, 2024
079c0ee
Merge branch 'release' of https://github.com/appsmithorg/appsmith int…
jacquesikot Sep 17, 2024
3aed3c0
rename test file for clarity
jacquesikot Sep 17, 2024
01cfe05
revert spacing change in index.styled
jacquesikot Sep 17, 2024
9545e07
Merge branch 'release' of https://github.com/appsmithorg/appsmith int…
jacquesikot Sep 17, 2024
6bb7b5a
fix selectors in Table_select_validation_spec
jacquesikot Sep 18, 2024
02d8949
abstract hideColumnByType to function + improve Table_select_validati…
jacquesikot Sep 19, 2024
64f8576
Merge branch 'release' of https://github.com/appsmithorg/appsmith int…
jacquesikot Sep 19, 2024
110e6fd
remove .only from test
jacquesikot Sep 19, 2024
8a38ded
remove reducndant check for border color in Table_select_validation_spec
jacquesikot Sep 19, 2024
17f9fbc
add const for select error and valid style
jacquesikot Sep 20, 2024
d2597e6
replace cy.dragAndDropToCanvas with entityExplorer.DragNDropWidget
jacquesikot Sep 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
import commonlocators from "../../../../../../locators/commonlocators.json";
import {
agHelper,
locators,
propPane,
table,
} from "../../../../../../support/Objects/ObjectsCore";
import EditorNavigation, {
EntityType,
} from "../../../../../../support/Pages/EditorNavigation";

const hexToRgb = (hex: string) => {
const shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i;
hex = hex.replace(shorthandRegex, (m, r, g, b) => r + r + g + g + b + b);

const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result
? `rgb(${parseInt(result[1], 16)}, ${parseInt(result[2], 16)}, ${parseInt(result[3], 16)})`
: null;
};

const validateSelectBorderColor = (color: string) => {
agHelper
.GetElement(commonlocators.singleSelectWidgetButtonControl)
.then(($el) => {
const borderDangerColor = getComputedStyle($el[0]).getPropertyValue(
color,
);
const borderDangerColorRgb = hexToRgb(borderDangerColor);
cy.wrap($el).should("have.css", "border-color", borderDangerColorRgb);
});
};

describe(
"Table widget - Select column validation",
{ tags: ["@tag.Widget", "@tag.Table", "@tag.Select"] },
() => {
before(() => {
cy.dragAndDropToCanvas("tablewidgetv2", { x: 350, y: 500 });
jacquesikot marked this conversation as resolved.
Show resolved Hide resolved
table.AddSampleTableData();
});
it.only("1. should prevent adding a row when a required select column has no data", () => {
jacquesikot marked this conversation as resolved.
Show resolved Hide resolved
EditorNavigation.SelectEntityByName("Table1", EntityType.Widget);

// Allow adding a row in table
propPane.TogglePropertyState("Allow adding a row", "On");

// Edit step column to select type
table.ChangeColumnType("step", "Select", "v2");
table.EditColumn("step", "v2");

// Add data to select options
agHelper.UpdateCodeInput(
locators._controlOption,
`
[
{
"label": "#1",
"value": "#1"
},
{
"label": "#2",
"value": "#2"
},
{
"label": "#3",
"value": "#3"
}
]
`,
);

// Set step column to editable
propPane.TogglePropertyState("Editable", "On");

// Set step column to required
propPane.TogglePropertyState("Required", "On");

// Click add a new row
table.AddNewRow();

// Expect the save row button to be disabled
agHelper.GetElement(table._saveNewRow).should("be.disabled");

// Expect select to have an error color
validateSelectBorderColor("--wds-color-border-danger");

// Select a valid option from the select table cell
agHelper.GetNClick(commonlocators.singleSelectWidgetButtonControl);
agHelper
.GetElement(commonlocators.singleSelectWidgetMenuItem)
.contains("#1")
.click();

// Expect the save row option to be enabled
agHelper.GetElement(table._saveNewRow).should("be.enabled");

// Expect button to have a valid color
validateSelectBorderColor("var(--wds-color-border)");

// Discard save new row
agHelper.GetElement(table._discardRow).click({ force: true });
});

it("2. should display an error when inline editing a required select cell in a table with no data", () => {
// Update table data to create emtpy cell in step column
propPane.NavigateBackToPropertyPane();
propPane.UpdatePropertyFieldValue(
"Table data",
`
[
{
"task": "Drop a table",
"status": "✅",
"action": ""
},
{
"step": "#2",
"task": "Create a query fetch_users with the Mock DB",
"status": "--",
"action": ""
},
{
"step": "#3",
"task": "Bind the query using => fetch_users.data",
"status": "--",
"action": ""
}
]
`,
);

// Click the first cell in the step column
table.ClickOnEditIcon(0, 0, true);

// Exect the select to have an error color
validateSelectBorderColor("--wds-color-border-danger");
});
},
);
1 change: 1 addition & 0 deletions app/client/cypress/locators/commonlocators.json
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@
"callApi": ".t--property-control-onpagechange .t--open-dropdown-Select-Action",
"singleSelectMenuItem": ".bp3-menu-item.single-select div",
"singleSelectWidgetMenuItem": ".menu-item-link",
"singleSelectWidgetButtonControl": ".bp3-button.select-button",
"singleSelectActiveMenuItem": ".menu-item-active div",
"selectInputSearch": ".select-popover-wrapper .bp3-input",
"multiSelectMenuItem": "rc-select-item.rc-select-item-option div",
Expand Down
18 changes: 12 additions & 6 deletions app/client/cypress/support/Pages/Table.ts
Original file line number Diff line number Diff line change
Expand Up @@ -638,18 +638,24 @@ export class Table {
this.agHelper.GetNClick(colSettings);
}

public ClickOnEditIcon(rowIndex: number, colIndex: number) {
public ClickOnEditIcon(
rowIndex: number,
colIndex: number,
isSelectColumn: boolean = false,
) {
this.agHelper.HoverElement(this._tableRow(rowIndex, colIndex, "v2"));
this.agHelper.GetNClick(
this._tableRow(rowIndex, colIndex, "v2") + " " + this._editCellIconDiv,
0,
true,
);
this.agHelper.AssertElementVisibility(
this._tableRow(rowIndex, colIndex, "v2") +
" " +
this._editCellEditorInput,
);
if (!isSelectColumn) {
this.agHelper.AssertElementVisibility(
this._tableRow(rowIndex, colIndex, "v2") +
" " +
this._editCellEditorInput,
);
}
}

public EditTableCell(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ const StyledSelectComponent = styled(SelectComponent)<{
accentColor: string;
height: number;
isNewRow: boolean;
isValid: boolean;
}>`
&&& {
width: ${(props) =>
Expand All @@ -37,7 +38,6 @@ const StyledSelectComponent = styled(SelectComponent)<{
}

& button.bp3-button {
border-color: #fff;
padding: 0 9px;
min-height: ${(props) => {
return props.isNewRow
Expand Down Expand Up @@ -82,6 +82,7 @@ type SelectProps = BaseCellComponentProps & {
value: string;
width: number;
isEditable: boolean;
isEditableCellValid: boolean;
tableWidth: number;
isCellEditable?: boolean;
isCellEditMode?: boolean;
Expand Down Expand Up @@ -131,6 +132,7 @@ export const SelectCell = (props: SelectProps) => {
isCellEditMode,
isCellVisible,
isEditable,
isEditableCellValid,
isFilterable = false,
isHidden,
isNewRow,
Expand Down Expand Up @@ -236,13 +238,14 @@ export const SelectCell = (props: SelectProps) => {
compactMode
dropDownWidth={width}
filterText={filterText}
hasError={!isEditableCellValid}
height={TABLE_SIZES[compactMode].ROW_HEIGHT}
hideCancelIcon
isFilterable={isFilterable}
isLoading={false}
isNewRow={isNewRow}
isOpen={autoOpen}
isValid
isValid={isEditableCellValid}
labelText=""
onClose={onClose}
onFilterChange={onFilter}
Expand Down
2 changes: 1 addition & 1 deletion app/client/src/widgets/TableWidgetV2/widget/derived.js
Original file line number Diff line number Diff line change
Expand Up @@ -1037,7 +1037,7 @@ export default {
};

let editableColumns = [];
const validatableColumns = ["text", "number", "currency", "date"];
const validatableColumns = ["text", "number", "currency", "date", "select"];

if (props.isAddRowInProgress) {
Object.values(props.primaryColumns)
Expand Down
1 change: 1 addition & 0 deletions app/client/src/widgets/TableWidgetV2/widget/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2156,6 +2156,7 @@ class TableWidgetV2 extends BaseWidget<TableWidgetProps, WidgetState> {
isCellEditable={isCellEditable}
isCellVisible={cellProperties.isCellVisible ?? true}
isEditable={isColumnEditable}
isEditableCellValid={this.isColumnCellValid(alias)}
isFilterable={cellProperties.isFilterable}
isHidden={isHidden}
isNewRow={isNewRow}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ export default {
ColumnTypes.NUMBER,
ColumnTypes.DATE,
ColumnTypes.CURRENCY,
ColumnTypes.SELECT,
],
true,
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,17 @@ import {
getColumnPath,
} from "widgets/TableWidgetV2/widget/propertyUtils";

const hideColumnByType = (props: TableWidgetProps, propertyPath: string) => {
const path = getColumnPath(propertyPath);

return showByColumnType(
props,
path,
[ColumnTypes.DATE, ColumnTypes.SELECT],
true,
);
};

export default [
{
propertyName: "validation.regex",
Expand All @@ -18,11 +29,7 @@ export default [
isBindProperty: true,
isTriggerProperty: false,
validation: { type: ValidationTypes.REGEX },
hidden: (props: TableWidgetProps, propertyPath: string) => {
const path = getColumnPath(propertyPath);

return showByColumnType(props, path, [ColumnTypes.DATE], true);
},
hidden: hideColumnByType,
},
{
propertyName: "validation.isColumnEditableCellValid",
Expand All @@ -39,11 +46,7 @@ export default [
default: true,
},
},
hidden: (props: TableWidgetProps, propertyPath: string) => {
const path = getColumnPath(propertyPath);

return showByColumnType(props, path, [ColumnTypes.DATE], true);
},
hidden: hideColumnByType,
},
{
propertyName: "validation.errorMessage",
Expand All @@ -56,11 +59,7 @@ export default [
isBindProperty: true,
isTriggerProperty: false,
validation: { type: ValidationTypes.TEXT },
hidden: (props: TableWidgetProps, propertyPath: string) => {
const path = getColumnPath(propertyPath);

return showByColumnType(props, path, [ColumnTypes.DATE], true);
},
hidden: hideColumnByType,
},
{
propertyName: "validation.isColumnEditableCellRequired",
Expand Down
Loading