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

feat(organizations): add theming/story for Mantine ActionIcon TASK-1448 #5412

Open
wants to merge 4 commits into
base: kalvis/mantine-setup
Choose a base branch
from

Conversation

jamesrkiger
Copy link
Contributor

@jamesrkiger jamesrkiger commented Jan 8, 2025

🗒️ Checklist

  1. run linter locally
  2. update all related docs (API, README, inline, etc.), if any
  3. draft PR with a title <type>(<scope>)<!>: <title> TASK-1234
  4. tag PR: at least frontend or backend unless it's global
  5. fill in the template below and delete template comments
  6. review thyself: read the diff and repro the preview as written
  7. open PR & confirm that CI passes
  8. request reviewers, if needed
  9. delete this section before merging

📣 Summary

Adds theming and storybook entry for ActionIcon

💭 Notes

We previously used our custom in-house button component to display icon buttons. With Mantine, however, these kinds of buttons are rendered with the ActionIcon component.

👀 Preview steps

Use storybook stories and compare to existing icon buttons in the repo. Existing examples include:

  • archive/share/delete options in project list view
  • edit/delete options in user permissions section of sharing view
  • member actions dropdown trigger in organizations member table

@jamesrkiger jamesrkiger changed the title Add ActionIcon theming and story feat(organizations): add theming/story for Mantine ActionIcon TASK-1448 Jan 8, 2025
@jamesrkiger jamesrkiger self-assigned this Jan 8, 2025
@jamesrkiger jamesrkiger marked this pull request as draft January 8, 2025 20:05
@jamesrkiger jamesrkiger marked this pull request as ready for review January 9, 2025 12:12
'--ai-hover': theme.colors.blue[5],
}),
...(props.variant === 'light' && {
'--ai-color': theme.colors.blue[5],
Copy link
Member

@magicznyleszek magicznyleszek Jan 10, 2025

Choose a reason for hiding this comment

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

I think that the blue color of the icon is lighter than our current icon buttons.

Also, is there a reason why these overrides doesn't happen at the styles file? I think that modifying styles through vars is not the approch we want to go (see https://github.com/kobotoolbox/kpi/pull/5366/files)

Copy link
Contributor

Choose a reason for hiding this comment

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

let's prefer CSS Modules file over styles prop, because that edits CSS class once, instead of adding style="font-size: calc(0.875rem * var(--mantine-scale)); border-top: 1px solid rgb(237, 238, 242);" to every cell individually (see DOM of storybook). Also, that's officially recommended.

Furthermore, would you agree to prefer vars prop over CSS Modules file, because that's a simple parameterization of the CSS Modules? Although performance is unknown and official docs lacks an opinion on using vars prop vs "hardcoded" values in CSS Modules.

Preferring vars over css is an option, let's talk in the meetup about our policy (options: prefer vars, prefer css, undefined).

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I think that the blue color of the icon is lighter than our current icon buttons.

Good catch. I have fixed this for the 'light' and 'danger-secondary' variants.

iconS: {
description: 'Icon',
options: Object.keys(IconNames),
mapping: generateSizedIconElementMap('s'),
Copy link
Member

Choose a reason for hiding this comment

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

There is something weird happening when I switch the size - the icon that I've set is gone and instead no icon or some other icon appears. It seems it's somehow connected to this function. It's not a bug per se, but it works differently from what we have

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah, this is a little annoying but it's because currently button size and icon size are independent of each other in our code so this a side effect of how I'm enforcing "only small icons in small buttons", etc. in the Storybook controls.

@@ -0,0 +1,7 @@
.root {
Copy link
Member

Choose a reason for hiding this comment

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

Shouldn't this file be .scss? I see that it does work in the build, but the code in it is not really CSS given the nesting and &

Copy link
Contributor

@Akuukis Akuukis Jan 11, 2025

Choose a reason for hiding this comment

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

Weird that Mantine officially does the same, see https://mantine.dev/styles/css-modules/

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants