Some examples of good practises, tips, and boilerplates that I like to follow. You will find the different technologies on the branches and we will add more examples in the future.
Feel free to give feedback and improvements to the repo.
master: Stable version of a basic SPA example with SCSS and ES6.
dev: Dev version of a basic SPA example with SCSS and ES6.
ts-master: Stable version of a TypeScript example with SCSS.
ts-dev: Dev version of a TypeScript example with SCSS.
vue-master: Stable version of a Vuejs example with SCSS and TypeScript.
vue-dev: Dev version of a Vuejs example with SCSS and TypeScript.
nuxt-master: Stable version of a Nuxt example with SCSS and TypeScript.
nuxt-dev: Dev version of a Nuxt example with SCSS and TypeScript.
node-ts-master: Stable version of a Nodejs with TypeScript example with SCSS and Nodejs.
node-ts-dev: Dev version of a Nodejs with TypeScript example with SCSS and Nodejs.
On this branch (Basic) we use:
- BEM + BEMIT + etc: A mix of BEM and related-BEM technologies to create conventions for CSS classes.
- TypeScript: All the code uses TypeScript.
- Linting: Linting for TypeScript and SASS.
- Normalize: Normalize our css, you can extend it easily.
- SASS: Scss structure with good practises.
On this branch (Basic) we use:
- Concurrently: Execute two tasks in parallel.
- Gulp Autoprefixer: Add browser prefixes for last two versions of the browsers.
- Gulp Clean CSS: To minify CSS.
- Gulp Connect: Preview website on local server.
- Gulp Environment: Call to different tasks depending of the environment.
- Gulp Fontmin: Generate fonts from .ttf.
- Gulp Imagemin: Compress images.
- Gulp Load plugins: Load all the plugins once.
- Gulp Newer: On some tasks we want to do something only with the newer files.
- Gulp Noop: Basic Noop but on stream.
- Gulp Sass: Compile Scss to CSS.
- Gulp Sasslint: Linting for SASS.
- Gulp Sourcemaps: Generate Sourcemaps when is necessary.
- Opn: Open browser to see the preview.
- Require all: Load all gulp tasks once.
- Webpack and Babel: To use Babel with Webpack (TypeScript -> ES5) and create a bundle.
- Webpack and Linting: To check TypeScript files.
To run the tasks we have these three commands:
- Install dependencies:
npm install
- Running tasks on production mode:
npm run prod
- Running tasks on development mode:
npm run dev
- Running tasks on local mode:
npm run local
- Running tasks on watch mode and serve the app:
npm start
On this project we have two environments:
- Local: Use this on your computer
- Development: Use this on your dev server
- Production: Use this on your production server
On this branch (Basic) the structure is:`
./
│
├── app/
│ ├── assets/
│ │ ├── fonts/
│ │ │ └── OpenSans
│ │ │ ├── OpenSans-Regular.ttf
│ │ │ ├── ...
│ │ │ └── OpenSans-SemiboldItalic.ttf
│ │ │
│ │ └── images/
│ │ └── example.jpg
│ │
│ ├── scripts/
│ │ └── app.ts
│ │ └── vendor.ts
│ │
│ └── styles/
│ ├── base/
│ │ ├── mixins # Some mixins to use on base folder
│ │ ├── _fonts.scss # Load the fonts for your project
│ │ ├── _globals.scss # Global styles
│ │ ├── _states.scss # States classes, like is-hidden, is-visible...
│ │ ├── _utilities.scss # Utility classes, like u-mt-10@xs _(margin-top 10px on media screen xs)_
│ │ └── _variables.scss # Global variables of the project
│ │
│ ├── components/
│ │ └── _ck-site.scss # Example of BEM based component
│ │
│ ├── vendor/
│ │ └── _normalize.scss # Import and extend Normalize
│ │
│ └── index.html
│
├── dist/ # Distribution folder
│
├── tasks/ # Gulp tasks
│ ├── config/
│ │ ├── helpers.js # Helpers that useful for tasks
│ │ └── options.js # Internal operation to use with tasks
│ ├── rules/
│ │ ├── scripts.js # Create a bundle for TypeScript files
│ │ └── scripts-lint.js # Check linting of TypeScript files
│ ├── assets.js # Minify images and generate fonts
│ ├── clean.js # Clean distribution folder
│ ├── copy.js # Copy index.html to dist
│ ├── serve.js # Open a browser with the preview of the project
│ ├── styles.js # Compile and compress SASS files when is necessary
│ ├── styles-lint.js # Linting for SASS
│ └── watch.js # Watcher for files
│
├── .gulpenvrc.yml # Environments configuration
├── .sass-lint.yml # SASS linting configuration
├── .scripts-lint.json # TypeScript linting configuration
├── gulpfile.js # Main gulp file
├── package.json # Configure npm tasks and dependencies
├── tasks.config.json # Configure paths and options for tasks
└── webpack.config.js # The Webpack configuration for scripts
This is how we configured the main file:
// We load all the tasks and pass some parameters
let tasks = require('require.all')('./tasks');
tasks((name, task) => { func = () => task(gulp, paths, $, _, tasks); func.displayName = name; return func});
// paths is for all the project paths
// $ is for plugins
// _ is for helpers
And these are the only two tasks:
gulp.task('default', gulp.series(tasks.clean, tasks.stylesLint, tasks.styles, tasks.copy, tasks.assets));
gulp.task('watcher', gulp.parallel(tasks.serve, tasks.watch));
In case that you want to modify some gulp tasks, this helpers can help you.
- Files and folders:
_.folder(paths.app.scripts);
Returns the path where the scripts are located, example: './app/js/'
_.files(paths.app.scripts)
Returns the file pattern to get the scripts, example: './app/js/**/*.js'
_.files(paths.app.scripts, _.NOT)
Exclude scripts, example: '!./app/js/**/*.js'
_.abs(_.folder(paths.app.scripts), __dirname)
Change path to absolute path: 'C:/project/app/js'
You can configure different things related with the tasks.
{
"app": {
"assets": {
"images": {}
}
}
};
You can acces to files and folders like:
_.folder(paths.assets.images);
// ./app/assets/images/
_.files(paths.assets.images)
// ./app/assets/images/**/*.*
But you can extend this structure:
{
"app": {
"assets": {
"images": {},
"fonts": {
"files": "**/*.ttf",
"folder": "custom"
}
}
}
};
You can acces to files and folders like:
_.folder(paths.assets.fonts);
// ./app/assets/custom/
_.files(paths.assets.fonts)
// ./app/assets/custom/**/*.ttf
Also you can use the parent folder
{
"app": {
"assets": {
"images": {},
"fonts": {
"files": "**/*.ttf",
"folder": "custom"
"roboto": {
"files": "Roboto.ttf",
"folder": "..",
}
}
}
}
};
And the result will look like that:
_.folder(paths.assets.fonts.roboto);
// ./app/assets/fonts/
_.files(paths.assets.fonts.roboto)
// ./app/assets/fonts/roboto.ttf
Quique Fdez Guerra 👨💻🌍🐦 |
Juan Carlos 👨💻🌍🐦 |
Alex Kryzhanovskyy 👨💻🌍🐦 |
---|
(The MIT License)
Copyright (c)
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the 'Software'), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.