Skip to content

Commit

Permalink
[article] Create a lit cheat sheet
Browse files Browse the repository at this point in the history
  • Loading branch information
e111077 committed Dec 30, 2024
1 parent 42d1ed5 commit e52fd31
Show file tree
Hide file tree
Showing 175 changed files with 3,745 additions and 35 deletions.
10 changes: 10 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 2 additions & 1 deletion packages/lit-dev-content/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -180,14 +180,15 @@
"rollup-plugin-minify-html-literals": "^1.2.6",
"rollup-plugin-summary": "^1.2.3",
"rollup-plugin-terser": "^7.0.2",
"signal-utils": "^0.21.1",
"slugify": "^1.3.6"
},
"dependencies": {
"@lit-labs/context": "^0.4.1",
"@lit-labs/motion": "^1.0.1",
"@lit-labs/react": "^1.0.8",
"@lit-labs/task": "^3.0.2",
"@lit-labs/signals": "^0.1.1",
"@lit-labs/task": "^3.0.2",
"@lit/context": "^1.1.0",
"@lit/localize": "^0.10.0",
"@lit/react": "^1.0.0 || 1.0.0-pre.0",
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { html, LitElement, css } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
render() {
return html`<p>I'm blue</p><div>I'm red</div>`;
}

static styles = css`
p {
color: blue;
}
div {
color: red;
}
`;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import { html, LitElement } from 'lit';
import { customElement, property } from 'lit/decorators.js';
import { html as staticHTML, StaticValue } from 'lit/static-html.js';

@customElement('input-or-textfield')
export class MyElement extends LitElement {
// attribute is false because this is a value that can't be serialized to an
// HTML attribute
@property({ attribute: false }) tagLiteral: StaticValue|null = null;
@property() value = '';

render() {
return html`
${
staticHTML`
<${this.tagLiteral}
@input=${this.#onInput}
.value=${this.value}></${this.tagLiteral}>
`
}
<div>
The value of the input is: ${this.value}
</div>
`;
}

#onInput(e: InputEvent) {
this.value = (e.target as (HTMLInputElement | HTMLTextAreaElement)).value;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
import { css, html, LitElement } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { literal } from 'lit/static-html.js';
import './input-or-textfield.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() tagLiteral = literal`input`;
render() {
return html`
<!-- /* playground-fold */ -->
<fieldset>
<legend>Choose a tag to render:</legend>
<div>
<label>
<input
type="radio"
name="selection"
@change=${this.#onChange}
value="input"
checked>
input
</label>
</div>
<div>
<label>
<input
type="radio"
name="selection"
@change=${this.#onChange}
value="textarea">
textarea
</label>
</div>
</fieldset>
<!-- /* playground-fold-end */ -->
<input-or-textfield
value="this is the default value"
.tagLiteral=${this.tagLiteral}>
</input-or-textfield>
`;
}

#onChange(e: InputEvent) {
const target = e.target as HTMLInputElement;
this.tagLiteral = target.value === 'input' ? literal`input` : literal`textarea`;
}

static styles = css`/* playground-fold */:host { font-family: sans-serif; } :host > * { margin-block: .5em; }/* playground-fold-end */`;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"extends": "/samples/v3-base.json",
"files": {
"input-or-textfield.ts": {},
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "175px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import { html, LitElement, css } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { classMap } from 'lit/directives/class-map.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() counter = 0

firstUpdated() {
setInterval(() => this.counter += 1 , 1000);
}

render() {
const classes = {
red: this.counter % 2 === 0,
blue: this.counter % 2 === 1
};
return html`<p class=${classMap(classes)}>Hello!</p>`;
}

static styles = css`
.red {
color: red;
}
.blue {
color: blue;
}
`;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { html, LitElement } from 'lit';
import { customElement, state } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
@state() private someBoolean = false;

render() {
let someText = html`<p>Some text</p>`;

if (this.someBoolean) {
someText = html`<p>Some other text</p>`;
}

return html`
<button
@click=${() => {this.someBoolean = !this.someBoolean}}>
Toggle template
</button>
<div>This is an inline ternary conditional</div>
${this.someBoolean ? html`<p>Some other text</p>` : html`<p>Some text</p>`}
<div>This is a variable conditional</div>
${someText}
`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "200px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element></my-element>
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { html, LitElement } from 'lit';
import { customElement } from 'lit/decorators.js';
import { trustedStyles, type CSSStyleSheet } from './trusted-stringified-css-source.js';

// Use constructable stylesheets on TRUSTED CSS strings to use them in a LitElement
const styles = new CSSStyleSheet();
// this type assertion is needed for the older version of TS like that the lit.dev website uses
(styles as unknown as CSSStyleSheet).replace(trustedStyles);

@customElement('my-element')
export class MyElement extends LitElement {
static styles = styles;
render() {
return html`
<div>
This should be red!
</div>
`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"trusted-stringified-css-source.ts": {},
"index.html": {}
},
"previewHeight": "100px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
export const trustedStyles = `
div {
color: red;
}
`;

// This may be needed for some older versions of TS
export type CSSStyleSheet = typeof globalThis['CSSStyleSheet'] & {
replaceSync(cssText: string): void;
replace(cssText: string): void;
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<script type="module" src="./my-element.js"></script>
<style>
.styled my-element::part(paragraph) {
color: yellow;
border-color: white;
padding: 8px;
margin: 2px;
}

.styled {
background-color: black;
}

div {
padding: 4px;
}
</style>

<div class="styled">
<my-element></my-element>
</div>
<div>
<my-element></my-element>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
import { html, LitElement, css } from 'lit';
import { customElement } from 'lit/decorators.js';

@customElement('my-element')
export class MyElement extends LitElement {
static styles = css`
p {
color: blue;
border: 1px solid black;
padding: 4px;
margin-block: 4px;
}
`;

render() {
return html`<p part="paragraph">This is in a shadow root!</p>`;
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
{
"extends": "/samples/v3-base.json",
"files": {
"my-element.ts": {},
"index.html": {}
},
"previewHeight": "120px"
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
<script type="module" src="./my-element.js"></script>

<my-element array='1,"2",3,4,"5"'></my-element>
Loading

0 comments on commit e52fd31

Please sign in to comment.