Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Error working with Html-webpack-plugin #43

Closed
unnieayilliath opened this issue May 9, 2019 · 5 comments
Closed

Error working with Html-webpack-plugin #43

unnieayilliath opened this issue May 9, 2019 · 5 comments
Labels

Comments

@unnieayilliath
Copy link

I am using handlebars-layouts with webpack and I use Html-webpack-plugin to generate html file. But if i use extends, webpack throws below error:

ERROR in Template execution failed: Error: Missing helper: "extend"

I am using handlebars-loader with webpack and below is my webpack config.

module: {
       rules: [{
           test: /\.tsx?$/,
           use: 'ts-loader',
           exclude: /node_modules/
       },
       {
           test: /\.hbs$/,
           use: [{
               loader:'handlebars-loader',
               options:{
                   partialDirs: path.resolve(__dirname, "./app/partials"),
                   helperDirs: path.resolve(__dirname, "./node_modules/handlebars-layouts"),
               }
           }]
       }]
   },
.
.
.
.

 new HtmlWebpackPlugin({ 
           filename: 'add.form.html', // name of the output file
           chunks: ['add'], // name of the entry point defined above
           template: './app/add/add.form.hbs' // path to the html for the webpart
       }),

@builditzach
Copy link

I found this response helpful: pcardune/handlebars-loader#110 (comment)

@builditzach
Copy link

Just a quick follow-up, it doesn't look like this will ever work with handlebars-loader. handlebars-loader does not add partials to the global Handlebars instance, which this library is looking for. If you manually load the partials into the Handlebars instance, you could potentially get this working.

@shannonmoeller
Copy link
Owner

You are correct that handlebars-layouts expects the partials to be registered globally. I'm not familiar with the webpack loader, so I'm not sure if it's possible. Seems like it might be with the runtime option.

https://gist.github.com/impankratov/18e862e9a54d2ce092138e1a7a052c12#file-webpack-config-js

Closing this as it's more of an issue with the webpack loader than this library.

@SalttySugar
Copy link

SalttySugar commented Jul 16, 2020

well, I'm trying to get it to work right now but I think there is no hope for me here.
maybe someone in the future will get here or someone can give me good advice.
handlebars-layouts extension not going to work with handlebars-loader. You have to build your own loader and precompile all this buy yourself to make it work.

The reason is why you can't make it work is just because of handlebars-loader doesn't use partials from runtime you pass to the loader. Maybe I'm wrong but I couldn't find any resource about manual registration of partials from handlebars instance for handlebars-loader. When I pass handlebars instance with already registered partials for some reason handlebars-loader can't find them. Don't be me and don't spend slipless nights on it.

@shannonmoeller
Copy link
Owner

Since loading partials is beyond the scope of this package, this seems like an issue to be solved in handlebars-loader. Sorry it's not working for you. Might want to create an issue in their repo.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants