Scripts are broken down into categories:
Category | Purpose |
---|---|
Vendors | 3rd Party includes, like modernizr, etc |
Plugins | 3rd Party plugins, like Formstone, etc |
Modules | Custom modules created by Fastspot |
Mixins | Plugin-n-Play bits of code that extract out common functionality. Events, etc |
Helpers | Functions / configurations that assist overall development |
Webpack allows us to have some unique features:
We have set up thev following configuration:
resolve: {
// ..
modules: ['node_modules'];
}
This means when using the import
syntax, webpack
will check in node_modules
first for absolute imports, then locally.
// will check node_modules/formstone first
import 'formstone/src/js/core';
resolve: {
// ..
alias: {
'@': `${srcPath}/js`,
'@base': basePath
}
}
Aliases help with keep module resolutions relative to a specific directory. This avoid having to use relative pathing everywhere based on the file’s location.
/**
* The `@` symbol will resolve to `src/js`
* no matter where you are in the file tree.
*/
import { accordion } from '@/modules/accordion';
Externals allow webpack to ignore specific imports if they are included elsewhere, like a <script>
tag.
Why do this? Imports tell a story of a file’s dependencies, so right away you know a file is depending on jQuery
.
externals: {
jquery: 'jQuery';
}
/**
* this will not produce an error even though `jquery`
* is not in our node_modules folder
*/
import $ from 'jquery';
// file-a.js
export const config = {
hello: 'world',
};
export const helper = function () {
//
};
// OR
const config = {
hello: 'world',
};
const helper = function () {
//
};
export { config, helper };
// file-b.js
// single
import { config } from 'file-a';
// multiple
import { config, helper } from 'file-a';
// all; allExports.config, allExports.helper, etc
import * as allExports from 'file-a';
// file-a.js
export default function helper() {
//
}
// OR
const helper = function () {
//
};
export default helper;
// file-b.js
// you decide what the default export is assigned to
import helper from 'file-a';
// you can name it anything
import blah from 'file-a';
// if the file has named and default exports
import blah, { someNamedExport } from 'file-a';
src/js/modules/sample-module.js
and add it to the same folderNAMESPACE
- this is the key for getting configurating from data attributes.DEFAULT_SELECTOR
DEFAULT_SETTINGS
class name
(currently SampleModule
)class name
in the factory
function (new SampleModule()
)If you would like your module to automatically be instantiated:
src/js/modules/index.js
import sampleModule from '@/modules/sample-module';
sampleModule('.js-sample-module', {
someSetting: 'value',
});