Skip to content
forked from bpierre/blo

๐Ÿ‘พ Fast + sharp Ethereum identical + with color

License

Notifications You must be signed in to change notification settings

jaikanthjay46/blo

ย 
ย 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 

History

28 Commits
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

blo
blo is a small and fast library to generate Ethereum identicons.

npm version bundle size License

Features

  • ๐Ÿฅ Small: 0.67 KB gzipped.
  • ๐Ÿ’ฅ Fast: 3.5x faster than the second fastest solution.
  • ๐Ÿ” Optimized: Leverages SVG to generate compact and sharp images at any size.
  • ๐Ÿ’† Simple: Focuses on Ethereum identicons only, allowing for a simpler API.
  • ๐Ÿ—‚ Typed: Ships with types included.
  • ๐Ÿ‘ซ Works everywhere: browsers, Bun, Node.js.
  • โ˜๏ธ Zero dependencies.

Library Comparison

Library Renders/sec1 Size Types Environment2 Rendering
blo ๐Ÿ’ฅ 8,197 SVG
ethereum-blockies-base64 807 PNG
blockies-react-svg 1,749 SVG
@download/blockies 334 Canvas
blockies-ts 342 Canvas
react-blockies 2,361 Canvas

Getting Started

npm i -S blo
pnpm add blo
yarn add blo
import { blo } from "blo";

img.src = blo("0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045");

React / Vue / Others

blo is fast enough to not require memoization or async rendering for common use cases.

function AddressIcon({ address }: { address: `0x${string}` }) {
  return (
    <img
      alt={address}
      src={blo(address)}
    />
  );
}

API

blo(address: Address, size = 64): string

Get a data URI string representing the identicon as an SVG image.

The size paramater shouldnโ€™t usually be needed, as the image will stay sharp no matter what the size of the img element is.

Example:

import { blo } from "blo";

img.src = blo(address); // size inside the SVG defaults to 64px
img2.src = blo(address, 24); // set it to 24px
bloWithColor(address: Address, pallette: Palette, size = 64): string

Get a data URI string representing the identicon as an SVG image.

Palette is an array of colors [background, color, spot] in HSL.

The size paramater shouldnโ€™t usually be needed, as the image will stay sharp no matter what the size of the img element is.

Example:

import { blo } from "blo";

img.src = bloWithColor(address, [
  Uint16Array.from([0, 0, 0]) // Background
  Uint16Array.from([154, 100, 50]) // Color
  Uint16Array.from([250, 100, 50]) // Spot
]); // Palette with 3 Colors, each color is HSL of Uint16Array
bloSvg(address: Address, size = 64): string

Same as above except it returns the SVG code instead of a data URI string.

bloImage(address: Address): BloImage

Get a BloImage data structure that can be used to render the image in different formats.

See src/svg.ts for an example of how to use it.

Types

The library ships with TypeScript types included.

// BloImage contains the data needed to render an icon.
export type BloImage = [BloImageData, Palette];

// 4x8 grid of the image left side, as 32 PaletteIndex items.
// The right side is omitted as it's a mirror of the left side.
export type BloImageData = Uint8Array;

// Colors used by a given icon.
export type Palette = [
  Hsl, // background
  Hsl, // color
  Hsl, // spot
];

// Points to one of the three Palette colors.
export type PaletteIndex =
  | 0 // background
  | 1 // color
  | 2; // spot

// A color in the HSL color space.
// [0]: 0-360 (hue)
// [1]: 0-100 (saturation)
// [2]: 0-100 (lightness)
export type Hsl = Uint16Array;

// An Ethereum address.
export type Address = `0x${string}`;

Acknowledgements

FAQ

Does it follow the exact same algorithm as Etherscan, MetaMask and others?

Yes.

Does it work with ENS names?

No it only works with Ethereum addresses, but you can resolve the ENS name to an address (e.g. with wagmi) and pass the result to blo.

Can blo render other formats than SVG?

You can render to any format you want by using the bloImage() function, which returns a data structure (see API above). Check out the Bun and Node demos for examples of rendering an identicon in the terminal.

Ethereum identicon rendered in the terminal

Can it be used to generate other types of identicons?

blo only focuses on the Ethereum identicons algorithm but you can use it with any data, just prefix it with 0x to fulfill the expected Address type if you are using TypeScript.

Why is it named blo?

blo is short for blockies, which is the name of the original library it is based on.

License

MIT

Footnotes

  1. The number of renders per second. It was measured on Chrome 117 Linux with an AMD Ryzen 7 PRO 4750U. See ./benchmark for the methodology. โ†ฉ

  2. The term โ€œallโ€ refers to libraries that are framework agnostic and that run in browsers, Bun and Node.js. โ†ฉ

About

๐Ÿ‘พ Fast + sharp Ethereum identical + with color

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 94.6%
  • JavaScript 3.2%
  • HTML 2.2%