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

doix-w2ui

v1.0.6

Published

doix w2ui adapter

Downloads

6

Readme

workflow Jest coverage

doix-w2ui is a w2ui adapter for the doix server platform.

More specifically, this is a translator of AJAX requests coming from w2grid into DbQuery instances.

Installation

npm install doix-w2ui

Initialization

doix-w2ui is a plug in for database clients, such as DbClientPg. It can be attached to any database connection pool by calling the plugInto method:

const {DbPoolPg}   = require ('doix-db-postgresql')
const w2ui = require ('doix-w2ui')

const db = new DbPoolPg ({
  db: conf.db,
  logger: createLogger (conf, 'db'),
})

w2ui.plugInto (db)

After that, each db instance injected into a Job will have the w2uiQuery method described in the next section.

Using in application code

With doix-w2ui plugged in, the db resource provides the w2uiQuery method having the same parameters as DbModel.createQuery:

select_users:    
  async function () {
    const {db} = this
    const query = db.w2uiQuery ([['users']], {order: ['label']})
    const list = await db.getArray (query)
    return {
      all: list, 
      cnt: list [Symbol.for ('count')], 
      portion: query.options.limit
    }
  }

In fact, this is the db.model.createQuery call, but with some additions:

  • the limit and offset options are overridden with this.request.limit and this.request.offset respectively;
  • the order list is replaced with the translated this.request.sort, if any (so the order passed in argument acts as a default value);
  • the 1st query table filter option is appended with the translated this.request.search.

More about search filters.

The base documentation on w2ui types and operators can be found at the developers' web site. In this section, only special doix-w2ui features are described.

Operators

doix-w2ui supports three extra operators:

|name|SQL operator| |-|-| |is not|<>| |less!|<| |more!|>|

Both standard is and local is not can be used with value: null, in which case they a mapped to IS NULL and IS NOT NULL respectively.

Search terms with operator: 'between' are replaced with 'more', 'less' or both, depending on values provided.

date type

For type: 'date', string values are accepted in any numeric DD ? MM ? YYYY or YYYY ? MM ? DD format. They are all translated into ISO YYYY-MM-DD format.

Any <= comparison with a date (original operator: 'less'; right part of 'between') is replaced with the strict < comparison with the next date. This makes sense for datetime values.