TypeScript config
User guide
- Getting Started
Api
Concepts
Configurations
Configuring webhint
Connectors
Development flow integration
Extensions
Formatters
Hints
- Avoid CSS limits
- Avoid HTTP redirects
- axe accessibility check
- Babel configuration hint set
- Compatibility of CSS, HTML and JavaScript features
- Correct `Content-Type` header
- Correct manifest extension
- Correct viewport
- Detect CSS Reflows
- Disallowed HTTP headers
- External links disown opener
- Has web app manifest
- Highest document mode
- HTTP cache
- Leading '.' in `classList.add` or `classList.remove`
- Manifest has name
- Minify JavaScript
- Modern DOCTYPE
- No `createElement` with SVG
- No `P3P` headers
- No broken links
- No byte-order mark
- No Inline CSS Styles
- No protocol-relative URLs
- No small error pages
- No vulnerable libraries
- Nu HTML test
- Optimal compression
- Optimize images
- Performance budget
- Prefixed CSS first
- scoped-svg-styles
- Specify button type
- SSL server test
- TypeScript configuration hints set
- Unneeded HTTP headers
- Use `Strict-Transport-Security` header
- Use `X-Content-Type-Options` header
- Use Apple touch icon
- Use charset `utf-8`
- Use HTTPS
- Use subresource integrity
- Valid `Set-Cookie` header
- Valid `theme-color`
- Valid manifest
- webpack configuration hints set
Parsers
Server configurations
Troubleshoot
- Api
- Concepts
- Configurations
- Configuring webhint
- Connectors
- Development flow integration
- Extensions
- Formatters
- Hints
- Parsers
- Server configurations
- Troubleshoot
TypeScript config (@hint/parser-typescript-config
)
The typescript-config
parser allows the user to analyze the
TypeScript configuration in their projects.
It will detect if a TypeScript configuration file is present in
your project, checking the name of the file (i.e. tsconfig.json
,
tsconfig.developement.json
). This parser detects if a config file
has a valid content.
This package is installed automatically by webhint:
npm install hint --save-dev |
To use it, activate it via the .hintrc
configuration file:
{
"connector": {...},
"formatters": [...],
"hints": {
...
},
"parsers": ["typescript-config"],
...
} |
Note: The recommended way of running webhint is as a devDependency
of
your project.
Events emitted
This parser
emits the following events:
parse::start::typescript-config
, of typeTypeScriptConfigParseStart
which contains the following information:resource
: the resource we are going to parse.
parse::end::typescript-config
, of typeTypeScriptConfigParse
which contains the following information:resource
: the parsed resource.getLocation
: helper to find the location of a path within the original JSON source.config
: the final configuration after adding default values (TypeScriptConfig
).mergedConfig
: the merged configuration after inliningextends
.originalConfig
: the original configuration before resolvingextends
.
parse::error::typescript-config::json
, of typeTypeScriptConfigInvalidJSON
which contains the following information:resource
: the parsed resource.error
: the error emited parsing the configuration file.
parse::error::typescript-config::cicular
, of typeTypeScriptConfigInvalidJSON
which contains the following information:resource
: the parsed resource.error
: the error emited parsing the configuration file.
parse::error::typescript-config::extends
, of typeTypeScriptConfigInvalidJSON
which contains the following information:resource
: the parsed resource.error
: the error emited parsing the configuration file.
parse::error::typescript-config::schema
, of typeTypeScriptConfigInvalidSchema
which contains the following information:resource
: the parsed resource.errors
: all the errors that the schama validator returns.
Types
If you need to import any type or enum defined in this parser, you need to import them as follows:
import { TypeOrEnumYouWantToUse } from '@hint/parser-typescript-config'; |