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

voucher-ts

v2.1.0

Published

TypeScript SDK for redeeming TrueWallet vouchers (zero dependencies)

Downloads

2

Readme

TrueWallet Voucher SDK

A zero-dependency TypeScript SDK for redeeming TrueWallet vouchers. This SDK provides a simple way to redeem TrueWallet gift vouchers programmatically.

Features

  • 🚀 Zero runtime dependencies
  • 📦 Tiny bundle size
  • 💪 Full TypeScript support
  • ⚡️ Native fetch API
  • 🔒 Built-in URL validation
  • 🌐 ESM and CommonJS support

Requirements

  • Node.js >= 18.0.0 (for native fetch API support)

Installation

npm install voucher-ts

Usage

Basic Usage

import { TrueWalletVoucher } from "voucher-ts";

// Initialize with your mobile number
const wallet = new TrueWalletVoucher({
  mobile: "0812345678",
});

// Redeem a voucher
try {
  const result = await wallet.redeem(
    "https://gift.truemoney.com/campaign/?v=abcdefghijk"
  );

  if ("error" in result) {
    console.error("Error:", result.error);
    return;
  }

  console.log("Success! Amount:", result.amount);
  console.log("Full response:", result.originalData);
} catch (error) {
  console.error("Failed to redeem voucher:", error);
}

TypeScript Usage

The SDK provides full TypeScript support with detailed type definitions:

import {
  TrueWalletVoucher,
  TrueWalletResult,
  TrueWalletError,
  TrueWalletSuccess,
} from "voucher-ts";

async function redeemVoucher(url: string): Promise<number | null> {
  const wallet = new TrueWalletVoucher({
    mobile: "0812345678",
  });

  const result: TrueWalletResult = await wallet.redeem(url);

  if ("error" in result) {
    // Result is TrueWalletError
    console.error("Failed:", result.error);
    console.error("Error code:", result.code);
    return null;
  }

  // Result is TrueWalletSuccess
  return result.amount;
}

Error Handling

The SDK uses a discriminated union type for results. Each redemption attempt returns either a success or error result:

Success Result Type

interface TrueWalletSuccess {
  amount: number;
  originalData: TrueWalletVoucherResponse;
}

Error Result Type

interface TrueWalletError {
  error: string;
  code: TrueWalletStatusCode;
}

Error Codes

| Code | Description | Thai Message | | ---------------------- | ------------------------- | ---------------------------------- | | TARGET_USER_REDEEMED | Voucher already redeemed | ซองของขวัญนี้ถูกใช้ไปแล้ว | | INTERNAL_ERROR | Internal server error | ไม่พบซองของขวัญหรือ URL ผิดพลาด | | CANNOT_GET_OWN_VOUCHER | Cannot redeem own voucher | ไม่สามารถใช้ซองของขวัญของตัวเองได้ | | VOUCHER_EXPIRED | Voucher has expired | ซองของขวัญหมดอายุแล้ว | | VOUCHER_OUT_OF_STOCK | Voucher is out of stock | ซองของขวัญถูกใช้ไปแล้ว | | VOUCHER_NOT_FOUND | Voucher not found | ไม่พบซองของขวัญนี้ |

URL Validation

The SDK includes built-in validation for TrueWallet voucher URLs. Invalid URLs will throw a ValidationError:

// These will throw ValidationError
await wallet.redeem(""); // Error: กรุณากรอก URL
await wallet.redeem("https://wrong-url.com"); // Error: URL ไม่ถูกต้อง

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

ISC License