-
-
Notifications
You must be signed in to change notification settings - Fork 32.4k
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
[AvatarGroup] Move to the core #18869
Comments
@Studio384 From my perspective, we could move the component as is in the core. In the pull request, we have explored a couple of enhancement, none required a breaking change:
@mbrookes What do you think? |
Given how simple the internals are, I have no objection to moving this to the core, and adding features later based on demand. Neither of the suggested features is technically challenging, so unlikely to cause issues. |
@Studio384 I think that we can wait a couple of weeks before taking on this task, it would be great for v4.9.0 :). Feel free to take the lead of it 💪. |
@oliviertassinari In the meantime, shouldn't the line about AvatarGroup in the 4.8.0 release notes be moved from the release notes of the core package to the notes for lab? |
Fixed, thanks |
This comment has been minimized.
This comment has been minimized.
Hi all, I'd like to take a stab at this issue. This is my first time contributing and any advice or recommendations would be greatly appreciated. From what I can see, the following needs to be done:
And for max +x behavior are you referring to defining a limit of avatar's shown and the remainder as the +x as shown in the docs @oliviertassinari ? If so should that be in these changes or as a separate feature? Correct me if I'm wrong or have any misunderstandings. Thanks! |
This sounds to me that it should be the subject of 3 different pull requests. 1. move to core 2. add spacing prop 3. add max prop. Otherwise, great, happy to see you around :). |
I'd suggest that the move to core should come last. |
What should the spacing prop be defined by? Just raw values ranging from some number such as 2 to -12 or something? Or is there a best practice that I'm not aware of? |
Great question. My initial intuition was to say a to use a multiple of theme.spacing unit (1.), but in this context, I wonder if a px unit wouldn't be better (2.). For instance, let's say a user customize theme.spacing, should it impact the AvatarGroup? |
Yeah that was my exact concern too. I think because the existing functionality is just an explicitly set pixel value and to change it requires using css we can extend that and allow those preset spacing options or they can continue to change via css. It feels to me that it should be unaffected by theme.spacing, do you agree? I was thinking 3 preset options of
Or something along those lines. |
I went with 5 spacings ranging from |
@GFynbo Right, there is this third option (3.): to accept an enum, like small, medium, large values. |
@oliviertassinari Yeah maybe that's the best way forward. I've changed it to reflect that with options for small, medium and large with corresponding -16px, -8px, and -4px. I'll create the first PR now. |
Spacing prop was merged into master with #19761, working on max prop now. |
This comment has been minimized.
This comment has been minimized.
@oliviertassinari Do we want the max prop to have be the default functionality? For example if I pass an AvatarGroup with 6 Avatar children, should the default behavior be to show 3 and have +3 at the end or to show all 6 and only have +x functionality when explicitly defined? |
@GFynbo Great question, I think that we can consider a default value for the max prop. |
@oliviertassinari Certainly makes sense to me! I'll work on that. |
Should the |
I think reasonable behavior is to show the number defined with an additional +x avatar shown after for a total of 6 avatars displayed. It seems fairly logical to have the max shown prop show that number of avatars with the remaining in an additional +x prop. |
PR #19853 deals with max prop |
It seems that this was missed from #20012, so I've added it. |
Current Behavior 😯
Currently, the only indication that AvatarGroup is a lab-component is its import statement in the example that is hidden by default. This should be mentioned in the text above the example.
The 4.8.0 release notes also don't mention this and even list AvatarGroup as part of
core
instead oflab
.I'd argue it would be even better to just split this component to its own page that is listed under "Lab" in the menu, and merge that back into the Avatar-page once the component is stable.
The text was updated successfully, but these errors were encountered: