Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
generator-addin
Advanced tools
Yeoman generator for MyGeotab/Geotab Drive add-ins
[!IMPORTANT] The add-in generator currently works with Yeoman version 5.0.0.
Leverage NPM
npm install -g yo@5.0.0
npm install -g generator-addin
mkdir <projdir>
cd <projdir>
yo addin
to scaffold your addinnpm install <package>
to install frontend dependenciesnpm run dev
or npm run serve
to preview and watch for changesnpm run build
to build your addin for production (Creates a Zip File with the production files for testing in MyG)For information on MyGeotab and Geotab Drive addins or the MyGeotab API head over to the MyGeotab SDK
The addin generator runs using Webpack, and makes heavy use of Webpack's ability to build out Dependency Graphs. When a build is run, Webpack takes the Dependency Graph and generates a single optimized JS, CSS, and HTML file.
For more comprehensive information about Webpack, head over to the Webpack Documentation
Webpack treats separate JavaScript files as Modules, which requires code intended to be used in main.js
to be exported first. Webpack's Module Support will handle browser compatibility for you.
Using Webpack allows us to leverage npm and it's associated libraries. For example, running npm install jquery
and placing import $ from 'jquery';
in main.js
will give you access to the jQuery library in your addin.
The entry point for the generator is .dev/index.js
for development builds and app/index.js
for production. Any files included in .dev/index.js
will not be bundled into the end product. The recommended approach is including dependencies in app/scripts/main.js
, as this will allow the files to be included in both production and development environments of Webpack.
Many old addins run directly out of main.js, and have several references to external scripts in the main HTML page. To make old addins run with webpack, you will need to move any reference to static assets from the *.html
file into main.js
:
// in app/scripts/main.js
require('../styles/main.css');
require('../styles/other.css');
// Importing a library downloaded with npm
import Vue from 'vue/dist/vue';
// Importing functions from another file
import { helper1, helper2, helper3 } from './helper.js';
Any files that are being imported need to be converted to es2015 modules.
To translate the addin on load, state.translate(...)
must be called in initialize()
and handed the addin's HTML root:
initialize: function (freshApi, freshState, initializeCallback) {
// Loading translations if available
if (freshState.translate) {
freshState.translate(elAddin || '');
}
// MUST call initializeCallback when done any setup
initializeCallback();
}
You can also translate sentences by directly passing them in using state.translate(...)
. This is useful for translating dynamically created content (IE. JavaScript):
focus: function(api, state){
document.querySelector('#app').textContent = state.translate('Translate this sentence');
}
Any text that requires translation needs to be added into a {language}.json
file, where {language}
is a supported abbreviation.
Do I have to make a reference to the build in my html file? No. Webpack handles this automatically
What version of node do I need? We support node 17.x and above. Node v22.12.0 recommended
I keep getting an error telling me regeneratorRuntime is not defined. What does this mean?
Webpack compiles with compatibility in mind, and will attempt to transpile async functions for compatibility with older IE browsers. There is currently a bug with Webpack causing transpilations to fail unless the regeneratorRuntime
is manually defined. Run npm i -D regenerator-runtime
and place const regeneratorRuntime = require('regenerator-runtime');
in the effected files
I keep getting an error message in the console telling me that my file was not found, but I can see it in my directory. Why?
This likely means that you have a reference to the file in your main HTML file. Remove this reference and instead import the file in main.js
.
Apache-2.0 © Geotab Inc
FAQs
MyGeotab/Geotab Drive add-in generator
The npm package generator-addin receives a total of 21 weekly downloads. As such, generator-addin popularity was classified as not popular.
We found that generator-addin demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.