npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@ibgib/web-gib

v0.0.46

Published

Framework for creating agentic ibGib web apps. Contains plumbing for ibgib components, agentic framework (currently only Gemini implemented), web-based IndexedDB storage substrate, and more.

Readme

web-gib - agent-driven ibGib web apps

:under_construction: I'm currently in the process of pulling this out as a framework from @ibgib/blank-gib.

This library enables ibgib apps with...

Build (Monorepo Policy)

[!IMPORTANT] This project is part of a monorepo. Build and development tasks are centralized in the monorepo root via the @ibgib/build-gib orchestrator.

Development & Build

Run these from the monorepo root:

  • npm run build:web-gib - Performs a full clean and build.
  • npm run test:web-gib - Runs the full respec-gib test suite for this library.

Legacy Scripts

Individual package scripts have been streamlined to avoid redundancy. Previous scripts are archived in docs/ARCHIVE_SCRIPTS.md at the monorepo root.

  • initializing the ibgib environment
    • bootstrapping the metaspace
  • utilizing and interacting with IndexedDB
    • IndexedDB-based ibgib space implementation
    • IndexedDB helper functions
  • building with the ibgib component framework

src notes

*.ext.mts, *.web.mts, *.app.mts

All ibgib code is TypeScript + ES Modules.

  • .ext for chrome extension-only (not the app)
  • .web.mts - web (not node)
  • .app.mts - blank-gib app (not the web extension)

AI Agent Skills (Scaffolding)

In lieu of a heavy framework CLI, the @ibgib/web-gib package comes bundled with built-in agent instructions and templates structure to help your IDE's AI agents natively scaffold new ibgib applications, components, and shells.

Because AI coding assistants typically do not read files inside node_modules, you must initialize these skills by copying them directly into your project's root folder. You can do this manually, or we have provided a simple script to do the copying for you.

Option 1 (For standard projects) If @ibgib/web-gib is installed at your project root, you can run the executable directly via npx:

npx web-gib-init-agents

Option 2 (For Monorepos & Workspaces) If @ibgib/web-gib is a dependency on a sub-app (e.g. apps/my-app) instead of the workspace root, package manager "hoisting" rules may prevent the executable from appearing at your root level.

To properly initialize the .agents folder at your monorepo's root, pull from one of the following commands:

Choice A (Execute via npx): Let npx automatically resolve and execute the binary hook from the package registry:

npx -p @ibgib/web-gib web-gib-init-agents

Choice B (Execute script directly): Bypass the broken .bin symlink entirely and execute the raw script locally from within the nested workspace dependency:

node ./apps/my-app/node_modules/@ibgib/web-gib/tools/init-agents.js

Recommendation for Monorepos: To streamline future updates, it is highly recommended to map whichever execution method you prefer directly into your root package.json scripts:

  "scripts": {
    "init-agents": "npx -p @ibgib/web-gib web-gib-init-agents"
  }

Or for the direct script approach:

  "scripts": {
    "init-agents": "node ./apps/my-app/node_modules/@ibgib/web-gib/tools/init-agents.js"
  }

Bootstrapping an IbGib App

@ibgib/web-gib provides a streamlined, multi-phase bootstrap process that minimizes boilerplate while maximizing performance. A standard ibgib application consists of 8 foundational files:

  1. index.html: The entry point with script tags for script.mjs and index.mjs.
  2. script.mts: Phase 1. Immediate UI Shell initialization (e.g., burger menus).
  3. index.mts: Phase 2. Storage (IndexedDB) and Engine orchestration.
  4. bootstrap.mts: Phase 3. The heavy ibgib engine and App witness loading.
  5. constants.mts: App-specific configuration and UUIDs.
  6. types.mts: App-specific global state typing.
  7. helpers.web.mts: Environment-aware initialization utilities.
  8. style.css: Core application styling.

Phase 1: Immediate Shell Interactivity (script.mts)

To ensure the UI is responsive immediately, the Shell is initialized in a dedicated entry point. This script runs as soon as the HTML is parsed.

import { getMyAppShellSvc } from "./ui/shell/my-app-shell-service.mjs";

// Early init of UI Shell logic so the burger menu responds immediately.
getMyAppShellSvc();

Phase 2: Environment Orchestration (index.mts)

The index.mts file handles the asynchronous setup of storage and triggers the dynamic loading of the heavy ibgib engine.

In your app's entry point (index.mts), you should initialize the global namespace immediately, then "spin off" the storage and bootstrap loading to avoid blocking the initial DOM paint.

import { 
    initIbGibStorage, 
    initIbGibGlobalThis, 
    dynamicallyLoadBootstrapScript 
} from '@ibgib/web-gib/dist/app-bootstrap/init-orchestration.mjs';

import { APP_CONFIG } from './constants.mjs';
import { simpleIbGibRouterSingleton as router } from './ui/router/router-one-file.mjs';

// 1. Initialize global namespace immediately
initIbGibGlobalThis(APP_CONFIG, 'my_app_key');

/**
 * spin off to avoid forestalling the DOMContentLoaded from firing
 */
async function spinOffStartup(): Promise<void> {
    document.addEventListener('DOMContentLoaded', async () => {
        // 2. Prepare storage (IndexedDB)
        await initIbGibStorage(APP_CONFIG);
        
        // 3. Initialize Router
        router.loadCurrentURLPath();

        // 4. Defer loading the heavy engine
        await dynamicallyLoadBootstrapScript('./bootstrap.mjs', 'bootstrapMyApp');
    });
}

spinOffStartup();

Phase 2: Dynamic Engine Bootstrap (bootstrap.mts)

The bootstrap.mts file is loaded dynamically. It handles the initialization of the metaspace, identity, and the application witness using a rich set of lifecycle hooks.

import { bootstrapIbGibApp } from '@ibgib/web-gib/dist/app-bootstrap/bootstrap.mjs';
import { getIbGibGlobalThis_IbGibApp } from '@ibgib/web-gib/dist/app-bootstrap/init-orchestration.mjs';

import { 
    APP_CONFIG, 
    TAG_AGENT_TEXT, TAG_AGENT_ICON, TAG_AGENT_DESCRIPTION,
    MY_APP_SPACE_PREFIX
} from './constants.mjs';
import { MyAppApp_V1 } from './witness/app/my-app-app-v1.mjs';
import { PARAM_INFOS } from './witness/app/my-app-constants.mjs';
import { DEFAULT_MY_APP_DATA_V1 } from './witness/app/my-app-types.mjs';
import { registerAgentFunctionInfos } from './api/function-infos.web.mjs';

export async function bootstrapMyApp() {
    await bootstrapIbGibApp({
        config: APP_CONFIG,
        // Bridge function that provides the typed globalThis for your app
        getGlobalThis: (config) => getIbGibGlobalThis_IbGibApp('my_app_key', config),
        AppClass: MyAppApp_V1,
        defaultAppData: DEFAULT_MY_APP_DATA_V1,
        paramInfos: PARAM_INFOS,
        // Lifecycle hooks
        registerAgentFunctionInfos,
        ensureTags: [
            { text: TAG_AGENT_TEXT, icon: TAG_AGENT_ICON, description: TAG_AGENT_DESCRIPTION }
        ],
        localSpaceNamePrefix: MY_APP_SPACE_PREFIX,
        onReady: async (app) => {
            console.log('Engine ready!');
            // Initialize your UI shell service here
            // getAppShellSvc().onEngineReady();
        }
    });
}

UI Architecture: Custom @ibgib component framework

tl;dr: Web Component-based components react to ibgib's unique Merkle DAG DLT time-centric data model.

The front end that this library enables is not built with a conventional framework like React or Vue. Instead, it uses a custom architecture built on top of standard Web Components and the ibgib protocol. This creates a reactive framework against an infinite space built on ibgib's unique DLT content-addressing system.

In particular, components are linked to a backing ibgib timeline, using the ibgib's tjp address (specifically the gib part, i.e., the tjpGib) as the pointer to the genesis of the timeline. This acts as a unique, content-addressed timeline/stream identifier. And components subscribe to the metaspace's local pubsub, specifically listening to timeline updates, reacting accordingly.

Big Idea

All current approaches to data are disconnected. So the best you can do with a front-end component framework is a Redux-like approach where you usually have a local data store and you provide pathing into that store. Slightly better is you can have a store provider layer. Then your local-only components react to updates via the lambdas/reducers.

The lone exception - and the reason for its ENORMOUS success - is git itself. Think of git's coarse branches as the paths and remotes as the components. Now think of a DLT-based approach to timeline dynamics (like version control systems), that wasn't built with source code as its only use case, rather with each piece of data as its own timeline. Now you have a universally-sized distributed computation addressing system that enables distributed component architecture.

Framework Parts

The component framework itself consists of three main parts:

  1. The Component Service (IbGibComponentService): A singleton service that acts as a central registry and router for all components in the application. When the application needs to display a new view, it asks the service to find and create the appropriate component for the given data (ibGibAddr).

  2. The Component Meta (IbGibDynamicComponentMeta): This is a "blueprint" or factory object for a component. It doesn't render any UI itself; instead, it defines the component's custom HTML tag name (e.g., ibgib-sidepanel), its routing rules (how it matches a URL or path), and contains the factory method (createInstance) to stamp out new instances.

  3. The Component Instance (IbGibDynamicComponentInstance): This is the component itself - an actual HTMLElement web component that gets rendered in the DOM. It contains the UI logic, event handling, and maintains a live link to its corresponding ibgib data. It uses a LiveProxyIbGib to automatically update the UI when the underlying data changes.

This architecture allows for a highly dynamic and modular UI where components can be loaded, unloaded, and updated in response to changes in the ibgib knowledge graph. For a more detailed technical breakdown, see the README.md in the apps/blank-gib/src/extension directory.