danguilherme / ng-cli-pug-loader

:sparkles: Angular schematics to add .pug to your project
GNU General Public License v3.0
56 stars 17 forks source link

Some other configuration #2

Closed GeometryRamiroGarcia closed 6 years ago

GeometryRamiroGarcia commented 6 years ago

Hi @danguilherme :) .

Execute the command ng add ng-cli-pug-loader , and change the extension to the app.component.plug file, but when you runng serve, the file is not compiled.

app.component.pug

// The content below is only a placeholder and can be replaced.
div(style='text-align:center')
    h1
        | Welcome to {{ title }}!
    img(width='300', alt='Angular Logo', src='')
h2 Here are some links to help you start: 
ul
    li
        h2
            a(target='_blank', rel='noopener', href='https://angular.io/tutorial') Tour of Heroes
    li
        h2
            a(target='_blank', rel='noopener', href='https://github.com/angular/angular-cli/wiki') CLI Documentation
    li
        h2
            a(target='_blank', rel='noopener', href='https://blog.angular.io/') Angular blog

app.component.ts


import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.pug',
  styleUrls: ['./app.component.stylus']
})
export class AppComponent {
  title = 'app';
}

ng-add-pug-loader.js

/**
 * Adds the pug-loader inside Angular CLI's webpack config, if not there yet.
 * @see https://github.com/danguilherme/ng-cli-pug-loader
 */
const fs = require('fs');
const commonCliConfig = 'node_modules/@angular-devkit/build-angular/src/angular-cli-files/models/webpack-configs/common.js';
const pugRule = '{ test: /.pug$/, use: [ { loader: "apply-loader" }, { loader: "pug-loader" } ] },';

fs.readFile(commonCliConfig, (err, data) => {
  if (err) { throw err; }

  const configText = data.toString();
  // make sure we don't add the rule if it already exists
  if (configText.indexOf(pugRule) > -1) { return; }

  // Insert the pug webpack rule
  const position = configText.indexOf('rules: [') + 8;
  const output = [configText.slice(0, position), pugRule, configText.slice(position)].join('');
  const file = fs.openSync(commonCliConfig, 'r+');
  fs.writeFile(file, output);
  fs.close(file);
});

Project screen shot 2018-05-04 at 10 42 38 am

danguilherme commented 6 years ago

Hello;

Would you mind to show your package.json?

Maybe you're using an outdated version of this plugin (current one is 0.1.3).

Also, is there any error?

danguilherme commented 6 years ago

Closing due to inactivity.