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 🙏

© 2025 – Pkg Stats / Ryan Hefner

jsgui3-html

v0.0.151

Published

Jsgui HTML generation and processing module (isomorphic, runs on client and server, few npm requirements)

Downloads

206

Readme

Jsgui3 HTML

This is the isomorphic (for both the client and server) core of the jsgui framework. It uses the "lang-mini" package for utility functions as well as its Evented_Class, which Control inherits from. Evented_Class allows events to be listened to and raised.

Its main functionality is the Control. It is somewhat synonymous with React Components. Its pupose is to represent an item within the DOM that is composed from HTML (or SVG) elements, and can be interacted with by the user.

Server-side rendering, client-side activation.

Controls are identified with their dom attribute "data-jsgui-id". The 'id' property generally does not get used or defined by jsgui3.

Control lifecycle:

Contruction Composition Activation (client-side only) Event responses (usually client-side only)

Mixins are a flexible way to add functionality to controls. It allows for better code reuse between classes in some cases.

Some more code to do with typed data could help.

Data_Type but with multiple possible ways it can be encoded.

Will make some simpler controls first... At least simple as in interacts with simple data. Number_Editor for a start.

Rendering SVG

const circle = new Control({ tagName: 'circle', attrs: { cx: 50, cy: 50, r: 40, stroke: 'green', 'stroke-width': 4, fill: 'yellow' } });