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

@papit/web-component

v0.0.4

Published

the root component for @papit web components, this package deals with all the heavy lifting such as reactive rendering, properties etc

Downloads

790

Readme

@papit/web-component

the root component for @papit web components, this package deals with all the heavy lifting such as reactive rendering, properties etc


Type Tests NPM version


installation

npm install @papit/web-component

Documentation

📄 Full Documentation →

Acknowledgements

💌 Special thanks to my loving wife Phuong — your support and patience make all the difference. 💛


Development Workflow

Development takes place inside the src folder.

Adding a new subcomponent

npm run component:add

This will:

  • Update .env
  • Create a view folder
  • Create the corresponding folder under src/components
  • Generate starter files

Styling

  • Edit styles in style.css
  • Styles are automatically imbedded into the JS thanks to esbuild.

Live Preview (see more @papit/server)

To preview during development:

npm start

This launches a demo server from the views folder.


Assets

  • Component assets (icons, translations, etc.) → store in assets/
  • Demo-only assets → store in views/<demo>/public/

Available Commands

| Command | Description | | ----------- | ---------------------------------------------------------------------------------- | | build | Builds the component. Add --prod for minification. | | watch | Watches for file changes and rebuilds. | | start | Starts the demo server for a specific view. | | analyse | Generates an analysis file (with --verbose and/or --force flags). | | react | Generates React wrappers for components (with --verbose and/or --force flags). |


## Decorators

`@papit/web-component` ships five decorators — `@property`, `@query`, `@bind`, `@debounce`, and `@context`.

📄 **[Decorator docs →](https://github.com/onkelhoy/papit/tree/main/packages/web/engines/web-component/docs/decorators)**

Example — Creating a Counter Component

Below is a small but complete example showing several key features in @papit/web-component:

  • Reactive properties via @property
  • DOM queries via @query
  • Event debouncing via @debounce and debounceFn
  • Method binding via @bind
  • Declarative rendering via the html tag
import {
  CustomElement,
  html,
  property,
  query,
  debounce,
  bind,
  debounceFn,
} from "@papit/web-component";

class MyCounter extends CustomElement {
  @property({ type: Number }) count = 0;
  @query("#incBtn") incrementButton!: HTMLButtonElement;

  @debounce(300)
  handleIncrement() {
    this.count++;
  }

  @bind
  handleReset() {
    this.count = 0;
  }

  render() {
    return html`
      <h2>Count: ${this.count}</h2>
      <button id="incBtn" @click=${this.handleIncrement}>+1</button>
      <button @click=${this.handleReset}>Reset</button>
    `;
  }
}

customElements.define("my-counter", MyCounter);

Once registered, you can use it anywhere:

<my-counter></my-counter>

Contributing

Contributions are welcome! Please follow the development guidelines above and ensure all tests pass before submitting a pull request.

License

Licensed under the @Papit License 1.0 - Copyright (c) 2024 Henry Pap (@onkelhoy)

Key points:

  • ✅ Free to use in commercial projects
  • ✅ Free to modify and distribute
  • ✅ Attribution required
  • ❌ Cannot resell the component itself as a standalone product

See the LICENSE file for full details.

Related Components

Support

For issues, questions, or contributions, please visit the GitHub repository.