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.
81 lines
3.0 KiB
81 lines
3.0 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 }: { title: string; isLocallySaved?: boolean }) { |
|
await this.toolbar.clickFields(); |
|
const toggleColumn = () => |
|
this.get().locator(`[data-testid="nc-fields-menu-${title}"]`).locator('input[type="checkbox"]').click(); |
|
|
|
await this.waitForResponse({ |
|
uiAction: toggleColumn, |
|
requestUrlPathToMatch: isLocallySaved ? '/api/v1/db/public/' : '/api/v1/db/data/noco/', |
|
httpMethodsToMatch: ['GET'], |
|
}); |
|
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(); |
|
} |
|
}
|
|
|