mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-31 17:38:28 +00:00
* reduce breadcrumb page * imrpove readability of code * reduce data-table page size * reduce datetime-picker code * fix datatable page * header and info drawer * update datatable page * toolbar cleanup * more test components cleanup * even move component cleanup * move wait utils to the Utils * unified waits * cleanup menu page * code fixes * fix code * code improvements * rename api * fix code * fix code * cleanup dialog pages * more fixes and dead code removal * code fixes * try to fix the flaky teset * fix code * fix code * update code * fix lint * unified text input * fix lint * add missing await * reduce the wrapper method around clear text * resolve element value Co-authored-by: Cilibiu Bogdan <bogdan.cilibiu@ness.com>
105 lines
3.9 KiB
TypeScript
Executable File
105 lines
3.9 KiB
TypeScript
Executable File
/*!
|
|
* @license
|
|
* Alfresco Example Content Application
|
|
*
|
|
* Copyright (C) 2005 - 2020 Alfresco Software Limited
|
|
*
|
|
* This file is part of the Alfresco Example Content Application.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { by, browser, ElementFinder } from 'protractor';
|
|
import { Component } from '../component';
|
|
import { isPresentAndEnabled, isPresentAndDisplayed, waitForVisibility } from '../../utilities/utils';
|
|
|
|
export class ContentMetadata extends Component {
|
|
expandedPanel = this.byCss('.mat-expansion-panel.mat-expanded');
|
|
propertyList = this.byCss('.adf-property-list');
|
|
propertyListElements = this.allByCss('.adf-property');
|
|
propertyValue = this.byCss('.adf-property-value');
|
|
editPropertiesButton = this.byCss(`button[title='Edit']`);
|
|
lessInfoButton = this.byCssText(`[data-automation-id='meta-data-card-toggle-expand']`, 'Less information');
|
|
moreInfoButton = this.byCssText(`[data-automation-id='meta-data-card-toggle-expand']`, 'More information');
|
|
imagePropertiesPanel = this.byCss(`[data-automation-id='adf-metadata-group-APP.CONTENT_METADATA.EXIF_GROUP_TITLE']`);
|
|
expandedImagePropertiesPanel = this.byCss(`[data-automation-id='adf-metadata-group-APP.CONTENT_METADATA.EXIF_GROUP_TITLE'].mat-expanded`);
|
|
|
|
constructor(ancestor?: string) {
|
|
super('adf-content-metadata-card', ancestor);
|
|
}
|
|
|
|
async isPropertiesListExpanded(): Promise<boolean> {
|
|
return browser.isElementPresent(this.expandedPanel);
|
|
}
|
|
|
|
async waitForImagePropertiesPanelToExpand(): Promise<void> {
|
|
await waitForVisibility(this.expandedImagePropertiesPanel);
|
|
}
|
|
|
|
async getVisiblePropertiesLabels(): Promise<string[]> {
|
|
return this.allByCss('.adf-property-label')
|
|
.filter(async (elem) => elem.isDisplayed())
|
|
.map(async (elem) => elem.getText());
|
|
}
|
|
|
|
async getVisiblePropertiesValues() {
|
|
return this.allByCss('.adf-property-value')
|
|
.filter(async (elem) => elem.isDisplayed())
|
|
.map(async (elem) => {
|
|
if (await elem.isElementPresent(by.css('.mat-checkbox'))) {
|
|
if (await elem.isElementPresent(by.css('.mat-checkbox-checked'))) {
|
|
return true;
|
|
}
|
|
return false
|
|
}
|
|
|
|
return this.getElementValue(elem);
|
|
});
|
|
}
|
|
|
|
async isEditPropertiesButtonEnabled(): Promise<boolean> {
|
|
return isPresentAndEnabled(this.editPropertiesButton);
|
|
}
|
|
|
|
async isLessInfoButtonEnabled(): Promise<boolean> {
|
|
return isPresentAndEnabled(this.lessInfoButton);
|
|
}
|
|
|
|
async isMoreInfoButtonEnabled(): Promise<boolean> {
|
|
return isPresentAndEnabled(this.moreInfoButton);
|
|
}
|
|
|
|
async isMoreInfoButtonDisplayed(): Promise<boolean> {
|
|
return browser.isElementPresent(this.moreInfoButton);
|
|
}
|
|
|
|
async isImagePropertiesPanelDisplayed(): Promise<boolean> {
|
|
return isPresentAndDisplayed(this.imagePropertiesPanel);
|
|
}
|
|
|
|
private async getElementValue(elem: ElementFinder): Promise<string> {
|
|
const tagName = await elem.getTagName();
|
|
|
|
if (tagName === 'input' || tagName === 'textarea') {
|
|
return elem.getAttribute('value');
|
|
}
|
|
|
|
return elem.getText();
|
|
}
|
|
}
|
|
|