-
Notifications
You must be signed in to change notification settings - Fork 2
/
gobblefile.js
112 lines (92 loc) · 3.12 KB
/
gobblefile.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*global module, require */
var gobble = require( 'gobble' );
var sander = require( 'sander' );
var marked = require( 'marked' );
var asString = { encoding: 'utf-8' };
var partials = {};
sander.readdirSync( 'src/partials' ).forEach( file => {
partials[ file.replace( '.html', '' ) ] = sander.readFileSync( `src/partials/${file}`, asString );
});
var replaceOptions = {
replacements: partials,
delimiters: [ '<@', '@>' ]
};
replaceOptions.replacements.version = require( 'buble/package.json' ).version;
module.exports = gobble([
gobble( 'src/files' )
.transform( 'replace', replaceOptions ),
// node_modules
gobble( 'node_modules/buble/dist' )
.include( 'buble-browser-deps.umd.js' ),
gobble( 'node_modules/codemirror' )
.include([ 'lib/**', 'mode/javascript/**', 'mode/shell/**' ])
.moveTo( 'codemirror' ),
// app
gobble( 'src/app' )
.transform( 'rollup', {
entry: 'main.js',
dest: 'app.js',
format: 'iife',
plugins: [
require( 'rollup-plugin-ractive' )(),
require( 'rollup-plugin-buble' )(),
require( 'rollup-plugin-node-resolve' )({
jsnext: true
})
]
}),
gobble( 'src/styles' )
.transform( 'postcss', {
src: 'index.css',
dest: 'min.css',
plugins: [
require( 'postcss-import' ),
require( 'autoprefixer' ),
require( 'postcss-nested' ),
require( 'postcss-clearfix' )
//require( 'cssnano' ) // commenting out until we can figure out how to disable z-index rebasing
],
map: true
}),
gobble( 'src/guide' )
.transform( function ( inputdir, outputdir, options, done ) {
var markdownFiles = sander.readdirSync( inputdir ).filter( file => /\.md$/.test( file ) );
var templates = {
index: sander.readFileSync( inputdir, 'index.html', asString ),
section: sander.readFileSync( inputdir, 'section.html', asString )
};
var sections = markdownFiles
.map( file => {
var markdown = sander.readFileSync( inputdir, file, asString );
var match = /---\n([\s\S]+?)\n---/.exec( markdown );
var frontMatter = match[1];
var content = markdown.slice( match[0].length );
var metadata = {};
frontMatter.split( '\n' ).forEach( pair => {
var colonIndex = pair.indexOf( ':' );
metadata[ pair.slice( 0, colonIndex ).trim() ] = pair.slice( colonIndex + 1 );
});
return {
html: marked( content ),
metadata: metadata,
slug: file.replace( /^\d+-/, '' ).replace( /\.md$/, '' )
};
});
var main = sections.map( section => {
return templates.section.replace( /\{\{([^\}]+)\}\}/g, function ( match, keypath ) {
return section.metadata[ keypath ] || section[ keypath ];
});
}).join( '\n' );
var sidebar = sections.map( section => {
return `<li><a href='#${section.slug}'>${section.metadata.title}</a></li>`;
}).join( '\n' );
var html = templates.index
.replace( '<@sidebar@>', sidebar )
.replace( '<@main@>', main );
sander.writeFileSync( outputdir, 'index.html', html );
done();
})
.transform( 'replace', replaceOptions )
.moveTo( 'guide' ),
// minify on deploy, but don't bother in development
]).transformIf( gobble.env() === 'production', 'uglifyjs' );