Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/davidmerfield/Typeset
An HTML pre-processor for web typography
https://github.com/davidmerfield/Typeset
Last synced: 2 months ago
JSON representation
An HTML pre-processor for web typography
- Host: GitHub
- URL: https://github.com/davidmerfield/Typeset
- Owner: davidmerfield
- License: cc0-1.0
- Created: 2015-02-26T16:46:25.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2023-08-16T12:58:25.000Z (over 1 year ago)
- Last Synced: 2024-11-11T23:37:59.537Z (2 months ago)
- Language: JavaScript
- Homepage: https://typeset.lllllllllllllllll.com/
- Size: 1.94 MB
- Stars: 2,650
- Watchers: 52
- Forks: 54
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-typography - Typeset.js - HTML pre-processor for web typography (hanging punctuation, soft hyphen insertion, optical margin outdents, small-caps conversion and punctuation substitution). (JavaScript)
README
# Typeset
Typeset is an HTML pre-processor for web typography which provides typographic features used traditionally in fine printing which remain unavailable to browser layout engines. Typeset's processing brings the following to your webpages:
- [Hanging punctuation](https://en.wikipedia.org/wiki/Hanging_punctuation)
- [Ligatures](https://en.wikipedia.org/wiki/Orthographic_ligature)
- [Optical margin alignment](https://en.wikipedia.org/wiki/Optical_margin_alignment)
- [Punctuation substitution](src/punctuation.js)
- [Small caps](https://en.wikipedia.org/wiki/Small_caps)
- [Soft hyphen insertion](https://en.wikipedia.org/wiki/Soft_hyphen)Typeset does not require any client-side JavaScript and uses less than a kilobyte of CSS. Processed HTML & CSS works in Internet Explorer 5 and without any CSS. Typeset can be used manually or as a plugin for [Grunt](https://github.com/mobinni/grunt-typeset) and [gulp](https://github.com/lucasconstantino/gulp-typeset).
---
## Getting Started
### Install
```shell
$ npm i typeset
```### Usage
```js
const typeset = require('typeset');
let html = '"Hello," said the fox.
';
let output = typeset(html);
```### CSS
Then tweak the CSS to match the metrics of your font and include it on your page.```css
/*
Small Capitals
https://en.wikipedia.org/wiki/Small_caps
*/.small-caps {font-variant: small-caps;}
/*
Optical margin alignment for particular letters
https://en.wikipedia.org/wiki/Optical_margin_alignment
*/.pull-T, .pull-V, .pull-W, .pull-Y {margin-left: -0.07em}
.push-T, .push-V, .push-W, .push-Y {margin-right: 0.07em}.pull-O, .pull-C, .pull-o, .pull-c {margin-left: -0.04em}
.push-O, .push-C, .push-o, .push-c {margin-right: 0.04em}.pull-A {margin-left: -0.03em}
.push-A {margin-right: 0.03em}/*
Quotation mark
https://en.wikipedia.org/wiki/Quotation_mark
*//* Single quotation marks (') */
.pull-single{margin-left:-.27em}
.push-single{margin-right:.27em}.pull-double, .push-double,
.pull-single, .push-single {display: inline-block}/* Double quotation marks (") */
.pull-double{margin-left:-.46em}
.push-double{margin-right:.46em}
```---
### Options
You can pass an options object to influence how your HTML is typeset:
```js
const options = {
ignore: '.skip, #anything, .which-matches', // string of CSS selector(s) to ignore
only: '#only-typeset, .these-elements', // string of CSS selector(s) to exclusively apply typeset to
disable: ['hyphenate'] // array of typeset feature(s) to disable
};
```#### Features
The following features may be disabled:- `hyphenate`
- `hangingPunctuation`
- `ligatures`
- `punctuation`
- `quotes`
- `smallCaps`
- `spaces`---
## CLI Usage
```shell
$ npm i -g typeset
``````shell
Usage: typeset-js [options] [ []]Options:
-h, --help output usage information
-V, --version output the version number
-i, --ignore string of CSS selector(s) to ignore
-O, --only string of CSS selector(s) to exclusively apply typeset to
--disable, string of typeset feature(s) to disable, separated by commas
```---
### Examples:
Compile a file and print it to stdout:
```shell
$ typeset-js inputFile.html
```To create an output file, just add a second argument:
```shell
$ typeset-js inputFile.html outputFile.html
```Use the `--ignore` option to ignore specific CSS selectors:
```shell
$ typeset-js inputFile.html outputFile.html --ignore ".some-class, h3"
```Use the `--disable` option to disable typeset features:
```shell
$ typeset-js inputFile.html outputFile.html --disable "hyphenate,ligatures"
```CLI redirections:
```shell
$ cat index.html | typeset-js > outputFile.html
```---
## Plugins
- [Grunt](https://github.com/mobinni/grunt-typeset)
- [gulp](https://github.com/lucasconstantino/gulp-typeset).---
## Support
If you don't find the answer to your problem in our docs, or have a suggestion for improvements, submit your question [here](https://github.com/davidmerfield/Typeset/issues).
---
## License
This software is dedicated to the public domain and licensed under Creative Commons Zero.
See the [LICENSE](LICENSE) file for details.---
## To Do:
- [Language options & support](https://github.com/davidmerfield/Typeset/issues/25)
- [Widows & orphans](https://github.com/davidmerfield/Typeset/issues/34).
- Incorporate features from [Normalize Opentype](http://kennethormandy.com/journal/normalize-opentype-css)