6.0.2 • Published 1 month ago

@stylable/runtime v6.0.2

Weekly downloads
6,818
License
MIT
Repository
github
Last release
1 month ago

@stylable/runtime

npm version

@stylable/runtime provides the utility that is used to create the stylesheet functions that apply classNames and states to the DOM. It also exposes an optional DOM renderer that is responsible for loading CSS in its correct order.

End-users will usually not add this package directly as a dependency themselves, and would instead receive it as a dependency of their chosen integration (e.g. @stylable/webpack-plugin).

Usage

@stylable/runtime exposes two methods, Stylesheet and Renderer.

Stylesheet

When importing a Stylable stylesheet, there are multiple named exports that are exposed for usage.

import { 
    style, 
    classes, 
    vars, 
    stVars, 
    keyframes, 
    layers, 
    containers, 
    cssStates 
} from './local.st.css';
Import nameDescription
styleutility function that returns a string to be used as a node class name for classes and states passed to it
classesan object mapping exported classes from their source name to their scoped name
varsan object mapping exported css custom properties (vars) from their source name to their scoped name
stVarsan object mapping build time Stylable variables to their build time values (these cannot be overridden in runtime)
keyframesan object mapping exported keyframes from their source name to their scoped name
layersan object mapping exported layers from their source name to their scoped name
containersan object mapping exported containers from their source name to their scoped name
cssStatesutility function that maps an object representing states and their values to a string with all required classes

Style utility function

The style function is useful for creating the root node of you component, passing along classes passed through props, or whenever a state is being defined.

style(
    contextClassName: string, stateOrClass: string | StateMap, ...classes: string[]
)
ArgumentTypeDescriptionRequired
contextClassNamestringclassName to be namespacedtrue
stateOrClassStateMap | stringeither an object containing states and their values, or a class stringfalse
classesstringany other argument passed will represent a classes that should be applied. In any root node of a component, props.className should be passed along to maintain external customizationfalse
import { style, classes } from './local.st.css';

// properties passed to the component externally
props = { className: "app__root app--propstate" };

// The classes export exposes a map of classNames and their namespaced values.
classes.root;
// returns "local__root"

<div className={style(classes.root)} />
// becomes <div className="local__root" /> 

<div className={style(classes.root, { localState: true })} />
// becomes <div className="local__root local--localstate" /> 

<div className={style(classes.root, { localState: true }, props.className)} />
// becomes <div className="local__root local--localstate app__root app--propstate" /> 

<div className={style(classes.root, 'global-class', props.className)} />
// becomes <div className="local__root global-class app__root app--propstate" /> 

<div className={classes.part} />
// becomes <div className="local__part" /> 

Renderer

Responsible for managing CSS files, linking to the document and maintaining their correct order in your application.

TypeScript integration

When importing a Stylable stylesheet in TypeScript, a global module declaration needs to be defined in order to not receive type errors about unknown imports.

Add the following file to your /src directory.

// globals.d.ts
declare module '*.st.css' {
    export * from '@stylable/runtime/stylesheet';

    const defaultExport: unknown;
    export default defaultExport;
}

License

Copyright (c) 2017 Wix.com Ltd. All Rights Reserved. Use of this source code is governed by a MIT license.

6.0.2

1 month ago

6.0.1

2 months ago

6.0.0

2 months ago

5.19.0

3 months ago

5.18.1

3 months ago

6.0.0-rc.3

4 months ago

5.18.0

4 months ago

5.15.0

10 months ago

5.16.1

8 months ago

5.16.0

8 months ago

6.0.0-rc.1

7 months ago

5.17.0

6 months ago

6.0.0-rc.2

7 months ago

5.14.0

11 months ago

5.15.2

8 months ago

5.15.1

10 months ago

5.11.1

12 months ago

5.12.0

11 months ago

5.13.0

11 months ago

5.11.0

1 year ago

5.9.0

1 year ago

5.10.0

1 year ago

5.8.0

1 year ago

5.7.1

1 year ago

5.7.0

1 year ago

5.4.1-rc.1

1 year ago

5.5.0

1 year ago

5.6.1

1 year ago

5.6.0

1 year ago

5.3.0

2 years ago

5.4.0

1 year ago

5.3.0-rc.1

2 years ago

5.3.1-rc.1

2 years ago

5.2.1

2 years ago

4.14.1

2 years ago

4.14.2

2 years ago

5.0.0-rc.3

2 years ago

5.0.0-rc.4

2 years ago

5.0.0-rc.5

2 years ago

4.14.0

2 years ago

5.0.1

2 years ago

4.13.3

2 years ago

5.0.0

2 years ago

5.1.0

2 years ago

5.2.0

2 years ago

4.15.0

2 years ago

4.15.1

2 years ago

5.0.0-rc.1

2 years ago

5.0.0-rc.2

2 years ago

4.13.2

2 years ago

4.13.1

2 years ago

4.13.0

2 years ago

4.12.0

2 years ago

4.11.0

2 years ago

4.10.4

2 years ago

4.10.1

2 years ago

4.10.2

2 years ago

4.10.3

2 years ago

4.10.0

2 years ago

4.9.4

2 years ago

4.9.3

2 years ago

4.9.5

2 years ago

4.9.0

2 years ago

4.9.2

2 years ago

4.9.1

2 years ago

3.13.2

2 years ago

4.8.3

3 years ago

4.8.0

3 years ago

4.7.4

3 years ago

4.7.3

3 years ago

4.7.2

3 years ago

3.13.0

3 years ago

4.7.0

3 years ago

4.6.0

3 years ago

4.5.1

3 years ago

4.5.0

3 years ago

4.4.0

3 years ago

4.3.3

3 years ago

4.3.1

3 years ago

4.3.0

3 years ago

4.2.5

3 years ago

4.2.4

3 years ago

4.2.3

3 years ago

4.2.2

3 years ago

4.2.1

3 years ago

4.2.0

3 years ago

4.1.1

3 years ago

4.1.0

3 years ago

4.0.6

3 years ago

3.12.4

3 years ago

4.0.4

3 years ago

3.12.3

3 years ago

4.1.0-alpha.3

3 years ago

4.1.0-alpha.1

3 years ago

4.1.0-alpha.0

3 years ago

4.1.0-alpha.2

3 years ago

4.0.2

3 years ago

3.12.2

3 years ago

3.12.1

3 years ago

4.0.1

3 years ago

3.12.0

3 years ago

4.0.0

3 years ago

3.11.14

3 years ago

4.0.0-alpha.10

3 years ago

4.0.0-alpha.9

3 years ago

4.0.0-alpha.7

3 years ago

3.11.13

3 years ago

4.0.0-alpha.6

3 years ago

4.0.0-alpha.5

3 years ago

3.11.10

3 years ago

4.0.0-alpha.4

3 years ago

3.11.9

3 years ago

4.0.0-alpha.3

3 years ago

4.0.0-alpha.1

3 years ago

4.0.0-alpha.2

3 years ago

4.0.0-alpha.0

3 years ago

3.11.8

3 years ago

3.11.6

3 years ago

3.11.7

3 years ago

3.11.5

4 years ago

3.11.2

4 years ago

3.11.1

4 years ago

3.11.0

4 years ago

3.10.0

4 years ago

3.9.0

4 years ago

3.8.4

4 years ago

3.8.1

4 years ago

3.8.0

4 years ago

3.7.0

4 years ago

3.6.2

4 years ago

3.6.1

4 years ago

3.6.0

4 years ago

3.5.2

4 years ago

3.5.0

4 years ago

3.4.5

4 years ago

3.4.4

4 years ago

3.4.3

4 years ago

3.4.2

4 years ago

3.4.1

4 years ago

3.4.0

4 years ago

3.3.2-rc.1

4 years ago

1.4.0

4 years ago

3.2.0

4 years ago

3.1.4

4 years ago

3.1.3

4 years ago

3.1.1

4 years ago

3.1.0

4 years ago

3.0.0

4 years ago

2.5.3

4 years ago

1.3.1

4 years ago

2.5.2

4 years ago

2.5.0

5 years ago

2.5.0-alpha.1

5 years ago

2.5.0-alpha.0

5 years ago

2.4.1

5 years ago

2.4.1-alpha.1

5 years ago

2.4.1-alpha.0

5 years ago

2.4.0

5 years ago

2.3.3-alpha.1

5 years ago

2.3.3-alpha.0

5 years ago

2.3.2

5 years ago

2.3.1

5 years ago

2.3.1-alpha.0

5 years ago

2.3.0

5 years ago

2.1.4-alpha.1

5 years ago

2.1.4-alpha.0

5 years ago

2.1.3

5 years ago

2.1.1

5 years ago

2.1.0

5 years ago

2.0.6

5 years ago

2.0.5

5 years ago

2.0.4

5 years ago

2.0.3

5 years ago

2.0.2

5 years ago

2.0.1

5 years ago

2.0.0

5 years ago

1.0.4

5 years ago

1.0.3

5 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.2.0-alpha.0

5 years ago

0.1.13

5 years ago

0.1.12

5 years ago

0.1.11

5 years ago

0.1.10

5 years ago

0.1.9

6 years ago

0.1.8

6 years ago

0.1.7

6 years ago

0.1.5

6 years ago

0.1.4

6 years ago

0.1.3

6 years ago

0.1.2

6 years ago