mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* Fixed linting * Fixed storybook with migration to WP5 * Fixed core unit test and excluded instable ones * Rebased with the latest develop * Fixed most of unit tests failing * Fixed prod build * Fixed linting and js-api tests * Fixed unit tests * Fixed last unit tests * Fixed js-api build * Attempt to fix the e2e run' * Fixing e2e part 2 * Fixing styles not migrated by material * Fixed unit test failing * E2E - fixing * Fixing unit after rebase * Fixing e2e - part III * Rebase went little bit wrong -II * Rebase went little bit wrong -III * Fixing e2e - changing toggles * Fixed code flow switch setting * wrong xdescribe * fixig e2es * fixig e2es - task and version * readded missing dep * Fixed slider search e2es * rebased and fixed the wrong directive for matList' * fixed unit test problem and some other e2e * Fixed search e2es * Rebased to latest * Fixed the last e2es? * reverted broken rebase * Fixed unit tests after rebase * Fixed unit tests after rebase * Honestly i'm going on just for the challenge now' * Readded method removed * Fixed pointless e2e * Fixed unit test * [AAE-18267] change unit test setup for auth service (#9216) * [AAE-18267] change unit test setup for auth service * [AAE-18267] remove exclude * [AAE-18267] removed CoreTestingModule from imports * unit test fixes for migration (#9217) * reenabled excluded test in TagNodeList * fixed tests for UploadApi in js-api * Fixed a dependency problem * remaining unit test fixes for the Angular 15 update (#9218) * removing excludes from working tests * test fixes for CategoriesManagementComponent * [ci:force] reenabling tests / fixes * fixes in process-services-cloud * change html element type * fix selector in StartProcessComponent * Revert "Fixed a dependency problem" This reverts commit 319e1830fec774b4a7d8e3662d80ca2a8a56f196. * Rebased to latest * Fixed PR after huge rebase -_- * Fixed lint files and exclude some needing migration * Fixed package.json * Fixed dependency to allow greater versions * Rebased to the latest * [affected:*][ci:force] Fixing rebase * [affected:*][ci:force] Fixing rebase * [affected:*][ci:force] Fixing rebase * [affected:*][ci:force] Wrong setting page * [affected:*][ci:force] Upgrading material selector class * [affected:*][ci:force] Fixed lint * [affected:*][ci:force] Fixed lint * [affected:*][ci:force] Fixed e2e with new notation * [affected:*][ci:force] Fixed e2e with new notation * [affected:*][ci:force] Fixed e2e with new notation * [affected:*][ci:force] [AAE-21070] Fix e2e Content: Components - C587084 - fix class selectors * [affected:*][ci:force] Fixed lint after error on important * Improvement/AAE-19176-reapply-selector-changes (#9424) * AAE-19510 remove selector variable * AAE-19510 poc for card view using variable selectors * AAE-19176 rename mat selectors file * AAE-19176 add missing style imports * AAE-19176 remove remaining mat selectors * AAE-19176 replaced todo material selectors with variables * AAE-19176 changes made in meantime * AAE-19176 conflict fixes * [AAE-21083] Fix e2e Content: Metadata - C245652 - fix tab active selector * Fix selector after merging https://github.com/Alfresco/alfresco-ng2-components/pull/9424, .mat-content-actions was replaced by .adf-start-process-content-actions * Fix lint issue * [AAE-21083] Fix e2e Content: Metadata - C280560 - fix slide toggle click, in v15 toggle is handled with a button instead of input * [affected:*][ci:force] Fixed check on expansion panel filter * [affected:*][ci:force] Fixed check on expansion panel filter * [affected:*][ci:force] Fixed other e2es * [affected:*][ci:force] Fixing e2e - the long painful journey * [affected:*][ci:force] Fixing e2e - the long painful journey - part II * [AAE-21084] Fix e2e Content: Upload and Versioning - C279992 - fix enable togle selector * [AAE-21085] Fix e2e Search - revert to previous version, text should be written without pressing eneter to show the autocomplete list items * [AAE-21085] Fix e2e Search - add content selector that wrap text * [affected:*][ci:force] Fixing e2e - the lord of E2E * [AAE-21089] Fix e2e Search - fix checkbox selector * [affected:*][ci:force] Fixing e2e - the lord of E2E * [affected:*][ci:force] Fixing e2e - the return of the fail * [affected:*][ci:force] Fixing e2e - the return of the fail * [affected:*][ci:force] Fixing e2e - the eternal fail * [affected:*][ci:force] Remove fit * [affected:*][ci:force] Fixing e2e - fixing the last ones * [affected:*][ci:force] attempt to fix mat-selectors importing * [affected:*][ci:force] Fixing the styles - check * [affected:*][ci:force] Added pretheme for core as it is mandatory when publishing and rebuilding * [affected:*][ci:force] - REBASED * [ACS-7359] - Angular 15 - Edit aspects modal [ACA] (#9488) * [affected:*][ci:force] - REBASED * [affected:*][ci:force] - REBASED * [affected:*][ci:force] - Rebased and added an extra fix for after * [affected:*][ci:force] - Funny imports * [ACS-7373] ng15 permissions page fixes * [ACS-7373] mat-icon-buttons * [ACS-7452] - Small screen notification banner [ACS-7418] About page (#9507) * [ACS-7413] Dialog height and spacing issues (#9515) * [ACS-7446] - Upload progress box issues * [ACS-7414] - Manage versions dialog * [ACS-7375] - Share link dialog issues * Fixed errors on unit and lint * Re Enabling unit test removed * Fixing unit test after last rebase + lint * Fixing unit test after last rebase + lint * Fixing unit test after last rebase + lint * [ACS-7419] Fix broken styling of notifications * [ACS-7419] Fix broken styling of notifications, apply pr remarks * [ACS-7419] Fix broken styling of notifications, apply pr remarks * [ACS-7419] Fix broken styling of notifications, apply pr remarks * Extra parentesys lint * [ACS-7528] - Notification and user icons are a bit different (#9540) * [ACS-7532] - Click on chip in search gives redundant icon (#9544) * [ACS-7530] - Notifications popup looks a bit differently (#9543) * [ACS-7414] - manage versions dialog (#9545) * [ACS-7535][ACS-7537][ACS-7536][ACA] Move/Copy dialogs, Share dialog, Aspects dialog (#9553) * AAE-21697 Fix people form widget style (#9555) * [affected:*][ci:force] - Rebased * [affected:*][ci:force] - Fixed problem after rebase * [ACS-7519] - Login page (#9565) * [ACS-7331] - View details sidebar (#9455) * [ACS-7542] - Upload new version dialog (#9572) * [ACS-7542] - Upload new version dialog * [ACS-7542] - Upload new version dialog * [ACS-7575] create library dialog fixes (#9574) * [ACS-7534] create/edit folder dialog fixes (#9575) * Rebased ADF Migration PR * Rebased ADF Migration PR * Sync lock * [ACS-7681] Bell icon not aligned [ACS-7571] Comments [ACS-7563] Add permission dialog (#9594) * [ACS-7554] Fix tags in column display (#9597) * Fixed unit test * AAE-21256 Fix form widget styles (#9599) * [ACS-7555] column filters (#9576) * Changed ng version before material migration * migration for material' * Upgrading NX and start fixing styles * Make all the part build * Fixed core unit test and excluded instable ones * Fixed most of unit tests failing * Fixed unit tests * Fixed last unit tests * fixed unit test problem and some other e2e * Fixed unit tests after rebase * [AAE-18267] change unit test setup for auth service (#9216) * [AAE-18267] change unit test setup for auth service * [AAE-18267] remove exclude * [AAE-18267] removed CoreTestingModule from imports * remaining unit test fixes for the Angular 15 update (#9218) * removing excludes from working tests * test fixes for CategoriesManagementComponent * [ci:force] reenabling tests / fixes * fixes in process-services-cloud * change html element type * fix selector in StartProcessComponent * Fixing unit test after last rebase + lint * ACS-7555 Fixed styles for node type filters * ACS-7555 Removed redundant padding * ACS-7555 Outlined input for text filter * ACS-7555 Resolved conflicts --------- Co-authored-by: Vito Albano <vito.albano@hyland.com> Co-authored-by: Wojciech Duda <69160975+wojd0@users.noreply.github.com> * AAE-21393 Fix amount form widget style (#9601) * AAE-21392 Fix dropdown form widget style (#9605) * [ACS-7582] Upload dialog button display fix (#9603) * [ACS-7531] - Search page (#9606) * rebased to last develop * Fixed SonarCloud complaints * Fixed SonarCloud complaints * Fixing some sonarcloud comments * [ACS-7572] link rules dialog fixes (#9607) * AAE-21703 Fix group widget style (#9612) * AAE-21703 Fix group form widget style * AAE-21703 Improve tests * [ACS-7533] - Advanced search chips dropdowns (#9618) * [ACS-7560] undo deletion notification (#9632) * ACS-7560 Fixed margin around snackbar and size of x icon * ACS-7560 Fixed styles for info snackbar * Rebased to the latest develop * Rebased to the latest * Skipped failing unit tests * Updated today date selector * rebased * Fixed process unit test fail * fix folder-edit license headers * fix FolderEditDirective unit tests * AAE-21937 Fix context menu list component (#9658) * Fixed broken unit test after rebase * ACS-7561 - permissions page (#9675) * Trying to fix the long failing e2ea * Missed import * Fixed changed unit test * Fixed property e2e * Updated calendar selector * [ACS-7768] unify inputs and selects across the app (#9687) * Changed ng version before material migration * migration for material' * Fixed most of unit tests failing * [affected:*][ci:force] Fixing rebase * [affected:*][ci:force] attempt to fix mat-selectors importing * [affected:*][ci:force] Fixing the styles - check * AAE-21392 Fix dropdown form widget style (#9605) * ACS-7768 Applied new styles for inputs * ACS-7768 Align icon * ACS-7768 Input colors based on input state * ACS-7768 Corrected spaces * ACS-7768 Styles for selectboxes * ACS-7768 Fixed label jumping on hovering * ACS-7768 Style inputs for add permission panel, user role column and comments, styles for inputs without label * ACS-7768 Style inputs in search filters * ACS-7768 Set appearance for inputs globally to outline * ACS-7768 Style inputs for share dialog and login page * ACS-7768 Style inputs in properties panel * ACS-7768 Fixed white background when disabled field * ACS-7768 Moved setting outline appearance for inputs to ACA, fix issue for inputs in permission container * Revert "[affected:*][ci:force] Fixing the styles - check" This reverts commit 80d971f7abbaf3fdd66f6731e6a84ffe23900c56. * Revert "[affected:*][ci:force] attempt to fix mat-selectors importing" This reverts commit 821d9e1864b48bb2723b51347e133346cc311e5d. * Revert "[affected:*][ci:force] Fixing rebase" This reverts commit 378c6c2000fe1319b2043ca3e4652e12737e30d8. * Revert "Fixed most of unit tests failing" This reverts commit 44948e0a2888f3f62c93d5ee439eeccf849cf9b2. * ACS-7768 Reverted unwanted changes --------- Co-authored-by: Vito Albano <vito.albano@hyland.com> Co-authored-by: Diogo Bastos <50139916+DiogoABastos@users.noreply.github.com> * [ACS-7768] unify inputs and selects across the app - revert (#9699) * Revert "[ACS-7768] unify inputs and selects across the app (#9687)" This reverts commit 7cfb5ea64a0bd3b9d462b4bd18c57abd0251d9df. * ACS-7768 Little correction * [ACS-7998] - Add permissions input (#9704) * [ACS-8004] Fix inputs for move folder (#9707) * [ACS-7999] Fix inputs for edit and create folder (#9713) * ACS-7999 Fix inputs for edit and create folder * ACS-7999 Fix jumping dialog when focus field * [ACS-7982] ACC - fix categories tree (#9715) * Fixed after rebase * Fixed package-lock * Fixed after rebase * Fixed unit test for process * AAE-22783 Fix form elements label style (#9725) * [ACS-8021] Inputs for comments (#9722) * [ACS-8008] - Inputs for properties panel "General info" (#9744) * [ACS-8052] Inputs for general info for libraries (#9745) * [ACS-7983] Fixed security controls dialog (#9747) * [ACS-8026] Fixed task form rendering (#9742) * [ACS-8026] Fixed Task form rendering * [ACS-8026] Fixed task form rendering * [ACS-8042] Fixed styles for inputs in library creation (#9751) * Added missing import for uppercase pipe (#9748) * Recreated package-lock * Fixed package and e2e with tabs that now are capital letters? * Fixed package json * Removed wrong version on core package * Ehi Js-Api should be 7.8 NOT 7.9 * These dependencies will kill me * [ACS-7981] UI fixes for create categories dialog (#9754) * [ACS-7981] Fixed UI for create categories dialog * [ACS-7981] Adding mat selectors for create categories dialog * [ACS-7981] Create category dialog no longer allows ability to add existing categories * [ACS-7974] Adding material selectors for assign security marks dialog (#9755) * [ACS-7974] Fixed UI for assign security controls to user dialog * [ACS-7974] Removing unneeded mat selector * [ACS-8069] Updated error-content.component.html to be aligned with the new mat typography classes in angular material v15 (#9762) * Added missing mat selector for mat-list-item-disabled (#9763) * Fixed process unit test after huge rebase * [ACS-8066] Style inputs for link rule dialog (#9773) * Insight material module has been removed * [ACS-7973] [ACC] header layout (#9782) * [ACS-8096] Print button in the viewer does not open the print window (#9776) (#9778) * [ACS-8066] Fixed unit tests (#9783) * [ACS-8092] [ACA] testing angular 15 notifications bell is much smaller and is further from the profile page 2 (#9786) * AAE 22837 Move confirm to core (#9750) * confirm dialog is used in many places and should be part of the core * fix * Update confirm.dialog.spec.ts * Update public-api.ts * Fixed imports for confirm dialog unit tests * Fixed linting for packages * Removed -mdc as it's wrong for mat calendar * [ACS-8098] [ACA] Testing Angular 15 - Move Popup placeholder missing (#9796) * [ACS-7944] [ADW] Start process page (#9802) * [ACS-8157] Used mat chip set instead of mat chip listbox for dynamic chip list to hide tick icon for chips (#9803) * Fixed issue on focus mat calendar * [ACS-7980] fix style (#9798) * [ACS-7979] Fixed UI for create tags dialog (#9793) * [ACS-7979] Fixed UI for create tags dialog. Minor UI fixes of create categories dialog as well * [ACS-7979] Fixed unit tests * [ACS-7979] Replaced dependency of CoreModule from tag.module.ts with TranslateModule and DynamicChipListModule * [ACS-8158] Fixed spacing of tags in ACA (#9808) * [ACS-8158] Fixed spacing of tags in ACA * [ACS-8158] Fixed unit tests * AAE-22965 fix datepicker focused element selector (#9814) * [ACS-8212] Fixed alignment issue of filters button in sidenav (#9828) * [ACS-8191] Added missing mat selectors for ACA. Updated mat selector name (#9809) * [ACS-8191] Updated mat selector names * [ACS-8191] Added missing mat selectors for ACA. Updated mat-selector names * [ACS-8196] fix style for pagination (#9810) * Removing implicitFlow in favor of codeFlow * [ACS-8230] Fixed UI for snackbars with long text content and action buttons (#9830) * [ACS-8231] [ADW] Processes button styling on hover- edit summary (#9833) [ADW] Processes button styling on hover * Revert "Removing implicitFlow in favor of codeFlow" This reverts commit 58951a77b859eab4f01ae44a27c2d6505fcd66b2. * Fixed unit test after rebase * Fixing unit test * Disabled failing unit from content * AAE-23287 migrate to storybook 8 (#9867) * Fixed core unit test and excluded instable ones * AAE-23287 migrate to storybook 8 --------- Co-authored-by: Vito Albano <vito.albano@hyland.com> * Fixed unit and lint * Fixing unit test and lint issues after merging with storybook latest * Storybook still not working though * Fixed missing locator for content e2e * fix storybook exceeding timeout * Fixed wrong package version * AAE-23478 replace nav-list with action-list (#9875) * [ACS-8272] [ADW] Testing Angular 15 - Misplaced buttons Cancel and Start process (#9869) * [ACS-8273] [ADW] Testing Angular 15 - Process' tab names are uppercased (#9870) * [ACS-8274] angular 15 description field in info drawer is truncated and scrollable (#9878) * [ACS-8275] - [ACA] Testing Angular 15 - Tags are not displayed correctly (#9872) * Fixing e2e tab label * AAE-22858 Fix date button style (#9892) * AAE-23556 Fix search text input component styles (#9895) * Fixing unit test an builds * Fixing style * [ACS-8260] add user dialog misplaced search icon and space issue (#9897) * [ACS-8275] [ACA] Angular 15 tags are not displayed correctly (#9896) * [ACS-8322] Testing Angular 15 - Info Drawer - General info - Missing … (#9901) * [ACS-8322] Testing Angular 15 - Info Drawer - General info - Missing arrow in Content type selector * [ACS-8322] Testing Angular 15 - Info Drawer - General info - Missing arrow in Content type selector * [AAE-23622] fixed buttons and chips (#9913) * Aae 23572 recreate js api lib into a proper nx workspace lib bis (#9917) * back to mocha, working in future node versions * update package-lock * change bundle to build * update node to 18.20.3 [ci:force] * fix e2es [ci:force] * bring bundle back to fix e2e [ci:force] * patch in legacy builds * Updated package-lock * Updated executor to new @nx * Revert "Updated executor to new @nx" This reverts commit a520ba3595bb8deb1f5727e6abfd5a75bd4c83a1. * Improved ts config reverted changes on @nrwl --------- Co-authored-by: Wojciech Duda <69160975+wojd0@users.noreply.github.com> * Fixing target name for publishing js-api as it's not happening anymore * fixed js-api publish command * JS-api wasn't building correctly on publish * Fixed naming for tests tab * Fixed tabs name missed * AAE-23704 Fixed outcome buttons text alignment (#9933) * Thanks tooltip change * Removing FIT :O * Fixing build broken * [ACS-8275] Testing Angular 15 - Tags are not displayed correctly (#9940) * [ACS-8253] viewer file name change position on navigation (#9900) * AAE-23783 Fixed feature flags dialog styles (#9945) * Added styles include path to feature flags lib * Fixed js-api version --------- Co-authored-by: Wojciech Duda <69160975+wojd0@users.noreply.github.com> Co-authored-by: Amedeo Lepore <amedeo.lepore85@gmail.com> Co-authored-by: Amedeo Lepore <amedeo.lepore@hyland.com> Co-authored-by: jacekpluta <73617938+jacekpluta@users.noreply.github.com> Co-authored-by: Mykyta Maliarchuk <maliarchuk99@gmail.com> Co-authored-by: tomson <tomasz.nastaly@hyland.com> Co-authored-by: DominikIwanek <dominik.iwanek@hyland.com> Co-authored-by: Jacek Pluta <jacek.pluta@hyland.com> Co-authored-by: dominikiwanekhyland <141320833+dominikiwanekhyland@users.noreply.github.com> Co-authored-by: Diogo Bastos <50139916+DiogoABastos@users.noreply.github.com> Co-authored-by: Mykyta Maliarchuk <84377976+nikita-web-ua@users.noreply.github.com> Co-authored-by: AleksanderSklorz <115619721+AleksanderSklorz@users.noreply.github.com> Co-authored-by: Ehsan Rezaei <ehsan.rezaei@hyland.com> Co-authored-by: swapnil-verma-gl <92505353+swapnil-verma-gl@users.noreply.github.com> Co-authored-by: Eugenio Romano <eromano@users.noreply.github.com> Co-authored-by: tamaragruszka <156320606+tamaragruszka@users.noreply.github.com> Co-authored-by: tomasz hanaj <12088991+tomaszhanaj@users.noreply.github.com>
404 lines
16 KiB
TypeScript
404 lines
16 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
*
|
|
* 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 { BrowserActions, BrowserVisibility, DropdownPage, TabsPage, materialLocators } from '@alfresco/adf-testing';
|
|
import { browser, by, element, Key, $, $$ } from 'protractor';
|
|
|
|
export class TaskDetailsPage {
|
|
formContent = $('adf-form');
|
|
formNameField = $('[data-automation-id="card-textitem-value-formName"]');
|
|
formNameButton = $('[data-automation-id="card-textitem-toggle-formName"]');
|
|
assigneeField = $('[data-automation-id="card-textitem-value-assignee"]');
|
|
assigneeButton = $('[data-automation-id="card-textitem-toggle-assignee"]');
|
|
statusField = $('[data-automation-id="card-textitem-value-status"]');
|
|
categoryField = $('[data-automation-id="card-textitem-value-category"] ');
|
|
parentNameField = $('span[data-automation-id*="parentName"] span');
|
|
parentTaskIdField = $('[data-automation-id="card-textitem-value-parentTaskId"] ');
|
|
durationField = $('[data-automation-id="card-textitem-value-duration"] ');
|
|
endDateField = $$('span[data-automation-id*="endDate"] span').first();
|
|
createdField = $('span[data-automation-id="card-dateitem-created"]');
|
|
idField = $$('[data-automation-id="card-textitem-value-id"]').first();
|
|
descriptionField = $('[data-automation-id="card-textitem-value-description"]');
|
|
dueDateField = $$('span[data-automation-id*="dueDate"] span').first();
|
|
activitiesTitle = $('div[class*="adf-info-drawer-layout-header-title"] div');
|
|
commentField = $('#comment-input');
|
|
addCommentButton = $('[data-automation-id="comments-input-add"]');
|
|
involvePeopleButton = $('div[class*="add-people"]');
|
|
addPeopleField = $('input[data-automation-id="adf-people-search-input"]');
|
|
addInvolvedUserButton = $('button[id="add-people"]');
|
|
taskDetailsSection = $('div[data-automation-id="app-tasks-details"]');
|
|
taskDetailsEmptySection = $('div[data-automation-id="adf-tasks-details--empty"]');
|
|
completeTask = $('button[id="adf-no-form-complete-button"]');
|
|
completeFormTask = $('button[id="adf-form-complete"]');
|
|
taskDetailsTitle = $('.adf-activiti-task-details__header span');
|
|
auditLogButton = $('button[adf-task-audit]');
|
|
noPeopleInvolved = $('#no-people-label');
|
|
cancelInvolvePeopleButton = $('#close-people-search');
|
|
involvePeopleHeader = $('.adf-search-text-header');
|
|
removeInvolvedPeople = $('button[data-automation-id="Remove"]');
|
|
peopleTitle = $('#people-title');
|
|
noFormMessage = $('span[id*="no-form-message"]');
|
|
attachFormButton = $('#adf-no-form-attach-form-button');
|
|
removeAttachForm = $('#adf-attach-form-remove-button');
|
|
emptyTaskDetails = $('adf-task-details > div > div');
|
|
priority = $('[data-automation-id*="card-textitem-value-priority"]');
|
|
editableAssignee = $('[data-automation-id="card-textitem-value-assignee"][class*="clickable"]');
|
|
claimElement = $('[data-automation-id="header-claim-button"]');
|
|
releaseElement = $('[data-automation-id="header-unclaim-button"]');
|
|
saveFormButton = $('button[id="adf-form-save"]');
|
|
|
|
attachFormDropdown = new DropdownPage($('.adf-attach-form-row'));
|
|
|
|
async checkEditableAssigneeIsNotDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(this.editableAssignee);
|
|
}
|
|
|
|
async checkEditableFormIsNotDisplayed(): Promise<void> {
|
|
const editableForm = $('[data-automation-id="card-textitem-value-formName"][class*="clickable"]');
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(editableForm);
|
|
}
|
|
|
|
async checkDueDatePickerButtonIsNotDisplayed(): Promise<void> {
|
|
const dueDatePickerButton = $('[data-automation-id="datepickertoggle-dueDate"]');
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(dueDatePickerButton);
|
|
}
|
|
|
|
getTaskDetailsTitle(): Promise<string> {
|
|
return BrowserActions.getText(this.taskDetailsTitle);
|
|
}
|
|
|
|
async checkSelectedForm(formName: string): Promise<void> {
|
|
await this.attachFormDropdown.checkOptionIsSelected(formName);
|
|
}
|
|
|
|
async checkAttachFormButtonIsEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsClickable(this.attachFormButton);
|
|
}
|
|
|
|
async noFormIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(this.formContent);
|
|
}
|
|
|
|
async checkRemoveAttachFormIsDisplayed() {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.removeAttachForm);
|
|
}
|
|
|
|
async clickRemoveAttachForm(): Promise<void> {
|
|
await BrowserActions.click(this.removeAttachForm);
|
|
await browser.sleep(2000);
|
|
}
|
|
|
|
async checkAttachFormButtonIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.attachFormButton);
|
|
}
|
|
|
|
async checkAttachFormButtonIsNotDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(this.attachFormButton);
|
|
}
|
|
|
|
async clickAttachFormButton(): Promise<void> {
|
|
return BrowserActions.click(this.attachFormButton);
|
|
}
|
|
|
|
async checkFormIsAttached(formName: string): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementHasValue(this.formNameField, formName);
|
|
}
|
|
|
|
async waitFormNameEqual(formName: string): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementHasValue(this.formNameField, formName);
|
|
}
|
|
|
|
async clickForm(): Promise<void> {
|
|
await BrowserActions.closeMenuAndDialogs();
|
|
await BrowserActions.click(this.formNameButton);
|
|
}
|
|
|
|
async checkStandaloneNoFormMessageIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.noFormMessage);
|
|
}
|
|
|
|
async getNoFormMessage(): Promise<string> {
|
|
return BrowserActions.getText(this.noFormMessage);
|
|
}
|
|
|
|
getAssignee(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.assigneeField);
|
|
}
|
|
|
|
isAssigneeClickable(): Promise<string> {
|
|
return BrowserVisibility.waitUntilElementIsVisible(this.editableAssignee);
|
|
}
|
|
|
|
getStatus(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.statusField);
|
|
}
|
|
|
|
getCategory(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.categoryField);
|
|
}
|
|
|
|
getParentName(): Promise<string> {
|
|
return BrowserActions.getText(this.parentNameField);
|
|
}
|
|
|
|
getParentTaskId(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.parentTaskIdField);
|
|
}
|
|
|
|
getDuration(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.durationField);
|
|
}
|
|
|
|
getEndDate(): Promise<string> {
|
|
return BrowserActions.getText(this.endDateField);
|
|
}
|
|
|
|
getCreated(): Promise<string> {
|
|
return BrowserActions.getText(this.createdField);
|
|
}
|
|
|
|
getId(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.idField);
|
|
}
|
|
|
|
getDescription(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.descriptionField);
|
|
}
|
|
|
|
async getDescriptionPlaceholder(): Promise<string> {
|
|
return BrowserActions.getAttribute(this.descriptionField, 'placeholder');
|
|
}
|
|
|
|
getDueDate(): Promise<string> {
|
|
return BrowserActions.getText(this.dueDateField);
|
|
}
|
|
|
|
getPriority(): Promise<string> {
|
|
return BrowserActions.getInputValue(this.priority);
|
|
}
|
|
|
|
async updatePriority(priority?: string): Promise<void> {
|
|
await BrowserActions.click(this.priority);
|
|
await BrowserActions.clearWithBackSpace(this.priority);
|
|
await BrowserActions.clearSendKeys($('input[data-automation-id="card-textitem-value-priority"]'), priority, 500);
|
|
await this.priority.sendKeys(Key.TAB);
|
|
await browser.sleep(1000);
|
|
}
|
|
|
|
async updateDueDate(): Promise<void> {
|
|
await BrowserActions.click(this.dueDateField);
|
|
await BrowserActions.click($$(materialLocators.DatetimePicker.calendar.body.cell.class).first());
|
|
await browser.sleep(1000);
|
|
}
|
|
|
|
async updateDescription(description?: string): Promise<void> {
|
|
await BrowserActions.click(this.descriptionField);
|
|
await BrowserActions.clearWithBackSpace(this.descriptionField);
|
|
await BrowserActions.clearSendKeys($('[data-automation-id="card-textitem-value-description"]'), description ? description : '');
|
|
await this.descriptionField.sendKeys(Key.TAB);
|
|
await browser.sleep(1000);
|
|
}
|
|
|
|
async updateAssignee(fullName: string): Promise<void> {
|
|
await BrowserActions.click(this.assigneeButton);
|
|
await BrowserActions.clearSendKeys($('[id="userSearchText"]'), fullName);
|
|
await BrowserActions.click(element(by.cssContainingText('.adf-people-full-name', fullName)));
|
|
await BrowserVisibility.waitUntilElementIsVisible($(`adf-datatable-row[class*='is-selected']`));
|
|
|
|
await browser.sleep(2000);
|
|
await BrowserActions.click($('button[id="add-people"]'));
|
|
}
|
|
|
|
getTitle(): Promise<string> {
|
|
return BrowserActions.getText(this.activitiesTitle);
|
|
}
|
|
|
|
async selectActivityTab(): Promise<void> {
|
|
const tabsPage: TabsPage = new TabsPage();
|
|
await tabsPage.clickTabByTitle('Activity');
|
|
}
|
|
|
|
async selectDetailsTab(): Promise<void> {
|
|
const tabsPage: TabsPage = new TabsPage();
|
|
await tabsPage.clickTabByTitle('Details');
|
|
}
|
|
|
|
async addComment(comment: string): Promise<void> {
|
|
await BrowserActions.clearSendKeys(this.commentField, comment);
|
|
await BrowserActions.click(this.addCommentButton);
|
|
}
|
|
|
|
async checkCommentIsDisplayed(comment: string): Promise<void> {
|
|
const row = element(by.cssContainingText('div.adf-comment-message', comment));
|
|
await BrowserVisibility.waitUntilElementIsVisible(row);
|
|
}
|
|
|
|
async checkIsEmptyCommentListDisplayed(): Promise<void> {
|
|
const emptyList = element(by.cssContainingText('div[id="comment-header"]', '(0)'));
|
|
await BrowserVisibility.waitUntilElementIsVisible(emptyList);
|
|
}
|
|
|
|
async clickInvolvePeopleButton(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.involvePeopleButton);
|
|
await BrowserVisibility.waitUntilElementIsClickable(this.involvePeopleButton);
|
|
await browser.actions().mouseMove(this.involvePeopleButton).perform();
|
|
await BrowserActions.click(this.involvePeopleButton);
|
|
}
|
|
|
|
async typeUser(user: string): Promise<void> {
|
|
await BrowserActions.clearSendKeys(this.addPeopleField, user);
|
|
}
|
|
|
|
async selectUserToInvolve(user: string): Promise<void> {
|
|
const row = this.getRowsUser(user);
|
|
await BrowserActions.click(row);
|
|
}
|
|
|
|
async checkUserIsSelected(user: string): Promise<void> {
|
|
const row = this.getRowsUser(user);
|
|
await BrowserVisibility.waitUntilElementIsVisible(row);
|
|
await browser.sleep(2000);
|
|
}
|
|
|
|
async clickAddInvolvedUserButton(): Promise<void> {
|
|
await BrowserActions.click(this.addInvolvedUserButton);
|
|
}
|
|
|
|
getRowsUser(user: string) {
|
|
return $(`div[data-automation-id="adf-people-full-name-${user.replace(' ', '-')}"]`);
|
|
}
|
|
|
|
async removeInvolvedUser(user: string): Promise<void> {
|
|
const row = this.getRowsUser(user).element(by.xpath('ancestor::adf-datatable-row[contains(@class, "adf-datatable-row")]'));
|
|
await BrowserActions.click(row.$('button[data-automation-id="action_menu_0"]'));
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.removeInvolvedPeople);
|
|
await BrowserActions.click(this.removeInvolvedPeople);
|
|
}
|
|
|
|
async getInvolvedUserEmail(user: string): Promise<string> {
|
|
return BrowserActions.getText($(`div[data-automation-id="adf-people-email-${user.replace(' ', '-')}"]`));
|
|
}
|
|
|
|
async clickAuditLogButton(): Promise<void> {
|
|
await BrowserActions.click(this.auditLogButton);
|
|
}
|
|
|
|
async checkNoPeopleIsInvolved(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.noPeopleInvolved);
|
|
}
|
|
|
|
async clickCancelInvolvePeopleButton(): Promise<void> {
|
|
await BrowserActions.click(this.cancelInvolvePeopleButton);
|
|
}
|
|
|
|
getInvolvePeopleHeader(): Promise<string> {
|
|
return BrowserActions.getText(this.involvePeopleHeader);
|
|
}
|
|
|
|
async getInvolvePeoplePlaceholder(): Promise<string> {
|
|
return BrowserActions.getAttribute(this.addPeopleField, 'placeholder');
|
|
}
|
|
|
|
async checkCancelButtonIsEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.cancelInvolvePeopleButton);
|
|
await BrowserVisibility.waitUntilElementIsClickable(this.cancelInvolvePeopleButton);
|
|
}
|
|
|
|
async checkAddPeopleButtonIsEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.addInvolvedUserButton);
|
|
await BrowserVisibility.waitUntilElementIsClickable(this.addInvolvedUserButton);
|
|
}
|
|
|
|
async noUserIsDisplayedInSearchInvolvePeople(user): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsNotVisible(element(by.cssContainingText('div[class*="people-full-name"]', user)));
|
|
}
|
|
|
|
getInvolvedPeopleTitle(): Promise<string> {
|
|
return BrowserActions.getText(this.peopleTitle);
|
|
}
|
|
|
|
checkTaskDetailsEmpty(): Promise<string> {
|
|
return BrowserActions.getText(this.taskDetailsEmptySection);
|
|
}
|
|
|
|
async checkTaskDetailsDisplayed(): Promise<string> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.taskDetailsSection);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.formNameField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.assigneeField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.statusField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.categoryField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.parentNameField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.createdField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.idField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.descriptionField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.dueDateField);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.priority);
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.activitiesTitle);
|
|
|
|
return BrowserActions.getText(this.taskDetailsSection);
|
|
}
|
|
|
|
async clickCompleteTask(): Promise<void> {
|
|
await BrowserActions.click(this.completeTask);
|
|
}
|
|
|
|
async checkCompleteFormButtonIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.completeFormTask);
|
|
}
|
|
|
|
async checkCompleteTaskButtonIsEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsClickable(this.completeTask);
|
|
}
|
|
|
|
async checkCompleteTaskButtonIsDisplayed(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.completeTask);
|
|
}
|
|
|
|
async clickCompleteFormTask(): Promise<void> {
|
|
await BrowserActions.click(this.completeFormTask);
|
|
}
|
|
|
|
async getEmptyTaskDetailsMessage(): Promise<string> {
|
|
return BrowserActions.getText(this.emptyTaskDetails);
|
|
}
|
|
|
|
async isCompleteButtonWithFormEnabled(): Promise<boolean> {
|
|
return this.completeFormTask.isEnabled();
|
|
}
|
|
|
|
async checkClaimEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsPresent(this.claimElement);
|
|
}
|
|
|
|
async checkReleaseEnabled(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsPresent(this.releaseElement);
|
|
}
|
|
|
|
async claimTask(): Promise<void> {
|
|
await BrowserActions.click(this.claimElement);
|
|
}
|
|
|
|
async releaseTask(): Promise<void> {
|
|
await BrowserActions.click(this.releaseElement);
|
|
}
|
|
|
|
async saveTaskForm(): Promise<void> {
|
|
await BrowserVisibility.waitUntilElementIsVisible(this.saveFormButton);
|
|
await BrowserActions.click(this.saveFormButton);
|
|
}
|
|
}
|