Releases: jails-org/Jails
v5.9.0 - Minor Update
Minor Update
⚠️ Breaking Change
The default template delimiters was changed to mustache {{ variable }}
.
This is to avoid conflict with Astro
meta-framework and also with Template Strings used in export const template()
.
Old ❌
<my-component>
<h1>Hello, ${name}</h1>
</my-component>
New ✅
<my-component>
<h1>Hello, {{name}}</h1>
</my-component>
v5.8.7 - Patch Update
Change Log
Consistency
Improving the latest bug fix regarding rendering issues with idiomorph.
v5.8.6 - Patch Update
Change Log
Consistency
, Extensability
-
Bug fix: There are some very edge cases cenarios where updating state from parent by emiting event from child onmount was rendering unexpected html output results. Adding a quick fix for those cases.
-
Template "children" support.
For cases where user wants to chare a web component using jails, There wasn't a easy way to wrap children with html code just like React and other frameworks does withchildren
orslot
features.
So it was added on this version, achildren
prop forexport const template()
function in order to access children data from server rendered html.
Example
Consider a web component that have to wrap the default html children.
import { html } from 'jails-js/html'
export default function appTitle({ main }) {
//
main(() => {
})
}
export const template = ({ children }) => {
return html`
<section>
<h1>${children}</h1>
</section>
`
}
import jails from 'jails-js'
import * as appTitle from 'components/app-title'
jails.register('app-title', appTitle)
jails.start()
<app-title>My Title</app-title>
Output
<section>
<h1>My Title</h1>
</section>
v5.8.5 - Patch Update
Change Log
Reusability
, Interoperability
Adding html
and attributes
template tags to use for SPA and SSR cenarios.
Use case
There are sometimes where we want to share functionality between 2 or more applications.
The most obvious ways is to use template literals because it's compatible with node & browser systems.
html, attributes are directives to be used on this context and we want more advanced features on template strings.
import { html, attributes } from 'jails-js/html'
export default function banner ({ attrs = [] }) {
return html`
[1, 2, 3].map( n => html`
<h1 ${ attributes( attrs ) }>
${n}
</h1>
`)
`
}
banner({
attrs : [{ title: 'Hello' }]
})
Output
<h1 title="Hello">1</h1>
<h2 title="Hello">2</h2>
<h3 title="Hello">3</h3>
v5.8.3 - Patch Update
Change Log
consistency
Fixing an edge case when dom element was queried inside the high order component function on page load.
The fix is to render component before running the high order function.
v5.8.2 - Patch Update
Change Log
- Fixing
innerHTML
feature. It was broken for elements outsidebody
tree. Likehtml
,head
etc. The alternative has also improve performance for this kind of operation.
v5.8.1 - Patch Update
Change Log
- Improving / Fixing child rendering on parent updates. On previous version, parent updates used to force children updates and that causes some bugs on certain cenarios. Now, just like versions that used to use morphdom, the tree updates stops on children components.
v5.8.0 - Minor Update
Change Log
We prioritize consistency over performance
The most recent updates aimed to enhance performance, but we encountered inconsistencies with HTML updates during testing. To ensure greater consistency and predictability, a significant change was implemented, replacing morphdom with idiomorph.
There are other well known libraries that already made that change:
We are indeed using idiomorph and we'll include it officially as part of Turbo 8. We started with morphdom, but eventually switched to idiomorph as we found it way more suitable. It just worked great with all the tests we threw at it, while morphdom was incredibly picky about "ids" to match nodes. Also, we noticed it's at least as fast.
-- Jorge Marubia / 37Signals
That helps on decision making about changing the core of the library which is the dom diff engine.
v5.7.1 - Patch Update
Change Log
Reverting previous release : Performance Improvement
The latest update focused on optimizing memory usage. However, as Jails is designed to function with or without templates, a bug has been identified when users interact directly with the DOM. Therefore, I am rolling forward the current build. Prioritizing correctness over performance remains our primary concern.
The performance optimization was not discarted but it requires more deep research.
v5.7.0 - Minor Update
Change Log
Performance Improvement
Making Templates smaller by removing child component html content from parent component template by creating "holes" inside the parent component template string.
Since parent component doesn't update child components html, it doesn't need to have child html data saved in memory.
This improvement is very welcome especially for pages that contains application component in the most top level hierarchy.