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

@queryform/queryformjs

v0.1.4

Published

Queryform allows users to easily track query string parameters, save them to local storage and automatically populate form fields on their website. It is a dependency free JS module that connects your website to the Queryform applications backend.

Downloads

39

Readme

QueryformJS

QueryformJS is a powerful JavaScript library designed to streamline the management of UTM parameters across your website forms. Whether you're fetching them from our API (Easy to use parameter tracking dashboard) or handling them locally in your code, this utility is invaluable for tracking campaign data and storing UTM parameters in local storage. It automatically populates form inputs with the corresponding values, providing a seamless way to capture attribution data directly within your forms.

Use Case

Are you or your client running ad or affiliate campaigns? Do you want to see attribution data directly in your form entries? With QueryformJS, you can effortlessly track UTM parameters, save them to local storage, and append them to your form inputs based on predefined settings. For example, if you're running a Google AdWords campaign and want to know if a user contacting you came from an ad, QueryformJS can display that information directly in the email you receive from the form submission. This saves you from having to check multiple analytics tools, making the data instantly accessible.

Key Benefits:

  • Direct Attribution Data: See where your users are coming from directly in the form submissions, perfect for instant insight without needing to dive into analytics platforms.
  • Flexible Integration: As an ES module, QueryformJS integrates seamlessly with modern JavaScript frameworks like Vue, React, Next.js, or Nuxt.js.
  • Simple Setup: Import the package, initialize the class, and run the init function using one of the two provided setup methods:
    • API Driven (paid): Fetch and manage UTM parameters via a centralized API.
    • Local Driven (free): Handle UTM parameters locally with no external dependencies.

Using Queryform.co

For an enhanced experience, consider using Queryform.co, a platform that offers a clean and asynchronous interface for managing UTM parameters. With Queryform.co, you or your client can easily update parameters on the fly without needing to alter your code. This allows for dynamic and efficient management of your campaign tracking efforts.

To learn more, visit Queryform.co.

Installation

You can install QueryformJS via npm:

npm install @queryform/queryformjs
yarn add @queryform/queryformjs

Usage

Standard HTML Integration

You can use QueryformJS in a standard HTML setup by including the script and initializing it when the page loads. Here’s an example pulling the latest release from unpkg:

<script src="https://unpkg.com/@queryform/queryformjs@latest/dist/queryform.umd.js" defer></script>
<script type="text/javascript" defer>
  window.addEventListener('load', function() {
    const qf = new Queryform('queryform-website-specific-api-key');
    qf.init();
  });
</script>

This approach is straightforward and can be used in any standard web environment where you want to quickly integrate QueryformJS. You may also download the latest code from github here: https://github.com/queryform/queryformjs

Nuxt 3 Plugin Integration

For Nuxt 3 users, you can easily integrate QueryformJS as a plugin. Here’s an example of how to set it up:

import Queryform from '@queryform/queryformjs/dist/queryform.es.js';

export default defineNuxtPlugin(() => {
  const nuxtApp = useNuxtApp();
  nuxtApp.hook('page:finish', async () => {

    // API Driven
    const queryform = new Queryform('queryform-website-specific-api-key');
    queryform.init();

    // Local Driven
    // const queryform = new Queryform();
    // queryform.init({ debug: false, local: true }, [
    //     { param: 'utm_campaign', class_name: 'qf_utm_campaign' },
    //     { param: 'utm_medium', class_name: 'qf_utm_medium' }
    // ]);

  });
});

This setup ensures that QueryformJS runs every time a page is fully loaded, making it a great fit for Nuxt 3’s dynamic routing environment.

Next.js Integration

In a Next.js project, you can integrate QueryformJS by using it in a custom hook or directly in your components/pages. Here’s an example using a custom hook:

import { useEffect } from 'react';
import Queryform from '@queryform/queryformjs/dist/queryform.es.js';

const useQueryform = () => {
  useEffect(() => {
    // API Driven
    const queryform = new Queryform('queryform-website-specific-api-key');
    queryform.init();

    // Local Driven
    // const queryform = new Queryform();
    // queryform.init({ debug: false, local: true }, [
    //     { param: 'utm_campaign', class_name: 'qf_utm_campaign' },
    //     { param: 'utm_medium', class_name: 'qf_utm_medium' }
    // ]);
  }, []);
};

export default useQueryform;

Scenarios

API Driven

In this scenario, the domain parameters (UTMs) are retrieved from the Queryform API backend, where you can easily control your parameters from an easy to use interface that does not require code updates to adjust tracked query parameters.

const queryform = new Queryform('queryform-website-specific-api-key');
queryform.init();

Local Driven

In this scenario, you can provide the UTM parameters locally, this provides a clean easy way for developers to deploy lead attribution tracking with a few lines of code for free. If you find that your client would appreciate a clean and easy dashboard to update these parameters on the fly, then we would appreciate a recommendation of our API backend where this library can connect to, using method 1 above.

const queryform = new Queryform();
queryform.init({ debug: false, local: true }, [
    { param: 'utm_campaign', class_name: 'qf_utm_campaign' },
    { param: 'utm_medium', class_name: 'qf_utm_medium' }
]);

Parameter Formatting for Local Tracking

When using QueryformJS for local tracking, you'll define a set of parameters that map to specific fields in the query string and correspond to form inputs on your webpage. Here's how it works:

Parameters Explained

  • param: This is the key that represents the field you are looking for in the query string. For example, if a user arrives at your site via a Google AdWords campaign, Google might send a parameter like utm_campaign in the URL. This would be the value you use for the param field.

  • class_name: This is the CSS class that QueryformJS will search for when looking to populate your form inputs. The class name can be applied directly to the input element (such as a hidden input field) or to a parent element that wraps the input. This flexibility allows you to organize your HTML as needed while still enabling QueryformJS to correctly find and populate the input.

Example

Here’s an example of how to set up parameters for local tracking:

const queryform = new Queryform();
queryform.init({ local: true }, [
    { param: 'utm_campaign', class_name: 'qf_utm_campaign' },
    { param: 'utm_medium', class_name: 'qf_utm_medium' }
]);

In this example:

  • utm_campaign: This is the query string parameter that Google (or another service) might include in the URL.
  • qf_utm_campaign: This is the CSS class that QueryformJS will look for in your form inputs.

HTML Example

Given the above configuration, QueryformJS will look for form inputs like the following:

<!-- Directly on the input element -->
<input type="hidden" class="qf_utm_campaign" />

<!-- Or on a parent element -->
<div class="qf_utm_campaign">
  <input type="hidden" />
</div>

QueryformJS will automatically find these elements, and if the corresponding utm_campaign parameter is found in the URL, or has been previously saved to local storage from a different time it will populate the input with the value from the query string.

Flexibility

This setup allows you to easily track various UTM parameters and other query string values by defining the appropriate param and class_name pairs in your code. This makes QueryformJS a highly flexible tool for form tracking and campaign attribution.

Notes

  • LocalStorage is required to store and retrieve UTM parameters. This is what lets us track users over time from the same browser.
  • When using the local-driven approach, validate that the utms array is correctly formatted to avoid warnings.

License

This project is licensed under the MIT License - see the LICENSE file for details.