107 lines
3.7 KiB
TypeScript

/*!
* @license
* Copyright 2016 Alfresco Software, Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import FormFields = require('../formFields');
import Util = require('../../../../util/util');
import { element, by, browser, protractor } from 'protractor';
export class DynamicTable {
formFields = new FormFields();
labelLocator = by.css('dynamic-table-widget div div');
columnNameLocator = by.css('table[id*="dynamic-table"] th');
addButton = element(by.id('label-add-row'));
columnDateTime = element(by.id('columnDateTime'));
columnDate = element(by.id('columnDate'));
calendarHeader = element(by.css('div[class="mat-datetimepicker-calendar-header-date-time"]'));
calendarContent = element(by.css('div[class="mat-datetimepicker-calendar-content"]'));
saveButton = element(by.cssContainingText('button span', 'Save'));
errorMessage = element(by.css('div[class="adf-error-text"]'));
dateWidget = element.all(by.css('button[aria-label="Open calendar"]')).first();
calendarNumber = element.all(by.css('td div'));
tableRow = element.all(by.css('tbody tr'));
getFieldLabel(fieldId) {
return this.formFields.getFieldLabel(fieldId, this.labelLocator);
}
getColumnName(fieldId) {
return this.formFields.getFieldText(fieldId, this.columnNameLocator);
}
clickAddButton() {
Util.waitUntilElementIsVisible(this.addButton);
return this.addButton.click();
}
clickColumnDateTime() {
Util.waitUntilElementIsVisible(this.columnDateTime);
this.columnDateTime.click();
Util.waitUntilElementIsVisible(this.calendarHeader);
Util.waitUntilElementIsVisible(this.calendarContent);
browser.actions().sendKeys(protractor.Key.ESCAPE).perform();
}
addRandomStringOnDateTime(randomText) {
Util.waitUntilElementIsVisible(this.columnDateTime);
this.columnDateTime.click();
browser.actions().sendKeys(protractor.Key.ESCAPE).perform();
this.columnDateTime.sendKeys(randomText);
this.columnDateTime.sendKeys(protractor.Key.ENTER);
return this.columnDateTime.getAttribute('value');
}
addRandomStringOnDate(randomText) {
Util.waitUntilElementIsVisible(this.columnDate);
this.columnDate.click();
return this.columnDate.sendKeys(randomText);
}
clickSaveButton() {
Util.waitUntilElementIsVisible(this.saveButton);
return this.saveButton.click();
}
checkErrorMessage() {
Util.waitUntilElementIsVisible(this.errorMessage);
return this.errorMessage.getText();
}
clickDateWidget() {
Util.waitUntilElementIsVisible(this.dateWidget);
return this.dateWidget.click();
}
getDateCalendarNumber(date) {
return this.calendarNumber.get(date).click();
}
getTableRow(rowNumber) {
return Util.waitUntilElementIsVisible(this.tableRow.get(rowNumber));
}
waitForCalendarToDisappear() {
Util.waitUntilElementIsNotVisible(this.calendarNumber);
}
checkItemIsPresent(item) {
let row = element(by.cssContainingText('table tbody tr td span', item));
let present = Util.waitUntilElementIsVisible(row);
expect(present).toBe(true);
}
}