tds-core
tds-core copied to clipboard
chore(deps): update dependency styled-components to v5
This PR contains the following updates:
Package | Change | Age | Adoption | Passing | Confidence |
---|---|---|---|---|---|
styled-components (source) | ^4.1.3 -> ^5.0.0 |
Release Notes
styled-components/styled-components
v5.3.3
What's Changed
- Backport #3568 (read from textContent rather than innerHTML during rehydrate) to v5 by @keeganstreet in https://github.com/styled-components/styled-components/pull/3591
- [v5] generate more complete sourcemaps by @henryqdineen in https://github.com/styled-components/styled-components/pull/3597
New Contributors
- @henryqdineen made their first contribution in https://github.com/styled-components/styled-components/pull/3597
Full Changelog: https://github.com/styled-components/styled-components/compare/v5.3.1...v5.3.3
v5.3.1
-
Fix forced server-side mode not triggering global styles (See #3566)
-
Fix SSR collisions caused by insufficient hash inputs and reordering of groups on the client, which is a regression in v5.2.0 (See #3563)
-
Fix dynamic creation React warning for React v18, backported to v5 by @lynndylanhurley (See #3564)
-
Add missing typeof window check when checking for duplicate instances of styled-components (See #3553)
-
Prevent ServerStyleSheet from emitting empty style tags, which would cause issues in IE11 (See #3555)
-
Support css tagged templates inside style objects, by @roginfarrer and @dvingo (See #3469)
v5.3.0
-
Pass
elementToBeCreated
as a third parameter toshouldForwardProp
so that the user-specified function can decide whether to pass through props based on whether the created element will be a tag or another component. (see #3436) -
Fix React Native components accepts function as style prop. (see #3389)
v5.2.3
fix an issue with an unguarded window accessor in a SSR path (see #3446)
v5.2.2
-
For React Native based components, pass
testID
down to the native component if specified for an easier time testing. (see #3365) -
Enable users of the babel macro to customize the styled-components import with
importModuleName
(see #3422) -
[fix] COMPLEX_SELECTOR_PREFIX.includes wasn't transpiled (see #3397)
v5.2.1
- Tweak server-side build settings to resolve an issue with jest-dom not being able to pick up generated styles (see #3308) thanks @Lazyuki
v5.2.0
-
Make sure
StyleSheetManager
renders all styles in iframe / child windows (see #3159) thanks @eramdam! -
Rework how components self-reference in extension scenarios (see #3236); should fix a bunch of subtle bugs around patterns like
& + &
-
Fix
keyframes
not receiving a modified stylis instance when using something likestylis-plugin-rtl
(see #3239) -
Big performance gain for components using style objects (see #3239)
-
We no longer emit dynamic classNames for empty rulesets, so some className churn may occur in snapshots
-
Preallocate global style placement to ensure cGS is consistently inserted at the top of the stylesheet; note that this is done in runtime order so, if you have multiple cGS that have overlapping styles, ensure they're defined in code in the sequence you would want them injected (see #3239)
-
Add "engines" to package.json (currently set to Node 10, the oldest supported LTS distribution) (see #3201) thanks @MichaelDeBoey!
-
Allow
DISABLE_SPEEDY
to be set tofalse
to enable speedy mode in non-production environments (see #3289) thanks @FastFedora! -
Enable new style rules can be inserted in the middle of existing sheet when rendering on client after rehydrate.
GroupIDAllocator
is now changed to findnextFreeGroup
by checkingreverseRegister
, instead of setting it to the end of existing groups. (see #3233) thanks @mu29!
v5.1.1
New Functionality
- Implement
shouldForwardProp
API for native and primitive platforms, which was previously missing in [v5.1.0] (see #3093) This has been released under a patch bump instead of a minor, since it's only been missing from Native-support.
Bugfixes
- Added
useTheme
hook to named exports for react-primitives entrypoint (see #2982) thanks @jladuval! - Escape every CSS ident character necessary when converting component display names to class names (see #3102) thanks @kripod!
v5.1.0
New Functionality
-
Add
shouldForwardProp
API (almost the same as emotion's, just a slightly different usage pattern); https://github.com/styled-components/styled-components/pull/3006Sometimes when composing multiple higher-order components together, it's possible to get into scenarios when multiple layers consume props by the same name. In the past we've introduced various workarounds for popular props like
"as"
but this power-user API allows for more granular customization of what props are passed down to descendant component children when using thestyled()
HOC wrapper.When combined with other APIs like
.attrs()
this becomes a very powerful constellation of abilities.Here's how you use it:
const Comp = styled('div').withConfig({ shouldForwardProp: (prop, defaultValidatorFn) => !['filterThis'].includes(prop), })` color: red; `; render(<Comp filterThis="abc" passThru="def" />);
v5.0.1
-
Added useTheme hook to named exports for react native
-
Performance enhancements
- Refactored hashing function that is a bit faster in benchmarks
- Fixed a bitwise math issue that was causing SSR performance degradations due to how we allocate typed arrays under the hood
-
Added some helpful new dev-time warnings for antipatterns
- Recommending against usage of css
@import
insidecreateGlobalStyle
and what to do instead - Catching and warning against dynamic creation of styled-components inside other component render paths
- Recommending against usage of css
v5.0.0
Read the v5 release announcement!
- 19% smaller bundle size
- 18% faster client-side mounting
- 17% faster updating of dynamic styles
- 45% faster server-side rendering
- RTL support
NOTE: At this time we recommend not using @import
inside of createGlobalStyle
. We're working on better behavior for this functionality but it just doesn't really work at the moment and it's better if you just embed these imports in your HTML index file, etc.
-
StyleSheetManager
enhancements- you can now supply stylis plugins like stylis-plugin-rtl;
<StyleSheetManager stylisPlugins={[]}>...</StyleSheetManager>
-
disableVendorPrefixes
removes autoprefixing if you don't need legacy browser support;<StyleSheetManager disableVendorPrefixes>...</StyleSheetManager>
-
disableCSSOMInjection
forces using the slower injection mode if other integrations in your runtime environment can't parse CSSOM-injected styles;<StyleSheetManager disableCSSOMInjection>...</StyleSheetManager>
- you can now supply stylis plugins like stylis-plugin-rtl;
-
Remove deprecated attrs "subfunction" syntax variant
styled.div.attrs({ color: p => p.color });
should become
styled.div.attrs(p => ({ color: p.color }));
You can still pass objects to
attrs
but individual properties shouldn't have functions that receive props anymore. -
Fix attrs not taking precedence over props when overriding a given prop
-
(ReactNative) upgrade css-to-react-native to v3 (changelog)
- Removed support for unitless line height in font shorthand
-
Replace
merge-anything
withmixin-deep
to save some bytes (this is what handles merging ofdefaultProps
between folded styled components); this is inlined into since the library is written in IE-incompatible syntax -
Fix certain adblockers messing up styling by purposefully not emitting the substring "ad" (case-insensitive) when generating dynamic class names
-
Fix regressed behavior between v3 and v4 where className was not correctly aggregated between folded
.attrs
invocations
- Fix support for styling custom elements (https://github.com/styled-components/styled-components/pull/2819)
v4.4.1
-
Fix
styled-components
'sreact-native
import for React Native Web, by @fiberjw (see #2797) -
Remove dev-time warning if referencing a theme prop without an outer
ThemeProvider
, the check for it isn't smart enough to handle cases with "or" or ternary fallbacks and creates undesirable noise in various third party integrations
v4.4.0
-
Fix to use
ownerDocument
instead of globaldocument
, by @yamachig (see #2721) -
Backport fix for SSR classname mismatches in development mode for some environments like next.js (see #2701)
-
Fix attrs not properly taking precedence over props
-
Backport fix where classnames are composed in the wrong order if custom class names are passed in (see #2760)
-
Fix add check for style tag detached - sheet in the style tag is null in this case, by @newying61 (see #2707)
v4.3.2
- Fix usage of the "css" prop with the styled-components babel macro (relevant to CRA 2.x users), by @jamesknelson (see #2633)
v4.3.1
- Revert #2586; breaks rehydration in dev for certain runtimes like next.js
v4.3.0
-
Make it possible to initialize
SC_ATTR
andSC_DISABLE_SPEEDY
viaREACT_APP_*
.env variables for easier integration with CRA applications (see #2501) -
Fix
theme
prop for styled native components, also fixestheme
indefaultProps
for them. -
Add "forwardedAs" prop to allow deeply passing a different "as" prop value to underlying components when using
styled()
as a higher-order component -
Implement defaultProps folding (see #2597)
Configuration
📅 Schedule: "before 3am on Monday" in timezone America/Vancouver.
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.
👻 Immortal: This PR will be recreated if closed unmerged. Get config help if that's undesired.
- [ ] If you want to rebase/retry this PR, click this checkbox.
This PR has been generated by WhiteSource Renovate. View repository job log here.