diff --git a/packages/main/src/TabContainer.js b/packages/main/src/TabContainer.js index d37b799f8da8..7abff5f282b0 100644 --- a/packages/main/src/TabContainer.js +++ b/packages/main/src/TabContainer.js @@ -755,7 +755,7 @@ class TabContainer extends WebComponent { } _navigationIconPress(icon) { - if (icon.classList.contains("sapMITBArrowScrollLeft")) { + if (icon.classList.contains("sapMITBArrowScrollLeft") || icon.classList.contains("sapMITBArrowScrollLeftTextOnly")) { this._leftArrow.onPress(); } else { this._rightArrow.onPress(); diff --git a/packages/main/test/sap/ui/webcomponents/main/pages/TabContainer.html b/packages/main/test/sap/ui/webcomponents/main/pages/TabContainer.html index 0704fbb1e285..6013e28ba6ce 100644 --- a/packages/main/test/sap/ui/webcomponents/main/pages/TabContainer.html +++ b/packages/main/test/sap/ui/webcomponents/main/pages/TabContainer.html @@ -103,7 +103,7 @@
Horizontal design
Icons only
- + Button 11 Button 12 @@ -117,14 +117,15 @@
Icons only
Text Only
- + Button 11 Button 12 + Button 2 - + Button 3 @@ -173,4 +174,4 @@
Text and Count Inline Mode
}); - \ No newline at end of file + diff --git a/packages/main/test/specs/TabContainer.spec.js b/packages/main/test/specs/TabContainer.spec.js index 3e283055996b..dc7b1739ebb3 100644 --- a/packages/main/test/specs/TabContainer.spec.js +++ b/packages/main/test/specs/TabContainer.spec.js @@ -18,4 +18,49 @@ describe("TabContainer general interaction", () => { assert.strictEqual(field2.getProperty("value"), SELECTED_TAB_KEY, "Item data-key is retrieved correctly"); assert.strictEqual(field3.getProperty("value"), SELECTED_TAB_TEXT, "Item text is retrieved correctly."); }); -}); \ No newline at end of file + + it("scroll works on iconsOnly TabContainer", () => { + browser.setWindowSize(250, 1080); + + const arrowLeft = browser.findElementDeep("#tabContainerIconOnly >>> .sapMITBArrowScrollLeft"); + const arrowRight = browser.findElementDeep("#tabContainerIconOnly >>> .sapMITBArrowScrollRight"); + + assert.ok(!arrowLeft.isDisplayed(), "'Left Arrow' should be initially hidden"); + assert.ok(arrowRight.isDisplayed(), "'Right Arrow' should be initially shown"); + + arrowRight.click(); + browser.pause(300); // TODO: wait for animation finish. Remove when solved on framework level + + assert.ok(arrowLeft.isDisplayed(), "'Left Arrow' should be shown after 'Right Arrow' click"); + assert.ok(!arrowRight.isDisplayed(), "'Right Arrow' should be hidden after 'Right Arrow' click"); + + arrowLeft.click(); + browser.pause(300); // TODO: wait for animation finish. Remove when solved on framework level + + assert.ok(!arrowLeft.isDisplayed(), "'Left Arrow' should be hidden after 'Left Arrow' click"); + assert.ok(arrowRight.isDisplayed(), "'Right Arrow' should be shown after 'Left Arrow' click"); + }); + + it("scroll works on textOnly TabContainer", () => { + browser.setWindowSize(250, 1080); + browser.findElementDeep("#tabContainerTextOnly").scrollIntoView(); + + const arrowLeft = browser.findElementDeep("#tabContainerTextOnly >>> .sapMITBArrowScrollLeftTextOnly"); + const arrowRight = browser.findElementDeep("#tabContainerTextOnly >>> .sapMITBArrowScrollRightTextOnly"); + + assert.ok(!arrowLeft.isDisplayed(), "'Left Arrow' should be initially hidden"); + assert.ok(arrowRight.isDisplayed(), "'Right Arrow' should be initially shown"); + + arrowRight.click(); + browser.pause(300); // TODO: wait for animation finish. Remove when solved on framework level + + assert.ok(arrowLeft.isDisplayed(), "'Left Arrow' should be shown after 'Right Arrow' click"); + assert.ok(!arrowRight.isDisplayed(), "'Right Arrow' should be hidden after 'Right Arrow' click"); + + arrowLeft.click(); + browser.pause(300); // TODO: wait for animation finish. Remove when solved on framework level + + assert.ok(!arrowLeft.isDisplayed(), "'Left Arrow' should be hidden after 'Left Arrow' click"); + assert.ok(arrowRight.isDisplayed(), "'Right Arrow' should be shown after 'Left Arrow' click"); + }); +});