• Stars
    star
    1,369
  • Rank 34,342 (Top 0.7 %)
  • Language
    TypeScript
  • License
    MIT License
  • Created almost 11 years ago
  • Updated over 1 year ago

Reviews

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

Repository Details

πŸ“š Medium's like reading time estimation.

reading-time

NPM Build Status


Medium's like reading time estimation.

reading-time helps you estimate how long an article will take to read. It works perfectly with plain text, but also with markdown or html.

Note that it's focused on performance and simplicity, so the number of words it will extract from other formats than plain text can vary a little. But this is an estimation right?

Installation

npm install reading-time --production

Usage

Classic

// In Node.js
const readingTime = require('reading-time');
// In the browser
const readingTime = require('reading-time/lib/reading-time');

const stats = readingTime(text);
// ->
// stats: {
//   minutes: 1,
//   time: 60000,
//   words: {total: 200}
// }
console.log(`The reading time is: ${stats.minutes} min`);
πŸ™‹β€β™‚οΈ Why different imports for Node.js and the browser?

This library is primarily for Node.js. The entrypoint also exports a ReadingTimeStream class which is, without polyfills, not supported in browsers. A simple workaround is to import the underlying lib/reading-time module.

Note that in the upcoming 2.0.0 version, this won't be necessary anymore.

Stream

const {ReadingTimeStream, readingTimeWithCount} = require('reading-time');

const analyzer = new ReadingTimeStream();
fs.createReadStream('foo')
  .pipe(analyzer)
  .on('data', (count) => {
    console.log(`The reading time is: ${readingTimeWithCount(count).minutes} min`);
  });
πŸ™‹β€β™‚οΈ Can I use this in the browser?

Yes. You need to provide the appropriate polyfills. Please refer to your bundler's documentation.

API

readingTime(text, options?)

Returns an object with minutes, time (in milliseconds), and words.

type ReadingTimeResults = {
  minutes: number;
  time: number;
  words: WordCountStats;
};
  • text: the text to analyze
  • options (optional)
    • options.wordsPerMinute: (optional) the words per minute an average reader can read (default: 200)
    • options.wordBound: (optional) a function that returns a boolean value depending on if a character is considered as a word bound (default: spaces, new lines and tabs)

countWords(text, options?)

Returns an object representing the word count stats:

type WordCountStats = {
  total: number;
};
  • text: the text to analyze
  • options (optional)
    • options.wordBound: (optional) a function that returns a boolean value depending on if a character is considered as a word bound (default: spaces, new lines and tabs)

readingTimeWithCount(words, options?)

Returns an object with minutes (rounded minute stats) and time (exact time in milliseconds).

  • words: the word count stats
  • options (optional)
    • options.wordsPerMinute: (optional) the words per minute an average reader can read (default: 200)

Note that readingTime(text, options) === readingTimeWithCount(countWords(text, options), options).

Help wanted!

This library has been optimized for alphabetical languages and CJK languages, but may not behave correctly for other languages that don't use spaces for word bounds. If you find the behavior of this library to deviate significantly from your expectation, issues or contributions are welcomed!

Other projects

  • Fauda: configuration made simple.
  • Badge Size: Displays the size of a given file in your repository.
  • Commitizen Emoji: Commitizen adapter formatting commit messages using emojis.

More Repositories

1

jquery.finger

✌️ jQuery touch & gestures, fingers in the nose.
JavaScript
426
star
2

cz-emoji

Commitizen adapter formatting commit messages using emojis.
JavaScript
356
star
3

badge-size

🍻 Displays the size of a given file in your repository.
JavaScript
298
star
4

gulp-bro

πŸ‘Š gulp + browserify + incremental build, done right.
JavaScript
121
star
5

social-redirects

🐳 Redirect glyph urls to your social networks profiles.
PHP
86
star
6

tree-crawl

πŸƒ Agnostic tree traversal library.
JavaScript
84
star
7

raf.js

πŸƒ Request Animation Frame polyfill
JavaScript
45
star
8

lol-champions

Simplified, up-to-date, League of Legends champions list.
JavaScript
45
star
9

ribs

πŸ– Responsive Images Baked Server-side.
JavaScript
39
star
10

fauda

Configuration made simple.
TypeScript
33
star
11

contributor-faces

Put your contributors faces in your readme.
JavaScript
31
star
12

virtual-pointer

Simulates a pointer with jQuery in PhantomJS and the browser.
JavaScript
25
star
13

codesandbox-theme

Codesandbox theme for VSCode.
22
star
14

obelisk-buildr

Isometric builder using obelisk.js.
JavaScript
21
star
15

compass

Compass wrapper and middleware for node.js.
JavaScript
16
star
16

lol-items

Simplified, up-to-date, League of Legends items list.
JavaScript
8
star
17

awesome-stars

A curated list of my GitHub stars!
7
star
18

tree-morph

πŸƒ Agnostic tree morphing library.
JavaScript
6
star
19

qs-numbers

A qs plugin that enables number parsing.
JavaScript
6
star
20

sass-dry

DRY your SASS code.
CSS
6
star
21

grunt-glue-js

Grunt task to build CommonJS modules for the browser using gluejs.
JavaScript
5
star
22

tree-mutate

πŸƒ n-ary tree mutation library.
JavaScript
4
star
23

lol-spells

Simplified, up-to-date, League of Legends summoner spells list.
JavaScript
4
star
24

v8-windows-tickprocessor

Drop-in v8 windows tick processor for profiling
4
star
25

readme-filename

Get a project readme file name.
JavaScript
3
star
26

mincmp

🍷 Compare npm package source files minimaps
JavaScript
3
star
27

woot-bar

Very minimalist tmux status bar that displays used memory and CPU usage.
Rust
3
star
28

experiment-car-drawing

Car Drawing Experiment
JavaScript
3
star
29

simulator

Mouse and touch events simulator
JavaScript
3
star
30

object-defaults

Like _.defaults, assigns properties of source objects to a target, without overriding existing ones.
JavaScript
2
star
31

hi5

Friendly lightweight type checker πŸ™Œ.
JavaScript
2
star
32

meta-dev

πŸ“¦ Meta package for devDependencies.
JavaScript
2
star
33

vinyl-adapter-picker

Protocol based vinyl adapter picker.
JavaScript
2
star
34

ds-linked-list

A simply linked list data structure in JavaScript.
JavaScript
2
star
35

optify

Generates a combination matrix from a set key/value pairs.
JavaScript
2
star
36

p-using

Dispose a resource when p-using promise resolves.
JavaScript
1
star
37

gulp-pimp

Pimp your imports!
JavaScript
1
star
38

ngryman.github.io

Script that executes me.
HTML
1
star
39

ViZion

OS for multimedia box in HTML and running on Node.JS
JavaScript
1
star
40

bookmarks-baby

Bookmarks Baby!
JavaScript
1
star
41

leap-impress

Control your Impress.js presentations with gestures using Leap Motion.
JavaScript
1
star
42

compare-values

Get functions to compare two values given an operator.
JavaScript
1
star
43

love-hate-particles

This is a little experiment about two particles' relationship.
CoffeeScript
1
star
44

thread-sass-loaders-bug

JavaScript
1
star
45

live-templates

A collection of handy live templates I use with IntelliJ / WebStorm.
1
star
46

npm-v

Get installed npm version
JavaScript
1
star
47

gulp-say

Text To Speech errors for gulp.
JavaScript
1
star
48

webstorm-libraries

Set of JavaScript for WebStorm and IntelliJ.
JavaScript
1
star
49

to-method

βš“ Convert c-like functions to class methods.
JavaScript
1
star
50

graceful-fs-stream

Graceful filesystem streams.
JavaScript
1
star
51

loop.js

HTML5 game ecosystem
JavaScript
1
star
52

traps

🐺 Capture me if you can!
JavaScript
1
star
53

lines-iterator

Iterates over lines, es6 way.
JavaScript
1
star
54

asmr

Show a list of your repos. That's it!
JavaScript
1
star
55

wombat-js

Javascript Game Engine
JavaScript
1
star
56

letenv

CLI environment variables loader.
JavaScript
1
star
57

unchain

Synchronous function chaining with delay support.
JavaScript
1
star
58

stores

Stores things efficiently. Don't worry about cache stampede anymore.
JavaScript
1
star
59

generator-library

Scaffold a generic node library.
JavaScript
1
star
60

compare-properties

Get functions to compare two object properties given an operator.
JavaScript
1
star