@jabuco/typed-scss-modules
v0.2.0
Published
TypeScript type definition generator for SCSS CSS Modules
Downloads
3
Maintainers
Readme
🎁 typed-scss-modules
Generate TypeScript definitions (.d.ts
) files for CSS Modules that are written in SCSS (.scss
). Check out this post to learn more about the rationale and inspiration behind this package.
For example, given the following SCSS:
@import "variables";
.text {
color: $blue;
&-highlighted {
color: $yellow;
}
}
The following type definitions will be generated:
export const text: string;
export const textHighlighted: string;
Basic Usage
Run with npm package runner:
npx tsm src
Or, install globally:
yarn global add typed-scss-modules
tsm src
Or, install and run as a devDependency
:
yarn add -D typed-scss-modules
yarn tsm src
Advanced Usage
For all possible commands, run tsm --help
.
The only required argument is the directoy where all SCSS files are located. Running tsm src
will search for all files matching src/**/*.scss
. This can be overridden by providing a glob pattern instead of a directory. For example, tsm src/*.scss
--logLevel
(-v
)
- Type:
"verbose" | "info" | "minimal" | "error" | "silent"
- Default:
verbose
- Example:
tsm --logLevel silent src
Set the Log verbosity to a certain level to regulate its output.
--watch
(-w
)
- Type:
boolean
- Default:
false
- Example:
tsm --watch src
Watch for files that get added or are changed and generate the corresponding type definitions.
--watchTimeout
(-t
)
- Type:
number
- Default:
50
- Example:
tsm --watchTimeout 250 src
Wait x miliseconds before writing the changes when watching. This is useful if file access is slow.
--ignoreInitial
- Type:
boolean
- Default:
false
- Example:
tsm --watch --ignoreInitial src
Skips the initial build when passing the watch flag. Use this when running concurrently with another watch, but the initial build should happen first. You would run without watch first, then start off the concurrent runs after.
--includePaths
(-i
)
- Type:
string[]
- Default:
[]
- Example:
tsm --includePaths src/core -- src
An array of paths to look in to attempt to resolve your @import
declarations. This example will search the src/core
directory when resolving imports.
--aliases
(-a
)
- Type:
object
- Default:
{}
- Example:
tsm --aliases.~some-alias src/core/variables -- src
An object of aliases to map to their corresponding paths. This example will replace any @import '~alias'
with @import 'src/core/variables'
.
--aliasPrefixes
(-p
)
- Type:
object
- Default:
{}
- Example:
tsm --aliasPrefixes.~ node_modules/ -- src
An object of prefix strings to replace with their corresponding paths. This example will replace any @import '~bootstrap/lib/bootstrap'
with @import 'node_modules/bootstrap/lib/bootstrap'
.
This matches the common use-case for importing scss files from node_modules when sass-loader
will be used with webpack
to compile the project.
--nameFormat
(-n
)
- Type:
"camel" | "kebab" | "param" | "dashes" | "none"
- Default:
"camel"
- Example:
tsm --nameFormat camel src
The class naming format to use when converting the classes to type definitions.
- camel: convert all class names to camel-case, e.g.
App-Logo
=>appLogo
. - kebab/param: convert all class names to kebab/param case, e.g.
App-Logo
=>app-logo
(all lower case with '-' separators). - dashes: only convert class names containing dashes to camel-case, leave others alone, e.g.
App
=>App
,App-Logo
=>appLogo
. Matches the webpack css-loader camelCase 'dashesOnly' option. - none: do not modify the given class names (you should use
--exportType default
when using--nameFormat none
as any classes with a-
in them are invalid as normal variable names). Note: If you are using create-react-app v2.x and have NOT ejected,--nameFormat none --exportType default
matches the class names that are generated in CRA's webpack's config.
--listDifferent
(-l
)
- Type:
boolean
- Default:
false
- Example:
tsm --listDifferent src
List any type definition files that are different than those that would be generated. If any are different, exit with a status code 1
.
--exportType
(-e
)
- Type:
"named" | "default"
- Default:
"named"
- Example:
tsm --exportType default src
The export type to use when generating type definitions.
named
Given the following SCSS:
.text {
color: blue;
&-highlighted {
color: yellow;
}
}
The following type definitions will be generated:
export const text: string;
export const textHighlighted: string;
default
Given the following SCSS:
.text {
color: blue;
&-highlighted {
color: yellow;
}
}
The following type definitions will be generated:
export interface Styles {
text: string;
textHighlighted: string;
}
export type ClassNames = keyof Styles;
declare const styles: Styles;
export default styles;
This export type is useful when using kebab (param) cased class names since variables with a -
are not valid variables and will produce invalid types or when a class name is a TypeScript keyword (eg: while
or delete
). Additionally, the Styles
and ClassNames
types are exported which can be useful for properly typing variables, functions, etc. when working with dynamic class names.
Examples
For examples, see the examples
directory:
Contributors ✨
Thanks goes to these wonderful people (emoji key):
This project follows the all-contributors specification. Contributions of any kind welcome!
Alternatives
This package was heavily influenced on typed-css-modules which generates TypeScript definitions (.d.ts
) files for CSS Modules that are written in CSS (.css
).
This package is currently used as a CLI. There are also packages that generate types as a webpack loader.