Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(tabs): content animation in RTL not working (chrome) #12215

Merged

Conversation

devversion
Copy link
Member

Fixes that the tabs content is not animating properly in chrome when RTL is turned on.

Fixes #8833. Fixes #9465

Fixes that the tabs content is not animating properly in chrome when RTL is turned on.

Fixes angular#8833. Fixes angular#9465
@devversion devversion added P2 The issue is important to a large percentage of users, with a workaround Accessibility This issue is related to accessibility (a11y) target: patch This PR is targeted for the next patch release labels Jul 15, 2018
@devversion devversion requested a review from andrewseguin as a code owner July 15, 2018 10:31
@googlebot googlebot added the cla: yes PR author has agreed to Google's Contributor License Agreement label Jul 15, 2018
@devversion devversion removed the Accessibility This issue is related to accessibility (a11y) label Jul 15, 2018
// in order to ensure that the element has a height before its state changes. This is
// necessary because Chrome does seem to skip the transition in RTL mode if the element does
// not have a static height and is not rendered. See related issue: #9465
state('left', style({transform: 'translate3d(-100%, 0, 0)', minHeight: '1px'})),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we do this directly in the stylesheet? I think we have a class for the off-screen tabs which should allow us to set the min-height.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We only have a class for the active tab body, so we could work with :not, but since this technically belongs to the animation setup I'd anyway prefer having this here.

That way if someone looks for the animations, he can quickly see that there is some special workaround applied.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

True, but this makes it a lot more difficult for somebody to change the min-height, if they wanted to.

Copy link
Member Author

@devversion devversion Jul 15, 2018

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That min-height is only temporarily while the tab is hidden. As soon as it transitions to the visible state, the min-height is completely gone.

Also, why would someone need to update the temporary min-height of an internal and hidden element? The developer can still set his own min-height in the projected content easily.

I'm fine changing if you really want to. Just think if we move into some SCSS file, we'd need some special selector (e.g. :not), and at some point we would not remember about that specific workaround that belongs to the animation.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The way I'm viewing it is that it's unlikely for somebody to want to change the min-height, but if they do, it would be very hard for them to do so, whereas it's very low-effort for us to have it in the stylesheet to begin with. Having it there also ends up being less generated code.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see your point with the low-effort to place in the stylesheet. In regards to the code size, I think the generated CSS will take up more space than how it's right now.

Also, if we consider it like that, we could also argue about moving the actual transform's that don't include any computed values to the stylesheet.

Anyway, I will switch it to the CSS but keep a comment that mentions the Chrome workaround that is placed in the stylesheet.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As discussed on Slack; since depending on the .mat-tab-body-active does not work because the class is being added before hidden tabs start the actual animation, we are keeping the workaround in the TS file.

Copy link
Member

@crisbeto crisbeto left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@crisbeto crisbeto added pr: lgtm action: merge The PR is ready for merge by the caretaker labels Jul 15, 2018
@josephperrott josephperrott merged commit c6c68a6 into angular:master Jul 17, 2018
@angular-automatic-lock-bot
Copy link

This issue has been automatically locked due to inactivity.
Please file a new issue if you are encountering a similar or related problem.

Read more about our automatic conversation locking policy.

This action has been performed automatically by a bot.

@angular-automatic-lock-bot angular-automatic-lock-bot bot locked and limited conversation to collaborators Sep 9, 2019
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
action: merge The PR is ready for merge by the caretaker cla: yes PR author has agreed to Google's Contributor License Agreement P2 The issue is important to a large percentage of users, with a workaround target: patch This PR is targeted for the next patch release
Projects
None yet
Development

Successfully merging this pull request may close these issues.

mat-tab-group animation is not supporting RTL [Tabs] RTL animation is broken
4 participants