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 🙏

© 2024 – Pkg Stats / Ryan Hefner

vue-ab-tests

v0.0.1

Published

Package for A/B testing of the site and components

Downloads

9

Readme

vue-ab-tests

Package for A/B testing of the site and components

Install

npm install vue-ab-tests

Usage

Plugin registration:

import { createApp } from 'vue'
import { ABTestPlugin } from 'vue-ab-tests';

createApp(App)
  .use(ABTestPlugin)
  .mount('#app')

When connecting globally, the ab-tests and ab-test components will be available.

Importing components:

import { ABTests, ABTest } from 'vue-ab-tests';

The ABTests component is a group of tests. The tests themselves must be located inside, in the form of an ABTest component, otherwise they will be ignored.

Example

<template>
  <ABTests name="ab-tests" :storage="StorageType.Cookie">
    <ABTest name="test-1" :chance="2">
      <h1>Test 1</h1>
      <p>Test 1 content</p> 
    </ABTest>
    <ABTest name="test-2" :chance="1">
      <h1>Test 2</h1>
      <p>Test 2 content</p> 
    </ABTest> 
  </ABTests>
</template>

<script setup lang="ts"> 
import { ABTests, ABTest, StorageType } from 'vue-ab-tests';
</script>

In this example, two tests are created, test-1 has priority 2, and test-2 has priority 1. In this case, test-1 has approximately 66% chance of being shown, and test-2 has approximately 34%.

Docs

StorageType

The storage type to save the selected option for the first time.

  • StorageType.LocalStorage - Save the selected option in the browser's local storage.
  • StorageType.Cookie - Save the selected option in the browser's cookie.

ABTests

Props

  • name: string - The name of the group of tests. The name will be used to save the selected option in the repository.
  • storage?: StorageType - (default: StorageType.LocalStorage) The storage type to save the selected option for the first time.
  • expire?: number - (default: 30) Time in days for which the first selected option will be saved.

Slots

  • default: ABTest[]

Events

  • selected: (name: string) => void - Called when a variant is selected.
  • reselected: (name: string) => void - Called when a variant is reselected. When this event was called, the selection of the component was based on the user's saved data after the very first impression.
<template>
  <ABTests @selected="selected">
    <ABTest name="test-1" :chance="2">
      ...
    </ABTest>
    <ABTest name="test-2" :chance="1">
      ...
    </ABTest> 
  </ABTests>
</template>

<script setup lang="ts">
  import { ABTests, ABTest } from 'vue-ab-tests';

  const selected = (name: string) => {
    console.log(name)
  }
</script>

ABTest

Props

  • name: string - The name of the variant.
  • chance?: number - (default: 1) The chance of the variant being selected.

Slots

  • default: any

useVariant

Returns a random variant from the given array of variants based on their chance.

  • variants: Variant<T>[] - An array of variants.
    • Variant.name: string - The name of the variant.
    • Variant.chance: number - The chance of the variant being selected.
    • Variant.data: T - The data associated with the variant.
  • @return {Variant<T> | null} - A random variant from the given array or null if the array is empty.
import { useVariant } from 'vue-ab-tests';
import type { Variant } from 'vue-ab-tests';

const variants: Variant<string>[] = [
  {
    name: "test-1",
    chance: 2,
    data: "Test 1"
  },
  {
    name: "test-2",
    chance: 1,
    data: "Test 2"
  }
];
const result = useVariant(variants);

console.log(result.name)