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

@shaivpidadi/trends-js

v1.0.1

Published

Google Trends API for Node.js

Readme

A TypeScript library for interacting with the Google Trends API. This package provides a simple and type-safe way to access Google Trends data programmatically.

Showcase

EliteTimesNews.com — Built with @shaivpidadi/trends-js

URL: https://elitetimesnews.com
What it uses: dailyTrends() (US, en) to power the home page “Daily Trending” rail, refreshed on a schedule.

Installation

npm install @shaivpidadi/trends-js

Features

  • Get daily trending topics
  • Get real-time trending topics
  • Get autocomplete suggestions
  • Explore trends data
  • Get interest by region data
  • Get related topics for any keyword
  • Get related queries for any keyword
  • Get combined related data (topics + queries)
  • TypeScript support
  • Promise-based API

Usage

Importing

import GoogleTrendsApi from '@shaivpidadi/trends-js';

Daily Trends

Get daily trending topics for a specific region:

const result = await GoogleTrendsApi.dailyTrends({
  geo: 'US', // Default: 'US'
  lang: 'en', // Default: 'en'
});

// Result structure:
// {
//   allTrendingStories: Array<{
//     title: string,
//     traffic: string,
//     image?: {
//       newsUrl: string,
//       source: string,
//       imageUrl: string
//     },
//     articles: Array<{
//       title: string,
//       url: string,
//       source: string,
//       time: string,
//       snippet: string
//     }>,
//     shareUrl: string,
//     startTime: number,      // Unix timestamp
//     endTime?: number        // Unix timestamp (optional)
//   }>,
//   summary: Array<...>
// }

Real-Time Trends

Get real-time trending topics:

const result = await GoogleTrendsApi.realTimeTrends({
  geo: 'US', // Default: 'US'
  trendingHours: 4, // Default: 4
});

// Result structure:
// {
//   allTrendingStories: Array<{
//     title: string,
//     traffic: string,
//     image?: {
//       newsUrl: string,
//       source: string,
//       imageUrl: string
//     },
//     articles: Array<{
//       title: string,
//       url: string,
//       source: string,
//       time: string,
//       snippet: string
//     }>,
//     shareUrl: string,
//     startTime: number,      // Unix timestamp
//     endTime?: number        // Unix timestamp (optional)
//   }>,
//   summary: Array<...>
// }

Autocomplete

Get search suggestions for a keyword:

const suggestions = await GoogleTrendsApi.autocomplete(
  'bitcoin', // Keyword to get suggestions for
  'en-US', // Language (default: 'en-US')
);

// Returns: string[]

Explore

Get widget data for a keyword:

const result = await GoogleTrendsApi.explore({
  keyword: 'bitcoin',
  geo: 'US', // Default: 'US'
  time: 'today 12-m', // Default: 'today 12-m'
  category: 0, // Default: 0
  property: '', // Default: ''
  hl: 'en-US', // Default: 'en-US'
});

// Result structure:
// {
//   widgets: Array<{
//     id: string,
//     request: {...},
//     token: string
//   }>
// }

Interest by Region

Get interest data by region:

const result = await GoogleTrendsApi.interestByRegion({
  keyword: 'Stock Market', // Required - string or string[]
  startTime: new Date('2024-01-01'), // Optional - defaults to 2004-01-01
  endTime: new Date(), // Optional - defaults to current date
  geo: 'US', // Optional - string or string[] - defaults to 'US'
  resolution: 'REGION', // Optional - 'COUNTRY' | 'REGION' | 'CITY' | 'DMA'
  hl: 'en-US', // Optional - defaults to 'en-US'
  timezone: -240, // Optional - defaults to local timezone
  category: 0, // Optional - defaults to 0
});

// Result structure:
// {
//   default: {
//     geoMapData: Array<{
//       geoCode: string,
//       geoName: string,
//       value: number[],
//       formattedValue: string[],
//       maxValueIndex: number,
//       hasData: boolean[],
//       coordinates?: {
//         lat: number,
//         lng: number
//       }
//     }>
//   }
// }

Example with multiple keywords and regions:

const result = await GoogleTrendsApi.interestByRegion({
  keyword: ['wine', 'peanuts'],
  geo: ['US-CA', 'US-VA'],
  startTime: new Date('2024-01-01'),
  endTime: new Date(),
  resolution: 'CITY',
});

Related Topics

Get related topics for any keyword:

const result = await GoogleTrendsApi.relatedTopics({
  keyword: 'artificial intelligence', // Required
  geo: 'US', // Optional - defaults to 'US'
  time: 'now 1-d', // Optional - defaults to 'now 1-d'
  category: 0, // Optional - defaults to 0
  property: '', // Optional - defaults to ''
  hl: 'en-US', // Optional - defaults to 'en-US'
});

// Result structure:
// {
//   data: {
//     default: {
//       rankedList: Array<{
//         rankedKeyword: Array<{
//           topic: {
//             mid: string,
//             title: string,
//             type: string
//           },
//           value: number,
//           formattedValue: string,
//           hasData: boolean,
//           link: string
//         }>
//       }>
//     }
//   }
// }

Related Queries

Get related queries for any keyword:

const result = await GoogleTrendsApi.relatedQueries({
  keyword: 'machine learning', // Required
  geo: 'US', // Optional - defaults to 'US'
  time: 'now 1-d', // Optional - defaults to 'now 1-d'
  category: 0, // Optional - defaults to 0
  property: '', // Optional - defaults to ''
  hl: 'en-US', // Optional - defaults to 'en-US'
});

// Result structure:
// {
//   data: {
//     default: {
//       rankedList: Array<{
//         rankedKeyword: Array<{
//           query: string,
//           value: number,
//           formattedValue: string,
//           hasData: boolean,
//           link: string
//         }>
//       }>
//     }
//   }
// }

Combined Related Data

Get both related topics and queries in a single call:

const result = await GoogleTrendsApi.relatedData({
  keyword: 'blockchain', // Required
  geo: 'US', // Optional - defaults to 'US'
  time: 'now 1-d', // Optional - defaults to 'now 1-d'
  category: 0, // Optional - defaults to 0
  property: '', // Optional - defaults to ''
  hl: 'en-US', // Optional - defaults to 'en-US'
});

// Result structure:
// {
//   data: {
//     topics: Array<RelatedTopic>,
//     queries: Array<RelatedQuery>
//   }
// }

API Reference

DailyTrendsOptions

interface DailyTrendsOptions {
  geo?: string; // Default: 'US'
  lang?: string; // Default: 'en'
}

RealTimeTrendsOptions

interface RealTimeTrendsOptions {
  geo: string;
  trendingHours?: number; // Default: 4
}

ExploreOptions

interface ExploreOptions {
  keyword: string;
  geo?: string; // Default: 'US'
  time?: string; // Default: 'today 12-m'
  category?: number; // Default: 0
  property?: string; // Default: ''
  hl?: string; // Default: 'en-US'
}

InterestByRegionOptions

interface InterestByRegionOptions {
  keyword: string | string[]; // Required - search term(s)
  startTime?: Date; // Optional - start date
  endTime?: Date; // Optional - end date
  geo?: string | string[]; // Optional - geocode(s)
  resolution?: 'COUNTRY' | 'REGION' | 'CITY' | 'DMA'; // Optional
  hl?: string; // Optional - language code
  timezone?: number; // Optional - timezone offset
  category?: number; // Optional - category number
}

RelatedTopicsResponse

interface RelatedTopicsResponse {
  default: {
    rankedList: Array<{
      rankedKeyword: Array<{
        topic: {
          mid: string;
          title: string;
          type: string;
        };
        value: number;
        formattedValue: string;
        hasData: boolean;
        link: string;
      }>;
    }>;
  };
}

RelatedQueriesResponse

interface RelatedQueriesResponse {
  default: {
    rankedList: Array<{
      rankedKeyword: Array<{
        query: string;
        value: number;
        formattedValue: string;
        hasData: boolean;
        link: string;
      }>;
    }>;
  };
}

RelatedData

interface RelatedData {
  topics: Array<RelatedTopic>;
  queries: Array<RelatedQuery>;
}

Development

Building