hi there,
in the metronic symfony starterkit there are 2 package.json files.
one inside the _keenthemes/tools folder:
{
"name": "keenthemes",
"version": "1.0.0",
"author": "Keenthemes",
"license": "ISC",
"homepage": "https://keenthemes.com/",
"description": "Packages used by yarn, npm, gulp and webpack",
"main": "gulpfile.js",
"type": "module",
"dependencies": {
"@ckeditor/ckeditor5-alignment": "^38.1.0",
"@ckeditor/ckeditor5-build-balloon": "^38.1.0",
"@ckeditor/ckeditor5-build-balloon-block": "^38.1.0",
"@ckeditor/ckeditor5-build-classic": "^38.1.0",
"@ckeditor/ckeditor5-build-decoupled-document": "^38.1.0",
"@ckeditor/ckeditor5-build-inline": "^38.1.0",
... and so on...
{
"dependencies": {
"@ckeditor/ckeditor5-alignment": "^35.2.1",
"@ckeditor/ckeditor5-build-balloon": "^35.2.1",
"@ckeditor/ckeditor5-build-balloon-block": "^35.2.1",
"@ckeditor/ckeditor5-build-classic": "^35.2.1",
"@ckeditor/ckeditor5-build-decoupled-document": "^35.2.1",
"@ckeditor/ckeditor5-build-inline": "^35.2.1",
... and so on ...
You're welcome! If you have any more questions or need further assistance, feel free to ask.
thanks for answering!
Hi Gerd,
Certainly, here are two approaches you can consider for managing dependencies in your Laravel project with Metronic:
1) Importing Plugins Directly in Custom JS:
In your custom JavaScript code, you can import the plugins directly from _keenthemes/tools/node_modules instead of the root node_modules. This way, you'll have only one reference to the plugin, avoiding potential conflicts with different versions.
2) Merging and Symlinking Node Modules:
Another approach is to merge the dependencies from _keenthemes/tools/package.json into your project's root package.json. This allows you to manage all your project's dependencies from one location.
After merging, you can install the node modules in your root directory.
To ensure that Metronic's Gulp build tool works, you can create a symbolic link (symlink) from the root node_modules folder into _keenthemes/tools/node_modules. This way, Metronic's assets can be built from _keenthemes/tools while still using the root node_modules for dependencies.
Both of these approaches aim to streamline your dependency management and minimize potential conflicts between versions. Choose the one that best fits your project's needs and structure.
Here are instructions for creating a symbolic link (symlink) using commands in both Windows and macOS:
On Windows:
Open Command Prompt as Administrator and run this command:
mklink /d "_keenthemes\tools\node_modules" "your\project\node_modules"
ln -s /path/to/your/project/node_modules /path/to/_keenthemes/tools/node_modules
thanks for clarifying!
so the dependencies from "_keenthemes/tools/package.json" get bundled into "public/assets/plugins/global/plugins.bundle.js", is that correct?
what happens if i add a javascript dependency to the projects "<projectdir>/package.json" file (which will be bundled into "build/app.js"),
but that dependency is already included in "_keenthemes/tools/package.json", possibly even in a different version?
will this create some kind of conflict when both "app.js" and "plugins.bundle.js" are loaded in the frontend?
how would i reference my version of the dependency from javascript code?
is this something i have to be aware of and just avoid this situation?
or is there a recommended way of dealing with this?
or maybe this is no problem at all?
thanks,
best regards
Thank you for reaching out with your questions regarding the two package.json files in the Metronic Symfony Starterkit. We apologize for any confusion and inconvenience caused.
The two package.json files serve different purposes:
The package.json file inside the _keenthemes/tools folder is specifically for Keenthemes assets. It contains dependencies and scripts necessary to manage and build Keenthemes assets, such as styles, scripts, and other resources. This file is used to bundle all theme dependencies and put everything in the public/assets folder within your Symfony project. Its primary purpose is to handle Keenthemes-specific assets.
The package.json file in the root directory of your Symfony project is related to the Symfony assets component. However, by design, it should contain empty dependencies. We will this update this by removing the dependencies as it cause confusions.
In summary, the package.json file inside _keenthemes/tools is for Keenthemes assets, while the one in the root of the Symfony folder is meant for Symfony assets.
If you integrate the Metronic into an existing project, you can focus on the _keenthemes/tools/package.json for theme-related assets.
We hope this clarifies the purpose of the two package.json files. If you have any more questions or need further assistance, please feel free to ask.
Thanks