mirror of
				https://github.com/Alfresco/alfresco-content-app.git
				synced 2025-10-22 15:11:25 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			101 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /*!
 | |
|  * @license
 | |
|  * Copyright 2017 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 { ElementFinder, by, browser, protractor, ExpectedConditions as EC, promise } from 'protractor';
 | |
| import { BROWSER_WAIT_TIMEOUT } from '../../configs';
 | |
| import { Component } from '../component';
 | |
| 
 | |
| export class CreateOrEditFolderDialog extends Component {
 | |
|     private static selectors = {
 | |
|         root: 'adf-folder-dialog',
 | |
| 
 | |
|         title: '.mat-dialog-title',
 | |
|         nameInput: '.mat-input-element[placeholder="Name" i]',
 | |
|         descriptionTextArea: '.mat-input-element[placeholder="Description" i]',
 | |
|         button: '.mat-dialog-actions button',
 | |
|         validationMessage: '.mat-hint span'
 | |
|     };
 | |
| 
 | |
|     title: ElementFinder = this.component.element(by.css(CreateOrEditFolderDialog.selectors.title));
 | |
|     nameInput: ElementFinder = this.component.element(by.css(CreateOrEditFolderDialog.selectors.nameInput));
 | |
|     descriptionTextArea: ElementFinder = this.component.element(by.css(CreateOrEditFolderDialog.selectors.descriptionTextArea));
 | |
|     createButton: ElementFinder = this.component.element(by.cssContainingText(CreateOrEditFolderDialog.selectors.button, 'Create'));
 | |
|     cancelButton: ElementFinder = this.component.element(by.cssContainingText(CreateOrEditFolderDialog.selectors.button, 'Cancel'));
 | |
|     updateButton: ElementFinder = this.component.element(by.cssContainingText(CreateOrEditFolderDialog.selectors.button, 'Update'));
 | |
|     validationMessage: ElementFinder = this.component.element(by.css(CreateOrEditFolderDialog.selectors.validationMessage));
 | |
| 
 | |
|     constructor(ancestor?: ElementFinder) {
 | |
|         super(CreateOrEditFolderDialog.selectors.root, ancestor);
 | |
|     }
 | |
| 
 | |
|     waitForDialogToOpen() {
 | |
|         return browser.wait(EC.presenceOf(this.title), BROWSER_WAIT_TIMEOUT);
 | |
|     }
 | |
| 
 | |
|     waitForDialogToClose() {
 | |
|         return browser.wait(EC.stalenessOf(this.title), BROWSER_WAIT_TIMEOUT);
 | |
|     }
 | |
| 
 | |
|     getTitle(): promise.Promise<string> {
 | |
|         return this.title.getText();
 | |
|     }
 | |
| 
 | |
|     isValidationMessageDisplayed(): promise.Promise<boolean> {
 | |
|         return this.validationMessage.isDisplayed();
 | |
|     }
 | |
| 
 | |
|     getValidationMessage(): promise.Promise<string> {
 | |
|         return this.isValidationMessageDisplayed()
 | |
|             .then(() => this.validationMessage.getText())
 | |
|             .catch(() => '');
 | |
|     }
 | |
| 
 | |
|     enterName(name: string): promise.Promise<CreateOrEditFolderDialog> {
 | |
|         return this.nameInput.clear()
 | |
|             .then(() => this.nameInput.sendKeys(name))
 | |
|             .then(() => this);
 | |
|     }
 | |
| 
 | |
|     enterDescription(description: string): promise.Promise<CreateOrEditFolderDialog> {
 | |
|         return this.descriptionTextArea.clear()
 | |
|             .then(() => {
 | |
|                 browser.actions().click(this.descriptionTextArea).sendKeys(description).perform();
 | |
|             })
 | |
|             .then(() => this);
 | |
|     }
 | |
| 
 | |
|     deleteNameWithBackspace(): promise.Promise<void> {
 | |
|         return this.nameInput.clear()
 | |
|             .then(() => {
 | |
|                 return this.nameInput.sendKeys(' ', protractor.Key.CONTROL, 'a', protractor.Key.NULL, protractor.Key.BACK_SPACE);
 | |
|             });
 | |
|     }
 | |
| 
 | |
|     clickCreate() {
 | |
|         return this.createButton.click();
 | |
|     }
 | |
| 
 | |
|     clickCancel() {
 | |
|         return this.cancelButton.click()
 | |
|             .then(() => this.waitForDialogToClose());
 | |
|     }
 | |
| 
 | |
|     clickUpdate() {
 | |
|         return this.updateButton.click();
 | |
|     }
 | |
| }
 |