mirror of
https://github.com/n8n-io/n8n.git
synced 2026-05-24 21:35:24 +02:00
Some checks are pending
CI: Master (Build, Test, Lint) / Build for Github Cache (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (22.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (24.14.1) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (25.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Lint (push) Waiting to run
CI: Master (Build, Test, Lint) / Performance (push) Waiting to run
CI: Master (Build, Test, Lint) / Notify Slack on failure (push) Blocked by required conditions
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
97 lines
2.7 KiB
TypeScript
97 lines
2.7 KiB
TypeScript
import { BasePage } from './BasePage';
|
|
import { AddResource } from './components/AddResource';
|
|
|
|
export class DataTableView extends BasePage {
|
|
async goto(projectId?: string) {
|
|
const url = projectId ? `/projects/${projectId}/datatables` : '/home/datatables';
|
|
await this.page.goto(url);
|
|
}
|
|
|
|
readonly addResource = new AddResource(this.page);
|
|
|
|
getEmptyStateActionBox() {
|
|
return this.page.getByTestId('empty-data-table-action-box');
|
|
}
|
|
|
|
getEmptyStateActionBoxButton() {
|
|
return this.getEmptyStateActionBox().getByRole('button');
|
|
}
|
|
|
|
getNewDataTableModal() {
|
|
return this.page.getByTestId('addDataTableModal-modal');
|
|
}
|
|
|
|
getNewDataTableNameInput() {
|
|
return this.page.getByTestId('data-table-name-input-select');
|
|
}
|
|
|
|
getFromScratchOption() {
|
|
return this.page.getByTestId('create-from-scratch-option');
|
|
}
|
|
|
|
getProceedFromSelectButton() {
|
|
return this.page.getByTestId('proceed-from-select-button');
|
|
}
|
|
|
|
getDataTableCards() {
|
|
return this.page.getByTestId('data-table-card');
|
|
}
|
|
|
|
getDataTableCardByName(name: string) {
|
|
return this.getDataTableCards().filter({ hasText: name });
|
|
}
|
|
|
|
getDataTableCardActionsButton(dataTableName: string) {
|
|
return this.getDataTableCardByName(dataTableName).getByTestId('data-table-card-actions');
|
|
}
|
|
|
|
getDataTableCardAction(actionName: string) {
|
|
return this.page.getByTestId('action-toggle-dropdown').getByTestId(`action-${actionName}`);
|
|
}
|
|
|
|
getDeleteDataTableModal() {
|
|
return this.page.locator('.el-message-box').filter({ hasText: 'Delete Data table' });
|
|
}
|
|
|
|
getDeleteDataTableConfirmButton() {
|
|
return this.getDeleteDataTableModal().locator('.btn--confirm');
|
|
}
|
|
|
|
getDataTablePageSizeSelect() {
|
|
return this.page.getByTestId('resources-list-pagination').locator('.el-pagination__sizes');
|
|
}
|
|
|
|
getDataTablePageOption(pageSize: string) {
|
|
return this.page.locator('.el-select-dropdown__item').filter({ hasText: `${pageSize}/page` });
|
|
}
|
|
|
|
getPaginationNextButton() {
|
|
return this.page.getByTestId('resources-list-pagination').locator('button.btn-next');
|
|
}
|
|
|
|
async clickDataTableProjectTab() {
|
|
await this.clickByTestId('tab-project-data-tables');
|
|
}
|
|
|
|
async clickEmptyStateButton() {
|
|
await this.getEmptyStateActionBoxButton().click();
|
|
}
|
|
|
|
async clickAddDataTableAction(fromDataTableTab: boolean = true) {
|
|
await this.addResource.dataTable(fromDataTableTab);
|
|
}
|
|
|
|
async clickDataTableCardActionsButton(dataTableName: string) {
|
|
await this.getDataTableCardActionsButton(dataTableName).click();
|
|
}
|
|
|
|
async clickDeleteDataTableConfirmButton() {
|
|
await this.getDeleteDataTableConfirmButton().click();
|
|
}
|
|
|
|
async selectDataTablePageSize(pageSize: string) {
|
|
await this.getDataTablePageSizeSelect().click();
|
|
await this.getDataTablePageOption(pageSize).click();
|
|
}
|
|
}
|