Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

jss-plugin-global

cssinjs5.7mMIT10.10.0TypeScript support: included

Global styles for JSS

cssinjs, css-in-js, css in js, jss, plugin, global, unscoped

readme

jss-plugin-global

Version License Downlodas Size Dependencies

Global styles for JSS

See our website jss-plugin-global for more information.

Install

Using npm:

npm install jss-plugin-global

or using yarn:

yarn add jss-plugin-global

changelog

Since you are interested in what happens next, in case, you work for a for-profit company that benefits from using the project, please consider supporting it on https://opencollective.com/jss.

Next (version and date will be generated, add changes below)

Improvements

  • [jss] Added support for @container query 1637

10.9.2 (2022-7-31)

Bug fixes

  • [react-jss] Fix import useInsertionEffect 1627

10.9.1 (2022-7-21)

Bug fixes

  • [jss] Update stylesheet if !important flag is set before and after the update 1612

10.9.1-alpha.2 (2022-4-24)

Bug fixes

  • [jss] Update stylesheet if !important flag is set before and after the update 1612

10.9.1-alpha.1 (2022-4-23)

Bug fixes

  • [react-jss] #1608 fixed the failing tests caused by #1604, but doing so reintroduced the original bug breaking React 18 support 1609

10.9.1-alpha.0 (2022-4-16)

Improvements

  • [react-jss] Use useInsertionEffect 1608, 1604

10.9.0 (2021-12-8)

Bug fixes

  • [jss, jss-plugin-global, jss-plugin-nested, jss-plugin-rule-value-function] Fixes a memory leak with nested function rules 1574

Improvements

  • Keep classes ref when sheet and dynamicRules have not any change 1573

10.8.2 (2021-10-25)

Bug fixes

  • Reverting 1563 because of regression 1565

10.8.1 (2021-10-16)

Bug fixes

  • [jss, jss-plugin-global, jss-plugin-nested, jss-plugin-rule-value-function] Fixes a memory leak with nested function rules 1563

10.8.0 (2021-9-18)

Improvements

  • [jss] New option to remove whitespaces. Useful for SSR 1549

  • [all] Flow types are now moved from .js files to .flow type defs 1509

  • [all] Upgrade typescript to 4.4.2 1550

10.7.1 (2021-6-28)

Bug fixes

  • [jss] Fixes regression from previous release where useStyles() without arguments would throw an error

10.7.0 (2021-6-27)

Improvements

  • [jss][ts] Improved style type 1521
  • [react-jss] Refactored JssProvider to function component 1513
  • [react-jss] Refactored WithStyles to function component 1508

10.6.0 (2021-3-14)

Improvements

  • [*] Define specific polyfills for specific packages that will be required and define a policy for adding polyfills. Makes sure we will notice if a polyfill is needed in a supported browser by failing the CI. 1456
  • [jss] Use globalThis to support secure version of JavaScript called SES 1449
  • [jss][ts] Styles now supports ClassNames, Props/Data, and Theme as type parameters (eg. Styles<Names, Data, Theme>). 1460
  • [react-jss][ts] withStyles and createUseStyles now support ClassNames, Props, and Theme as type parameters (eg. createUseStyles<Names, Props, Theme>). 1460
  • [react-jss][ts] useStyles finally expects the correct argument type: a Props object with an optional Theme property (both determined from createUseStyles). 1460
  • [react-jss][ts] Support global TS theme definition 1453
  • [react-jss][ts] Allow partial classes prop in withStyles() 1428

Breaking Changes

  • [react-jss][ts] Theme is no longer the first generic type parameter for createUseStyles. 1460
    • There are two main ways to tell TS your Theme's type without reaching over the other type parameters:

Using the function argument.

const useStyles = createUseStyles(theme: Theme => ({
  ruleName: { /* ... */ };
}))

Using the object argument with a function. (You will only need to specify the Theme type once.)

const useStyles = createUseStyles({
  ruleName: ({theme}: {theme: Theme}) => ({
    /* ... */
  })
})

10.5.1 (2021-1-23)

Bug fixes

  • [jss-plugin-default-unit] Fix crash in Chrome 88 when NaN is used by the user 1446
  • [jss][ts] Fix intellisense suggestions 1423

Improvements

  • [jss-plugin-default-unit] Add px as default unit for text-decoration-thickness 1438
  • [jss-plugin-default-unit] Add px as default unit for row-gap 1436
  • [*] Allow project to be in a directory that contains spaces 1433

10.5.0 (2020-11-15)

Bug fixes

  • [jss][ts] Restore support for Observable styles 1402
  • [jss-plugin-default-unit] Fix missing default unit for 0ms and 0% 1413

Improvements

  • [*] Improve docs 1384, 1387, 1391,
  • [*] Remove test files from the package 1406
  • [*] Upgrade rollup 1426
  • [*] Upgrade flow to 0.138.0 1425
  • [jss-plugin-default-unit] Add gap unit 1403
  • [jss-plugin-default-unit] Add default units to logical properties 1415
  • [jss] Improve deleteRule() performance 1424

10.4.0 (2020-8-14)

Bug fixes

  • [jss-plugin-extend] Fix can not extend rule name is array 1357
  • [*] Fix yarn build for windows 1376

Improvements

  • [jss][ts] Bump csstype to 3.0.2 1379
  • [react-jss][ts] TS support for innerRef prop 1355
  • [react-jss][ts] TS fix theme types 1349
  • [react-jss][ts] Add properly react default props types calculation 1353
  • [react-jss] Upgrade Theming to 3.3.0 1382
  • [*] Upgrade flowtype to 0.131.0 1382

10.3.0 (2020-6-10)

Improvements

  • [jss, react-jss][ts] ts fixes, allow autocomplete for CSS rules 1352

10.2.0 (2020-6-3)

Improvements

  • [react-jss][ts] ts fixes 1310
  • [jss][ts] ts fixes 1318
  • [examples] Convert plugin examples to codesandbox 1316

Bug fixes

  • [jss-plugin-rule-value-function] Fixed missing dependency to tiny-warning 1315
  • [jss-plugin-vendor-prefixer] Correct prefixing of writing-mode property 1326

10.1.1 (2020-3-15)

Bug fixes

  • [jss, react-jss] revert getDynamicStyles migration introduced in 10.1.0

10.1.0 (2020-3-15)

Bug fixes

  • [jss] Fix multiple .addRule calls with font-face (1280)
  • [jss] Allow a Comment node as insertion point (1284)

Improvements

  • [jss-plugin-rule-value-function] Add warning when using a function value inside a function rule (1285)
  • [react-jss][ts] Typescript support for createUseStyles theme (1294)
  • [jss, react-jss] - getDynamicStyles utility function was originally exposed from jss package, but I don't think it was used externally, so I moved it to react-jss package and made it internal. If you have been using it as public API let me know, we will have to revert the change.
  • [examples] Migrate examples to monorepo (1306)

Features

  • [jss-plugin-default-unit] Allow options to pass function transforms in (1292)

10.0.4 (2020-1-28)

Bug fixes

  • [react-jss] Add type alias for WithStyles (1254)
  • [react-jss] Fix ts typings for hook, created common interface for options (1266)
  • [react-jss] Revert strict style types for ts, since it's a breaking change and needs much more work done upfront (1270)

Improvements

  • [css-jss][ts] Add TS type definitions (1247)
  • [react-jss] Accept options.generateId in useStyles() and withStyles() as an option (1263)

10.0.3 (2020-1-1)

Improvements

  • [jss] Improve JssStyle definition (1218)
  • [react-jss] Improve createUseStyles definition (1218)

Bug fixes

  • [jss] Fix create definitions to allow minify: boolean (1218)
  • [jss][ts] Fix Name Typescript constraint (1218)

10.0.2 (2019-12-30)

Bug fixes

  • [jss] Fix breaking change that was introduced in 10.0.1 (1252)

10.0.1 (2019-12-28)

Bug fixes

  • [jss-plugin-vendor-prefixer] Upgrade css-vendor package to v2.0.7 (1208)
  • [jss] Fix sheet.addRule() support for duplicate rule names (1242)
  • [react-jss] Fix function values support inside of nested media queries when component is a list item (1242)

10.0.0 (2019-9-22)

Summary

A higher level overview of v10 release.

  • [react-jss] A new hooks-based API has been released and became the new default way to use JSS with React.
  • [jss] Keyframe IDs are now scoped by default.
  • [jss] Function values, function rules and observables apply plugins by default now, which means they can support all kinds of syntaxes: e.g. fallbacks, media queries, nesting, global styles.
  • [jss] Houdini Typed CSSOM Values are supported now.
  • [all] Each package supports ESM modules import, also possible directly from https://unpkg.com/.
  • [all][ts] Added TS type definitions to this repository.

For more details please read the rest of the changelog.

10.0.0-alpha.27 (2019-9-22)

Bug fixes

  • [react-jss] Add fallback for Number.MIN_SAFE_INTEGER, because not supported by IE <= 11 (1197)
  • [jss-plugin-vendor-prefixer] Fix fallbacks syntax support regression (1198)

10.0.0-alpha.26 (2019-9-22)

Bug fixes

  • [jss] Fix dynamic rule updating after sheet re-attach in IE (1194)
  • [ci] Fix browsers.json, bump suported ios Safari to 10.3.

10.0.0-alpha.25 (2019-9-16)

Bug fixes

  • [jss] Fix dynamic rule updating after sheet re-attach (1190)

Improvements

  • [jss-plugin-nested] Better warning text (1170)

10.0.0-alpha.24 (2019-8-13)

Bug fixes

  • [react-jss] Fix nested dynamic rule updating (1144)
  • [jss] Support falsy value from fn rule (1164)

Improvements

  • [react-jss][ts] Improve TS definitions and add missing definition for createUseStyles (1155)
  • [jss-plugin-default-unit] Consistent usage of the CSS browser API (1168)

10.0.0-alpha.23 (2019-7-20)

Bug fixes

  • [react-jss] Update dynamic nested rules need (#1144)
  • [react-jss] withStyles shouldn't attach() on SSR (#1149, #1157)

Improvements

  • [jss] Improve treeshaking for webpack by not using global. (#1153)

10.0.0-alpha.22 (2019-7-2)

Breaking Changes

  • [jss] SheetsRegistry.toString(options) will now return all sheets by default, no matter detached or attached. You can specify which one you want by using the option registry.toString({attached: true}) (1140)

Bug fixes

  • [react-jss] SSR for the hooks based API will now work with the registry as expected (1140)
  • [react-jss] When id options passed to JssProvider, we need to create a new generateId function (#1147)

Improvements

  • [react-jss] Document id prop for JssProvider, add "Class name generator options" to the docs. (#1147)
  • [react-jss] Use component name or displayName as a class name prefix also in production by default (#1147)

10.0.0-alpha.21 (2019-6-22)

Bug fixes

  • [jss-plugin-vendor-prefixer] Upgrade css-vendor package to v2.0.5 (#1142)
  • [css-jss] Slows down in benchmark after 10k rules (#1137)

10.0.0-alpha.20 (2019-6-17)

Bug Fixes

  • [react-jss] Experimental styled API got some fixes and many more tests (#1118)

10.0.0-alpha.18 (2019-6-14)

Features

  • [react-jss] New experimental styled API (undocumented intentionally)(#1094)
  • [react-jss] JSX pragma for css prop (undocumented intentionally)(#1130)
  • [css-jss] New experimental css() API (undocumented intentionally)(#1129)

Bug fixes

  • [jss] After attempting to insert an invalid rule, JSS is now able to insert a valid one (#1123)
  • [react-jss][ts] Fix type optional theming property (#1121)
  • [react-jss][ts] Export useTheme in TS declaration (#1124)

10.0.0-alpha.17 (2019-6-7)

Features

  • [react-jss] New hooks based API is out. HOC based API is deprecated. It will stay in v10 but will be removed in v11. (#1089)

Breaking Changes

  • [jss] Add option for opt-in minification of class names. (#1075)

Bug fixes

  • [jss-plugin-expand] Fix attributes spread for border-bottom, border-top, border-left and border-right (#1083)
  • [jss-plugin-props-sort] Fix sorting in Node 11 (#1084)
  • [jss] Fix escaping keyframes names (#1100)

10.0.0-alpha.16 (2019-3-24)

Bug fixes

  • [jss-plugin-camel-case] Fix some IE 11 regression (#1065)
  • [jss-vendor-prefixer] Fix value prefixing, in particular position: sticky (#1068)

10.0.0-alpha.14 (2019-3-17)

Improvements

  • [jss] Add support for multiple referenced keyframes (#1063)

Bug fixes

  • [jss] Fix SSR aggregation regression (#1064)

10.0.0-alpha.13 (2019-3-12)

Bug fixes

  • [react-jss] Replace spaces inside the display name with hyphens (#1049)

Improvements

  • [jss] Remove VirtualRenderer and the option virtual: true. Now to simulate a non-browser environment, pass create({Renderer: null}) when creating a Jss instance.
  • [react-jss] Add dynamic rules to the static sheet (#1048)

10.0.0-alpha.12 (2019-2-27)

Bug fixes

  • [jss] Fix using function values with scoped keyframes (#1043)
  • [jss] Fix removing styles from function rules (#1046)

10.0.0-alpha.11 (2019-2-24)

Bug fixes

  • [jss] Fix dynamic values inside of @global plugin (#664)

Improvements

  • [all] All packages except of react-jss can now be used as ESM modules directly from unpkg.com (1029)
  • [jss][ts] Improve typings (#973)

10.0.0-alpha.10 (2019-2-9)

Improvements

  • [jss] Simplify cloneStyle function (#1003)
  • [jss] Use WeakMap inside SheetsManager (#1019)
  • [internal] Improve publish script for creating github release (#999)
  • [react-jss] Warn about themed styles misuse (#1006)

Bug fixes

  • [jss-starter-kit] Fix react-jss exports and add missing jss exports (#1001)
  • [jss-plugin-camel-case] Fix hyphenating css variables (#1017)

10.0.0-alpha.9 (2019-1-25)

Bug fixes

  • [all] Move jss dependencies to normal dependencies instead of peer and dev dependencies (#993)
  • [internal] Upgrade lerna (#992)
  • [react-jss] Move @types/react to dev dependencies (#990)
  • [react-jss] Upgrade theming package to v3.0.3 (#994)
  • [docs] Fix demo links for jss-plugin-extend (#992)

Improvements

  • [internal] Add script for building readme for packages (#996)

10.0.0-alpha.8 (2018-1-17)

Bug fixes

  • [all] Fix npm repo urls (#983)
  • [jss][ts] Declare ES classes as TS classes instead of interfaces (#971)

Improvements

  • [all] Remove warning from production (#980)

Breaking changes

  • [react-jss] Move JssContext to new React Context, deprecate the sheetOptions prop on the JssProvider and support a media prop (#924)
  • [react-jss] Remove inject option (#934)
  • [react-jss] Extend classes instead of overwriting theme (#946)
  • [react-jss] Add forwardRef support (#943)
  • [react-jss] Upgrade to theming version 3 (#942)

10.0.0-alpha.7 (2019-1-3)

Bug fixes

  • [jss] Fix IE 11 injection order

10.0.0-alpha.6 (2019-1-1)

Republish of alpha 5 with properly building the code.

10.0.0-alpha.5 (2018-12-31)

Bug fixes

  • [jss] Fix warning dependency

10.0.0-alpha.4 (2018-12-31)

Bug fixes

  • [all] Fix peer dependencies warnings (#957)

Improvements

  • [all] Use smaller version of the warning package (#953)
  • [all] Improve documentation (#958)
  • [internal] Upgrade lerna (#962)

10.0.0-alpha.3 (2018-12-26)

Bug fixes

  • [all] Fix building packages

10.0.0-alpha.2 (2018-12-26)

Bug fixes

  • [internal] Fix changelog.md

10.0.0-alpha.1 (2018-12-26)

Bug fixes

  • [jss] Fix class name white space escaping in dev mode (938)
  • [jss] Fix multiple cases where linking CSS rules didn't work (#815, #710, #664)
  • [jss] Fix sheet ordering when the last sheet was the last sibling in the head element (#819)
  • [jss-plugin-syntax-nested] Fix referencing rules inside media queries (#900)
  • [jss-plugin-syntax-global] Fix TypeError: Cannot read property '@global' of undefined (#905)

Improvements

  • [jss-starter-kit] Introduce jss-starter-kit.bundle.js, which packages all the other libraries into one import for playgrounds like Codepen. (#936)
  • [jss] Add support for Typed CSSOM values (#882)
  • [jss] Function values and function rules support now fallbacks, media queries, nesting, global styles (#682)
  • [react-jss] Remove old lifecycle hooks (#834)
  • [react-jss] Add flow types (#818)
  • [all] Migrate to a monorepo using yarn workspaces and lerna (#729)
  • [all][ts] Add TS definitions to all packages (#889)

Breaking changes

  • [jss] Observables, function values and rules are now standalone packages, not part of the core. They are still part of the default preset though.
  • [jss] Function values, rules and observables apply plugins by default now, which means they can support all plugin defined syntaxes, but they are also slower by default. To speed them up use sheet.update(data, {process: false}) for fn values/rules and jss.use(pluginObservable({process: false})) when setting up observables plugin. (#682)
  • [jss] Rule @keyframes has now scoped name by default, which means that you can access it using $ref from the same sheet and generate global one as before using @global rule (#346).
  • [jss] Add scoped keyframes support (#346)
  • [jss|react-jss] Options createGenerateClassName and generateClassName are renamed to createGenerateId and generateId because the same function is now used to scope @keyframes rules.
  • [react-jss] Drop support for older React versions, require v16.3 or higher (#868, #851)

Pre v10 changelogs