• Stars
    star
    152
  • Rank 244,685 (Top 5 %)
  • Language
    TypeScript
  • License
    MIT License
  • Created almost 7 years ago
  • Updated over 4 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

✏️ Font selector component for Google Fonts

Font Picker for React

A simple, customizable font picker allowing users to preview, select and use Google Fonts on your website.

  • Simple setup
  • No dependencies
  • Automatic font download and generation of the required CSS selectors
  • Efficient font previews (full fonts are only downloaded on selection)

Demo

This is the React component for the Font Picker library.

Font picker demo

Getting started

To be able to access the API, you'll need to generate a Google Fonts API key.

1. Setup

Install the font-picker-react package using NPM:

npm install font-picker-react

2. Displaying the font picker

Add the FontPicker component to your React code:

import React, { Component } from "react";
import FontPicker from "font-picker-react";

export default class ExampleComponent extends Component {
	constructor(props) {
		super(props);
		this.state = {
			activeFontFamily: "Open Sans",
		};
	}

	render() {
		return (
			<div>
				<FontPicker
					apiKey="YOUR_API_KEY"
					activeFontFamily={this.state.activeFontFamily}
					onChange={(nextFont) =>
						this.setState({
							activeFontFamily: nextFont.family,
						})
					}
				/>
				<p className="apply-font">The font will be applied to this text.</p>
			</div>
		);
	}
}

3. Applying the selected font

Add the class "apply-font" to all JSX elements you want to apply the selected font to.

When the user selects a font, it will automatically be downloaded and applied to all elements with the "apply-font" class.

Props

The following props can be passed to the FontPicker component:

  • apiKey (required): Google API key
  • activeFontFamily: Font that should be selected in the font picker and applied to the text. Should be stored in the component state and updated using onChange
  • onChange: Function which is executed when the user changes the active font. This function should update activeFontFamily in the component state
  • pickerId: If you have multiple font pickers on your site, you need to give them unique IDs which must be provided as a prop and appended to the .apply-font class names. Example: If pickerId="main", use className="apply-font-main"
  • families: If only specific fonts shall appear in the list, specify their names in an array. Default: All font families
  • categories: Array of font categories to include in the list. Possible values: "sans-serif", "serif", "display", "handwriting", "monospace". Default: All categories
  • scripts: Array of scripts which the fonts must include and which will be downloaded on font selection. Default: ["latin"]. Example: ["latin", "greek", "hebrew"] (see all possible values)
  • variants: Array of variants which the fonts must include and which will be downloaded on font selection. Default: ["regular"]. Example: ["regular", "italic", "700", "700italic"] (see all possible values)
  • filter: Function which must evaluate to true for a font to be included in the list. Default: font => true. Example: If font => font.family.toLowerCase().startsWith("m"), only fonts whose names begin with "M" will be in the list
  • limit: Maximum number of fonts to display in the list (the least popular fonts will be omitted). Default: 50
  • sort: Sorting attribute for the font list. Possible values: "alphabet", "popularity". Default: "alphabet"

Currently, only the activeFontFamily, onChange and sort props are reactive.

Development

Requirements: Node.js, Yarn

  1. Clone this repository: git clone REPO_URL
  2. Install all dependencies: yarn
  3. Generate the library bundle: yarn start
  4. View the rendered component on localhost:3000

Suggestions and contributions are always welcome! Please discuss larger changes via issue before submitting a pull request.

More Repositories

1

mini-diary

📘 Simple and secure journal app
TypeScript
1,031
star
2

glance

🔎 All-in-one Quick Look plugin
Swift
953
star
3

action-electron-builder

:electron: GitHub Action for building and releasing Electron apps
JavaScript
651
star
4

tmignore

🕔 Exclude development files from Time Machine backups
Swift
322
star
5

font-picker

✏️ Font selector component for Google Fonts
TypeScript
171
star
6

react-magnifier

🔍 React image zoom component
TypeScript
151
star
7

action-maven-publish

📦 GitHub Action for automatically publishing Maven packages
JavaScript
101
star
8

lyrics-poster

🎤 Create posters of your favorite artists, written in their lyrics
JavaScript
63
star
9

refind-theme-dark

🎨 A simple, dark theme for rEFInd
54
star
10

action-snapcraft

🐦 GitHub Action for setting up Snapcraft
JavaScript
49
star
11

font-manager

🗂 Manages, downloads and applies Google Fonts for picker components
TypeScript
27
star
12

swift-exec

🚀 Simple process execution with Swift
Swift
16
star
13

draft-js-list-plugin

📝 Better lists for Draft.js
TypeScript
14
star
14

python-wikibase

🤖 Wikibase queries and edits made easy
Python
11
star
15

nbtohtml

📈 Convert Jupyter Notebook files to HTML
Go
9
star
16

github-downloads

⬇️ See the number of downloads next to releases on GitHub
JavaScript
8
star
17

alfred-system-theme

🎨 Alfred themes in style of Apple's macOS apps
7
star
18

react-library-boilerplate

🔨 Create a React component library with no configuration
JavaScript
6
star
19

iconsets.org

🌟 Icon set discovery website for designers
JavaScript
5
star
20

wikibase-api

📦 Wrapper library for the Wikibase API
Python
4
star
21

anonymize-ip

👤 Python library for anonymizing IP addresses
Python
4
star
22

strava-bulk-edit

🏃 Edit multiple Strava activities at once
Go
2
star
23

electron-md-to-pdf

:electron: Convert Markdown to PDF in Electron apps
CSS
2
star
24

hugo-starter-theme

🔨 Boilerplate for building a custom Hugo theme
HTML
2
star
25

samuelmeuli.com

👨‍💻 My personal website
CSS
1
star
26

music-notifications

🎵 Notification service for new releases on iTunes
JavaScript
1
star
27

prettier-config

☑️ My Prettier configuration
JavaScript
1
star
28

react-app-boilerplate

🔨 Create a React application with no configuration
JavaScript
1
star