- Fix multiple cases where linking CSS rules didn't work (#815, #710, #664)
- Fix
global
access in the dist version (#736)
- Remove type attribute from style element (#724)
- Fix version in the dist version (#730)
- Add link to the egghead course
- Upgrade prettier and format code (#726)
- Fix CSSOM local typings (flow stopped looking into node_modules if types are not imported directly since v0.57.0)
- Fixed typings for RuleList.update method.
- Migrated from webpack to rollup.
- Upgraded to flow 0.72
- Upgrade to flow 0.68.0
- Remove hyphenation from the core, moved it to jss-camel-case. Now any function values and
rule.prop()
will get hyphenation automatically.
- Allow function values return falsy values in order to remove a property.
- Added prettier
- Added a new, correct way of handling CSP
- Added postinstall script with donation log.
- Export
toCssValue
utility function for css-vendor package.
- Added array values support when used with function values. It now also supports priority option "!important" (#629)
- Use classNamePrefix option in production mode (#638)
- Added onUpdate to docs and types, now officially supported
- Fixed class names collisions with multiple jss instances (#644)
- Added CSS.escape fallback, so that polyfill is not required.
- Don't put escaped class names into classes hash
- Never use window object directly
- Add CSS class name escaping for dev mode also we support emoji now! (#624)
- Added CSP over webpack (#559)
- Allow empty rules when option {link: true} is used.
- Simplify internal logic for function values.
- Introduce function rules - similar to function values, now function can return the entire style object.
- Added Observable rules. Now not only values can be an observable, but also the entire style object.
- Added
SheetsManager.size
getter to get amount of items inSheetsManager
. - Refactored
StyleRule.selector
for better performance. Breaking change - it doesn't reregister rule in the classes map any more. It was used mainly in jss-isolate (#419). - Method
jss.setup()
can now be called multiple times and will merge properly the options. Also it will avoid applying same plugins more than once by comparing the reference (#576). - Fixed linker, which didn't work if selectors were escaped (#557).
- In production
createGenerateClassName()
option will now produce short selectors and warn about memory leaks. (#546) - Update flow to v0.54.1.
- Support observable values (#442).
- Warn when dynamic properties update but link: true option is not set (#581)
- Added webpackbin examples
- Added size-limit tool
- Added SheetsManager
- Option
insertionPoint
can now accept a DOM node - DOM node provided in
insertionPoint
can be inside of an iframe. - Warn when an
insertionPoint
was specified but not found in the DOM.
- Option
generateClassName
which was used in Jss constructor andJss.setup
has been removed. A new option is calledcreateGenerateClassName
which is a factory that returns the oldgenerateClassName
. We need this to reset counters on SSR for each request. - Removed default
insertionPoint
value ("jss") in order to have warnings when insertionPoint is not found in the DOM. With the default one we simply don't know when to warn.
- KeyframeRule has been renamed to KeyframesRule.
- KeyframeRule.type === 'keyframe' => KeyFrames.type === 'keyframes'.
- RegularRule has been renamed to StyleRule
- RegularRule.type === 'regular' => StyleRule.type === 'style'.
- RegularRule.name => RegularRule.key
- ConditionalRule.selector => ConditionalRule.key
- FontFaceRule.selector => FontFaceRule.key
- SimpleRule.name => SimpleRule.key
- ViewportRule.name => ViewportRule.key
- RulesContainer => RuleList
- Fix CSS flow types
- Fix dynamic values for conditional and keyframe rules
- Prevent duplicates in the sheets registry (#504)
- Optimize
sheets.add
for a big registry
- Fixed undefined rule support (#489)
- Fixes flow error when updating to the latest version (#507)
- Fixes createStyleSheet type definitions error (#495)
- Fixes function values for for nested rules (#500)
- Fixes function values within keyframes (#471)
- Fixes rendering rules with function values only (#475)
- Support updating specific rule in
sheet.update(name, data)
- Fix a bug when dynamically inserted rules disapeared after reattaching the sheet (#438)
- Remove temporarily jss-isolate from the tests
- Fix
getDynamicStyles
when nested object is in the same styles object (#467)
- Perf improvement through removing of JSON.parse(JSON.stringify(style))
- New hook
onProcessStyle
- New hook
onChangeValue
- Run plugins over property names with function values (#441)
- Function values inside of nested rules (#445)
- New signature of
generateClassName(rule, sheet)
option. - Property
rule.originalStyle
is now available throughrule.options.parent.rules.raw[rule.name]
. It is longer but its a better place and is used in plugins only. - Plugin signature for the hook
onProcessRule
shortcutjss.use((rule) => {})
is not supported any more. Instead this hook is supported using its full name:jss.use({onProcessRule: () => {}})
- Dynamic Sheets for theming and animations. #356
- Reintroduced counter based class generation algorithm. #432
- Introduced new option
insertionPoint
. - Reduced amount of files in the package, dropped .npmignore file.
- Removed babel-runtime from the build.
- Added a new hook
onProcessSheet
. - Started a list of companies/products using JSS, see docs/users.md
- Added @viewport and @-ms-viewport support (used in bootstrap).
- Allow sheet.link() call when VirtualRenderer is used.
- Add jss-cache to the tests suit.
- Don't run processors on a rule which has been processed already.
- Add test for onCreateRule arguments.
- Add sheet as a second argument to the onProcessRule hook.
- Call
onCreateRule
for every rule type. - RulesContainer is now exported for the plugins.
- Using babel-runtime for the lib build now.
- Using webpack 2 now.
- Preparation for the bugfix - nesting within @global (#380)
- Preparation for the bugfix - nested @media inside of a rule inside of @global (#387).
- Don't insert empty rules #363.
- Added flow types.
- Added a new plugins API. It is backwards compatible. See plugins section.
- Perf improvements.
- Option "named" has been removed from JSS core and replaced by a jss-global plugin. From now on global styles are only possible using that plugin.
- Sheets are not added to the sheets registry automatically server-side any more. In order to prevent leaking styles between requests, you now need to create your own SheetsRegistry instance and add sheets to it manually. Make sure to create a new instance for each request. On the client, sheets are still automatically added to the registry.
- test suite
- new is-in-browser detection #305
- warning when using an unknown at-rule
- start using flow #296
- remove rewire from build
- update roadmap
- always use
cssRules.insertRule
when using addRule on attached sheet, mixing them results in weird overwrite of a rule added by insertRule by a media query rendered using text node. - catch errors from
cssRules.insertRule
and use a warning in development
- add edge browser for browserstack
- fix addRule insertion order from plugins when sheet is attached
- fix @media insertion in IE
- Skip empty values #307
- Fix adding rules during the plugins loop
- Fix wrong order of nested rules #285
- Add
index
option tosheet.addRule
which allows to specify the order or added rules - Add
<style>
node position control optionindex
and insertion point comment - Better browser detection by using
is-browser
package
- More docs
- More benchmarks
- Make sheet.addRule accept options
- Added
jss.setup
method which accepts options like the contructor and can be used for presets - Docs
- Create Rodamap
- Cleanup DomRenderer from IE8 code.
- Fix benchmark, use a new jss instance, because there is sheets registry
- Added
sheet.deleteRule
#266
- alternative syntax for space and comma separated values #264
- new fallbacks api #256
- rule.applyTo doesn't support fallbacks any more
- support conditionals overwrite upfront #259, #180
- remove compatibility fix for babel 5, now you need to use
var jss = require('jss').default
in ES5
- fixed bug when plugins called twice on createStyleSheet #258
- enable node 7 #248
- allow adding rules to a detached sheet #253
- fix jss.version in lib
- user defined classname generation function
- deterministic class names generation
- run plugins separately when creating rules in a batch
- register children of a conditional in sheet.classes #81
- added option element to .createStyleSheet #231
- fix multiple @imports
- added benchmarks
- rewrote all tests with mocha
- fix multiple @media in one sheet
- update linter eslint-config-jss@1.0.0
- added jss.version to the build (Daijiro Wachi)
- docs
- font-face rule can now handle array of font-faces (Ken Carpenter)
- fix rule registration in style sheet, previous commits resulted in a selector instead of class nem within sheet.classes map.
- register rule when changed worked by setting selector
- Update StyleSheet#rules when modifying selector
- implement selector setter, now Rule#selector can be set, due to the fact not every browser implements selectorText setter, the entire sheet will be rerendered in such browsers. Should be used with caution.
- fixed breaking change, which made exports of 3.4.0 incompatible with 3.3.0
- fix font-face rule type
- added style sheets registry accesible via jss.sheets
- updated babel to version 6
- fixed bug: nested rule inside of a @media conditional
- new docs
- trim empty rules (@wldcordeiro)
- support node 5 (@nikgraf)
- jss-debug is deprecated, rule name is inside of generated class name now
- no more "type" option for style sheet, its always set to text/css
- no more "title" option for style sheet, its not a part of the spec http://www.w3.org/TR/html-markup/style.html
- added meta option, now you can for e.g. set the name of your component and find it on style element.
- fixed bug when multiple conditionals used in one sheet
- added Rule#originalStyle property to access original style object from a plugin
- new testing infrastructure with browserstack and codeship
- internal rewrite for cleaner code (ConditionalRule, KeyframeRule, SimpleRule)
- moved all DOM related methods to dom.js module
- now child rules exist only in ConditionalRule, simplified Rule and StyleSheet logic
- fixed Named rules not generating when using @media only #81
- added support for @charset, @import, @namespace, @supports
- removed jss.Rule from public access, use jss.createRule() instead
- removed jss.Jss from public access, use jss.create() instead
- removed jss.StyleSheet from public access, use jss.createStyleSheet() instead
- remove bower.json
- remove dist from repository
- add dist to npm package
- add cdnjs support
- remove xpkg, update npmignore and ingore list for bower
- reference rule name on the rule instance to fix jss-debug
- use eslint-config-jss
- migrate to es6
- move examples to jss-examples repository
- remove @media from classes hash
- added support for named at-rules e.g. @media
- removed invalid characters
- stop mutating original rules passed by user. expecting style to be a plaing object.
- add internal method uid.reset() for testing
- rename global reference to globalReference
- avoid conflicts of jss ids when multiple jss versions are used on the same page
- remove browser field from package.json, it makes webpack use dist version instead of src.
- create Jss constructor so that we can have multiple jss instances with different plugins, needed when you want to reuse jss lib from different standalone components which have own jss configuration and should not clash.
- create jss-cli package, remove bin script from jss
- fix bower package name
- make change condition to include any non-null value in Rule#prop (Stephen Saunders)
- remove NO-BREAK SPACE chars
- add rule.toJSON()
- support any node version above 0.8
- allow rule options to be passed in internal rule#addRule method to allow nested rules to have different options than parent one (for now just "named")
- pass rule name to make debug plugin possible
- fix duplicated rule rendering
- run plugins on inner rules of at-rules
- styles have named: true option by default, this is backwards incompatible
- at-rules like @media can now also have named rules
- fixed #40 there is no colons in all at-rules with nested declarations
- fixed firefox issues
- added rule.prop() for dynamic rule properties #15
- added Rule#prop() for setting and getting rule props dynamically
- added
link
option in order to make .prop() work but still without to add perf overhead by default. - added example for .prop()
- added build for "support non browser env #12"
- added calendar example
- supported non browser env #12
- renamed Stylesheet to StyleSheet because its wrong.
- moved jss to separate github organization
- moved all plugins to separate repositories (don't force people use plugins they don't need)
- renamed processors to plugins
- added public .use function for registering plugins
- supported multiple declarations with identical property names #22
- supported nested rules when using .addRule method #20
- rewrittn prefixer for feature testing using camel cased version because of firefox
- added vendor prefixes plugin for properties #21
- supported nested extend
- added more complex topcoat example
- added @keyframes and @media support #16
- added possibility write multi nested selector in one line #18
- added @font-face to cli converter
- added @keyframes to cli converter
- createed perf comparence for bootstrap #13
- createed css->jss converter #11
- made tests runnable from githubs gh-pages http://jsstyles.github.io/jss/test/
- fixed test failing in firefox #14
- Renamed param "generateClasses" to "named" in createStyleSheet
- If
named
is true, ss.rules[name] is accessible using the name. - ss.addRules will render new rules after style element has been rendered too.
- document ss.addRules
First official release.