-
-
Notifications
You must be signed in to change notification settings - Fork 839
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
Standalone chartjs build (don't include moment.js) #124
Comments
Hey @CalebKester to be honest, I am not completely sure 🤔 if this is possible. I don't think that treeshaking will work. Because it only works on es modules. And neither Chart.js nor moment.js are available as es modules. AFAIK. Thats a reason, why I have extra es modules output in The problem is, that I am simply importing chart.js over So I guess, if you're using |
I Have the same problem Here. I load chartJs like that :
But, in compilation, I have momentJS in the bundle :/ |
That is because if you import I would love to change that, however it would be confusing to break with the standard behaviour of the chart.js npm package. So the solution needs to be on user side right now. 💍 SolutionYou need to add an alias to your webpack config, so it will grab the standalone version webpack.config.js resolve: {
alias: {
'chart.js': 'chart.js/dist/Chart.js'
}
} This way it will grab the standalone version. |
Thanks. It works |
Sorry, I might be doing something wrong but I can't get this to work: configureWebpack: {
resolve: {
alias: {
'chart.js': 'chart.js/dist/Chart.js'
}
}
} With that moment.js still ends up in my chunk-files. Any idea? I'm importing the line chart like this: import { Line } from 'vue-chartjs'
|
I think this is not possible anymore. Not as far as I understand it is bundled in both version. |
Oh damn, really? So I'm stuck with having moment.js in my project even though I never use it. It's literally the largest chunk in my whole project. Thanks for your answer though! Update: vue.config.js configureWebpack: {
externals: {
moment: 'moment'
}
} I don't know if it has any other impacts besides moment.js is gone and my full project shrunk by about 250kb. |
Seems it works fine. No issues for now. |
I think it will work as long as you do not use any chart.js features that rely on momentjs. |
Yes of course. But that would‘ve been the same with only using the standalone in earlier version, no? |
Hi! First of all, I would like to thank you for vue-charts, it's really great! The standalone build does not include moment (except if you use webpack) as mentioned here since 2.8.0, it was implemented in the PR chartjs/Chart.js#5978 . This is also to allow us to choose an other date library, now there is adapters, as implemented in chartjs/Chart.js#5960 . There are two adapters at this time, one for luxon and another for date-nfs. It would be really nice to add a way to I'm planning to switch to date-fns as soon as I can to reduce the size of my builds by using Date-nfs because it can benefits from treeshaking and is lighter than moment. |
Strange, building my project with the standalone (general npm package) adds moment to it. Maybe I need to change my chartjs npm installation. |
In fact, it is included by default if you use webpack so you are right, you need to manually remove it as stated here. |
Yes exactly, that‘s what I did and commented here: #124 (comment) |
I use rollup. After excluding moment.js with
because there was This plugin helped me: https://github.com/proteriax/rollup-plugin-ignore My rollup.config.js:
|
@SergeiMinaev thanks, it helped me with some additions! Why should it be placed before others? really wasn't working until I placed it on the top. I'm using vite. When I tried to exclude moment.js with
This worked: import ignore from 'rollup-plugin-ignore';
export default () => defineConfig({
plugins: [
ignore(['moment', 'moment?commonjs-require']), // need to add also moment?commonjs-require, otherwise doesn't work, couldn't find out why 🤷♂️
],
}); I submitted PR alex-kinokon/rollup-plugin-ignore#5 to rollup-plugin-ignore, check it's status, maybe it won't be needed to add |
Expected Behavior
Moment.js shouldn't be included
Actual Behavior
Moment.js appears on my package.lock file and gets bundled in my build
Environment
Can you help me figure out how I configure this correctly so that I only get the standalone chart.js build: https://github.com/chartjs/Chart.js/blob/3e94b9431a5b3d6e4bfbfd6a2339a350999b3292/docs/getting-started/installation.md . Moment.js is a very heavy package and if I can avoid including it in my site I'll gladly do that. The documentation makes it sound like treeshaking can do this but I'm just using the vue webpack cli and it's still coming through.
Thanks
The text was updated successfully, but these errors were encountered: