forked from npm/marky-markdown
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
70 lines (56 loc) · 1.73 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
var cheerio = require('cheerio')
var defaults = require('lodash.defaults')
var render = require('./lib/render')
var sanitize = require('./lib/sanitize')
var badges = require('./lib/badges')
var cdn = require('./lib/cdn')
var github = require('./lib/github')
var youtube = require('./lib/youtube')
var gravatar = require('./lib/gravatar')
var packagize = require('./lib/packagize')
var marky = module.exports = function (markdown, options) {
var html, $
if (typeof markdown !== 'string') {
throw Error('first argument must be a string')
}
options = options || {}
defaults(options, {
sanitize: true,
linkify: true,
highlightSyntax: true,
prefixHeadingIds: true,
serveImagesWithCDN: false,
debug: false,
package: null
})
var log = function (msg) {
if (options.debug) {
console.log('marky-markdown: ' + msg)
}
}
log('\n\n' + markdown + '\n\n')
log('Parse markdown into HTML and add syntax highlighting')
html = render(markdown, options)
if (options.sanitize) {
log('Sanitize malicious or malformed HTML')
html = sanitize(html)
}
log('Parse HTML into a cheerio DOM object')
$ = cheerio.load(html)
log('Make gravatar image URLs secure')
$ = gravatar($)
log('Resolve relative GitHub link hrefs')
$ = github($, options.package)
log('Dress up Youtube iframes')
$ = youtube($)
log('Add CSS classes to paragraphs containing badges')
$ = badges($)
log('Apply CSS classes to readme content already expressed by package metadata')
$ = packagize($, options.package)
if (options.serveImagesWithCDN) {
log('Rewrite relative image source to use CDN')
$ = cdn($, options.package)
}
return $
}
marky.parsePackageDescription = packagize.parsePackageDescription