Last active
          April 29, 2018 17:34 
        
      - 
      
- 
        Save maddindeiss/957607ee673e09870ce0106d134dfc69 to your computer and use it in GitHub Desktop. 
    Pug / Jade support for Angular-CLI
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | const fs = require('fs'); | |
| const commonCliConfig = 'node_modules/@angular/cli/models/webpack-configs/common.js'; | |
| const pug_rule = `\n{ | |
| test: /\\.(pug|jade)$/, | |
| use: [ | |
| 'apply-loader', | |
| { | |
| loader: 'pug-loader', | |
| options: { | |
| pretty: true, | |
| doctype: 'html', | |
| plugins: ["pug-plugin-ng"] | |
| } | |
| } | |
| ] | |
| },`; | |
| fs.readFile(commonCliConfig, (err, data) => { | |
| if (err) { throw err; } | |
| const configText = data.toString(); | |
| if (configText.indexOf(pug_rule) > -1) { | |
| console.log('Pug webpack rule already inserted.'); | |
| return; | |
| } | |
| console.log('Inserting pug webpack rule...'); | |
| const position = configText.indexOf('rules: [') + 8; | |
| const output = [configText.slice(0, position), pug_rule, configText.slice(position)].join(''); | |
| const file = fs.openSync(commonCliConfig, 'r+'); | |
| fs.writeFile(file, output, (err) => { | |
| console.log('Pug webpack rule inserted.'); | |
| if(err) { | |
| console.error('Error when inserting pug webpack rule.'); | |
| } | |
| }); | |
| fs.close(file, (err) => { | |
| if(err) { | |
| console.error('Error when inserting pug webpack rule.'); | |
| } | |
| }); | |
| }); | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
Pug / Jade support for the Angular-CLI
This script inserts the webpack rule for pug templates in the angular-cli webpack config.
Works with
ng serve(+live reloads) and AoT prod builds.Requirements
Usage:
Run it with
or create a postinstall hook in your
package.jsonfor new installs: