From 1325f46a8f8a1708815cfbe80490cbe2208ac7cf Mon Sep 17 00:00:00 2001 From: Justin Fagnani Date: Mon, 1 Jul 2024 17:11:04 -0700 Subject: [PATCH 1/3] Add language-specific note about TypeScript decorators. --- packages/lit-dev-content/site/css/global.css | 10 ++++++++++ .../site/docs/v3/components/overview.md | 13 +++++++++++++ 2 files changed, 23 insertions(+) diff --git a/packages/lit-dev-content/site/css/global.css b/packages/lit-dev-content/site/css/global.css index e802d7bcb..2efc986ed 100644 --- a/packages/lit-dev-content/site/css/global.css +++ b/packages/lit-dev-content/site/css/global.css @@ -80,3 +80,13 @@ a { height: 1px; overflow: hidden; } + +body[code-language-preference="ts"] [code-language]:not([code-language="ts"]) { + /* Hide JS content when preference is TS. */ + display: none; +} + +body[code-language-preference="js"] [code-language]:not([code-language="js"]) { + /* Hide TS content when preference is JS. */ + display: none; +} \ No newline at end of file diff --git a/packages/lit-dev-content/site/docs/v3/components/overview.md b/packages/lit-dev-content/site/docs/v3/components/overview.md index c365610e2..c6af5978d 100644 --- a/packages/lit-dev-content/site/docs/v3/components/overview.md +++ b/packages/lit-dev-content/site/docs/v3/components/overview.md @@ -26,3 +26,16 @@ Creating a Lit component involves a number of concepts: Here's a sample component: {% playground-example "v3-docs/components/overview/simple-greeting" "simple-greeting.ts" %} + +
+ +{% aside "info"%} + +This example uses TypeScript decorators. + +See the [Decorators](/docs/components/decorators) documentation for more information on configuring TypeScript for decorators. + +{% endaside %} + +
+ From 6b916de082a4bd777e6726ff327880f4411705f9 Mon Sep 17 00:00:00 2001 From: Justin Fagnani Date: Mon, 1 Jul 2024 17:43:28 -0700 Subject: [PATCH 2/3] Use v3 link --- packages/lit-dev-content/site/docs/v3/components/overview.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/lit-dev-content/site/docs/v3/components/overview.md b/packages/lit-dev-content/site/docs/v3/components/overview.md index c6af5978d..9428d4981 100644 --- a/packages/lit-dev-content/site/docs/v3/components/overview.md +++ b/packages/lit-dev-content/site/docs/v3/components/overview.md @@ -33,9 +33,8 @@ Here's a sample component: This example uses TypeScript decorators. -See the [Decorators](/docs/components/decorators) documentation for more information on configuring TypeScript for decorators. +See the [Decorators](/docs/v3/components/decorators) documentation for more information on configuring TypeScript for decorators. {% endaside %} - From eec82d72eee3b959df14dd02a187d5a2447341b9 Mon Sep 17 00:00:00 2001 From: Justin Fagnani Date: Mon, 1 Jul 2024 17:38:40 -0700 Subject: [PATCH 3/3] Add more details to the TypeScript docs --- .../site/docs/v3/tools/development.md | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/packages/lit-dev-content/site/docs/v3/tools/development.md b/packages/lit-dev-content/site/docs/v3/tools/development.md index 43eea8a59..226e94c41 100644 --- a/packages/lit-dev-content/site/docs/v3/tools/development.md +++ b/packages/lit-dev-content/site/docs/v3/tools/development.md @@ -202,12 +202,23 @@ For full installation and usage instructions, see the [Web Dev Server documentat ## TypeScript { #typescript } -TypeScript extends the Javascript language by adding support for types. Types are useful for catching errors early and making code more readable and understandable. +Lit support developing components in TypeScript, including full type declarations for the Lit APIs, standard and experimental decorators, and community tools for template type-checking and linting. + +Because Lit is just a library, and doesn't require a compiler or use non-standard langauge syntax, there are no specific TypeScript tools that are required. Lit works with the official TypeScript compiler, `tsc`, with TypeScript wrappers such as those for Rollup, Vite, or Webpack, and alternate compilers like `esbuild`. + +The main requirements of a TypeScript project are: +- Enabling a modern JavaScript language level, like with the `"ES2021"` [lib](https://www.typescriptlang.org/tsconfig/#lib). +- Enabling the DOM types with the `"DOM"` [lib](https://www.typescriptlang.org/tsconfig/#lib). +- Optionally [enabling experimental decorators](https://www.typescriptlang.org/tsconfig/#experimentalDecorators) and [disabling "define" semantics for class fields](https://www.typescriptlang.org/tsconfig/#useDefineForClassFields), if you choose to use TypeScript's experimental decorators. + +These options are generally set in your project's tsconfig. + +### Installation To install TypeScript in your project: ```bash -npm install typescript --save-dev +npm i -D typescript ``` To build the code: @@ -218,6 +229,10 @@ npx tsc --watch For full installation and usage instructions, see the [TypeScript site](https://www.typescriptlang.org/). To get started, the sections on [installing TypeScript](https://www.typescriptlang.org/docs/handbook/typescript-tooling-in-5-minutes.html) and [using its features](https://www.typescriptlang.org/docs/handbook/typescript-in-5-minutes.html) are particularly helpful. +### Decorators + +TypeScript supports two versions of decorators: experimental and standard. See our [Decorators](/docs/v3/components/decorators/#decorators-typescript) documentation for more information. + ## JavaScript and TypeScript linting { #linting } Linting can help catch errors in your code. We recommend using [ESLint](https://eslint.org) for linting Lit code.