From 07dfff8c8c69f79a2e8567d53d5d9f4f6f957c6c Mon Sep 17 00:00:00 2001 From: Justin Fagnani Date: Thu, 18 Nov 2021 15:15:13 -0800 Subject: [PATCH] Add initial content outline (#16) --- plan/README.md | 5 ++++ plan/outline.md | 80 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 85 insertions(+) create mode 100644 plan/README.md create mode 100644 plan/outline.md diff --git a/plan/README.md b/plan/README.md new file mode 100644 index 0000000..fc42cf4 --- /dev/null +++ b/plan/README.md @@ -0,0 +1,5 @@ +# Docs and Guide Plan + +This folder exists to capture the current docs plans in a central place where changes to the plans can be reviewed in PRs. + +[Outline](./outline.md) diff --git a/plan/outline.md b/plan/outline.md new file mode 100644 index 0000000..1a53a5f --- /dev/null +++ b/plan/outline.md @@ -0,0 +1,80 @@ +# Docs Outline + +* What are web components + * Custom Elements + * Shadow DOM + * Standard JS Modules +* Why web components + * What do we mean by interop? + * Interop with HTML, frameworks, the browser + * Interop with file formats: Markdown vs MDX, etc. + * Interoperable composition with slots + * Interop with the future + * Use cases + * Standalone components + * Component sets and design systems + * Applications +* Related specs + * MDN links + * GitHub repos with proposals + * What's left, ie. WCCG reports +* Using web components + * Basics + * Definining, the custom element registry, and the single tag name scope + * Upgrading, and `:defined` + * Children and slots + * Events + * Using web components in HTML and vanilla JS + * Styling + * CSS Custom Properties + * ::part()s + * Using web components with frameworks + * Using web components in... + * Markdown (how to import in various systems) + * WordPress +* Writing web components + * Defining + * Custom element registries + * Self-registering vs not + * Defensive registration for special cases (CDN distribution) + * Lifecycle + * Basics: `observedAttributes`, `constructor`, `attributeChangedCallback`... + * Cleaning up resources in `disconnectedCallback` + * Shadow DOM + * attachShadow() + * open vs closed + * Encapsulation: DOM, events, CSS + * Just overview: more detail in Styling and Composition sections + * Slots + * Styling + * Encapsulation (more detail than) + * Shadow selectors: `:host`, `:host()`, and `::slotted()` + * CSS Custom Properties + * CSS Shadow Parts: `part` and `::part()` + * Constructible style sheets + * Theming + * Strategies for deep styling + * Dealing with data + * Designing both a property & attribute API + * Responding to attribute changes (`attributeChangedCallback`) + * Responding to property changes (accessors) + * Considerations about when to use methods + * Reflecting between properties and attributes + * Using events for data + * Publishing to npm + * Composition + * Slots + * Communicating with events + * Using children + * Accessibility + * Forms + * Web component libraries +* Community Protocols +* Community and Resources +* FAQ + * Myth-busting answers can go here + * Can custom elements really only take strings? + * Is it impossible to SSR web components? + * Why don't web components solve ___ that other frameworks do? + * ... +* Demos and Playgrounds (standalone or to accompany each piece of content?)