mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
115 lines
3.7 KiB
115 lines
3.7 KiB
import { expect } from '@playwright/test'; |
|
import BasePage from '../../../Base'; |
|
import { ToolbarPage } from './index'; |
|
|
|
export class ToolbarFieldsPage extends BasePage { |
|
readonly toolbar: ToolbarPage; |
|
|
|
constructor(toolbar: ToolbarPage) { |
|
super(toolbar.rootPage); |
|
this.toolbar = toolbar; |
|
} |
|
|
|
get() { |
|
return this.rootPage.locator(`[data-testid="nc-fields-menu"]`); |
|
} |
|
|
|
// todo: Click and toggle are similar method. Remove one of them |
|
async toggle({ |
|
title, |
|
isLocallySaved, |
|
validateResponse = true, |
|
}: { |
|
title: string; |
|
isLocallySaved?: boolean; |
|
validateResponse?: boolean; |
|
}) { |
|
await this.toolbar.clickFields(); |
|
|
|
// hack |
|
await this.rootPage.waitForTimeout(100); |
|
|
|
const toggleColumn = () => |
|
this.get().locator(`[data-testid="nc-fields-menu-${title}"]`).locator('input[type="checkbox"]').click(); |
|
|
|
if (validateResponse) { |
|
await this.waitForResponse({ |
|
uiAction: toggleColumn, |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
} else { |
|
await toggleColumn(); |
|
} |
|
|
|
await this.toolbar.parent.dashboard.waitForLoaderToDisappear(); |
|
await this.toolbar.clickFields(); |
|
} |
|
|
|
async verify({ title, checked }: { title: string; checked?: boolean }) { |
|
const checkbox = this.get().locator(`[data-testid="nc-fields-menu-${title}"]`).locator('input[type="checkbox"]'); |
|
|
|
if (checked) { |
|
await expect(checkbox).toBeChecked(); |
|
} else if (checked === false) { |
|
await expect(checkbox).not.toBeChecked(); |
|
} |
|
} |
|
|
|
async click({ title, isLocallySaved }: { title: string; isLocallySaved?: boolean }) { |
|
await this.waitForResponse({ |
|
uiAction: () => |
|
this.get().locator(`[data-testid="nc-fields-menu-${title}"]`).locator('input[type="checkbox"]').click(), |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
await this.toolbar.parent.waitLoading(); |
|
} |
|
|
|
async hideAll({ isLocallySaved }: { isLocallySaved?: boolean } = {}) { |
|
await this.toolbar.clickFields(); |
|
await this.waitForResponse({ |
|
uiAction: () => this.get().locator(`button:has-text("Hide all")`).click(), |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
await this.toolbar.clickFields(); |
|
} |
|
|
|
async showAll({ isLocallySaved }: { isLocallySaved?: boolean } = {}) { |
|
await this.toolbar.clickFields(); |
|
await this.waitForResponse({ |
|
uiAction: () => this.get().locator(`button:has-text("Show all")`).click(), |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
await this.toolbar.clickFields(); |
|
} |
|
|
|
async toggleShowSystemFields({ isLocallySaved }: { isLocallySaved?: boolean } = {}) { |
|
await this.toolbar.clickFields(); |
|
await this.waitForResponse({ |
|
uiAction: () => this.get().locator(`.nc-fields-show-system-fields`).click(), |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
await this.toolbar.clickFields(); |
|
} |
|
|
|
async getFieldsTitles() { |
|
let fields: string[] = await this.rootPage.locator(`.nc-grid-header .name`).allTextContents(); |
|
return fields; |
|
} |
|
|
|
async dragDropFields(param: { from: number; to: number }) { |
|
await this.toolbar.clickFields(); |
|
const { from, to } = param; |
|
const [fromStack, toStack] = await Promise.all([ |
|
this.get().locator(`.cursor-move`).nth(from), |
|
this.get().locator(`.cursor-move`).nth(to), |
|
]); |
|
|
|
await fromStack.dragTo(toStack); |
|
await this.toolbar.clickFields(); |
|
} |
|
}
|
|
|