chore: alterative functional templating syntax #15599
Merged
+322
−532
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Note, this PR is against #15538
You can use this playground link if you want to play around with the output.
It's implementing a version of the comment from @Rich-Harris #15538 (comment) that moves the logic to invoke the function to the runtime instead of build time. Basically instead of actually creating the body of an arrow function this create a structure that
template_fn
can convert to a series of functional calls. Specifically the structure looks like thisthe function accepts an array of
TemplateStructure
and follows the following convention:<!--data-->
otherwise it's an empty comment...this allow us to save bytes because 99% of the times we can actually just send undefined which means an array with an empty spot eg. `[,,"there are two comments before me"];I've opened another PR for a couple of reason:
Before submitting the PR, please make sure you do the following
feat:
,fix:
,chore:
, ordocs:
.Tests and linting
pnpm test
and lint the project withpnpm lint