Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wix/stylable
Stylable - CSS for components
https://github.com/wix/stylable
components css design-system preprocessor style theme web-components webpack
Last synced: 5 days ago
JSON representation
Stylable - CSS for components
- Host: GitHub
- URL: https://github.com/wix/stylable
- Owner: wix
- License: mit
- Created: 2017-06-25T11:07:05.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-30T17:36:52.000Z (13 days ago)
- Last Synced: 2024-12-31T13:05:10.387Z (12 days ago)
- Topics: components, css, design-system, preprocessor, style, theme, web-components, webpack
- Language: TypeScript
- Homepage: https://stylable.io
- Size: 25.6 MB
- Stars: 1,270
- Watchers: 24
- Forks: 62
- Open Issues: 119
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome-list - stylable - CSS for components | wix | 1272 | (TypeScript)
README
[![Stand With Ukraine](https://raw.githubusercontent.com/vshymanskyy/StandWithUkraine/main/banner2-direct.svg)](https://stand-with-ukraine.pp.ua)
![Stylable CSS for Components](./stylable.svg)
[![Build Status](https://github.com/wix/stylable/workflows/tests/badge.svg)](https://github.com/wix/stylable/actions)
**Stylable** enables you to write reusable, highly-performant components. Each component exposes a style API that maps its internal parts so you can reuse components across teams without sacrificing stylability.
- Scopes styles to components so they don't "leak" and clash with other styles.
- Enables custom pseudo-classes and pseudo-elements that abstract the internal structure of a component. These can then be styled externally.
- Cuts down on the resulting CSS bundles using "rule-shaking" and other optimizationsAt build time, the preprocessor converts the Stylable CSS into a minimal, flat, static, valid vanilla CSS that works cross-browser.
Learn more in our [Documentation Center](https://stylable.io/).
## Installation
There are two options for installing Stylable:
- Create a new project using [create-stylable-app](./packages/create-stylable-app)
- Install Stylable and its [webpack plugin](./packages/webpack-plugin) to an existing webpack based projectFor details on both options, see [Install & Configure](https://stylable.io/docs/getting-started/install-configure).
## Demos
- [Mr. Potato Bruce](https://github.com/wix/potato-bruce) - A small application showcasing Stylable
- [Manual Vue Integration](https://github.com/wix-playground/stylable-vue-example) - Simple example showing how to manually integrate Stylable into a Vue project (proof of concept)
- [Various webpack project setups](./packages/webpack-plugin/test/e2e/projects) - An example of possible webpack configurations## Repository Structure
This repository is a `mono-repo` containing multiple `packages` that together comprise the Stylable ecosystem. It uses [NPM workspaces](https://docs.npmjs.com/cli/v8/using-npm/workspaces) to manage the various packages and their dependencies.
### Core & Internals
| Package Name | Published Name | Latest Version | Description |
| --------------------------------------- | ------------------------ | :-----------------------------------------------------------------------------------------------------------------------------: | ---------------------------------- |
| [core](./packages/core) | `@stylable/core` | [![npm version](https://img.shields.io/npm/v/@stylable/core.svg)](https://www.npmjs.com/package/@stylable/core) | Core CSS preprocessor |
| [runtime](./packages/runtime) | `@stylable/runtime` | [![npm version](https://img.shields.io/npm/v/@stylable/runtime.svg)](https://www.npmjs.com/package/@stylable/runtime) | Runtime browser code |
| [optimizer](./packages/optimizer) | `@stylable/optimizer` | [![npm version](https://img.shields.io/npm/v/@stylable/optimizer.svg)](https://www.npmjs.com/package/@stylable/optimizer) | Production mode optimizer |
| [module-utils](./packages/module-utils) | `@stylable/module-utils` | [![npm version](https://img.shields.io/npm/v/@stylable/module-utils.svg)](https://www.npmjs.com/package/@stylable/module-utils) | Stylable CommonJS module generator |
| [custom-value](./packages/custom-value) | `@stylable/custom-value` | [![npm version](https://img.shields.io/npm/v/@stylable/custom-value.svg)](https://www.npmjs.com/package/@stylable/custom-value) | Stylable custom build-time values |### Tooling & Utilities
| Package Name | Published Name | Latest Version | Description |
| ----------------------------------------------------- | ---------------------------- | :-------------------------------------------------------------------------------------------------------------------------------------: | ------------------------------------------------------------------------------------------ |
| [cli](./packages/cli) | `@stylable/cli` | [![npm version](https://img.shields.io/npm/v/@stylable/cli.svg)](https://www.npmjs.com/package/@stylable/cli) | Used for managing Stylable stylesheets in a project |
| [create-stylable-app](./packages/create-stylable-app) | `create-stylable-app` | [![npm version](https://img.shields.io/npm/v/create-stylable-app.svg)](https://www.npmjs.com/package/create-stylable-app) | Boilerplate generator CLI |
| [schema-extract](./packages/schema-extract) | `@stylable/schema-extract` | [![npm version](https://img.shields.io/npm/v/@stylable/schema-extract.svg)](https://www.npmjs.com/package/@stylable/schema-extract) | JSON Schema convertor for Stylable stylesheets |
| [language-service](./packages/language-service) | `@stylable/language-service` | [![npm version](https://img.shields.io/npm/v/@stylable/language-service.svg)](https://www.npmjs.com/package/@stylable/language-service) | Language service protocol provider, business logic for the stylable-intelligence extension |
| [build-tools](./packages/build-tools) | `@stylable/build-tools` | [![npm version](https://img.shields.io/npm/v/@stylable/build-tools.svg)](https://www.npmjs.com/package/@stylable/build-tools) | A collection of tools used during build-time by our `webpack` and `rollup` plugins |### Integrations
| Package Name | Published Name | Latest Version | Description |
| ----------------------------------------------------- | ------------------------------- | :-------------------------------------------------------------------------------------------------------------------------------------------: | ------------------------------------------------------------------ |
| [jest](./packages/jest) | `@stylable/jest` | [![npm version](https://img.shields.io/npm/v/@stylable/jest.svg)](https://www.npmjs.com/package/@stylable/jest) | Jest Stylable processor plugin |
| [node](./packages/node) | `@stylable/node` | [![npm version](https://img.shields.io/npm/v/@stylable/node.svg)](https://www.npmjs.com/package/@stylable/node) | `require` hook and Node module factory |
| [webpack-extensions](./packages/webpack-extensions) | `@stylable/webpack-extensions` | [![npm version](https://img.shields.io/npm/v/@stylable/webpack-extensions.svg)](https://www.npmjs.com/package/@stylable/webpack-extensions) | Experimental features for `webpack` integration |
| [webpack-plugin](./packages/webpack-plugin) | `@stylable/webpack-plugin` | [![npm version](https://img.shields.io/npm/v/@stylable/webpack-plugin.svg)](https://www.npmjs.com/package/@stylable/webpack-plugin) | `webpack` (`^5.30.0`) integration plugin |
| [experimental-loader](./packages/experimental-loader) | `@stylable/experimental-loader` | [![npm version](https://img.shields.io/npm/v/@stylable/experimental-loader.svg)](https://www.npmjs.com/package/@stylable/experimental-loader) | experimental `webpack` loader - not recommended for production use |
| [rollup-plugin](./packages/rollup-plugin) | `@stylable/rollup-plugin` | [![npm version](https://img.shields.io/npm/v/@stylable/rollup-plugin.svg)](https://www.npmjs.com/package/@stylable/rollup-plugin) | Rollup (`v2.x`) integration plugin |
| [esbuild](./packages/esbuild) | `@stylable/esbuild` | [![npm version](https://img.shields.io/npm/v/@stylable/rollup-plugin.svg)](https://www.npmjs.com/package/@stylable/esbuild) | esbuild integration plugin |### Test-kits
| Package Name | Published Name | Latest Version | Description |
| ----------------------------------------- | ------------------------- | :-------------------------------------------------------------------------------------------------------------------------------: | ------------------------------------------------------------------------------------ |
| [e2e-test-kit](./packages/e2e-test-kit) | `@stylable/e2e-test-kit` | [![npm version](https://img.shields.io/npm/v/@stylable/e2e-test-kit.svg)](https://www.npmjs.com/package/@stylable/e2e-test-kit) | `webpack` project runner used for `E2E` testing |
| [dom-test-kit](./packages/dom-test-kit) | `@stylable/dom-test-kit` | [![npm version](https://img.shields.io/npm/v/@stylable/dom-test-kit.svg)](https://www.npmjs.com/package/@stylable/dom-test-kit) | Stylable DOM related testing utils |
| [core-test-kit](./packages/core-test-kit) | `@stylable/core-test-kit` | [![npm version](https://img.shields.io/npm/v/@stylable/core-test-kit.svg)](https://www.npmjs.com/package/@stylable/core-test-kit) | Utilities used for testing core Stylable operations (processing and transformations) |### External Packages
| Package Name | Description |
| --------------------------------------------------------------------- | --------------------------------------------------------- |
| [stylable-intelligence](https://github.com/wix/stylable-intelligence) | VSCode extension providing language services for Stylable |## Contributing
Read our [contributing guidelines](./CONTRIBUTING.md) for details on our code of conduct, and the process for submitting pull requests.
## License
Copyright (c) 2017 Wix.com Ltd. All Rights Reserved. Use of this source code is governed by a [MIT license](./LICENSE).