Skip to content

Commit

Permalink
Added Pug support from parcel-plugin-pug (#1051)
Browse files Browse the repository at this point in the history
  • Loading branch information
Ty3uK authored and devongovett committed Mar 28, 2018
1 parent 4bd32f2 commit 09a959d
Show file tree
Hide file tree
Showing 21 changed files with 416 additions and 10 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@
"postcss-modules": "^0.8.0",
"posthtml-include": "^1.1.0",
"prettier": "^1.9.1",
"pug": "^2.0.3",
"rimraf": "^2.6.1",
"sinon": "^4.2.2",
"sourcemap-validator": "^1.0.6",
Expand Down
3 changes: 3 additions & 0 deletions src/Parser.js
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,9 @@ class Parser {
this.registerExtension('vert', './assets/GLSLAsset');
this.registerExtension('frag', './assets/GLSLAsset');

this.registerExtension('jade', './assets/PugAsset');
this.registerExtension('pug', './assets/PugAsset');

let extensions = options.extensions || {};
for (let ext in extensions) {
this.registerExtension(ext, extensions[ext]);
Expand Down
39 changes: 39 additions & 0 deletions src/assets/PugAsset.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
const path = require('path');
const Asset = require('../Asset');
const localRequire = require('../utils/localRequire');

class PugAsset extends Asset {
constructor(name, pkg, options) {
super(name, pkg, options);
this.type = 'html';
}

async generate() {
const pug = await localRequire('pug', this.name);
const config =
(await this.getConfig(['.pugrc', '.pugrc.js', 'pug.config.js'])) || {};

const compiled = pug.compile(this.contents, {
compileDebug: false,
filename: this.name,
basedir: path.dirname(this.name),
pretty: !this.options.minify,
templateName: path.basename(this.basename, path.extname(this.basename)),
filters: config.filters,
filterOptions: config.filterOptions,
filterAliases: config.filterAliases
});

if (compiled.dependencies) {
for (let item of compiled.dependencies) {
this.addDependency(item, {
includedInParent: true
});
}
}

return compiled();
}
}

module.exports = PugAsset;
7 changes: 7 additions & 0 deletions test/integration/pug-filters/.pugrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
module.exports = {
filters: {
'custom-filter': function (text, options) {
return 'FILTERED: ' + text;
}
}
}
2 changes: 2 additions & 0 deletions test/integration/pug-filters/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
:custom-filter()
Hello!
4 changes: 4 additions & 0 deletions test/integration/pug-include-extends/base.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
doctype html
html
body
block content
6 changes: 6 additions & 0 deletions test/integration/pug-include-extends/expect.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<!DOCTYPE html>
<html>
<body>
<h1>Yep, it's working!</h1>
</body>
</html>
4 changes: 4 additions & 0 deletions test/integration/pug-include-extends/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
extends ./base.pug

block content
include other.pug
1 change: 1 addition & 0 deletions test/integration/pug-include-extends/other.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
h1 Yep, it's working!
6 changes: 6 additions & 0 deletions test/integration/pug-minify/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
doctype html
html
head
title Minify
body
h1 Minified
8 changes: 8 additions & 0 deletions test/integration/pug-mixins/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
include ./mixins.pug

doctype html
html
head
title Pug variables
body
+greetings('Parcel')
2 changes: 2 additions & 0 deletions test/integration/pug-mixins/mixins.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
mixin greetings(name)
h1 Greetings, #{name}
Binary file added test/integration/pug-var/100x100.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
7 changes: 7 additions & 0 deletions test/integration/pug-var/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
doctype html
html
head
title Pug variables
body
- var image = './100x100.png'
img(src=image, alt='100x100')
Binary file added test/integration/pug/100x100.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
5 changes: 5 additions & 0 deletions test/integration/pug/icons.svg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
3 changes: 3 additions & 0 deletions test/integration/pug/index.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
body {
background: red;
}
1 change: 1 addition & 0 deletions test/integration/pug/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
alert('Hi');
16 changes: 16 additions & 0 deletions test/integration/pug/index.pug
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
doctype html
html
head
link(rel='stylesheet', href='index.css')
meta(property='og:image', content='100x100.png')
body
h1 Hello world
a(href='#hash_link') Hash link
a(href='mailto:someone@acme.com') Mailto link
a(href='tel:+33636757575') Tel link
script(src='index.js')
script(src='https://unpkg.com/parcel-bundler')
i hello
i world
svg
use(href='icons.svg#icon-repo-pull')
120 changes: 120 additions & 0 deletions test/pug.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
const assert = require('assert');
const fs = require('fs');
const {bundle, assertBundleTree} = require('./utils');

describe('pug', function() {
it('should support bundling HTML', async function() {
const b = await bundle(__dirname + '/integration/pug/index.pug');

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug'],
childBundles: [
{
type: 'png',
assets: ['100x100.png'],
childBundles: []
},
{
type: 'svg',
assets: ['icons.svg'],
childBundles: []
},
{
type: 'css',
assets: ['index.css'],
childBundles: []
},
{
type: 'js',
assets: ['index.js'],
childBundles: [
{
type: 'map'
}
]
}
]
});

const files = fs.readdirSync(__dirname + '/dist');
const html = fs.readFileSync(__dirname + '/dist/index.html');
for (const file of files) {
const ext = file.match(/\.([0-9a-z]+)(?:[?#]|$)/i)[0];
if (file !== 'index.html' && ext !== '.map') {
assert(html.includes(file));
}
}
});

it('should support include and extends files', async function() {
const b = await bundle(
__dirname + '/integration/pug-include-extends/index.pug'
);

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug']
});

const html = fs.readFileSync(__dirname + '/dist/index.html', 'utf-8');
const expect = fs.readFileSync(
__dirname + '/integration/pug-include-extends/expect.html',
'utf-8'
);

assert.equal(html, expect, 'Content mismatch');
});

it('should support variables', async function() {
const b = await bundle(__dirname + '/integration/pug-var/index.pug');

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug']
});

const html = fs.readFileSync(__dirname + '/dist/index.html', 'utf-8');

assert(/src="\/?100x100.*.png"/.test(html));
});

it('should support mixins', async function() {
const b = await bundle(__dirname + '/integration/pug-mixins/index.pug');

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug']
});

const html = fs.readFileSync(__dirname + '/dist/index.html', 'utf-8');
assert(html.includes('Greetings, Parcel'));
});

it('should support filters', async function() {
const b = await bundle(__dirname + '/integration/pug-filters/index.pug');

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug']
});

const html = fs.readFileSync(__dirname + '/dist/index.html', 'utf-8');
assert(html.includes('FILTERED: Hello!'));
});

it('should minify HTML in production mode', async function() {
const b = await bundle(__dirname + '/integration/pug-minify/index.pug', {
production: true
});

assertBundleTree(b, {
name: 'index.html',
assets: ['index.pug']
});

const html = fs.readFileSync(__dirname + '/dist/index.html', 'utf-8');

assert(html.includes('Minified'));
});
});
Loading

0 comments on commit 09a959d

Please sign in to comment.