Releases: atomicojs/atomico
[email protected] 🔧 - fixes types and context synchronization in case of edges
- Fix first argument to useState at type level, example:
// BEFORE
const [state, setState] = useState<string>(()=>"welcome"); // ❌Typescript announces error
// BEFORE
const [state, setState] = useState<string>(()=>"welcome"); // ✅Typescript announces success
- Context synchronization
While version 1.79 fixed cases where HTML-based synchronization is privileged, this fix fixes synchronization when using JSX, avoiding 2 renders when connecting to contexts 💪, example:
<MyParent>
<MyContext>
<MyChild/>
</MyContext>
</MyParent>
Using JSX/TSX has better performance when synchronizing contexts,thanks to the fact that MyChild will be receiving the status at the time of mount.
[email protected]
This version applies fixes to improve component unmounting when using useSuspense and code reductions for the context API.
- Internal fixes for the context API, reducing the code and logic.
- Internal fixes for the suspense API, properly cleaning up the state upon unmounting.
Say hello to [email protected] 🎉🚀
This version has 2 core changes:
- Improvements in the context API to achieve state synchronization in extreme and collaborative cases (When using Atomico within other libraries like React, Vue or Angular).
- Enhancements in the suspense API, now allowing to properly observe and clean up promises resolved in nested components.
Fix : type declarations for refactor to context api
1.78.2 fix: ts
fix: TS, fix GetValueFromContext type
1.78.1 fix:TS
Say hello to [email protected] 🚀, asynchronously friendlier 🤗🤝.
New Features
Now usePromise is also observed by the useSuspense Hook.
With this, you can create interfaces that react from the parent component to the asynchrony of its children.
New hook useProvider
With this new hook, you can set the context instance, for example:
const Theme = createContext({ mode: "light" });
const App = c(() => {
useProvider(Theme, { mode: "dark" });
});
Internal improvements
- The context api is improved to synchronize states according to the HTML.
Fix useContext in SSR
Fixes a bug when using contexts in SSR environments.
Thanks to @WickyNilliams for reporting the issue atomicojs/astro#1.
Fix type Mark
This allows fixing the filter by instanceof a nidel of typescript types, example:
import { Mark } from "atomico";
Array.from(element.childNodes).filter(
(el) => !(el instanceof Mark)
);
[email protected] - New assignNode property for the tag slot 🚀
This new property allows working with slots in manual assignment mode in an agile way. For example:
import { c } from "atomico";
import { useChildNodes } from "@atomico/use-child-nodes";
const MyComponent = c(() => {
const childNodes = useChildNodes();
return (
<host shadowDom={{ slotAssignment: "manual" }}>
{childNodes
.filter((el) => el instanceof HTMLElement)
.map((child: HTMLElement) => (
<slot assignNode={child}></slot>
))}
</host>
);
});
customElements.define("my-component", MyComponent);
Fix missing useRefEffect type
Now the type exists as a module at the TS level