mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
[ADF-3723]Add visibility conditions on tabs - form rendering component tests (#5022)
* Add visibility conditions on tabs - form rendering component tests * no message * Moved the suite to process-services-cloud folder * no message
This commit is contained in:
parent
505e8204e2
commit
31bec59a16
@ -0,0 +1,215 @@
|
|||||||
|
/*!
|
||||||
|
* @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 { LoginSSOPage, SettingsPage, Widget } from '@alfresco/adf-testing';
|
||||||
|
import { browser } from 'protractor';
|
||||||
|
|
||||||
|
import { AlfrescoApiCompatibility as AlfrescoApi } from '@alfresco/js-api';
|
||||||
|
import { NavigationBarPage } from '../../pages/adf/navigationBarPage';
|
||||||
|
import { FormCloudDemoPage } from '../../pages/adf/demo-shell/process-services-cloud/cloudFormDemoPage';
|
||||||
|
import { tabFieldValueVisibilityJson, tabVarValueVisibilityJson, tabVarFieldVisibilityJson,
|
||||||
|
tabFieldFieldVisibilityJson, tabFieldVarVisibilityJson, tabVarVarVisibilityJson,
|
||||||
|
tabNextOperatorsVisibilityJson } from '../../resources/forms/tab-visibility-conditions';
|
||||||
|
|
||||||
|
describe('Visibility conditions on tabs - cloud', () => {
|
||||||
|
|
||||||
|
const settingsPage = new SettingsPage();
|
||||||
|
const loginSSOPage = new LoginSSOPage();
|
||||||
|
|
||||||
|
const navigationBarPage = new NavigationBarPage();
|
||||||
|
const formCloudDemoPage = new FormCloudDemoPage();
|
||||||
|
const widget = new Widget();
|
||||||
|
|
||||||
|
const widgets = {
|
||||||
|
textOneId: 'TextOne',
|
||||||
|
textTwoId: 'TextTwo',
|
||||||
|
textThreeId: 'TextThree'
|
||||||
|
};
|
||||||
|
|
||||||
|
const value = {
|
||||||
|
displayTab: 'showTab',
|
||||||
|
notDisplayTab: 'anythingElse'
|
||||||
|
};
|
||||||
|
|
||||||
|
const tab = {
|
||||||
|
tabWithFields: 'tabWithFields',
|
||||||
|
tabFieldValue: 'tabBasicFieldValue',
|
||||||
|
tabVarValue: 'tabBasicVarValue',
|
||||||
|
tabVarField: 'tabBasicVarField',
|
||||||
|
tabFieldField: 'tabBasicFieldField',
|
||||||
|
tabVarVar: 'tabBasicVarVar',
|
||||||
|
tabNextOperators: 'tabNextOperators'
|
||||||
|
};
|
||||||
|
|
||||||
|
beforeAll(async () => {
|
||||||
|
this.alfrescoJsApi = new AlfrescoApi({
|
||||||
|
provider: 'BPM',
|
||||||
|
hostBpm: browser.params.testConfig.adf_aps.host
|
||||||
|
});
|
||||||
|
|
||||||
|
await settingsPage.setProviderBpmSso(
|
||||||
|
browser.params.config.bpmHost,
|
||||||
|
browser.params.config.oauth2.host,
|
||||||
|
browser.params.config.identityHost);
|
||||||
|
await loginSSOPage.loginSSOIdentityService(browser.params.testConfig.adf.adminEmail, browser.params.testConfig.adf.adminPassword);
|
||||||
|
|
||||||
|
await navigationBarPage.navigateToFormCloudPage();
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C309647] Should be able to see tab when visibility condition refers to a field with specific value', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabFieldValueVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabFieldValue);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabFieldValue);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabFieldValue);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabFieldValue);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315148] Should be able to see tab when visibility condition refers to a variable with specific value', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabVarValueVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabVarValue);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
const visibleTab = tabVarValueVisibilityJson;
|
||||||
|
visibleTab.formRepresentation.formDefinition.variables[0].value = value.notDisplayTab;
|
||||||
|
await formCloudDemoPage.setConfigToEditor(visibleTab);
|
||||||
|
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarValue);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315149] Should be able to see tab when visibility condition refers to a form variable and a field', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabVarFieldVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabVarField);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315150] Should be able to see tab when visibility condition refers to a field and another field', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabFieldFieldVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabFieldField);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textThreeId);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabFieldField);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textThreeId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabFieldField);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabFieldField);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315151] Should be able to see tab when visibility condition refers to a field and form variable', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabFieldVarVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabVarField);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarField);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315152] Should be able to see tab when visibility condition refers to form variable and another form variable', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabVarVarVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabVarVar);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
|
||||||
|
const visibleTab = tabVarVarVisibilityJson;
|
||||||
|
visibleTab.formRepresentation.formDefinition.variables[0].value = value.notDisplayTab;
|
||||||
|
await formCloudDemoPage.setConfigToEditor(visibleTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarVar);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textOneId);
|
||||||
|
|
||||||
|
visibleTab.formRepresentation.formDefinition.variables[1].value = value.notDisplayTab;
|
||||||
|
await formCloudDemoPage.setConfigToEditor(visibleTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabVarVar);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
|
||||||
|
visibleTab.formRepresentation.formDefinition.variables[0].value = value.displayTab;
|
||||||
|
await formCloudDemoPage.setConfigToEditor(visibleTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabVarVar);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textOneId);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('[C315153] Should be able to see tab when has multiple visibility conditions and next condition operators', async () => {
|
||||||
|
await formCloudDemoPage.setConfigToEditor(tabNextOperatorsVisibilityJson);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabWithFields);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textOneId);
|
||||||
|
await widget.textWidget().isWidgetVisible(widgets.textThreeId);
|
||||||
|
await widget.textWidget().isWidgetNotVisible(widgets.textTwoId);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
|
||||||
|
await widget.tab().clickTabByLabel(tab.tabWithFields);
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textThreeId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textOneId, value.displayTab);
|
||||||
|
await widget.tab().checkTabIsNotDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
|
||||||
|
await widget.textWidget().setValue(widgets.textThreeId, value.notDisplayTab);
|
||||||
|
await widget.tab().checkTabIsDisplayedByLabel(tab.tabNextOperators);
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
673
e2e/resources/forms/tab-visibility-conditions.ts
Normal file
673
e2e/resources/forms/tab-visibility-conditions.ts
Normal file
@ -0,0 +1,673 @@
|
|||||||
|
/*!
|
||||||
|
* @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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* tslint:disable */
|
||||||
|
export const tabFieldValueVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabBasicFieldValue',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'field',
|
||||||
|
leftValue: 'TextOne',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'showTab',
|
||||||
|
rightType: 'value',
|
||||||
|
nextConditionOperator: '',
|
||||||
|
nextCondition: null
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
title: 'tabWithFields',
|
||||||
|
visibilityCondition: null
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'df452297-d0e8-4406-b9d3-10842033549d',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabVarValueVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabBasicVarValue',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'variable',
|
||||||
|
leftValue: 'stringVar',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'showTab',
|
||||||
|
rightType: 'value',
|
||||||
|
nextConditionOperator: ''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: [
|
||||||
|
{
|
||||||
|
id: "803269e6-a568-40e2-aec3-75ad2f411688",
|
||||||
|
name: "stringVar",
|
||||||
|
type: "string",
|
||||||
|
value: "showTab"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabVarFieldVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabBasicVarField',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'variable',
|
||||||
|
leftValue: 'stringVar',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'TextOne',
|
||||||
|
rightType: 'field',
|
||||||
|
nextConditionOperator: ''
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '0e538a28-f8d6-4cb8-ae93-dbfb2efdf3b1',
|
||||||
|
title: 'tabWithFields',
|
||||||
|
visibilityCondition: null
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '1308e433-08ce-4448-a62a-0accc1187d15',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '0e538a28-f8d6-4cb8-ae93-dbfb2efdf3b1',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: [
|
||||||
|
{
|
||||||
|
id: "803269e6-a568-40e2-aec3-75ad2f411688",
|
||||||
|
name: "stringVar",
|
||||||
|
type: "string",
|
||||||
|
value: "showTab"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabFieldFieldVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabBasicFieldField',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'field',
|
||||||
|
leftValue: 'TextThree',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'TextOne',
|
||||||
|
rightType: 'field',
|
||||||
|
nextConditionOperator: ''
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
title: 'tabWithFields',
|
||||||
|
visibilityCondition: null
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'df452297-d0e8-4406-b9d3-10842033549d',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: [
|
||||||
|
{
|
||||||
|
id: 'TextThree',
|
||||||
|
name: 'TextThree',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabFieldVarVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabBasicVarField',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'field',
|
||||||
|
leftValue: 'TextOne',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'stringVar',
|
||||||
|
rightType: 'variable',
|
||||||
|
nextConditionOperator: ''
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '0e538a28-f8d6-4cb8-ae93-dbfb2efdf3b1',
|
||||||
|
title: 'tabWithFields',
|
||||||
|
visibilityCondition: null
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '1308e433-08ce-4448-a62a-0accc1187d15',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '0e538a28-f8d6-4cb8-ae93-dbfb2efdf3b1',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: [
|
||||||
|
{
|
||||||
|
id: "803269e6-a568-40e2-aec3-75ad2f411688",
|
||||||
|
name: "stringVar",
|
||||||
|
type: "string",
|
||||||
|
value: "showTab"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabVarVarVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: 'ef512cb3-0c41-4d12-84ef-a7ef8f0b111a',
|
||||||
|
title: 'tabBasicVarVar',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'variable',
|
||||||
|
leftValue: 'showTabOne',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'showTabTwo',
|
||||||
|
rightType: 'variable',
|
||||||
|
nextConditionOperator: ''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: '6eeb9e54-e51d-44f3-9557-503308f07361',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: 'ef512cb3-0c41-4d12-84ef-a7ef8f0b111a',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: [
|
||||||
|
{
|
||||||
|
id: "b116df99-f6b5-45f8-b48c-15b74f7f1c92",
|
||||||
|
name: "showTabOne",
|
||||||
|
type: "string",
|
||||||
|
value: "showTab"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: "6e3e88ab-848c-4f48-8326-a404d1427f60",
|
||||||
|
name: "showTabTwo",
|
||||||
|
type: "string",
|
||||||
|
value: "showTab"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export const tabNextOperatorsVisibilityJson = {
|
||||||
|
formRepresentation: {
|
||||||
|
id: 'form-3aff57d3-62af-4adf-9b14-1d8f44a28077',
|
||||||
|
name: 'tabvisibility',
|
||||||
|
description: '',
|
||||||
|
version: 0,
|
||||||
|
standAlone: true,
|
||||||
|
formDefinition: {
|
||||||
|
tabs: [
|
||||||
|
{
|
||||||
|
id: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
title: 'tabNextOperators',
|
||||||
|
visibilityCondition: {
|
||||||
|
leftType: 'field',
|
||||||
|
leftValue: 'TextOne',
|
||||||
|
operator: '==',
|
||||||
|
rightValue: 'showTab',
|
||||||
|
rightType: 'value',
|
||||||
|
nextConditionOperator: 'and',
|
||||||
|
nextCondition: {
|
||||||
|
leftType: 'field',
|
||||||
|
leftValue: 'TextThree',
|
||||||
|
operator: '!=',
|
||||||
|
rightValue: 'showTab',
|
||||||
|
rightType: 'value',
|
||||||
|
nextConditionOperator: '',
|
||||||
|
nextCondition: null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
title: 'tabWithFields',
|
||||||
|
visibilityCondition: null
|
||||||
|
}
|
||||||
|
],
|
||||||
|
fields: [
|
||||||
|
{
|
||||||
|
id: 'dcde7e13-2444-48bc-ab30-32902cea549e',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '71da814d-5580-4f1f-972a-8089253aeded',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextTwo',
|
||||||
|
name: 'TextTwo',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: []
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'df452297-d0e8-4406-b9d3-10842033549d',
|
||||||
|
name: 'Label',
|
||||||
|
type: 'container',
|
||||||
|
tab: '442eea0b-65f9-484e-b37f-f5a91d5e1f21',
|
||||||
|
numberOfColumns: 2,
|
||||||
|
fields: {
|
||||||
|
1: [
|
||||||
|
{
|
||||||
|
id: 'TextOne',
|
||||||
|
name: 'TextOne',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
2: [
|
||||||
|
{
|
||||||
|
id: 'TextThree',
|
||||||
|
name: 'TextThree',
|
||||||
|
type: 'text',
|
||||||
|
required: false,
|
||||||
|
colspan: 1,
|
||||||
|
placeholder: null,
|
||||||
|
minLength: 0,
|
||||||
|
maxLength: 0,
|
||||||
|
regexPattern: null,
|
||||||
|
visibilityCondition: null,
|
||||||
|
params: {
|
||||||
|
existingColspan: 1,
|
||||||
|
maxColspan: 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
outcomes: [],
|
||||||
|
metadata: {},
|
||||||
|
variables: []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
@ -44,6 +44,11 @@ export class FormFields {
|
|||||||
await BrowserVisibility.waitUntilElementIsVisible(fieldElement);
|
await BrowserVisibility.waitUntilElementIsVisible(fieldElement);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async checkWidgetIsClickable(fieldId): Promise<void> {
|
||||||
|
const fieldElement = element.all(by.css(`adf-form-field div[id='field-${fieldId}-container']`)).first();
|
||||||
|
await BrowserVisibility.waitUntilElementIsClickable(fieldElement);
|
||||||
|
}
|
||||||
|
|
||||||
async checkWidgetIsHidden(fieldId): Promise<void> {
|
async checkWidgetIsHidden(fieldId): Promise<void> {
|
||||||
const hiddenElement = element(by.css(`adf-form-field div[id='field-${fieldId}-container'][hidden]`));
|
const hiddenElement = element(by.css(`adf-form-field div[id='field-${fieldId}-container'][hidden]`));
|
||||||
await BrowserVisibility.waitUntilElementIsNotVisible(hiddenElement);
|
await BrowserVisibility.waitUntilElementIsNotVisible(hiddenElement);
|
||||||
|
36
lib/testing/src/lib/core/pages/form/widgets/tab.ts
Normal file
36
lib/testing/src/lib/core/pages/form/widgets/tab.ts
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
/*!
|
||||||
|
* @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 { by, element, browser } from 'protractor';
|
||||||
|
import { BrowserActions, BrowserVisibility } from '../../../utils/public-api';
|
||||||
|
|
||||||
|
export class Tab {
|
||||||
|
|
||||||
|
async clickTabByLabel(tabLabel): Promise<void> {
|
||||||
|
const user = element(by.cssContainingText('.mat-tab-label-content', tabLabel));
|
||||||
|
await BrowserActions.click(user);
|
||||||
|
await browser.sleep(300);
|
||||||
|
}
|
||||||
|
|
||||||
|
async checkTabIsDisplayedByLabel(tabLabel): Promise<void> {
|
||||||
|
await BrowserVisibility.waitUntilElementIsVisible(element(by.cssContainingText('.mat-tab-label-content', tabLabel)));
|
||||||
|
}
|
||||||
|
|
||||||
|
async checkTabIsNotDisplayedByLabel(tabLabel): Promise<void> {
|
||||||
|
await BrowserVisibility.waitUntilElementIsNotVisible(element(by.cssContainingText('.mat-tab-label-content', tabLabel)));
|
||||||
|
}
|
||||||
|
}
|
@ -48,6 +48,10 @@ export class TextWidget {
|
|||||||
await this.formFields.checkWidgetIsVisible(fieldId);
|
await this.formFields.checkWidgetIsVisible(fieldId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async isWidgetClickable(fieldId): Promise<void> {
|
||||||
|
await this.formFields.checkWidgetIsClickable(fieldId);
|
||||||
|
}
|
||||||
|
|
||||||
async isWidgetNotVisible(fieldId): Promise<void> {
|
async isWidgetNotVisible(fieldId): Promise<void> {
|
||||||
await this.formFields.checkWidgetIsHidden(fieldId);
|
await this.formFields.checkWidgetIsHidden(fieldId);
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,7 @@ import { NumberWidget } from './numberWidget';
|
|||||||
import { AmountWidget } from './amountWidget';
|
import { AmountWidget } from './amountWidget';
|
||||||
import { ContainerWidget } from './containerWidget';
|
import { ContainerWidget } from './containerWidget';
|
||||||
import { PeopleWidget } from './peopleWidget';
|
import { PeopleWidget } from './peopleWidget';
|
||||||
|
import { Tab } from './tab';
|
||||||
import { DocumentWidget } from './documentWidget';
|
import { DocumentWidget } from './documentWidget';
|
||||||
import { AttachFileWidgetCloud } from './attachFileWidgetCloud';
|
import { AttachFileWidgetCloud } from './attachFileWidgetCloud';
|
||||||
|
|
||||||
@ -112,4 +113,8 @@ export class Widget {
|
|||||||
peopleWidget(): PeopleWidget {
|
peopleWidget(): PeopleWidget {
|
||||||
return new PeopleWidget();
|
return new PeopleWidget();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tab(): Tab {
|
||||||
|
return new Tab();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user