/* * Copyright (c) 2017 Jeremy Thomerson * Licensed under the MIT license. */ 'use strict'; var path = require('path'), getCodeVersion = require('silvermine-serverless-utils/src/get-code-version'), markdownlint = require('markdownlint'); const sass = require('node-sass'); module.exports = function(grunt) { var DEBUG = !!grunt.option('debug'), config; config = { js: { all: [ 'Gruntfile.js', 'src/**/*.js', 'tests/**/*.js' ], standalone: path.join(__dirname, 'src', 'js', 'standalone.js'), }, sass: { base: path.join(__dirname, 'src', 'sass'), all: [ 'src/**/*.scss' ], }, dist: { base: path.join(__dirname, 'dist'), jsFileName: 'silvermine-videojs-quality-selector', }, }; config.dist.js = { bundle: path.join(config.dist.base, 'js', '<%= config.dist.jsFileName %>.js'), minified: path.join(config.dist.base, 'js', '<%= config.dist.jsFileName %>.min.js'), }; config.dist.css = { base: path.join(config.dist.base, 'css'), all: path.join(config.dist.base, '**', '*.css'), }; grunt.initConfig({ pkg: grunt.file.readJSON('package.json'), versionInfo: getCodeVersion.both(), config: config, browserify: { main: { src: config.js.standalone, dest: config.dist.js.bundle, }, }, uglify: { main: { files: { '<%= config.dist.js.minified %>': config.dist.js.bundle, }, options: { banner: '/*! <%= pkg.name %> <%= grunt.template.today("yyyy-mm-dd") %> <%= versionInfo %> */\n', sourceMap: true, sourceMapIncludeSources: true, mangle: true, compress: true, beautify: false, }, }, }, sass: { options: { implementation: sass, sourceMap: DEBUG, indentWidth: 3, outputStyle: DEBUG ? 'expanded' : 'compressed', sourceComments: DEBUG, }, main: { files: [ { expand: true, cwd: config.sass.base, src: [ '**/*.scss' ], dest: config.dist.css.base, ext: '.css', extDot: 'first', }, ], }, }, postcss: { options: { map: DEBUG, processors: [ require('autoprefixer')({ browsers: '> .05%' }), // eslint-disable-line global-require ], }, main: { src: config.dist.css.all, }, }, clean: { dist: config.dist.base, }, eslint: { target: config.js.all, }, stylelint: { options: { configFile: path.join(__dirname, 'node_modules', '@silvermine', 'standardization', '.stylelintrc.yml'), }, src: config.sass.all, }, watch: { grunt: { files: [ 'Gruntfile.js' ], tasks: [ 'build' ], }, js: { files: [ 'src/**/*.js' ], tasks: [ 'build-js' ], }, css: { files: [ 'src/**/*.scss' ], tasks: [ 'build-css' ], }, }, markdownlint: { all: { // Adjust `src` depending on how many files need to be linted: src: [ 'README.md' ], options: { // eslint-disable-next-line no-sync config: markdownlint.readConfigSync('.markdownlint.json'), }, }, }, }); grunt.loadNpmTasks('grunt-contrib-uglify'); grunt.loadNpmTasks('grunt-contrib-watch'); grunt.loadNpmTasks('grunt-browserify'); grunt.loadNpmTasks('grunt-eslint'); grunt.loadNpmTasks('grunt-postcss'); grunt.loadNpmTasks('grunt-contrib-clean'); grunt.loadNpmTasks('grunt-sass'); grunt.loadNpmTasks('grunt-stylelint'); grunt.loadNpmTasks('grunt-markdownlint'); grunt.registerTask('standards', [ 'eslint', 'stylelint', 'markdownlint' ]); grunt.registerTask('build-js', [ 'browserify', 'uglify' ]); grunt.registerTask('build-css', [ 'sass', 'postcss' ]); grunt.registerTask('build', [ 'build-js', 'build-css' ]); grunt.registerTask('develop', [ 'build', 'watch' ]); grunt.registerTask('default', [ 'standards' ]); };