# Installation & Setup SigPro is designed to be drop-in ready. Whether you are building a complex application with a bundler or a simple reactive widget in a single HTML file, SigPro scales with your needs. ## 1. Installation Choose the method that best fits your workflow:
```bash npm install sigpro ```
```bash pnpm add sigpro ```
```bash yarn add sigpro ```
```bash bun add sigpro ```
```html ```
<script type="module">
  // Import the core and UI components
  import SigPro from 'https://cdn.jsdelivr.net/npm/sigpro@latest/+esm';
  import { UI } from 'https://cdn.jsdelivr.net/npm/sigpro@latest/ui/+esm';
  
  // Initialize UI components globally
  UI($);
</script>
--- ## 2. Quick Start Examples SigPro uses **PascalCase** for Tag Helpers (e.g., `Div`, `Button`) to provide a clean, component-like syntax without needing JSX.
```javascript // File: App.js import SigPro from "sigpro"; export const App = () => { const $count = $(0); // Tag Helpers like Div, H1, Button are available globally return Div({ class: "card p-4" }, [ H1(["Count is: ", $count]), Button( { class: "btn btn-primary", onclick: () => $count((c) => c + 1), }, "Increment", ), ]); }; // File: main.js import SigPro from "sigpro"; import { App } from "./App.js"; $mount(App, "#app"); ```
```html
```
--- ## 3. Global by Design One of SigPro's core strengths is its **Global API**, which eliminates "Import Hell" while remaining ESM-compatible. * **The "Zero-Config" Import:** By simply adding `import SigPro from "sigpro"`, the framework automatically "hydrates" the global `window` object. * **Core Functions:** You get immediate access to `$`, `$watch`, `$html`, `$if`, `$for`, and `$router` anywhere in your scripts without using the `SigPro.` prefix. * **Auto-Installation:** This happens instantly upon import thanks to its built-in `install()` routine, making it "Plug & Play" for both local projects and CDN usage. * **PascalCase Tag Helpers:** Standard HTML tags are pre-registered as global functions (`Div`, `Span`, `Button`, `Section`, etc.). * **Clean UI Syntax:** This allows you to write UI structures that look like HTML but are pure, reactive JavaScript: `Div({ class: "card" }, [ H1("Title") ])`. * **Hybrid Tree Shaking:** * For **Maximum Speed**, use `import SigPro from "sigpro"`. * For **Maximum Optimization**, you can still use Named Imports: `import { $, $html } from "sigpro"`. This allows modern bundlers like Vite to prune unused code while keeping your core reactive. * **Custom Components:** We recommend using **PascalCase** for your own components (e.g., `UserCard()`) to maintain visual consistency with the built-in Tag Helpers and distinguish them from standard logic. --- ## 4. Why no build step? Because SigPro uses **native ES Modules** and standard JavaScript functions to generate the DOM, you don't actually _need_ a compiler like Babel or a transformer for JSX. - **Development:** Just save and refresh. Pure JS, no "transpilation" required. - **Performance:** Extremely lightweight. Use any modern bundler (Vite, esbuild) only when you are ready to minify and tree-shake for production. ## 5. Why SigPro? (The Competitive Edge) SigPro stands out by removing the "Build Step" tax and the "Virtual DOM" overhead. It is the closest you can get to writing raw HTML/JS while maintaining modern reactivity. | Feature | **SigPro** | **SolidJS** | **Svelte** | **React** | **Vue** | | :----------------- | :--------------- | :----------- | :----------- | :---------- | :---------- | | **Bundle Size** | **~2KB** | ~7KB | ~4KB | ~40KB+ | ~30KB | | **DOM Strategy** | **Direct DOM** | Direct DOM | Compiled DOM | Virtual DOM | Virtual DOM | | **Reactivity** | **Fine-grained** | Fine-grained | Compiled | Re-renders | Proxies | | **Build Step** | **Optional** | Required | Required | Required | Optional | | **Learning Curve** | **Minimal** | Medium | Low | High | Medium | | **Initialization** | **Ultra-Fast** | Very Fast | Fast | Slow | Medium | --- ## 6. Key Advantages - **Extreme Performance**: No Virtual DOM reconciliation. SigPro updates the specific node or attribute instantly when a Signal changes. - **Fine-Grained Reactivity**: State changes only trigger updates where the data is actually used, not on the entire component. - **Native Web Standards**: Everything is a standard JS function. No custom template syntax to learn. - **Zero Magic**: No hidden compilers. What you write is what runs in the browser. - **Global by Design**: Tag Helpers and the `$` function are available globally to eliminate "Import Hell" and keep your code clean. ## 7. Summary SigPro isn't just another framework; it's a bridge to the native web. By using standard ES Modules and functional DOM generation, you gain the benefits of a modern library with the weight of a utility script. **Because, in the end... why fight the web when we can embrace it?**