mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* [ACA-3596] Fix e2e due to process header properties changes * Change pages structure * Move the build demoshell as last step and exclude for PR * move more pages * change testing pkg * better JSON import * update script * move CLOUD in the right place * some logs and not used methods * retrycout Co-authored-by: maurizio vitale <maurizio.vitale@alfresco.com> Co-authored-by: Eugenio Romano <eugenio.romano@alfresco.com> Co-authored-by: Eugenio Romano <eromano@users.noreply.github.com>
125 lines
4.5 KiB
TypeScript
125 lines
4.5 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2019 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 { element, by } from 'protractor';
|
|
import { BrowserVisibility, TogglePage, BrowserActions, DateTimePickerPage } from '@alfresco/adf-testing';
|
|
import moment = require('moment');
|
|
|
|
export class ShareDialogPage {
|
|
|
|
togglePage = new TogglePage();
|
|
dateTimePickerPage = new DateTimePickerPage();
|
|
shareDialog = element(by.css('adf-share-dialog'));
|
|
dialogTitle = element.all(by.css('[data-automation-id="adf-share-dialog-title"]')).first();
|
|
shareToggle = element(by.css('[data-automation-id="adf-share-toggle"] label'));
|
|
expireToggle = element(by.css(`[data-automation-id="adf-expire-toggle"] label`));
|
|
shareToggleChecked = element(by.css('mat-dialog-container mat-slide-toggle.mat-checked'));
|
|
shareLink = element(by.css('[data-automation-id="adf-share-link"]'));
|
|
closeButton = element(by.css('button[data-automation-id="adf-share-dialog-close"]'));
|
|
copySharedLinkButton = element(by.css('.adf-input-action'));
|
|
expirationDateInput = element(by.css('input[formcontrolname="time"]'));
|
|
confirmationDialog = element(by.css('adf-confirm-dialog'));
|
|
confirmationCancelButton = element(by.id('adf-confirm-cancel'));
|
|
confirmationRemoveButton = element(by.id('adf-confirm-accept'));
|
|
|
|
async checkDialogIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.dialogTitle);
|
|
}
|
|
|
|
async clickUnShareFile() {
|
|
await this.togglePage.enableToggle(this.shareToggle);
|
|
}
|
|
|
|
async clickExpireToggle() {
|
|
await this.togglePage.enableToggle(this.expireToggle);
|
|
}
|
|
|
|
async clickConfirmationDialogCancelButton(): Promise<void> {
|
|
await BrowserActions.click(this.confirmationCancelButton);
|
|
}
|
|
|
|
async clickConfirmationDialogRemoveButton(): Promise<void> {
|
|
await BrowserActions.click(this.confirmationRemoveButton);
|
|
}
|
|
|
|
async checkShareLinkIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.shareLink);
|
|
}
|
|
|
|
async getShareLink(): Promise<string> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.shareLink);
|
|
return this.shareLink.getAttribute('value');
|
|
}
|
|
|
|
async clickCloseButton(): Promise<void> {
|
|
await BrowserActions.click(this.closeButton);
|
|
}
|
|
|
|
async clickShareLinkButton(): Promise<void> {
|
|
await BrowserActions.click(this.copySharedLinkButton);
|
|
}
|
|
|
|
async shareToggleButtonIsChecked(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsPresent(this.shareToggleChecked);
|
|
}
|
|
|
|
async dialogIsClosed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsStale(this.shareDialog);
|
|
}
|
|
|
|
async clickDateTimePickerButton(): Promise<void> {
|
|
await this.dateTimePickerPage.clickDateTimePicker();
|
|
}
|
|
|
|
async calendarTodayDayIsDisabled(): Promise<void> {
|
|
const tomorrow = moment().add(1, 'days').format('D');
|
|
|
|
if (tomorrow !== '1') {
|
|
await this.dateTimePickerPage.checkCalendarTodayDayIsDisabled();
|
|
}
|
|
}
|
|
|
|
async setDefaultDay(): Promise<void> {
|
|
const tomorrow = moment().add(1, 'days').format('D');
|
|
await this.dateTimePickerPage.setDate(tomorrow);
|
|
}
|
|
|
|
async setDefaultHour(): Promise<void> {
|
|
await this.dateTimePickerPage.dateTime.setDefaultEnabledHour();
|
|
}
|
|
|
|
async setDefaultMinutes() {
|
|
await this.dateTimePickerPage.dateTime.setDefaultEnabledMinutes();
|
|
}
|
|
|
|
async dateTimePickerDialogIsClosed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsStale(element(by.css('mat-datetimepicker-content')));
|
|
}
|
|
|
|
async getExpirationDate(): Promise<string> {
|
|
return this.expirationDateInput.getAttribute('value');
|
|
}
|
|
|
|
async expirationDateInputHasValue(value): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementHasValue(this.expirationDateInput, value);
|
|
}
|
|
|
|
async confirmationDialogIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.confirmationDialog);
|
|
}
|
|
}
|