@luna_ui/luna
v0.2.3
Published
Fine-grained reactive UI library for Moonbit/JS
Readme
@luna_ui/luna
A lightweight reactive UI library with SolidJS-Like API. Implemented in MoonBit.
Documentation
Quick Start
# Create a new TSX project
npx @luna_ui/luna new myapp
cd myapp
npm install
npm run dev
# Or create a MoonBit project
npx @luna_ui/luna new myapp --mbt
cd myapp
moon update
npm install
npm run devManual Setup
Installation
npm install @luna_ui/lunaTypeScript + Vite
tsconfig.json:
{
"compilerOptions": {
"jsxImportSource": "@luna_ui/luna"
}
}vite.config.ts:
import { defineConfig } from 'vite';
export default defineConfig({
esbuild: {
jsx: 'automatic',
jsxImportSource: '@luna_ui/luna',
},
});Basic Usage
import { createSignal, createMemo, render } from '@luna_ui/luna';
function Counter() {
const [count, setCount] = createSignal(0);
const doubled = createMemo(() => count() * 2);
return (
<div>
<p>Count: {count}</p>
<p>Doubled: {doubled}</p>
<button onClick={() => setCount(c => c + 1)}>+</button>
<button onClick={() => setCount(c => c - 1)}>-</button>
<button onClick={() => setCount(0)}>Reset</button>
</div>
);
}
render(document.getElementById('app')!, <Counter />);API
Signal
import { createSignal, createMemo, createEffect } from '@luna_ui/luna';
// Signal: reactive value
const [count, setCount] = createSignal(0);
count(); // get value
setCount(5); // set value
setCount(c => c + 1); // update with function
// Memo: derived value
const doubled = createMemo(() => count() * 2);
// Effect: side effects
createEffect(() => {
console.log('Count changed:', count());
});Components
import { For, Show } from '@luna_ui/luna';
// For: list rendering
<For each={items}>
{(item) => <li>{item.name}</li>}
</For>
// Show: conditional rendering
<Show when={() => isVisible()}>
<div>Visible content</div>
</Show>Styles
// Object syntax (camelCase → kebab-case auto-conversion)
<div style={{ backgroundColor: 'red', maxWidth: '600px' }}>
styled content
</div>
// String syntax
<div style="color: blue; margin: 10px">
styled content
</div>Event Handlers
<button onClick={() => console.log('clicked')}>Click</button>
<input onInput={(e) => setValue(e.target.value)} />
<form onSubmit={(e) => { e.preventDefault(); submit(); }}>License
MIT
