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

hex-color-randomizer

v1.0.5

Published

A TypeScript package for generating random hex color codes.

Downloads

29

Readme

Hex Color Randomizer

A TypeScript package for generating random hex color codes with advanced options, including avoiding certain colors or shades. This package is useful for creating unique color schemes or avoiding specific colors in your projects.

Features

  • Generate a single random hex color code.
  • Generate an array of random hex color codes.
  • Avoid generating colors similar to a specified background color.
  • Avoid generating colors from a specified list.
  • Optionally remember previously generated colors and avoid shades of a specified background color.
  • Generate colors biased towards a specific color.
  • Create palettes of analogous or complementary colors.

Installation

To install the package, run:

npm install hex-color-randomizer

Usage

First, import the class from the package:

import { ColorGenerator } from 'hex-color-randomizer';

Methods

generateRandomHexColor()

Generates a single random hex color code.

  • Returns: string - A random hex color code in the format #RRGGBB.

Example:

const color = ColorGenerator.generateRandomHexColor();
console.log(color); // e.g., "#A3C1AD"

generateRandomHexColorsArray(num: number)

Generates an array of random hex color codes.

  • Parameters:
    • num (number): The number of hex color codes to generate.
  • Returns: string[] - An array of random hex color codes.

Example:

const colors = ColorGenerator.generateRandomHexColorsArray(5);
console.log(colors); // e.g., ["#E57373", "#F06292", "#BA68C8", "#64B5F6", "#4DB6AC"]

generateColorsAvoidingBgColor(bgColor: string, num: number)

Generates an array of hex color codes that are not similar to a specified background color.

  • Parameters:

    • bgColor (string): The background color to avoid shades of, in hex format (e.g., #FFFFFF).
    • num (number): The number of hex color codes to generate.
  • Returns: string[] - An array of hex color codes avoiding shades of the background color.

  • Throws: Error - If it cannot generate the required number of suitable colors within the maximum attempts.

Example:

const colors = ColorGenerator.generateColorsAvoidingBgColor("#FFFFFF", 3);
console.log(colors); // e.g., ["#E57373", "#F06292", "#BA68C8"]

generateColorsAvoidingArray(avoidColors: string[], num: number)

Generates an array of hex color codes that do not include any colors from a specified array of colors to avoid.

  • Parameters:
    • avoidColors (string[]): An array of hex color codes to avoid.
    • num (number): The number of hex color codes to generate.
  • Returns: string[] - An array of hex color codes that do not include any colors from the avoidColors array.

Example:

const avoidColors = ["#FF0000", "#00FF00"];
const colors = ColorGenerator.generateColorsAvoidingArray(avoidColors, 3);
console.log(colors); // e.g., ["#E57373", "#F06292", "#BA68C8"]

generateColorsWithMemoryAvoidingShades(bgColor: string, num: number, remember: boolean)

Generates an array of hex color codes, optionally remembering previously generated colors and avoiding shades of a specified background color.

  • Parameters:
    • bgColor (string): The background color to avoid shades of, in hex format (e.g., #FFFFFF).
    • num (number): The number of hex color codes to generate.
    • remember (boolean): Whether to remember previously generated colors. If true, previously generated colors will be kept in memory and new colors will be appended to this list. If false, previously generated colors will be cleared.
  • Returns: string[] - An array of hex color codes, which may include previously generated colors depending on the remember parameter.

Example:

const colors = ColorGenerator.generateColorsWithMemoryAvoidingShades("#FFFFFF", 5, true);
console.log(colors); // e.g., ["#E57373", "#F06292", "#BA68C8", "#64B5F6", "#4DB6AC"]

generateBiasedColor(biasColor: string)

Generates a random color with a bias towards a certain color.

  • Parameters:

    • biasColor (string): The color to bias towards in hex format (e.g., #FF0000).
  • Returns: string - A random color biased towards the specified color.

  • Throws: Error - If the bias color is invalid.

Example:

const biasedColor = ColorGenerator.generateBiasedColor("#FF0000");
console.log(biasedColor); // e.g., "#FF7F7F"

generateAnalogousPalette(baseColor: string, num: number)

Generates a palette of analogous colors based on a base color.

  • Parameters:

    • baseColor (string): The base color in hex format (e.g., #FF0000).
    • num (number): The number of analogous colors to generate.
  • Returns: string[] - An array of analogous color codes.

  • Throws: Error - If the base color is invalid.

Example:

const analogousPalette = ColorGenerator.generateAnalogousPalette("#FF0000", 5);
console.log(analogousPalette); // e.g., ["#FF0000", "#FF3F00", "#FF7F00", "#FFBF00", "#FFFF00"]

generateComplementaryPalette(baseColor: string)

Generates a palette of complementary colors based on a base color.

  • Parameters:

    • baseColor (string): The base color in hex format (e.g., #FF0000).
  • Returns: string[] - An array of complementary color codes.

  • Throws: Error - If the base color is invalid.

Example:

const complementaryPalette = ColorGenerator.generateComplementaryPalette("#FF0000");
console.log(complementaryPalette); // e.g., ["#FF0000", "#00FFFF"]

Example

Here’s an example of using the package to generate random colors while avoiding certain shades:

import { ColorGenerator } from 'hex-color-randomizer';

const initialColors = ColorGenerator.generateColorsAvoidingBgColor("#FF0000", 5);
console.log('Initial colors:', initialColors);

const moreColors = ColorGenerator.generateColorsWithMemoryAvoidingShades("#FF0000", 5, true);
console.log('More colors:', moreColors);

License

This package is licensed under the MIT License.