Skip to content

Comments

feat: simplify parametric HTML DSL with automatic Html[F] derivation …#463

Open
RahulDev-01 wants to merge 4 commits intoarmanbilge:mainfrom
RahulDev-01:fix/issue-461-parametric-html-dsl
Open

feat: simplify parametric HTML DSL with automatic Html[F] derivation …#463
RahulDev-01 wants to merge 4 commits intoarmanbilge:mainfrom
RahulDev-01:fix/issue-461-parametric-html-dsl

Conversation

@RahulDev-01
Copy link

This PR addresses issue #461 by simplifying the usage of Calico's HTML DSL in parametric (effect-polymorphic) code.

Currently, users working with a parametric effect F[_]: Async must manually pass an Html[F] capability and import from it in every function scope, which creates significant boilerplate. This change introduces an automatic derivation for the Html[F] capability, allowing it to be synthesized directly from an Async[F] instance.

Key Changes
Automatic Derivation: Added given [F[]: Async]: Html[F] = new Html[F] to the Html companion object. This makes Html[F] available for any effect type that has an Async instance.
Ergonomic Pattern: Enables the use of context bounds to request the DSL: def component[F[
]: Async: Html].
Documentation: Updated
docs/concepts.md
to highlight the simplified parametric usage pattern.
Verification: Added a compile-time test case in
SyntaxSuite.scala
ensuring that parametric components correctly type-check using the new pattern.

@RahulDev-01 RahulDev-01 force-pushed the fix/issue-461-parametric-html-dsl branch from ba0caf1 to 9022155 Compare February 22, 2026 15:46
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant