jss icon indicating copy to clipboard operation
jss copied to clipboard

Jss generates the same class name for dynamic rendering

Open heyymarco opened this issue 5 years ago • 5 comments

Expected behavior: the class name suffix should be unique (by the counter increment). same

Describe the bug: I created 2 simple react component, called ChildComponent & ParentComponent. The ParentComponent renders the ChildComponent dynamically based on the states or props or both. When the parent render the child, the child class name is exactly the same as the parent, thus make collision - the parent style overwrites the child.

Reproduction:

see this sandbox: https://codesandbox.io/s/create-react-app-forked-go82n?file=/src/App.jsx

then check the checkbox to show the component, then open dev tool, find the generated css.

Versions (please complete the following information):

  • react-jss: 10.5.1
  • Browser: chrome
  • OS : windows

Feel free to add any additional versions which you may think are relevant to the bug.

Managing expectations:

Maintainers will not be fixing the problem you have unless they have it too, if you want it to get fixed:

  1. Submit a PR with a failing test
  2. Discuss a solution
  3. Implement it

You can also do the first step only and wait for someone else to work on a fix. Anything is much better than nothing.

heyymarco avatar Mar 01 '21 07:03 heyymarco

This is indeed very strange, looks def. like a bug

kof avatar Apr 26 '21 10:04 kof

have you fix the bug? I think the bug around the react-jss => getSheetIndex(). It rely the increment each time a new sheet generated. The index is remain the same if the components are statically rendered, but for dynamically rendered the index possibility different depend on the number of rendered unique components.

heyymarco avatar Jul 28 '21 19:07 heyymarco

Same issue here. Does JSS team has plans to fix this as this probably affects everyone with more or less standard JSS setup

Only workaround we see is to pass Component.displayName to createUseStyles that is not minified on production build and makes classname unique

const useStyles = createUseStyles(styles, { name: Component.displayName });

quarryman avatar Aug 03 '21 08:08 quarryman

Please provide a failing test and feel free to prototype a fix!

kof avatar Aug 03 '21 11:08 kof

Same issue here. Does JSS team has plans to fix this as this probably affects everyone with more or less standard JSS setup

Only workaround we see is to pass Component.displayName to createUseStyles that is not minified on production build and makes classname unique

const useStyles = createUseStyles(styles, { name: Component.displayName });

Great!. It is work correctly. But i think it is not best practise method. It must provide to global context solution.

lfabl avatar Jul 04 '22 00:07 lfabl