import { T, t } from "./utils/index.js"; export const info= { title: t`Appendix & Summary`, fullTitle: t`dd Comprehensive Reference`, description: t`A final overview, case studies, key concepts, and best practices for working with deka-dom-el.`, }; import { el } from "deka-dom-el"; import { simplePage } from "./layout/simplePage.html.js"; import { h3 } from "./components/pageUtils.html.js"; import { code } from "./components/code.html.js"; /** @param {string} url */ const references= { /** GitHub repository */ github: { title: t`dd GitHub Repository`, href: "https://github.com/jaandrle/deka-dom-el", }, /** TodoMVC */ todomvc: { title: t`TodoMVC Implementation`, href: "p10-todomvc.html", }, /** Performance best practices */ performance: { title: t`Performance Optimization Guide`, href: "p09-optimization.html", } }; /** @param {import("./types.d.ts").PageAttrs} attrs */ export function page({ pkg, info }){ const page_id= info.id; return el(simplePage, { info, pkg }).append( el("p").append(...T` This reference guide provides a comprehensive summary of dd's key concepts, best practices, case studies, and advanced techniques. Use it as a quick reference when working with the library or to deepen your understanding of its design principles and patterns. `), el(h3, t`Core Principles of dd`), el("p").append(...T` At its foundation, dd is built on several core principles that shape its design and usage: `), el("div", { className: "callout" }).append( el("h4", t`Guiding Principles`), el("ul").append( el("li").append(...T` ${el("strong", "DOM-First Approach:")} Working directly with the real DOM instead of virtual DOM abstractions `), el("li").append(...T` ${el("strong", "Declarative Syntax:")} Creating UIs by describing what they should look like, not how to create them `), el("li").append(...T` ${el("strong", "Minimal Overhead:")} Staying close to standard Web APIs without unnecessary abstractions `), el("li").append(...T` ${el("strong", "Progressive Enhancement:")} Starting simple and adding complexity only when needed `), el("li").append(...T` ${el("strong", "Functional Composition:")} Building UIs through function composition rather than inheritance `), el("li").append(...T` ${el("strong", "Clear Patterns:")} Promoting maintainable code organization with the 3PS pattern `), el("li").append(...T` ${el("strong", "Targeted Reactivity:")} Using signals for efficient, fine-grained updates `), el("li").append(...T` ${el("strong", "Unix Philosophy:")} Doing one thing well and allowing composability with other tools `) ) ), el(h3, t`Case Studies & Real-World Applications`), el("h4", t`TodoMVC Implementation`), el("p").append(...T` The ${el("a", references.todomvc).append("TodoMVC implementation")} showcases how dd handles a complete, real-world application with all standard features of a modern web app: `), el("ul").append( el("li", t`Persistent storage with localStorage`), el("li", t`Reactive UI with automatic updates`), el("li", t`Client-side routing with hash-based URLs`), el("li", t`Component-based architecture`), el("li", t`Performance optimization with memoization`), el("li", t`Custom event system for component communication`), el("li", t`Proper focus management and accessibility`) ), el("p").append(...T` Key takeaways from the TodoMVC example: `), el("ul").append( el("li").append(...T` Signal factories like ${el("code", "routerSignal")} and ${el("code", "todosSignal")} encapsulate related functionality `), el("li").append(...T` Custom events provide clean communication between components `), el("li").append(...T` Targeted memoization improves rendering performance dramatically `), el("li").append(...T` Derived signals simplify complex UI logic like filtering `) ), el("h4", t`Migrating from Traditional Approaches`), el("p").append(...T` When migrating from traditional DOM manipulation or other frameworks to dd: `), el("ol").append( el("li").append(...T` ${el("strong", "Start with state:")}: Convert global variables or ad-hoc state to signals `), el("li").append(...T` ${el("strong", "Replace query selectors:")}: Replace getElementById/querySelector with direct references to elements `), el("li").append(...T` ${el("strong", "Convert imperative updates:")}: Replace manual DOM updates with declarative signal bindings `), el("li").append(...T` ${el("strong", "Refactor into components:")}: Organize related UI elements into component functions `) ), el(code, { content: ` // Before: Imperative DOM updates function updateUI() { document.getElementById('counter').textContent = count; document.getElementById('status').className = count > 10 ? 'warning' : ''; } // After: Declarative with dd const countS = S(0); el("div").append( el("span", { id: "counter", textContent: countS }), el("div", { id: "status", className: S(() => countS.get() > 10 ? 'warning' : '') }) ); `, page_id }), el(h3, t`Key Concepts Reference`), el("div", { className: "function-table" }).append( el("h4", t`Elements & DOM Creation`), el("dl").append( el("dt", t`el(tag|component, props, ...addons)`), el("dd", t`Core function for creating DOM elements with declarative properties`), el("dt", t`el().append(...children)`), el("dd", t`Add child elements to a parent element`), el("dt", t`memo(key, () => element)`), el("dd", t`Cache and reuse DOM elements for performance optimization`), el("dt", t`on(eventType, handler)`), el("dd", t`Attach event handlers to elements as addons`) ) ), el("div", { className: "function-table" }).append( el("h4", t`Signals & Reactivity`), el("dl").append( el("dt", t`S(initialValue)`), el("dd", t`Create a signal with an initial value`), el("dt", t`S(() => computation)`), el("dd", t`Create a derived signal that updates when dependencies change`), el("dt", t`S.el(signal, data => element)`), el("dd", t`Create reactive elements that update when a signal changes`), el("dt", t`S.action(signal, "method", ...args)`), el("dd", t`Call custom methods defined on a signal`), el("dt", t`signal.get()`), el("dd", t`Get the current value of a signal`), el("dt", t`signal.set(newValue)`), el("dd", t`Update a signal's value and trigger reactive updates`) ) ), el("div", { className: "function-table" }).append( el("h4", t`Component Patterns`), el("dl").append( el("dt", t`Function Components`), el("dd", t`Javascript functions that return DOM elements`), el("dt", t`scope Object`), el("dd", t`Provides access to component context, signal, host element`), el("dt", t`dispatchEvent(type, element)`), el("dd", t`Creates a function for dispatching custom events`), el("dt", t`Signal Factories`), el("dd", t`Functions that create and configure signals with domain-specific behavior`) ) ), el(h3, t`Best Practices Summary`), el("div").append( el("h4", t`Code Organization`), el("ul").append( el("li").append(...T` ${el("strong", "Follow the 3PS pattern:")}: Separate state creation, binding to elements, and state updates `), el("li").append(...T` ${el("strong", "Use component functions:")}: Create reusable UI components as functions `), el("li").append(...T` ${el("strong", "Create signal factories:")}: Extract reusable signal patterns into factory functions `), el("li").append(...T` ${el("strong", "Leverage scopes:")}: Use scope for component context and clean resource management `), el("li").append(...T` ${el("strong", "Event delegation:")}: Prefer component-level event handlers over many individual handlers `) ) ), el("div").append( el("h4", t`Performance Optimization`), el("ul").append( el("li").append(...T` ${el("strong", "Memoize list items:")}: Use ${el("code", "memo")} for items in frequently-updated lists `), el("li").append(...T` ${el("strong", "Avoid unnecessary signal updates:")}: Only update signals when values actually change `), el("li").append(...T` ${el("strong", "Use AbortSignals:")}: Clean up resources when components are removed `), el("li").append(...T` ${el("strong", "Prefer derived signals:")}: Use computed values instead of manual updates `), el("li").append(...T` ${el("strong", "Avoid memoizing fragments:")}: Never memoize DocumentFragments, only individual elements `) ), el("p").append(...T` See the ${el("a", references.performance).append("Performance Optimization Guide")} for detailed strategies. `) ), el("div").append( el("h4", t`Common Pitfalls to Avoid`), el("dl").append( el("dt", t`Excessive DOM Manipulation`), el("dd", t`Let signals handle updates instead of manually manipulating the DOM after creation`), el("dt", t`Forgetting to Clean Up Resources`), el("dd", t`Use scope.signal or AbortSignals to handle resource cleanup when elements are removed`), el("dt", t`Circular Signal Dependencies`), el("dd", t`Avoid signals that depend on each other in a circular way, which can cause infinite update loops`), el("dt", t`Memoizing with Unstable Keys`), el("dd", t`Always use stable, unique identifiers as memo keys, not array indices or objects`), el("dt", t`Deep Nesting Without Structure`), el("dd", t`Break deeply nested element structures into smaller, logical component functions`) ) ), el(h3, t`Feature Comparison with Other Libraries`), el("table").append( el("thead").append( el("tr").append( el("th", "Feature"), el("th", "dd"), el("th", "React"), el("th", "Vue"), el("th", "Svelte") ) ), el("tbody").append( el("tr").append( el("td", "No Build Step Required"), el("td", "✅"), el("td", "⚠️ JSX needs transpilation"), el("td", "⚠️ SFC needs compilation"), el("td", "❌ Requires compilation") ), el("tr").append( el("td", "Bundle Size (minimal)"), el("td", "~10-15kb"), el("td", "~40kb+"), el("td", "~33kb+"), el("td", "Minimal runtime") ), el("tr").append( el("td", "Reactivity Model"), el("td", "Signal-based"), el("td", "Virtual DOM diffing"), el("td", "Proxy-based"), el("td", "Compile-time reactivity") ), el("tr").append( el("td", "DOM Interface"), el("td", "Direct DOM API"), el("td", "Virtual DOM"), el("td", "Virtual DOM"), el("td", "Compiled DOM updates") ), el("tr").append( el("td", "Server-Side Rendering"), el("td", "✅ Basic Support"), el("td", "✅ Advanced"), el("td", "✅ Advanced"), el("td", "✅ Advanced") ) ) ), el(h3, t`Looking Ahead: Future Directions`), el("p").append(...T` The dd library continues to evolve, with several areas of focus for future development: `), el("ul").append( el("li").append(...T` ${el("strong", "Future Compatibility:")} Alignment with the TC39 Signals proposal for native browser support `), el("li").append(...T` ${el("strong", "SSR Improvements:")} Enhanced server-side rendering capabilities `), el("li").append(...T` ${el("strong", "Ecosystem Growth:")} More utilities, patterns, and integrations with other libraries `), el("li").append(...T` ${el("strong", "Documentation Expansion:")} Additional examples, tutorials, and best practices `), el("li").append(...T` ${el("strong", "TypeScript Enhancements:")} Improved type definitions and inference `) ), el(h3, t`Contribution and Community`), el("p").append(...T` dd is an open-source project that welcomes contributions from the community: `), el("ul").append( el("li").append(...T` ${el("a", references.github).append("GitHub Repository")}: Star, fork, and contribute to the project `), el("li").append(...T` Bug reports and feature requests: Open issues on GitHub `), el("li").append(...T` Documentation improvements: Help expand and clarify these guides `), el("li").append(...T` Examples and case studies: Share your implementations and solutions `) ), el("div", { className: "callout" }).append( el("h4", t`Final Thoughts`), el("p").append(...T` dd provides a lightweight yet powerful approach to building modern web interfaces with minimal overhead and maximal flexibility. By embracing standard web technologies rather than abstracting them away, it offers a development experience that scales from simple interactive elements to complex applications while remaining close to what makes the web platform powerful. `), el("p").append(...T` Whether you're building a small interactive component or a full-featured application, dd's combination of declarative syntax, targeted reactivity, and pragmatic design provides the tools you need without the complexity you don't. `) ), ); }