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

UNSAFE classname test #1826

Draft
wants to merge 5 commits into
base: main
Choose a base branch
from
Draft

Conversation

pavelklibani
Copy link
Contributor

@pavelklibani pavelklibani commented Dec 18, 2024

Description

  • Our Spirit components still require UNSAFE_className, UNSAFE_style
  • Third party components required their own props - className, style, etc.

Warning

Some components are still broken and will need to be fixed in upcoming changes.
The problem is that some components spread their props, while others combine classes inline.

Additional context

Note

Testing demo available at Next.js app router: http://localhost:3000/test1

Issue reference

(UNSAFE_)className v elementType komponentach

@pavelklibani pavelklibani self-assigned this Dec 18, 2024
@github-actions github-actions bot added the refactoring A code change that neither fixes a bug nor adds a feature label Dec 18, 2024
Copy link

netlify bot commented Dec 18, 2024

Deploy Preview for spirit-design-system ready!

Name Link
🔨 Latest commit 25ae27e
🔍 Latest deploy log https://app.netlify.com/sites/spirit-design-system/deploys/677e997f843f3e000882fb5f
😎 Deploy Preview https://deploy-preview-1826--spirit-design-system.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.
Lighthouse
Lighthouse
1 paths audited
Performance: 96 (no change from production)
Accessibility: 91 (no change from production)
Best Practices: 100 (no change from production)
SEO: 91 (no change from production)
PWA: -
View the detailed breakdown and full score reports

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

netlify bot commented Dec 18, 2024

Deploy Preview for spirit-design-system-storybook ready!

Name Link
🔨 Latest commit 25ae27e
🔍 Latest deploy log https://app.netlify.com/sites/spirit-design-system-storybook/deploys/677e997f83907b000892e4c3
😎 Deploy Preview https://deploy-preview-1826--spirit-design-system-storybook.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

@@ -52,4 +52,6 @@ const _Button = <T extends ElementType = 'button', C = void, S = void>(

const Button = forwardRef<HTMLButtonElement, SpiritButtonProps<ElementType>>(_Button);

Button.isSystemComponent = true;
Copy link
Collaborator

Choose a reason for hiding this comment

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

suggestion: I think, we will use something like Button.spiritComponent = Button for cases where we want to check if it is a Spirit component or if we want a name.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Or we can use Button.isSpiritComponent first and reimplement it when needed.

const styleProps = {
style: Object.keys(style).length > 0 ? style : undefined,
className: classNames(UNSAFE_className, ...styleUtilities) || undefined,
const rimmerProps = {
Copy link
Collaborator

Choose a reason for hiding this comment

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

suggestion: Please, remove this.

...(UNSAFE_style !== undefined && { UNSAFE_style }),
...(UNSAFE_className !== undefined && { UNSAFE_className }),
},
props: rimmerProps as HTMLAttributes<HTMLElement>,
Copy link
Collaborator

Choose a reason for hiding this comment

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

suggestion: This should be refactored back.

// For backward compatibility!
/** Sets the CSS [className](https://developer.mozilla.org/en-US/docs/Web/API/Element/className) for the element. Only use as a **last resort**. Use style props instead. */
UNSAFE_className?: string;
/** Sets inline [style](https://developer.mozilla.org/en-US/docs/Web/API/Element/style) for the element. Only use as a **last resort**. Use style props instead. */
UNSAFE_style?: CSSProperties;
useUnsafe?: boolean;
Copy link
Collaborator

Choose a reason for hiding this comment

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

suggestion: We do not need this anymore.

props: HTMLAttributes<HTMLElement>;
};

export function useStyleProps<T extends StyleProps>(props: T): StylePropsResult {
const classNamePrefix = useContext(ClassNamePrefixContext);
const { UNSAFE_className, UNSAFE_style, ...otherProps } = props;
const { UNSAFE_className, UNSAFE_style, ElementTag, ...otherProps } = props;
Copy link
Collaborator

Choose a reason for hiding this comment

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

suggestion: I think we should pass here only the bool value and not the entire ElementTag/Component.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
refactoring A code change that neither fixes a bug nor adds a feature
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants